diff --git a/css/NotificationsApp-CZ4IK7S-.chunk.css b/css/NotificationsApp-CpJY74x6.chunk.css similarity index 97% rename from css/NotificationsApp-CZ4IK7S-.chunk.css rename to css/NotificationsApp-CpJY74x6.chunk.css index f4f3dfe36..8d58d5af3 100644 --- a/css/NotificationsApp-CZ4IK7S-.chunk.css +++ b/css/NotificationsApp-CpJY74x6.chunk.css @@ -1,4 +1,4 @@ @charset "UTF-8";.material-design-icon[data-v-697cfd8f]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.empty-content[data-v-697cfd8f]{display:flex;align-items:center;flex-direction:column;justify-content:center;flex-grow:1;padding:var(--default-grid-baseline)}.modal-wrapper .empty-content[data-v-697cfd8f]{margin-top:5vh;margin-bottom:5vh}.empty-content__icon[data-v-697cfd8f]{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto 15px;opacity:.4;background-repeat:no-repeat;background-position:center;background-size:64px}.empty-content__icon[data-v-697cfd8f] svg{width:64px!important;height:64px!important;max-width:64px!important;max-height:64px!important}.empty-content__name[data-v-697cfd8f]{margin-bottom:10px;text-align:center;font-weight:700;font-size:20px;line-height:30px}.empty-content__description[data-v-697cfd8f]{color:var(--color-text-maxcontrast);text-align:center;text-wrap-style:balance}.empty-content__action[data-v-697cfd8f]{margin-top:8px}.modal-wrapper .empty-content__action[data-v-697cfd8f]{margin-top:20px;display:flex}.material-design-icon[data-v-d45c5788]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}/*! * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors * SPDX-License-Identifier: AGPL-3.0-or-later - */.header-menu[data-v-d45c5788]{position:relative;width:var(--header-height);height:var(--header-height)}.header-menu .header-menu__trigger[data-v-d45c5788]{--button-size: var(--header-height) !important;height:var(--header-height);opacity:.85;filter:none!important;color:var(--color-background-plain-text, var(--color-primary-text))!important}.header-menu .header-menu__trigger[data-v-d45c5788]:focus-visible{outline:none!important;box-shadow:none!important}.header-menu .header-menu__trigger[data-v-d45c5788] .button-vue__icon svg,.header-menu .header-menu__trigger[data-v-d45c5788] .button-vue__icon:not(:has(svg)){mask:var(--header-menu-icon-mask, none)}.header-menu--opened .header-menu__trigger[data-v-d45c5788],.header-menu__trigger[data-v-d45c5788]:hover,.header-menu__trigger[data-v-d45c5788]:focus,.header-menu__trigger[data-v-d45c5788]:active{opacity:1}@media only screen and (max-width: 512px){.header-menu[data-v-d45c5788]{width:var(--default-clickable-area)}.header-menu .header-menu__trigger[data-v-d45c5788]{--button-size: var(--default-clickable-area) !important}}.header-menu__wrapper[data-v-d45c5788]{position:fixed;z-index:2000;top:var(--header-height);inset-inline-end:0;box-sizing:border-box;margin:0 8px;border-radius:var(--border-radius-element);background-color:var(--color-main-background);filter:drop-shadow(0 1px 5px var(--color-box-shadow))}.header-menu__caret[data-v-d45c5788]{position:absolute;z-index:2001;bottom:0;inset-inline-start:calc(50% - 10px);width:0;height:0;content:" ";pointer-events:none;border:10px solid transparent;border-bottom-color:var(--color-main-background)}.header-menu__content[data-v-d45c5788]{overflow:auto;width:350px;max-width:calc(100vw - 16px);min-height:calc(var(--default-clickable-area) * 1.5);max-height:calc(100vh - var(--header-height) * 2)}.header-menu__content[data-v-d45c5788] .empty-content{margin:12vh 10px}.material-design-icon[data-v-ddd65c9e]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.widgets--list[data-v-ddd65c9e]{width:100%;min-height:var(--default-clickable-area)}.material-design-icon[data-v-bfd4d4b7]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.rich-text--wrapper[data-v-bfd4d4b7]{overflow-wrap:break-word;line-height:1.5}.rich-text--wrapper .rich-text--fallback[data-v-bfd4d4b7],.rich-text--wrapper .rich-text-component[data-v-bfd4d4b7]{display:inline}.rich-text--wrapper .rich-text--external-link[data-v-bfd4d4b7]{text-decoration:underline}.rich-text--wrapper .rich-text--external-link[data-v-bfd4d4b7]:after{content:" ↗"}.rich-text--wrapper-markdown[data-v-bfd4d4b7]{tab-size:4}.rich-text--wrapper-markdown[data-v-bfd4d4b7]>:first-child,.rich-text--wrapper-markdown div[data-v-bfd4d4b7]>:first-child,.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7]>:first-child{margin-top:0!important}.rich-text--wrapper-markdown[data-v-bfd4d4b7]>:last-child,.rich-text--wrapper-markdown[data-v-bfd4d4b7]>*:has(+.rich-text--reference-widget),.rich-text--wrapper-markdown div[data-v-bfd4d4b7]>:last-child,.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7]>:last-child{margin-block-end:0!important}.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7]{padding-inline-start:13px;border-inline-start:2px solid var(--color-border-dark);color:var(--color-text-maxcontrast)}.rich-text--wrapper-markdown h1[data-v-bfd4d4b7],.rich-text--wrapper-markdown h2[data-v-bfd4d4b7],.rich-text--wrapper-markdown h3[data-v-bfd4d4b7],.rich-text--wrapper-markdown h4[data-v-bfd4d4b7],.rich-text--wrapper-markdown h5[data-v-bfd4d4b7],.rich-text--wrapper-markdown h6[data-v-bfd4d4b7],.rich-text--wrapper-markdown p[data-v-bfd4d4b7],.rich-text--wrapper-markdown ul[data-v-bfd4d4b7],.rich-text--wrapper-markdown ol[data-v-bfd4d4b7],.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7],.rich-text--wrapper-markdown pre[data-v-bfd4d4b7]{margin-top:0;margin-block-end:1em}.rich-text--wrapper-markdown h1[data-v-bfd4d4b7],.rich-text--wrapper-markdown h2[data-v-bfd4d4b7],.rich-text--wrapper-markdown h3[data-v-bfd4d4b7],.rich-text--wrapper-markdown h4[data-v-bfd4d4b7],.rich-text--wrapper-markdown h5[data-v-bfd4d4b7],.rich-text--wrapper-markdown h6[data-v-bfd4d4b7]{font-weight:700}.rich-text--wrapper-markdown h1[data-v-bfd4d4b7]{font-size:30px}.rich-text--wrapper-markdown ul[data-v-bfd4d4b7],.rich-text--wrapper-markdown ol[data-v-bfd4d4b7]{padding-inline-start:4ch}.rich-text--wrapper-markdown ul[data-v-bfd4d4b7]{list-style-type:disc}.rich-text--wrapper-markdown ul.contains-task-list[data-v-bfd4d4b7]{list-style-type:none;padding:0}.rich-text--wrapper-markdown li.task-list-item>ul[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>ol[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>li[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>blockquote[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>pre[data-v-bfd4d4b7]{margin-inline-start:15px;margin-block-end:0}.rich-text--wrapper-markdown pre[data-v-bfd4d4b7]{direction:ltr}.rich-text--wrapper-markdown table[data-v-bfd4d4b7]{border-collapse:collapse;border:2px solid var(--color-border-maxcontrast)}.rich-text--wrapper-markdown table th[data-v-bfd4d4b7],.rich-text--wrapper-markdown table td[data-v-bfd4d4b7]{padding:var(--default-grid-baseline);border:1px solid var(--color-border-maxcontrast)}.rich-text--wrapper-markdown table th[data-v-bfd4d4b7]:first-child,.rich-text--wrapper-markdown table td[data-v-bfd4d4b7]:first-child{border-inline-start:0}.rich-text--wrapper-markdown table th[data-v-bfd4d4b7]:last-child,.rich-text--wrapper-markdown table td[data-v-bfd4d4b7]:last-child{border-inline-end:0}.rich-text--wrapper-markdown table tr:first-child th[data-v-bfd4d4b7]{border-top:0}.rich-text--wrapper-markdown table tr:last-child td[data-v-bfd4d4b7]{border-block-end:0}.rich-text--wrapper-markdown pre[data-v-bfd4d4b7]:has(.hljs){color:var(--hljs-color);background:var(--hljs-background-color)}.rich-text--wrapper-markdown .hljs-doctag[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-keyword[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-meta .hljs-keyword[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-template-tag[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-template-variable[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-type[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-variable.language_[data-v-bfd4d4b7]{color:var(--hljs-syntax-keyword-color)}.rich-text--wrapper-markdown .hljs-title[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-title.class_[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-title.class_.inherited__[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-title.function_[data-v-bfd4d4b7]{color:var(--hljs-syntax-entity-color)}.rich-text--wrapper-markdown .hljs-attr[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-attribute[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-literal[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-meta[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-number[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-operator[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-variable[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-attr[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-class[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-id[data-v-bfd4d4b7]{color:var(--hljs-syntax-constant-color)}.rich-text--wrapper-markdown .hljs-regexp[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-string[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-meta .hljs-string[data-v-bfd4d4b7]{color:var(--hljs-syntax-string-color)}.rich-text--wrapper-markdown .hljs-built_in[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-symbol[data-v-bfd4d4b7]{color:var(--hljs-syntax-variable-color)}.rich-text--wrapper-markdown .hljs-comment[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-code[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-formula[data-v-bfd4d4b7]{color:var(--hljs-syntax-comment-color)}.rich-text--wrapper-markdown .hljs-name[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-quote[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-tag[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-pseudo[data-v-bfd4d4b7]{color:var(--hljs-syntax-entity-tag-color)}.rich-text--wrapper-markdown .hljs-subst[data-v-bfd4d4b7]{color:var(--hljs-syntax-storage-modifier-import-color)}.rich-text--wrapper-markdown .hljs-section[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-heading-color);font-weight:700}.rich-text--wrapper-markdown .hljs-bullet[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-list-color)}.rich-text--wrapper-markdown .hljs-emphasis[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-italic-color);font-style:italic}.rich-text--wrapper-markdown .hljs-strong[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-bold-color);font-weight:700}.rich-text--wrapper-markdown .hljs-addition[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-inserted-color);background-color:var(--hljs-syntax-markup-inserted-background-color)}.rich-text--wrapper-markdown .hljs-deletion[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-deleted-color);background-color:var(--hljs-syntax-markup-deleted-background-color)}a[data-v-bfd4d4b7]:not(.rich-text--component){text-decoration:underline}@media (prefers-color-scheme: light){.rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #24292e);--hljs-background-color: var(--color-background-dark, #ffffff);--hljs-syntax-keyword-color: #d73a49;--hljs-syntax-entity-color: #6f42c1;--hljs-syntax-constant-color: #005cc5;--hljs-syntax-string-color: #032f62;--hljs-syntax-variable-color: #e36209;--hljs-syntax-comment-color: #6a737d;--hljs-syntax-entity-tag-color: #22863a;--hljs-syntax-storage-modifier-import-color: #24292e;--hljs-syntax-markup-heading-color: #005cc5;--hljs-syntax-markup-list-color: #735c0f;--hljs-syntax-markup-italic-color: #24292e;--hljs-syntax-markup-bold-color: #24292e;--hljs-syntax-markup-inserted-color: #22863a;--hljs-syntax-markup-inserted-background-color: #f0fff4;--hljs-syntax-markup-deleted-color: #b31d28;--hljs-syntax-markup-deleted-background-color: #ffeef0}[data-theme-dark] .rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #c9d1d9);--hljs-background-color: var(--color-background-dark, #0d1117);--hljs-syntax-keyword-color: #ff7b72;--hljs-syntax-entity-color: #d2a8ff;--hljs-syntax-constant-color: #79c0ff;--hljs-syntax-string-color: #a5d6ff;--hljs-syntax-variable-color: #ffa657;--hljs-syntax-comment-color: #8b949e;--hljs-syntax-entity-tag-color: #7ee787;--hljs-syntax-storage-modifier-import-color: #c9d1d9;--hljs-syntax-markup-heading-color: #1f6feb;--hljs-syntax-markup-list-color: #f2cc60;--hljs-syntax-markup-italic-color: #c9d1d9;--hljs-syntax-markup-bold-color: #c9d1d9;--hljs-syntax-markup-inserted-color: #aff5b4;--hljs-syntax-markup-inserted-background-color: #033a16;--hljs-syntax-markup-deleted-color: #ffdcd7;--hljs-syntax-markup-deleted-background-color: #67060c}}@media (prefers-color-scheme: dark){.rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #c9d1d9);--hljs-background-color: var(--color-background-dark, #0d1117);--hljs-syntax-keyword-color: #ff7b72;--hljs-syntax-entity-color: #d2a8ff;--hljs-syntax-constant-color: #79c0ff;--hljs-syntax-string-color: #a5d6ff;--hljs-syntax-variable-color: #ffa657;--hljs-syntax-comment-color: #8b949e;--hljs-syntax-entity-tag-color: #7ee787;--hljs-syntax-storage-modifier-import-color: #c9d1d9;--hljs-syntax-markup-heading-color: #1f6feb;--hljs-syntax-markup-list-color: #f2cc60;--hljs-syntax-markup-italic-color: #c9d1d9;--hljs-syntax-markup-bold-color: #c9d1d9;--hljs-syntax-markup-inserted-color: #aff5b4;--hljs-syntax-markup-inserted-background-color: #033a16;--hljs-syntax-markup-deleted-color: #ffdcd7;--hljs-syntax-markup-deleted-background-color: #67060c}[data-theme-light] .rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #24292e);--hljs-background-color: var(--color-background-dark, #ffffff);--hljs-syntax-keyword-color: #d73a49;--hljs-syntax-entity-color: #6f42c1;--hljs-syntax-constant-color: #005cc5;--hljs-syntax-string-color: #032f62;--hljs-syntax-variable-color: #e36209;--hljs-syntax-comment-color: #6a737d;--hljs-syntax-entity-tag-color: #22863a;--hljs-syntax-storage-modifier-import-color: #24292e;--hljs-syntax-markup-heading-color: #005cc5;--hljs-syntax-markup-list-color: #735c0f;--hljs-syntax-markup-italic-color: #24292e;--hljs-syntax-markup-bold-color: #24292e;--hljs-syntax-markup-inserted-color: #22863a;--hljs-syntax-markup-inserted-background-color: #f0fff4;--hljs-syntax-markup-deleted-color: #b31d28;--hljs-syntax-markup-deleted-background-color: #ffeef0}}.material-design-icon[data-v-e408867a],.material-design-icon[data-v-90c6aa3b]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.provider-list[data-v-90c6aa3b]{width:100%;min-height:400px;padding:0 16px 16px;display:flex;flex-direction:column}.provider-list--select[data-v-90c6aa3b]{width:100%}.provider-list--select .provider[data-v-90c6aa3b]{display:flex;align-items:center;height:28px;overflow:hidden}.provider-list--select .provider .link-icon[data-v-90c6aa3b]{margin-inline-end:8px}.provider-list--select .provider .provider-icon[data-v-90c6aa3b]{width:20px;height:20px;object-fit:contain;margin-inline-end:8px;filter:var(--background-invert-if-dark)}.provider-list--select .provider .option-text[data-v-90c6aa3b]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-design-icon[data-v-17076b70]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.widget-custom[data-v-17076b70]{width:100%;margin:auto;margin-bottom:calc(var(--default-grid-baseline, 4px) * 3);margin-top:calc(var(--default-grid-baseline, 4px) * 3);overflow:hidden;border:2px solid var(--color-border);border-radius:var(--border-radius-container);background-color:transparent;display:flex}.widget-custom.full-width[data-v-17076b70]{width:var(--widget-full-width, 100%)!important;inset-inline-start:calc((var(--widget-full-width, 100%) - 100%) / 2 * -1);position:relative}.widget-access[data-v-17076b70]{width:100%;margin:auto;margin-bottom:calc(var(--default-grid-baseline, 4px) * 3);margin-top:calc(var(--default-grid-baseline, 4px) * 3);overflow:hidden;border:2px solid var(--color-border);border-radius:var(--border-radius-container);background-color:transparent;display:flex;padding:calc(var(--default-grid-baseline, 4px) * 3)}.widget-default[data-v-17076b70]{width:100%;margin:auto;margin-bottom:calc(var(--default-grid-baseline, 4px) * 3);margin-top:calc(var(--default-grid-baseline, 4px) * 3);overflow:hidden;border:2px solid var(--color-border);border-radius:var(--border-radius-container);background-color:transparent;display:flex}.widget-default--compact[data-v-17076b70]{flex-direction:column}.widget-default--compact .widget-default--image[data-v-17076b70]{width:100%;height:150px}.widget-default--compact .widget-default--details[data-v-17076b70]{width:100%;padding-top:calc(var(--default-grid-baseline, 4px) * 2);padding-bottom:calc(var(--default-grid-baseline, 4px) * 2)}.widget-default--compact .widget-default--description[data-v-17076b70]{display:none}.widget-default--image[data-v-17076b70]{width:40%;background-position:center;background-size:cover;background-repeat:no-repeat}.widget-default--name[data-v-17076b70]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}.widget-default--details[data-v-17076b70]{padding:calc(var(--default-grid-baseline, 4px) * 3);width:60%}.widget-default--details p[data-v-17076b70]{margin:0;padding:0}.widget-default--description[data-v-17076b70]{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical}.widget-default--link[data-v-17076b70]{color:var(--color-text-maxcontrast);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toggle-interactive[data-v-17076b70]{position:relative}.toggle-interactive .toggle-interactive--button[data-v-17076b70]{position:absolute;bottom:var(--default-grid-baseline);inset-inline-end:var(--default-grid-baseline);z-index:10000}.material-design-icon[data-v-6d7fc06a]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.raw-link[data-v-6d7fc06a]{width:100%;min-height:350px;display:flex;flex-direction:column;overflow-y:auto;padding:0 16px 16px}.raw-link .input-wrapper[data-v-6d7fc06a]{width:100%}.raw-link .reference-widget[data-v-6d7fc06a]{display:flex}.raw-link--empty-content .provider-icon[data-v-6d7fc06a]{width:150px;height:150px;object-fit:contain;filter:var(--background-invert-if-dark)}.raw-link--input[data-v-6d7fc06a]{width:99%}.material-design-icon[data-v-059edcfb]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.result[data-v-059edcfb]{display:flex;align-items:center;height:var(--default-clickable-area);overflow:hidden}.result--icon-class[data-v-059edcfb],.result--image[data-v-059edcfb]{width:40px;min-width:40px;height:40px;object-fit:contain}.result--icon-class.rounded[data-v-059edcfb],.result--image.rounded[data-v-059edcfb]{border-radius:50%}.result--content[data-v-059edcfb]{display:flex;flex-direction:column;padding-inline-start:10px;overflow:hidden}.result--content--name[data-v-059edcfb],.result--content--subline[data-v-059edcfb]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-design-icon[data-v-e8abf1d4]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.smart-picker-search[data-v-e8abf1d4]{width:100%;display:flex;flex-direction:column;padding:0 16px 16px}.smart-picker-search.with-empty-content[data-v-e8abf1d4]{min-height:400px}.smart-picker-search .provider-icon[data-v-e8abf1d4]{width:150px;height:150px;object-fit:contain;filter:var(--background-invert-if-dark)}.smart-picker-search--select[data-v-e8abf1d4],.smart-picker-search--select .search-result[data-v-e8abf1d4]{width:100%}.smart-picker-search--select .group-name-icon[data-v-e8abf1d4],.smart-picker-search--select .option-simple-icon[data-v-e8abf1d4]{width:20px;height:20px;margin:0 20px 0 10px}.smart-picker-search--select .custom-option[data-v-e8abf1d4]{height:var(--default-clickable-area);display:flex;align-items:center;overflow:hidden}.smart-picker-search--select .option-text[data-v-e8abf1d4]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-design-icon[data-v-b193005a]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.reference-picker[data-v-b193005a],.reference-picker .custom-element-wrapper[data-v-b193005a],.reference-picker .custom-element-wrapper .custom-element[data-v-b193005a]{display:flex;overflow-y:auto;width:100%}.material-design-icon[data-v-15018516]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.reference-picker-modal[data-v-15018516] .modal-container{display:flex!important}.reference-picker-modal--content[data-v-15018516]{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto}.reference-picker-modal--content .close-button[data-v-15018516],.reference-picker-modal--content .back-button[data-v-15018516]{position:absolute;top:4px}.reference-picker-modal--content .back-button[data-v-15018516]{inset-inline-start:4px}.reference-picker-modal--content .close-button[data-v-15018516]{inset-inline-end:4px}.reference-picker-modal--content>h2[data-v-15018516]{display:flex;margin:12px 0 20px}.reference-picker-modal--content>h2 .icon[data-v-15018516]{margin-inline-end:8px}.material-design-icon[data-v-8e3b7bdd]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.input-field[data-v-8e3b7bdd]{--input-border-color: var(--color-border-maxcontrast);--input-border-radius: var(--border-radius-element);--input-border-width-offset: calc(var(--border-width-input-focused, 2px) - var(--border-width-input, 2px));--input-padding-start: var(--border-radius-element);--input-padding-end: var(--border-radius-element);position:relative;width:100%;margin-block-start:6px}.input-field--disabled[data-v-8e3b7bdd]{opacity:.4;filter:saturate(.4)}.input-field--label-outside[data-v-8e3b7bdd]{margin-block-start:0}.input-field--leading-icon[data-v-8e3b7bdd]{--input-padding-start: calc(var(--default-clickable-area) - var(--default-grid-baseline))}.input-field--trailing-icon[data-v-8e3b7bdd]{--input-padding-end: calc(var(--default-clickable-area) - var(--default-grid-baseline))}.input-field--pill[data-v-8e3b7bdd]{--input-border-radius: var(--border-radius-pill)}.input-field__main-wrapper[data-v-8e3b7bdd]{height:var(--default-clickable-area);padding:var(--border-width-input, 2px);position:relative}.input-field__main-wrapper[data-v-8e3b7bdd]:not(:has([disabled])):has(input:focus),.input-field__main-wrapper[data-v-8e3b7bdd]:not(:has([disabled])):has(input:active){padding:0}.input-field__input[data-v-8e3b7bdd]{background-color:var(--color-main-background);color:var(--color-main-text);border:none;border-radius:var(--input-border-radius);box-shadow:0 -1px var(--input-border-color),0 0 0 1px color-mix(in srgb,var(--input-border-color),65% transparent);cursor:pointer;-webkit-appearance:textfield!important;-moz-appearance:textfield!important;appearance:textfield!important;font-size:var(--default-font-size);text-overflow:ellipsis;height:100%!important;min-height:unset;width:100%;padding-block:var(--input-border-width-offset);padding-inline:calc(var(--input-padding-start) + var(--input-border-width-offset)) calc(var(--input-padding-end) + var(--input-border-width-offset))}.input-field__input[data-v-8e3b7bdd]::placeholder{color:var(--color-text-maxcontrast)}.input-field__input[data-v-8e3b7bdd]::-webkit-search-cancel-button{display:none}.input-field__input[data-v-8e3b7bdd]::-webkit-search-decoration,.input-field__input[data-v-8e3b7bdd]::-webkit-search-results-button,.input-field__input[data-v-8e3b7bdd]::-webkit-search-results-decoration,.input-field__input[data-v-8e3b7bdd]::-ms-clear{display:none}.input-field__input[data-v-8e3b7bdd]:hover:not([disabled]){box-shadow:0 0 0 1px var(--input-border-color)}.input-field__input[data-v-8e3b7bdd]:active:not([disabled]),.input-field__input[data-v-8e3b7bdd]:focus:not([disabled]){--input-border-color: var(--color-main-text);--input-border-width-offset: 0px;border:var(--border-width-input-focused, 2px) solid var(--input-border-color);box-shadow:0 0 0 2px var(--color-main-background)!important}.input-field__input:focus+.input-field__label[data-v-8e3b7bdd],.input-field__input:hover:not(:placeholder-shown)+.input-field__label[data-v-8e3b7bdd]{color:var(--color-main-text)}.input-field__input[data-v-8e3b7bdd]:focus{cursor:text}.input-field__input[data-v-8e3b7bdd]:disabled{cursor:default}.input-field__input[data-v-8e3b7bdd]:focus-visible{box-shadow:unset!important}.input-field:not(.input-field--label-outside) .input-field__input[data-v-8e3b7bdd]:not(:focus)::placeholder{opacity:0}.input-field__label[data-v-8e3b7bdd]{--input-label-font-size: var(--default-font-size);font-size:var(--input-label-font-size);position:absolute;margin-inline:var(--input-padding-start) var(--input-padding-end);max-width:fit-content;inset-block-start:calc((var(--default-clickable-area) - 1lh) / 2);inset-inline:var(--border-width-input-focused, 2px);color:var(--color-text-maxcontrast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;transition:height var(--animation-quick),inset-block-start var(--animation-quick),font-size var(--animation-quick),color var(--animation-quick),background-color var(--animation-quick) var(--animation-slow)}.input-field__input:focus+.input-field__label[data-v-8e3b7bdd],.input-field__input:not(:placeholder-shown)+.input-field__label[data-v-8e3b7bdd]{--input-label-font-size: 13px;line-height:1.5;inset-block-start:calc(-1.5 * var(--input-label-font-size) / 2);font-weight:500;border-radius:var(--default-grid-baseline) var(--default-grid-baseline) 0 0;background-color:var(--color-main-background);padding-inline:var(--default-grid-baseline);margin-inline:calc(var(--input-padding-start) - var(--default-grid-baseline)) calc(var(--input-padding-end) - var(--default-grid-baseline));transition:height var(--animation-quick),inset-block-start var(--animation-quick),font-size var(--animation-quick),color var(--animation-quick)}.input-field__icon[data-v-8e3b7bdd]{position:absolute;height:var(--default-clickable-area);width:var(--default-clickable-area);display:flex;align-items:center;justify-content:center;opacity:.7;inset-block-end:0}.input-field__icon--leading[data-v-8e3b7bdd]{inset-inline-start:0px}.input-field__icon--trailing[data-v-8e3b7bdd]{inset-inline-end:0px}.input-field__trailing-button[data-v-8e3b7bdd]{--button-size: calc(var(--default-clickable-area) - 2 * var(--border-width-input-focused, 2px)) !important;--button-radius: calc(var(--input-border-radius) - var(--border-width-input-focused, 2px))}.input-field__trailing-button.button-vue[data-v-8e3b7bdd]{position:absolute;top:var(--border-width-input-focused, 2px);inset-inline-end:var(--border-width-input-focused, 2px)}.input-field__trailing-button.button-vue[data-v-8e3b7bdd]:focus-visible{box-shadow:none!important}.input-field__helper-text-message[data-v-8e3b7bdd]{padding-block:4px;padding-inline:var(--border-radius-element);display:flex;align-items:center;color:var(--color-text-maxcontrast)}.input-field__helper-text-message__icon[data-v-8e3b7bdd]{margin-inline-end:8px}.input-field--error .input-field__helper-text-message[data-v-8e3b7bdd],.input-field--error .input-field__icon--trailing[data-v-8e3b7bdd]{color:var(--color-text-error, var(--color-error))}.input-field--error .input-field__input[data-v-8e3b7bdd],.input-field__input[data-v-8e3b7bdd]:user-invalid{--input-border-color: var(--color-border-error, var(--color-error)) !important}.input-field--error .input-field__input[data-v-8e3b7bdd]:focus-visible,.input-field__input[data-v-8e3b7bdd]:user-invalid:focus-visible{box-shadow:#f8fafc 0 0 0 2px,var(--color-primary-element) 0 0 0 4px,#0000000d 0 1px 2px}.input-field--success .input-field__input[data-v-8e3b7bdd]{--input-border-color: var(--color-border-success, var(--color-success)) !important}.input-field--success .input-field__input[data-v-8e3b7bdd]:focus-visible{box-shadow:#f8fafc 0 0 0 2px,var(--color-primary-element) 0 0 0 4px,#0000000d 0 1px 2px}.input-field--success .input-field__helper-text-message__icon[data-v-8e3b7bdd]{color:var(--color-border-success, var(--color-success))}.input-field--legacy .input-field__input[data-v-8e3b7bdd]{box-shadow:0 0 0 1px var(--input-border-color) inset}.input-field--legacy .input-field__main-wrapper[data-v-8e3b7bdd]:hover:not(:has([disabled])){padding:0}.input-field--legacy .input-field__main-wrapper:hover:not(:has([disabled])) .input-field__input[data-v-8e3b7bdd]{--input-border-color: var(--color-main-text);--input-border-width-offset: 0px;border:var(--border-width-input-focused, 2px) solid var(--input-border-color);box-shadow:0 0 0 2px var(--color-main-background)!important}.external[data-v-9803ab31]:after{content:" ↗"}.material-design-icon[data-v-37bde6b7]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.user-bubble__wrapper[data-v-37bde6b7]{display:inline-block;vertical-align:middle;min-width:0;max-width:100%}.user-bubble__content[data-v-37bde6b7]{display:inline-flex;max-width:100%;background-color:var(--color-background-dark)}.user-bubble__content--primary[data-v-37bde6b7]{color:var(--color-primary-element-text);background-color:var(--color-primary-element)}.user-bubble__content[data-v-37bde6b7]>:last-child{padding-inline-end:8px}.user-bubble__avatar[data-v-37bde6b7]{align-self:center}.user-bubble__name[data-v-37bde6b7]{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.user-bubble__name[data-v-37bde6b7],.user-bubble__secondary[data-v-37bde6b7]{padding-block:0;padding-inline:4px 0}.material-design-icon[data-v-a32502f1]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.avatardiv[data-v-a32502f1]{position:relative;display:inline-block;width:var(--avatar-size);height:var(--avatar-size)}.avatardiv--unknown[data-v-a32502f1]{position:relative;background-color:var(--color-main-background);white-space:normal}.avatardiv[data-v-a32502f1]:not(.avatardiv--unknown){background-color:var(--color-main-background)!important;box-shadow:0 0 5px #0000000d inset}.avatardiv--with-menu[data-v-a32502f1]{cursor:pointer}.avatardiv--with-menu .action-item[data-v-a32502f1]{position:absolute;top:0;inset-inline-start:0}.avatardiv--with-menu[data-v-a32502f1] .action-item__menutoggle{cursor:pointer;opacity:0}.avatardiv--with-menu[data-v-a32502f1]:focus-within .action-item__menutoggle,.avatardiv--with-menu[data-v-a32502f1]:hover .action-item__menutoggle,.avatardiv--with-menu.avatardiv--with-menu-loading[data-v-a32502f1] .action-item__menutoggle{opacity:1}.avatardiv--with-menu:focus-within img[data-v-a32502f1],.avatardiv--with-menu:hover img[data-v-a32502f1],.avatardiv--with-menu.avatardiv--with-menu-loading img[data-v-a32502f1]{opacity:.3}.avatardiv--with-menu[data-v-a32502f1] .action-item__menutoggle,.avatardiv--with-menu img[data-v-a32502f1]{transition:opacity var(--animation-quick)}.avatardiv--with-menu[data-v-a32502f1] .button-vue,.avatardiv--with-menu[data-v-a32502f1] .button-vue__icon{height:var(--avatar-size);min-height:var(--avatar-size);width:var(--avatar-size)!important;min-width:var(--avatar-size)}.avatardiv--with-menu[data-v-a32502f1]>.button-vue,.avatardiv--with-menu[data-v-a32502f1]>.action-item .button-vue{--button-radius: calc(var(--avatar-size) / 2)}.avatardiv .avatardiv__initials-wrapper[data-v-a32502f1]{display:block;height:var(--avatar-size);width:var(--avatar-size);background-color:var(--color-main-background);border-radius:calc(var(--avatar-size) / 2)}.avatardiv .avatardiv__initials-wrapper .avatardiv__initials[data-v-a32502f1]{position:absolute;top:0;inset-inline-start:0;display:block;width:100%;text-align:center;font-weight:400}.avatardiv img[data-v-a32502f1]{width:100%;height:100%;object-fit:cover}.avatardiv .material-design-icon[data-v-a32502f1]{width:var(--avatar-size);height:var(--avatar-size)}.avatardiv .avatardiv__user-status[data-v-a32502f1]{--avatar-status-size-orbital: calc(var(--avatar-size) * (1 - 1 / sqrt(2)));--avatar-status-size-min: var(--font-size-small);--avatar-status-size: max(var(--avatar-status-size-orbital), var(--avatar-status-size-min));box-sizing:border-box;position:absolute;inset-inline-end:0;inset-block-end:0;height:var(--avatar-status-size);width:var(--avatar-status-size);line-height:1;font-size:calc(var(--avatar-status-size) / 1.2);background-color:var(--color-main-background);background-repeat:no-repeat;background-size:var(--avatar-status-size);background-position:center;border-radius:50%;display:flex;align-items:center;justify-content:center}.acli:hover .avatardiv .avatardiv__user-status[data-v-a32502f1]{border-color:var(--color-background-hover);background-color:var(--color-background-hover)}.acli.active .avatardiv .avatardiv__user-status[data-v-a32502f1]{border-color:var(--color-primary-element-light);background-color:var(--color-primary-element-light)}.avatardiv .avatardiv__user-status--icon[data-v-a32502f1]{border:none;background-color:transparent}.avatardiv .popovermenu-wrapper[data-v-a32502f1]{position:relative;display:inline-block}.avatar-class-icon[data-v-a32502f1]{display:block;border-radius:calc(var(--avatar-size) / 2);background-color:var(--color-background-darker);height:100%}.material-design-icon[data-v-45238efd]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.mention-bubble--primary .mention-bubble__content[data-v-45238efd]{color:var(--color-primary-element-text);background-color:var(--color-primary-element)}.mention-bubble__wrapper[data-v-45238efd]{position:relative;max-width:150px;height:18px;vertical-align:text-bottom;display:inline-flex;align-items:center}.mention-bubble__content[data-v-45238efd]{display:inline-flex;overflow:hidden;align-items:center;max-width:100%;height:20px;-webkit-user-select:none;user-select:none;padding-inline:2px 6px;border-radius:10px;background-color:var(--color-background-dark)}.mention-bubble__icon[data-v-45238efd]{position:relative;width:16px;height:16px;border-radius:8px;background-color:var(--color-background-darker);background-repeat:no-repeat;background-position:center;background-size:12px}.mention-bubble__icon--with-avatar[data-v-45238efd]{color:inherit;background-size:cover}.mention-bubble__title[data-v-45238efd]{overflow:hidden;margin-inline-start:2px;white-space:nowrap;text-overflow:ellipsis}.mention-bubble__title[data-v-45238efd]:before{content:attr(title)}.mention-bubble__select[data-v-45238efd]{position:absolute;z-index:-1;inset-inline-start:-100vw;width:1px;height:1px;overflow:hidden}.material-design-icon[data-v-009e879d]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.user-status-icon[data-v-009e879d]{--user-status-color-online: #2D7B41;--user-status-color-busy: #DB0606;--user-status-color-away: #C88800;--user-status-color-offline: #6B6B6B;display:flex;justify-content:center;align-items:center}.user-status-icon--invisible[data-v-009e879d]{filter:var(--background-invert-if-dark)}.user-status-icon[data-v-009e879d] svg{width:100%;height:100%}.material-design-icon[data-v-330b5e3e]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-330b5e3e]:hover,li.action.active[data-v-330b5e3e]{border-radius:6px;padding:0}li.action[data-v-330b5e3e]:hover{background-color:var(--color-background-hover)}.action--disabled[data-v-330b5e3e]{pointer-events:none;opacity:.5}.action--disabled[data-v-330b5e3e]:hover,.action--disabled[data-v-330b5e3e]:focus{cursor:default;opacity:.5}.action--disabled[data-v-330b5e3e] *{opacity:1!important}.action-button[data-v-330b5e3e]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-button>span[data-v-330b5e3e]{cursor:pointer;white-space:nowrap}.action-button__icon[data-v-330b5e3e]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-button[data-v-330b5e3e] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-button[data-v-330b5e3e] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-button__longtext-wrapper[data-v-330b5e3e],.action-button__longtext[data-v-330b5e3e]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-button__longtext[data-v-330b5e3e]{cursor:pointer;white-space:pre-wrap!important}.action-button__name[data-v-330b5e3e]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-button__description[data-v-330b5e3e]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-button__menu-icon[data-v-330b5e3e],.action-button__pressed-icon[data-v-330b5e3e]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.action-button[data-v-330b5e3e] *{cursor:pointer}.material-design-icon[data-v-9e538838]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-9e538838]:hover,li.action.active[data-v-9e538838]{border-radius:6px;padding:0}li.action[data-v-9e538838]:hover{background-color:var(--color-background-hover)}.action-link[data-v-9e538838]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-link>span[data-v-9e538838]{cursor:pointer;white-space:nowrap}.action-link__icon[data-v-9e538838]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-link[data-v-9e538838] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-link[data-v-9e538838] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-link__longtext-wrapper[data-v-9e538838],.action-link__longtext[data-v-9e538838]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-link__longtext[data-v-9e538838]{cursor:pointer;white-space:pre-wrap!important}.action-link__name[data-v-9e538838]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-link__description[data-v-9e538838]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-link__menu-icon[data-v-9e538838]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.material-design-icon[data-v-87267750]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-87267750]:hover,li.action.active[data-v-87267750]{border-radius:6px;padding:0}li.action[data-v-87267750]:hover{background-color:var(--color-background-hover)}.action-router[data-v-87267750]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-router>span[data-v-87267750]{cursor:pointer;white-space:nowrap}.action-router__icon[data-v-87267750]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-router[data-v-87267750] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-router[data-v-87267750] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-router__longtext-wrapper[data-v-87267750],.action-router__longtext[data-v-87267750]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-router__longtext[data-v-87267750]{cursor:pointer;white-space:pre-wrap!important}.action-router__name[data-v-87267750]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-router__description[data-v-87267750]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-router__menu-icon[data-v-87267750]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.action--disabled[data-v-87267750]{pointer-events:none;opacity:.5}.action--disabled[data-v-87267750]:hover,.action--disabled[data-v-87267750]:focus{cursor:default;opacity:.5}.action--disabled[data-v-87267750] *{opacity:1!important}.material-design-icon[data-v-fa684b48]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-fa684b48]:hover,li.action.active[data-v-fa684b48]{border-radius:6px;padding:0}li.action[data-v-fa684b48]:hover{background-color:var(--color-background-hover)}.action-text[data-v-fa684b48]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-text>span[data-v-fa684b48]{cursor:pointer;white-space:nowrap}.action-text__icon[data-v-fa684b48]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-text[data-v-fa684b48] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-text[data-v-fa684b48] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-text__longtext-wrapper[data-v-fa684b48],.action-text__longtext[data-v-fa684b48]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-text__longtext[data-v-fa684b48]{cursor:pointer;white-space:pre-wrap!important}.action-text__name[data-v-fa684b48]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-text__description[data-v-fa684b48]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-text__menu-icon[data-v-fa684b48]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.action--disabled[data-v-fa684b48]{pointer-events:none;opacity:.5}.action--disabled[data-v-fa684b48]:hover,.action--disabled[data-v-fa684b48]:focus{cursor:default;opacity:.5}.action--disabled[data-v-fa684b48] *{opacity:1!important}.action-text[data-v-fa684b48],.action-text span[data-v-fa684b48]{cursor:default}.mention[data-v-85edf4b2]{display:contents;white-space:nowrap}.notification[data-v-58882784] img.notification-icon{display:flex;width:32px;height:32px;filter:var(--background-invert-if-dark)}.notification[data-v-58882784] .rich-text--wrapper{white-space:pre-wrap;overflow-wrap:break-word}.notification .notification-subject[data-v-58882784]{padding:4px}.notification a.notification-subject[data-v-58882784]:focus-visible{box-shadow:inset 0 0 0 2px var(--color-main-text)!important}.notification-container[data-v-e4adb601]{overflow:hidden}.notification-container[data-v-e4adb601],.notification-container[data-v-e4adb601] *,.notification-container[data-v-e4adb601] *:before,.notification-container[data-v-e4adb601] *:after{box-sizing:border-box}.notification-container .notification-wrapper[data-v-e4adb601]{display:flex;flex-direction:column;max-height:calc(100vh - 250px);overflow:auto}.notification-container .dismiss-all[data-v-e4adb601]{padding:calc(2 * var(--default-grid-baseline));border-top:1px solid var(--color-border)}.icon-alert-outline[data-v-e4adb601]{background-size:64px;width:64px;height:64px}.fade-enter-active[data-v-e4adb601],.fade-leave-active[data-v-e4adb601]{transition:opacity var(--animation-quick) ease}.fade-enter-from[data-v-e4adb601],.fade-leave-to[data-v-e4adb601]{opacity:0}.list-move[data-v-e4adb601],.list-enter-active[data-v-e4adb601],.list-leave-active[data-v-e4adb601]{transition:all var(--animation-quick) ease}.list-enter-from[data-v-e4adb601],.list-leave-to[data-v-e4adb601]{opacity:0;transform:translate(30px)}.list-leave-active[data-v-e4adb601]{width:100%} + */.header-menu[data-v-d45c5788]{position:relative;width:var(--header-height);height:var(--header-height)}.header-menu .header-menu__trigger[data-v-d45c5788]{--button-size: var(--header-height) !important;height:var(--header-height);opacity:.85;filter:none!important;color:var(--color-background-plain-text, var(--color-primary-text))!important}.header-menu .header-menu__trigger[data-v-d45c5788]:focus-visible{outline:none!important;box-shadow:none!important}.header-menu .header-menu__trigger[data-v-d45c5788] .button-vue__icon svg,.header-menu .header-menu__trigger[data-v-d45c5788] .button-vue__icon:not(:has(svg)){mask:var(--header-menu-icon-mask, none)}.header-menu--opened .header-menu__trigger[data-v-d45c5788],.header-menu__trigger[data-v-d45c5788]:hover,.header-menu__trigger[data-v-d45c5788]:focus,.header-menu__trigger[data-v-d45c5788]:active{opacity:1}@media only screen and (max-width: 512px){.header-menu[data-v-d45c5788]{width:var(--default-clickable-area)}.header-menu .header-menu__trigger[data-v-d45c5788]{--button-size: var(--default-clickable-area) !important}}.header-menu__wrapper[data-v-d45c5788]{position:fixed;z-index:2000;top:var(--header-height);inset-inline-end:0;box-sizing:border-box;margin:0 8px;border-radius:var(--border-radius-element);background-color:var(--color-main-background);filter:drop-shadow(0 1px 5px var(--color-box-shadow))}.header-menu__caret[data-v-d45c5788]{position:absolute;z-index:2001;bottom:0;inset-inline-start:calc(50% - 10px);width:0;height:0;content:" ";pointer-events:none;border:10px solid transparent;border-bottom-color:var(--color-main-background)}.header-menu__content[data-v-d45c5788]{overflow:auto;width:350px;max-width:calc(100vw - 16px);min-height:calc(var(--default-clickable-area) * 1.5);max-height:calc(100vh - var(--header-height) * 2)}.header-menu__content[data-v-d45c5788] .empty-content{margin:12vh 10px}.material-design-icon[data-v-ddd65c9e]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.widgets--list[data-v-ddd65c9e]{width:100%;min-height:var(--default-clickable-area)}.material-design-icon[data-v-bfd4d4b7]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.rich-text--wrapper[data-v-bfd4d4b7]{overflow-wrap:break-word;line-height:1.5}.rich-text--wrapper .rich-text--fallback[data-v-bfd4d4b7],.rich-text--wrapper .rich-text-component[data-v-bfd4d4b7]{display:inline}.rich-text--wrapper .rich-text--external-link[data-v-bfd4d4b7]{text-decoration:underline}.rich-text--wrapper .rich-text--external-link[data-v-bfd4d4b7]:after{content:" ↗"}.rich-text--wrapper-markdown[data-v-bfd4d4b7]{tab-size:4}.rich-text--wrapper-markdown[data-v-bfd4d4b7]>:first-child,.rich-text--wrapper-markdown div[data-v-bfd4d4b7]>:first-child,.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7]>:first-child{margin-top:0!important}.rich-text--wrapper-markdown[data-v-bfd4d4b7]>:last-child,.rich-text--wrapper-markdown[data-v-bfd4d4b7]>*:has(+.rich-text--reference-widget),.rich-text--wrapper-markdown div[data-v-bfd4d4b7]>:last-child,.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7]>:last-child{margin-block-end:0!important}.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7]{padding-inline-start:13px;border-inline-start:2px solid var(--color-border-dark);color:var(--color-text-maxcontrast)}.rich-text--wrapper-markdown h1[data-v-bfd4d4b7],.rich-text--wrapper-markdown h2[data-v-bfd4d4b7],.rich-text--wrapper-markdown h3[data-v-bfd4d4b7],.rich-text--wrapper-markdown h4[data-v-bfd4d4b7],.rich-text--wrapper-markdown h5[data-v-bfd4d4b7],.rich-text--wrapper-markdown h6[data-v-bfd4d4b7],.rich-text--wrapper-markdown p[data-v-bfd4d4b7],.rich-text--wrapper-markdown ul[data-v-bfd4d4b7],.rich-text--wrapper-markdown ol[data-v-bfd4d4b7],.rich-text--wrapper-markdown blockquote[data-v-bfd4d4b7],.rich-text--wrapper-markdown pre[data-v-bfd4d4b7]{margin-top:0;margin-block-end:1em}.rich-text--wrapper-markdown h1[data-v-bfd4d4b7],.rich-text--wrapper-markdown h2[data-v-bfd4d4b7],.rich-text--wrapper-markdown h3[data-v-bfd4d4b7],.rich-text--wrapper-markdown h4[data-v-bfd4d4b7],.rich-text--wrapper-markdown h5[data-v-bfd4d4b7],.rich-text--wrapper-markdown h6[data-v-bfd4d4b7]{font-weight:700}.rich-text--wrapper-markdown h1[data-v-bfd4d4b7]{font-size:30px}.rich-text--wrapper-markdown ul[data-v-bfd4d4b7],.rich-text--wrapper-markdown ol[data-v-bfd4d4b7]{padding-inline-start:4ch}.rich-text--wrapper-markdown ul[data-v-bfd4d4b7]{list-style-type:disc}.rich-text--wrapper-markdown ul.contains-task-list[data-v-bfd4d4b7]{list-style-type:none;padding:0}.rich-text--wrapper-markdown li.task-list-item>ul[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>ol[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>li[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>blockquote[data-v-bfd4d4b7],.rich-text--wrapper-markdown li.task-list-item>pre[data-v-bfd4d4b7]{margin-inline-start:15px;margin-block-end:0}.rich-text--wrapper-markdown pre[data-v-bfd4d4b7]{direction:ltr}.rich-text--wrapper-markdown table[data-v-bfd4d4b7]{border-collapse:collapse;border:2px solid var(--color-border-maxcontrast)}.rich-text--wrapper-markdown table th[data-v-bfd4d4b7],.rich-text--wrapper-markdown table td[data-v-bfd4d4b7]{padding:var(--default-grid-baseline);border:1px solid var(--color-border-maxcontrast)}.rich-text--wrapper-markdown table th[data-v-bfd4d4b7]:first-child,.rich-text--wrapper-markdown table td[data-v-bfd4d4b7]:first-child{border-inline-start:0}.rich-text--wrapper-markdown table th[data-v-bfd4d4b7]:last-child,.rich-text--wrapper-markdown table td[data-v-bfd4d4b7]:last-child{border-inline-end:0}.rich-text--wrapper-markdown table tr:first-child th[data-v-bfd4d4b7]{border-top:0}.rich-text--wrapper-markdown table tr:last-child td[data-v-bfd4d4b7]{border-block-end:0}.rich-text--wrapper-markdown pre[data-v-bfd4d4b7]:has(.hljs){color:var(--hljs-color);background:var(--hljs-background-color)}.rich-text--wrapper-markdown .hljs-doctag[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-keyword[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-meta .hljs-keyword[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-template-tag[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-template-variable[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-type[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-variable.language_[data-v-bfd4d4b7]{color:var(--hljs-syntax-keyword-color)}.rich-text--wrapper-markdown .hljs-title[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-title.class_[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-title.class_.inherited__[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-title.function_[data-v-bfd4d4b7]{color:var(--hljs-syntax-entity-color)}.rich-text--wrapper-markdown .hljs-attr[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-attribute[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-literal[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-meta[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-number[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-operator[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-variable[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-attr[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-class[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-id[data-v-bfd4d4b7]{color:var(--hljs-syntax-constant-color)}.rich-text--wrapper-markdown .hljs-regexp[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-string[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-meta .hljs-string[data-v-bfd4d4b7]{color:var(--hljs-syntax-string-color)}.rich-text--wrapper-markdown .hljs-built_in[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-symbol[data-v-bfd4d4b7]{color:var(--hljs-syntax-variable-color)}.rich-text--wrapper-markdown .hljs-comment[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-code[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-formula[data-v-bfd4d4b7]{color:var(--hljs-syntax-comment-color)}.rich-text--wrapper-markdown .hljs-name[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-quote[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-tag[data-v-bfd4d4b7],.rich-text--wrapper-markdown .hljs-selector-pseudo[data-v-bfd4d4b7]{color:var(--hljs-syntax-entity-tag-color)}.rich-text--wrapper-markdown .hljs-subst[data-v-bfd4d4b7]{color:var(--hljs-syntax-storage-modifier-import-color)}.rich-text--wrapper-markdown .hljs-section[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-heading-color);font-weight:700}.rich-text--wrapper-markdown .hljs-bullet[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-list-color)}.rich-text--wrapper-markdown .hljs-emphasis[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-italic-color);font-style:italic}.rich-text--wrapper-markdown .hljs-strong[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-bold-color);font-weight:700}.rich-text--wrapper-markdown .hljs-addition[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-inserted-color);background-color:var(--hljs-syntax-markup-inserted-background-color)}.rich-text--wrapper-markdown .hljs-deletion[data-v-bfd4d4b7]{color:var(--hljs-syntax-markup-deleted-color);background-color:var(--hljs-syntax-markup-deleted-background-color)}a[data-v-bfd4d4b7]:not(.rich-text--component){text-decoration:underline}@media (prefers-color-scheme: light){.rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #24292e);--hljs-background-color: var(--color-background-dark, #ffffff);--hljs-syntax-keyword-color: #d73a49;--hljs-syntax-entity-color: #6f42c1;--hljs-syntax-constant-color: #005cc5;--hljs-syntax-string-color: #032f62;--hljs-syntax-variable-color: #e36209;--hljs-syntax-comment-color: #6a737d;--hljs-syntax-entity-tag-color: #22863a;--hljs-syntax-storage-modifier-import-color: #24292e;--hljs-syntax-markup-heading-color: #005cc5;--hljs-syntax-markup-list-color: #735c0f;--hljs-syntax-markup-italic-color: #24292e;--hljs-syntax-markup-bold-color: #24292e;--hljs-syntax-markup-inserted-color: #22863a;--hljs-syntax-markup-inserted-background-color: #f0fff4;--hljs-syntax-markup-deleted-color: #b31d28;--hljs-syntax-markup-deleted-background-color: #ffeef0}[data-theme-dark] .rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #c9d1d9);--hljs-background-color: var(--color-background-dark, #0d1117);--hljs-syntax-keyword-color: #ff7b72;--hljs-syntax-entity-color: #d2a8ff;--hljs-syntax-constant-color: #79c0ff;--hljs-syntax-string-color: #a5d6ff;--hljs-syntax-variable-color: #ffa657;--hljs-syntax-comment-color: #8b949e;--hljs-syntax-entity-tag-color: #7ee787;--hljs-syntax-storage-modifier-import-color: #c9d1d9;--hljs-syntax-markup-heading-color: #1f6feb;--hljs-syntax-markup-list-color: #f2cc60;--hljs-syntax-markup-italic-color: #c9d1d9;--hljs-syntax-markup-bold-color: #c9d1d9;--hljs-syntax-markup-inserted-color: #aff5b4;--hljs-syntax-markup-inserted-background-color: #033a16;--hljs-syntax-markup-deleted-color: #ffdcd7;--hljs-syntax-markup-deleted-background-color: #67060c}}@media (prefers-color-scheme: dark){.rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #c9d1d9);--hljs-background-color: var(--color-background-dark, #0d1117);--hljs-syntax-keyword-color: #ff7b72;--hljs-syntax-entity-color: #d2a8ff;--hljs-syntax-constant-color: #79c0ff;--hljs-syntax-string-color: #a5d6ff;--hljs-syntax-variable-color: #ffa657;--hljs-syntax-comment-color: #8b949e;--hljs-syntax-entity-tag-color: #7ee787;--hljs-syntax-storage-modifier-import-color: #c9d1d9;--hljs-syntax-markup-heading-color: #1f6feb;--hljs-syntax-markup-list-color: #f2cc60;--hljs-syntax-markup-italic-color: #c9d1d9;--hljs-syntax-markup-bold-color: #c9d1d9;--hljs-syntax-markup-inserted-color: #aff5b4;--hljs-syntax-markup-inserted-background-color: #033a16;--hljs-syntax-markup-deleted-color: #ffdcd7;--hljs-syntax-markup-deleted-background-color: #67060c}[data-theme-light] .rich-text--wrapper-markdown[data-v-bfd4d4b7]{--hljs-color: var(--color-main-text, #24292e);--hljs-background-color: var(--color-background-dark, #ffffff);--hljs-syntax-keyword-color: #d73a49;--hljs-syntax-entity-color: #6f42c1;--hljs-syntax-constant-color: #005cc5;--hljs-syntax-string-color: #032f62;--hljs-syntax-variable-color: #e36209;--hljs-syntax-comment-color: #6a737d;--hljs-syntax-entity-tag-color: #22863a;--hljs-syntax-storage-modifier-import-color: #24292e;--hljs-syntax-markup-heading-color: #005cc5;--hljs-syntax-markup-list-color: #735c0f;--hljs-syntax-markup-italic-color: #24292e;--hljs-syntax-markup-bold-color: #24292e;--hljs-syntax-markup-inserted-color: #22863a;--hljs-syntax-markup-inserted-background-color: #f0fff4;--hljs-syntax-markup-deleted-color: #b31d28;--hljs-syntax-markup-deleted-background-color: #ffeef0}}.material-design-icon[data-v-e408867a],.material-design-icon[data-v-90c6aa3b]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.provider-list[data-v-90c6aa3b]{width:100%;min-height:400px;padding:0 16px 16px;display:flex;flex-direction:column}.provider-list--select[data-v-90c6aa3b]{width:100%}.provider-list--select .provider[data-v-90c6aa3b]{display:flex;align-items:center;height:28px;overflow:hidden}.provider-list--select .provider .link-icon[data-v-90c6aa3b]{margin-inline-end:8px}.provider-list--select .provider .provider-icon[data-v-90c6aa3b]{width:20px;height:20px;object-fit:contain;margin-inline-end:8px;filter:var(--background-invert-if-dark)}.provider-list--select .provider .option-text[data-v-90c6aa3b]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-design-icon[data-v-17076b70]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.widget-custom[data-v-17076b70]{width:100%;margin:auto;margin-bottom:calc(var(--default-grid-baseline, 4px) * 3);margin-top:calc(var(--default-grid-baseline, 4px) * 3);overflow:hidden;border:2px solid var(--color-border);border-radius:var(--border-radius-container);background-color:transparent;display:flex}.widget-custom.full-width[data-v-17076b70]{width:var(--widget-full-width, 100%)!important;inset-inline-start:calc((var(--widget-full-width, 100%) - 100%) / 2 * -1);position:relative}.widget-access[data-v-17076b70]{width:100%;margin:auto;margin-bottom:calc(var(--default-grid-baseline, 4px) * 3);margin-top:calc(var(--default-grid-baseline, 4px) * 3);overflow:hidden;border:2px solid var(--color-border);border-radius:var(--border-radius-container);background-color:transparent;display:flex;padding:calc(var(--default-grid-baseline, 4px) * 3)}.widget-default[data-v-17076b70]{width:100%;margin:auto;margin-bottom:calc(var(--default-grid-baseline, 4px) * 3);margin-top:calc(var(--default-grid-baseline, 4px) * 3);overflow:hidden;border:2px solid var(--color-border);border-radius:var(--border-radius-container);background-color:transparent;display:flex}.widget-default--compact[data-v-17076b70]{flex-direction:column}.widget-default--compact .widget-default--image[data-v-17076b70]{width:100%;height:150px}.widget-default--compact .widget-default--details[data-v-17076b70]{width:100%;padding-top:calc(var(--default-grid-baseline, 4px) * 2);padding-bottom:calc(var(--default-grid-baseline, 4px) * 2)}.widget-default--compact .widget-default--description[data-v-17076b70]{display:none}.widget-default--image[data-v-17076b70]{width:40%;background-position:center;background-size:cover;background-repeat:no-repeat}.widget-default--name[data-v-17076b70]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}.widget-default--details[data-v-17076b70]{padding:calc(var(--default-grid-baseline, 4px) * 3);width:60%}.widget-default--details p[data-v-17076b70]{margin:0;padding:0}.widget-default--description[data-v-17076b70]{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical}.widget-default--link[data-v-17076b70]{color:var(--color-text-maxcontrast);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toggle-interactive[data-v-17076b70]{position:relative}.toggle-interactive .toggle-interactive--button[data-v-17076b70]{position:absolute;bottom:var(--default-grid-baseline);inset-inline-end:var(--default-grid-baseline);z-index:10000}.material-design-icon[data-v-6d7fc06a]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.raw-link[data-v-6d7fc06a]{width:100%;min-height:350px;display:flex;flex-direction:column;overflow-y:auto;padding:0 16px 16px}.raw-link .input-wrapper[data-v-6d7fc06a]{width:100%}.raw-link .reference-widget[data-v-6d7fc06a]{display:flex}.raw-link--empty-content .provider-icon[data-v-6d7fc06a]{width:150px;height:150px;object-fit:contain;filter:var(--background-invert-if-dark)}.raw-link--input[data-v-6d7fc06a]{width:99%}.material-design-icon[data-v-059edcfb]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.result[data-v-059edcfb]{display:flex;align-items:center;height:var(--default-clickable-area);overflow:hidden}.result--icon-class[data-v-059edcfb],.result--image[data-v-059edcfb]{width:40px;min-width:40px;height:40px;object-fit:contain}.result--icon-class.rounded[data-v-059edcfb],.result--image.rounded[data-v-059edcfb]{border-radius:50%}.result--content[data-v-059edcfb]{display:flex;flex-direction:column;padding-inline-start:10px;overflow:hidden}.result--content--name[data-v-059edcfb],.result--content--subline[data-v-059edcfb]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-design-icon[data-v-e8abf1d4]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.smart-picker-search[data-v-e8abf1d4]{width:100%;display:flex;flex-direction:column;padding:0 16px 16px}.smart-picker-search.with-empty-content[data-v-e8abf1d4]{min-height:400px}.smart-picker-search .provider-icon[data-v-e8abf1d4]{width:150px;height:150px;object-fit:contain;filter:var(--background-invert-if-dark)}.smart-picker-search--select[data-v-e8abf1d4],.smart-picker-search--select .search-result[data-v-e8abf1d4]{width:100%}.smart-picker-search--select .group-name-icon[data-v-e8abf1d4],.smart-picker-search--select .option-simple-icon[data-v-e8abf1d4]{width:20px;height:20px;margin:0 20px 0 10px}.smart-picker-search--select .custom-option[data-v-e8abf1d4]{height:var(--default-clickable-area);display:flex;align-items:center;overflow:hidden}.smart-picker-search--select .option-text[data-v-e8abf1d4]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-design-icon[data-v-b193005a]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.reference-picker[data-v-b193005a],.reference-picker .custom-element-wrapper[data-v-b193005a],.reference-picker .custom-element-wrapper .custom-element[data-v-b193005a]{display:flex;overflow-y:auto;width:100%}.material-design-icon[data-v-15018516]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.reference-picker-modal[data-v-15018516] .modal-container{display:flex!important}.reference-picker-modal--content[data-v-15018516]{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto}.reference-picker-modal--content .close-button[data-v-15018516],.reference-picker-modal--content .back-button[data-v-15018516]{position:absolute;top:4px}.reference-picker-modal--content .back-button[data-v-15018516]{inset-inline-start:4px}.reference-picker-modal--content .close-button[data-v-15018516]{inset-inline-end:4px}.reference-picker-modal--content>h2[data-v-15018516]{display:flex;margin:12px 0 20px}.reference-picker-modal--content>h2 .icon[data-v-15018516]{margin-inline-end:8px}.material-design-icon[data-v-8e3b7bdd]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.input-field[data-v-8e3b7bdd]{--input-border-color: var(--color-border-maxcontrast);--input-border-radius: var(--border-radius-element);--input-border-width-offset: calc(var(--border-width-input-focused, 2px) - var(--border-width-input, 2px));--input-padding-start: var(--border-radius-element);--input-padding-end: var(--border-radius-element);position:relative;width:100%;margin-block-start:6px}.input-field--disabled[data-v-8e3b7bdd]{opacity:.4;filter:saturate(.4)}.input-field--label-outside[data-v-8e3b7bdd]{margin-block-start:0}.input-field--leading-icon[data-v-8e3b7bdd]{--input-padding-start: calc(var(--default-clickable-area) - var(--default-grid-baseline))}.input-field--trailing-icon[data-v-8e3b7bdd]{--input-padding-end: calc(var(--default-clickable-area) - var(--default-grid-baseline))}.input-field--pill[data-v-8e3b7bdd]{--input-border-radius: var(--border-radius-pill)}.input-field__main-wrapper[data-v-8e3b7bdd]{height:var(--default-clickable-area);padding:var(--border-width-input, 2px);position:relative}.input-field__main-wrapper[data-v-8e3b7bdd]:not(:has([disabled])):has(input:focus),.input-field__main-wrapper[data-v-8e3b7bdd]:not(:has([disabled])):has(input:active){padding:0}.input-field__input[data-v-8e3b7bdd]{background-color:var(--color-main-background);color:var(--color-main-text);border:none;border-radius:var(--input-border-radius);box-shadow:0 -1px var(--input-border-color),0 0 0 1px color-mix(in srgb,var(--input-border-color),65% transparent);cursor:pointer;-webkit-appearance:textfield!important;-moz-appearance:textfield!important;appearance:textfield!important;font-size:var(--default-font-size);text-overflow:ellipsis;height:100%!important;min-height:unset;width:100%;padding-block:var(--input-border-width-offset);padding-inline:calc(var(--input-padding-start) + var(--input-border-width-offset)) calc(var(--input-padding-end) + var(--input-border-width-offset))}.input-field__input[data-v-8e3b7bdd]::placeholder{color:var(--color-text-maxcontrast)}.input-field__input[data-v-8e3b7bdd]::-webkit-search-cancel-button{display:none}.input-field__input[data-v-8e3b7bdd]::-webkit-search-decoration,.input-field__input[data-v-8e3b7bdd]::-webkit-search-results-button,.input-field__input[data-v-8e3b7bdd]::-webkit-search-results-decoration,.input-field__input[data-v-8e3b7bdd]::-ms-clear{display:none}.input-field__input[data-v-8e3b7bdd]:hover:not([disabled]){box-shadow:0 0 0 1px var(--input-border-color)}.input-field__input[data-v-8e3b7bdd]:active:not([disabled]),.input-field__input[data-v-8e3b7bdd]:focus:not([disabled]){--input-border-color: var(--color-main-text);--input-border-width-offset: 0px;border:var(--border-width-input-focused, 2px) solid var(--input-border-color);box-shadow:0 0 0 2px var(--color-main-background)!important}.input-field__input:focus+.input-field__label[data-v-8e3b7bdd],.input-field__input:hover:not(:placeholder-shown)+.input-field__label[data-v-8e3b7bdd]{color:var(--color-main-text)}.input-field__input[data-v-8e3b7bdd]:focus{cursor:text}.input-field__input[data-v-8e3b7bdd]:disabled{cursor:default}.input-field__input[data-v-8e3b7bdd]:focus-visible{box-shadow:unset!important}.input-field:not(.input-field--label-outside) .input-field__input[data-v-8e3b7bdd]:not(:focus)::placeholder{opacity:0}.input-field__label[data-v-8e3b7bdd]{--input-label-font-size: var(--default-font-size);font-size:var(--input-label-font-size);position:absolute;margin-inline:var(--input-padding-start) var(--input-padding-end);max-width:fit-content;inset-block-start:calc((var(--default-clickable-area) - 1lh) / 2);inset-inline:var(--border-width-input-focused, 2px);color:var(--color-text-maxcontrast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;transition:height var(--animation-quick),inset-block-start var(--animation-quick),font-size var(--animation-quick),color var(--animation-quick),background-color var(--animation-quick) var(--animation-slow)}.input-field__input:focus+.input-field__label[data-v-8e3b7bdd],.input-field__input:not(:placeholder-shown)+.input-field__label[data-v-8e3b7bdd]{--input-label-font-size: 13px;line-height:1.5;inset-block-start:calc(-1.5 * var(--input-label-font-size) / 2);font-weight:500;border-radius:var(--default-grid-baseline) var(--default-grid-baseline) 0 0;background-color:var(--color-main-background);padding-inline:var(--default-grid-baseline);margin-inline:calc(var(--input-padding-start) - var(--default-grid-baseline)) calc(var(--input-padding-end) - var(--default-grid-baseline));transition:height var(--animation-quick),inset-block-start var(--animation-quick),font-size var(--animation-quick),color var(--animation-quick)}.input-field__icon[data-v-8e3b7bdd]{position:absolute;height:var(--default-clickable-area);width:var(--default-clickable-area);display:flex;align-items:center;justify-content:center;opacity:.7;inset-block-end:0}.input-field__icon--leading[data-v-8e3b7bdd]{inset-inline-start:0px}.input-field__icon--trailing[data-v-8e3b7bdd]{inset-inline-end:0px}.input-field__trailing-button[data-v-8e3b7bdd]{--button-size: calc(var(--default-clickable-area) - 2 * var(--border-width-input-focused, 2px)) !important;--button-radius: calc(var(--input-border-radius) - var(--border-width-input-focused, 2px))}.input-field__trailing-button.button-vue[data-v-8e3b7bdd]{position:absolute;top:var(--border-width-input-focused, 2px);inset-inline-end:var(--border-width-input-focused, 2px)}.input-field__trailing-button.button-vue[data-v-8e3b7bdd]:focus-visible{box-shadow:none!important}.input-field__helper-text-message[data-v-8e3b7bdd]{padding-block:4px;padding-inline:var(--border-radius-element);display:flex;align-items:center;color:var(--color-text-maxcontrast)}.input-field__helper-text-message__icon[data-v-8e3b7bdd]{margin-inline-end:8px}.input-field--error .input-field__helper-text-message[data-v-8e3b7bdd],.input-field--error .input-field__icon--trailing[data-v-8e3b7bdd]{color:var(--color-text-error, var(--color-error))}.input-field--error .input-field__input[data-v-8e3b7bdd],.input-field__input[data-v-8e3b7bdd]:user-invalid{--input-border-color: var(--color-border-error, var(--color-error)) !important}.input-field--error .input-field__input[data-v-8e3b7bdd]:focus-visible,.input-field__input[data-v-8e3b7bdd]:user-invalid:focus-visible{box-shadow:#f8fafc 0 0 0 2px,var(--color-primary-element) 0 0 0 4px,#0000000d 0 1px 2px}.input-field--success .input-field__input[data-v-8e3b7bdd]{--input-border-color: var(--color-border-success, var(--color-success)) !important}.input-field--success .input-field__input[data-v-8e3b7bdd]:focus-visible{box-shadow:#f8fafc 0 0 0 2px,var(--color-primary-element) 0 0 0 4px,#0000000d 0 1px 2px}.input-field--success .input-field__helper-text-message__icon[data-v-8e3b7bdd]{color:var(--color-border-success, var(--color-success))}.input-field--legacy .input-field__input[data-v-8e3b7bdd]{box-shadow:0 0 0 1px var(--input-border-color) inset}.input-field--legacy .input-field__main-wrapper[data-v-8e3b7bdd]:hover:not(:has([disabled])){padding:0}.input-field--legacy .input-field__main-wrapper:hover:not(:has([disabled])) .input-field__input[data-v-8e3b7bdd]{--input-border-color: var(--color-main-text);--input-border-width-offset: 0px;border:var(--border-width-input-focused, 2px) solid var(--input-border-color);box-shadow:0 0 0 2px var(--color-main-background)!important}.external[data-v-9803ab31]:after{content:" ↗"}.material-design-icon[data-v-37bde6b7]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.user-bubble__wrapper[data-v-37bde6b7]{display:inline-block;vertical-align:middle;min-width:0;max-width:100%}.user-bubble__content[data-v-37bde6b7]{display:inline-flex;max-width:100%;background-color:var(--color-background-dark)}.user-bubble__content--primary[data-v-37bde6b7]{color:var(--color-primary-element-text);background-color:var(--color-primary-element)}.user-bubble__content[data-v-37bde6b7]>:last-child{padding-inline-end:8px}.user-bubble__avatar[data-v-37bde6b7]{align-self:center}.user-bubble__name[data-v-37bde6b7]{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.user-bubble__name[data-v-37bde6b7],.user-bubble__secondary[data-v-37bde6b7]{padding-block:0;padding-inline:4px 0}.material-design-icon[data-v-a32502f1]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.avatardiv[data-v-a32502f1]{position:relative;display:inline-block;width:var(--avatar-size);height:var(--avatar-size)}.avatardiv--unknown[data-v-a32502f1]{position:relative;background-color:var(--color-main-background);white-space:normal}.avatardiv[data-v-a32502f1]:not(.avatardiv--unknown){background-color:var(--color-main-background)!important;box-shadow:0 0 5px #0000000d inset}.avatardiv--with-menu[data-v-a32502f1]{cursor:pointer}.avatardiv--with-menu .action-item[data-v-a32502f1]{position:absolute;top:0;inset-inline-start:0}.avatardiv--with-menu[data-v-a32502f1] .action-item__menutoggle{cursor:pointer;opacity:0}.avatardiv--with-menu[data-v-a32502f1]:focus-within .action-item__menutoggle,.avatardiv--with-menu[data-v-a32502f1]:hover .action-item__menutoggle,.avatardiv--with-menu.avatardiv--with-menu-loading[data-v-a32502f1] .action-item__menutoggle{opacity:1}.avatardiv--with-menu:focus-within img[data-v-a32502f1],.avatardiv--with-menu:hover img[data-v-a32502f1],.avatardiv--with-menu.avatardiv--with-menu-loading img[data-v-a32502f1]{opacity:.3}.avatardiv--with-menu[data-v-a32502f1] .action-item__menutoggle,.avatardiv--with-menu img[data-v-a32502f1]{transition:opacity var(--animation-quick)}.avatardiv--with-menu[data-v-a32502f1] .button-vue,.avatardiv--with-menu[data-v-a32502f1] .button-vue__icon{height:var(--avatar-size);min-height:var(--avatar-size);width:var(--avatar-size)!important;min-width:var(--avatar-size)}.avatardiv--with-menu[data-v-a32502f1]>.button-vue,.avatardiv--with-menu[data-v-a32502f1]>.action-item .button-vue{--button-radius: calc(var(--avatar-size) / 2)}.avatardiv .avatardiv__initials-wrapper[data-v-a32502f1]{display:block;height:var(--avatar-size);width:var(--avatar-size);background-color:var(--color-main-background);border-radius:calc(var(--avatar-size) / 2)}.avatardiv .avatardiv__initials-wrapper .avatardiv__initials[data-v-a32502f1]{position:absolute;top:0;inset-inline-start:0;display:block;width:100%;text-align:center;font-weight:400}.avatardiv img[data-v-a32502f1]{width:100%;height:100%;object-fit:cover}.avatardiv .material-design-icon[data-v-a32502f1]{width:var(--avatar-size);height:var(--avatar-size)}.avatardiv .avatardiv__user-status[data-v-a32502f1]{--avatar-status-size-orbital: calc(var(--avatar-size) * (1 - 1 / sqrt(2)));--avatar-status-size-min: var(--font-size-small);--avatar-status-size: max(var(--avatar-status-size-orbital), var(--avatar-status-size-min));box-sizing:border-box;position:absolute;inset-inline-end:0;inset-block-end:0;height:var(--avatar-status-size);width:var(--avatar-status-size);line-height:1;font-size:calc(var(--avatar-status-size) / 1.2);background-color:var(--color-main-background);background-repeat:no-repeat;background-size:var(--avatar-status-size);background-position:center;border-radius:50%;display:flex;align-items:center;justify-content:center}.acli:hover .avatardiv .avatardiv__user-status[data-v-a32502f1]{border-color:var(--color-background-hover);background-color:var(--color-background-hover)}.acli.active .avatardiv .avatardiv__user-status[data-v-a32502f1]{border-color:var(--color-primary-element-light);background-color:var(--color-primary-element-light)}.avatardiv .avatardiv__user-status--icon[data-v-a32502f1]{border:none;background-color:transparent}.avatardiv .popovermenu-wrapper[data-v-a32502f1]{position:relative;display:inline-block}.avatar-class-icon[data-v-a32502f1]{display:block;border-radius:calc(var(--avatar-size) / 2);background-color:var(--color-background-darker);height:100%}.material-design-icon[data-v-45238efd]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.mention-bubble--primary .mention-bubble__content[data-v-45238efd]{color:var(--color-primary-element-text);background-color:var(--color-primary-element)}.mention-bubble__wrapper[data-v-45238efd]{position:relative;max-width:150px;height:18px;vertical-align:text-bottom;display:inline-flex;align-items:center}.mention-bubble__content[data-v-45238efd]{display:inline-flex;overflow:hidden;align-items:center;max-width:100%;height:20px;-webkit-user-select:none;user-select:none;padding-inline:2px 6px;border-radius:10px;background-color:var(--color-background-dark)}.mention-bubble__icon[data-v-45238efd]{position:relative;width:16px;height:16px;border-radius:8px;background-color:var(--color-background-darker);background-repeat:no-repeat;background-position:center;background-size:12px}.mention-bubble__icon--with-avatar[data-v-45238efd]{color:inherit;background-size:cover}.mention-bubble__title[data-v-45238efd]{overflow:hidden;margin-inline-start:2px;white-space:nowrap;text-overflow:ellipsis}.mention-bubble__title[data-v-45238efd]:before{content:attr(title)}.mention-bubble__select[data-v-45238efd]{position:absolute;z-index:-1;inset-inline-start:-100vw;width:1px;height:1px;overflow:hidden}.material-design-icon[data-v-009e879d]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}.user-status-icon[data-v-009e879d]{--user-status-color-online: #2D7B41;--user-status-color-busy: #DB0606;--user-status-color-away: #C88800;--user-status-color-offline: #6B6B6B;display:flex;justify-content:center;align-items:center}.user-status-icon--invisible[data-v-009e879d]{filter:var(--background-invert-if-dark)}.user-status-icon[data-v-009e879d] svg{width:100%;height:100%}.material-design-icon[data-v-330b5e3e]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-330b5e3e]:hover,li.action.active[data-v-330b5e3e]{border-radius:6px;padding:0}li.action[data-v-330b5e3e]:hover{background-color:var(--color-background-hover)}.action--disabled[data-v-330b5e3e]{pointer-events:none;opacity:.5}.action--disabled[data-v-330b5e3e]:hover,.action--disabled[data-v-330b5e3e]:focus{cursor:default;opacity:.5}.action--disabled[data-v-330b5e3e] *{opacity:1!important}.action-button[data-v-330b5e3e]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-button>span[data-v-330b5e3e]{cursor:pointer;white-space:nowrap}.action-button__icon[data-v-330b5e3e]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-button[data-v-330b5e3e] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-button[data-v-330b5e3e] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-button__longtext-wrapper[data-v-330b5e3e],.action-button__longtext[data-v-330b5e3e]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-button__longtext[data-v-330b5e3e]{cursor:pointer;white-space:pre-wrap!important}.action-button__name[data-v-330b5e3e]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-button__description[data-v-330b5e3e]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-button__menu-icon[data-v-330b5e3e],.action-button__pressed-icon[data-v-330b5e3e]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.action-button[data-v-330b5e3e] *{cursor:pointer}.material-design-icon[data-v-9e538838]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-9e538838]:hover,li.action.active[data-v-9e538838]{border-radius:6px;padding:0}li.action[data-v-9e538838]:hover{background-color:var(--color-background-hover)}.action-link[data-v-9e538838]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-link>span[data-v-9e538838]{cursor:pointer;white-space:nowrap}.action-link__icon[data-v-9e538838]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-link[data-v-9e538838] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-link[data-v-9e538838] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-link__longtext-wrapper[data-v-9e538838],.action-link__longtext[data-v-9e538838]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-link__longtext[data-v-9e538838]{cursor:pointer;white-space:pre-wrap!important}.action-link__name[data-v-9e538838]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-link__description[data-v-9e538838]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-link__menu-icon[data-v-9e538838]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.material-design-icon[data-v-87267750]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-87267750]:hover,li.action.active[data-v-87267750]{border-radius:6px;padding:0}li.action[data-v-87267750]:hover{background-color:var(--color-background-hover)}.action-router[data-v-87267750]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-router>span[data-v-87267750]{cursor:pointer;white-space:nowrap}.action-router__icon[data-v-87267750]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-router[data-v-87267750] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-router[data-v-87267750] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-router__longtext-wrapper[data-v-87267750],.action-router__longtext[data-v-87267750]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-router__longtext[data-v-87267750]{cursor:pointer;white-space:pre-wrap!important}.action-router__name[data-v-87267750]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-router__description[data-v-87267750]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-router__menu-icon[data-v-87267750]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.action--disabled[data-v-87267750]{pointer-events:none;opacity:.5}.action--disabled[data-v-87267750]:hover,.action--disabled[data-v-87267750]:focus{cursor:default;opacity:.5}.action--disabled[data-v-87267750] *{opacity:1!important}.material-design-icon[data-v-fa684b48]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}li.action[data-v-fa684b48]:hover,li.action.active[data-v-fa684b48]{border-radius:6px;padding:0}li.action[data-v-fa684b48]:hover{background-color:var(--color-background-hover)}.action-text[data-v-fa684b48]{display:flex;align-items:flex-start;width:100%;height:auto;margin:0;padding:0;padding-inline-end:calc((var(--default-clickable-area) - 16px) / 2);box-sizing:border-box;cursor:pointer;white-space:nowrap;color:var(--color-main-text);border:0;border-radius:0;background-color:transparent;box-shadow:none;font-weight:400;font-size:var(--default-font-size);line-height:var(--default-clickable-area)}.action-text>span[data-v-fa684b48]{cursor:pointer;white-space:nowrap}.action-text__icon[data-v-fa684b48]{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1;background-position:calc((var(--default-clickable-area) - 16px) / 2) center;background-size:16px;background-repeat:no-repeat}.action-text[data-v-fa684b48] .material-design-icon{width:var(--default-clickable-area);height:var(--default-clickable-area);opacity:1}.action-text[data-v-fa684b48] .material-design-icon .material-design-icon__svg{vertical-align:middle}.action-text__longtext-wrapper[data-v-fa684b48],.action-text__longtext[data-v-fa684b48]{max-width:220px;line-height:1.6em;padding:calc((var(--default-clickable-area) - 1.6em) / 2) 0;cursor:pointer;text-align:start;overflow:hidden;text-overflow:ellipsis}.action-text__longtext[data-v-fa684b48]{cursor:pointer;white-space:pre-wrap!important}.action-text__name[data-v-fa684b48]{font-weight:700;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;display:block}.action-text__description[data-v-fa684b48]{display:block;white-space:pre-wrap;font-size:var(--font-size-small);line-height:var(--default-line-height);color:var(--color-text-maxcontrast);cursor:pointer}.action-text__menu-icon[data-v-fa684b48]{margin-inline:auto calc((var(--default-clickable-area) - 16px) / 2 * -1)}.action--disabled[data-v-fa684b48]{pointer-events:none;opacity:.5}.action--disabled[data-v-fa684b48]:hover,.action--disabled[data-v-fa684b48]:focus{cursor:default;opacity:.5}.action--disabled[data-v-fa684b48] *{opacity:1!important}.action-text[data-v-fa684b48],.action-text span[data-v-fa684b48]{cursor:default}.mention[data-v-85edf4b2]{display:contents;white-space:nowrap}.notification[data-v-58882784] img.notification-icon{display:flex;width:32px;height:32px;filter:var(--background-invert-if-dark)}.notification[data-v-58882784] .rich-text--wrapper{white-space:pre-wrap;overflow-wrap:break-word}.notification .notification-subject[data-v-58882784]{padding:4px}.notification a.notification-subject[data-v-58882784]:focus-visible{box-shadow:inset 0 0 0 2px var(--color-main-text)!important}.notification-container[data-v-344260f0]{overflow:hidden}.notification-container[data-v-344260f0],.notification-container[data-v-344260f0] *,.notification-container[data-v-344260f0] *:before,.notification-container[data-v-344260f0] *:after{box-sizing:border-box}.notification-container .notification-wrapper[data-v-344260f0]{display:flex;flex-direction:column;max-height:calc(100vh - 250px);overflow:auto}.notification-container .dismiss-all[data-v-344260f0]{padding:calc(2 * var(--default-grid-baseline));border-top:1px solid var(--color-border)}.icon-alert-outline[data-v-344260f0]{background-size:64px;width:64px;height:64px}.fade-enter-active[data-v-344260f0],.fade-leave-active[data-v-344260f0]{transition:opacity var(--animation-quick) ease}.fade-enter-from[data-v-344260f0],.fade-leave-to[data-v-344260f0]{opacity:0}.list-move[data-v-344260f0],.list-enter-active[data-v-344260f0],.list-leave-active[data-v-344260f0]{transition:all var(--animation-quick) ease}.list-enter-from[data-v-344260f0],.list-leave-to[data-v-344260f0]{opacity:0;transform:translate(30px)}.list-leave-active[data-v-344260f0]{width:100%} diff --git a/js/NotificationsApp-CRRsckwj.chunk.mjs b/js/NotificationsApp-BOamGkxL.chunk.mjs similarity index 99% rename from js/NotificationsApp-CRRsckwj.chunk.mjs rename to js/NotificationsApp-BOamGkxL.chunk.mjs index 0e2a275d5..612a1ca07 100644 --- a/js/NotificationsApp-CRRsckwj.chunk.mjs +++ b/js/NotificationsApp-BOamGkxL.chunk.mjs @@ -1,4 +1,4 @@ -const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=[window.OC.filePath('notifications', '', 'js/index-BgKnKn3-.chunk.mjs'),window.OC.filePath('notifications', '', 'js/_plugin-vue_export-helper-CgN6rZFt.chunk.mjs'),window.OC.filePath('notifications', '', 'js/style-D9pbF5Ey.chunk.mjs'),window.OC.filePath('notifications', '', 'css/style-BDBO5m-f.chunk.css'),window.OC.filePath('notifications', '', 'css/_plugin-vue_export-helper-CdPWKeL0.chunk.css'),window.OC.filePath('notifications', '', 'js/vite-preload-helper-CpjhnH87.chunk.mjs'),window.OC.filePath('notifications', '', 'js/BrowserStorage-DcWn_QZV.chunk.mjs'),window.OC.filePath('notifications', '', 'css/BrowserStorage-DWlHHNhc.chunk.css')])))=>i.map(i=>d[i]); +const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=[window.OC.filePath('notifications', '', 'js/index-C6tzCbpH.chunk.mjs'),window.OC.filePath('notifications', '', 'js/_plugin-vue_export-helper-CgN6rZFt.chunk.mjs'),window.OC.filePath('notifications', '', 'js/style-D9pbF5Ey.chunk.mjs'),window.OC.filePath('notifications', '', 'css/style-BDBO5m-f.chunk.css'),window.OC.filePath('notifications', '', 'css/_plugin-vue_export-helper-CdPWKeL0.chunk.css'),window.OC.filePath('notifications', '', 'js/vite-preload-helper-CpjhnH87.chunk.mjs'),window.OC.filePath('notifications', '', 'js/BrowserStorage-DcWn_QZV.chunk.mjs'),window.OC.filePath('notifications', '', 'css/BrowserStorage-DWlHHNhc.chunk.css')])))=>i.map(i=>d[i]); /*! third party licenses: js/vendor.LICENSE.txt */ import{g as getLanguage,b as _export_sfc,p as purify,e as process$1,f as commonjsGlobal,B as Buffer,h as requireValid,i as requireMajor,j as requireDist$8,k as getCanonicalLocale,d as t,r as register,m as t2,o as onKeyStroke,n as createSharedComposable,u as useMutationObserver,q as usePreferredDark,w as createElementId,x as onClickOutside$1,y as useTrapStackControl,z as createFocusTrap,A as getTrapStack,C as NcButton,_ as _export_sfc$1,D as getDefaultExportFromCjs,l as loadState$1,E as logger$1,F as w,G as f,R as RouterLink,H as useElementSize,I as useIntersectionObserver,J as t8,K as h$1,L as t43,M as t39,O as t23,P as t24,Q as t41,S as t31,T as t19,U as t12,N as NcCheckboxRadioSwitch,V as getCurrentUser,c as cancelableClient,v,t as translate,W as noop,X as isIOS,Y as isClient,Z as toArray,$ as watchImmediate,a0 as isObject,a1 as tryOnScopeDispose,a2 as toRef$1,a3 as t3,a4 as _,a5 as t11,a6 as NC_ACTIONS_CLOSE_MENU,a7 as NC_ACTIONS_IS_SEMANTIC_MENU,a8 as NcLoadingIcon,a9 as NcActions,aa as IconDotsHorizontal,ab as unsubscribe,ac as subscribe,ad as distExports$1,ae as t10,af as NcPopover,s as showError,ag as emit,ah as d,ai as getRequestToken}from"./_plugin-vue_export-helper-CgN6rZFt.chunk.mjs";import{m as defineComponent,q as useCssVars,s as computed,f as createElementBlock,o as openBlock,b as createBaseVNode,x as normalizeClass,g as createCommentVNode,n as renderSlot,t as toDisplayString,j as createTextVNode,y as toValue,l as ref$1,z as watchEffect,A as onUnmounted,B as readonly,C as inject,D as watch,E as useTemplateRef,G as nextTick,a as createBlock,w as withCtx,e as createVNode,h as withDirectives,u as unref,H as withModifiers,I as vShow,J as resolveDynamicComponent,p as mergeProps,K as toRef,L as h,r as resolveComponent,M as normalizeStyle,F as Fragment,i as renderList,N as shallowRef,O as mergeModels,P as useModel,Q as resolveDirective,R as createSlots,S as warn,T as Transition,U as TransitionGroup}from"./style-D9pbF5Ey.chunk.mjs";import{_ as __vitePreload}from"./vite-preload-helper-CpjhnH87.chunk.mjs";import{B as BrowserStorage}from"./BrowserStorage-DcWn_QZV.chunk.mjs";const appName="notifications",appVersion="5.0.0-dev.0";function formatRelativeTime(n=Date.now(),p={}){const c={ignoreSeconds:!1,language:getLanguage(),relativeTime:"long",...p},l=new Date(n),x=new Intl.RelativeTimeFormat([c.language,getLanguage()],{numeric:"auto",style:c.relativeTime}),o=(l.getTime()-Date.now())/1e3;if(Math.abs(o)<59.5)return c.ignoreSeconds||x.format(Math.round(o),"second");const E=o/60;if(Math.abs(E)<=59)return x.format(Math.round(E),"minute");const A=E/60;if(Math.abs(A)<23.5)return x.format(Math.round(A),"hour");const B=A/24;if(Math.abs(B)<6.5)return x.format(Math.round(B),"day");if(Math.abs(B)<27.5){const g=B/7;return x.format(Math.round(g),"week")}const b=B/30,R=Math.abs(b)<11?{month:c.relativeTime,day:"numeric"}:{year:c.relativeTime==="narrow"?"2-digit":"numeric",month:c.relativeTime};return new Intl.DateTimeFormat([c.language,getLanguage()],R).format(l)}const _hoisted_1$k=["aria-hidden","aria-label"],_hoisted_2$h={key:0,viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg"},_hoisted_3$e=["d"],_hoisted_4$b=["innerHTML"],_sfc_main$m=defineComponent({__name:"NcIconSvgWrapper",props:{directional:{type:Boolean},inline:{type:Boolean},svg:{default:""},name:{default:void 0},path:{default:""},size:{default:20}},setup(n){useCssVars(x=>({"0c3ef411":c.value}));const p=n,c=computed(()=>typeof p.size=="number"?`${p.size}px`:p.size),l=computed(()=>{if(!p.svg||p.path)return;const x=purify.sanitize(p.svg),o=new DOMParser().parseFromString(x,"image/svg+xml");return o.querySelector("parsererror")?"":(o.documentElement.id&&o.documentElement.removeAttribute("id"),o.documentElement.outerHTML)});return(x,o)=>(openBlock(),createElementBlock("span",{"aria-hidden":x.name?void 0:"true","aria-label":x.name||void 0,class:normalizeClass(["icon-vue",{"icon-vue--directional":x.directional,"icon-vue--inline":x.inline}]),role:"img"},[l.value?(openBlock(),createElementBlock("span",{key:1,innerHTML:l.value},null,8,_hoisted_4$b)):(openBlock(),createElementBlock("svg",_hoisted_2$h,[createBaseVNode("path",{d:x.path},null,8,_hoisted_3$e)]))],10,_hoisted_1$k))}}),NcIconSvgWrapper=_export_sfc(_sfc_main$m,[["__scopeId","data-v-5a43cff9"]]);var mdiCheck="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z",mdiChevronRight="M8.59,16.58L13.17,12L8.59,7.41L10,6L16,12L10,18L8.59,16.58Z",dist$7={},dist$6={},dist$5={},hasRequiredDist$7;function requireDist$7(){return hasRequiredDist$7||(hasRequiredDist$7=1,function(n){Object.defineProperty(n,Symbol.toStringTag,{value:"Module"});function p(c,l,x){const o=document.querySelector(`#initial-state-${c}-${l}`);if(o===null){if(x!==void 0)return x;throw new Error(`Could not find initial state ${l} of ${c}`)}try{return JSON.parse(atob(o.value))}catch{throw new Error(`Could not parse initial state ${l} of ${c}`)}}n.loadState=p}(dist$5)),dist$5}var hasRequiredDist$6;function requireDist$6(){return hasRequiredDist$6||(hasRequiredDist$6=1,function(n){Object.defineProperty(n,Symbol.toStringTag,{value:"Module"});const p=requireDist$7();function c(){try{return p.loadState("core","capabilities")}catch{return console.debug("Could not find capabilities initial state fall back to _oc_capabilities"),"_oc_capabilities"in window?window._oc_capabilities:{}}}n.getCapabilities=c}(dist$6)),dist$6}var dist$4={},axios_1,hasRequiredAxios;function requireAxios(){if(hasRequiredAxios)return axios_1;hasRequiredAxios=1;function n(K,ie){return function(){return K.apply(ie,arguments)}}const{toString:p}=Object.prototype,{getPrototypeOf:c}=Object,{iterator:l,toStringTag:x}=Symbol,o=(K=>ie=>{const ue=p.call(ie);return K[ue]||(K[ue]=ue.slice(8,-1).toLowerCase())})(Object.create(null)),E=K=>(K=K.toLowerCase(),ie=>o(ie)===K),A=K=>ie=>typeof ie===K,{isArray:B}=Array,b=A("undefined");function R(K){return K!==null&&!b(K)&&K.constructor!==null&&!b(K.constructor)&&$(K.constructor.isBuffer)&&K.constructor.isBuffer(K)}const g=E("ArrayBuffer");function S(K){let ie;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?ie=ArrayBuffer.isView(K):ie=K&&K.buffer&&g(K.buffer),ie}const q=A("string"),$=A("function"),I=A("number"),P=K=>K!==null&&typeof K=="object",O=K=>K===!0||K===!1,L=K=>{if(o(K)!=="object")return!1;const ie=c(K);return(ie===null||ie===Object.prototype||Object.getPrototypeOf(ie)===null)&&!(x in K)&&!(l in K)},F=K=>{if(!P(K)||R(K))return!1;try{return Object.keys(K).length===0&&Object.getPrototypeOf(K)===Object.prototype}catch{return!1}},U=E("Date"),Q=E("File"),Y=E("Blob"),ce=E("FileList"),le=K=>P(K)&&$(K.pipe),ne=K=>{let ie;return K&&(typeof FormData=="function"&&K instanceof FormData||$(K.append)&&((ie=o(K))==="formdata"||ie==="object"&&$(K.toString)&&K.toString()==="[object FormData]"))},he=E("URLSearchParams"),[r,a,s,m]=["ReadableStream","Request","Response","Headers"].map(E),k=K=>K.trim?K.trim():K.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"");function C(K,ie,{allOwnKeys:ue=!1}={}){if(K===null||typeof K>"u")return;let fe,ve;if(typeof K!="object"&&(K=[K]),B(K))for(fe=0,ve=K.length;fe0;)if(ve=ue[fe],ie===ve.toLowerCase())return ve;return null}const M=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:commonjsGlobal,i=K=>!b(K)&&K!==M;function y(){const{caseless:K,skipUndefined:ie}=i(this)&&this||{},ue={},fe=(ve,Re)=>{const Te=K&&T(ue,Re)||Re;L(ue[Te])&&L(ve)?ue[Te]=y(ue[Te],ve):L(ve)?ue[Te]=y({},ve):B(ve)?ue[Te]=ve.slice():(!ie||!b(ve))&&(ue[Te]=ve)};for(let ve=0,Re=arguments.length;ve(C(ie,(ve,Re)=>{ue&&$(ve)?K[Re]=n(ve,ue):K[Re]=ve},{allOwnKeys:fe}),K),j=K=>(K.charCodeAt(0)===65279&&(K=K.slice(1)),K),z=(K,ie,ue,fe)=>{K.prototype=Object.create(ie.prototype,fe),K.prototype.constructor=K,Object.defineProperty(K,"super",{value:ie.prototype}),ue&&Object.assign(K.prototype,ue)},X=(K,ie,ue,fe)=>{let ve,Re,Te;const Je={};if(ie=ie||{},K==null)return ie;do{for(ve=Object.getOwnPropertyNames(K),Re=ve.length;Re-- >0;)Te=ve[Re],(!fe||fe(Te,K,ie))&&!Je[Te]&&(ie[Te]=K[Te],Je[Te]=!0);K=ue!==!1&&c(K)}while(K&&(!ue||ue(K,ie))&&K!==Object.prototype);return ie},te=(K,ie,ue)=>{K=String(K),(ue===void 0||ue>K.length)&&(ue=K.length),ue-=ie.length;const fe=K.indexOf(ie,ue);return fe!==-1&&fe===ue},ee=K=>{if(!K)return null;if(B(K))return K;let ie=K.length;if(!I(ie))return null;const ue=new Array(ie);for(;ie-- >0;)ue[ie]=K[ie];return ue},G=(K=>ie=>K&&ie instanceof K)(typeof Uint8Array<"u"&&c(Uint8Array)),V=(K,ie)=>{const ue=(K&&K[l]).call(K);let fe;for(;(fe=ue.next())&&!fe.done;){const ve=fe.value;ie.call(K,ve[0],ve[1])}},oe=(K,ie)=>{let ue;const fe=[];for(;(ue=K.exec(ie))!==null;)fe.push(ue);return fe},ye=E("HTMLFormElement"),Z=K=>K.toLowerCase().replace(/[-_\s]([a-z\d])(\w*)/g,function(ie,ue,fe){return ue.toUpperCase()+fe}),J=(({hasOwnProperty:K})=>(ie,ue)=>K.call(ie,ue))(Object.prototype),_e=E("RegExp"),pe=(K,ie)=>{const ue=Object.getOwnPropertyDescriptors(K),fe={};C(ue,(ve,Re)=>{let Te;(Te=ie(ve,Re,K))!==!1&&(fe[Re]=Te||ve)}),Object.defineProperties(K,fe)},Me=K=>{pe(K,(ie,ue)=>{if($(K)&&["arguments","caller","callee"].indexOf(ue)!==-1)return!1;const fe=K[ue];if($(fe)){if(ie.enumerable=!1,"writable"in ie){ie.writable=!1;return}ie.set||(ie.set=()=>{throw Error("Can not rewrite read-only method '"+ue+"'")})}})},Ke=(K,ie)=>{const ue={},fe=ve=>{ve.forEach(Re=>{ue[Re]=!0})};return B(K)?fe(K):fe(String(K).split(ie)),ue},ke=()=>{},Le=(K,ie)=>K!=null&&Number.isFinite(K=+K)?K:ie;function Be(K){return!!(K&&$(K.append)&&K[x]==="FormData"&&K[l])}const xe=K=>{const ie=new Array(10),ue=(fe,ve)=>{if(P(fe)){if(ie.indexOf(fe)>=0)return;if(R(fe))return fe;if(!("toJSON"in fe)){ie[ve]=fe;const Re=B(fe)?[]:{};return C(fe,(Te,Je)=>{const nt=ue(Te,ve+1);!b(nt)&&(Re[Je]=nt)}),ie[ve]=void 0,Re}}return fe};return ue(K,0)},Ie=E("AsyncFunction"),Ye=K=>K&&(P(K)||$(K))&&$(K.then)&&$(K.catch),Se=((K,ie)=>K?setImmediate:ie?((ue,fe)=>(M.addEventListener("message",({source:ve,data:Re})=>{ve===M&&Re===ue&&fe.length&&fe.shift()()},!1),ve=>{fe.push(ve),M.postMessage(ue,"*")}))(`axios@${Math.random()}`,[]):ue=>setTimeout(ue))(typeof setImmediate=="function",$(M.postMessage)),Ne=typeof queueMicrotask<"u"?queueMicrotask.bind(M):typeof process$1<"u"&&process$1.nextTick||Se;var we={isArray:B,isArrayBuffer:g,isBuffer:R,isFormData:ne,isArrayBufferView:S,isString:q,isNumber:I,isBoolean:O,isObject:P,isPlainObject:L,isEmptyObject:F,isReadableStream:r,isRequest:a,isResponse:s,isHeaders:m,isUndefined:b,isDate:U,isFile:Q,isBlob:Y,isRegExp:_e,isFunction:$,isStream:le,isURLSearchParams:he,isTypedArray:G,isFileList:ce,forEach:C,merge:y,extend:D,trim:k,stripBOM:j,inherits:z,toFlatObject:X,kindOf:o,kindOfTest:E,endsWith:te,toArray:ee,forEachEntry:V,matchAll:oe,isHTMLForm:ye,hasOwnProperty:J,hasOwnProp:J,reduceDescriptors:pe,freezeMethods:Me,toObjectSet:Ke,toCamelCase:Z,noop:ke,toFiniteNumber:Le,findKey:T,global:M,isContextDefined:i,isSpecCompliantForm:Be,toJSONObject:xe,isAsyncFn:Ie,isThenable:Ye,setImmediate:Se,asap:Ne,isIterable:K=>K!=null&&$(K[l])};function se(K,ie,ue,fe,ve){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=K,this.name="AxiosError",ie&&(this.code=ie),ue&&(this.config=ue),fe&&(this.request=fe),ve&&(this.response=ve,this.status=ve.status?ve.status:null)}we.inherits(se,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:we.toJSONObject(this.config),code:this.code,status:this.status}}});const ge=se.prototype,Xe={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(K=>{Xe[K]={value:K}}),Object.defineProperties(se,Xe),Object.defineProperty(ge,"isAxiosError",{value:!0}),se.from=(K,ie,ue,fe,ve,Re)=>{const Te=Object.create(ge);we.toFlatObject(K,Te,function(Qe){return Qe!==Error.prototype},Qe=>Qe!=="isAxiosError");const Je=K&&K.message?K.message:"Error",nt=ie==null&&K?K.code:ie;return se.call(Te,Je,nt,ue,fe,ve),K&&Te.cause==null&&Object.defineProperty(Te,"cause",{value:K,configurable:!0}),Te.name=K&&K.name||"Error",Re&&Object.assign(Te,Re),Te};var Ae=null;function Oe(K){return we.isPlainObject(K)||we.isArray(K)}function at(K){return we.endsWith(K,"[]")?K.slice(0,-2):K}function Pe(K,ie,ue){return K?K.concat(ie).map(function(fe,ve){return fe=at(fe),!ue&&ve?"["+fe+"]":fe}).join(ue?".":""):ie}function Ve(K){return we.isArray(K)&&!K.some(Oe)}const st=we.toFlatObject(we,{},null,function(K){return/^is[A-Z]/.test(K)});function Ce(K,ie,ue){if(!we.isObject(K))throw new TypeError("target must be an object");ie=ie||new FormData,ue=we.toFlatObject(ue,{metaTokens:!0,dots:!1,indexes:!1},!1,function(mt,et){return!we.isUndefined(et[mt])});const fe=ue.metaTokens,ve=ue.visitor||Qe,Re=ue.dots,Te=ue.indexes,Je=(ue.Blob||typeof Blob<"u"&&Blob)&&we.isSpecCompliantForm(ie);if(!we.isFunction(ve))throw new TypeError("visitor must be a function");function nt(mt){if(mt===null)return"";if(we.isDate(mt))return mt.toISOString();if(we.isBoolean(mt))return mt.toString();if(!Je&&we.isBlob(mt))throw new se("Blob is not supported. Use a Buffer instead.");return we.isArrayBuffer(mt)||we.isTypedArray(mt)?Je&&typeof Blob=="function"?new Blob([mt]):Buffer.from(mt):mt}function Qe(mt,et,ot){let Ot=mt;if(mt&&!ot&&typeof mt=="object"){if(we.endsWith(et,"{}"))et=fe?et:et.slice(0,-2),mt=JSON.stringify(mt);else if(we.isArray(mt)&&Ve(mt)||(we.isFileList(mt)||we.endsWith(et,"[]"))&&(Ot=we.toArray(mt)))return et=at(et),Ot.forEach(function(Lt,Pt){!(we.isUndefined(Lt)||Lt===null)&&ie.append(Te===!0?Pe([et],Pt,Re):Te===null?et:et+"[]",nt(Lt))}),!1}return Oe(mt)?!0:(ie.append(Pe(ot,et,Re),nt(mt)),!1)}const tt=[],dt=Object.assign(st,{defaultVisitor:Qe,convertValue:nt,isVisitable:Oe});function $t(mt,et){if(!we.isUndefined(mt)){if(tt.indexOf(mt)!==-1)throw Error("Circular reference detected in "+et.join("."));tt.push(mt),we.forEach(mt,function(ot,Ot){(!(we.isUndefined(ot)||ot===null)&&ve.call(ie,ot,we.isString(Ot)?Ot.trim():Ot,et,dt))===!0&&$t(ot,et?et.concat(Ot):[Ot])}),tt.pop()}}if(!we.isObject(K))throw new TypeError("data must be an object");return $t(K),ie}function je(K){const ie={"!":"%21","'":"%27","(":"%28",")":"%29","~":"%7E","%20":"+","%00":"\0"};return encodeURIComponent(K).replace(/[!'()~]|%20|%00/g,function(ue){return ie[ue]})}function lt(K,ie){this._pairs=[],K&&Ce(K,this,ie)}const $e=lt.prototype;$e.append=function(K,ie){this._pairs.push([K,ie])},$e.toString=function(K){const ie=K?function(ue){return K.call(this,ue,je)}:je;return this._pairs.map(function(ue){return ie(ue[0])+"="+ie(ue[1])},"").join("&")};function We(K){return encodeURIComponent(K).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+")}function pt(K,ie,ue){if(!ie)return K;const fe=ue&&ue.encode||We;we.isFunction(ue)&&(ue={serialize:ue});const ve=ue&&ue.serialize;let Re;if(ve?Re=ve(ie,ue):Re=we.isURLSearchParams(ie)?ie.toString():new lt(ie,ue).toString(fe),Re){const Te=K.indexOf("#");Te!==-1&&(K=K.slice(0,Te)),K+=(K.indexOf("?")===-1?"?":"&")+Re}return K}class ze{constructor(){this.handlers=[]}use(ie,ue,fe){return this.handlers.push({fulfilled:ie,rejected:ue,synchronous:fe?fe.synchronous:!1,runWhen:fe?fe.runWhen:null}),this.handlers.length-1}eject(ie){this.handlers[ie]&&(this.handlers[ie]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(ie){we.forEach(this.handlers,function(ue){ue!==null&&ie(ue)})}}var He=ze,ut={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},Ue=typeof URLSearchParams<"u"?URLSearchParams:lt,Ge=typeof FormData<"u"?FormData:null,ht=typeof Blob<"u"?Blob:null,Fe={isBrowser:!0,classes:{URLSearchParams:Ue,FormData:Ge,Blob:ht},protocols:["http","https","file","blob","url","data"]};const N=typeof window<"u"&&typeof document<"u",W=typeof navigator=="object"&&navigator||void 0,H=N&&(!W||["ReactNative","NativeScript","NS"].indexOf(W.product)<0),ae=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function",be=N&&window.location.href||"http://localhost";var de=Object.freeze({__proto__:null,hasBrowserEnv:N,hasStandardBrowserWebWorkerEnv:ae,hasStandardBrowserEnv:H,navigator:W,origin:be}),me={...de,...Fe};function it(K,ie){return Ce(K,new me.classes.URLSearchParams,{visitor:function(ue,fe,ve,Re){return me.isNode&&we.isBuffer(ue)?(this.append(fe,ue.toString("base64")),!1):Re.defaultVisitor.apply(this,arguments)},...ie})}function qe(K){return we.matchAll(/\w+|\[(\w*)]/g,K).map(ie=>ie[0]==="[]"?"":ie[1]||ie[0])}function De(K){const ie={},ue=Object.keys(K);let fe;const ve=ue.length;let Re;for(fe=0;fe=ue.length;return Te=!Te&&we.isArray(ve)?ve.length:Te,nt?(we.hasOwnProp(ve,Te)?ve[Te]=[ve[Te],fe]:ve[Te]=fe,!Je):((!ve[Te]||!we.isObject(ve[Te]))&&(ve[Te]=[]),ie(ue,fe,ve[Te],Re)&&we.isArray(ve[Te])&&(ve[Te]=De(ve[Te])),!Je)}if(we.isFormData(K)&&we.isFunction(K.entries)){const ue={};return we.forEachEntry(K,(fe,ve)=>{ie(qe(fe),ve,ue,0)}),ue}return null}function Ee(K,ie,ue){if(we.isString(K))try{return(ie||JSON.parse)(K),we.trim(K)}catch(fe){if(fe.name!=="SyntaxError")throw fe}return(ue||JSON.stringify)(K)}const Ze={transitional:ut,adapter:["xhr","http","fetch"],transformRequest:[function(K,ie){const ue=ie.getContentType()||"",fe=ue.indexOf("application/json")>-1,ve=we.isObject(K);if(ve&&we.isHTMLForm(K)&&(K=new FormData(K)),we.isFormData(K))return fe?JSON.stringify(rt(K)):K;if(we.isArrayBuffer(K)||we.isBuffer(K)||we.isStream(K)||we.isFile(K)||we.isBlob(K)||we.isReadableStream(K))return K;if(we.isArrayBufferView(K))return K.buffer;if(we.isURLSearchParams(K))return ie.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),K.toString();let Re;if(ve){if(ue.indexOf("application/x-www-form-urlencoded")>-1)return it(K,this.formSerializer).toString();if((Re=we.isFileList(K))||ue.indexOf("multipart/form-data")>-1){const Te=this.env&&this.env.FormData;return Ce(Re?{"files[]":K}:K,Te&&new Te,this.formSerializer)}}return ve||fe?(ie.setContentType("application/json",!1),Ee(K)):K}],transformResponse:[function(K){const ie=this.transitional||Ze.transitional,ue=ie&&ie.forcedJSONParsing,fe=this.responseType==="json";if(we.isResponse(K)||we.isReadableStream(K))return K;if(K&&we.isString(K)&&(ue&&!this.responseType||fe)){const ve=!(ie&&ie.silentJSONParsing)&&fe;try{return JSON.parse(K,this.parseReviver)}catch(Re){if(ve)throw Re.name==="SyntaxError"?se.from(Re,se.ERR_BAD_RESPONSE,this,null,this.response):Re}}return K}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:me.classes.FormData,Blob:me.classes.Blob},validateStatus:function(K){return K>=200&&K<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};we.forEach(["delete","get","head","post","put","patch"],K=>{Ze.headers[K]={}});var ct=Ze;const ft=we.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]);var xt=K=>{const ie={};let ue,fe,ve;return K&&K.split(` `).forEach(function(Re){ve=Re.indexOf(":"),ue=Re.substring(0,ve).trim().toLowerCase(),fe=Re.substring(ve+1).trim(),!(!ue||ie[ue]&&ft[ue])&&(ue==="set-cookie"?ie[ue]?ie[ue].push(fe):ie[ue]=[fe]:ie[ue]=ie[ue]?ie[ue]+", "+fe:fe)}),ie};const kt=Symbol("internals");function bt(K){return K&&String(K).trim().toLowerCase()}function vt(K){return K===!1||K==null?K:we.isArray(K)?K.map(vt):String(K)}function Et(K){const ie=Object.create(null),ue=/([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g;let fe;for(;fe=ue.exec(K);)ie[fe[1]]=fe[2];return ie}const Bt=K=>/^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(K.trim());function _t(K,ie,ue,fe,ve){if(we.isFunction(fe))return fe.call(this,ie,ue);if(ve&&(ie=ue),!!we.isString(ie)){if(we.isString(fe))return ie.indexOf(fe)!==-1;if(we.isRegExp(fe))return fe.test(ie)}}function qt(K){return K.trim().toLowerCase().replace(/([a-z\d])(\w*)/g,(ie,ue,fe)=>ue.toUpperCase()+fe)}function Rt(K,ie){const ue=we.toCamelCase(" "+ie);["get","set","has"].forEach(fe=>{Object.defineProperty(K,fe+ue,{value:function(ve,Re,Te){return this[fe].call(this,ie,ve,Re,Te)},configurable:!0})})}class wt{constructor(ie){ie&&this.set(ie)}set(ie,ue,fe){const ve=this;function Re(Je,nt,Qe){const tt=bt(nt);if(!tt)throw new Error("header name must be a non-empty string");const dt=we.findKey(ve,tt);(!dt||ve[dt]===void 0||Qe===!0||Qe===void 0&&ve[dt]!==!1)&&(ve[dt||nt]=vt(Je))}const Te=(Je,nt)=>we.forEach(Je,(Qe,tt)=>Re(Qe,tt,nt));if(we.isPlainObject(ie)||ie instanceof this.constructor)Te(ie,ue);else if(we.isString(ie)&&(ie=ie.trim())&&!Bt(ie))Te(xt(ie),ue);else if(we.isObject(ie)&&we.isIterable(ie)){let Je={},nt,Qe;for(const tt of ie){if(!we.isArray(tt))throw TypeError("Object iterator must return a key-value pair");Je[Qe=tt[0]]=(nt=Je[Qe])?we.isArray(nt)?[...nt,tt[1]]:[nt,tt[1]]:tt[1]}Te(Je,ue)}else ie!=null&&Re(ue,ie,fe);return this}get(ie,ue){if(ie=bt(ie),ie){const fe=we.findKey(this,ie);if(fe){const ve=this[fe];if(!ue)return ve;if(ue===!0)return Et(ve);if(we.isFunction(ue))return ue.call(this,ve,fe);if(we.isRegExp(ue))return ue.exec(ve);throw new TypeError("parser must be boolean|regexp|function")}}}has(ie,ue){if(ie=bt(ie),ie){const fe=we.findKey(this,ie);return!!(fe&&this[fe]!==void 0&&(!ue||_t(this,this[fe],fe,ue)))}return!1}delete(ie,ue){const fe=this;let ve=!1;function Re(Te){if(Te=bt(Te),Te){const Je=we.findKey(fe,Te);Je&&(!ue||_t(fe,fe[Je],Je,ue))&&(delete fe[Je],ve=!0)}}return we.isArray(ie)?ie.forEach(Re):Re(ie),ve}clear(ie){const ue=Object.keys(this);let fe=ue.length,ve=!1;for(;fe--;){const Re=ue[fe];(!ie||_t(this,this[Re],Re,ie,!0))&&(delete this[Re],ve=!0)}return ve}normalize(ie){const ue=this,fe={};return we.forEach(this,(ve,Re)=>{const Te=we.findKey(fe,Re);if(Te){ue[Te]=vt(ve),delete ue[Re];return}const Je=ie?qt(Re):String(Re).trim();Je!==Re&&delete ue[Re],ue[Je]=vt(ve),fe[Je]=!0}),this}concat(...ie){return this.constructor.concat(this,...ie)}toJSON(ie){const ue=Object.create(null);return we.forEach(this,(fe,ve)=>{fe!=null&&fe!==!1&&(ue[ve]=ie&&we.isArray(fe)?fe.join(", "):fe)}),ue}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map(([ie,ue])=>ie+": "+ue).join(` @@ -33,7 +33,7 @@ import{g as getLanguage,b as _export_sfc,p as purify,e as process$1,f as commonj `))+1))}const E="#".repeat(x),A=c.enter("headingAtx"),B=c.enter("phrasing");o.move(E+" ");let b=c.containerPhrasing(n,{before:"# ",after:` `,...o.current()});return/^[\t ]/.test(b)&&(b=encodeCharacterReference(b.charCodeAt(0))+b.slice(1)),b=b?E+" "+b:E,c.options.closeAtx&&(b+=" "+E),B(),A(),b}html.peek=htmlPeek;function html(n){return n.value||""}function htmlPeek(){return"<"}image.peek=imagePeek;function image(n,p,c,l){const x=checkQuote(c),o=x==='"'?"Quote":"Apostrophe",E=c.enter("image");let A=c.enter("label");const B=c.createTracker(l);let b=B.move("![");return b+=B.move(c.safe(n.alt,{before:b,after:"]",...B.current()})),b+=B.move("]("),A(),!n.url&&n.title||/[\0- \u007F]/.test(n.url)?(A=c.enter("destinationLiteral"),b+=B.move("<"),b+=B.move(c.safe(n.url,{before:b,after:">",...B.current()})),b+=B.move(">")):(A=c.enter("destinationRaw"),b+=B.move(c.safe(n.url,{before:b,after:n.title?" ":")",...B.current()}))),A(),n.title&&(A=c.enter(`title${o}`),b+=B.move(" "+x),b+=B.move(c.safe(n.title,{before:b,after:x,...B.current()})),b+=B.move(x),A()),b+=B.move(")"),E(),b}function imagePeek(){return"!"}imageReference.peek=imageReferencePeek;function imageReference(n,p,c,l){const x=n.referenceType,o=c.enter("imageReference");let E=c.enter("label");const A=c.createTracker(l);let B=A.move("![");const b=c.safe(n.alt,{before:B,after:"]",...A.current()});B+=A.move(b+"]["),E();const R=c.stack;c.stack=[],E=c.enter("reference");const g=c.safe(c.associationId(n),{before:B,after:"]",...A.current()});return E(),c.stack=R,o(),x==="full"||!b||b!==g?B+=A.move(g+"]"):x==="shortcut"?B=B.slice(0,-1):B+=A.move("]"),B}function imageReferencePeek(){return"!"}inlineCode.peek=inlineCodePeek;function inlineCode(n,p,c){let l=n.value||"",x="`",o=-1;for(;new RegExp("(^|[^`])"+x+"([^`]|$)").test(l);)x+="`";for(/[^ \r\n]/.test(l)&&(/^[ \r\n]/.test(l)&&/[ \r\n]$/.test(l)||/^`|`$/.test(l))&&(l=" "+l+" ");++o\u007F]/.test(n.url))}link.peek=linkPeek;function link(n,p,c,l){const x=checkQuote(c),o=x==='"'?"Quote":"Apostrophe",E=c.createTracker(l);let A,B;if(formatLinkAsAutolink(n,c)){const R=c.stack;c.stack=[],A=c.enter("autolink");let g=E.move("<");return g+=E.move(c.containerPhrasing(n,{before:g,after:">",...E.current()})),g+=E.move(">"),A(),c.stack=R,g}A=c.enter("link"),B=c.enter("label");let b=E.move("[");return b+=E.move(c.containerPhrasing(n,{before:b,after:"](",...E.current()})),b+=E.move("]("),B(),!n.url&&n.title||/[\0- \u007F]/.test(n.url)?(B=c.enter("destinationLiteral"),b+=E.move("<"),b+=E.move(c.safe(n.url,{before:b,after:">",...E.current()})),b+=E.move(">")):(B=c.enter("destinationRaw"),b+=E.move(c.safe(n.url,{before:b,after:n.title?" ":")",...E.current()}))),B(),n.title&&(B=c.enter(`title${o}`),b+=E.move(" "+x),b+=E.move(c.safe(n.title,{before:b,after:x,...E.current()})),b+=E.move(x),B()),b+=E.move(")"),A(),b}function linkPeek(n,p,c){return formatLinkAsAutolink(n,c)?"<":"["}linkReference.peek=linkReferencePeek;function linkReference(n,p,c,l){const x=n.referenceType,o=c.enter("linkReference");let E=c.enter("label");const A=c.createTracker(l);let B=A.move("[");const b=c.containerPhrasing(n,{before:B,after:"]",...A.current()});B+=A.move(b+"]["),E();const R=c.stack;c.stack=[],E=c.enter("reference");const g=c.safe(c.associationId(n),{before:B,after:"]",...A.current()});return E(),c.stack=R,o(),x==="full"||!b||b!==g?B+=A.move(g+"]"):x==="shortcut"?B=B.slice(0,-1):B+=A.move("]"),B}function linkReferencePeek(){return"["}function checkBullet(n){const p=n.options.bullet||"*";if(p!=="*"&&p!=="+"&&p!=="-")throw new Error("Cannot serialize items with `"+p+"` for `options.bullet`, expected `*`, `+`, or `-`");return p}function checkBulletOther(n){const p=checkBullet(n),c=n.options.bulletOther;if(!c)return p==="*"?"-":"*";if(c!=="*"&&c!=="+"&&c!=="-")throw new Error("Cannot serialize items with `"+c+"` for `options.bulletOther`, expected `*`, `+`, or `-`");if(c===p)throw new Error("Expected `bullet` (`"+p+"`) and `bulletOther` (`"+c+"`) to be different");return c}function checkBulletOrdered(n){const p=n.options.bulletOrdered||".";if(p!=="."&&p!==")")throw new Error("Cannot serialize items with `"+p+"` for `options.bulletOrdered`, expected `.` or `)`");return p}function checkRule(n){const p=n.options.rule||"*";if(p!=="*"&&p!=="-"&&p!=="_")throw new Error("Cannot serialize rules with `"+p+"` for `options.rule`, expected `*`, `-`, or `_`");return p}function list(n,p,c,l){const x=c.enter("list"),o=c.bulletCurrent;let E=n.ordered?checkBulletOrdered(c):checkBullet(c);const A=n.ordered?E==="."?")":".":checkBulletOther(c);let B=p&&c.bulletLastUsed?E===c.bulletLastUsed:!1;if(!n.ordered){const R=n.children?n.children[0]:void 0;if((E==="*"||E==="-")&&R&&(!R.children||!R.children[0])&&c.stack[c.stack.length-1]==="list"&&c.stack[c.stack.length-2]==="listItem"&&c.stack[c.stack.length-3]==="list"&&c.stack[c.stack.length-4]==="listItem"&&c.indexStack[c.indexStack.length-1]===0&&c.indexStack[c.indexStack.length-2]===0&&c.indexStack[c.indexStack.length-3]===0&&(B=!0),checkRule(c)===E&&R){let g=-1;for(;++g-1?p.start:1)+(c.options.incrementListMarker===!1?0:p.children.indexOf(n))+o);let E=o.length+1;(x==="tab"||x==="mixed"&&(p&&p.type==="list"&&p.spread||n.spread))&&(E=Math.ceil(E/4)*4);const A=c.createTracker(l);A.move(o+" ".repeat(E-o.length)),A.shift(E);const B=c.enter("listItem"),b=c.indentLines(c.containerFlow(n,A.current()),R);return B(),b;function R(g,S,q){return S?(q?"":" ".repeat(E))+g:(q?o:o+" ".repeat(E-o.length))+g}}function paragraph(n,p,c,l){const x=c.enter("paragraph"),o=c.enter("phrasing"),E=c.containerPhrasing(n,l);return o(),x(),E}const phrasing=convert(["break","delete","emphasis","footnote","footnoteReference","image","imageReference","inlineCode","inlineMath","link","linkReference","mdxJsxTextElement","mdxTextExpression","strong","text","textDirective"]);function root(n,p,c,l){return(n.children.some(function(x){return phrasing(x)})?c.containerPhrasing:c.containerFlow).call(c,n,l)}function checkStrong(n){const p=n.options.strong||"*";if(p!=="*"&&p!=="_")throw new Error("Cannot serialize strong with `"+p+"` for `options.strong`, expected `*`, or `_`");return p}strong.peek=strongPeek;function strong(n,p,c,l){const x=checkStrong(c),o=c.enter("strong"),E=c.createTracker(l),A=E.move(x+x);let B=E.move(c.containerPhrasing(n,{after:x,before:A,...E.current()}));const b=B.charCodeAt(0),R=encodeInfo(l.before.charCodeAt(l.before.length-1),b,x);R.inside&&(B=encodeCharacterReference(b)+B.slice(1));const g=B.charCodeAt(B.length-1),S=encodeInfo(l.after.charCodeAt(0),g,x);S.inside&&(B=B.slice(0,-1)+encodeCharacterReference(g));const q=E.move(x+x);return o(),c.attentionEncodeSurroundingInfo={after:S.outside,before:R.outside},A+B+q}function strongPeek(n,p,c){return c.options.strong||"*"}function text$1(n,p,c,l){return c.safe(n.value,l)}function checkRuleRepetition(n){const p=n.options.ruleRepetition||3;if(p<3)throw new Error("Cannot serialize rules with repetition `"+p+"` for `options.ruleRepetition`, expected `3` or more");return p}function thematicBreak(n,p,c){const l=(checkRule(c)+(c.options.ruleSpaces?" ":"")).repeat(checkRuleRepetition(c));return c.options.ruleSpaces?l.slice(0,-1):l}const handle={blockquote,break:hardBreak,code:code$1,definition,emphasis,hardBreak,heading,html,image,imageReference,inlineCode,link,linkReference,list,listItem,paragraph,root,strong,text:text$1,thematicBreak};function gfmTableFromMarkdown(){return{enter:{table:enterTable,tableData:enterCell,tableHeader:enterCell,tableRow:enterRow},exit:{codeText:exitCodeText,table:exitTable,tableData:exit,tableHeader:exit,tableRow:exit}}}function enterTable(n){const p=n._align;this.enter({type:"table",align:p.map(function(c){return c==="none"?null:c}),children:[]},n),this.data.inTable=!0}function exitTable(n){this.exit(n),this.data.inTable=void 0}function enterRow(n){this.enter({type:"tableRow",children:[]},n)}function exit(n){this.exit(n)}function enterCell(n){this.enter({type:"tableCell",children:[]},n)}function exitCodeText(n){let p=this.resume();this.data.inTable&&(p=p.replace(/\\([\\|])/g,replace));const c=this.stack[this.stack.length-1];c.type,c.value=p,this.exit(n)}function replace(n,p){return p==="|"?p:n}function gfmTableToMarkdown(n){const p=n||{},c=p.tableCellPadding,l=p.tablePipeAlign,x=p.stringLength,o=c?" ":"|";return{unsafe:[{character:"\r",inConstruct:"tableCell"},{character:` `,inConstruct:"tableCell"},{atBreak:!0,character:"|",after:"[ :-]"},{character:"|",inConstruct:"tableCell"},{atBreak:!0,character:":",after:"-"},{atBreak:!0,character:"-",after:"[:|-]"}],handlers:{inlineCode:S,table:E,tableCell:B,tableRow:A}};function E(q,$,I,P){return b(R(q,I,P),q.align)}function A(q,$,I,P){const O=g(q,I,P),L=b([O]);return L.slice(0,L.indexOf(` -`))}function B(q,$,I,P){const O=I.enter("tableCell"),L=I.enter("phrasing"),F=I.containerPhrasing(q,{...P,before:o,after:o});return L(),O(),F}function b(q,$){return markdownTable(q,{align:$,alignDelimiters:l,padding:c,stringLength:x})}function R(q,$,I){const P=q.children;let O=-1;const L=[],F=$.enter("table");for(;++Ox?0:x+p:p=p>x?x:p,c=c>0?c:0,l.length<1e4)E=Array.from(l),E.unshift(p,c),n.splice(...E);else for(c&&n.splice(p,c);o0&&!c&&(n[n.length-1][1]._gfmAutolinkLiteralWalkedInto=!0),c}function resolveAll(n,p,c){const l=[];let x=-1;for(;++x999||g===93&&!E||g===null||g===91||markdownLineEndingOrSpace(g))return c(g);if(g===93){n.exit("chunkString");const S=n.exit("gfmFootnoteCallString");return x.includes(normalizeIdentifier(l.sliceSerialize(S)))?(n.enter("gfmFootnoteCallLabelMarker"),n.consume(g),n.exit("gfmFootnoteCallLabelMarker"),n.exit("gfmFootnoteCall"),p):c(g)}return markdownLineEndingOrSpace(g)||(E=!0),o++,n.consume(g),g===92?R:b}function R(g){return g===91||g===92||g===93?(n.consume(g),o++,b):b(g)}}function tokenizeDefinitionStart(n,p,c){const l=this,x=l.parser.gfmFootnotes||(l.parser.gfmFootnotes=[]);let o,E=0,A;return B;function B($){return n.enter("gfmFootnoteDefinition")._container=!0,n.enter("gfmFootnoteDefinitionLabel"),n.enter("gfmFootnoteDefinitionLabelMarker"),n.consume($),n.exit("gfmFootnoteDefinitionLabelMarker"),b}function b($){return $===94?(n.enter("gfmFootnoteDefinitionMarker"),n.consume($),n.exit("gfmFootnoteDefinitionMarker"),n.enter("gfmFootnoteDefinitionLabelString"),n.enter("chunkString").contentType="string",R):c($)}function R($){if(E>999||$===93&&!A||$===null||$===91||markdownLineEndingOrSpace($))return c($);if($===93){n.exit("chunkString");const I=n.exit("gfmFootnoteDefinitionLabelString");return o=normalizeIdentifier(l.sliceSerialize(I)),n.enter("gfmFootnoteDefinitionLabelMarker"),n.consume($),n.exit("gfmFootnoteDefinitionLabelMarker"),n.exit("gfmFootnoteDefinitionLabel"),S}return markdownLineEndingOrSpace($)||(A=!0),E++,n.consume($),$===92?g:R}function g($){return $===91||$===92||$===93?(n.consume($),E++,R):R($)}function S($){return $===58?(n.enter("definitionMarker"),n.consume($),n.exit("definitionMarker"),x.includes(o)||x.push(o),factorySpace(n,q,"gfmFootnoteDefinitionWhitespace")):c($)}function q($){return p($)}}function tokenizeDefinitionContinuation(n,p,c){return n.check(blankLine,p,n.attempt(indent,p,c))}function gfmFootnoteDefinitionEnd(n){n.exit("gfmFootnoteDefinition")}function tokenizeIndent(n,p,c){const l=this;return factorySpace(n,x,"gfmFootnoteDefinitionIndent",5);function x(o){const E=l.events[l.events.length-1];return E&&E[1].type==="gfmFootnoteDefinitionIndent"&&E[2].sliceSerialize(E[1],!0).length===4?p(o):c(o)}}function gfmStrikethrough(n){let p=(n||{}).singleTilde;const c={name:"strikethrough",tokenize:x,resolveAll:l};return p==null&&(p=!0),{text:{126:c},insideSpan:{null:[c]},attentionMarkers:{null:[126]}};function l(o,E){let A=-1;for(;++A1?A(q):(o.consume(q),R++,S);if(R<2&&!p)return A(q);const I=o.exit("strikethroughSequenceTemporary"),P=classifyCharacter(q);return I._open=!P||P===2&&!!$,I._close=!$||$===2&&!!P,E(q)}}}class EditMap{constructor(){this.map=[]}add(p,c,l){addImplementation(this,p,c,l)}consume(p){if(this.map.sort(function(o,E){return o[0]-E[0]}),this.map.length===0)return;let c=this.map.length;const l=[];for(;c>0;)c-=1,l.push(p.slice(this.map[c][0]+this.map[c][1]),this.map[c][2]),p.length=this.map[c][0];l.push(p.slice()),p.length=0;let x=l.pop();for(;x;){for(const o of x)p.push(o);x=l.pop()}this.map.length=0}}function addImplementation(n,p,c,l){let x=0;if(!(c===0&&l.length===0)){for(;x-1;){const m=l.events[r][1].type;if(m==="lineEnding"||m==="linePrefix")r--;else break}const a=r>-1?l.events[r][1].type:null,s=a==="tableHead"||a==="tableRow"?Y:B;return s===Y&&l.parser.lazy[l.now().line]?c(he):s(he)}function B(he){return n.enter("tableHead"),n.enter("tableRow"),b(he)}function b(he){return he===124||(E=!0,o+=1),R(he)}function R(he){return he===null?c(he):markdownLineEnding(he)?o>1?(o=0,l.interrupt=!0,n.exit("tableRow"),n.enter("lineEnding"),n.consume(he),n.exit("lineEnding"),q):c(he):markdownSpace(he)?factorySpace(n,R,"whitespace")(he):(o+=1,E&&(E=!1,x+=1),he===124?(n.enter("tableCellDivider"),n.consume(he),n.exit("tableCellDivider"),E=!0,R):(n.enter("data"),g(he)))}function g(he){return he===null||he===124||markdownLineEndingOrSpace(he)?(n.exit("data"),R(he)):(n.consume(he),he===92?S:g)}function S(he){return he===92||he===124?(n.consume(he),g):g(he)}function q(he){return l.interrupt=!1,l.parser.lazy[l.now().line]?c(he):(n.enter("tableDelimiterRow"),E=!1,markdownSpace(he)?factorySpace(n,$,"linePrefix",l.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(he):$(he))}function $(he){return he===45||he===58?P(he):he===124?(E=!0,n.enter("tableCellDivider"),n.consume(he),n.exit("tableCellDivider"),I):Q(he)}function I(he){return markdownSpace(he)?factorySpace(n,P,"whitespace")(he):P(he)}function P(he){return he===58?(o+=1,E=!0,n.enter("tableDelimiterMarker"),n.consume(he),n.exit("tableDelimiterMarker"),O):he===45?(o+=1,O(he)):he===null||markdownLineEnding(he)?U(he):Q(he)}function O(he){return he===45?(n.enter("tableDelimiterFiller"),L(he)):Q(he)}function L(he){return he===45?(n.consume(he),L):he===58?(E=!0,n.exit("tableDelimiterFiller"),n.enter("tableDelimiterMarker"),n.consume(he),n.exit("tableDelimiterMarker"),F):(n.exit("tableDelimiterFiller"),F(he))}function F(he){return markdownSpace(he)?factorySpace(n,U,"whitespace")(he):U(he)}function U(he){return he===124?$(he):he===null||markdownLineEnding(he)?!E||x!==o?Q(he):(n.exit("tableDelimiterRow"),n.exit("tableHead"),p(he)):Q(he)}function Q(he){return c(he)}function Y(he){return n.enter("tableRow"),ce(he)}function ce(he){return he===124?(n.enter("tableCellDivider"),n.consume(he),n.exit("tableCellDivider"),ce):he===null||markdownLineEnding(he)?(n.exit("tableRow"),p(he)):markdownSpace(he)?factorySpace(n,ce,"whitespace")(he):(n.enter("data"),le(he))}function le(he){return he===null||he===124||markdownLineEndingOrSpace(he)?(n.exit("data"),ce(he)):(n.consume(he),he===92?ne:le)}function ne(he){return he===92||he===124?(n.consume(he),le):le(he)}}function resolveTable(n,p){let c=-1,l=!0,x=0,o=[0,0,0,0],E=[0,0,0,0],A=!1,B=0,b,R,g;const S=new EditMap;for(;++cc[2]+1){const $=c[2]+1,I=c[3]-c[2]-1;n.add($,I,[])}}n.add(c[3]+1,0,[["exit",g,p]])}return x!==void 0&&(o.end=Object.assign({},getPoint(p.events,x)),n.add(x,0,[["exit",o,p]]),o=void 0),o}function flushTableEnd(n,p,c,l,x){const o=[],E=getPoint(p.events,c);x&&(x.end=Object.assign({},E),o.push(["exit",x,p])),l.end=Object.assign({},E),o.push(["exit",l,p]),n.add(c+1,0,o)}function getPoint(n,p){const c=n[p],l=c[0]==="enter"?"start":"end";return c[1][l]}const tasklistCheck={name:"tasklistCheck",tokenize:tokenizeTasklistCheck};function gfmTaskListItem(){return{text:{91:tasklistCheck}}}function tokenizeTasklistCheck(n,p,c){const l=this;return x;function x(B){return l.previous!==null||!l._gfmTasklistFirstContentOfListItem?c(B):(n.enter("taskListCheck"),n.enter("taskListCheckMarker"),n.consume(B),n.exit("taskListCheckMarker"),o)}function o(B){return markdownLineEndingOrSpace(B)?(n.enter("taskListCheckValueUnchecked"),n.consume(B),n.exit("taskListCheckValueUnchecked"),E):B===88||B===120?(n.enter("taskListCheckValueChecked"),n.consume(B),n.exit("taskListCheckValueChecked"),E):c(B)}function E(B){return B===93?(n.enter("taskListCheckMarker"),n.consume(B),n.exit("taskListCheckMarker"),n.exit("taskListCheck"),A):c(B)}function A(B){return markdownLineEnding(B)?p(B):markdownSpace(B)?n.check({tokenize:spaceThenNonSpace},p,c)(B):c(B)}}function spaceThenNonSpace(n,p,c){return factorySpace(n,l,"whitespace");function l(x){return x===null?c(x):p(x)}}function gfm(n){return combineExtensions([gfmAutolinkLiteral(),gfmFootnote(),gfmStrikethrough(n),gfmTable(),gfmTaskListItem()])}const emptyOptions={};function remarkGfm(n){const p=this,c=n||emptyOptions,l=p.data(),x=l.micromarkExtensions||(l.micromarkExtensions=[]),o=l.fromMarkdownExtensions||(l.fromMarkdownExtensions=[]),E=l.toMarkdownExtensions||(l.toMarkdownExtensions=[]);x.push(gfm(c)),o.push(gfmFromMarkdown()),E.push(gfmToMarkdown(c))}function isTextNode$1(n){return n.type==="text"}const transformPlaceholders=function(n){visit(n,isTextNode$1,p);function p(c,l,x){const o=c.value.split(/(\{[a-z\-_.0-9]+\})/ig).map(E=>{const A=E.match(/^\{([a-z\-_.0-9]+)\}$/i);if(!A)return u("text",E);const[,B]=A;return u("element",{tagName:`#${B}`,children:[]})});x.children.splice(l,1,...o)}},remarkPlaceholder=()=>transformPlaceholders;function isTextNode(n){return["text","code","inlineCode"].includes(n.type)}const remarkUnescape=function(){return function(n){visit(n,isTextNode,(p,c,l)=>(l.children.splice(c,1,{...p,value:p.value.replace(/</gmi,"<").replace(/>/gmi,">")}),[SKIP$1,c+1]))}},LINK_PROTOCOLS=["http","https","mailto","tel"],rehypeHighlight=ref$1(null);async function importRehypeHighlightLibrary(){const n=await __vitePreload(()=>import("./index-BgKnKn3-.chunk.mjs"),__vite__mapDeps([0,1,2,3,4,5,6,7]),import.meta.url);rehypeHighlight.value=n.default}const _sfc_main$d={name:"NcRichText",components:{NcReferenceList},props:{text:{type:String,default:""},arguments:{type:Object,default:()=>({})},referenceLimit:{type:Number,default:0},referenceInteractive:{type:Boolean,default:!0},referenceInteractiveOptIn:{type:Boolean,default:!1},references:{type:Array,default:null},useMarkdown:{type:Boolean,default:!1},useExtendedMarkdown:{type:Boolean,default:!1},interactive:{type:Boolean,default:!1},autolink:{type:Boolean,default:!0}},emits:["interactTodo"],data(){return{parentId:createElementId()}},methods:{renderPlaintext(){const n=this.text.split(/(\{[a-z\-_.0-9]+\})/ig).map(p=>{const c=p.match(/^\{([a-z\-_.0-9]+)\}$/i);if(!c)return this.prepareTextNode(p);const l=c[1],x=this.arguments[l];if(typeof x=="object"){const{component:o,props:E}=x;return h(typeof o=="string"?resolveComponent(o):o,{...E,class:"rich-text--component"})}return x?h("span",{class:"rich-text--fallback"},x):p});return h("div",{class:"rich-text--wrapper"},[h("div",{},n.flat()),this.referenceLimit>0?h("div",{class:"rich-text--reference-widget"},[h(NcReferenceList,{text:this.text,referenceData:this.references,interactive:this.referenceInteractive,interactiveOptIn:this.referenceInteractiveOptIn})]):null])},renderMarkdown(){const n=unified().use(remarkParse).use(remarkAutolink,{autolink:this.autolink,useMarkdown:this.useMarkdown,useExtendedMarkdown:this.useExtendedMarkdown}).use(remarkUnescape).use(this.useExtendedMarkdown?remarkGfm:void 0).use(remarkBreaks).use(remarkUnlinkProtocols,{except:LINK_PROTOCOLS}).use(remarkRehype,{handlers:{component(p,c){return p(c,c.component,{value:c.value})}}}).use(this.useExtendedMarkdown?rehypeHighlight.value:void 0).use(remarkPlaceholder).use(rehypeExternalLinks,{target:"_blank",rel:["noopener noreferrer"]}).use(rehypeReact,{Fragment,jsx:this.createElement,jsxs:this.createElement,elementAttributeNameCase:"html",prefix:!1}).processSync(this.text.replace(/<[^>]+>/g,p=>p.replace(/")).result;return h("div",{class:"rich-text--wrapper rich-text--wrapper-markdown"},[n,this.referenceLimit>0?h("div",{class:"rich-text--reference-widget"},[h(NcReferenceList,{text:this.text,referenceData:this.references,interactive:this.referenceInteractive,interactiveOptIn:this.referenceInteractiveOptIn})]):null])},prepareTextNode(n){return this.autolink&&(n=parseUrl(n)),Array.isArray(n)?n.map(p=>{if(typeof p=="string")return p;const{component:c,props:l}=p,x=c.name==="NcLink"?void 0:"rich-text--component";return h(c,{...l,class:x})}):n},createElement(n,p,c){c&&(p.key=c);const l=p.children??[];if(delete p.children,!String(n).startsWith("#")){let o=null;if(this.useExtendedMarkdown&&(String(n)==="code"&&!rehypeHighlight.value&&p?.class?.includes("language")&&importRehypeHighlightLibrary(),String(n)==="li"&&Array.isArray(l)&&l.length!==0&&l[0].type==="input"&&l[0].props.type==="checkbox")){const[E,,...A]=l,B=A.findIndex(S=>["ul","ol","li","blockquote","pre"].includes(S.type));B!==-1&&(o=A[B],A.splice(B));const b=this.parentId+"-markdown-input-"+createElementId(),R={...E.props};delete R.checked;const g=h(NcCheckboxRadioSwitch,{...R,modelValue:E.props.checked,id:b,disabled:!this.interactive,"onUpdate:modelValue":()=>{this.$emit("interactTodo",b)}},{default:()=>A});return h(n,p,[g,o])}if(String(n)==="a"){const E=getRoute(this.$router,p.href);if(E)return delete p.href,delete p.target,h(RouterLink,{...p,to:E},{default:()=>l})}return h(n,p,l)}const x=this.arguments[n.slice(1)];return x?x.component?h(typeof x.component=="string"?resolveComponent(x.component):x.component,{...p,...x.props,class:"rich-text--component"},{default:()=>l}):h("span",{...p},[x]):h("span",{...p,class:"rich-text--fallback"},[`{${n.slice(1)}}`])}},render(){return this.useMarkdown||this.useExtendedMarkdown?this.renderMarkdown():this.renderPlaintext()}},NcRichText=_export_sfc(_sfc_main$d,[["__scopeId","data-v-bfd4d4b7"]]),_sfc_main$c={__name:"ActionButton",props:{action:{type:Object,required:!0}},emits:["click"],setup(n,{emit:p}){const c=n,l=p,x=computed(()=>c.action.type==="WEB");function o(E){const A={url:c.action.link,type:c.action.type||"GET"};l("click",{event:E,action:A})}return(E,A)=>(openBlock(),createBlock(unref(NcButton),{variant:x.value||n.action.primary?"primary":"secondary",href:x.value?n.action.link:void 0,class:"action-button pull-right",onClick:o},{default:withCtx(()=>[createTextVNode(toDisplayString(n.action.label),1)]),_:1},8,["variant","href"]))}},_sfc_main$b={name:"DefaultParameter",props:{type:{type:String,required:!0},id:{type:[Number,String],required:!0},name:{type:String,required:!0},link:{type:String,default:""}},computed:{hasInternalLink(){return this.link&&(this.type==="deck-board"||this.type==="deck-card")}}},_hoisted_1$b=["href"],_hoisted_2$9=["href"],_hoisted_3$7={key:2};function _sfc_render$a(n,p,c,l,x,o){return o.hasInternalLink?(openBlock(),createElementBlock("a",{key:0,href:c.link},[createBaseVNode("strong",null,toDisplayString(c.name),1)],8,_hoisted_1$b)):c.link?(openBlock(),createElementBlock("a",{key:1,href:c.link,class:"external",target:"_blank",rel:"noopener noreferrer"},[createBaseVNode("strong",null,toDisplayString(c.name),1)],8,_hoisted_2$9)):(openBlock(),createElementBlock("strong",_hoisted_3$7,toDisplayString(c.name),1))}const DefaultParameter=_export_sfc$1(_sfc_main$b,[["render",_sfc_render$a],["__scopeId","data-v-9803ab31"]]),_sfc_main$a={name:"FileParameter",props:{type:{type:String,required:!0},id:{type:[Number,String],required:!0},name:{type:String,required:!0},path:{type:String,default:""},link:{type:String,default:""}},computed:{title(){const n=this.path.lastIndexOf("/"),p=this.path.indexOf("/"),c=this.path.substring(p===0?1:0,n);return c.length===0?"":translate("notifications","in {path}",{path:c})}}},_hoisted_1$a=["title","href"];function _sfc_render$9(n,p,c,l,x,o){return openBlock(),createElementBlock("a",{title:o.title,class:"filename",href:c.link},toDisplayString(c.name),9,_hoisted_1$a)}const FileParameter=_export_sfc$1(_sfc_main$a,[["render",_sfc_render$9]]),defaultWindow=isClient?window:void 0;function unrefElement(n){var p;const c=toValue(n);return(p=c?.$el)!=null?p:c}function useEventListener(...n){const p=[],c=()=>{p.forEach(A=>A()),p.length=0},l=(A,B,b,R)=>(A.addEventListener(B,b,R),()=>A.removeEventListener(B,b,R)),x=computed(()=>{const A=toArray(toValue(n[0])).filter(B=>B!=null);return A.every(B=>typeof B!="string")?A:void 0}),o=watchImmediate(()=>{var A,B;return[(B=(A=x.value)==null?void 0:A.map(b=>unrefElement(b)))!=null?B:[defaultWindow].filter(b=>b!=null),toArray(toValue(x.value?n[1]:n[0])),toArray(unref(x.value?n[2]:n[1])),toValue(x.value?n[3]:n[2])]},([A,B,b,R])=>{if(c(),!A?.length||!B?.length||!b?.length)return;const g=isObject(R)?{...R}:R;p.push(...A.flatMap(S=>B.flatMap(q=>b.map($=>l(S,q,$,g)))))},{flush:"post"}),E=()=>{o(),c()};return tryOnScopeDispose(c),E}let _iOSWorkaround=!1;function onClickOutside(n,p,c={}){const{window:l=defaultWindow,ignore:x=[],capture:o=!0,detectIframe:E=!1,controls:A=!1}=c;if(!l)return A?{stop:noop,cancel:noop,trigger:noop}:noop;if(isIOS&&!_iOSWorkaround){_iOSWorkaround=!0;const P={passive:!0};Array.from(l.document.body.children).forEach(O=>O.addEventListener("click",noop,P)),l.document.documentElement.addEventListener("click",noop,P)}let B=!0;const b=P=>toValue(x).some(O=>{if(typeof O=="string")return Array.from(l.document.querySelectorAll(O)).some(L=>L===P.target||P.composedPath().includes(L));{const L=unrefElement(O);return L&&(P.target===L||P.composedPath().includes(L))}});function R(P){const O=toValue(P);return O&&O.$.subTree.shapeFlag===16}function g(P,O){const L=toValue(P),F=L.$.subTree&&L.$.subTree.children;return F==null||!Array.isArray(F)?!1:F.some(U=>U.el===O.target||O.composedPath().includes(U.el))}const S=P=>{const O=unrefElement(n);if(P.target!=null&&!(!(O instanceof Element)&&R(n)&&g(n,P))&&!(!O||O===P.target||P.composedPath().includes(O))){if("detail"in P&&P.detail===0&&(B=!b(P)),!B){B=!0;return}p(P)}};let q=!1;const $=[useEventListener(l,"click",P=>{q||(q=!0,setTimeout(()=>{q=!1},0),S(P))},{passive:!0,capture:o}),useEventListener(l,"pointerdown",P=>{const O=unrefElement(n);B=!b(P)&&!!(O&&!P.composedPath().includes(O))},{passive:!0}),E&&useEventListener(l,"blur",P=>{setTimeout(()=>{var O;const L=unrefElement(n);((O=l.document.activeElement)==null?void 0:O.tagName)==="IFRAME"&&!L?.contains(l.document.activeElement)&&p(P)},0)},{passive:!0})].filter(Boolean),I=()=>$.forEach(P=>P());return A?{stop:I,cancel:()=>{B=!1},trigger:P=>{B=!0,S(P),B=!1}}:I}const stopClickOutsideMap=new WeakMap,vOnClickOutside={mounted(n,p){const c=!p.modifiers.bubble;let l;if(typeof p.value=="function")l=onClickOutside(n,p.value,{capture:c});else{const[x,o]=p.value;l=onClickOutside(n,x,Object.assign({capture:c},o))}stopClickOutsideMap.set(n,l)},unmounted(n){const p=stopClickOutsideMap.get(n);p&&typeof p=="function"?p():p?.stop(),stopClickOutsideMap.delete(n)}};function resolveElement(n){return typeof Window<"u"&&n instanceof Window?n.document.documentElement:typeof Document<"u"&&n instanceof Document?n.documentElement:n}function checkOverflowScroll(n){const p=window.getComputedStyle(n);if(p.overflowX==="scroll"||p.overflowY==="scroll"||p.overflowX==="auto"&&n.clientWidth1?!0:(p.preventDefault&&p.preventDefault(),!1)}const elInitialOverflow=new WeakMap;function useScrollLock(n,p=!1){const c=shallowRef(p);let l=null,x="";watch(toRef$1(n),A=>{const B=resolveElement(toValue(A));if(B){const b=B;if(elInitialOverflow.get(b)||elInitialOverflow.set(b,b.style.overflow),b.style.overflow!=="hidden"&&(x=b.style.overflow),b.style.overflow==="hidden")return c.value=!0;if(c.value)return b.style.overflow="hidden"}},{immediate:!0});const o=()=>{const A=resolveElement(toValue(n));!A||c.value||(isIOS&&(l=useEventListener(A,"touchmove",B=>{preventDefault(B)},{passive:!1})),A.style.overflow="hidden",c.value=!0)},E=()=>{const A=resolveElement(toValue(n));!A||!c.value||(isIOS&&l?.(),A.style.overflow=x,elInitialOverflow.delete(A),c.value=!1)};return tryOnScopeDispose(E),computed({get(){return c.value},set(A){A?o():E()}})}function onScrollLock(){let n=!1;const p=shallowRef(!1);return(c,l)=>{if(p.value=l.value,n)return;n=!0;const x=useScrollLock(c,l.value);watch(p,o=>x.value=o)}}onScrollLock();function getEnabledContactsMenuActions(n){return window._nc_contacts_menu_hooks?Object.values(window._nc_contacts_menu_hooks).filter(p=>p.enabled(n)):[]}var cryptoBrowserify={},browser$b={exports:{}},safeBuffer$1={exports:{}},dist={},hasRequiredDist;function requireDist(){return hasRequiredDist||(hasRequiredDist=1,function(n){Object.defineProperties(n,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var p={},c={};c.byteLength=R,c.toByteArray=S,c.fromByteArray=I;for(var l=[],x=[],o=typeof Uint8Array<"u"?Uint8Array:Array,E="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",A=0,B=E.length;A0)throw new Error("Invalid string. Length must be a multiple of 4");var U=L.indexOf("=");U===-1&&(U=F);var Q=U===F?0:4-U%4;return[U,Q]}function R(L){var F=b(L),U=F[0],Q=F[1];return(U+Q)*3/4-Q}function g(L,F,U){return(F+U)*3/4-U}function S(L){var F,U=b(L),Q=U[0],Y=U[1],ce=new o(g(L,Q,Y)),le=0,ne=Y>0?Q-4:Q,he;for(he=0;he>16&255,ce[le++]=F>>8&255,ce[le++]=F&255;return Y===2&&(F=x[L.charCodeAt(he)]<<2|x[L.charCodeAt(he+1)]>>4,ce[le++]=F&255),Y===1&&(F=x[L.charCodeAt(he)]<<10|x[L.charCodeAt(he+1)]<<4|x[L.charCodeAt(he+2)]>>2,ce[le++]=F>>8&255,ce[le++]=F&255),ce}function q(L){return l[L>>18&63]+l[L>>12&63]+l[L>>6&63]+l[L&63]}function $(L,F,U){for(var Q,Y=[],ce=F;cene?ne:le+ce));return Q===1?(F=L[U-1],Y.push(l[F>>2]+l[F<<4&63]+"==")):Q===2&&(F=(L[U-2]<<8)+L[U-1],Y.push(l[F>>10]+l[F>>4&63]+l[F<<2&63]+"=")),Y.join("")}var P={};P.read=function(L,F,U,Q,Y){var ce,le,ne=Y*8-Q-1,he=(1<>1,a=-7,s=U?Y-1:0,m=U?-1:1,k=L[F+s];for(s+=m,ce=k&(1<<-a)-1,k>>=-a,a+=ne;a>0;ce=ce*256+L[F+s],s+=m,a-=8);for(le=ce&(1<<-a)-1,ce>>=-a,a+=Q;a>0;le=le*256+L[F+s],s+=m,a-=8);if(ce===0)ce=1-r;else{if(ce===he)return le?NaN:(k?-1:1)*(1/0);le=le+Math.pow(2,Q),ce=ce-r}return(k?-1:1)*le*Math.pow(2,ce-Q)},P.write=function(L,F,U,Q,Y,ce){var le,ne,he,r=ce*8-Y-1,a=(1<>1,m=Y===23?Math.pow(2,-24)-Math.pow(2,-77):0,k=Q?0:ce-1,C=Q?1:-1,T=F<0||F===0&&1/F<0?1:0;for(F=Math.abs(F),isNaN(F)||F===1/0?(ne=isNaN(F)?1:0,le=a):(le=Math.floor(Math.log(F)/Math.LN2),F*(he=Math.pow(2,-le))<1&&(le--,he*=2),le+s>=1?F+=m/he:F+=m*Math.pow(2,1-s),F*he>=2&&(le++,he/=2),le+s>=a?(ne=0,le=a):le+s>=1?(ne=(F*he-1)*Math.pow(2,Y),le=le+s):(ne=F*Math.pow(2,s-1)*Math.pow(2,Y),le=0));Y>=8;L[U+k]=ne&255,k+=C,ne/=256,Y-=8);for(le=le<0;L[U+k]=le&255,k+=C,le/=256,r-=8);L[U+k-C]|=T*128},function(L){const F=c,U=P,Q=typeof Symbol=="function"&&typeof Symbol.for=="function"?Symbol.for("nodejs.util.inspect.custom"):null;L.Buffer=a,L.SlowBuffer=z,L.INSPECT_MAX_BYTES=50;const Y=2147483647;L.kMaxLength=Y;const{Uint8Array:ce,ArrayBuffer:le,SharedArrayBuffer:ne}=globalThis;a.TYPED_ARRAY_SUPPORT=he(),!a.TYPED_ARRAY_SUPPORT&&typeof console<"u"&&typeof console.error=="function"&&console.error("This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support.");function he(){try{const N=new ce(1),W={foo:function(){return 42}};return Object.setPrototypeOf(W,ce.prototype),Object.setPrototypeOf(N,W),N.foo()===42}catch{return!1}}Object.defineProperty(a.prototype,"parent",{enumerable:!0,get:function(){if(a.isBuffer(this))return this.buffer}}),Object.defineProperty(a.prototype,"offset",{enumerable:!0,get:function(){if(a.isBuffer(this))return this.byteOffset}});function r(N){if(N>Y)throw new RangeError('The value "'+N+'" is invalid for option "size"');const W=new ce(N);return Object.setPrototypeOf(W,a.prototype),W}function a(N,W,H){if(typeof N=="number"){if(typeof W=="string")throw new TypeError('The "string" argument must be of type string. Received type number');return C(N)}return s(N,W,H)}a.poolSize=8192;function s(N,W,H){if(typeof N=="string")return T(N,W);if(le.isView(N))return i(N);if(N==null)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof N);if(ut(N,le)||N&&ut(N.buffer,le)||typeof ne<"u"&&(ut(N,ne)||N&&ut(N.buffer,ne)))return y(N,W,H);if(typeof N=="number")throw new TypeError('The "value" argument must not be of type number. Received type number');const ae=N.valueOf&&N.valueOf();if(ae!=null&&ae!==N)return a.from(ae,W,H);const be=D(N);if(be)return be;if(typeof Symbol<"u"&&Symbol.toPrimitive!=null&&typeof N[Symbol.toPrimitive]=="function")return a.from(N[Symbol.toPrimitive]("string"),W,H);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof N)}a.from=function(N,W,H){return s(N,W,H)},Object.setPrototypeOf(a.prototype,ce.prototype),Object.setPrototypeOf(a,ce);function m(N){if(typeof N!="number")throw new TypeError('"size" argument must be of type number');if(N<0)throw new RangeError('The value "'+N+'" is invalid for option "size"')}function k(N,W,H){return m(N),N<=0?r(N):W!==void 0?typeof H=="string"?r(N).fill(W,H):r(N).fill(W):r(N)}a.alloc=function(N,W,H){return k(N,W,H)};function C(N){return m(N),r(N<0?0:j(N)|0)}a.allocUnsafe=function(N){return C(N)},a.allocUnsafeSlow=function(N){return C(N)};function T(N,W){if((typeof W!="string"||W==="")&&(W="utf8"),!a.isEncoding(W))throw new TypeError("Unknown encoding: "+W);const H=X(N,W)|0;let ae=r(H);const be=ae.write(N,W);return be!==H&&(ae=ae.slice(0,be)),ae}function M(N){const W=N.length<0?0:j(N.length)|0,H=r(W);for(let ae=0;ae=Y)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+Y.toString(16)+" bytes");return N|0}function z(N){return+N!=N&&(N=0),a.alloc(+N)}a.isBuffer=function(N){return N!=null&&N._isBuffer===!0&&N!==a.prototype},a.compare=function(N,W){if(ut(N,ce)&&(N=a.from(N,N.offset,N.byteLength)),ut(W,ce)&&(W=a.from(W,W.offset,W.byteLength)),!a.isBuffer(N)||!a.isBuffer(W))throw new TypeError('The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array');if(N===W)return 0;let H=N.length,ae=W.length;for(let be=0,de=Math.min(H,ae);beae.length?(a.isBuffer(de)||(de=a.from(de)),de.copy(ae,be)):ce.prototype.set.call(ae,de,be);else if(a.isBuffer(de))de.copy(ae,be);else throw new TypeError('"list" argument must be an Array of Buffers');be+=de.length}return ae};function X(N,W){if(a.isBuffer(N))return N.length;if(le.isView(N)||ut(N,le))return N.byteLength;if(typeof N!="string")throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof N);const H=N.length,ae=arguments.length>2&&arguments[2]===!0;if(!ae&&H===0)return 0;let be=!1;for(;;)switch(W){case"ascii":case"latin1":case"binary":return H;case"utf8":case"utf-8":return $e(N).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return H*2;case"hex":return H>>>1;case"base64":return ze(N).length;default:if(be)return ae?-1:$e(N).length;W=(""+W).toLowerCase(),be=!0}}a.byteLength=X;function te(N,W,H){let ae=!1;if((W===void 0||W<0)&&(W=0),W>this.length||((H===void 0||H>this.length)&&(H=this.length),H<=0)||(H>>>=0,W>>>=0,H<=W))return"";for(N||(N="utf8");;)switch(N){case"hex":return xe(this,W,H);case"utf8":case"utf-8":return Me(this,W,H);case"ascii":return Le(this,W,H);case"latin1":case"binary":return Be(this,W,H);case"base64":return pe(this,W,H);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return Ie(this,W,H);default:if(ae)throw new TypeError("Unknown encoding: "+N);N=(N+"").toLowerCase(),ae=!0}}a.prototype._isBuffer=!0;function ee(N,W,H){const ae=N[W];N[W]=N[H],N[H]=ae}a.prototype.swap16=function(){const N=this.length;if(N%2!==0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let W=0;WW&&(N+=" ... "),""},Q&&(a.prototype[Q]=a.prototype.inspect),a.prototype.compare=function(N,W,H,ae,be){if(ut(N,ce)&&(N=a.from(N,N.offset,N.byteLength)),!a.isBuffer(N))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof N);if(W===void 0&&(W=0),H===void 0&&(H=N?N.length:0),ae===void 0&&(ae=0),be===void 0&&(be=this.length),W<0||H>N.length||ae<0||be>this.length)throw new RangeError("out of range index");if(ae>=be&&W>=H)return 0;if(ae>=be)return-1;if(W>=H)return 1;if(W>>>=0,H>>>=0,ae>>>=0,be>>>=0,this===N)return 0;let de=be-ae,me=H-W;const it=Math.min(de,me),qe=this.slice(ae,be),De=N.slice(W,H);for(let rt=0;rt2147483647?H=2147483647:H<-2147483648&&(H=-2147483648),H=+H,Ue(H)&&(H=be?0:N.length-1),H<0&&(H=N.length+H),H>=N.length){if(be)return-1;H=N.length-1}else if(H<0)if(be)H=0;else return-1;if(typeof W=="string"&&(W=a.from(W,ae)),a.isBuffer(W))return W.length===0?-1:V(N,W,H,ae,be);if(typeof W=="number")return W=W&255,typeof ce.prototype.indexOf=="function"?be?ce.prototype.indexOf.call(N,W,H):ce.prototype.lastIndexOf.call(N,W,H):V(N,[W],H,ae,be);throw new TypeError("val must be string, number or Buffer")}function V(N,W,H,ae,be){let de=1,me=N.length,it=W.length;if(ae!==void 0&&(ae=String(ae).toLowerCase(),ae==="ucs2"||ae==="ucs-2"||ae==="utf16le"||ae==="utf-16le")){if(N.length<2||W.length<2)return-1;de=2,me/=2,it/=2,H/=2}function qe(rt,Ee){return de===1?rt[Ee]:rt.readUInt16BE(Ee*de)}let De;if(be){let rt=-1;for(De=H;Deme&&(H=me-it),De=H;De>=0;De--){let rt=!0;for(let Ee=0;Eebe&&(ae=be)):ae=be;const de=W.length;ae>de/2&&(ae=de/2);let me;for(me=0;me>>0,isFinite(H)?(H=H>>>0,ae===void 0&&(ae="utf8")):(ae=H,H=void 0);else throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");const be=this.length-W;if((H===void 0||H>be)&&(H=be),N.length>0&&(H<0||W<0)||W>this.length)throw new RangeError("Attempt to write outside buffer bounds");ae||(ae="utf8");let de=!1;for(;;)switch(ae){case"hex":return oe(this,N,W,H);case"utf8":case"utf-8":return ye(this,N,W,H);case"ascii":case"latin1":case"binary":return Z(this,N,W,H);case"base64":return J(this,N,W,H);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return _e(this,N,W,H);default:if(de)throw new TypeError("Unknown encoding: "+ae);ae=(""+ae).toLowerCase(),de=!0}},a.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};function pe(N,W,H){return W===0&&H===N.length?F.fromByteArray(N):F.fromByteArray(N.slice(W,H))}function Me(N,W,H){H=Math.min(N.length,H);const ae=[];let be=W;for(;be239?4:de>223?3:de>191?2:1;if(be+it<=H){let qe,De,rt,Ee;switch(it){case 1:de<128&&(me=de);break;case 2:qe=N[be+1],(qe&192)===128&&(Ee=(de&31)<<6|qe&63,Ee>127&&(me=Ee));break;case 3:qe=N[be+1],De=N[be+2],(qe&192)===128&&(De&192)===128&&(Ee=(de&15)<<12|(qe&63)<<6|De&63,Ee>2047&&(Ee<55296||Ee>57343)&&(me=Ee));break;case 4:qe=N[be+1],De=N[be+2],rt=N[be+3],(qe&192)===128&&(De&192)===128&&(rt&192)===128&&(Ee=(de&15)<<18|(qe&63)<<12|(De&63)<<6|rt&63,Ee>65535&&Ee<1114112&&(me=Ee))}}me===null?(me=65533,it=1):me>65535&&(me-=65536,ae.push(me>>>10&1023|55296),me=56320|me&1023),ae.push(me),be+=it}return ke(ae)}const Ke=4096;function ke(N){const W=N.length;if(W<=Ke)return String.fromCharCode.apply(String,N);let H="",ae=0;for(;aeae)&&(H=ae);let be="";for(let de=W;deH&&(N=H),W<0?(W+=H,W<0&&(W=0)):W>H&&(W=H),WH)throw new RangeError("Trying to access beyond buffer length")}a.prototype.readUintLE=a.prototype.readUIntLE=function(N,W,H){N=N>>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=this[N],be=1,de=0;for(;++de>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=this[N+--W],be=1;for(;W>0&&(be*=256);)ae+=this[N+--W]*be;return ae},a.prototype.readUint8=a.prototype.readUInt8=function(N,W){return N=N>>>0,W||Ye(N,1,this.length),this[N]},a.prototype.readUint16LE=a.prototype.readUInt16LE=function(N,W){return N=N>>>0,W||Ye(N,2,this.length),this[N]|this[N+1]<<8},a.prototype.readUint16BE=a.prototype.readUInt16BE=function(N,W){return N=N>>>0,W||Ye(N,2,this.length),this[N]<<8|this[N+1]},a.prototype.readUint32LE=a.prototype.readUInt32LE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),(this[N]|this[N+1]<<8|this[N+2]<<16)+this[N+3]*16777216},a.prototype.readUint32BE=a.prototype.readUInt32BE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),this[N]*16777216+(this[N+1]<<16|this[N+2]<<8|this[N+3])},a.prototype.readBigUInt64LE=ht(function(N){N=N>>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=W+this[++N]*2**8+this[++N]*2**16+this[++N]*2**24,be=this[++N]+this[++N]*2**8+this[++N]*2**16+H*2**24;return BigInt(ae)+(BigInt(be)<>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=W*2**24+this[++N]*2**16+this[++N]*2**8+this[++N],be=this[++N]*2**24+this[++N]*2**16+this[++N]*2**8+H;return(BigInt(ae)<>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=this[N],be=1,de=0;for(;++de=be&&(ae-=Math.pow(2,8*W)),ae},a.prototype.readIntBE=function(N,W,H){N=N>>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=W,be=1,de=this[N+--ae];for(;ae>0&&(be*=256);)de+=this[N+--ae]*be;return be*=128,de>=be&&(de-=Math.pow(2,8*W)),de},a.prototype.readInt8=function(N,W){return N=N>>>0,W||Ye(N,1,this.length),this[N]&128?(255-this[N]+1)*-1:this[N]},a.prototype.readInt16LE=function(N,W){N=N>>>0,W||Ye(N,2,this.length);const H=this[N]|this[N+1]<<8;return H&32768?H|4294901760:H},a.prototype.readInt16BE=function(N,W){N=N>>>0,W||Ye(N,2,this.length);const H=this[N+1]|this[N]<<8;return H&32768?H|4294901760:H},a.prototype.readInt32LE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),this[N]|this[N+1]<<8|this[N+2]<<16|this[N+3]<<24},a.prototype.readInt32BE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),this[N]<<24|this[N+1]<<16|this[N+2]<<8|this[N+3]},a.prototype.readBigInt64LE=ht(function(N){N=N>>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=this[N+4]+this[N+5]*2**8+this[N+6]*2**16+(H<<24);return(BigInt(ae)<>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=(W<<24)+this[++N]*2**16+this[++N]*2**8+this[++N];return(BigInt(ae)<>>0,W||Ye(N,4,this.length),U.read(this,N,!0,23,4)},a.prototype.readFloatBE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),U.read(this,N,!1,23,4)},a.prototype.readDoubleLE=function(N,W){return N=N>>>0,W||Ye(N,8,this.length),U.read(this,N,!0,52,8)},a.prototype.readDoubleBE=function(N,W){return N=N>>>0,W||Ye(N,8,this.length),U.read(this,N,!1,52,8)};function Se(N,W,H,ae,be,de){if(!a.isBuffer(N))throw new TypeError('"buffer" argument must be a Buffer instance');if(W>be||WN.length)throw new RangeError("Index out of range")}a.prototype.writeUintLE=a.prototype.writeUIntLE=function(N,W,H,ae){if(N=+N,W=W>>>0,H=H>>>0,!ae){const me=Math.pow(2,8*H)-1;Se(this,N,W,H,me,0)}let be=1,de=0;for(this[W]=N&255;++de>>0,H=H>>>0,!ae){const me=Math.pow(2,8*H)-1;Se(this,N,W,H,me,0)}let be=H-1,de=1;for(this[W+be]=N&255;--be>=0&&(de*=256);)this[W+be]=N/de&255;return W+H},a.prototype.writeUint8=a.prototype.writeUInt8=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,1,255,0),this[W]=N&255,W+1},a.prototype.writeUint16LE=a.prototype.writeUInt16LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,65535,0),this[W]=N&255,this[W+1]=N>>>8,W+2},a.prototype.writeUint16BE=a.prototype.writeUInt16BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,65535,0),this[W]=N>>>8,this[W+1]=N&255,W+2},a.prototype.writeUint32LE=a.prototype.writeUInt32LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,4294967295,0),this[W+3]=N>>>24,this[W+2]=N>>>16,this[W+1]=N>>>8,this[W]=N&255,W+4},a.prototype.writeUint32BE=a.prototype.writeUInt32BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,4294967295,0),this[W]=N>>>24,this[W+1]=N>>>16,this[W+2]=N>>>8,this[W+3]=N&255,W+4};function Ne(N,W,H,ae,be){Ve(W,ae,be,N,H,7);let de=Number(W&BigInt(4294967295));N[H++]=de,de=de>>8,N[H++]=de,de=de>>8,N[H++]=de,de=de>>8,N[H++]=de;let me=Number(W>>BigInt(32)&BigInt(4294967295));return N[H++]=me,me=me>>8,N[H++]=me,me=me>>8,N[H++]=me,me=me>>8,N[H++]=me,H}function we(N,W,H,ae,be){Ve(W,ae,be,N,H,7);let de=Number(W&BigInt(4294967295));N[H+7]=de,de=de>>8,N[H+6]=de,de=de>>8,N[H+5]=de,de=de>>8,N[H+4]=de;let me=Number(W>>BigInt(32)&BigInt(4294967295));return N[H+3]=me,me=me>>8,N[H+2]=me,me=me>>8,N[H+1]=me,me=me>>8,N[H]=me,H+8}a.prototype.writeBigUInt64LE=ht(function(N,W=0){return Ne(this,N,W,BigInt(0),BigInt("0xffffffffffffffff"))}),a.prototype.writeBigUInt64BE=ht(function(N,W=0){return we(this,N,W,BigInt(0),BigInt("0xffffffffffffffff"))}),a.prototype.writeIntLE=function(N,W,H,ae){if(N=+N,W=W>>>0,!ae){const it=Math.pow(2,8*H-1);Se(this,N,W,H,it-1,-it)}let be=0,de=1,me=0;for(this[W]=N&255;++be>0)-me&255;return W+H},a.prototype.writeIntBE=function(N,W,H,ae){if(N=+N,W=W>>>0,!ae){const it=Math.pow(2,8*H-1);Se(this,N,W,H,it-1,-it)}let be=H-1,de=1,me=0;for(this[W+be]=N&255;--be>=0&&(de*=256);)N<0&&me===0&&this[W+be+1]!==0&&(me=1),this[W+be]=(N/de>>0)-me&255;return W+H},a.prototype.writeInt8=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,1,127,-128),N<0&&(N=255+N+1),this[W]=N&255,W+1},a.prototype.writeInt16LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,32767,-32768),this[W]=N&255,this[W+1]=N>>>8,W+2},a.prototype.writeInt16BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,32767,-32768),this[W]=N>>>8,this[W+1]=N&255,W+2},a.prototype.writeInt32LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,2147483647,-2147483648),this[W]=N&255,this[W+1]=N>>>8,this[W+2]=N>>>16,this[W+3]=N>>>24,W+4},a.prototype.writeInt32BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,2147483647,-2147483648),N<0&&(N=4294967295+N+1),this[W]=N>>>24,this[W+1]=N>>>16,this[W+2]=N>>>8,this[W+3]=N&255,W+4},a.prototype.writeBigInt64LE=ht(function(N,W=0){return Ne(this,N,W,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))}),a.prototype.writeBigInt64BE=ht(function(N,W=0){return we(this,N,W,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))});function se(N,W,H,ae,be,de){if(H+ae>N.length)throw new RangeError("Index out of range");if(H<0)throw new RangeError("Index out of range")}function ge(N,W,H,ae,be){return W=+W,H=H>>>0,be||se(N,W,H,4),U.write(N,W,H,ae,23,4),H+4}a.prototype.writeFloatLE=function(N,W,H){return ge(this,N,W,!0,H)},a.prototype.writeFloatBE=function(N,W,H){return ge(this,N,W,!1,H)};function Xe(N,W,H,ae,be){return W=+W,H=H>>>0,be||se(N,W,H,8),U.write(N,W,H,ae,52,8),H+8}a.prototype.writeDoubleLE=function(N,W,H){return Xe(this,N,W,!0,H)},a.prototype.writeDoubleBE=function(N,W,H){return Xe(this,N,W,!1,H)},a.prototype.copy=function(N,W,H,ae){if(!a.isBuffer(N))throw new TypeError("argument should be a Buffer");if(H||(H=0),!ae&&ae!==0&&(ae=this.length),W>=N.length&&(W=N.length),W||(W=0),ae>0&&ae=this.length)throw new RangeError("Index out of range");if(ae<0)throw new RangeError("sourceEnd out of bounds");ae>this.length&&(ae=this.length),N.length-W>>0,H=H===void 0?this.length:H>>>0,N||(N=0);let be;if(typeof N=="number")for(be=W;be2**32?be=at(String(H)):typeof H=="bigint"&&(be=String(H),(H>BigInt(2)**BigInt(32)||H<-(BigInt(2)**BigInt(32)))&&(be=at(be)),be+="n"),ae+=` It must be ${W}. Received ${be}`,ae},RangeError);function at(N){let W="",H=N.length;const ae=N[0]==="-"?1:0;for(;H>=ae+4;H-=3)W=`_${N.slice(H-3,H)}${W}`;return`${N.slice(0,H)}${W}`}function Pe(N,W,H){st(W,"offset"),(N[W]===void 0||N[W+H]===void 0)&&Ce(W,N.length-(H+1))}function Ve(N,W,H,ae,be,de){if(N>H||N= 0${me} and < 2${me} ** ${(de+1)*8}${me}`:it=`>= -(2${me} ** ${(de+1)*8-1}${me}) and < 2 ** ${(de+1)*8-1}${me}`,new Ae.ERR_OUT_OF_RANGE("value",it,N)}Pe(ae,be,de)}function st(N,W){if(typeof N!="number")throw new Ae.ERR_INVALID_ARG_TYPE(W,"number",N)}function Ce(N,W,H){throw Math.floor(N)!==N?(st(N,H),new Ae.ERR_OUT_OF_RANGE("offset","an integer",N)):W<0?new Ae.ERR_BUFFER_OUT_OF_BOUNDS:new Ae.ERR_OUT_OF_RANGE("offset",`>= 0 and <= ${W}`,N)}const je=/[^+/0-9A-Za-z-_]/g;function lt(N){if(N=N.split("=")[0],N=N.trim().replace(je,""),N.length<2)return"";for(;N.length%4!==0;)N=N+"=";return N}function $e(N,W){W=W||1/0;let H;const ae=N.length;let be=null;const de=[];for(let me=0;me55295&&H<57344){if(!be){if(H>56319){(W-=3)>-1&&de.push(239,191,189);continue}else if(me+1===ae){(W-=3)>-1&&de.push(239,191,189);continue}be=H;continue}if(H<56320){(W-=3)>-1&&de.push(239,191,189),be=H;continue}H=(be-55296<<10|H-56320)+65536}else be&&(W-=3)>-1&&de.push(239,191,189);if(be=null,H<128){if((W-=1)<0)break;de.push(H)}else if(H<2048){if((W-=2)<0)break;de.push(H>>6|192,H&63|128)}else if(H<65536){if((W-=3)<0)break;de.push(H>>12|224,H>>6&63|128,H&63|128)}else if(H<1114112){if((W-=4)<0)break;de.push(H>>18|240,H>>12&63|128,H>>6&63|128,H&63|128)}else throw new Error("Invalid code point")}return de}function We(N){const W=[];for(let H=0;H>8,be=H%256,de.push(be),de.push(ae);return de}function ze(N){return F.toByteArray(lt(N))}function He(N,W,H,ae){let be;for(be=0;be=W.length||be>=N.length);++be)W[be+H]=N[be];return be}function ut(N,W){return N instanceof W||N!=null&&N.constructor!=null&&N.constructor.name!=null&&N.constructor.name===W.name}function Ue(N){return N!==N}const Ge=function(){const N="0123456789abcdef",W=new Array(256);for(let H=0;H<16;++H){const ae=H*16;for(let be=0;be<16;++be)W[ae+be]=N[H]+N[be]}return W}();function ht(N){return typeof BigInt>"u"?Fe:N}function Fe(){throw new Error("BigInt not supported")}}(p);const O=p.Buffer;n.Blob=p.Blob,n.BlobOptions=p.BlobOptions,n.Buffer=p.Buffer,n.File=p.File,n.FileOptions=p.FileOptions,n.INSPECT_MAX_BYTES=p.INSPECT_MAX_BYTES,n.SlowBuffer=p.SlowBuffer,n.TranscodeEncoding=p.TranscodeEncoding,n.atob=p.atob,n.btoa=p.btoa,n.constants=p.constants,n.default=O,n.isAscii=p.isAscii,n.isUtf8=p.isUtf8,n.kMaxLength=p.kMaxLength,n.kStringMaxLength=p.kStringMaxLength,n.resolveObjectURL=p.resolveObjectURL,n.transcode=p.transcode}(dist)),dist}var hasRequiredSafeBuffer$1;function requireSafeBuffer$1(){return hasRequiredSafeBuffer$1||(hasRequiredSafeBuffer$1=1,function(n,p){var c=requireDist(),l=c.Buffer;function x(E,A){for(var B in E)A[B]=E[B]}l.from&&l.alloc&&l.allocUnsafe&&l.allocUnsafeSlow?n.exports=c:(x(c,p),p.Buffer=o);function o(E,A,B){return l(E,A,B)}o.prototype=Object.create(l.prototype),x(l,o),o.from=function(E,A,B){if(typeof E=="number")throw new TypeError("Argument must not be a number");return l(E,A,B)},o.alloc=function(E,A,B){if(typeof E!="number")throw new TypeError("Argument must be a number");var b=l(E);return A!==void 0?typeof B=="string"?b.fill(A,B):b.fill(A):b.fill(0),b},o.allocUnsafe=function(E){if(typeof E!="number")throw new TypeError("Argument must be a number");return l(E)},o.allocUnsafeSlow=function(E){if(typeof E!="number")throw new TypeError("Argument must be a number");return c.SlowBuffer(E)}}(safeBuffer$1,safeBuffer$1.exports)),safeBuffer$1.exports}var hasRequiredBrowser$b;function requireBrowser$b(){if(hasRequiredBrowser$b)return browser$b.exports;hasRequiredBrowser$b=1;var n=65536,p=4294967295;function c(){throw new Error(`Secure random number generation is not supported by this browser. +`))}function B(q,$,I,P){const O=I.enter("tableCell"),L=I.enter("phrasing"),F=I.containerPhrasing(q,{...P,before:o,after:o});return L(),O(),F}function b(q,$){return markdownTable(q,{align:$,alignDelimiters:l,padding:c,stringLength:x})}function R(q,$,I){const P=q.children;let O=-1;const L=[],F=$.enter("table");for(;++Ox?0:x+p:p=p>x?x:p,c=c>0?c:0,l.length<1e4)E=Array.from(l),E.unshift(p,c),n.splice(...E);else for(c&&n.splice(p,c);o0&&!c&&(n[n.length-1][1]._gfmAutolinkLiteralWalkedInto=!0),c}function resolveAll(n,p,c){const l=[];let x=-1;for(;++x999||g===93&&!E||g===null||g===91||markdownLineEndingOrSpace(g))return c(g);if(g===93){n.exit("chunkString");const S=n.exit("gfmFootnoteCallString");return x.includes(normalizeIdentifier(l.sliceSerialize(S)))?(n.enter("gfmFootnoteCallLabelMarker"),n.consume(g),n.exit("gfmFootnoteCallLabelMarker"),n.exit("gfmFootnoteCall"),p):c(g)}return markdownLineEndingOrSpace(g)||(E=!0),o++,n.consume(g),g===92?R:b}function R(g){return g===91||g===92||g===93?(n.consume(g),o++,b):b(g)}}function tokenizeDefinitionStart(n,p,c){const l=this,x=l.parser.gfmFootnotes||(l.parser.gfmFootnotes=[]);let o,E=0,A;return B;function B($){return n.enter("gfmFootnoteDefinition")._container=!0,n.enter("gfmFootnoteDefinitionLabel"),n.enter("gfmFootnoteDefinitionLabelMarker"),n.consume($),n.exit("gfmFootnoteDefinitionLabelMarker"),b}function b($){return $===94?(n.enter("gfmFootnoteDefinitionMarker"),n.consume($),n.exit("gfmFootnoteDefinitionMarker"),n.enter("gfmFootnoteDefinitionLabelString"),n.enter("chunkString").contentType="string",R):c($)}function R($){if(E>999||$===93&&!A||$===null||$===91||markdownLineEndingOrSpace($))return c($);if($===93){n.exit("chunkString");const I=n.exit("gfmFootnoteDefinitionLabelString");return o=normalizeIdentifier(l.sliceSerialize(I)),n.enter("gfmFootnoteDefinitionLabelMarker"),n.consume($),n.exit("gfmFootnoteDefinitionLabelMarker"),n.exit("gfmFootnoteDefinitionLabel"),S}return markdownLineEndingOrSpace($)||(A=!0),E++,n.consume($),$===92?g:R}function g($){return $===91||$===92||$===93?(n.consume($),E++,R):R($)}function S($){return $===58?(n.enter("definitionMarker"),n.consume($),n.exit("definitionMarker"),x.includes(o)||x.push(o),factorySpace(n,q,"gfmFootnoteDefinitionWhitespace")):c($)}function q($){return p($)}}function tokenizeDefinitionContinuation(n,p,c){return n.check(blankLine,p,n.attempt(indent,p,c))}function gfmFootnoteDefinitionEnd(n){n.exit("gfmFootnoteDefinition")}function tokenizeIndent(n,p,c){const l=this;return factorySpace(n,x,"gfmFootnoteDefinitionIndent",5);function x(o){const E=l.events[l.events.length-1];return E&&E[1].type==="gfmFootnoteDefinitionIndent"&&E[2].sliceSerialize(E[1],!0).length===4?p(o):c(o)}}function gfmStrikethrough(n){let p=(n||{}).singleTilde;const c={name:"strikethrough",tokenize:x,resolveAll:l};return p==null&&(p=!0),{text:{126:c},insideSpan:{null:[c]},attentionMarkers:{null:[126]}};function l(o,E){let A=-1;for(;++A1?A(q):(o.consume(q),R++,S);if(R<2&&!p)return A(q);const I=o.exit("strikethroughSequenceTemporary"),P=classifyCharacter(q);return I._open=!P||P===2&&!!$,I._close=!$||$===2&&!!P,E(q)}}}class EditMap{constructor(){this.map=[]}add(p,c,l){addImplementation(this,p,c,l)}consume(p){if(this.map.sort(function(o,E){return o[0]-E[0]}),this.map.length===0)return;let c=this.map.length;const l=[];for(;c>0;)c-=1,l.push(p.slice(this.map[c][0]+this.map[c][1]),this.map[c][2]),p.length=this.map[c][0];l.push(p.slice()),p.length=0;let x=l.pop();for(;x;){for(const o of x)p.push(o);x=l.pop()}this.map.length=0}}function addImplementation(n,p,c,l){let x=0;if(!(c===0&&l.length===0)){for(;x-1;){const m=l.events[r][1].type;if(m==="lineEnding"||m==="linePrefix")r--;else break}const a=r>-1?l.events[r][1].type:null,s=a==="tableHead"||a==="tableRow"?Y:B;return s===Y&&l.parser.lazy[l.now().line]?c(he):s(he)}function B(he){return n.enter("tableHead"),n.enter("tableRow"),b(he)}function b(he){return he===124||(E=!0,o+=1),R(he)}function R(he){return he===null?c(he):markdownLineEnding(he)?o>1?(o=0,l.interrupt=!0,n.exit("tableRow"),n.enter("lineEnding"),n.consume(he),n.exit("lineEnding"),q):c(he):markdownSpace(he)?factorySpace(n,R,"whitespace")(he):(o+=1,E&&(E=!1,x+=1),he===124?(n.enter("tableCellDivider"),n.consume(he),n.exit("tableCellDivider"),E=!0,R):(n.enter("data"),g(he)))}function g(he){return he===null||he===124||markdownLineEndingOrSpace(he)?(n.exit("data"),R(he)):(n.consume(he),he===92?S:g)}function S(he){return he===92||he===124?(n.consume(he),g):g(he)}function q(he){return l.interrupt=!1,l.parser.lazy[l.now().line]?c(he):(n.enter("tableDelimiterRow"),E=!1,markdownSpace(he)?factorySpace(n,$,"linePrefix",l.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(he):$(he))}function $(he){return he===45||he===58?P(he):he===124?(E=!0,n.enter("tableCellDivider"),n.consume(he),n.exit("tableCellDivider"),I):Q(he)}function I(he){return markdownSpace(he)?factorySpace(n,P,"whitespace")(he):P(he)}function P(he){return he===58?(o+=1,E=!0,n.enter("tableDelimiterMarker"),n.consume(he),n.exit("tableDelimiterMarker"),O):he===45?(o+=1,O(he)):he===null||markdownLineEnding(he)?U(he):Q(he)}function O(he){return he===45?(n.enter("tableDelimiterFiller"),L(he)):Q(he)}function L(he){return he===45?(n.consume(he),L):he===58?(E=!0,n.exit("tableDelimiterFiller"),n.enter("tableDelimiterMarker"),n.consume(he),n.exit("tableDelimiterMarker"),F):(n.exit("tableDelimiterFiller"),F(he))}function F(he){return markdownSpace(he)?factorySpace(n,U,"whitespace")(he):U(he)}function U(he){return he===124?$(he):he===null||markdownLineEnding(he)?!E||x!==o?Q(he):(n.exit("tableDelimiterRow"),n.exit("tableHead"),p(he)):Q(he)}function Q(he){return c(he)}function Y(he){return n.enter("tableRow"),ce(he)}function ce(he){return he===124?(n.enter("tableCellDivider"),n.consume(he),n.exit("tableCellDivider"),ce):he===null||markdownLineEnding(he)?(n.exit("tableRow"),p(he)):markdownSpace(he)?factorySpace(n,ce,"whitespace")(he):(n.enter("data"),le(he))}function le(he){return he===null||he===124||markdownLineEndingOrSpace(he)?(n.exit("data"),ce(he)):(n.consume(he),he===92?ne:le)}function ne(he){return he===92||he===124?(n.consume(he),le):le(he)}}function resolveTable(n,p){let c=-1,l=!0,x=0,o=[0,0,0,0],E=[0,0,0,0],A=!1,B=0,b,R,g;const S=new EditMap;for(;++cc[2]+1){const $=c[2]+1,I=c[3]-c[2]-1;n.add($,I,[])}}n.add(c[3]+1,0,[["exit",g,p]])}return x!==void 0&&(o.end=Object.assign({},getPoint(p.events,x)),n.add(x,0,[["exit",o,p]]),o=void 0),o}function flushTableEnd(n,p,c,l,x){const o=[],E=getPoint(p.events,c);x&&(x.end=Object.assign({},E),o.push(["exit",x,p])),l.end=Object.assign({},E),o.push(["exit",l,p]),n.add(c+1,0,o)}function getPoint(n,p){const c=n[p],l=c[0]==="enter"?"start":"end";return c[1][l]}const tasklistCheck={name:"tasklistCheck",tokenize:tokenizeTasklistCheck};function gfmTaskListItem(){return{text:{91:tasklistCheck}}}function tokenizeTasklistCheck(n,p,c){const l=this;return x;function x(B){return l.previous!==null||!l._gfmTasklistFirstContentOfListItem?c(B):(n.enter("taskListCheck"),n.enter("taskListCheckMarker"),n.consume(B),n.exit("taskListCheckMarker"),o)}function o(B){return markdownLineEndingOrSpace(B)?(n.enter("taskListCheckValueUnchecked"),n.consume(B),n.exit("taskListCheckValueUnchecked"),E):B===88||B===120?(n.enter("taskListCheckValueChecked"),n.consume(B),n.exit("taskListCheckValueChecked"),E):c(B)}function E(B){return B===93?(n.enter("taskListCheckMarker"),n.consume(B),n.exit("taskListCheckMarker"),n.exit("taskListCheck"),A):c(B)}function A(B){return markdownLineEnding(B)?p(B):markdownSpace(B)?n.check({tokenize:spaceThenNonSpace},p,c)(B):c(B)}}function spaceThenNonSpace(n,p,c){return factorySpace(n,l,"whitespace");function l(x){return x===null?c(x):p(x)}}function gfm(n){return combineExtensions([gfmAutolinkLiteral(),gfmFootnote(),gfmStrikethrough(n),gfmTable(),gfmTaskListItem()])}const emptyOptions={};function remarkGfm(n){const p=this,c=n||emptyOptions,l=p.data(),x=l.micromarkExtensions||(l.micromarkExtensions=[]),o=l.fromMarkdownExtensions||(l.fromMarkdownExtensions=[]),E=l.toMarkdownExtensions||(l.toMarkdownExtensions=[]);x.push(gfm(c)),o.push(gfmFromMarkdown()),E.push(gfmToMarkdown(c))}function isTextNode$1(n){return n.type==="text"}const transformPlaceholders=function(n){visit(n,isTextNode$1,p);function p(c,l,x){const o=c.value.split(/(\{[a-z\-_.0-9]+\})/ig).map(E=>{const A=E.match(/^\{([a-z\-_.0-9]+)\}$/i);if(!A)return u("text",E);const[,B]=A;return u("element",{tagName:`#${B}`,children:[]})});x.children.splice(l,1,...o)}},remarkPlaceholder=()=>transformPlaceholders;function isTextNode(n){return["text","code","inlineCode"].includes(n.type)}const remarkUnescape=function(){return function(n){visit(n,isTextNode,(p,c,l)=>(l.children.splice(c,1,{...p,value:p.value.replace(/</gmi,"<").replace(/>/gmi,">")}),[SKIP$1,c+1]))}},LINK_PROTOCOLS=["http","https","mailto","tel"],rehypeHighlight=ref$1(null);async function importRehypeHighlightLibrary(){const n=await __vitePreload(()=>import("./index-C6tzCbpH.chunk.mjs"),__vite__mapDeps([0,1,2,3,4,5,6,7]),import.meta.url);rehypeHighlight.value=n.default}const _sfc_main$d={name:"NcRichText",components:{NcReferenceList},props:{text:{type:String,default:""},arguments:{type:Object,default:()=>({})},referenceLimit:{type:Number,default:0},referenceInteractive:{type:Boolean,default:!0},referenceInteractiveOptIn:{type:Boolean,default:!1},references:{type:Array,default:null},useMarkdown:{type:Boolean,default:!1},useExtendedMarkdown:{type:Boolean,default:!1},interactive:{type:Boolean,default:!1},autolink:{type:Boolean,default:!0}},emits:["interactTodo"],data(){return{parentId:createElementId()}},methods:{renderPlaintext(){const n=this.text.split(/(\{[a-z\-_.0-9]+\})/ig).map(p=>{const c=p.match(/^\{([a-z\-_.0-9]+)\}$/i);if(!c)return this.prepareTextNode(p);const l=c[1],x=this.arguments[l];if(typeof x=="object"){const{component:o,props:E}=x;return h(typeof o=="string"?resolveComponent(o):o,{...E,class:"rich-text--component"})}return x?h("span",{class:"rich-text--fallback"},x):p});return h("div",{class:"rich-text--wrapper"},[h("div",{},n.flat()),this.referenceLimit>0?h("div",{class:"rich-text--reference-widget"},[h(NcReferenceList,{text:this.text,referenceData:this.references,interactive:this.referenceInteractive,interactiveOptIn:this.referenceInteractiveOptIn})]):null])},renderMarkdown(){const n=unified().use(remarkParse).use(remarkAutolink,{autolink:this.autolink,useMarkdown:this.useMarkdown,useExtendedMarkdown:this.useExtendedMarkdown}).use(remarkUnescape).use(this.useExtendedMarkdown?remarkGfm:void 0).use(remarkBreaks).use(remarkUnlinkProtocols,{except:LINK_PROTOCOLS}).use(remarkRehype,{handlers:{component(p,c){return p(c,c.component,{value:c.value})}}}).use(this.useExtendedMarkdown?rehypeHighlight.value:void 0).use(remarkPlaceholder).use(rehypeExternalLinks,{target:"_blank",rel:["noopener noreferrer"]}).use(rehypeReact,{Fragment,jsx:this.createElement,jsxs:this.createElement,elementAttributeNameCase:"html",prefix:!1}).processSync(this.text.replace(/<[^>]+>/g,p=>p.replace(/")).result;return h("div",{class:"rich-text--wrapper rich-text--wrapper-markdown"},[n,this.referenceLimit>0?h("div",{class:"rich-text--reference-widget"},[h(NcReferenceList,{text:this.text,referenceData:this.references,interactive:this.referenceInteractive,interactiveOptIn:this.referenceInteractiveOptIn})]):null])},prepareTextNode(n){return this.autolink&&(n=parseUrl(n)),Array.isArray(n)?n.map(p=>{if(typeof p=="string")return p;const{component:c,props:l}=p,x=c.name==="NcLink"?void 0:"rich-text--component";return h(c,{...l,class:x})}):n},createElement(n,p,c){c&&(p.key=c);const l=p.children??[];if(delete p.children,!String(n).startsWith("#")){let o=null;if(this.useExtendedMarkdown&&(String(n)==="code"&&!rehypeHighlight.value&&p?.class?.includes("language")&&importRehypeHighlightLibrary(),String(n)==="li"&&Array.isArray(l)&&l.length!==0&&l[0].type==="input"&&l[0].props.type==="checkbox")){const[E,,...A]=l,B=A.findIndex(S=>["ul","ol","li","blockquote","pre"].includes(S.type));B!==-1&&(o=A[B],A.splice(B));const b=this.parentId+"-markdown-input-"+createElementId(),R={...E.props};delete R.checked;const g=h(NcCheckboxRadioSwitch,{...R,modelValue:E.props.checked,id:b,disabled:!this.interactive,"onUpdate:modelValue":()=>{this.$emit("interactTodo",b)}},{default:()=>A});return h(n,p,[g,o])}if(String(n)==="a"){const E=getRoute(this.$router,p.href);if(E)return delete p.href,delete p.target,h(RouterLink,{...p,to:E},{default:()=>l})}return h(n,p,l)}const x=this.arguments[n.slice(1)];return x?x.component?h(typeof x.component=="string"?resolveComponent(x.component):x.component,{...p,...x.props,class:"rich-text--component"},{default:()=>l}):h("span",{...p},[x]):h("span",{...p,class:"rich-text--fallback"},[`{${n.slice(1)}}`])}},render(){return this.useMarkdown||this.useExtendedMarkdown?this.renderMarkdown():this.renderPlaintext()}},NcRichText=_export_sfc(_sfc_main$d,[["__scopeId","data-v-bfd4d4b7"]]),_sfc_main$c={__name:"ActionButton",props:{action:{type:Object,required:!0}},emits:["click"],setup(n,{emit:p}){const c=n,l=p,x=computed(()=>c.action.type==="WEB");function o(E){const A={url:c.action.link,type:c.action.type||"GET"};l("click",{event:E,action:A})}return(E,A)=>(openBlock(),createBlock(unref(NcButton),{variant:x.value||n.action.primary?"primary":"secondary",href:x.value?n.action.link:void 0,class:"action-button pull-right",onClick:o},{default:withCtx(()=>[createTextVNode(toDisplayString(n.action.label),1)]),_:1},8,["variant","href"]))}},_sfc_main$b={name:"DefaultParameter",props:{type:{type:String,required:!0},id:{type:[Number,String],required:!0},name:{type:String,required:!0},link:{type:String,default:""}},computed:{hasInternalLink(){return this.link&&(this.type==="deck-board"||this.type==="deck-card")}}},_hoisted_1$b=["href"],_hoisted_2$9=["href"],_hoisted_3$7={key:2};function _sfc_render$a(n,p,c,l,x,o){return o.hasInternalLink?(openBlock(),createElementBlock("a",{key:0,href:c.link},[createBaseVNode("strong",null,toDisplayString(c.name),1)],8,_hoisted_1$b)):c.link?(openBlock(),createElementBlock("a",{key:1,href:c.link,class:"external",target:"_blank",rel:"noopener noreferrer"},[createBaseVNode("strong",null,toDisplayString(c.name),1)],8,_hoisted_2$9)):(openBlock(),createElementBlock("strong",_hoisted_3$7,toDisplayString(c.name),1))}const DefaultParameter=_export_sfc$1(_sfc_main$b,[["render",_sfc_render$a],["__scopeId","data-v-9803ab31"]]),_sfc_main$a={name:"FileParameter",props:{type:{type:String,required:!0},id:{type:[Number,String],required:!0},name:{type:String,required:!0},path:{type:String,default:""},link:{type:String,default:""}},computed:{title(){const n=this.path.lastIndexOf("/"),p=this.path.indexOf("/"),c=this.path.substring(p===0?1:0,n);return c.length===0?"":translate("notifications","in {path}",{path:c})}}},_hoisted_1$a=["title","href"];function _sfc_render$9(n,p,c,l,x,o){return openBlock(),createElementBlock("a",{title:o.title,class:"filename",href:c.link},toDisplayString(c.name),9,_hoisted_1$a)}const FileParameter=_export_sfc$1(_sfc_main$a,[["render",_sfc_render$9]]),defaultWindow=isClient?window:void 0;function unrefElement(n){var p;const c=toValue(n);return(p=c?.$el)!=null?p:c}function useEventListener(...n){const p=[],c=()=>{p.forEach(A=>A()),p.length=0},l=(A,B,b,R)=>(A.addEventListener(B,b,R),()=>A.removeEventListener(B,b,R)),x=computed(()=>{const A=toArray(toValue(n[0])).filter(B=>B!=null);return A.every(B=>typeof B!="string")?A:void 0}),o=watchImmediate(()=>{var A,B;return[(B=(A=x.value)==null?void 0:A.map(b=>unrefElement(b)))!=null?B:[defaultWindow].filter(b=>b!=null),toArray(toValue(x.value?n[1]:n[0])),toArray(unref(x.value?n[2]:n[1])),toValue(x.value?n[3]:n[2])]},([A,B,b,R])=>{if(c(),!A?.length||!B?.length||!b?.length)return;const g=isObject(R)?{...R}:R;p.push(...A.flatMap(S=>B.flatMap(q=>b.map($=>l(S,q,$,g)))))},{flush:"post"}),E=()=>{o(),c()};return tryOnScopeDispose(c),E}let _iOSWorkaround=!1;function onClickOutside(n,p,c={}){const{window:l=defaultWindow,ignore:x=[],capture:o=!0,detectIframe:E=!1,controls:A=!1}=c;if(!l)return A?{stop:noop,cancel:noop,trigger:noop}:noop;if(isIOS&&!_iOSWorkaround){_iOSWorkaround=!0;const P={passive:!0};Array.from(l.document.body.children).forEach(O=>O.addEventListener("click",noop,P)),l.document.documentElement.addEventListener("click",noop,P)}let B=!0;const b=P=>toValue(x).some(O=>{if(typeof O=="string")return Array.from(l.document.querySelectorAll(O)).some(L=>L===P.target||P.composedPath().includes(L));{const L=unrefElement(O);return L&&(P.target===L||P.composedPath().includes(L))}});function R(P){const O=toValue(P);return O&&O.$.subTree.shapeFlag===16}function g(P,O){const L=toValue(P),F=L.$.subTree&&L.$.subTree.children;return F==null||!Array.isArray(F)?!1:F.some(U=>U.el===O.target||O.composedPath().includes(U.el))}const S=P=>{const O=unrefElement(n);if(P.target!=null&&!(!(O instanceof Element)&&R(n)&&g(n,P))&&!(!O||O===P.target||P.composedPath().includes(O))){if("detail"in P&&P.detail===0&&(B=!b(P)),!B){B=!0;return}p(P)}};let q=!1;const $=[useEventListener(l,"click",P=>{q||(q=!0,setTimeout(()=>{q=!1},0),S(P))},{passive:!0,capture:o}),useEventListener(l,"pointerdown",P=>{const O=unrefElement(n);B=!b(P)&&!!(O&&!P.composedPath().includes(O))},{passive:!0}),E&&useEventListener(l,"blur",P=>{setTimeout(()=>{var O;const L=unrefElement(n);((O=l.document.activeElement)==null?void 0:O.tagName)==="IFRAME"&&!L?.contains(l.document.activeElement)&&p(P)},0)},{passive:!0})].filter(Boolean),I=()=>$.forEach(P=>P());return A?{stop:I,cancel:()=>{B=!1},trigger:P=>{B=!0,S(P),B=!1}}:I}const stopClickOutsideMap=new WeakMap,vOnClickOutside={mounted(n,p){const c=!p.modifiers.bubble;let l;if(typeof p.value=="function")l=onClickOutside(n,p.value,{capture:c});else{const[x,o]=p.value;l=onClickOutside(n,x,Object.assign({capture:c},o))}stopClickOutsideMap.set(n,l)},unmounted(n){const p=stopClickOutsideMap.get(n);p&&typeof p=="function"?p():p?.stop(),stopClickOutsideMap.delete(n)}};function resolveElement(n){return typeof Window<"u"&&n instanceof Window?n.document.documentElement:typeof Document<"u"&&n instanceof Document?n.documentElement:n}function checkOverflowScroll(n){const p=window.getComputedStyle(n);if(p.overflowX==="scroll"||p.overflowY==="scroll"||p.overflowX==="auto"&&n.clientWidth1?!0:(p.preventDefault&&p.preventDefault(),!1)}const elInitialOverflow=new WeakMap;function useScrollLock(n,p=!1){const c=shallowRef(p);let l=null,x="";watch(toRef$1(n),A=>{const B=resolveElement(toValue(A));if(B){const b=B;if(elInitialOverflow.get(b)||elInitialOverflow.set(b,b.style.overflow),b.style.overflow!=="hidden"&&(x=b.style.overflow),b.style.overflow==="hidden")return c.value=!0;if(c.value)return b.style.overflow="hidden"}},{immediate:!0});const o=()=>{const A=resolveElement(toValue(n));!A||c.value||(isIOS&&(l=useEventListener(A,"touchmove",B=>{preventDefault(B)},{passive:!1})),A.style.overflow="hidden",c.value=!0)},E=()=>{const A=resolveElement(toValue(n));!A||!c.value||(isIOS&&l?.(),A.style.overflow=x,elInitialOverflow.delete(A),c.value=!1)};return tryOnScopeDispose(E),computed({get(){return c.value},set(A){A?o():E()}})}function onScrollLock(){let n=!1;const p=shallowRef(!1);return(c,l)=>{if(p.value=l.value,n)return;n=!0;const x=useScrollLock(c,l.value);watch(p,o=>x.value=o)}}onScrollLock();function getEnabledContactsMenuActions(n){return window._nc_contacts_menu_hooks?Object.values(window._nc_contacts_menu_hooks).filter(p=>p.enabled(n)):[]}var cryptoBrowserify={},browser$b={exports:{}},safeBuffer$1={exports:{}},dist={},hasRequiredDist;function requireDist(){return hasRequiredDist||(hasRequiredDist=1,function(n){Object.defineProperties(n,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var p={},c={};c.byteLength=R,c.toByteArray=S,c.fromByteArray=I;for(var l=[],x=[],o=typeof Uint8Array<"u"?Uint8Array:Array,E="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",A=0,B=E.length;A0)throw new Error("Invalid string. Length must be a multiple of 4");var U=L.indexOf("=");U===-1&&(U=F);var Q=U===F?0:4-U%4;return[U,Q]}function R(L){var F=b(L),U=F[0],Q=F[1];return(U+Q)*3/4-Q}function g(L,F,U){return(F+U)*3/4-U}function S(L){var F,U=b(L),Q=U[0],Y=U[1],ce=new o(g(L,Q,Y)),le=0,ne=Y>0?Q-4:Q,he;for(he=0;he>16&255,ce[le++]=F>>8&255,ce[le++]=F&255;return Y===2&&(F=x[L.charCodeAt(he)]<<2|x[L.charCodeAt(he+1)]>>4,ce[le++]=F&255),Y===1&&(F=x[L.charCodeAt(he)]<<10|x[L.charCodeAt(he+1)]<<4|x[L.charCodeAt(he+2)]>>2,ce[le++]=F>>8&255,ce[le++]=F&255),ce}function q(L){return l[L>>18&63]+l[L>>12&63]+l[L>>6&63]+l[L&63]}function $(L,F,U){for(var Q,Y=[],ce=F;cene?ne:le+ce));return Q===1?(F=L[U-1],Y.push(l[F>>2]+l[F<<4&63]+"==")):Q===2&&(F=(L[U-2]<<8)+L[U-1],Y.push(l[F>>10]+l[F>>4&63]+l[F<<2&63]+"=")),Y.join("")}var P={};P.read=function(L,F,U,Q,Y){var ce,le,ne=Y*8-Q-1,he=(1<>1,a=-7,s=U?Y-1:0,m=U?-1:1,k=L[F+s];for(s+=m,ce=k&(1<<-a)-1,k>>=-a,a+=ne;a>0;ce=ce*256+L[F+s],s+=m,a-=8);for(le=ce&(1<<-a)-1,ce>>=-a,a+=Q;a>0;le=le*256+L[F+s],s+=m,a-=8);if(ce===0)ce=1-r;else{if(ce===he)return le?NaN:(k?-1:1)*(1/0);le=le+Math.pow(2,Q),ce=ce-r}return(k?-1:1)*le*Math.pow(2,ce-Q)},P.write=function(L,F,U,Q,Y,ce){var le,ne,he,r=ce*8-Y-1,a=(1<>1,m=Y===23?Math.pow(2,-24)-Math.pow(2,-77):0,k=Q?0:ce-1,C=Q?1:-1,T=F<0||F===0&&1/F<0?1:0;for(F=Math.abs(F),isNaN(F)||F===1/0?(ne=isNaN(F)?1:0,le=a):(le=Math.floor(Math.log(F)/Math.LN2),F*(he=Math.pow(2,-le))<1&&(le--,he*=2),le+s>=1?F+=m/he:F+=m*Math.pow(2,1-s),F*he>=2&&(le++,he/=2),le+s>=a?(ne=0,le=a):le+s>=1?(ne=(F*he-1)*Math.pow(2,Y),le=le+s):(ne=F*Math.pow(2,s-1)*Math.pow(2,Y),le=0));Y>=8;L[U+k]=ne&255,k+=C,ne/=256,Y-=8);for(le=le<0;L[U+k]=le&255,k+=C,le/=256,r-=8);L[U+k-C]|=T*128},function(L){const F=c,U=P,Q=typeof Symbol=="function"&&typeof Symbol.for=="function"?Symbol.for("nodejs.util.inspect.custom"):null;L.Buffer=a,L.SlowBuffer=z,L.INSPECT_MAX_BYTES=50;const Y=2147483647;L.kMaxLength=Y;const{Uint8Array:ce,ArrayBuffer:le,SharedArrayBuffer:ne}=globalThis;a.TYPED_ARRAY_SUPPORT=he(),!a.TYPED_ARRAY_SUPPORT&&typeof console<"u"&&typeof console.error=="function"&&console.error("This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support.");function he(){try{const N=new ce(1),W={foo:function(){return 42}};return Object.setPrototypeOf(W,ce.prototype),Object.setPrototypeOf(N,W),N.foo()===42}catch{return!1}}Object.defineProperty(a.prototype,"parent",{enumerable:!0,get:function(){if(a.isBuffer(this))return this.buffer}}),Object.defineProperty(a.prototype,"offset",{enumerable:!0,get:function(){if(a.isBuffer(this))return this.byteOffset}});function r(N){if(N>Y)throw new RangeError('The value "'+N+'" is invalid for option "size"');const W=new ce(N);return Object.setPrototypeOf(W,a.prototype),W}function a(N,W,H){if(typeof N=="number"){if(typeof W=="string")throw new TypeError('The "string" argument must be of type string. Received type number');return C(N)}return s(N,W,H)}a.poolSize=8192;function s(N,W,H){if(typeof N=="string")return T(N,W);if(le.isView(N))return i(N);if(N==null)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof N);if(ut(N,le)||N&&ut(N.buffer,le)||typeof ne<"u"&&(ut(N,ne)||N&&ut(N.buffer,ne)))return y(N,W,H);if(typeof N=="number")throw new TypeError('The "value" argument must not be of type number. Received type number');const ae=N.valueOf&&N.valueOf();if(ae!=null&&ae!==N)return a.from(ae,W,H);const be=D(N);if(be)return be;if(typeof Symbol<"u"&&Symbol.toPrimitive!=null&&typeof N[Symbol.toPrimitive]=="function")return a.from(N[Symbol.toPrimitive]("string"),W,H);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof N)}a.from=function(N,W,H){return s(N,W,H)},Object.setPrototypeOf(a.prototype,ce.prototype),Object.setPrototypeOf(a,ce);function m(N){if(typeof N!="number")throw new TypeError('"size" argument must be of type number');if(N<0)throw new RangeError('The value "'+N+'" is invalid for option "size"')}function k(N,W,H){return m(N),N<=0?r(N):W!==void 0?typeof H=="string"?r(N).fill(W,H):r(N).fill(W):r(N)}a.alloc=function(N,W,H){return k(N,W,H)};function C(N){return m(N),r(N<0?0:j(N)|0)}a.allocUnsafe=function(N){return C(N)},a.allocUnsafeSlow=function(N){return C(N)};function T(N,W){if((typeof W!="string"||W==="")&&(W="utf8"),!a.isEncoding(W))throw new TypeError("Unknown encoding: "+W);const H=X(N,W)|0;let ae=r(H);const be=ae.write(N,W);return be!==H&&(ae=ae.slice(0,be)),ae}function M(N){const W=N.length<0?0:j(N.length)|0,H=r(W);for(let ae=0;ae=Y)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+Y.toString(16)+" bytes");return N|0}function z(N){return+N!=N&&(N=0),a.alloc(+N)}a.isBuffer=function(N){return N!=null&&N._isBuffer===!0&&N!==a.prototype},a.compare=function(N,W){if(ut(N,ce)&&(N=a.from(N,N.offset,N.byteLength)),ut(W,ce)&&(W=a.from(W,W.offset,W.byteLength)),!a.isBuffer(N)||!a.isBuffer(W))throw new TypeError('The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array');if(N===W)return 0;let H=N.length,ae=W.length;for(let be=0,de=Math.min(H,ae);beae.length?(a.isBuffer(de)||(de=a.from(de)),de.copy(ae,be)):ce.prototype.set.call(ae,de,be);else if(a.isBuffer(de))de.copy(ae,be);else throw new TypeError('"list" argument must be an Array of Buffers');be+=de.length}return ae};function X(N,W){if(a.isBuffer(N))return N.length;if(le.isView(N)||ut(N,le))return N.byteLength;if(typeof N!="string")throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof N);const H=N.length,ae=arguments.length>2&&arguments[2]===!0;if(!ae&&H===0)return 0;let be=!1;for(;;)switch(W){case"ascii":case"latin1":case"binary":return H;case"utf8":case"utf-8":return $e(N).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return H*2;case"hex":return H>>>1;case"base64":return ze(N).length;default:if(be)return ae?-1:$e(N).length;W=(""+W).toLowerCase(),be=!0}}a.byteLength=X;function te(N,W,H){let ae=!1;if((W===void 0||W<0)&&(W=0),W>this.length||((H===void 0||H>this.length)&&(H=this.length),H<=0)||(H>>>=0,W>>>=0,H<=W))return"";for(N||(N="utf8");;)switch(N){case"hex":return xe(this,W,H);case"utf8":case"utf-8":return Me(this,W,H);case"ascii":return Le(this,W,H);case"latin1":case"binary":return Be(this,W,H);case"base64":return pe(this,W,H);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return Ie(this,W,H);default:if(ae)throw new TypeError("Unknown encoding: "+N);N=(N+"").toLowerCase(),ae=!0}}a.prototype._isBuffer=!0;function ee(N,W,H){const ae=N[W];N[W]=N[H],N[H]=ae}a.prototype.swap16=function(){const N=this.length;if(N%2!==0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let W=0;WW&&(N+=" ... "),""},Q&&(a.prototype[Q]=a.prototype.inspect),a.prototype.compare=function(N,W,H,ae,be){if(ut(N,ce)&&(N=a.from(N,N.offset,N.byteLength)),!a.isBuffer(N))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof N);if(W===void 0&&(W=0),H===void 0&&(H=N?N.length:0),ae===void 0&&(ae=0),be===void 0&&(be=this.length),W<0||H>N.length||ae<0||be>this.length)throw new RangeError("out of range index");if(ae>=be&&W>=H)return 0;if(ae>=be)return-1;if(W>=H)return 1;if(W>>>=0,H>>>=0,ae>>>=0,be>>>=0,this===N)return 0;let de=be-ae,me=H-W;const it=Math.min(de,me),qe=this.slice(ae,be),De=N.slice(W,H);for(let rt=0;rt2147483647?H=2147483647:H<-2147483648&&(H=-2147483648),H=+H,Ue(H)&&(H=be?0:N.length-1),H<0&&(H=N.length+H),H>=N.length){if(be)return-1;H=N.length-1}else if(H<0)if(be)H=0;else return-1;if(typeof W=="string"&&(W=a.from(W,ae)),a.isBuffer(W))return W.length===0?-1:V(N,W,H,ae,be);if(typeof W=="number")return W=W&255,typeof ce.prototype.indexOf=="function"?be?ce.prototype.indexOf.call(N,W,H):ce.prototype.lastIndexOf.call(N,W,H):V(N,[W],H,ae,be);throw new TypeError("val must be string, number or Buffer")}function V(N,W,H,ae,be){let de=1,me=N.length,it=W.length;if(ae!==void 0&&(ae=String(ae).toLowerCase(),ae==="ucs2"||ae==="ucs-2"||ae==="utf16le"||ae==="utf-16le")){if(N.length<2||W.length<2)return-1;de=2,me/=2,it/=2,H/=2}function qe(rt,Ee){return de===1?rt[Ee]:rt.readUInt16BE(Ee*de)}let De;if(be){let rt=-1;for(De=H;Deme&&(H=me-it),De=H;De>=0;De--){let rt=!0;for(let Ee=0;Eebe&&(ae=be)):ae=be;const de=W.length;ae>de/2&&(ae=de/2);let me;for(me=0;me>>0,isFinite(H)?(H=H>>>0,ae===void 0&&(ae="utf8")):(ae=H,H=void 0);else throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");const be=this.length-W;if((H===void 0||H>be)&&(H=be),N.length>0&&(H<0||W<0)||W>this.length)throw new RangeError("Attempt to write outside buffer bounds");ae||(ae="utf8");let de=!1;for(;;)switch(ae){case"hex":return oe(this,N,W,H);case"utf8":case"utf-8":return ye(this,N,W,H);case"ascii":case"latin1":case"binary":return Z(this,N,W,H);case"base64":return J(this,N,W,H);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return _e(this,N,W,H);default:if(de)throw new TypeError("Unknown encoding: "+ae);ae=(""+ae).toLowerCase(),de=!0}},a.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};function pe(N,W,H){return W===0&&H===N.length?F.fromByteArray(N):F.fromByteArray(N.slice(W,H))}function Me(N,W,H){H=Math.min(N.length,H);const ae=[];let be=W;for(;be239?4:de>223?3:de>191?2:1;if(be+it<=H){let qe,De,rt,Ee;switch(it){case 1:de<128&&(me=de);break;case 2:qe=N[be+1],(qe&192)===128&&(Ee=(de&31)<<6|qe&63,Ee>127&&(me=Ee));break;case 3:qe=N[be+1],De=N[be+2],(qe&192)===128&&(De&192)===128&&(Ee=(de&15)<<12|(qe&63)<<6|De&63,Ee>2047&&(Ee<55296||Ee>57343)&&(me=Ee));break;case 4:qe=N[be+1],De=N[be+2],rt=N[be+3],(qe&192)===128&&(De&192)===128&&(rt&192)===128&&(Ee=(de&15)<<18|(qe&63)<<12|(De&63)<<6|rt&63,Ee>65535&&Ee<1114112&&(me=Ee))}}me===null?(me=65533,it=1):me>65535&&(me-=65536,ae.push(me>>>10&1023|55296),me=56320|me&1023),ae.push(me),be+=it}return ke(ae)}const Ke=4096;function ke(N){const W=N.length;if(W<=Ke)return String.fromCharCode.apply(String,N);let H="",ae=0;for(;aeae)&&(H=ae);let be="";for(let de=W;deH&&(N=H),W<0?(W+=H,W<0&&(W=0)):W>H&&(W=H),WH)throw new RangeError("Trying to access beyond buffer length")}a.prototype.readUintLE=a.prototype.readUIntLE=function(N,W,H){N=N>>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=this[N],be=1,de=0;for(;++de>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=this[N+--W],be=1;for(;W>0&&(be*=256);)ae+=this[N+--W]*be;return ae},a.prototype.readUint8=a.prototype.readUInt8=function(N,W){return N=N>>>0,W||Ye(N,1,this.length),this[N]},a.prototype.readUint16LE=a.prototype.readUInt16LE=function(N,W){return N=N>>>0,W||Ye(N,2,this.length),this[N]|this[N+1]<<8},a.prototype.readUint16BE=a.prototype.readUInt16BE=function(N,W){return N=N>>>0,W||Ye(N,2,this.length),this[N]<<8|this[N+1]},a.prototype.readUint32LE=a.prototype.readUInt32LE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),(this[N]|this[N+1]<<8|this[N+2]<<16)+this[N+3]*16777216},a.prototype.readUint32BE=a.prototype.readUInt32BE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),this[N]*16777216+(this[N+1]<<16|this[N+2]<<8|this[N+3])},a.prototype.readBigUInt64LE=ht(function(N){N=N>>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=W+this[++N]*2**8+this[++N]*2**16+this[++N]*2**24,be=this[++N]+this[++N]*2**8+this[++N]*2**16+H*2**24;return BigInt(ae)+(BigInt(be)<>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=W*2**24+this[++N]*2**16+this[++N]*2**8+this[++N],be=this[++N]*2**24+this[++N]*2**16+this[++N]*2**8+H;return(BigInt(ae)<>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=this[N],be=1,de=0;for(;++de=be&&(ae-=Math.pow(2,8*W)),ae},a.prototype.readIntBE=function(N,W,H){N=N>>>0,W=W>>>0,H||Ye(N,W,this.length);let ae=W,be=1,de=this[N+--ae];for(;ae>0&&(be*=256);)de+=this[N+--ae]*be;return be*=128,de>=be&&(de-=Math.pow(2,8*W)),de},a.prototype.readInt8=function(N,W){return N=N>>>0,W||Ye(N,1,this.length),this[N]&128?(255-this[N]+1)*-1:this[N]},a.prototype.readInt16LE=function(N,W){N=N>>>0,W||Ye(N,2,this.length);const H=this[N]|this[N+1]<<8;return H&32768?H|4294901760:H},a.prototype.readInt16BE=function(N,W){N=N>>>0,W||Ye(N,2,this.length);const H=this[N+1]|this[N]<<8;return H&32768?H|4294901760:H},a.prototype.readInt32LE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),this[N]|this[N+1]<<8|this[N+2]<<16|this[N+3]<<24},a.prototype.readInt32BE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),this[N]<<24|this[N+1]<<16|this[N+2]<<8|this[N+3]},a.prototype.readBigInt64LE=ht(function(N){N=N>>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=this[N+4]+this[N+5]*2**8+this[N+6]*2**16+(H<<24);return(BigInt(ae)<>>0,st(N,"offset");const W=this[N],H=this[N+7];(W===void 0||H===void 0)&&Ce(N,this.length-8);const ae=(W<<24)+this[++N]*2**16+this[++N]*2**8+this[++N];return(BigInt(ae)<>>0,W||Ye(N,4,this.length),U.read(this,N,!0,23,4)},a.prototype.readFloatBE=function(N,W){return N=N>>>0,W||Ye(N,4,this.length),U.read(this,N,!1,23,4)},a.prototype.readDoubleLE=function(N,W){return N=N>>>0,W||Ye(N,8,this.length),U.read(this,N,!0,52,8)},a.prototype.readDoubleBE=function(N,W){return N=N>>>0,W||Ye(N,8,this.length),U.read(this,N,!1,52,8)};function Se(N,W,H,ae,be,de){if(!a.isBuffer(N))throw new TypeError('"buffer" argument must be a Buffer instance');if(W>be||WN.length)throw new RangeError("Index out of range")}a.prototype.writeUintLE=a.prototype.writeUIntLE=function(N,W,H,ae){if(N=+N,W=W>>>0,H=H>>>0,!ae){const me=Math.pow(2,8*H)-1;Se(this,N,W,H,me,0)}let be=1,de=0;for(this[W]=N&255;++de>>0,H=H>>>0,!ae){const me=Math.pow(2,8*H)-1;Se(this,N,W,H,me,0)}let be=H-1,de=1;for(this[W+be]=N&255;--be>=0&&(de*=256);)this[W+be]=N/de&255;return W+H},a.prototype.writeUint8=a.prototype.writeUInt8=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,1,255,0),this[W]=N&255,W+1},a.prototype.writeUint16LE=a.prototype.writeUInt16LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,65535,0),this[W]=N&255,this[W+1]=N>>>8,W+2},a.prototype.writeUint16BE=a.prototype.writeUInt16BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,65535,0),this[W]=N>>>8,this[W+1]=N&255,W+2},a.prototype.writeUint32LE=a.prototype.writeUInt32LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,4294967295,0),this[W+3]=N>>>24,this[W+2]=N>>>16,this[W+1]=N>>>8,this[W]=N&255,W+4},a.prototype.writeUint32BE=a.prototype.writeUInt32BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,4294967295,0),this[W]=N>>>24,this[W+1]=N>>>16,this[W+2]=N>>>8,this[W+3]=N&255,W+4};function Ne(N,W,H,ae,be){Ve(W,ae,be,N,H,7);let de=Number(W&BigInt(4294967295));N[H++]=de,de=de>>8,N[H++]=de,de=de>>8,N[H++]=de,de=de>>8,N[H++]=de;let me=Number(W>>BigInt(32)&BigInt(4294967295));return N[H++]=me,me=me>>8,N[H++]=me,me=me>>8,N[H++]=me,me=me>>8,N[H++]=me,H}function we(N,W,H,ae,be){Ve(W,ae,be,N,H,7);let de=Number(W&BigInt(4294967295));N[H+7]=de,de=de>>8,N[H+6]=de,de=de>>8,N[H+5]=de,de=de>>8,N[H+4]=de;let me=Number(W>>BigInt(32)&BigInt(4294967295));return N[H+3]=me,me=me>>8,N[H+2]=me,me=me>>8,N[H+1]=me,me=me>>8,N[H]=me,H+8}a.prototype.writeBigUInt64LE=ht(function(N,W=0){return Ne(this,N,W,BigInt(0),BigInt("0xffffffffffffffff"))}),a.prototype.writeBigUInt64BE=ht(function(N,W=0){return we(this,N,W,BigInt(0),BigInt("0xffffffffffffffff"))}),a.prototype.writeIntLE=function(N,W,H,ae){if(N=+N,W=W>>>0,!ae){const it=Math.pow(2,8*H-1);Se(this,N,W,H,it-1,-it)}let be=0,de=1,me=0;for(this[W]=N&255;++be>0)-me&255;return W+H},a.prototype.writeIntBE=function(N,W,H,ae){if(N=+N,W=W>>>0,!ae){const it=Math.pow(2,8*H-1);Se(this,N,W,H,it-1,-it)}let be=H-1,de=1,me=0;for(this[W+be]=N&255;--be>=0&&(de*=256);)N<0&&me===0&&this[W+be+1]!==0&&(me=1),this[W+be]=(N/de>>0)-me&255;return W+H},a.prototype.writeInt8=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,1,127,-128),N<0&&(N=255+N+1),this[W]=N&255,W+1},a.prototype.writeInt16LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,32767,-32768),this[W]=N&255,this[W+1]=N>>>8,W+2},a.prototype.writeInt16BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,2,32767,-32768),this[W]=N>>>8,this[W+1]=N&255,W+2},a.prototype.writeInt32LE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,2147483647,-2147483648),this[W]=N&255,this[W+1]=N>>>8,this[W+2]=N>>>16,this[W+3]=N>>>24,W+4},a.prototype.writeInt32BE=function(N,W,H){return N=+N,W=W>>>0,H||Se(this,N,W,4,2147483647,-2147483648),N<0&&(N=4294967295+N+1),this[W]=N>>>24,this[W+1]=N>>>16,this[W+2]=N>>>8,this[W+3]=N&255,W+4},a.prototype.writeBigInt64LE=ht(function(N,W=0){return Ne(this,N,W,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))}),a.prototype.writeBigInt64BE=ht(function(N,W=0){return we(this,N,W,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))});function se(N,W,H,ae,be,de){if(H+ae>N.length)throw new RangeError("Index out of range");if(H<0)throw new RangeError("Index out of range")}function ge(N,W,H,ae,be){return W=+W,H=H>>>0,be||se(N,W,H,4),U.write(N,W,H,ae,23,4),H+4}a.prototype.writeFloatLE=function(N,W,H){return ge(this,N,W,!0,H)},a.prototype.writeFloatBE=function(N,W,H){return ge(this,N,W,!1,H)};function Xe(N,W,H,ae,be){return W=+W,H=H>>>0,be||se(N,W,H,8),U.write(N,W,H,ae,52,8),H+8}a.prototype.writeDoubleLE=function(N,W,H){return Xe(this,N,W,!0,H)},a.prototype.writeDoubleBE=function(N,W,H){return Xe(this,N,W,!1,H)},a.prototype.copy=function(N,W,H,ae){if(!a.isBuffer(N))throw new TypeError("argument should be a Buffer");if(H||(H=0),!ae&&ae!==0&&(ae=this.length),W>=N.length&&(W=N.length),W||(W=0),ae>0&&ae=this.length)throw new RangeError("Index out of range");if(ae<0)throw new RangeError("sourceEnd out of bounds");ae>this.length&&(ae=this.length),N.length-W>>0,H=H===void 0?this.length:H>>>0,N||(N=0);let be;if(typeof N=="number")for(be=W;be2**32?be=at(String(H)):typeof H=="bigint"&&(be=String(H),(H>BigInt(2)**BigInt(32)||H<-(BigInt(2)**BigInt(32)))&&(be=at(be)),be+="n"),ae+=` It must be ${W}. Received ${be}`,ae},RangeError);function at(N){let W="",H=N.length;const ae=N[0]==="-"?1:0;for(;H>=ae+4;H-=3)W=`_${N.slice(H-3,H)}${W}`;return`${N.slice(0,H)}${W}`}function Pe(N,W,H){st(W,"offset"),(N[W]===void 0||N[W+H]===void 0)&&Ce(W,N.length-(H+1))}function Ve(N,W,H,ae,be,de){if(N>H||N= 0${me} and < 2${me} ** ${(de+1)*8}${me}`:it=`>= -(2${me} ** ${(de+1)*8-1}${me}) and < 2 ** ${(de+1)*8-1}${me}`,new Ae.ERR_OUT_OF_RANGE("value",it,N)}Pe(ae,be,de)}function st(N,W){if(typeof N!="number")throw new Ae.ERR_INVALID_ARG_TYPE(W,"number",N)}function Ce(N,W,H){throw Math.floor(N)!==N?(st(N,H),new Ae.ERR_OUT_OF_RANGE("offset","an integer",N)):W<0?new Ae.ERR_BUFFER_OUT_OF_BOUNDS:new Ae.ERR_OUT_OF_RANGE("offset",`>= 0 and <= ${W}`,N)}const je=/[^+/0-9A-Za-z-_]/g;function lt(N){if(N=N.split("=")[0],N=N.trim().replace(je,""),N.length<2)return"";for(;N.length%4!==0;)N=N+"=";return N}function $e(N,W){W=W||1/0;let H;const ae=N.length;let be=null;const de=[];for(let me=0;me55295&&H<57344){if(!be){if(H>56319){(W-=3)>-1&&de.push(239,191,189);continue}else if(me+1===ae){(W-=3)>-1&&de.push(239,191,189);continue}be=H;continue}if(H<56320){(W-=3)>-1&&de.push(239,191,189),be=H;continue}H=(be-55296<<10|H-56320)+65536}else be&&(W-=3)>-1&&de.push(239,191,189);if(be=null,H<128){if((W-=1)<0)break;de.push(H)}else if(H<2048){if((W-=2)<0)break;de.push(H>>6|192,H&63|128)}else if(H<65536){if((W-=3)<0)break;de.push(H>>12|224,H>>6&63|128,H&63|128)}else if(H<1114112){if((W-=4)<0)break;de.push(H>>18|240,H>>12&63|128,H>>6&63|128,H&63|128)}else throw new Error("Invalid code point")}return de}function We(N){const W=[];for(let H=0;H>8,be=H%256,de.push(be),de.push(ae);return de}function ze(N){return F.toByteArray(lt(N))}function He(N,W,H,ae){let be;for(be=0;be=W.length||be>=N.length);++be)W[be+H]=N[be];return be}function ut(N,W){return N instanceof W||N!=null&&N.constructor!=null&&N.constructor.name!=null&&N.constructor.name===W.name}function Ue(N){return N!==N}const Ge=function(){const N="0123456789abcdef",W=new Array(256);for(let H=0;H<16;++H){const ae=H*16;for(let be=0;be<16;++be)W[ae+be]=N[H]+N[be]}return W}();function ht(N){return typeof BigInt>"u"?Fe:N}function Fe(){throw new Error("BigInt not supported")}}(p);const O=p.Buffer;n.Blob=p.Blob,n.BlobOptions=p.BlobOptions,n.Buffer=p.Buffer,n.File=p.File,n.FileOptions=p.FileOptions,n.INSPECT_MAX_BYTES=p.INSPECT_MAX_BYTES,n.SlowBuffer=p.SlowBuffer,n.TranscodeEncoding=p.TranscodeEncoding,n.atob=p.atob,n.btoa=p.btoa,n.constants=p.constants,n.default=O,n.isAscii=p.isAscii,n.isUtf8=p.isUtf8,n.kMaxLength=p.kMaxLength,n.kStringMaxLength=p.kStringMaxLength,n.resolveObjectURL=p.resolveObjectURL,n.transcode=p.transcode}(dist)),dist}var hasRequiredSafeBuffer$1;function requireSafeBuffer$1(){return hasRequiredSafeBuffer$1||(hasRequiredSafeBuffer$1=1,function(n,p){var c=requireDist(),l=c.Buffer;function x(E,A){for(var B in E)A[B]=E[B]}l.from&&l.alloc&&l.allocUnsafe&&l.allocUnsafeSlow?n.exports=c:(x(c,p),p.Buffer=o);function o(E,A,B){return l(E,A,B)}o.prototype=Object.create(l.prototype),x(l,o),o.from=function(E,A,B){if(typeof E=="number")throw new TypeError("Argument must not be a number");return l(E,A,B)},o.alloc=function(E,A,B){if(typeof E!="number")throw new TypeError("Argument must be a number");var b=l(E);return A!==void 0?typeof B=="string"?b.fill(A,B):b.fill(A):b.fill(0),b},o.allocUnsafe=function(E){if(typeof E!="number")throw new TypeError("Argument must be a number");return l(E)},o.allocUnsafeSlow=function(E){if(typeof E!="number")throw new TypeError("Argument must be a number");return c.SlowBuffer(E)}}(safeBuffer$1,safeBuffer$1.exports)),safeBuffer$1.exports}var hasRequiredBrowser$b;function requireBrowser$b(){if(hasRequiredBrowser$b)return browser$b.exports;hasRequiredBrowser$b=1;var n=65536,p=4294967295;function c(){throw new Error(`Secure random number generation is not supported by this browser. Use Chrome, Firefox or Internet Explorer 11`)}var l=requireSafeBuffer$1().Buffer,x=commonjsGlobal.crypto||commonjsGlobal.msCrypto;x&&x.getRandomValues?browser$b.exports=o:browser$b.exports=c;function o(E,A){if(E>p)throw new RangeError("requested too many random bytes");var B=l.allocUnsafe(E);if(E>0)if(E>n)for(var b=0;b0&&(ne=Q[0]),ne instanceof Error)throw ne;var he=new Error("Unhandled error."+(ne?" ("+ne.message+")":""));throw he.context=ne,he}var r=le[U];if(r===void 0)return!1;if(typeof r=="function")p(r,this,Q);else for(var a=r.length,s=$(r,a),Y=0;Y0&&he.length>le&&!he.warned){he.warned=!0;var r=new Error("Possible EventEmitter memory leak detected. "+he.length+" "+String(Q)+" listeners added. Use emitter.setMaxListeners() to increase limit");r.name="MaxListenersExceededWarning",r.emitter=U,r.type=Q,r.count=he.length,l(r)}return U}o.prototype.addListener=function(U,Q){return b(this,U,Q,!1)},o.prototype.on=o.prototype.addListener,o.prototype.prependListener=function(U,Q){return b(this,U,Q,!0)};function R(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,arguments.length===0?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function g(U,Q,Y){var ce={fired:!1,wrapFn:void 0,target:U,type:Q,listener:Y},le=R.bind(ce);return le.listener=Y,ce.wrapFn=le,le}o.prototype.once=function(U,Q){return A(Q),this.on(U,g(this,U,Q)),this},o.prototype.prependOnceListener=function(U,Q){return A(Q),this.prependListener(U,g(this,U,Q)),this},o.prototype.removeListener=function(U,Q){var Y,ce,le,ne,he;if(A(Q),ce=this._events,ce===void 0)return this;if(Y=ce[U],Y===void 0)return this;if(Y===Q||Y.listener===Q)--this._eventsCount===0?this._events=Object.create(null):(delete ce[U],ce.removeListener&&this.emit("removeListener",U,Y.listener||Q));else if(typeof Y!="function"){for(le=-1,ne=Y.length-1;ne>=0;ne--)if(Y[ne]===Q||Y[ne].listener===Q){he=Y[ne].listener,le=ne;break}if(le<0)return this;le===0?Y.shift():I(Y,le),Y.length===1&&(ce[U]=Y[0]),ce.removeListener!==void 0&&this.emit("removeListener",U,he||Q)}return this},o.prototype.off=o.prototype.removeListener,o.prototype.removeAllListeners=function(U){var Q,Y,ce;if(Y=this._events,Y===void 0)return this;if(Y.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):Y[U]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete Y[U]),this;if(arguments.length===0){var le=Object.keys(Y),ne;for(ce=0;ce=0;ce--)this.removeListener(U,Q[ce]);return this};function S(U,Q,Y){var ce=U._events;if(ce===void 0)return[];var le=ce[Q];return le===void 0?[]:typeof le=="function"?Y?[le.listener||le]:[le]:Y?P(le):$(le,le.length)}o.prototype.listeners=function(U){return S(this,U,!0)},o.prototype.rawListeners=function(U){return S(this,U,!1)},o.listenerCount=function(U,Q){return typeof U.listenerCount=="function"?U.listenerCount(Q):q.call(U,Q)},o.prototype.listenerCount=q;function q(U){var Q=this._events;if(Q!==void 0){var Y=Q[U];if(typeof Y=="function")return 1;if(Y!==void 0)return Y.length}return 0}o.prototype.eventNames=function(){return this._eventsCount>0?c(this._events):[]};function $(U,Q){for(var Y=new Array(Q),ce=0;ce"u"||!ce?n:ce(Uint8Array),m={__proto__:null,"%AggregateError%":typeof AggregateError>"u"?n:AggregateError,"%Array%":Array,"%ArrayBuffer%":typeof ArrayBuffer>"u"?n:ArrayBuffer,"%ArrayIteratorPrototype%":Y&&ce?ce([][Symbol.iterator]()):n,"%AsyncFromSyncIteratorPrototype%":n,"%AsyncFunction%":a,"%AsyncGenerator%":a,"%AsyncGeneratorFunction%":a,"%AsyncIteratorPrototype%":a,"%Atomics%":typeof Atomics>"u"?n:Atomics,"%BigInt%":typeof BigInt>"u"?n:BigInt,"%BigInt64Array%":typeof BigInt64Array>"u"?n:BigInt64Array,"%BigUint64Array%":typeof BigUint64Array>"u"?n:BigUint64Array,"%Boolean%":Boolean,"%DataView%":typeof DataView>"u"?n:DataView,"%Date%":Date,"%decodeURI%":decodeURI,"%decodeURIComponent%":decodeURIComponent,"%encodeURI%":encodeURI,"%encodeURIComponent%":encodeURIComponent,"%Error%":c,"%eval%":eval,"%EvalError%":l,"%Float16Array%":typeof Float16Array>"u"?n:Float16Array,"%Float32Array%":typeof Float32Array>"u"?n:Float32Array,"%Float64Array%":typeof Float64Array>"u"?n:Float64Array,"%FinalizationRegistry%":typeof FinalizationRegistry>"u"?n:FinalizationRegistry,"%Function%":P,"%GeneratorFunction%":a,"%Int8Array%":typeof Int8Array>"u"?n:Int8Array,"%Int16Array%":typeof Int16Array>"u"?n:Int16Array,"%Int32Array%":typeof Int32Array>"u"?n:Int32Array,"%isFinite%":isFinite,"%isNaN%":isNaN,"%IteratorPrototype%":Y&&ce?ce(ce([][Symbol.iterator]())):n,"%JSON%":typeof JSON=="object"?JSON:n,"%Map%":typeof Map>"u"?n:Map,"%MapIteratorPrototype%":typeof Map>"u"||!Y||!ce?n:ce(new Map()[Symbol.iterator]()),"%Math%":Math,"%Number%":Number,"%Object%":p,"%Object.getOwnPropertyDescriptor%":L,"%parseFloat%":parseFloat,"%parseInt%":parseInt,"%Promise%":typeof Promise>"u"?n:Promise,"%Proxy%":typeof Proxy>"u"?n:Proxy,"%RangeError%":x,"%ReferenceError%":o,"%Reflect%":typeof Reflect>"u"?n:Reflect,"%RegExp%":RegExp,"%Set%":typeof Set>"u"?n:Set,"%SetIteratorPrototype%":typeof Set>"u"||!Y||!ce?n:ce(new Set()[Symbol.iterator]()),"%SharedArrayBuffer%":typeof SharedArrayBuffer>"u"?n:SharedArrayBuffer,"%String%":String,"%StringIteratorPrototype%":Y&&ce?ce(""[Symbol.iterator]()):n,"%Symbol%":Y?Symbol:n,"%SyntaxError%":E,"%ThrowTypeError%":Q,"%TypedArray%":s,"%TypeError%":A,"%Uint8Array%":typeof Uint8Array>"u"?n:Uint8Array,"%Uint8ClampedArray%":typeof Uint8ClampedArray>"u"?n:Uint8ClampedArray,"%Uint16Array%":typeof Uint16Array>"u"?n:Uint16Array,"%Uint32Array%":typeof Uint32Array>"u"?n:Uint32Array,"%URIError%":B,"%WeakMap%":typeof WeakMap>"u"?n:WeakMap,"%WeakRef%":typeof WeakRef>"u"?n:WeakRef,"%WeakSet%":typeof WeakSet>"u"?n:WeakSet,"%Function.prototype.call%":r,"%Function.prototype.apply%":he,"%Object.defineProperty%":F,"%Object.getPrototypeOf%":le,"%Math.abs%":b,"%Math.floor%":R,"%Math.max%":g,"%Math.min%":S,"%Math.pow%":q,"%Math.round%":$,"%Math.sign%":I,"%Reflect.getPrototypeOf%":ne};if(ce)try{null.error}catch(oe){var k=ce(ce(oe));m["%Error.prototype%"]=k}var C=function oe(ye){var Z;if(ye==="%AsyncFunction%")Z=O("async function () {}");else if(ye==="%GeneratorFunction%")Z=O("function* () {}");else if(ye==="%AsyncGeneratorFunction%")Z=O("async function* () {}");else if(ye==="%AsyncGenerator%"){var J=oe("%AsyncGeneratorFunction%");J&&(Z=J.prototype)}else if(ye==="%AsyncIteratorPrototype%"){var _e=oe("%AsyncGenerator%");_e&&ce&&(Z=ce(_e.prototype))}return m[ye]=Z,Z},T={__proto__:null,"%ArrayBufferPrototype%":["ArrayBuffer","prototype"],"%ArrayPrototype%":["Array","prototype"],"%ArrayProto_entries%":["Array","prototype","entries"],"%ArrayProto_forEach%":["Array","prototype","forEach"],"%ArrayProto_keys%":["Array","prototype","keys"],"%ArrayProto_values%":["Array","prototype","values"],"%AsyncFunctionPrototype%":["AsyncFunction","prototype"],"%AsyncGenerator%":["AsyncGeneratorFunction","prototype"],"%AsyncGeneratorPrototype%":["AsyncGeneratorFunction","prototype","prototype"],"%BooleanPrototype%":["Boolean","prototype"],"%DataViewPrototype%":["DataView","prototype"],"%DatePrototype%":["Date","prototype"],"%ErrorPrototype%":["Error","prototype"],"%EvalErrorPrototype%":["EvalError","prototype"],"%Float32ArrayPrototype%":["Float32Array","prototype"],"%Float64ArrayPrototype%":["Float64Array","prototype"],"%FunctionPrototype%":["Function","prototype"],"%Generator%":["GeneratorFunction","prototype"],"%GeneratorPrototype%":["GeneratorFunction","prototype","prototype"],"%Int8ArrayPrototype%":["Int8Array","prototype"],"%Int16ArrayPrototype%":["Int16Array","prototype"],"%Int32ArrayPrototype%":["Int32Array","prototype"],"%JSONParse%":["JSON","parse"],"%JSONStringify%":["JSON","stringify"],"%MapPrototype%":["Map","prototype"],"%NumberPrototype%":["Number","prototype"],"%ObjectPrototype%":["Object","prototype"],"%ObjProto_toString%":["Object","prototype","toString"],"%ObjProto_valueOf%":["Object","prototype","valueOf"],"%PromisePrototype%":["Promise","prototype"],"%PromiseProto_then%":["Promise","prototype","then"],"%Promise_all%":["Promise","all"],"%Promise_reject%":["Promise","reject"],"%Promise_resolve%":["Promise","resolve"],"%RangeErrorPrototype%":["RangeError","prototype"],"%ReferenceErrorPrototype%":["ReferenceError","prototype"],"%RegExpPrototype%":["RegExp","prototype"],"%SetPrototype%":["Set","prototype"],"%SharedArrayBufferPrototype%":["SharedArrayBuffer","prototype"],"%StringPrototype%":["String","prototype"],"%SymbolPrototype%":["Symbol","prototype"],"%SyntaxErrorPrototype%":["SyntaxError","prototype"],"%TypedArrayPrototype%":["TypedArray","prototype"],"%TypeErrorPrototype%":["TypeError","prototype"],"%Uint8ArrayPrototype%":["Uint8Array","prototype"],"%Uint8ClampedArrayPrototype%":["Uint8ClampedArray","prototype"],"%Uint16ArrayPrototype%":["Uint16Array","prototype"],"%Uint32ArrayPrototype%":["Uint32Array","prototype"],"%URIErrorPrototype%":["URIError","prototype"],"%WeakMapPrototype%":["WeakMap","prototype"],"%WeakSetPrototype%":["WeakSet","prototype"]},M=requireFunctionBind(),i=requireHasown(),y=M.call(r,Array.prototype.concat),D=M.call(he,Array.prototype.splice),j=M.call(r,String.prototype.replace),z=M.call(r,String.prototype.slice),X=M.call(r,RegExp.prototype.exec),te=/[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g,ee=/\\(\\)?/g,G=function(oe){var ye=z(oe,0,1),Z=z(oe,-1);if(ye==="%"&&Z!=="%")throw new E("invalid intrinsic syntax, expected closing `%`");if(Z==="%"&&ye!=="%")throw new E("invalid intrinsic syntax, expected opening `%`");var J=[];return j(oe,te,function(_e,pe,Me,Ke){J[J.length]=Me?j(Ke,ee,"$1"):pe||_e}),J},V=function(oe,ye){var Z=oe,J;if(i(T,Z)&&(J=T[Z],Z="%"+J[0]+"%"),i(m,Z)){var _e=m[Z];if(_e===a&&(_e=C(Z)),typeof _e>"u"&&!ye)throw new A("intrinsic "+oe+" exists, but is not available. Please file an issue!");return{alias:J,name:Z,value:_e}}throw new E("intrinsic "+oe+" does not exist!")};return getIntrinsic=function(oe,ye){if(typeof oe!="string"||oe.length===0)throw new A("intrinsic name must be a non-empty string");if(arguments.length>1&&typeof ye!="boolean")throw new A('"allowMissing" argument must be a boolean');if(X(/^%?[^%]*%?$/,oe)===null)throw new E("`%` may not be present anywhere but at the beginning and end of the intrinsic name");var Z=G(oe),J=Z.length>0?Z[0]:"",_e=V("%"+J+"%",ye),pe=_e.name,Me=_e.value,Ke=!1,ke=_e.alias;ke&&(J=ke[0],D(Z,y([0,1],ke)));for(var Le=1,Be=!0;Le=Z.length){var Se=L(Me,xe);Be=!!Se,Be&&"get"in Se&&!("originalValue"in Se.get)?Me=Se.get:Me=Me[xe]}else Be=i(Me,xe),Me=Me[xe];Be&&!Ke&&(m[pe]=Me)}}return Me},getIntrinsic}var callBound,hasRequiredCallBound;function requireCallBound(){if(hasRequiredCallBound)return callBound;hasRequiredCallBound=1;var n=requireGetIntrinsic(),p=requireCallBindApplyHelpers(),c=p([n("%String.prototype.indexOf%")]);return callBound=function(l,x){var o=n(l,!!x);return typeof o=="function"&&c(l,".prototype.")>-1?p([o]):o},callBound}var isArguments,hasRequiredIsArguments;function requireIsArguments(){if(hasRequiredIsArguments)return isArguments;hasRequiredIsArguments=1;var n=requireShams()(),p=requireCallBound(),c=p("Object.prototype.toString"),l=function(E){return n&&E&&typeof E=="object"&&Symbol.toStringTag in E?!1:c(E)==="[object Arguments]"},x=function(E){return l(E)?!0:E!==null&&typeof E=="object"&&"length"in E&&typeof E.length=="number"&&E.length>=0&&c(E)!=="[object Array]"&&"callee"in E&&c(E.callee)==="[object Function]"},o=function(){return l(arguments)}();return l.isLegacyArguments=x,isArguments=o?l:x,isArguments}var isRegex,hasRequiredIsRegex;function requireIsRegex(){if(hasRequiredIsRegex)return isRegex;hasRequiredIsRegex=1;var n=requireCallBound(),p=requireShams()(),c=requireHasown(),l=requireGopd(),x;if(p){var o=n("RegExp.prototype.exec"),E={},A=function(){throw E},B={toString:A,valueOf:A};typeof Symbol.toPrimitive=="symbol"&&(B[Symbol.toPrimitive]=A),x=function(g){if(!g||typeof g!="object")return!1;var S=l(g,"lastIndex"),q=S&&c(S,"value");if(!q)return!1;try{o(g,B)}catch($){return $===E}}}else{var b=n("Object.prototype.toString"),R="[object RegExp]";x=function(g){return!g||typeof g!="object"&&typeof g!="function"?!1:b(g)===R}}return isRegex=x,isRegex}var safeRegexTest,hasRequiredSafeRegexTest;function requireSafeRegexTest(){if(hasRequiredSafeRegexTest)return safeRegexTest;hasRequiredSafeRegexTest=1;var n=requireCallBound(),p=requireIsRegex(),c=n("RegExp.prototype.exec"),l=requireType();return safeRegexTest=function(x){if(!p(x))throw new l("`regex` must be a RegExp");return function(o){return c(x,o)!==null}},safeRegexTest}var isGeneratorFunction,hasRequiredIsGeneratorFunction;function requireIsGeneratorFunction(){if(hasRequiredIsGeneratorFunction)return isGeneratorFunction;hasRequiredIsGeneratorFunction=1;var n=requireCallBound(),p=requireSafeRegexTest(),c=p(/^\s*(?:function)?\*/),l=requireShams()(),x=requireGetProto(),o=n("Object.prototype.toString"),E=n("Function.prototype.toString"),A=function(){if(!l)return!1;try{return Function("return function*() {}")()}catch{}},B;return isGeneratorFunction=function(b){if(typeof b!="function")return!1;if(c(E(b)))return!0;if(!l){var R=o(b);return R==="[object GeneratorFunction]"}if(!x)return!1;if(typeof B>"u"){var g=A();B=g?x(g):!1}return x(b)===B},isGeneratorFunction}var isCallable,hasRequiredIsCallable;function requireIsCallable(){if(hasRequiredIsCallable)return isCallable;hasRequiredIsCallable=1;var n=Function.prototype.toString,p=typeof Reflect=="object"&&Reflect!==null&&Reflect.apply,c,l;if(typeof p=="function"&&typeof Object.defineProperty=="function")try{c=Object.defineProperty({},"length",{get:function(){throw l}}),l={},p(function(){throw 42},null,c)}catch(L){L!==l&&(p=null)}else p=null;var x=/^\s*class\b/,o=function(L){try{var F=n.call(L);return x.test(F)}catch{return!1}},E=function(L){try{return o(L)?!1:(n.call(L),!0)}catch{return!1}},A=Object.prototype.toString,B="[object Object]",b="[object Function]",R="[object GeneratorFunction]",g="[object HTMLAllCollection]",S="[object HTML document.all class]",q="[object HTMLCollection]",$=typeof Symbol=="function"&&!!Symbol.toStringTag,I=!(0 in[,]),P=function(){return!1};if(typeof document=="object"){var O=document.all;A.call(O)===A.call(document.all)&&(P=function(L){if((I||!L)&&(typeof L>"u"||typeof L=="object"))try{var F=A.call(L);return(F===g||F===S||F===q||F===B)&&L("")==null}catch{}return!1})}return isCallable=p?function(L){if(P(L))return!0;if(!L||typeof L!="function"&&typeof L!="object")return!1;try{p(L,null,c)}catch(F){if(F!==l)return!1}return!o(L)&&E(L)}:function(L){if(P(L))return!0;if(!L||typeof L!="function"&&typeof L!="object")return!1;if($)return E(L);if(o(L))return!1;var F=A.call(L);return F!==b&&F!==R&&!/^\[object HTML/.test(F)?!1:E(L)},isCallable}var forEach,hasRequiredForEach;function requireForEach(){if(hasRequiredForEach)return forEach;hasRequiredForEach=1;var n=requireIsCallable(),p=Object.prototype.toString,c=Object.prototype.hasOwnProperty,l=function(A,B,b){for(var R=0,g=A.length;R=3&&(R=b),E(A)?l(A,B,R):typeof A=="string"?x(A,B,R):o(A,B,R)},forEach}var possibleTypedArrayNames,hasRequiredPossibleTypedArrayNames;function requirePossibleTypedArrayNames(){return hasRequiredPossibleTypedArrayNames||(hasRequiredPossibleTypedArrayNames=1,possibleTypedArrayNames=["Float16Array","Float32Array","Float64Array","Int8Array","Int16Array","Int32Array","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","BigInt64Array","BigUint64Array"]),possibleTypedArrayNames}var availableTypedArrays,hasRequiredAvailableTypedArrays;function requireAvailableTypedArrays(){if(hasRequiredAvailableTypedArrays)return availableTypedArrays;hasRequiredAvailableTypedArrays=1;var n=requirePossibleTypedArrayNames(),p=typeof globalThis>"u"?commonjsGlobal:globalThis;return availableTypedArrays=function(){for(var c=[],l=0;l3&&typeof arguments[3]!="boolean"&&arguments[3]!==null)throw new c("`nonEnumerable`, if provided, must be a boolean or null");if(arguments.length>4&&typeof arguments[4]!="boolean"&&arguments[4]!==null)throw new c("`nonWritable`, if provided, must be a boolean or null");if(arguments.length>5&&typeof arguments[5]!="boolean"&&arguments[5]!==null)throw new c("`nonConfigurable`, if provided, must be a boolean or null");if(arguments.length>6&&typeof arguments[6]!="boolean")throw new c("`loose`, if provided, must be a boolean");var A=arguments.length>3?arguments[3]:null,B=arguments.length>4?arguments[4]:null,b=arguments.length>5?arguments[5]:null,R=arguments.length>6?arguments[6]:!1,g=!!l&&l(x,o);if(n)n(x,o,{configurable:b===null&&g?g.configurable:!b,enumerable:A===null&&g?g.enumerable:!A,value:E,writable:B===null&&g?g.writable:!B});else if(R||!A&&!B&&!b)x[o]=E;else throw new p("This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.")},defineDataProperty}var hasPropertyDescriptors_1,hasRequiredHasPropertyDescriptors;function requireHasPropertyDescriptors(){if(hasRequiredHasPropertyDescriptors)return hasPropertyDescriptors_1;hasRequiredHasPropertyDescriptors=1;var n=requireEsDefineProperty(),p=function(){return!!n};return p.hasArrayLengthDefineBug=function(){if(!n)return null;try{return n([],"length",{value:1}).length!==1}catch{return!0}},hasPropertyDescriptors_1=p,hasPropertyDescriptors_1}var setFunctionLength,hasRequiredSetFunctionLength;function requireSetFunctionLength(){if(hasRequiredSetFunctionLength)return setFunctionLength;hasRequiredSetFunctionLength=1;var n=requireGetIntrinsic(),p=requireDefineDataProperty(),c=requireHasPropertyDescriptors()(),l=requireGopd(),x=requireType(),o=n("%Math.floor%");return setFunctionLength=function(E,A){if(typeof E!="function")throw new x("`fn` is not a function");if(typeof A!="number"||A<0||A>4294967295||o(A)!==A)throw new x("`length` must be a positive 32-bit integer");var B=arguments.length>2&&!!arguments[2],b=!0,R=!0;if("length"in E&&l){var g=l(E,"length");g&&!g.configurable&&(b=!1),g&&!g.writable&&(R=!1)}return(b||R||!B)&&(c?p(E,"length",A,!0,!0):p(E,"length",A)),E},setFunctionLength}var applyBind,hasRequiredApplyBind;function requireApplyBind(){if(hasRequiredApplyBind)return applyBind;hasRequiredApplyBind=1;var n=requireFunctionBind(),p=requireFunctionApply(),c=requireActualApply();return applyBind=function(){return c(n,p,arguments)},applyBind}var hasRequiredCallBind;function requireCallBind(){return hasRequiredCallBind||(hasRequiredCallBind=1,function(n){var p=requireSetFunctionLength(),c=requireEsDefineProperty(),l=requireCallBindApplyHelpers(),x=requireApplyBind();n.exports=function(o){var E=l(arguments),A=o.length-(arguments.length-1);return p(E,1+(A>0?A:0),!0)},c?c(n.exports,"apply",{value:x}):n.exports.apply=x}(callBind)),callBind.exports}var whichTypedArray,hasRequiredWhichTypedArray;function requireWhichTypedArray(){if(hasRequiredWhichTypedArray)return whichTypedArray;hasRequiredWhichTypedArray=1;var n=requireForEach(),p=requireAvailableTypedArrays(),c=requireCallBind(),l=requireCallBound(),x=requireGopd(),o=requireGetProto(),E=l("Object.prototype.toString"),A=requireShams()(),B=typeof globalThis>"u"?commonjsGlobal:globalThis,b=p(),R=l("String.prototype.slice"),g=l("Array.prototype.indexOf",!0)||function(I,P){for(var O=0;O-1?P:P!=="Object"?!1:$(I)}return x?q(I):null},whichTypedArray}var isTypedArray,hasRequiredIsTypedArray;function requireIsTypedArray(){if(hasRequiredIsTypedArray)return isTypedArray;hasRequiredIsTypedArray=1;var n=requireWhichTypedArray();return isTypedArray=function(p){return!!n(p)},isTypedArray}var hasRequiredTypes;function requireTypes(){return hasRequiredTypes||(hasRequiredTypes=1,function(n){var p=requireIsArguments(),c=requireIsGeneratorFunction(),l=requireWhichTypedArray(),x=requireIsTypedArray();function o(Be){return Be.call.bind(Be)}var E=typeof BigInt<"u",A=typeof Symbol<"u",B=o(Object.prototype.toString),b=o(Number.prototype.valueOf),R=o(String.prototype.valueOf),g=o(Boolean.prototype.valueOf);if(E)var S=o(BigInt.prototype.valueOf);if(A)var q=o(Symbol.prototype.valueOf);function $(Be,xe){if(typeof Be!="object")return!1;try{return xe(Be),!0}catch{return!1}}n.isArgumentsObject=p,n.isGeneratorFunction=c,n.isTypedArray=x;function I(Be){return typeof Promise<"u"&&Be instanceof Promise||Be!==null&&typeof Be=="object"&&typeof Be.then=="function"&&typeof Be.catch=="function"}n.isPromise=I;function P(Be){return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?ArrayBuffer.isView(Be):x(Be)||z(Be)}n.isArrayBufferView=P;function O(Be){return l(Be)==="Uint8Array"}n.isUint8Array=O;function L(Be){return l(Be)==="Uint8ClampedArray"}n.isUint8ClampedArray=L;function F(Be){return l(Be)==="Uint16Array"}n.isUint16Array=F;function U(Be){return l(Be)==="Uint32Array"}n.isUint32Array=U;function Q(Be){return l(Be)==="Int8Array"}n.isInt8Array=Q;function Y(Be){return l(Be)==="Int16Array"}n.isInt16Array=Y;function ce(Be){return l(Be)==="Int32Array"}n.isInt32Array=ce;function le(Be){return l(Be)==="Float32Array"}n.isFloat32Array=le;function ne(Be){return l(Be)==="Float64Array"}n.isFloat64Array=ne;function he(Be){return l(Be)==="BigInt64Array"}n.isBigInt64Array=he;function r(Be){return l(Be)==="BigUint64Array"}n.isBigUint64Array=r;function a(Be){return B(Be)==="[object Map]"}a.working=typeof Map<"u"&&a(new Map);function s(Be){return typeof Map>"u"?!1:a.working?a(Be):Be instanceof Map}n.isMap=s;function m(Be){return B(Be)==="[object Set]"}m.working=typeof Set<"u"&&m(new Set);function k(Be){return typeof Set>"u"?!1:m.working?m(Be):Be instanceof Set}n.isSet=k;function C(Be){return B(Be)==="[object WeakMap]"}C.working=typeof WeakMap<"u"&&C(new WeakMap);function T(Be){return typeof WeakMap>"u"?!1:C.working?C(Be):Be instanceof WeakMap}n.isWeakMap=T;function M(Be){return B(Be)==="[object WeakSet]"}M.working=typeof WeakSet<"u"&&M(new WeakSet);function i(Be){return M(Be)}n.isWeakSet=i;function y(Be){return B(Be)==="[object ArrayBuffer]"}y.working=typeof ArrayBuffer<"u"&&y(new ArrayBuffer);function D(Be){return typeof ArrayBuffer>"u"?!1:y.working?y(Be):Be instanceof ArrayBuffer}n.isArrayBuffer=D;function j(Be){return B(Be)==="[object DataView]"}j.working=typeof ArrayBuffer<"u"&&typeof DataView<"u"&&j(new DataView(new ArrayBuffer(1),0,1));function z(Be){return typeof DataView>"u"?!1:j.working?j(Be):Be instanceof DataView}n.isDataView=z;var X=typeof SharedArrayBuffer<"u"?SharedArrayBuffer:void 0;function te(Be){return B(Be)==="[object SharedArrayBuffer]"}function ee(Be){return typeof X>"u"?!1:(typeof te.working>"u"&&(te.working=te(new X)),te.working?te(Be):Be instanceof X)}n.isSharedArrayBuffer=ee;function G(Be){return B(Be)==="[object AsyncFunction]"}n.isAsyncFunction=G;function V(Be){return B(Be)==="[object Map Iterator]"}n.isMapIterator=V;function oe(Be){return B(Be)==="[object Set Iterator]"}n.isSetIterator=oe;function ye(Be){return B(Be)==="[object Generator]"}n.isGeneratorObject=ye;function Z(Be){return B(Be)==="[object WebAssembly.Module]"}n.isWebAssemblyCompiledModule=Z;function J(Be){return $(Be,b)}n.isNumberObject=J;function _e(Be){return $(Be,R)}n.isStringObject=_e;function pe(Be){return $(Be,g)}n.isBooleanObject=pe;function Me(Be){return E&&$(Be,S)}n.isBigIntObject=Me;function Ke(Be){return A&&$(Be,q)}n.isSymbolObject=Ke;function ke(Be){return J(Be)||_e(Be)||pe(Be)||Me(Be)||Ke(Be)}n.isBoxedPrimitive=ke;function Le(Be){return typeof Uint8Array<"u"&&(D(Be)||ee(Be))}n.isAnyArrayBuffer=Le,["isProxy","isExternal","isModuleNamespaceObject"].forEach(function(Be){Object.defineProperty(n,Be,{enumerable:!1,value:function(){throw new Error(Be+" is not supported in userland")}})})}(types)),types}var isBufferBrowser,hasRequiredIsBufferBrowser;function requireIsBufferBrowser(){return hasRequiredIsBufferBrowser||(hasRequiredIsBufferBrowser=1,isBufferBrowser=function(n){return n&&typeof n=="object"&&typeof n.copy=="function"&&typeof n.fill=="function"&&typeof n.readUInt8=="function"}),isBufferBrowser}var hasRequiredUtil$1;function requireUtil$1(){return hasRequiredUtil$1||(hasRequiredUtil$1=1,function(n){var p={},c=Object.getOwnPropertyDescriptors||function(z){for(var X=Object.keys(z),te={},ee=0;ee=G)return Z;switch(Z){case"%s":return String(ee[te++]);case"%d":return Number(ee[te++]);case"%j":try{return JSON.stringify(ee[te++])}catch{return"[Circular]"}default:return Z}}),oe=ee[te];te"u")return function(){return n.deprecate(z,X).apply(this,arguments)};var te=!1;function ee(){if(!te){if(process$1.throwDeprecation)throw new Error(X);process$1.traceDeprecation?console.trace(X):console.error(X),te=!0}return z.apply(this,arguments)}return ee};var x={},o=/^$/;if(p.NODE_DEBUG){var E=p.NODE_DEBUG;E=E.replace(/[|\\{}()[\]^$+?.]/g,"\\$&").replace(/\*/g,".*").replace(/,/g,"$|^").toUpperCase(),o=new RegExp("^"+E+"$","i")}n.debuglog=function(z){if(z=z.toUpperCase(),!x[z])if(o.test(z)){var X=process$1.pid;x[z]=function(){var te=n.format.apply(n,arguments);console.error("%s %d: %s",z,X,te)}}else x[z]=function(){};return x[z]};function A(z,X){var te={seen:[],stylize:b};return arguments.length>=3&&(te.depth=arguments[2]),arguments.length>=4&&(te.colors=arguments[3]),L(X)?te.showHidden=X:X&&n._extend(te,X),le(te.showHidden)&&(te.showHidden=!1),le(te.depth)&&(te.depth=2),le(te.colors)&&(te.colors=!1),le(te.customInspect)&&(te.customInspect=!0),te.colors&&(te.stylize=B),g(te,z,te.depth)}n.inspect=A,A.colors={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[30,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[31,39],yellow:[33,39]},A.styles={special:"cyan",number:"yellow",boolean:"yellow",undefined:"grey",null:"bold",string:"green",date:"magenta",regexp:"red"};function B(z,X){var te=A.styles[X];return te?"\x1B["+A.colors[te][0]+"m"+z+"\x1B["+A.colors[te][1]+"m":z}function b(z,X){return z}function R(z){var X={};return z.forEach(function(te,ee){X[te]=!0}),X}function g(z,X,te){if(z.customInspect&&X&&s(X.inspect)&&X.inspect!==n.inspect&&!(X.constructor&&X.constructor.prototype===X)){var ee=X.inspect(te,z);return Y(ee)||(ee=g(z,ee,te)),ee}var G=S(z,X);if(G)return G;var V=Object.keys(X),oe=R(V);if(z.showHidden&&(V=Object.getOwnPropertyNames(X)),a(X)&&(V.indexOf("message")>=0||V.indexOf("description")>=0))return q(X);if(V.length===0){if(s(X)){var ye=X.name?": "+X.name:"";return z.stylize("[Function"+ye+"]","special")}if(ne(X))return z.stylize(RegExp.prototype.toString.call(X),"regexp");if(r(X))return z.stylize(Date.prototype.toString.call(X),"date");if(a(X))return q(X)}var Z="",J=!1,_e=["{","}"];if(O(X)&&(J=!0,_e=["[","]"]),s(X)){var pe=X.name?": "+X.name:"";Z=" [Function"+pe+"]"}if(ne(X)&&(Z=" "+RegExp.prototype.toString.call(X)),r(X)&&(Z=" "+Date.prototype.toUTCString.call(X)),a(X)&&(Z=" "+q(X)),V.length===0&&(!J||X.length==0))return _e[0]+Z+_e[1];if(te<0)return ne(X)?z.stylize(RegExp.prototype.toString.call(X),"regexp"):z.stylize("[Object]","special");z.seen.push(X);var Me;return J?Me=$(z,X,te,oe,V):Me=V.map(function(Ke){return I(z,X,te,oe,Ke,J)}),z.seen.pop(),P(Me,Z,_e)}function S(z,X){if(le(X))return z.stylize("undefined","undefined");if(Y(X)){var te="'"+JSON.stringify(X).replace(/^"|"$/g,"").replace(/'/g,"\\'").replace(/\\"/g,'"')+"'";return z.stylize(te,"string")}if(Q(X))return z.stylize(""+X,"number");if(L(X))return z.stylize(""+X,"boolean");if(F(X))return z.stylize("null","null")}function q(z){return"["+Error.prototype.toString.call(z)+"]"}function $(z,X,te,ee,G){for(var V=[],oe=0,ye=X.length;oe-1&&(V?ye=ye.split(` `).map(function(J){return" "+J}).join(` @@ -97,5 +97,5 @@ https://github.com/browserify/crypto-browserify`)},cryptoBrowserify.constants={D `;register(),register(t11);function getUserStatusText(n){switch(n){case"away":return t("away");case"busy":return t("busy");case"dnd":return t("do not disturb");case"online":return t("online");case"invisible":return t("invisible");case"offline":return t("offline");default:return n}}const _hoisted_1$9=["aria-hidden","aria-label","innerHTML"],_sfc_main$9=defineComponent({__name:"NcUserStatusIcon",props:mergeModels({user:{default:void 0},ariaHidden:{type:[Boolean,String],default:!1}},{status:{},statusModifiers:{}}),emits:["update:status"],setup(n){const p=useModel(n,"status"),c=n,l=computed(()=>p.value&&["invisible","offline"].includes(p.value)),x=computed(()=>p.value&&(!c.ariaHidden||c.ariaHidden==="false")?t("User status: {status}",{status:getUserStatusText(p.value)}):void 0);watch(()=>c.user,async A=>{if(!p.value&&A&&e()?.user_status?.enabled)try{const{data:B}=await cancelableClient.get(v("/apps/user_status/api/v1/statuses/{user}",{user:A}));p.value=B.ocs?.data?.status}catch(B){logger$1.debug("Error while fetching user status",{error:B})}},{immediate:!0});const o={online:onlineSvg,away:awaySvg,busy:busySvg,dnd:dndSvg,invisible:invisibleSvg,offline:invisibleSvg},E=computed(()=>p.value&&o[p.value]);return(A,B)=>p.value?(openBlock(),createElementBlock("span",{key:0,class:normalizeClass(["user-status-icon",{"user-status-icon--invisible":l.value}]),"aria-hidden":!x.value||void 0,"aria-label":x.value,role:"img",innerHTML:E.value},null,10,_hoisted_1$9)):createCommentVNode("",!0)}}),NcUserStatusIcon=_export_sfc(_sfc_main$9,[["__scopeId","data-v-009e879d"]]),ActionGlobalMixin={beforeUpdate(){this.text=this.getText()},data(){return{text:this.getText()}},computed:{isLongText(){return this.text&&this.text.trim().length>20}},methods:{getText(){return this.$slots.default?.()[0].children?.trim?.()||""}}},ActionTextMixin={mixins:[ActionGlobalMixin],props:{icon:{type:String,default:""},name:{type:String,default:""},title:{type:String,default:""},closeAfterClick:{type:Boolean,default:!1},ariaLabel:{type:String,default:null}},inject:{closeMenu:{from:NC_ACTIONS_CLOSE_MENU}},emits:["click"],created(){"ariaHidden"in this.$attrs},computed:{isIconUrl(){try{return!!new URL(this.icon,this.icon.startsWith("/")?window.location.origin:void 0)}catch{return!1}}},methods:{onClick(n){this.$emit("click",n),this.closeAfterClick&&this.closeMenu(!1)}}},_sfc_main$8={name:"NcActionButton",components:{NcIconSvgWrapper},mixins:[ActionTextMixin],inject:{isInSemanticMenu:{from:NC_ACTIONS_IS_SEMANTIC_MENU,default:!1}},props:{disabled:{type:Boolean,default:!1},isMenu:{type:Boolean,default:!1},type:{type:String,default:"button",validator:n=>["button","checkbox","radio","reset","submit"].includes(n)},modelValue:{type:[Boolean,String],default:null},value:{type:String,default:null},description:{type:String,default:""}},emits:["update:modelValue"],setup(){return{mdiCheck,mdiChevronRight}},computed:{isFocusable(){return!this.disabled},isChecked(){return this.type==="radio"&&typeof this.modelValue!="boolean"?this.modelValue===this.value:this.modelValue},nativeType(){return this.type==="submit"||this.type==="reset"?this.type:"button"},buttonAttributes(){const n={};return this.isInSemanticMenu?(n.role="menuitem",this.type==="radio"?(n.role="menuitemradio",n["aria-checked"]=this.isChecked?"true":"false"):(this.type==="checkbox"||this.nativeType==="button"&&this.modelValue!==null)&&(n.role="menuitemcheckbox",n["aria-checked"]=this.modelValue===null?"mixed":this.modelValue?"true":"false")):this.modelValue!==null&&this.nativeType==="button"&&(n["aria-pressed"]=this.modelValue?"true":"false"),n}},methods:{handleClick(n){this.onClick(n),(this.modelValue!==null||this.type!=="button")&&(this.type==="radio"?typeof this.modelValue!="boolean"?this.isChecked||this.$emit("update:modelValue",this.value):this.$emit("update:modelValue",!this.isChecked):this.$emit("update:modelValue",!this.isChecked))}}},_hoisted_1$8=["role"],_hoisted_2$8=["aria-label","disabled","title","type"],_hoisted_3$6={class:"action-button__longtext-wrapper"},_hoisted_4$4={key:0,class:"action-button__name"},_hoisted_5$4=["textContent"],_hoisted_6$4={key:2,class:"action-button__text"},_hoisted_7$2=["textContent"],_hoisted_8$1={key:2,class:"action-button__pressed-icon material-design-icon"};function _sfc_render$8(n,p,c,l,x,o){const E=resolveComponent("NcIconSvgWrapper");return openBlock(),createElementBlock("li",{class:normalizeClass(["action",{"action--disabled":c.disabled}]),role:o.isInSemanticMenu&&"presentation"},[createBaseVNode("button",mergeProps({"aria-label":n.ariaLabel,class:["action-button button-vue",{"action-button--active":o.isChecked,focusable:o.isFocusable}],disabled:c.disabled,title:n.title,type:o.nativeType},o.buttonAttributes,{onClick:p[0]||(p[0]=(...A)=>o.handleClick&&o.handleClick(...A))}),[renderSlot(n.$slots,"icon",{},()=>[createBaseVNode("span",{class:normalizeClass([[n.isIconUrl?"action-button__icon--url":n.icon],"action-button__icon"]),style:normalizeStyle({backgroundImage:n.isIconUrl?`url(${n.icon})`:null}),"aria-hidden":"true"},null,6)],!0),createBaseVNode("span",_hoisted_3$6,[n.name?(openBlock(),createElementBlock("strong",_hoisted_4$4,toDisplayString(n.name),1)):createCommentVNode("",!0),n.isLongText?(openBlock(),createElementBlock("span",{key:1,class:"action-button__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_5$4)):(openBlock(),createElementBlock("span",_hoisted_6$4,toDisplayString(n.text),1)),c.description?(openBlock(),createElementBlock("span",{key:3,class:"action-button__description",textContent:toDisplayString(c.description)},null,8,_hoisted_7$2)):createCommentVNode("",!0)]),c.isMenu?(openBlock(),createBlock(E,{key:0,class:"action-button__menu-icon",directional:"",path:l.mdiChevronRight},null,8,["path"])):o.isChecked?(openBlock(),createBlock(E,{key:1,path:l.mdiCheck,class:"action-button__pressed-icon"},null,8,["path"])):o.isChecked===!1?(openBlock(),createElementBlock("span",_hoisted_8$1)):createCommentVNode("",!0),createCommentVNode("",!0)],16,_hoisted_2$8)],10,_hoisted_1$8)}const NcActionButton=_export_sfc(_sfc_main$8,[["render",_sfc_render$8],["__scopeId","data-v-330b5e3e"]]),_sfc_main$7={name:"NcActionLink",mixins:[ActionTextMixin],inject:{isInSemanticMenu:{from:NC_ACTIONS_IS_SEMANTIC_MENU,default:!1}},props:{href:{type:String,required:!0,validator:n=>{try{return new URL(n)}catch{return n.startsWith("#")||n.startsWith("/")}}},download:{type:String,default:null},target:{type:String,default:"_self",validator:n=>n&&(!n.startsWith("_")||["_blank","_self","_parent","_top"].indexOf(n)>-1)},title:{type:String,default:null}}},_hoisted_1$7=["role"],_hoisted_2$7=["download","href","aria-label","target","title","role"],_hoisted_3$5={key:0,class:"action-link__longtext-wrapper"},_hoisted_4$3={class:"action-link__name"},_hoisted_5$3=["textContent"],_hoisted_6$3=["textContent"],_hoisted_7$1={key:2,class:"action-link__text"};function _sfc_render$7(n,p,c,l,x,o){return openBlock(),createElementBlock("li",{class:"action",role:o.isInSemanticMenu&&"presentation"},[createBaseVNode("a",{download:c.download,href:c.href,"aria-label":n.ariaLabel,target:c.target,title:c.title,class:"action-link focusable",rel:"nofollow noreferrer noopener",role:o.isInSemanticMenu&&"menuitem",onClick:p[0]||(p[0]=(...E)=>n.onClick&&n.onClick(...E))},[renderSlot(n.$slots,"icon",{},()=>[createBaseVNode("span",{"aria-hidden":"true",class:normalizeClass(["action-link__icon",[n.isIconUrl?"action-link__icon--url":n.icon]]),style:normalizeStyle({backgroundImage:n.isIconUrl?`url(${n.icon})`:null})},null,6)],!0),n.name?(openBlock(),createElementBlock("span",_hoisted_3$5,[createBaseVNode("strong",_hoisted_4$3,toDisplayString(n.name),1),p[1]||(p[1]=createBaseVNode("br",null,null,-1)),createBaseVNode("span",{class:"action-link__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_5$3)])):n.isLongText?(openBlock(),createElementBlock("span",{key:1,class:"action-link__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_6$3)):(openBlock(),createElementBlock("span",_hoisted_7$1,toDisplayString(n.text),1)),createCommentVNode("",!0)],8,_hoisted_2$7)],8,_hoisted_1$7)}const NcActionLink=_export_sfc(_sfc_main$7,[["render",_sfc_render$7],["__scopeId","data-v-9e538838"]]),_sfc_main$6={name:"NcActionRouter",mixins:[ActionTextMixin],inject:{isInSemanticMenu:{from:NC_ACTIONS_IS_SEMANTIC_MENU,default:!1}},props:{to:{type:[String,Object],required:!0}}},_hoisted_1$6=["role"],_hoisted_2$6={key:0,class:"action-router__longtext-wrapper"},_hoisted_3$4={class:"action-router__name"},_hoisted_4$2=["textContent"],_hoisted_5$2=["textContent"],_hoisted_6$2={key:2,class:"action-router__text"};function _sfc_render$6(n,p,c,l,x,o){const E=resolveComponent("RouterLink");return openBlock(),createElementBlock("li",{class:"action",role:o.isInSemanticMenu&&"presentation"},[createVNode(E,{"aria-label":n.ariaLabel,class:"action-router focusable",rel:"nofollow noreferrer noopener",role:o.isInSemanticMenu&&"menuitem",title:n.title,to:c.to,onClick:n.onClick},{default:withCtx(()=>[renderSlot(n.$slots,"icon",{},()=>[createBaseVNode("span",{"aria-hidden":"true",class:normalizeClass(["action-router__icon",[n.isIconUrl?"action-router__icon--url":n.icon]]),style:normalizeStyle({backgroundImage:n.isIconUrl?`url(${n.icon})`:null})},null,6)],!0),n.name?(openBlock(),createElementBlock("span",_hoisted_2$6,[createBaseVNode("strong",_hoisted_3$4,toDisplayString(n.name),1),p[0]||(p[0]=createBaseVNode("br",null,null,-1)),createBaseVNode("span",{class:"action-router__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_4$2)])):n.isLongText?(openBlock(),createElementBlock("span",{key:1,class:"action-router__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_5$2)):(openBlock(),createElementBlock("span",_hoisted_6$2,toDisplayString(n.text),1)),createCommentVNode("",!0)]),_:3},8,["aria-label","role","title","to","onClick"])],8,_hoisted_1$6)}const NcActionRouter=_export_sfc(_sfc_main$6,[["render",_sfc_render$6],["__scopeId","data-v-87267750"]]),_sfc_main$5={name:"NcActionText",mixins:[ActionTextMixin],inject:{isInSemanticMenu:{from:NC_ACTIONS_IS_SEMANTIC_MENU,default:!1}}},_hoisted_1$5=["role"],_hoisted_2$5={key:0,class:"action-text__longtext-wrapper"},_hoisted_3$3={class:"action-text__name"},_hoisted_4$1=["textContent"],_hoisted_5$1=["textContent"],_hoisted_6$1={key:2,class:"action-text__text"};function _sfc_render$5(n,p,c,l,x,o){return openBlock(),createElementBlock("li",{class:"action",role:o.isInSemanticMenu&&"presentation"},[createBaseVNode("span",{class:"action-text",onClick:p[0]||(p[0]=(...E)=>n.onClick&&n.onClick(...E))},[renderSlot(n.$slots,"icon",{},()=>[n.icon!==""?(openBlock(),createElementBlock("span",{key:0,"aria-hidden":"true",class:normalizeClass(["action-text__icon",[n.isIconUrl?"action-text__icon--url":n.icon]]),style:normalizeStyle({backgroundImage:n.isIconUrl?`url(${n.icon})`:null})},null,6)):createCommentVNode("",!0)],!0),n.name?(openBlock(),createElementBlock("span",_hoisted_2$5,[createBaseVNode("strong",_hoisted_3$3,toDisplayString(n.name),1),createBaseVNode("span",{class:"action-text__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_4$1)])):n.isLongText?(openBlock(),createElementBlock("span",{key:1,class:"action-text__longtext",textContent:toDisplayString(n.text)},null,8,_hoisted_5$1)):(openBlock(),createElementBlock("span",_hoisted_6$1,toDisplayString(n.text),1)),createCommentVNode("",!0)])],8,_hoisted_1$5)}const NcActionText=_export_sfc(_sfc_main$5,[["render",_sfc_render$5],["__scopeId","data-v-fa684b48"]]);register(t10);const userStatus={data(){return{hasStatus:!1,userStatus:{status:null,message:null,icon:null}}},methods:{async fetchUserStatus(n){if(!n)return;const p=e();if(!(!Object.hasOwn(p,"user_status")||!p.user_status.enabled)&&getCurrentUser())try{const{data:c}=await cancelableClient.get(v("apps/user_status/api/v1/statuses/{userId}",{userId:n})),{status:l,message:x,icon:o}=c.ocs.data;this.userStatus.status=l,this.userStatus.message=x||"",this.userStatus.icon=o||"",this.hasStatus=!0}catch(c){if(c.response.status===404&&c.response.data.ocs?.data?.length===0)return;logger$1.error("Failed to fetch user status",{error:c})}}}},browserStorage=distExports$1.getBuilder("nextcloud").persist().build();function getUserHasAvatar(n){const p=browserStorage.getItem("user-has-avatar."+n);return typeof p=="string"?!!p:null}function setUserHasAvatar(n,p){n&&browserStorage.setItem("user-has-avatar."+n,p)}const _sfc_main$4={name:"NcAvatar",directives:{ClickOutside:vOnClickOutside},components:{IconDotsHorizontal,NcActions,NcButton,NcIconSvgWrapper,NcLoadingIcon,NcUserStatusIcon},mixins:[userStatus],props:{url:{type:String,default:void 0},iconClass:{type:String,default:void 0},user:{type:String,default:void 0},hideStatus:{type:Boolean,default:!1},verboseStatus:{type:Boolean,default:!1},preloadedUserStatus:{type:Object,default:void 0},isGuest:{type:Boolean,default:!1},displayName:{type:String,default:void 0},size:{type:Number,default:32},noPlaceholder:{type:Boolean,default:!1},disableTooltip:{type:Boolean,default:!1},disableMenu:{type:Boolean,default:!1},tooltipMessage:{type:String,default:null},isNoUser:{type:Boolean,default:!1},menuContainer:{type:[Boolean,String,Object,Element],default:"body"}},setup(){return{isDarkTheme:useIsDarkTheme()}},data(){return{avatarUrlLoaded:null,avatarSrcSetLoaded:null,userDoesNotExist:!1,isAvatarLoaded:!1,isMenuLoaded:!1,contactsMenuLoading:!1,contactsMenuData:{},contactsMenuActions:[],contactsMenuOpenState:!1}},computed:{avatarAriaLabel(){if(this.hasMenu)return this.canDisplayUserStatus||this.showUserStatusIconOnAvatar?t("Avatar of {displayName}, {status}",{displayName:this.displayName??this.user,status:getUserStatusText(this.userStatus.status)}):t("Avatar of {displayName}",{displayName:this.displayName??this.user})},canDisplayUserStatus(){return!this.hideStatus&&this.hasStatus&&["online","away","busy","dnd"].includes(this.userStatus.status)},showUserStatusIconOnAvatar(){return!this.hideStatus&&!this.verboseStatus&&this.hasStatus&&this.userStatus.status!=="dnd"&&this.userStatus.icon},userIdentifier(){return this.isDisplayNameDefined?this.displayName:this.isUserDefined?this.user:""},isUserDefined(){return typeof this.user<"u"},isDisplayNameDefined(){return typeof this.displayName<"u"},isUrlDefined(){return typeof this.url<"u"},hasMenu(){return this.disableMenu?!1:this.isMenuLoaded?this.menu.length>0:!(this.user===getCurrentUser()?.uid||this.userDoesNotExist||this.url)},showInitials(){return!this.noPlaceholder&&this.userDoesNotExist&&!(this.iconClass||this.$slots.icon)},avatarStyle(){return{"--avatar-size":this.size+"px",lineHeight:this.showInitials?this.size+"px":0,fontSize:Math.round(this.size*.45)+"px"}},initialsWrapperStyle(){const{r:n,g:p,b:c}=usernameToColor(this.userIdentifier);return{backgroundColor:`rgba(${n}, ${p}, ${c}, 0.1)`}},initialsStyle(){const{r:n,g:p,b:c}=usernameToColor(this.userIdentifier);return{color:`rgb(${n}, ${p}, ${c})`}},tooltip(){return this.disableTooltip?null:this.tooltipMessage?this.tooltipMessage:this.displayName},initials(){let n="?";if(this.showInitials){const p=this.userIdentifier.trim();if(p==="")return n;const c=p.match(/[\p{L}\p{N}\s]/gu);if(!c)return n;const l=c.join(""),x=l.lastIndexOf(" ");n=String.fromCodePoint(l.codePointAt(0)),x!==-1&&(n=n.concat(String.fromCodePoint(l.codePointAt(x+1))))}return n.toLocaleUpperCase()},menu(){const n=this.contactsMenuActions.map(c=>{const l=getRoute(this.$router,c.hyperlink);return{ncActionComponent:l?NcActionRouter:NcActionLink,ncActionComponentProps:l?{to:l,icon:c.icon}:{href:c.hyperlink,icon:c.icon},text:c.title}});for(const c of getEnabledContactsMenuActions(this.contactsMenuData))try{n.push({ncActionComponent:NcActionButton,ncActionComponentProps:{onClick:()=>c.callback(this.contactsMenuData)},text:c.displayName(this.contactsMenuData),iconSvg:c.iconSvg(this.contactsMenuData)})}catch(l){logger$1.error(`Failed to render ContactsMenu action ${c.id}`,{error:l,action:c})}function p(c){const l=document.createTextNode(c),x=document.createElement("p");return x.appendChild(l),x.innerHTML}if(!this.hideStatus&&(this.userStatus.icon||this.userStatus.message)){const c=` ${p(this.userStatus.icon)} - `;return[{ncActionComponent:NcActionText,ncActionComponentProps:{},iconSvg:this.userStatus.icon?c:void 0,text:`${this.userStatus.message}`}].concat(n)}return n}},watch:{url(){this.userDoesNotExist=!1,this.loadAvatarUrl()},user(){this.userDoesNotExist=!1,this.isMenuLoaded=!1,this.loadAvatarUrl()}},mounted(){this.loadAvatarUrl(),subscribe("settings:avatar:updated",this.loadAvatarUrl),subscribe("settings:display-name:updated",this.loadAvatarUrl),!this.hideStatus&&this.user&&!this.isNoUser&&(this.preloadedUserStatus?(this.userStatus.status=this.preloadedUserStatus.status||"",this.userStatus.message=this.preloadedUserStatus.message||"",this.userStatus.icon=this.preloadedUserStatus.icon||"",this.hasStatus=this.preloadedUserStatus.status!==null):this.fetchUserStatus(this.user),subscribe("user_status:status.updated",this.handleUserStatusUpdated))},beforeUnmount(){unsubscribe("settings:avatar:updated",this.loadAvatarUrl),unsubscribe("settings:display-name:updated",this.loadAvatarUrl),unsubscribe("user_status:status.updated",this.handleUserStatusUpdated)},methods:{t,handleUserStatusUpdated(n){this.user===n.userId&&(this.userStatus={status:n.status,icon:n.icon,message:n.message},this.hasStatus=n.status!==null)},async toggleMenu(n){n.type==="keydown"&&n.key!=="Enter"||(this.contactsMenuOpenState||await this.fetchContactsMenu(),this.contactsMenuOpenState=!this.contactsMenuOpenState)},closeMenu(){this.contactsMenuOpenState=!1},async fetchContactsMenu(){this.contactsMenuLoading=!0;try{const n=encodeURIComponent(this.user),{data:p}=await cancelableClient.post(_("contactsmenu/findOne"),`shareType=0&shareWith=${n}`);this.contactsMenuData=p,this.contactsMenuActions=p.topAction?[p.topAction].concat(p.actions):p.actions}catch{this.contactsMenuOpenState=!1}this.contactsMenuLoading=!1,this.isMenuLoaded=!0},loadAvatarUrl(){if(this.isAvatarLoaded=!1,!this.isUrlDefined&&(!this.isUserDefined||this.isNoUser||this.iconClass)){this.isAvatarLoaded=!0,this.userDoesNotExist=!0;return}if(this.isUrlDefined){this.updateImageIfValid(this.url);return}if(this.size<=64){const n=this.avatarUrlGenerator(this.user,64),p=[n+" 1x",this.avatarUrlGenerator(this.user,512)+" 8x"].join(", ");this.updateImageIfValid(n,p)}else{const n=this.avatarUrlGenerator(this.user,512);this.updateImageIfValid(n)}},avatarUrlGenerator(n,p){let c=getAvatarUrl(n,{size:p,isDarkTheme:this.isDarkTheme,isGuest:this.isGuest});return n===getCurrentUser()?.uid&&typeof oc_userconfig<"u"&&(c+="?v="+window.oc_userconfig.avatar.version),c},updateImageIfValid(n,p=null){const c=getUserHasAvatar(this.user);if(this.isUserDefined&&typeof c=="boolean"){this.isAvatarLoaded=!0,this.avatarUrlLoaded=n,p&&(this.avatarSrcSetLoaded=p),c===!1&&(this.userDoesNotExist=!0);return}const l=new Image;l.onload=()=>{this.avatarUrlLoaded=n,p&&(this.avatarSrcSetLoaded=p),this.isAvatarLoaded=!0,setUserHasAvatar(this.user,!0)},l.onerror=()=>{logger$1.debug("[NcAvatar] Invalid avatar url",{url:n}),this.avatarUrlLoaded=null,this.avatarSrcSetLoaded=null,this.userDoesNotExist=!0,this.isAvatarLoaded=!1,setUserHasAvatar(this.user,!1)},p&&(l.srcset=p),l.src=n}}},_hoisted_1$4=["title"],_hoisted_2$4=["src","srcset"],_hoisted_3$2={key:2,class:"avatardiv__user-status avatardiv__user-status--icon"};function _sfc_render$4(n,p,c,l,x,o){const E=resolveComponent("NcLoadingIcon"),A=resolveComponent("IconDotsHorizontal"),B=resolveComponent("NcButton"),b=resolveComponent("NcIconSvgWrapper"),R=resolveComponent("NcActions"),g=resolveComponent("NcUserStatusIcon"),S=resolveDirective("click-outside");return withDirectives((openBlock(),createElementBlock("span",{class:normalizeClass(["avatardiv popovermenu-wrapper",{"avatardiv--unknown":x.userDoesNotExist,"avatardiv--with-menu":o.hasMenu,"avatardiv--with-menu-loading":x.contactsMenuLoading}]),style:normalizeStyle(o.avatarStyle),title:o.tooltip},[renderSlot(n.$slots,"icon",{},()=>[c.iconClass?(openBlock(),createElementBlock("span",{key:0,class:normalizeClass([c.iconClass,"avatar-class-icon"])},null,2)):x.isAvatarLoaded&&!x.userDoesNotExist?(openBlock(),createElementBlock("img",{key:1,src:x.avatarUrlLoaded,srcset:x.avatarSrcSetLoaded,alt:""},null,8,_hoisted_2$4)):createCommentVNode("",!0)],!0),o.hasMenu&&o.menu.length===0?(openBlock(),createBlock(B,{key:0,"aria-label":o.avatarAriaLabel,class:"action-item action-item__menutoggle",variant:"tertiary-no-background",onClick:o.toggleMenu},{icon:withCtx(()=>[x.contactsMenuLoading?(openBlock(),createBlock(E,{key:0})):(openBlock(),createBlock(A,{key:1,size:20}))]),_:1},8,["aria-label","onClick"])):o.hasMenu?(openBlock(),createBlock(R,{key:1,open:x.contactsMenuOpenState,"onUpdate:open":p[0]||(p[0]=q=>x.contactsMenuOpenState=q),"aria-label":o.avatarAriaLabel,container:c.menuContainer,"force-menu":"","manual-open":"",variant:"tertiary-no-background",onClick:o.toggleMenu},createSlots({default:withCtx(()=>[(openBlock(!0),createElementBlock(Fragment,null,renderList(o.menu,(q,$)=>(openBlock(),createBlock(resolveDynamicComponent(q.ncActionComponent),mergeProps({key:$},{ref_for:!0},q.ncActionComponentProps),createSlots({default:withCtx(()=>[createTextVNode(" "+toDisplayString(q.text),1)]),_:2},[q.iconSvg?{name:"icon",fn:withCtx(()=>[createVNode(b,{svg:q.iconSvg},null,8,["svg"])]),key:"0"}:void 0]),1040))),128))]),_:2},[x.contactsMenuLoading?{name:"icon",fn:withCtx(()=>[createVNode(E)]),key:"0"}:void 0]),1032,["open","aria-label","container","onClick"])):createCommentVNode("",!0),o.showUserStatusIconOnAvatar?(openBlock(),createElementBlock("span",_hoisted_3$2,toDisplayString(n.userStatus.icon),1)):o.canDisplayUserStatus?(openBlock(),createBlock(g,{key:3,class:"avatardiv__user-status",status:n.userStatus.status,"aria-hidden":String(o.hasMenu)},null,8,["status","aria-hidden"])):createCommentVNode("",!0),o.showInitials?(openBlock(),createElementBlock("span",{key:4,style:normalizeStyle(o.initialsWrapperStyle),class:"avatardiv__initials-wrapper"},[createBaseVNode("span",{style:normalizeStyle(o.initialsStyle),class:"avatardiv__initials"},toDisplayString(o.initials),5)],4)):createCommentVNode("",!0)],14,_hoisted_1$4)),[[S,o.closeMenu]])}const NcAvatar=_export_sfc(_sfc_main$4,[["render",_sfc_render$4],["__scopeId","data-v-a32502f1"]]),_sfc_main$1$1={};function _sfc_render$3(n,p){return openBlock(),createElementBlock("div",null,[renderSlot(n.$slots,"trigger")])}const NcUserBubbleDiv=_export_sfc(_sfc_main$1$1,[["render",_sfc_render$3]]),_hoisted_1$3={class:"user-bubble__name"},_hoisted_2$3={key:0,class:"user-bubble__secondary"},_sfc_main$3=defineComponent({__name:"NcUserBubble",props:mergeModels({avatarImage:{default:void 0},user:{default:void 0},displayName:{default:void 0},showUserStatus:{type:Boolean},url:{default:void 0},to:{default:void 0},primary:{type:Boolean},size:{default:20},margin:{default:2}},{open:{type:Boolean},openModifiers:{}}),emits:mergeModels(["click"],["update:open"]),setup(n,{emit:p}){const c=useModel(n,"open"),l=n,x=p,o=computed(()=>{if(!l.avatarImage)return!1;try{return!!new URL(l.avatarImage)}catch{return!1}}),E=computed(()=>!!l.avatarImage),A=computed(()=>({marginInlineStart:`${l.margin}px`})),B=computed(()=>{if(!l.url||l.url.trim()==="")return!1;try{return!!new URL(l.url,l.url?.startsWith?.("/")?window.location.href:void 0)}catch{return warn("[NcUserBubble] Invalid URL passed",{url:l.url}),!1}}),b=computed(()=>B.value?l.url:void 0),R=computed(()=>B.value?"a":l.to?RouterLink:"div"),g=computed(()=>({height:`${l.size}px`,lineHeight:`${l.size}px`,borderRadius:`${l.size/2}px`}));return watch([()=>l.displayName,()=>l.user],()=>{!l.displayName&&l.user}),(S,q)=>(openBlock(),createBlock(resolveDynamicComponent(S.$slots.default?unref(NcPopover):NcUserBubbleDiv),{shown:c.value,"onUpdate:shown":q[1]||(q[1]=$=>c.value=$),class:"user-bubble__wrapper",trigger:"hover focus"},{trigger:withCtx(({attrs:$})=>[(openBlock(),createBlock(resolveDynamicComponent(R.value),mergeProps({class:["user-bubble__content",{"user-bubble__content--primary":S.primary}],style:g.value,to:S.to,href:b.value},$,{onClick:q[0]||(q[0]=I=>x("click",I))}),{default:withCtx(()=>[createVNode(unref(NcAvatar),{url:E.value&&o.value?S.avatarImage:void 0,"icon-class":E.value&&!o.value?S.avatarImage:void 0,user:S.user,"display-name":S.displayName,size:S.size-S.margin*2,style:normalizeStyle(A.value),"disable-tooltip":!0,"disable-menu":!0,"hide-status":!S.showUserStatus,class:"user-bubble__avatar"},null,8,["url","icon-class","user","display-name","size","style","hide-status"]),createBaseVNode("span",_hoisted_1$3,toDisplayString(S.displayName||S.user),1),S.$slots.name?(openBlock(),createElementBlock("span",_hoisted_2$3,[renderSlot(S.$slots,"name",{},void 0,!0)])):createCommentVNode("",!0)]),_:2},1040,["class","style","to","href"]))]),default:withCtx(()=>[renderSlot(S.$slots,"default",{},void 0,!0)]),_:3},40,["shown"]))}}),NcUserBubble=_export_sfc(_sfc_main$3,[["__scopeId","data-v-37bde6b7"]]),_sfc_main$2={name:"UserParameter",components:{NcUserBubble},props:{type:{type:String,required:!0},id:{type:String,required:!0},name:{type:String,required:!0},server:{type:String,default:""}},computed:{cloudId(){return this.server?this.id+"@"+this.server:""}}},_hoisted_1$2={class:"mention"},_hoisted_2$2=["title"];function _sfc_render$2(n,p,c,l,x,o){const E=resolveComponent("NcUserBubble");return openBlock(),createElementBlock("div",_hoisted_1$2,[o.cloudId?(openBlock(),createElementBlock("strong",{key:1,title:o.cloudId},toDisplayString(c.name),9,_hoisted_2$2)):(openBlock(),createBlock(E,{key:0,"display-name":c.name,user:c.id},null,8,["display-name","user"]))])}const UserParameter=_export_sfc$1(_sfc_main$2,[["render",_sfc_render$2],["__scopeId","data-v-85edf4b2"]]),_sfc_main$1={name:"NotificationItem",components:{ActionButton:_sfc_main$c,NcButton,NcDateTime:_sfc_main$e,IconClose,IconMessageOutline,NcRichText},props:{notification:{type:Object,required:!0}},emits:["remove"],data(){return{showFullMessage:!1}},computed:{timestamp(){return this.notification.datetime==="warning"?0:new Date(this.notification.datetime).valueOf()},useLink(){if(!this.notification.link)return!1;let n=!1;return Object.keys(Object(this.notification.subjectRichParameters)).forEach(p=>{Object(this.notification.subjectRichParameters)[p].link&&(n=!0)}),!n},preparedSubjectParameters(){return this.prepareParameters(this.notification.subjectRichParameters)},preparedMessageParameters(){return this.prepareParameters(this.notification.messageRichParameters)},isCollapsedMessage(){return this.notification.message.length>200&&!this.showFullMessage}},methods:{t:translate,prepareParameters(n={}){const p={};return Object.keys(n).forEach(c=>{const l=n[c].type;l==="user"?p[c]={component:UserParameter,props:n[c]}:l==="file"?p[c]={component:FileParameter,props:n[c]}:p[c]={component:DefaultParameter,props:n[c]}}),p},onClickMessage(n){n.target.closest(".rich-text--wrapper")?this.showFullMessage=!this.showFullMessage:!this.notification.messageRich&&this.notification.message&&(this.showFullMessage=!this.showFullMessage)},async onClickAction({event:n,action:p}){try{const c={cancelAction:!1,notification:this.notification,action:p};if(await emit("notifications:action:execute",c),p.type==="WEB"){c.cancelAction&&n.preventDefault();return}if(c.cancelAction)return;await cancelableClient({method:p.type,url:p.url}),this.$emit("remove"),emit("notifications:action:executed",n)}catch(c){console.error("Failed to perform action",c),showError(translate("notifications","Failed to perform action"))}},onDismissNotification(){cancelableClient.delete(v("apps/notifications/api/v2/notifications/{id}",{id:this.notification.notificationId})).then(()=>{this.$emit("remove")}).catch(()=>{showError(translate("notifications","Failed to dismiss notification"))})}}},_hoisted_1$1=["data-id","data-timestamp","data-object-type","data-app"],_hoisted_2$1={class:"notification-heading"},_hoisted_3$1=["href"],_hoisted_4={key:0,class:"image"},_hoisted_5=["src"],_hoisted_6={class:"subject"},_hoisted_7=["href"],_hoisted_8={key:0,class:"image"},_hoisted_9=["src"],_hoisted_10={key:2,class:"subject"},_hoisted_11={key:2,class:"notification-subject"},_hoisted_12={key:0,class:"image"},_hoisted_13=["src"],_hoisted_14={key:2,class:"subject"},_hoisted_15={key:1},_hoisted_16={key:0,class:"notification-overflow"},_hoisted_17={key:4,class:"notification-actions"},_hoisted_18={key:5,class:"notification-actions"};function _sfc_render$1(n,p,c,l,x,o){const E=resolveComponent("NcDateTime"),A=resolveComponent("IconClose"),B=resolveComponent("NcButton"),b=resolveComponent("NcRichText"),R=resolveComponent("ActionButton"),g=resolveComponent("IconMessageOutline");return openBlock(),createElementBlock("li",{class:"notification","data-id":c.notification.notificationId,"data-timestamp":o.timestamp,"data-object-type":c.notification.objectType,"data-app":c.notification.app},[createBaseVNode("div",_hoisted_2$1,[o.timestamp?(openBlock(),createBlock(E,{key:0,class:"notification-time","ignore-seconds":"",format:{timeStyle:"short",dateStyle:"long"},timestamp:o.timestamp},null,8,["timestamp"])):createCommentVNode("",!0),o.timestamp?(openBlock(),createBlock(B,{key:1,class:"notification-dismiss-button",variant:"tertiary","aria-label":o.t("notifications","Dismiss"),onClick:o.onDismissNotification},{icon:withCtx(()=>[createVNode(A,{size:20})]),_:1},8,["aria-label","onClick"])):createCommentVNode("",!0)]),c.notification.externalLink?(openBlock(),createElementBlock("a",{key:0,href:c.notification.externalLink,class:"notification-subject full-subject-link external",target:"_blank",rel:"noreferrer noopener"},[c.notification.icon?(openBlock(),createElementBlock("span",_hoisted_4,[createBaseVNode("img",{src:c.notification.icon,class:"notification-icon",alt:""},null,8,_hoisted_5)])):createCommentVNode("",!0),createBaseVNode("span",_hoisted_6,toDisplayString(c.notification.subject)+" ↗",1)],8,_hoisted_3$1)):o.useLink?(openBlock(),createElementBlock("a",{key:1,href:c.notification.link,class:"notification-subject full-subject-link"},[c.notification.icon?(openBlock(),createElementBlock("span",_hoisted_8,[createBaseVNode("img",{src:c.notification.icon,class:"notification-icon",alt:""},null,8,_hoisted_9)])):createCommentVNode("",!0),c.notification.subjectRich?(openBlock(),createBlock(b,{key:1,text:c.notification.subjectRich,arguments:o.preparedSubjectParameters},null,8,["text","arguments"])):(openBlock(),createElementBlock("span",_hoisted_10,toDisplayString(c.notification.subject),1))],8,_hoisted_7)):(openBlock(),createElementBlock("div",_hoisted_11,[c.notification.icon?(openBlock(),createElementBlock("span",_hoisted_12,[createBaseVNode("img",{src:c.notification.icon,class:"notification-icon",alt:""},null,8,_hoisted_13)])):createCommentVNode("",!0),c.notification.subjectRich?(openBlock(),createBlock(b,{key:1,text:c.notification.subjectRich,arguments:o.preparedSubjectParameters},null,8,["text","arguments"])):(openBlock(),createElementBlock("span",_hoisted_14,toDisplayString(c.notification.subject),1))])),c.notification.message?(openBlock(),createElementBlock("div",{key:3,class:"notification-message",onClick:p[0]||(p[0]=(...S)=>o.onClickMessage&&o.onClickMessage(...S))},[createBaseVNode("div",{class:normalizeClass(["message-container",{collapsed:o.isCollapsedMessage}])},[c.notification.messageRich?(openBlock(),createBlock(b,{key:0,text:c.notification.messageRich,arguments:o.preparedMessageParameters,autolink:!0},null,8,["text","arguments"])):(openBlock(),createElementBlock("span",_hoisted_15,toDisplayString(c.notification.message),1))],2),o.isCollapsedMessage?(openBlock(),createElementBlock("div",_hoisted_16)):createCommentVNode("",!0)])):createCommentVNode("",!0),c.notification.actions.length?(openBlock(),createElementBlock("div",_hoisted_17,[(openBlock(!0),createElementBlock(Fragment,null,renderList(c.notification.actions,(S,q)=>(openBlock(),createBlock(R,{key:q,action:S,onClick:o.onClickAction,onRemove:p[1]||(p[1]=$=>n.$emit("remove"))},null,8,["action","onClick"]))),128))])):c.notification.externalLink?(openBlock(),createElementBlock("div",_hoisted_18,[createVNode(B,{variant:"primary",href:"https://nextcloud.com/fairusepolicy",class:"action-button pull-right",target:"_blank",rel:"noreferrer noopener"},{icon:withCtx(()=>[createVNode(g,{size:20})]),default:withCtx(()=>[createTextVNode(" "+toDisplayString(o.t("notifications","Contact Nextcloud GmbH"))+" ↗ ",1)]),_:1})])):createCommentVNode("",!0)],8,_hoisted_1$1)}const NotificationItem=_export_sfc$1(_sfc_main$1,[["render",_sfc_render$1],["__scopeId","data-v-58882784"]]);async function getNotificationsData(n,p,c,l){const x=parseInt(BrowserStorage.getItem("lastUpdated"),10),o=BrowserStorage.getItem("tabId"),E=Math.floor(Date.now()/1e3);return(c||o===n&&x+25=0&&g<=1){if(S._volume=g,S._muted)return S;S.usingWebAudio&&S.masterGain.gain.setValueAtTime(g,c.ctx.currentTime);for(var q=0;q=0;S--)g._howls[S].unload();return g.usingWebAudio&&g.ctx&&typeof g.ctx.close<"u"&&(g.ctx.close(),g.ctx=null,R()),g},codecs:function(g){return(this||c)._codecs[g.replace(/^x-/,"")]},_setup:function(){var g=this||c;if(g.state=g.ctx&&g.ctx.state||"suspended",g._autoSuspend(),!g.usingWebAudio)if(typeof Audio<"u")try{var S=new Audio;typeof S.oncanplaythrough>"u"&&(g._canPlayEvent="canplay")}catch{g.noAudio=!0}else g.noAudio=!0;try{var S=new Audio;S.muted&&(g.noAudio=!0)}catch{}return g.noAudio||g._setupCodecs(),g},_setupCodecs:function(){var g=this||c,S=null;try{S=typeof Audio<"u"?new Audio:null}catch{return g}if(!S||typeof S.canPlayType!="function")return g;var q=S.canPlayType("audio/mpeg;").replace(/^no$/,""),$=g._navigator?g._navigator.userAgent:"",I=$.match(/OPR\/(\d+)/g),P=I&&parseInt(I[0].split("/")[1],10)<33,O=$.indexOf("Safari")!==-1&&$.indexOf("Chrome")===-1,L=$.match(/Version\/(.*?) /),F=O&&L&&parseInt(L[1],10)<15;return g._codecs={mp3:!!(!P&&(q||S.canPlayType("audio/mp3;").replace(/^no$/,""))),mpeg:!!q,opus:!!S.canPlayType('audio/ogg; codecs="opus"').replace(/^no$/,""),ogg:!!S.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,""),oga:!!S.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,""),wav:!!(S.canPlayType('audio/wav; codecs="1"')||S.canPlayType("audio/wav")).replace(/^no$/,""),aac:!!S.canPlayType("audio/aac;").replace(/^no$/,""),caf:!!S.canPlayType("audio/x-caf;").replace(/^no$/,""),m4a:!!(S.canPlayType("audio/x-m4a;")||S.canPlayType("audio/m4a;")||S.canPlayType("audio/aac;")).replace(/^no$/,""),m4b:!!(S.canPlayType("audio/x-m4b;")||S.canPlayType("audio/m4b;")||S.canPlayType("audio/aac;")).replace(/^no$/,""),mp4:!!(S.canPlayType("audio/x-mp4;")||S.canPlayType("audio/mp4;")||S.canPlayType("audio/aac;")).replace(/^no$/,""),weba:!!(!F&&S.canPlayType('audio/webm; codecs="vorbis"').replace(/^no$/,"")),webm:!!(!F&&S.canPlayType('audio/webm; codecs="vorbis"').replace(/^no$/,"")),dolby:!!S.canPlayType('audio/mp4; codecs="ec-3"').replace(/^no$/,""),flac:!!(S.canPlayType("audio/x-flac;")||S.canPlayType("audio/flac;")).replace(/^no$/,"")},g},_unlockAudio:function(){var g=this||c;if(!(g._audioUnlocked||!g.ctx)){g._audioUnlocked=!1,g.autoUnlock=!1,!g._mobileUnloaded&&g.ctx.sampleRate!==44100&&(g._mobileUnloaded=!0,g.unload()),g._scratchBuffer=g.ctx.createBuffer(1,1,22050);var S=function(q){for(;g._html5AudioPool.length"u"?F.noteOn(0):F.start(0),typeof g.ctx.resume=="function"&&g.ctx.resume(),F.onended=function(){F.disconnect(0),g._audioUnlocked=!0,document.removeEventListener("touchstart",S,!0),document.removeEventListener("touchend",S,!0),document.removeEventListener("click",S,!0),document.removeEventListener("keydown",S,!0);for(var U=0;U"u"||!c.usingWebAudio)){for(var S=0;S"u"||!c.usingWebAudio))return g.state==="running"&&g.ctx.state!=="interrupted"&&g._suspendTimer?(clearTimeout(g._suspendTimer),g._suspendTimer=null):g.state==="suspended"||g.state==="running"&&g.ctx.state==="interrupted"?(g.ctx.resume().then(function(){g.state="running";for(var S=0;S"u"&&(g="__default",!q._playLock)){for(var I=0,P=0;P0?O._seek:q._sprite[g][0]/1e3),U=Math.max(0,(q._sprite[g][0]+q._sprite[g][1])/1e3-F),Q=U*1e3/Math.abs(O._rate),Y=q._sprite[g][0]/1e3,ce=(q._sprite[g][0]+q._sprite[g][1])/1e3;O._sprite=g,O._ended=!1;var le=function(){O._paused=!1,O._seek=F,O._start=Y,O._stop=ce,O._loop=!!(O._loop||q._sprite[g][2])};if(F>=ce){q._ended(O);return}var ne=O._node;if(q._webAudio){var he=function(){q._playLock=!1,le(),q._refreshBuffer(O);var m=O._muted||q._muted?0:O._volume;ne.gain.setValueAtTime(m,c.ctx.currentTime),O._playStart=c.ctx.currentTime,typeof ne.bufferSource.start>"u"?O._loop?ne.bufferSource.noteGrainOn(0,F,86400):ne.bufferSource.noteGrainOn(0,F,U):O._loop?ne.bufferSource.start(0,F,86400):ne.bufferSource.start(0,F,U),Q!==1/0&&(q._endTimers[O._id]=setTimeout(q._ended.bind(q,O),Q)),S||setTimeout(function(){q._emit("play",O._id),q._loadQueue()},0)};c.state==="running"&&c.ctx.state!=="interrupted"?he():(q._playLock=!0,q.once("resume",he),q._clearTimer(O._id))}else{var r=function(){ne.currentTime=F,ne.muted=O._muted||q._muted||c._muted||ne.muted,ne.volume=O._volume*c.volume(),ne.playbackRate=O._rate;try{var m=ne.play();if(m&&typeof Promise<"u"&&(m instanceof Promise||typeof m.then=="function")?(q._playLock=!0,le(),m.then(function(){q._playLock=!1,ne._unlocked=!0,S?q._loadQueue():q._emit("play",O._id)}).catch(function(){q._playLock=!1,q._emit("playerror",O._id,"Playback was unable to start. This is most commonly an issue on mobile devices and Chrome where playback was not within a user interaction."),O._ended=!0,O._paused=!0})):S||(q._playLock=!1,le(),q._emit("play",O._id)),ne.playbackRate=O._rate,ne.paused){q._emit("playerror",O._id,"Playback was unable to start. This is most commonly an issue on mobile devices and Chrome where playback was not within a user interaction.");return}g!=="__default"||O._loop?q._endTimers[O._id]=setTimeout(q._ended.bind(q,O),Q):(q._endTimers[O._id]=function(){q._ended(O),ne.removeEventListener("ended",q._endTimers[O._id],!1)},ne.addEventListener("ended",q._endTimers[O._id],!1))}catch(k){q._emit("playerror",O._id,k)}};ne.src==="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA"&&(ne.src=q._src,ne.load());var a=window&&window.ejecta||!ne.readyState&&c._navigator.isCocoonJS;if(ne.readyState>=3||a)r();else{q._playLock=!0,q._state="loading";var s=function(){q._state="loaded",r(),ne.removeEventListener(c._canPlayEvent,s,!1)};ne.addEventListener(c._canPlayEvent,s,!1),q._clearTimer(O._id)}}return O._id},pause:function(g){var S=this;if(S._state!=="loaded"||S._playLock)return S._queue.push({event:"pause",action:function(){S.pause(g)}}),S;for(var q=S._getSoundIds(g),$=0;$"u"?I._node.bufferSource.noteOff(0):I._node.bufferSource.stop(0),S._cleanBuffer(I._node)}else(!isNaN(I._node.duration)||I._node.duration===1/0)&&I._node.pause();arguments[1]||S._emit("pause",I?I._id:null)}return S},stop:function(g,S){var q=this;if(q._state!=="loaded"||q._playLock)return q._queue.push({event:"stop",action:function(){q.stop(g)}}),q;for(var $=q._getSoundIds(g),I=0;I<$.length;I++){q._clearTimer($[I]);var P=q._soundById($[I]);P&&(P._seek=P._start||0,P._rateSeek=0,P._paused=!0,P._ended=!0,q._stopFade($[I]),P._node&&(q._webAudio?P._node.bufferSource&&(typeof P._node.bufferSource.stop>"u"?P._node.bufferSource.noteOff(0):P._node.bufferSource.stop(0),q._cleanBuffer(P._node)):(!isNaN(P._node.duration)||P._node.duration===1/0)&&(P._node.currentTime=P._start||0,P._node.pause(),P._node.duration===1/0&&q._clearSound(P._node))),S||q._emit("stop",P._id))}return q},mute:function(g,S){var q=this;if(q._state!=="loaded"||q._playLock)return q._queue.push({event:"mute",action:function(){q.mute(g,S)}}),q;if(typeof S>"u")if(typeof g=="boolean")q._muted=g;else return q._muted;for(var $=q._getSoundIds(S),I=0;I<$.length;I++){var P=q._soundById($[I]);P&&(P._muted=g,P._interval&&q._stopFade(P._id),q._webAudio&&P._node?P._node.gain.setValueAtTime(g?0:P._volume,c.ctx.currentTime):P._node&&(P._node.muted=c._muted?!0:g),q._emit("mute",P._id))}return q},volume:function(){var g=this,S=arguments,q,$;if(S.length===0)return g._volume;if(S.length===1||S.length===2&&typeof S[1]>"u"){var I=g._getSoundIds(),P=I.indexOf(S[0]);P>=0?$=parseInt(S[0],10):q=parseFloat(S[0])}else S.length>=2&&(q=parseFloat(S[0]),$=parseInt(S[1],10));var O;if(typeof q<"u"&&q>=0&&q<=1){if(g._state!=="loaded"||g._playLock)return g._queue.push({event:"volume",action:function(){g.volume.apply(g,S)}}),g;typeof $>"u"&&(g._volume=q),$=g._getSoundIds($);for(var L=0;L<$.length;L++)O=g._soundById($[L]),O&&(O._volume=q,S[2]||g._stopFade($[L]),g._webAudio&&O._node&&!O._muted?O._node.gain.setValueAtTime(q,c.ctx.currentTime):O._node&&!O._muted&&(O._node.volume=q*c.volume()),g._emit("volume",O._id))}else return O=$?g._soundById($):g._sounds[0],O?O._volume:0;return g},fade:function(g,S,q,$){var I=this;if(I._state!=="loaded"||I._playLock)return I._queue.push({event:"fade",action:function(){I.fade(g,S,q,$)}}),I;g=Math.min(Math.max(0,parseFloat(g)),1),S=Math.min(Math.max(0,parseFloat(S)),1),q=parseFloat(q),I.volume(g,$);for(var P=I._getSoundIds($),O=0;O"u")}}return I},_startFadeInterval:function(g,S,q,$,I,P){var O=this,L=S,F=q-S,U=Math.abs(F/.01),Q=Math.max(4,U>0?$/U:$),Y=Date.now();g._fadeTo=q,g._interval=setInterval(function(){var ce=(Date.now()-Y)/$;Y=Date.now(),L+=F*ce,L=Math.round(L*100)/100,F<0?L=Math.max(q,L):L=Math.min(q,L),O._webAudio?g._volume=L:O.volume(L,g._id,!0),P&&(O._volume=L),(qS&&L>=q)&&(clearInterval(g._interval),g._interval=null,g._fadeTo=null,O.volume(q,g._id),O._emit("fade",g._id))},Q)},_stopFade:function(g){var S=this,q=S._soundById(g);return q&&q._interval&&(S._webAudio&&q._node.gain.cancelScheduledValues(c.ctx.currentTime),clearInterval(q._interval),q._interval=null,S.volume(q._fadeTo,g),q._fadeTo=null,S._emit("fade",g)),S},loop:function(){var g=this,S=arguments,q,$,I;if(S.length===0)return g._loop;if(S.length===1)if(typeof S[0]=="boolean")q=S[0],g._loop=q;else return I=g._soundById(parseInt(S[0],10)),I?I._loop:!1;else S.length===2&&(q=S[0],$=parseInt(S[1],10));for(var P=g._getSoundIds($),O=0;O=0?$=parseInt(S[0],10):q=parseFloat(S[0])}else S.length===2&&(q=parseFloat(S[0]),$=parseInt(S[1],10));var O;if(typeof q=="number"){if(g._state!=="loaded"||g._playLock)return g._queue.push({event:"rate",action:function(){g.rate.apply(g,S)}}),g;typeof $>"u"&&(g._rate=q),$=g._getSoundIds($);for(var L=0;L<$.length;L++)if(O=g._soundById($[L]),O){g.playing($[L])&&(O._rateSeek=g.seek($[L]),O._playStart=g._webAudio?c.ctx.currentTime:O._playStart),O._rate=q,g._webAudio&&O._node&&O._node.bufferSource?O._node.bufferSource.playbackRate.setValueAtTime(q,c.ctx.currentTime):O._node&&(O._node.playbackRate=q);var F=g.seek($[L]),U=(g._sprite[O._sprite][0]+g._sprite[O._sprite][1])/1e3-F,Q=U*1e3/Math.abs(O._rate);(g._endTimers[$[L]]||!O._paused)&&(g._clearTimer($[L]),g._endTimers[$[L]]=setTimeout(g._ended.bind(g,O),Q)),g._emit("rate",O._id)}}else return O=g._soundById($),O?O._rate:g._rate;return g},seek:function(){var g=this,S=arguments,q,$;if(S.length===0)g._sounds.length&&($=g._sounds[0]._id);else if(S.length===1){var I=g._getSoundIds(),P=I.indexOf(S[0]);P>=0?$=parseInt(S[0],10):g._sounds.length&&($=g._sounds[0]._id,q=parseFloat(S[0]))}else S.length===2&&(q=parseFloat(S[0]),$=parseInt(S[1],10));if(typeof $>"u")return 0;if(typeof q=="number"&&(g._state!=="loaded"||g._playLock))return g._queue.push({event:"seek",action:function(){g.seek.apply(g,S)}}),g;var O=g._soundById($);if(O)if(typeof q=="number"&&q>=0){var L=g.playing($);L&&g.pause($,!0),O._seek=q,O._ended=!1,g._clearTimer($),!g._webAudio&&O._node&&!isNaN(O._node.duration)&&(O._node.currentTime=q);var F=function(){L&&g.play($,!0),g._emit("seek",$)};if(L&&!g._webAudio){var U=function(){g._playLock?setTimeout(U,0):F()};setTimeout(U,0)}else F()}else if(g._webAudio){var Q=g.playing($)?c.ctx.currentTime-O._playStart:0,Y=O._rateSeek?O._rateSeek-O._seek:0;return O._seek+(Y+Q*Math.abs(O._rate))}else return O._node.currentTime;return g},playing:function(g){var S=this;if(typeof g=="number"){var q=S._soundById(g);return q?!q._paused:!1}for(var $=0;$=0&&c._howls.splice($,1);var I=!0;for(q=0;q=0){I=!1;break}return o&&I&&delete o[g._src],c.noAudio=!1,g._state="unloaded",g._sounds=[],g=null,null},on:function(g,S,q,$){var I=this,P=I["_on"+g];return typeof S=="function"&&P.push($?{id:q,fn:S,once:$}:{id:q,fn:S}),I},off:function(g,S,q){var $=this,I=$["_on"+g],P=0;if(typeof S=="number"&&(q=S,S=null),S||q)for(P=0;P=0;P--)(!I[P].id||I[P].id===S||g==="load")&&(setTimeout(function(O){O.call(this,S,q)}.bind($,I[P].fn),0),I[P].once&&$.off(g,I[P].fn,I[P].id));return $._loadQueue(g),$},_loadQueue:function(g){var S=this;if(S._queue.length>0){var q=S._queue[0];q.event===g&&(S._queue.shift(),S._loadQueue()),g||q.action()}return S},_ended:function(g){var S=this,q=g._sprite;if(!S._webAudio&&g._node&&!g._node.paused&&!g._node.ended&&g._node.currentTime=0;$--){if(q<=S)return;g._sounds[$]._ended&&(g._webAudio&&g._sounds[$]._node&&g._sounds[$]._node.disconnect(0),g._sounds.splice($,1),q--)}}},_getSoundIds:function(g){var S=this;if(typeof g>"u"){for(var q=[],$=0;$=0;if(!g.bufferSource)return S;if(c._scratchBuffer&&g.bufferSource&&(g.bufferSource.onended=null,g.bufferSource.disconnect(0),q))try{g.bufferSource.buffer=c._scratchBuffer}catch{}return g.bufferSource=null,S},_clearSound:function(g){var S=/MSIE |Trident\//.test(c._navigator&&c._navigator.userAgent);S||(g.src="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA")}};var x=function(g){this._parent=g,this.init()};x.prototype={init:function(){var g=this,S=g._parent;return g._muted=S._muted,g._loop=S._loop,g._volume=S._volume,g._rate=S._rate,g._seek=0,g._paused=!0,g._ended=!0,g._sprite="__default",g._id=++c._counter,S._sounds.push(g),g.create(),g},create:function(){var g=this,S=g._parent,q=c._muted||g._muted||g._parent._muted?0:g._volume;return S._webAudio?(g._node=typeof c.ctx.createGain>"u"?c.ctx.createGainNode():c.ctx.createGain(),g._node.gain.setValueAtTime(q,c.ctx.currentTime),g._node.paused=!0,g._node.connect(c.masterGain)):c.noAudio||(g._node=c._obtainHtml5Audio(),g._errorFn=g._errorListener.bind(g),g._node.addEventListener("error",g._errorFn,!1),g._loadFn=g._loadListener.bind(g),g._node.addEventListener(c._canPlayEvent,g._loadFn,!1),g._endFn=g._endListener.bind(g),g._node.addEventListener("ended",g._endFn,!1),g._node.src=S._src,g._node.preload=S._preload===!0?"auto":S._preload,g._node.volume=q*c.volume(),g._node.load()),g},reset:function(){var g=this,S=g._parent;return g._muted=S._muted,g._loop=S._loop,g._volume=S._volume,g._rate=S._rate,g._seek=0,g._rateSeek=0,g._paused=!0,g._ended=!0,g._sprite="__default",g._id=++c._counter,g},_errorListener:function(){var g=this;g._parent._emit("loaderror",g._id,g._node.error?g._node.error.code:0),g._node.removeEventListener("error",g._errorFn,!1)},_loadListener:function(){var g=this,S=g._parent;S._duration=Math.ceil(g._node.duration*10)/10,Object.keys(S._sprite).length===0&&(S._sprite={__default:[0,S._duration*1e3]}),S._state!=="loaded"&&(S._state="loaded",S._emit("load"),S._loadQueue()),g._node.removeEventListener(c._canPlayEvent,g._loadFn,!1)},_endListener:function(){var g=this,S=g._parent;S._duration===1/0&&(S._duration=Math.ceil(g._node.duration*10)/10,S._sprite.__default[1]===1/0&&(S._sprite.__default[1]=S._duration*1e3),S._ended(g)),g._node.removeEventListener("ended",g._endFn,!1)}};var o={},E=function(g){var S=g._src;if(o[S]){g._duration=o[S].duration,b(g);return}if(/^data:[^;]+;base64,/.test(S)){for(var q=atob(S.split(",")[1]),$=new Uint8Array(q.length),I=0;I0?(o[S._src]=I,b(S,I)):q()};typeof Promise<"u"&&c.ctx.decodeAudioData.length===1?c.ctx.decodeAudioData(g).then($).catch(q):c.ctx.decodeAudioData(g,$,q)},b=function(g,S){S&&!g._duration&&(g._duration=S.duration),Object.keys(g._sprite).length===0&&(g._sprite={__default:[0,g._duration*1e3]}),g._state!=="loaded"&&(g._state="loaded",g._emit("load"),g._loadQueue())},R=function(){if(c.usingWebAudio){try{typeof AudioContext<"u"?c.ctx=new AudioContext:typeof webkitAudioContext<"u"?c.ctx=new webkitAudioContext:c.usingWebAudio=!1}catch{c.usingWebAudio=!1}c.ctx||(c.usingWebAudio=!1);var g=/iP(hone|od|ad)/.test(c._navigator&&c._navigator.platform),S=c._navigator&&c._navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/),q=S?parseInt(S[1],10):null;if(g&&q&&q<9){var $=/safari/.test(c._navigator&&c._navigator.userAgent.toLowerCase());c._navigator&&!$&&(c.usingWebAudio=!1)}c.usingWebAudio&&(c.masterGain=typeof c.ctx.createGain>"u"?c.ctx.createGainNode():c.ctx.createGain(),c.masterGain.gain.setValueAtTime(c._muted?0:c._volume,c.ctx.currentTime),c.masterGain.connect(c.ctx.destination)),c._setup()}};n.Howler=c,n.Howl=l,typeof commonjsGlobal<"u"?(commonjsGlobal.HowlerGlobal=p,commonjsGlobal.Howler=c,commonjsGlobal.Howl=l,commonjsGlobal.Sound=x):typeof window<"u"&&(window.HowlerGlobal=p,window.Howler=c,window.Howl=l,window.Sound=x)})(),function(){HowlerGlobal.prototype._pos=[0,0,0],HowlerGlobal.prototype._orientation=[0,0,-1,0,1,0],HowlerGlobal.prototype.stereo=function(c){var l=this;if(!l.ctx||!l.ctx.listener)return l;for(var x=l._howls.length-1;x>=0;x--)l._howls[x].stereo(c);return l},HowlerGlobal.prototype.pos=function(c,l,x){var o=this;if(!o.ctx||!o.ctx.listener)return o;if(l=typeof l!="number"?o._pos[1]:l,x=typeof x!="number"?o._pos[2]:x,typeof c=="number")o._pos=[c,l,x],typeof o.ctx.listener.positionX<"u"?(o.ctx.listener.positionX.setTargetAtTime(o._pos[0],Howler.ctx.currentTime,.1),o.ctx.listener.positionY.setTargetAtTime(o._pos[1],Howler.ctx.currentTime,.1),o.ctx.listener.positionZ.setTargetAtTime(o._pos[2],Howler.ctx.currentTime,.1)):o.ctx.listener.setPosition(o._pos[0],o._pos[1],o._pos[2]);else return o._pos;return o},HowlerGlobal.prototype.orientation=function(c,l,x,o,E,A){var B=this;if(!B.ctx||!B.ctx.listener)return B;var b=B._orientation;if(l=typeof l!="number"?b[1]:l,x=typeof x!="number"?b[2]:x,o=typeof o!="number"?b[3]:o,E=typeof E!="number"?b[4]:E,A=typeof A!="number"?b[5]:A,typeof c=="number")B._orientation=[c,l,x,o,E,A],typeof B.ctx.listener.forwardX<"u"?(B.ctx.listener.forwardX.setTargetAtTime(c,Howler.ctx.currentTime,.1),B.ctx.listener.forwardY.setTargetAtTime(l,Howler.ctx.currentTime,.1),B.ctx.listener.forwardZ.setTargetAtTime(x,Howler.ctx.currentTime,.1),B.ctx.listener.upX.setTargetAtTime(o,Howler.ctx.currentTime,.1),B.ctx.listener.upY.setTargetAtTime(E,Howler.ctx.currentTime,.1),B.ctx.listener.upZ.setTargetAtTime(A,Howler.ctx.currentTime,.1)):B.ctx.listener.setOrientation(c,l,x,o,E,A);else return b;return B},Howl.prototype.init=function(c){return function(l){var x=this;return x._orientation=l.orientation||[1,0,0],x._stereo=l.stereo||null,x._pos=l.pos||null,x._pannerAttr={coneInnerAngle:typeof l.coneInnerAngle<"u"?l.coneInnerAngle:360,coneOuterAngle:typeof l.coneOuterAngle<"u"?l.coneOuterAngle:360,coneOuterGain:typeof l.coneOuterGain<"u"?l.coneOuterGain:0,distanceModel:typeof l.distanceModel<"u"?l.distanceModel:"inverse",maxDistance:typeof l.maxDistance<"u"?l.maxDistance:1e4,panningModel:typeof l.panningModel<"u"?l.panningModel:"HRTF",refDistance:typeof l.refDistance<"u"?l.refDistance:1,rolloffFactor:typeof l.rolloffFactor<"u"?l.rolloffFactor:1},x._onstereo=l.onstereo?[{fn:l.onstereo}]:[],x._onpos=l.onpos?[{fn:l.onpos}]:[],x._onorientation=l.onorientation?[{fn:l.onorientation}]:[],c.call(this,l)}}(Howl.prototype.init),Howl.prototype.stereo=function(c,l){var x=this;if(!x._webAudio)return x;if(x._state!=="loaded")return x._queue.push({event:"stereo",action:function(){x.stereo(c,l)}}),x;var o=typeof Howler.ctx.createStereoPanner>"u"?"spatial":"stereo";if(typeof l>"u")if(typeof c=="number")x._stereo=c,x._pos=[c,0,0];else return x._stereo;for(var E=x._getSoundIds(l),A=0;A"u")if(typeof c=="number")E._pos=[c,l,x];else return E._pos;for(var A=E._getSoundIds(o),B=0;B"u")if(typeof c=="number")E._orientation=[c,l,x];else return E._orientation;for(var A=E._getSoundIds(o),B=0;B"u"&&(x.pannerAttr||(x.pannerAttr={coneInnerAngle:x.coneInnerAngle,coneOuterAngle:x.coneOuterAngle,coneOuterGain:x.coneOuterGain,distanceModel:x.distanceModel,maxDistance:x.maxDistance,refDistance:x.refDistance,rolloffFactor:x.rolloffFactor,panningModel:x.panningModel}),c._pannerAttr={coneInnerAngle:typeof x.pannerAttr.coneInnerAngle<"u"?x.pannerAttr.coneInnerAngle:c._coneInnerAngle,coneOuterAngle:typeof x.pannerAttr.coneOuterAngle<"u"?x.pannerAttr.coneOuterAngle:c._coneOuterAngle,coneOuterGain:typeof x.pannerAttr.coneOuterGain<"u"?x.pannerAttr.coneOuterGain:c._coneOuterGain,distanceModel:typeof x.pannerAttr.distanceModel<"u"?x.pannerAttr.distanceModel:c._distanceModel,maxDistance:typeof x.pannerAttr.maxDistance<"u"?x.pannerAttr.maxDistance:c._maxDistance,refDistance:typeof x.pannerAttr.refDistance<"u"?x.pannerAttr.refDistance:c._refDistance,rolloffFactor:typeof x.pannerAttr.rolloffFactor<"u"?x.pannerAttr.rolloffFactor:c._rolloffFactor,panningModel:typeof x.pannerAttr.panningModel<"u"?x.pannerAttr.panningModel:c._panningModel});else return E=c._soundById(parseInt(l[0],10)),E?E._pannerAttr:c._pannerAttr;else l.length===2&&(x=l[0],o=parseInt(l[1],10));for(var A=c._getSoundIds(o),B=0;Bconsole.debug("Audio output successfully redirected to secondary speaker")).catch(A=>console.error("Failed to redirect audio output:",A)),E.play()}}}else loadState$1("notifications","sound_notification")&&new howlerExports.Howl({src:[d("notifications","img","notification.ogg")],volume:.5}).play()}const sessionKeepAlive=loadState$1("core","config",{session_keepalive:!0}).session_keepalive,hasThrottledPushNotifications=loadState$1("notifications","throttled_push_notifications"),fairUsePolicyNotification={notificationId:-1,app:"core",user:"",datetime:"warning",objectId:"",objectType:"",subject:translate("notifications","Push notifications might be unreliable"),message:translate("notifications","Nextcloud GmbH sponsors a free push notification gateway for private users. To ensure good service, the gateway limits the number of push notifications per server. For enterprise users, a more scalable gateway is available. Contact Nextcloud GmbH for more information."),link:"https://nextcloud.com/fairusepolicy",actions:[],externalLink:"https://nextcloud.com/fairusepolicy",icon:h$1("core","actions/alert-outline.svg")},_sfc_main={name:"NotificationsApp",components:{IconBellOutline,IconClose,IconMessageOutline,IconNotification:_sfc_main$f,NcButton,NcEmptyContent,NcHeaderMenu,NotificationItem},setup(){return{fairUsePolicyNotification,hasThrottledPushNotifications}},data(){return{webNotificationsGranted:!1,backgroundFetching:!1,hasNotifyPush:!1,shutdown:!1,notifications:[],lastETag:null,lastTabId:null,userStatus:null,tabId:null,webNotificationsThresholdId:0,pollIntervalBase:3e4,pollIntervalCurrent:3e4,interval:null,pushEndpoints:null,open:!1}},computed:{showBrowserNotifications(){return this.backgroundFetching&&this.webNotificationsGranted&&this.userStatus!=="dnd"&&this.tabId===this.lastTabId},emptyContentMessage(){return this.webNotificationsGranted===null?translate("notifications","Requesting browser permissions to show notifications"):this.hasThrottledPushNotifications?this.fairUsePolicyNotification.subject:translate("notifications","No notifications")},emptyContentDescription(){return this.hasThrottledPushNotifications?this.fairUsePolicyNotification.message:""}},mounted(){this.tabId=getRequestToken()||""+Math.random(),this._oldcount=0,this.checkWebNotificationPermissions(),this._fetch(),distExports.listen("notify_notification",()=>{this._fetchAfterNotifyPush()})&&(console.debug("Has notify_push enabled, slowing polling to 15 minutes"),this.pollIntervalBase=15*60*1e3,this.hasNotifyPush=!0),this._setPollingInterval(this.pollIntervalBase),this._watchTabVisibility(),subscribe("networkOffline",this.handleNetworkOffline),subscribe("networkOnline",this.handleNetworkOnline),subscribe("user_status:status.updated",this.userStatusUpdated)},beforeUnmount(){unsubscribe("user_status:status.updated",this.userStatusUpdated),unsubscribe("networkOffline",this.handleNetworkOffline),unsubscribe("networkOnline",this.handleNetworkOnline)},methods:{t:translate,userStatusUpdated(n){getCurrentUser().uid===n.userId&&(this.userStatus=n.status)},onOpen(){this.requestWebNotificationPermissions()},handleNetworkOffline(){console.debug("Network is offline, slowing down pollingInterval to "+this.pollIntervalBase*10),this._setPollingInterval(this.pollIntervalBase*10)},handleNetworkOnline(){this._fetch(),console.debug("Network is online, reseting pollingInterval to "+this.pollIntervalBase),this._setPollingInterval(this.pollIntervalBase)},setupBackgroundFetcher(){sessionKeepAlive?(console.debug("Started background fetcher as session_keepalive is enabled"),this.interval=window.setInterval(this._backgroundFetch.bind(this),this.pollIntervalCurrent)):console.debug("Did not start background fetcher as session_keepalive is off")},onDismissAll(){cancelableClient.delete(v("apps/notifications/api/v2/notifications")).then(()=>{this.notifications=[]}).catch(()=>{showError(translate("notifications","Failed to dismiss all notifications"))})},onRemove(n){this.notifications.splice(n,1)},_updateDocTitleOnNewNotifications(n){n.length>this._oldcount&&(this._oldcount=n.length,this.backgroundFetching&&document.hidden&&(document.title.startsWith("* ")||(document.title="* "+document.title)))},_restoreTitle(){document.title.startsWith("* ")&&(document.title=document.title.substring(2))},_fetchAfterNotifyPush(){this.backgroundFetching=!0,this.hasNotifyPush&&this.tabId!==this.lastTabId?(console.debug("Deferring notification refresh from browser storage are notify_push event to give the last tab the chance to do it"),setTimeout(()=>{this._fetch()},5e3)):(console.debug("Refreshing notifications are notify_push event"),this._fetch())},async _fetch(){this.notifications.length&&this.notifications[0].notificationId>this.webNotificationsThresholdId&&(this.webNotificationsThresholdId=this.notifications[0].notificationId);const n=await getNotificationsData(this.tabId,this.lastETag,!this.backgroundFetching,this.hasNotifyPush);n.status===204?(console.debug("Fetching notifications but no content, slowing down polling to "+this.pollIntervalBase*10),this._setPollingInterval(this.pollIntervalBase*10)):n.status===200?(this.userStatus=n.headers["x-nextcloud-user-status"],this.lastETag=n.headers.etag,this.lastTabId=n.tabId,this.notifications=n.data,this.processWebNotifications(n.data),console.debug("Got notification data, restoring default polling interval."),this._setPollingInterval(this.pollIntervalBase),this._updateDocTitleOnNewNotifications(this.notifications),!this.backgroundFetching&&this.notifications.length&&(this.webNotificationsThresholdId=this.notifications[0].notificationId)):n.status===304?this._setPollingInterval(this.pollIntervalBase):n.status===503?(console.info("Slowing down notifications: instance is in maintenance mode."),this._setPollingInterval(this.pollIntervalBase*10)):n.status===404?(console.info("Slowing down notifications: app is disabled."),this._setPollingInterval(this.pollIntervalBase*10)):(console.info("Slowing down notifications: Status "+n.status),this._setPollingInterval(this.pollIntervalBase*10))},_backgroundFetch(){this.backgroundFetching=!0,this._fetch()},_watchTabVisibility(){document.addEventListener("visibilitychange",this._visibilityChange,!1)},_visibilityChange(){document.hidden||this._restoreTitle()},_setPollingInterval(n){this.interval&&n===this.pollIntervalCurrent||(console.debug("Polling interval updated to "+n),this.interval&&(window.clearInterval(this.interval),this.interval=null),this.pollIntervalCurrent=n,this.setupBackgroundFetcher())},_shutDownNotifications(n){console.debug("Shutting down notifications "+(n?"temporary":"bye")),this.interval&&(window.clearInterval(this.interval),this.interval=null),this.shutdown=!n},checkWebNotificationPermissions(){if(!("Notification"in window)){console.info("Browser does not support notifications"),this.webNotificationsGranted=!1;return}if(window.Notification.permission==="granted"){console.debug("Notifications permissions granted"),this.webNotificationsGranted=!0;return}if(window.Notification.permission==="denied"){console.debug("Notifications permissions denied"),this.webNotificationsGranted=!1;return}if(window.location.protocol==="http:"){console.debug("Notifications require HTTPS"),this.webNotificationsGranted=!1;return}console.info("Notifications permissions not yet requested"),this.webNotificationsGranted=null},async requestWebNotificationPermissions(){this.webNotificationsGranted===null&&(console.info("Requesting notifications permissions"),window.Notification.requestPermission().then(n=>{this.webNotificationsGranted=n==="granted"}))},processWebNotifications(n){n.forEach(p=>{this.backgroundFetching&&emit("notifications:notification:received",{notification:p}),this.showBrowserNotifications&&this.webNotificationsThresholdIdx.open=$),class:"notifications-button","exclude-click-outside-selectors":[".popover"],"aria-label":o.t("notifications","Notifications"),title:o.t("notifications","Notifications"),onOpen:o.onOpen},{trigger:withCtx(()=>[createVNode(E,{size:20,"show-dot":x.notifications.length!==0||x.webNotificationsGranted===null,"show-warning":l.hasThrottledPushNotifications},null,8,["show-dot","show-warning"])]),default:withCtx(()=>[createBaseVNode("div",_hoisted_1,[createVNode(Transition,{name:"fade",mode:"out-in"},{default:withCtx(()=>[x.notifications.length>0?(openBlock(),createBlock(TransitionGroup,{key:0,class:"notification-wrapper",name:"list",tag:"ul"},{default:withCtx(()=>[l.hasThrottledPushNotifications?(openBlock(),createBlock(A,{key:-2016,notification:l.fairUsePolicyNotification},null,8,["notification"])):createCommentVNode("",!0),(openBlock(!0),createElementBlock(Fragment,null,renderList(x.notifications,($,I)=>(openBlock(),createBlock(A,{key:$.notificationId,notification:$,onRemove:P=>o.onRemove(I)},null,8,["notification","onRemove"]))),128))]),_:1})):(openBlock(),createBlock(g,{key:1,name:o.emptyContentMessage,description:o.emptyContentDescription},createSlots({icon:withCtx(()=>[l.hasThrottledPushNotifications?(openBlock(),createElementBlock("span",_hoisted_2)):(openBlock(),createBlock(B,{key:0}))]),_:2},[l.hasThrottledPushNotifications?{name:"action",fn:withCtx(()=>[createVNode(R,{variant:"primary",href:"https://nextcloud.com/fairusepolicy",target:"_blank",rel:"noreferrer noopener"},{icon:withCtx(()=>[createVNode(b,{size:20})]),default:withCtx(()=>[createTextVNode(" "+toDisplayString(o.t("notifications","Contact Nextcloud GmbH"))+" ↗ ",1)]),_:1})]),key:"0"}:void 0]),1032,["name","description"]))]),_:1}),x.notifications.length>0?(openBlock(),createElementBlock("div",_hoisted_3,[createVNode(R,{variant:"tertiary",wide:"",onClick:o.onDismissAll},{icon:withCtx(()=>[createVNode(S,{size:20})]),default:withCtx(()=>[createTextVNode(" "+toDisplayString(o.t("notifications","Dismiss all notifications")),1)]),_:1},8,["onClick"])])):createCommentVNode("",!0)])]),_:1},8,["open","aria-label","title","onOpen"]))}const NotificationsApp=_export_sfc$1(_sfc_main,[["render",_sfc_render],["__scopeId","data-v-e4adb601"]]),NotificationsApp$1=Object.freeze(Object.defineProperty({__proto__:null,default:NotificationsApp},Symbol.toStringTag,{value:"Module"}));export{NotificationsApp$1 as N,convertElement as a,convert$1 as c,visit as v}; -//# sourceMappingURL=NotificationsApp-CRRsckwj.chunk.mjs.map + `;return[{ncActionComponent:NcActionText,ncActionComponentProps:{},iconSvg:this.userStatus.icon?c:void 0,text:`${this.userStatus.message}`}].concat(n)}return n}},watch:{url(){this.userDoesNotExist=!1,this.loadAvatarUrl()},user(){this.userDoesNotExist=!1,this.isMenuLoaded=!1,this.loadAvatarUrl()}},mounted(){this.loadAvatarUrl(),subscribe("settings:avatar:updated",this.loadAvatarUrl),subscribe("settings:display-name:updated",this.loadAvatarUrl),!this.hideStatus&&this.user&&!this.isNoUser&&(this.preloadedUserStatus?(this.userStatus.status=this.preloadedUserStatus.status||"",this.userStatus.message=this.preloadedUserStatus.message||"",this.userStatus.icon=this.preloadedUserStatus.icon||"",this.hasStatus=this.preloadedUserStatus.status!==null):this.fetchUserStatus(this.user),subscribe("user_status:status.updated",this.handleUserStatusUpdated))},beforeUnmount(){unsubscribe("settings:avatar:updated",this.loadAvatarUrl),unsubscribe("settings:display-name:updated",this.loadAvatarUrl),unsubscribe("user_status:status.updated",this.handleUserStatusUpdated)},methods:{t,handleUserStatusUpdated(n){this.user===n.userId&&(this.userStatus={status:n.status,icon:n.icon,message:n.message},this.hasStatus=n.status!==null)},async toggleMenu(n){n.type==="keydown"&&n.key!=="Enter"||(this.contactsMenuOpenState||await this.fetchContactsMenu(),this.contactsMenuOpenState=!this.contactsMenuOpenState)},closeMenu(){this.contactsMenuOpenState=!1},async fetchContactsMenu(){this.contactsMenuLoading=!0;try{const n=encodeURIComponent(this.user),{data:p}=await cancelableClient.post(_("contactsmenu/findOne"),`shareType=0&shareWith=${n}`);this.contactsMenuData=p,this.contactsMenuActions=p.topAction?[p.topAction].concat(p.actions):p.actions}catch{this.contactsMenuOpenState=!1}this.contactsMenuLoading=!1,this.isMenuLoaded=!0},loadAvatarUrl(){if(this.isAvatarLoaded=!1,!this.isUrlDefined&&(!this.isUserDefined||this.isNoUser||this.iconClass)){this.isAvatarLoaded=!0,this.userDoesNotExist=!0;return}if(this.isUrlDefined){this.updateImageIfValid(this.url);return}if(this.size<=64){const n=this.avatarUrlGenerator(this.user,64),p=[n+" 1x",this.avatarUrlGenerator(this.user,512)+" 8x"].join(", ");this.updateImageIfValid(n,p)}else{const n=this.avatarUrlGenerator(this.user,512);this.updateImageIfValid(n)}},avatarUrlGenerator(n,p){let c=getAvatarUrl(n,{size:p,isDarkTheme:this.isDarkTheme,isGuest:this.isGuest});return n===getCurrentUser()?.uid&&typeof oc_userconfig<"u"&&(c+="?v="+window.oc_userconfig.avatar.version),c},updateImageIfValid(n,p=null){const c=getUserHasAvatar(this.user);if(this.isUserDefined&&typeof c=="boolean"){this.isAvatarLoaded=!0,this.avatarUrlLoaded=n,p&&(this.avatarSrcSetLoaded=p),c===!1&&(this.userDoesNotExist=!0);return}const l=new Image;l.onload=()=>{this.avatarUrlLoaded=n,p&&(this.avatarSrcSetLoaded=p),this.isAvatarLoaded=!0,setUserHasAvatar(this.user,!0)},l.onerror=()=>{logger$1.debug("[NcAvatar] Invalid avatar url",{url:n}),this.avatarUrlLoaded=null,this.avatarSrcSetLoaded=null,this.userDoesNotExist=!0,this.isAvatarLoaded=!1,setUserHasAvatar(this.user,!1)},p&&(l.srcset=p),l.src=n}}},_hoisted_1$4=["title"],_hoisted_2$4=["src","srcset"],_hoisted_3$2={key:2,class:"avatardiv__user-status avatardiv__user-status--icon"};function _sfc_render$4(n,p,c,l,x,o){const E=resolveComponent("NcLoadingIcon"),A=resolveComponent("IconDotsHorizontal"),B=resolveComponent("NcButton"),b=resolveComponent("NcIconSvgWrapper"),R=resolveComponent("NcActions"),g=resolveComponent("NcUserStatusIcon"),S=resolveDirective("click-outside");return withDirectives((openBlock(),createElementBlock("span",{class:normalizeClass(["avatardiv popovermenu-wrapper",{"avatardiv--unknown":x.userDoesNotExist,"avatardiv--with-menu":o.hasMenu,"avatardiv--with-menu-loading":x.contactsMenuLoading}]),style:normalizeStyle(o.avatarStyle),title:o.tooltip},[renderSlot(n.$slots,"icon",{},()=>[c.iconClass?(openBlock(),createElementBlock("span",{key:0,class:normalizeClass([c.iconClass,"avatar-class-icon"])},null,2)):x.isAvatarLoaded&&!x.userDoesNotExist?(openBlock(),createElementBlock("img",{key:1,src:x.avatarUrlLoaded,srcset:x.avatarSrcSetLoaded,alt:""},null,8,_hoisted_2$4)):createCommentVNode("",!0)],!0),o.hasMenu&&o.menu.length===0?(openBlock(),createBlock(B,{key:0,"aria-label":o.avatarAriaLabel,class:"action-item action-item__menutoggle",variant:"tertiary-no-background",onClick:o.toggleMenu},{icon:withCtx(()=>[x.contactsMenuLoading?(openBlock(),createBlock(E,{key:0})):(openBlock(),createBlock(A,{key:1,size:20}))]),_:1},8,["aria-label","onClick"])):o.hasMenu?(openBlock(),createBlock(R,{key:1,open:x.contactsMenuOpenState,"onUpdate:open":p[0]||(p[0]=q=>x.contactsMenuOpenState=q),"aria-label":o.avatarAriaLabel,container:c.menuContainer,"force-menu":"","manual-open":"",variant:"tertiary-no-background",onClick:o.toggleMenu},createSlots({default:withCtx(()=>[(openBlock(!0),createElementBlock(Fragment,null,renderList(o.menu,(q,$)=>(openBlock(),createBlock(resolveDynamicComponent(q.ncActionComponent),mergeProps({key:$},{ref_for:!0},q.ncActionComponentProps),createSlots({default:withCtx(()=>[createTextVNode(" "+toDisplayString(q.text),1)]),_:2},[q.iconSvg?{name:"icon",fn:withCtx(()=>[createVNode(b,{svg:q.iconSvg},null,8,["svg"])]),key:"0"}:void 0]),1040))),128))]),_:2},[x.contactsMenuLoading?{name:"icon",fn:withCtx(()=>[createVNode(E)]),key:"0"}:void 0]),1032,["open","aria-label","container","onClick"])):createCommentVNode("",!0),o.showUserStatusIconOnAvatar?(openBlock(),createElementBlock("span",_hoisted_3$2,toDisplayString(n.userStatus.icon),1)):o.canDisplayUserStatus?(openBlock(),createBlock(g,{key:3,class:"avatardiv__user-status",status:n.userStatus.status,"aria-hidden":String(o.hasMenu)},null,8,["status","aria-hidden"])):createCommentVNode("",!0),o.showInitials?(openBlock(),createElementBlock("span",{key:4,style:normalizeStyle(o.initialsWrapperStyle),class:"avatardiv__initials-wrapper"},[createBaseVNode("span",{style:normalizeStyle(o.initialsStyle),class:"avatardiv__initials"},toDisplayString(o.initials),5)],4)):createCommentVNode("",!0)],14,_hoisted_1$4)),[[S,o.closeMenu]])}const NcAvatar=_export_sfc(_sfc_main$4,[["render",_sfc_render$4],["__scopeId","data-v-a32502f1"]]),_sfc_main$1$1={};function _sfc_render$3(n,p){return openBlock(),createElementBlock("div",null,[renderSlot(n.$slots,"trigger")])}const NcUserBubbleDiv=_export_sfc(_sfc_main$1$1,[["render",_sfc_render$3]]),_hoisted_1$3={class:"user-bubble__name"},_hoisted_2$3={key:0,class:"user-bubble__secondary"},_sfc_main$3=defineComponent({__name:"NcUserBubble",props:mergeModels({avatarImage:{default:void 0},user:{default:void 0},displayName:{default:void 0},showUserStatus:{type:Boolean},url:{default:void 0},to:{default:void 0},primary:{type:Boolean},size:{default:20},margin:{default:2}},{open:{type:Boolean},openModifiers:{}}),emits:mergeModels(["click"],["update:open"]),setup(n,{emit:p}){const c=useModel(n,"open"),l=n,x=p,o=computed(()=>{if(!l.avatarImage)return!1;try{return!!new URL(l.avatarImage)}catch{return!1}}),E=computed(()=>!!l.avatarImage),A=computed(()=>({marginInlineStart:`${l.margin}px`})),B=computed(()=>{if(!l.url||l.url.trim()==="")return!1;try{return!!new URL(l.url,l.url?.startsWith?.("/")?window.location.href:void 0)}catch{return warn("[NcUserBubble] Invalid URL passed",{url:l.url}),!1}}),b=computed(()=>B.value?l.url:void 0),R=computed(()=>B.value?"a":l.to?RouterLink:"div"),g=computed(()=>({height:`${l.size}px`,lineHeight:`${l.size}px`,borderRadius:`${l.size/2}px`}));return watch([()=>l.displayName,()=>l.user],()=>{!l.displayName&&l.user}),(S,q)=>(openBlock(),createBlock(resolveDynamicComponent(S.$slots.default?unref(NcPopover):NcUserBubbleDiv),{shown:c.value,"onUpdate:shown":q[1]||(q[1]=$=>c.value=$),class:"user-bubble__wrapper",trigger:"hover focus"},{trigger:withCtx(({attrs:$})=>[(openBlock(),createBlock(resolveDynamicComponent(R.value),mergeProps({class:["user-bubble__content",{"user-bubble__content--primary":S.primary}],style:g.value,to:S.to,href:b.value},$,{onClick:q[0]||(q[0]=I=>x("click",I))}),{default:withCtx(()=>[createVNode(unref(NcAvatar),{url:E.value&&o.value?S.avatarImage:void 0,"icon-class":E.value&&!o.value?S.avatarImage:void 0,user:S.user,"display-name":S.displayName,size:S.size-S.margin*2,style:normalizeStyle(A.value),"disable-tooltip":!0,"disable-menu":!0,"hide-status":!S.showUserStatus,class:"user-bubble__avatar"},null,8,["url","icon-class","user","display-name","size","style","hide-status"]),createBaseVNode("span",_hoisted_1$3,toDisplayString(S.displayName||S.user),1),S.$slots.name?(openBlock(),createElementBlock("span",_hoisted_2$3,[renderSlot(S.$slots,"name",{},void 0,!0)])):createCommentVNode("",!0)]),_:2},1040,["class","style","to","href"]))]),default:withCtx(()=>[renderSlot(S.$slots,"default",{},void 0,!0)]),_:3},40,["shown"]))}}),NcUserBubble=_export_sfc(_sfc_main$3,[["__scopeId","data-v-37bde6b7"]]),_sfc_main$2={name:"UserParameter",components:{NcUserBubble},props:{type:{type:String,required:!0},id:{type:String,required:!0},name:{type:String,required:!0},server:{type:String,default:""}},computed:{cloudId(){return this.server?this.id+"@"+this.server:""}}},_hoisted_1$2={class:"mention"},_hoisted_2$2=["title"];function _sfc_render$2(n,p,c,l,x,o){const E=resolveComponent("NcUserBubble");return openBlock(),createElementBlock("div",_hoisted_1$2,[o.cloudId?(openBlock(),createElementBlock("strong",{key:1,title:o.cloudId},toDisplayString(c.name),9,_hoisted_2$2)):(openBlock(),createBlock(E,{key:0,"display-name":c.name,user:c.id},null,8,["display-name","user"]))])}const UserParameter=_export_sfc$1(_sfc_main$2,[["render",_sfc_render$2],["__scopeId","data-v-85edf4b2"]]),_sfc_main$1={name:"NotificationItem",components:{ActionButton:_sfc_main$c,NcButton,NcDateTime:_sfc_main$e,IconClose,IconMessageOutline,NcRichText},props:{notification:{type:Object,required:!0}},emits:["remove"],data(){return{showFullMessage:!1}},computed:{timestamp(){return this.notification.datetime==="warning"?0:new Date(this.notification.datetime).valueOf()},useLink(){if(!this.notification.link)return!1;let n=!1;return Object.keys(Object(this.notification.subjectRichParameters)).forEach(p=>{Object(this.notification.subjectRichParameters)[p].link&&(n=!0)}),!n},preparedSubjectParameters(){return this.prepareParameters(this.notification.subjectRichParameters)},preparedMessageParameters(){return this.prepareParameters(this.notification.messageRichParameters)},isCollapsedMessage(){return this.notification.message.length>200&&!this.showFullMessage}},methods:{t:translate,prepareParameters(n={}){const p={};return Object.keys(n).forEach(c=>{const l=n[c].type;l==="user"?p[c]={component:UserParameter,props:n[c]}:l==="file"?p[c]={component:FileParameter,props:n[c]}:p[c]={component:DefaultParameter,props:n[c]}}),p},onClickMessage(n){n.target.closest(".rich-text--wrapper")?this.showFullMessage=!this.showFullMessage:!this.notification.messageRich&&this.notification.message&&(this.showFullMessage=!this.showFullMessage)},async onClickAction({event:n,action:p}){try{const c={cancelAction:!1,notification:this.notification,action:p};if(await emit("notifications:action:execute",c),p.type==="WEB"){c.cancelAction&&n.preventDefault();return}if(c.cancelAction)return;await cancelableClient({method:p.type,url:p.url}),this.$emit("remove"),emit("notifications:action:executed",n)}catch(c){console.error("Failed to perform action",c),showError(translate("notifications","Failed to perform action"))}},onDismissNotification(){cancelableClient.delete(v("apps/notifications/api/v2/notifications/{id}",{id:this.notification.notificationId})).then(()=>{this.$emit("remove")}).catch(()=>{showError(translate("notifications","Failed to dismiss notification"))})}}},_hoisted_1$1=["data-id","data-timestamp","data-object-type","data-app"],_hoisted_2$1={class:"notification-heading"},_hoisted_3$1=["href"],_hoisted_4={key:0,class:"image"},_hoisted_5=["src"],_hoisted_6={class:"subject"},_hoisted_7=["href"],_hoisted_8={key:0,class:"image"},_hoisted_9=["src"],_hoisted_10={key:2,class:"subject"},_hoisted_11={key:2,class:"notification-subject"},_hoisted_12={key:0,class:"image"},_hoisted_13=["src"],_hoisted_14={key:2,class:"subject"},_hoisted_15={key:1},_hoisted_16={key:0,class:"notification-overflow"},_hoisted_17={key:4,class:"notification-actions"},_hoisted_18={key:5,class:"notification-actions"};function _sfc_render$1(n,p,c,l,x,o){const E=resolveComponent("NcDateTime"),A=resolveComponent("IconClose"),B=resolveComponent("NcButton"),b=resolveComponent("NcRichText"),R=resolveComponent("ActionButton"),g=resolveComponent("IconMessageOutline");return openBlock(),createElementBlock("li",{class:"notification","data-id":c.notification.notificationId,"data-timestamp":o.timestamp,"data-object-type":c.notification.objectType,"data-app":c.notification.app},[createBaseVNode("div",_hoisted_2$1,[o.timestamp?(openBlock(),createBlock(E,{key:0,class:"notification-time","ignore-seconds":"",format:{timeStyle:"short",dateStyle:"long"},timestamp:o.timestamp},null,8,["timestamp"])):createCommentVNode("",!0),o.timestamp?(openBlock(),createBlock(B,{key:1,class:"notification-dismiss-button",variant:"tertiary","aria-label":o.t("notifications","Dismiss"),onClick:o.onDismissNotification},{icon:withCtx(()=>[createVNode(A,{size:20})]),_:1},8,["aria-label","onClick"])):createCommentVNode("",!0)]),c.notification.externalLink?(openBlock(),createElementBlock("a",{key:0,href:c.notification.externalLink,class:"notification-subject full-subject-link external",target:"_blank",rel:"noreferrer noopener"},[c.notification.icon?(openBlock(),createElementBlock("span",_hoisted_4,[createBaseVNode("img",{src:c.notification.icon,class:"notification-icon",alt:""},null,8,_hoisted_5)])):createCommentVNode("",!0),createBaseVNode("span",_hoisted_6,toDisplayString(c.notification.subject)+" ↗",1)],8,_hoisted_3$1)):o.useLink?(openBlock(),createElementBlock("a",{key:1,href:c.notification.link,class:"notification-subject full-subject-link"},[c.notification.icon?(openBlock(),createElementBlock("span",_hoisted_8,[createBaseVNode("img",{src:c.notification.icon,class:"notification-icon",alt:""},null,8,_hoisted_9)])):createCommentVNode("",!0),c.notification.subjectRich?(openBlock(),createBlock(b,{key:1,text:c.notification.subjectRich,arguments:o.preparedSubjectParameters},null,8,["text","arguments"])):(openBlock(),createElementBlock("span",_hoisted_10,toDisplayString(c.notification.subject),1))],8,_hoisted_7)):(openBlock(),createElementBlock("div",_hoisted_11,[c.notification.icon?(openBlock(),createElementBlock("span",_hoisted_12,[createBaseVNode("img",{src:c.notification.icon,class:"notification-icon",alt:""},null,8,_hoisted_13)])):createCommentVNode("",!0),c.notification.subjectRich?(openBlock(),createBlock(b,{key:1,text:c.notification.subjectRich,arguments:o.preparedSubjectParameters},null,8,["text","arguments"])):(openBlock(),createElementBlock("span",_hoisted_14,toDisplayString(c.notification.subject),1))])),c.notification.message?(openBlock(),createElementBlock("div",{key:3,class:"notification-message",onClick:p[0]||(p[0]=(...S)=>o.onClickMessage&&o.onClickMessage(...S))},[createBaseVNode("div",{class:normalizeClass(["message-container",{collapsed:o.isCollapsedMessage}])},[c.notification.messageRich?(openBlock(),createBlock(b,{key:0,text:c.notification.messageRich,arguments:o.preparedMessageParameters,autolink:!0},null,8,["text","arguments"])):(openBlock(),createElementBlock("span",_hoisted_15,toDisplayString(c.notification.message),1))],2),o.isCollapsedMessage?(openBlock(),createElementBlock("div",_hoisted_16)):createCommentVNode("",!0)])):createCommentVNode("",!0),c.notification.actions.length?(openBlock(),createElementBlock("div",_hoisted_17,[(openBlock(!0),createElementBlock(Fragment,null,renderList(c.notification.actions,(S,q)=>(openBlock(),createBlock(R,{key:q,action:S,onClick:o.onClickAction,onRemove:p[1]||(p[1]=$=>n.$emit("remove"))},null,8,["action","onClick"]))),128))])):c.notification.externalLink?(openBlock(),createElementBlock("div",_hoisted_18,[createVNode(B,{variant:"primary",href:"https://nextcloud.com/fairusepolicy",class:"action-button pull-right",target:"_blank",rel:"noreferrer noopener"},{icon:withCtx(()=>[createVNode(g,{size:20})]),default:withCtx(()=>[createTextVNode(" "+toDisplayString(o.t("notifications","Contact Nextcloud GmbH"))+" ↗ ",1)]),_:1})])):createCommentVNode("",!0)],8,_hoisted_1$1)}const NotificationItem=_export_sfc$1(_sfc_main$1,[["render",_sfc_render$1],["__scopeId","data-v-58882784"]]);async function getNotificationsData(n,p,c,l){const x=parseInt(BrowserStorage.getItem("lastUpdated"),10),o=BrowserStorage.getItem("tabId"),E=Math.floor(Date.now()/1e3);return(c||o===n&&x+25=0&&g<=1){if(S._volume=g,S._muted)return S;S.usingWebAudio&&S.masterGain.gain.setValueAtTime(g,c.ctx.currentTime);for(var q=0;q=0;S--)g._howls[S].unload();return g.usingWebAudio&&g.ctx&&typeof g.ctx.close<"u"&&(g.ctx.close(),g.ctx=null,R()),g},codecs:function(g){return(this||c)._codecs[g.replace(/^x-/,"")]},_setup:function(){var g=this||c;if(g.state=g.ctx&&g.ctx.state||"suspended",g._autoSuspend(),!g.usingWebAudio)if(typeof Audio<"u")try{var S=new Audio;typeof S.oncanplaythrough>"u"&&(g._canPlayEvent="canplay")}catch{g.noAudio=!0}else g.noAudio=!0;try{var S=new Audio;S.muted&&(g.noAudio=!0)}catch{}return g.noAudio||g._setupCodecs(),g},_setupCodecs:function(){var g=this||c,S=null;try{S=typeof Audio<"u"?new Audio:null}catch{return g}if(!S||typeof S.canPlayType!="function")return g;var q=S.canPlayType("audio/mpeg;").replace(/^no$/,""),$=g._navigator?g._navigator.userAgent:"",I=$.match(/OPR\/(\d+)/g),P=I&&parseInt(I[0].split("/")[1],10)<33,O=$.indexOf("Safari")!==-1&&$.indexOf("Chrome")===-1,L=$.match(/Version\/(.*?) /),F=O&&L&&parseInt(L[1],10)<15;return g._codecs={mp3:!!(!P&&(q||S.canPlayType("audio/mp3;").replace(/^no$/,""))),mpeg:!!q,opus:!!S.canPlayType('audio/ogg; codecs="opus"').replace(/^no$/,""),ogg:!!S.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,""),oga:!!S.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,""),wav:!!(S.canPlayType('audio/wav; codecs="1"')||S.canPlayType("audio/wav")).replace(/^no$/,""),aac:!!S.canPlayType("audio/aac;").replace(/^no$/,""),caf:!!S.canPlayType("audio/x-caf;").replace(/^no$/,""),m4a:!!(S.canPlayType("audio/x-m4a;")||S.canPlayType("audio/m4a;")||S.canPlayType("audio/aac;")).replace(/^no$/,""),m4b:!!(S.canPlayType("audio/x-m4b;")||S.canPlayType("audio/m4b;")||S.canPlayType("audio/aac;")).replace(/^no$/,""),mp4:!!(S.canPlayType("audio/x-mp4;")||S.canPlayType("audio/mp4;")||S.canPlayType("audio/aac;")).replace(/^no$/,""),weba:!!(!F&&S.canPlayType('audio/webm; codecs="vorbis"').replace(/^no$/,"")),webm:!!(!F&&S.canPlayType('audio/webm; codecs="vorbis"').replace(/^no$/,"")),dolby:!!S.canPlayType('audio/mp4; codecs="ec-3"').replace(/^no$/,""),flac:!!(S.canPlayType("audio/x-flac;")||S.canPlayType("audio/flac;")).replace(/^no$/,"")},g},_unlockAudio:function(){var g=this||c;if(!(g._audioUnlocked||!g.ctx)){g._audioUnlocked=!1,g.autoUnlock=!1,!g._mobileUnloaded&&g.ctx.sampleRate!==44100&&(g._mobileUnloaded=!0,g.unload()),g._scratchBuffer=g.ctx.createBuffer(1,1,22050);var S=function(q){for(;g._html5AudioPool.length"u"?F.noteOn(0):F.start(0),typeof g.ctx.resume=="function"&&g.ctx.resume(),F.onended=function(){F.disconnect(0),g._audioUnlocked=!0,document.removeEventListener("touchstart",S,!0),document.removeEventListener("touchend",S,!0),document.removeEventListener("click",S,!0),document.removeEventListener("keydown",S,!0);for(var U=0;U"u"||!c.usingWebAudio)){for(var S=0;S"u"||!c.usingWebAudio))return g.state==="running"&&g.ctx.state!=="interrupted"&&g._suspendTimer?(clearTimeout(g._suspendTimer),g._suspendTimer=null):g.state==="suspended"||g.state==="running"&&g.ctx.state==="interrupted"?(g.ctx.resume().then(function(){g.state="running";for(var S=0;S"u"&&(g="__default",!q._playLock)){for(var I=0,P=0;P0?O._seek:q._sprite[g][0]/1e3),U=Math.max(0,(q._sprite[g][0]+q._sprite[g][1])/1e3-F),Q=U*1e3/Math.abs(O._rate),Y=q._sprite[g][0]/1e3,ce=(q._sprite[g][0]+q._sprite[g][1])/1e3;O._sprite=g,O._ended=!1;var le=function(){O._paused=!1,O._seek=F,O._start=Y,O._stop=ce,O._loop=!!(O._loop||q._sprite[g][2])};if(F>=ce){q._ended(O);return}var ne=O._node;if(q._webAudio){var he=function(){q._playLock=!1,le(),q._refreshBuffer(O);var m=O._muted||q._muted?0:O._volume;ne.gain.setValueAtTime(m,c.ctx.currentTime),O._playStart=c.ctx.currentTime,typeof ne.bufferSource.start>"u"?O._loop?ne.bufferSource.noteGrainOn(0,F,86400):ne.bufferSource.noteGrainOn(0,F,U):O._loop?ne.bufferSource.start(0,F,86400):ne.bufferSource.start(0,F,U),Q!==1/0&&(q._endTimers[O._id]=setTimeout(q._ended.bind(q,O),Q)),S||setTimeout(function(){q._emit("play",O._id),q._loadQueue()},0)};c.state==="running"&&c.ctx.state!=="interrupted"?he():(q._playLock=!0,q.once("resume",he),q._clearTimer(O._id))}else{var r=function(){ne.currentTime=F,ne.muted=O._muted||q._muted||c._muted||ne.muted,ne.volume=O._volume*c.volume(),ne.playbackRate=O._rate;try{var m=ne.play();if(m&&typeof Promise<"u"&&(m instanceof Promise||typeof m.then=="function")?(q._playLock=!0,le(),m.then(function(){q._playLock=!1,ne._unlocked=!0,S?q._loadQueue():q._emit("play",O._id)}).catch(function(){q._playLock=!1,q._emit("playerror",O._id,"Playback was unable to start. This is most commonly an issue on mobile devices and Chrome where playback was not within a user interaction."),O._ended=!0,O._paused=!0})):S||(q._playLock=!1,le(),q._emit("play",O._id)),ne.playbackRate=O._rate,ne.paused){q._emit("playerror",O._id,"Playback was unable to start. This is most commonly an issue on mobile devices and Chrome where playback was not within a user interaction.");return}g!=="__default"||O._loop?q._endTimers[O._id]=setTimeout(q._ended.bind(q,O),Q):(q._endTimers[O._id]=function(){q._ended(O),ne.removeEventListener("ended",q._endTimers[O._id],!1)},ne.addEventListener("ended",q._endTimers[O._id],!1))}catch(k){q._emit("playerror",O._id,k)}};ne.src==="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA"&&(ne.src=q._src,ne.load());var a=window&&window.ejecta||!ne.readyState&&c._navigator.isCocoonJS;if(ne.readyState>=3||a)r();else{q._playLock=!0,q._state="loading";var s=function(){q._state="loaded",r(),ne.removeEventListener(c._canPlayEvent,s,!1)};ne.addEventListener(c._canPlayEvent,s,!1),q._clearTimer(O._id)}}return O._id},pause:function(g){var S=this;if(S._state!=="loaded"||S._playLock)return S._queue.push({event:"pause",action:function(){S.pause(g)}}),S;for(var q=S._getSoundIds(g),$=0;$"u"?I._node.bufferSource.noteOff(0):I._node.bufferSource.stop(0),S._cleanBuffer(I._node)}else(!isNaN(I._node.duration)||I._node.duration===1/0)&&I._node.pause();arguments[1]||S._emit("pause",I?I._id:null)}return S},stop:function(g,S){var q=this;if(q._state!=="loaded"||q._playLock)return q._queue.push({event:"stop",action:function(){q.stop(g)}}),q;for(var $=q._getSoundIds(g),I=0;I<$.length;I++){q._clearTimer($[I]);var P=q._soundById($[I]);P&&(P._seek=P._start||0,P._rateSeek=0,P._paused=!0,P._ended=!0,q._stopFade($[I]),P._node&&(q._webAudio?P._node.bufferSource&&(typeof P._node.bufferSource.stop>"u"?P._node.bufferSource.noteOff(0):P._node.bufferSource.stop(0),q._cleanBuffer(P._node)):(!isNaN(P._node.duration)||P._node.duration===1/0)&&(P._node.currentTime=P._start||0,P._node.pause(),P._node.duration===1/0&&q._clearSound(P._node))),S||q._emit("stop",P._id))}return q},mute:function(g,S){var q=this;if(q._state!=="loaded"||q._playLock)return q._queue.push({event:"mute",action:function(){q.mute(g,S)}}),q;if(typeof S>"u")if(typeof g=="boolean")q._muted=g;else return q._muted;for(var $=q._getSoundIds(S),I=0;I<$.length;I++){var P=q._soundById($[I]);P&&(P._muted=g,P._interval&&q._stopFade(P._id),q._webAudio&&P._node?P._node.gain.setValueAtTime(g?0:P._volume,c.ctx.currentTime):P._node&&(P._node.muted=c._muted?!0:g),q._emit("mute",P._id))}return q},volume:function(){var g=this,S=arguments,q,$;if(S.length===0)return g._volume;if(S.length===1||S.length===2&&typeof S[1]>"u"){var I=g._getSoundIds(),P=I.indexOf(S[0]);P>=0?$=parseInt(S[0],10):q=parseFloat(S[0])}else S.length>=2&&(q=parseFloat(S[0]),$=parseInt(S[1],10));var O;if(typeof q<"u"&&q>=0&&q<=1){if(g._state!=="loaded"||g._playLock)return g._queue.push({event:"volume",action:function(){g.volume.apply(g,S)}}),g;typeof $>"u"&&(g._volume=q),$=g._getSoundIds($);for(var L=0;L<$.length;L++)O=g._soundById($[L]),O&&(O._volume=q,S[2]||g._stopFade($[L]),g._webAudio&&O._node&&!O._muted?O._node.gain.setValueAtTime(q,c.ctx.currentTime):O._node&&!O._muted&&(O._node.volume=q*c.volume()),g._emit("volume",O._id))}else return O=$?g._soundById($):g._sounds[0],O?O._volume:0;return g},fade:function(g,S,q,$){var I=this;if(I._state!=="loaded"||I._playLock)return I._queue.push({event:"fade",action:function(){I.fade(g,S,q,$)}}),I;g=Math.min(Math.max(0,parseFloat(g)),1),S=Math.min(Math.max(0,parseFloat(S)),1),q=parseFloat(q),I.volume(g,$);for(var P=I._getSoundIds($),O=0;O"u")}}return I},_startFadeInterval:function(g,S,q,$,I,P){var O=this,L=S,F=q-S,U=Math.abs(F/.01),Q=Math.max(4,U>0?$/U:$),Y=Date.now();g._fadeTo=q,g._interval=setInterval(function(){var ce=(Date.now()-Y)/$;Y=Date.now(),L+=F*ce,L=Math.round(L*100)/100,F<0?L=Math.max(q,L):L=Math.min(q,L),O._webAudio?g._volume=L:O.volume(L,g._id,!0),P&&(O._volume=L),(qS&&L>=q)&&(clearInterval(g._interval),g._interval=null,g._fadeTo=null,O.volume(q,g._id),O._emit("fade",g._id))},Q)},_stopFade:function(g){var S=this,q=S._soundById(g);return q&&q._interval&&(S._webAudio&&q._node.gain.cancelScheduledValues(c.ctx.currentTime),clearInterval(q._interval),q._interval=null,S.volume(q._fadeTo,g),q._fadeTo=null,S._emit("fade",g)),S},loop:function(){var g=this,S=arguments,q,$,I;if(S.length===0)return g._loop;if(S.length===1)if(typeof S[0]=="boolean")q=S[0],g._loop=q;else return I=g._soundById(parseInt(S[0],10)),I?I._loop:!1;else S.length===2&&(q=S[0],$=parseInt(S[1],10));for(var P=g._getSoundIds($),O=0;O=0?$=parseInt(S[0],10):q=parseFloat(S[0])}else S.length===2&&(q=parseFloat(S[0]),$=parseInt(S[1],10));var O;if(typeof q=="number"){if(g._state!=="loaded"||g._playLock)return g._queue.push({event:"rate",action:function(){g.rate.apply(g,S)}}),g;typeof $>"u"&&(g._rate=q),$=g._getSoundIds($);for(var L=0;L<$.length;L++)if(O=g._soundById($[L]),O){g.playing($[L])&&(O._rateSeek=g.seek($[L]),O._playStart=g._webAudio?c.ctx.currentTime:O._playStart),O._rate=q,g._webAudio&&O._node&&O._node.bufferSource?O._node.bufferSource.playbackRate.setValueAtTime(q,c.ctx.currentTime):O._node&&(O._node.playbackRate=q);var F=g.seek($[L]),U=(g._sprite[O._sprite][0]+g._sprite[O._sprite][1])/1e3-F,Q=U*1e3/Math.abs(O._rate);(g._endTimers[$[L]]||!O._paused)&&(g._clearTimer($[L]),g._endTimers[$[L]]=setTimeout(g._ended.bind(g,O),Q)),g._emit("rate",O._id)}}else return O=g._soundById($),O?O._rate:g._rate;return g},seek:function(){var g=this,S=arguments,q,$;if(S.length===0)g._sounds.length&&($=g._sounds[0]._id);else if(S.length===1){var I=g._getSoundIds(),P=I.indexOf(S[0]);P>=0?$=parseInt(S[0],10):g._sounds.length&&($=g._sounds[0]._id,q=parseFloat(S[0]))}else S.length===2&&(q=parseFloat(S[0]),$=parseInt(S[1],10));if(typeof $>"u")return 0;if(typeof q=="number"&&(g._state!=="loaded"||g._playLock))return g._queue.push({event:"seek",action:function(){g.seek.apply(g,S)}}),g;var O=g._soundById($);if(O)if(typeof q=="number"&&q>=0){var L=g.playing($);L&&g.pause($,!0),O._seek=q,O._ended=!1,g._clearTimer($),!g._webAudio&&O._node&&!isNaN(O._node.duration)&&(O._node.currentTime=q);var F=function(){L&&g.play($,!0),g._emit("seek",$)};if(L&&!g._webAudio){var U=function(){g._playLock?setTimeout(U,0):F()};setTimeout(U,0)}else F()}else if(g._webAudio){var Q=g.playing($)?c.ctx.currentTime-O._playStart:0,Y=O._rateSeek?O._rateSeek-O._seek:0;return O._seek+(Y+Q*Math.abs(O._rate))}else return O._node.currentTime;return g},playing:function(g){var S=this;if(typeof g=="number"){var q=S._soundById(g);return q?!q._paused:!1}for(var $=0;$=0&&c._howls.splice($,1);var I=!0;for(q=0;q=0){I=!1;break}return o&&I&&delete o[g._src],c.noAudio=!1,g._state="unloaded",g._sounds=[],g=null,null},on:function(g,S,q,$){var I=this,P=I["_on"+g];return typeof S=="function"&&P.push($?{id:q,fn:S,once:$}:{id:q,fn:S}),I},off:function(g,S,q){var $=this,I=$["_on"+g],P=0;if(typeof S=="number"&&(q=S,S=null),S||q)for(P=0;P=0;P--)(!I[P].id||I[P].id===S||g==="load")&&(setTimeout(function(O){O.call(this,S,q)}.bind($,I[P].fn),0),I[P].once&&$.off(g,I[P].fn,I[P].id));return $._loadQueue(g),$},_loadQueue:function(g){var S=this;if(S._queue.length>0){var q=S._queue[0];q.event===g&&(S._queue.shift(),S._loadQueue()),g||q.action()}return S},_ended:function(g){var S=this,q=g._sprite;if(!S._webAudio&&g._node&&!g._node.paused&&!g._node.ended&&g._node.currentTime=0;$--){if(q<=S)return;g._sounds[$]._ended&&(g._webAudio&&g._sounds[$]._node&&g._sounds[$]._node.disconnect(0),g._sounds.splice($,1),q--)}}},_getSoundIds:function(g){var S=this;if(typeof g>"u"){for(var q=[],$=0;$=0;if(!g.bufferSource)return S;if(c._scratchBuffer&&g.bufferSource&&(g.bufferSource.onended=null,g.bufferSource.disconnect(0),q))try{g.bufferSource.buffer=c._scratchBuffer}catch{}return g.bufferSource=null,S},_clearSound:function(g){var S=/MSIE |Trident\//.test(c._navigator&&c._navigator.userAgent);S||(g.src="data:audio/wav;base64,UklGRigAAABXQVZFZm10IBIAAAABAAEARKwAAIhYAQACABAAAABkYXRhAgAAAAEA")}};var x=function(g){this._parent=g,this.init()};x.prototype={init:function(){var g=this,S=g._parent;return g._muted=S._muted,g._loop=S._loop,g._volume=S._volume,g._rate=S._rate,g._seek=0,g._paused=!0,g._ended=!0,g._sprite="__default",g._id=++c._counter,S._sounds.push(g),g.create(),g},create:function(){var g=this,S=g._parent,q=c._muted||g._muted||g._parent._muted?0:g._volume;return S._webAudio?(g._node=typeof c.ctx.createGain>"u"?c.ctx.createGainNode():c.ctx.createGain(),g._node.gain.setValueAtTime(q,c.ctx.currentTime),g._node.paused=!0,g._node.connect(c.masterGain)):c.noAudio||(g._node=c._obtainHtml5Audio(),g._errorFn=g._errorListener.bind(g),g._node.addEventListener("error",g._errorFn,!1),g._loadFn=g._loadListener.bind(g),g._node.addEventListener(c._canPlayEvent,g._loadFn,!1),g._endFn=g._endListener.bind(g),g._node.addEventListener("ended",g._endFn,!1),g._node.src=S._src,g._node.preload=S._preload===!0?"auto":S._preload,g._node.volume=q*c.volume(),g._node.load()),g},reset:function(){var g=this,S=g._parent;return g._muted=S._muted,g._loop=S._loop,g._volume=S._volume,g._rate=S._rate,g._seek=0,g._rateSeek=0,g._paused=!0,g._ended=!0,g._sprite="__default",g._id=++c._counter,g},_errorListener:function(){var g=this;g._parent._emit("loaderror",g._id,g._node.error?g._node.error.code:0),g._node.removeEventListener("error",g._errorFn,!1)},_loadListener:function(){var g=this,S=g._parent;S._duration=Math.ceil(g._node.duration*10)/10,Object.keys(S._sprite).length===0&&(S._sprite={__default:[0,S._duration*1e3]}),S._state!=="loaded"&&(S._state="loaded",S._emit("load"),S._loadQueue()),g._node.removeEventListener(c._canPlayEvent,g._loadFn,!1)},_endListener:function(){var g=this,S=g._parent;S._duration===1/0&&(S._duration=Math.ceil(g._node.duration*10)/10,S._sprite.__default[1]===1/0&&(S._sprite.__default[1]=S._duration*1e3),S._ended(g)),g._node.removeEventListener("ended",g._endFn,!1)}};var o={},E=function(g){var S=g._src;if(o[S]){g._duration=o[S].duration,b(g);return}if(/^data:[^;]+;base64,/.test(S)){for(var q=atob(S.split(",")[1]),$=new Uint8Array(q.length),I=0;I0?(o[S._src]=I,b(S,I)):q()};typeof Promise<"u"&&c.ctx.decodeAudioData.length===1?c.ctx.decodeAudioData(g).then($).catch(q):c.ctx.decodeAudioData(g,$,q)},b=function(g,S){S&&!g._duration&&(g._duration=S.duration),Object.keys(g._sprite).length===0&&(g._sprite={__default:[0,g._duration*1e3]}),g._state!=="loaded"&&(g._state="loaded",g._emit("load"),g._loadQueue())},R=function(){if(c.usingWebAudio){try{typeof AudioContext<"u"?c.ctx=new AudioContext:typeof webkitAudioContext<"u"?c.ctx=new webkitAudioContext:c.usingWebAudio=!1}catch{c.usingWebAudio=!1}c.ctx||(c.usingWebAudio=!1);var g=/iP(hone|od|ad)/.test(c._navigator&&c._navigator.platform),S=c._navigator&&c._navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/),q=S?parseInt(S[1],10):null;if(g&&q&&q<9){var $=/safari/.test(c._navigator&&c._navigator.userAgent.toLowerCase());c._navigator&&!$&&(c.usingWebAudio=!1)}c.usingWebAudio&&(c.masterGain=typeof c.ctx.createGain>"u"?c.ctx.createGainNode():c.ctx.createGain(),c.masterGain.gain.setValueAtTime(c._muted?0:c._volume,c.ctx.currentTime),c.masterGain.connect(c.ctx.destination)),c._setup()}};n.Howler=c,n.Howl=l,typeof commonjsGlobal<"u"?(commonjsGlobal.HowlerGlobal=p,commonjsGlobal.Howler=c,commonjsGlobal.Howl=l,commonjsGlobal.Sound=x):typeof window<"u"&&(window.HowlerGlobal=p,window.Howler=c,window.Howl=l,window.Sound=x)})(),function(){HowlerGlobal.prototype._pos=[0,0,0],HowlerGlobal.prototype._orientation=[0,0,-1,0,1,0],HowlerGlobal.prototype.stereo=function(c){var l=this;if(!l.ctx||!l.ctx.listener)return l;for(var x=l._howls.length-1;x>=0;x--)l._howls[x].stereo(c);return l},HowlerGlobal.prototype.pos=function(c,l,x){var o=this;if(!o.ctx||!o.ctx.listener)return o;if(l=typeof l!="number"?o._pos[1]:l,x=typeof x!="number"?o._pos[2]:x,typeof c=="number")o._pos=[c,l,x],typeof o.ctx.listener.positionX<"u"?(o.ctx.listener.positionX.setTargetAtTime(o._pos[0],Howler.ctx.currentTime,.1),o.ctx.listener.positionY.setTargetAtTime(o._pos[1],Howler.ctx.currentTime,.1),o.ctx.listener.positionZ.setTargetAtTime(o._pos[2],Howler.ctx.currentTime,.1)):o.ctx.listener.setPosition(o._pos[0],o._pos[1],o._pos[2]);else return o._pos;return o},HowlerGlobal.prototype.orientation=function(c,l,x,o,E,A){var B=this;if(!B.ctx||!B.ctx.listener)return B;var b=B._orientation;if(l=typeof l!="number"?b[1]:l,x=typeof x!="number"?b[2]:x,o=typeof o!="number"?b[3]:o,E=typeof E!="number"?b[4]:E,A=typeof A!="number"?b[5]:A,typeof c=="number")B._orientation=[c,l,x,o,E,A],typeof B.ctx.listener.forwardX<"u"?(B.ctx.listener.forwardX.setTargetAtTime(c,Howler.ctx.currentTime,.1),B.ctx.listener.forwardY.setTargetAtTime(l,Howler.ctx.currentTime,.1),B.ctx.listener.forwardZ.setTargetAtTime(x,Howler.ctx.currentTime,.1),B.ctx.listener.upX.setTargetAtTime(o,Howler.ctx.currentTime,.1),B.ctx.listener.upY.setTargetAtTime(E,Howler.ctx.currentTime,.1),B.ctx.listener.upZ.setTargetAtTime(A,Howler.ctx.currentTime,.1)):B.ctx.listener.setOrientation(c,l,x,o,E,A);else return b;return B},Howl.prototype.init=function(c){return function(l){var x=this;return x._orientation=l.orientation||[1,0,0],x._stereo=l.stereo||null,x._pos=l.pos||null,x._pannerAttr={coneInnerAngle:typeof l.coneInnerAngle<"u"?l.coneInnerAngle:360,coneOuterAngle:typeof l.coneOuterAngle<"u"?l.coneOuterAngle:360,coneOuterGain:typeof l.coneOuterGain<"u"?l.coneOuterGain:0,distanceModel:typeof l.distanceModel<"u"?l.distanceModel:"inverse",maxDistance:typeof l.maxDistance<"u"?l.maxDistance:1e4,panningModel:typeof l.panningModel<"u"?l.panningModel:"HRTF",refDistance:typeof l.refDistance<"u"?l.refDistance:1,rolloffFactor:typeof l.rolloffFactor<"u"?l.rolloffFactor:1},x._onstereo=l.onstereo?[{fn:l.onstereo}]:[],x._onpos=l.onpos?[{fn:l.onpos}]:[],x._onorientation=l.onorientation?[{fn:l.onorientation}]:[],c.call(this,l)}}(Howl.prototype.init),Howl.prototype.stereo=function(c,l){var x=this;if(!x._webAudio)return x;if(x._state!=="loaded")return x._queue.push({event:"stereo",action:function(){x.stereo(c,l)}}),x;var o=typeof Howler.ctx.createStereoPanner>"u"?"spatial":"stereo";if(typeof l>"u")if(typeof c=="number")x._stereo=c,x._pos=[c,0,0];else return x._stereo;for(var E=x._getSoundIds(l),A=0;A"u")if(typeof c=="number")E._pos=[c,l,x];else return E._pos;for(var A=E._getSoundIds(o),B=0;B"u")if(typeof c=="number")E._orientation=[c,l,x];else return E._orientation;for(var A=E._getSoundIds(o),B=0;B"u"&&(x.pannerAttr||(x.pannerAttr={coneInnerAngle:x.coneInnerAngle,coneOuterAngle:x.coneOuterAngle,coneOuterGain:x.coneOuterGain,distanceModel:x.distanceModel,maxDistance:x.maxDistance,refDistance:x.refDistance,rolloffFactor:x.rolloffFactor,panningModel:x.panningModel}),c._pannerAttr={coneInnerAngle:typeof x.pannerAttr.coneInnerAngle<"u"?x.pannerAttr.coneInnerAngle:c._coneInnerAngle,coneOuterAngle:typeof x.pannerAttr.coneOuterAngle<"u"?x.pannerAttr.coneOuterAngle:c._coneOuterAngle,coneOuterGain:typeof x.pannerAttr.coneOuterGain<"u"?x.pannerAttr.coneOuterGain:c._coneOuterGain,distanceModel:typeof x.pannerAttr.distanceModel<"u"?x.pannerAttr.distanceModel:c._distanceModel,maxDistance:typeof x.pannerAttr.maxDistance<"u"?x.pannerAttr.maxDistance:c._maxDistance,refDistance:typeof x.pannerAttr.refDistance<"u"?x.pannerAttr.refDistance:c._refDistance,rolloffFactor:typeof x.pannerAttr.rolloffFactor<"u"?x.pannerAttr.rolloffFactor:c._rolloffFactor,panningModel:typeof x.pannerAttr.panningModel<"u"?x.pannerAttr.panningModel:c._panningModel});else return E=c._soundById(parseInt(l[0],10)),E?E._pannerAttr:c._pannerAttr;else l.length===2&&(x=l[0],o=parseInt(l[1],10));for(var A=c._getSoundIds(o),B=0;Bconsole.debug("Audio output successfully redirected to secondary speaker")).catch(A=>console.error("Failed to redirect audio output:",A)),E.play()}}}else loadState$1("notifications","sound_notification")&&new howlerExports.Howl({src:[d("notifications","img","notification.ogg")],volume:.5}).play()}const sessionKeepAlive=loadState$1("core","config",{session_keepalive:!0}).session_keepalive,hasThrottledPushNotifications=loadState$1("notifications","throttled_push_notifications"),fairUsePolicyNotification={notificationId:-1,app:"core",user:"",datetime:"warning",objectId:"",objectType:"",subject:translate("notifications","Push notifications might be unreliable"),message:translate("notifications","Nextcloud GmbH sponsors a free push notification gateway for private users. To ensure good service, the gateway limits the number of push notifications per server. For enterprise users, a more scalable gateway is available. Contact Nextcloud GmbH for more information."),link:"https://nextcloud.com/fairusepolicy",actions:[],externalLink:"https://nextcloud.com/fairusepolicy",icon:h$1("core","actions/alert-outline.svg")},_sfc_main={name:"NotificationsApp",components:{IconBellOutline,IconClose,IconMessageOutline,IconNotification:_sfc_main$f,NcButton,NcEmptyContent,NcHeaderMenu,NotificationItem},setup(){return{fairUsePolicyNotification,hasThrottledPushNotifications}},data(){return{webNotificationsGranted:!1,backgroundFetching:!1,hasNotifyPush:!1,shutdown:!1,notifications:[],lastETag:null,lastTabId:null,userStatus:null,tabId:null,webNotificationsThresholdId:0,pollIntervalBase:3e4,pollIntervalCurrent:3e4,interval:null,pushEndpoints:null,open:!1}},computed:{showBrowserNotifications(){return this.backgroundFetching&&this.webNotificationsGranted&&this.userStatus!=="dnd"&&this.tabId===this.lastTabId},emptyContentMessage(){return this.webNotificationsGranted===null?translate("notifications","Requesting browser permissions to show notifications"):this.hasThrottledPushNotifications?this.fairUsePolicyNotification.subject:translate("notifications","No notifications")},emptyContentDescription(){return this.hasThrottledPushNotifications?this.fairUsePolicyNotification.message:""}},mounted(){this.tabId=getRequestToken()||""+Math.random(),this._oldcount=0,this.checkWebNotificationPermissions(),this._fetch(),distExports.listen("notify_notification",()=>{this._fetchAfterNotifyPush()})&&(console.debug("Has notify_push enabled, slowing polling to 15 minutes"),this.pollIntervalBase=15*60*1e3,this.hasNotifyPush=!0),this._setPollingInterval(this.pollIntervalBase),this._watchTabVisibility(),subscribe("networkOffline",this.handleNetworkOffline),subscribe("networkOnline",this.handleNetworkOnline),subscribe("user_status:status.updated",this.userStatusUpdated)},beforeUnmount(){unsubscribe("user_status:status.updated",this.userStatusUpdated),unsubscribe("networkOffline",this.handleNetworkOffline),unsubscribe("networkOnline",this.handleNetworkOnline)},methods:{t:translate,userStatusUpdated(n){getCurrentUser().uid===n.userId&&(this.userStatus=n.status)},onOpen(){this.requestWebNotificationPermissions()},handleNetworkOffline(){console.debug("Network is offline, slowing down pollingInterval to "+this.pollIntervalBase*10),this._setPollingInterval(this.pollIntervalBase*10)},handleNetworkOnline(){this._fetch(),console.debug("Network is online, reseting pollingInterval to "+this.pollIntervalBase),this._setPollingInterval(this.pollIntervalBase)},setupBackgroundFetcher(){sessionKeepAlive?(console.debug("Started background fetcher as session_keepalive is enabled"),this.interval=window.setInterval(this._backgroundFetch.bind(this),this.pollIntervalCurrent)):console.debug("Did not start background fetcher as session_keepalive is off")},onDismissAll(){cancelableClient.delete(v("apps/notifications/api/v2/notifications")).then(()=>{this.notifications=[]}).catch(()=>{showError(translate("notifications","Failed to dismiss all notifications"))})},onRemove(n){this.notifications.splice(n,1)},_updateDocTitleOnNewNotifications(n){n.length>this._oldcount&&(this._oldcount=n.length,this.backgroundFetching&&document.hidden&&(document.title.startsWith("* ")||(document.title="* "+document.title)))},_restoreTitle(){document.title.startsWith("* ")&&(document.title=document.title.substring(2))},_fetchAfterNotifyPush(){this.backgroundFetching=!0,this.hasNotifyPush&&this.tabId!==this.lastTabId?(console.debug("Deferring notification refresh from browser storage are notify_push event to give the last tab the chance to do it"),setTimeout(()=>{this._fetch()},5e3)):(console.debug("Refreshing notifications are notify_push event"),this._fetch())},async _fetch(){this.notifications.length&&this.notifications[0].notificationId>this.webNotificationsThresholdId&&(this.webNotificationsThresholdId=this.notifications[0].notificationId);const n=await getNotificationsData(this.tabId,this.lastETag,!this.backgroundFetching,this.hasNotifyPush);n.status===204?(console.debug("Fetching notifications but no content, slowing down polling to "+this.pollIntervalBase*10),this._setPollingInterval(this.pollIntervalBase*10)):n.status===200?(this.userStatus=n.headers["x-nextcloud-user-status"],this.lastETag=n.headers.etag,this.lastTabId=n.tabId,this.notifications=n.data,this.processWebNotifications(n.data),console.debug("Got notification data, restoring default polling interval."),this._setPollingInterval(this.pollIntervalBase),this._updateDocTitleOnNewNotifications(this.notifications),!this.backgroundFetching&&this.notifications.length&&(this.webNotificationsThresholdId=this.notifications[0].notificationId)):n.status===304?this._setPollingInterval(this.pollIntervalBase):n.status===503?(console.info("Slowing down notifications: instance is in maintenance mode."),this._setPollingInterval(this.pollIntervalBase*10)):n.status===404?(console.info("Slowing down notifications: app is disabled."),this._setPollingInterval(this.pollIntervalBase*10)):(console.info("Slowing down notifications: Status "+n.status),this._setPollingInterval(this.pollIntervalBase*10))},_backgroundFetch(){this.backgroundFetching=!0,this._fetch()},_watchTabVisibility(){document.addEventListener("visibilitychange",this._visibilityChange,!1)},_visibilityChange(){document.hidden||this._restoreTitle()},_setPollingInterval(n){this.interval&&n===this.pollIntervalCurrent||(console.debug("Polling interval updated to "+n),this.interval&&(window.clearInterval(this.interval),this.interval=null),this.pollIntervalCurrent=n,this.setupBackgroundFetcher())},_shutDownNotifications(n){console.debug("Shutting down notifications "+(n?"temporary":"bye")),this.interval&&(window.clearInterval(this.interval),this.interval=null),this.shutdown=!n},checkWebNotificationPermissions(){if(!("Notification"in window)){console.info("Browser does not support notifications"),this.webNotificationsGranted=!1;return}if(window.Notification.permission==="granted"){console.debug("Notifications permissions granted"),this.webNotificationsGranted=!0;return}if(window.Notification.permission==="denied"){console.debug("Notifications permissions denied"),this.webNotificationsGranted=!1;return}if(window.location.protocol==="http:"){console.debug("Notifications require HTTPS"),this.webNotificationsGranted=!1;return}console.info("Notifications permissions not yet requested"),this.webNotificationsGranted=null},async requestWebNotificationPermissions(){this.webNotificationsGranted===null&&(console.info("Requesting notifications permissions"),window.Notification.requestPermission().then(n=>{this.webNotificationsGranted=n==="granted"}))},processWebNotifications(n){n.forEach(p=>{this.backgroundFetching&&emit("notifications:notification:received",{notification:p}),this.showBrowserNotifications&&this.webNotificationsThresholdIdx.open=$),class:"notifications-button","exclude-click-outside-selectors":[".popover"],"aria-label":o.t("notifications","Notifications"),title:o.t("notifications","Notifications"),onOpened:o.onOpen},{trigger:withCtx(()=>[createVNode(E,{size:20,"show-dot":x.notifications.length!==0||x.webNotificationsGranted===null,"show-warning":l.hasThrottledPushNotifications},null,8,["show-dot","show-warning"])]),default:withCtx(()=>[createBaseVNode("div",_hoisted_1,[createVNode(Transition,{name:"fade",mode:"out-in"},{default:withCtx(()=>[x.notifications.length>0?(openBlock(),createBlock(TransitionGroup,{key:0,class:"notification-wrapper",name:"list",tag:"ul"},{default:withCtx(()=>[l.hasThrottledPushNotifications?(openBlock(),createBlock(A,{key:-2016,notification:l.fairUsePolicyNotification},null,8,["notification"])):createCommentVNode("",!0),(openBlock(!0),createElementBlock(Fragment,null,renderList(x.notifications,($,I)=>(openBlock(),createBlock(A,{key:$.notificationId,notification:$,onRemove:P=>o.onRemove(I)},null,8,["notification","onRemove"]))),128))]),_:1})):(openBlock(),createBlock(g,{key:1,name:o.emptyContentMessage,description:o.emptyContentDescription},createSlots({icon:withCtx(()=>[l.hasThrottledPushNotifications?(openBlock(),createElementBlock("span",_hoisted_2)):(openBlock(),createBlock(B,{key:0}))]),_:2},[l.hasThrottledPushNotifications?{name:"action",fn:withCtx(()=>[createVNode(R,{variant:"primary",href:"https://nextcloud.com/fairusepolicy",target:"_blank",rel:"noreferrer noopener"},{icon:withCtx(()=>[createVNode(b,{size:20})]),default:withCtx(()=>[createTextVNode(" "+toDisplayString(o.t("notifications","Contact Nextcloud GmbH"))+" ↗ ",1)]),_:1})]),key:"0"}:void 0]),1032,["name","description"]))]),_:1}),x.notifications.length>0?(openBlock(),createElementBlock("div",_hoisted_3,[createVNode(R,{variant:"tertiary",wide:"",onClick:o.onDismissAll},{icon:withCtx(()=>[createVNode(S,{size:20})]),default:withCtx(()=>[createTextVNode(" "+toDisplayString(o.t("notifications","Dismiss all notifications")),1)]),_:1},8,["onClick"])])):createCommentVNode("",!0)])]),_:1},8,["open","aria-label","title","onOpened"]))}const NotificationsApp=_export_sfc$1(_sfc_main,[["render",_sfc_render],["__scopeId","data-v-344260f0"]]),NotificationsApp$1=Object.freeze(Object.defineProperty({__proto__:null,default:NotificationsApp},Symbol.toStringTag,{value:"Module"}));export{NotificationsApp$1 as N,convertElement as a,convert$1 as c,visit as v}; +//# sourceMappingURL=NotificationsApp-BOamGkxL.chunk.mjs.map diff --git a/js/NotificationsApp-CRRsckwj.chunk.mjs.license b/js/NotificationsApp-BOamGkxL.chunk.mjs.license similarity index 100% rename from js/NotificationsApp-CRRsckwj.chunk.mjs.license rename to js/NotificationsApp-BOamGkxL.chunk.mjs.license diff --git a/js/NotificationsApp-CRRsckwj.chunk.mjs.map b/js/NotificationsApp-BOamGkxL.chunk.mjs.map similarity index 99% rename from js/NotificationsApp-CRRsckwj.chunk.mjs.map rename to js/NotificationsApp-BOamGkxL.chunk.mjs.map index 399fec442..2be0704ed 100644 --- a/js/NotificationsApp-CRRsckwj.chunk.mjs.map +++ b/js/NotificationsApp-BOamGkxL.chunk.mjs.map @@ -1 +1 @@ -{"version":3,"mappings":"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AAK,KAAM,EAEX,KAAK,GAAKpB,EAEVV,EAAK,KAAK,KAAM,GAAI,EAAE,CACvB,CAEA,OAAAtuE,EAASowE,EAAQX,CAAM,EAEvBW,EAAO,UAAU,KAAO,UAAY,CACnC,OAAK,QAAK,WACV,KAAK,GAAK,UACV,KAAK,GAAK,UACV,KAAK,GAAK,WACV,KAAK,GAAK,WACV,KAAK,GAAK,WACV,KAAK,GAAK,WACV,KAAK,GAAK,WAEH,IACP,EAEDA,EAAO,UAAU,MAAQ,UAAY,CACpC,IAAIf,EAAIntB,EAAO,YAAY,EAAE,EAE7B,OAAAmtB,EAAE,aAAa,KAAK,GAAI,CAAC,EACzBA,EAAE,aAAa,KAAK,GAAI,CAAC,EACzBA,EAAE,aAAa,KAAK,GAAI,CAAC,EACzBA,EAAE,aAAa,KAAK,GAAI,EAAE,EAC1BA,EAAE,aAAa,KAAK,GAAI,EAAE,EAC1BA,EAAE,aAAa,KAAK,GAAI,EAAE,EAC1BA,EAAE,aAAa,KAAK,GAAI,EAAE,EAEnBA,CACP,EAEDgB,SAAiBD,4HCpDjB,IAAIpwE,EAAWlE,wBAAmB,EAC9BwyE,EAAOlzD,cAAiB,EACxB8mC,EAAS9jC,oBAAsB,EAAC,OAEhC2wD,EAAI,CACP,WACA,WACA,WACA,UACA,WACA,WACA,WACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,UACA,UACA,WACA,UACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,WACA,UACA,UACA,UACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,WACA,WACA,WACA,WACA,WACA,WACA,UACA,UACA,UACA,WACA,UACA,WACA,UACA,WACA,UACA,WACA,UACA,WAC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EACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,gEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,CACF,CACF,EACD,IAAK,CACH,IAAK,EACL,OAAQ,CACN,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,iEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,kEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,iEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEACA,kEACD,EACD,CACE,mEA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","names":["timestamp","opts","options","date","formatter","seconds","minutes","hours","days","weeks","months","format","_hoisted_1","_hoisted_2","_hoisted_3","_hoisted_4","_sfc_main","__props","_ctx","iconSize","props","cleanSvg","svg","DOMPurify","svgDocument","_cache","createElementVNode","exports","loadState","app","key","fallback","elem","i","require$$0","t","bind","fn","thisArg","toString","getPrototypeOf","iterator","toStringTag","kindOf","cache","thing","str","kindOfTest","type","typeOfTest","isArray","isUndefined","isBuffer","val","isFunction$1","isArrayBuffer","isArrayBufferView","result","isString","isNumber","isObject","isBoolean","isPlainObject","prototype","isEmptyObject","isDate","isFile","isBlob","isFileList","isStream","isFormData","kind","isURLSearchParams","isReadableStream","isRequest","isResponse","isHeaders","trim","forEach","obj","allOwnKeys","l","keys","len","findKey","_key","_global","global","isContextDefined","context","merge","caseless","skipUndefined","assignValue","targetKey","extend","a","b","stripBOM","content","inherits","constructor","superConstructor","descriptors","toFlatObject","sourceObj","destObj","filter","propFilter","prop","merged","endsWith","searchString","position","lastIndex","toArray","arr","isTypedArray","TypedArray","forEachEntry","_iterator","pair","matchAll","regExp","matches","isHTMLForm","toCamelCase","m","p1","p2","hasOwnProperty","isRegExp","reduceDescriptors","reducer","reducedDescriptors","descriptor","name","ret","freezeMethods","value","toObjectSet","arrayOrString","delimiter","define","noop","toFiniteNumber","defaultValue","isSpecCompliantForm","toJSONObject","stack","visit","source","target","reducedValue","isAsyncFn","isThenable","_setImmediate","setImmediateSupported","postMessageSupported","token","callbacks","data","cb","asap","process","utils$1","AxiosError","message","code","config","request","response","prototype$1","error","customProps","axiosError","msg","errCode","httpAdapter","isVisitable","removeBrackets","renderKey","path","dots","isFlatArray","predicates","toFormData","formData","option","metaTokens","visitor","defaultVisitor","indexes","useBlob","convertValue","el","index","exposedHelpers","build","encode$1","charMap","match","AxiosURLSearchParams","params","encoder","_encode","encode","buildURL","url","serializeFn","serializedParams","hashmarkIndex","InterceptorManager","fulfilled","rejected","id","h","InterceptorManager$1","transitionalDefaults","URLSearchParams$1","FormData$1","Blob$1","platform$1","hasBrowserEnv","_navigator","hasStandardBrowserEnv","hasStandardBrowserWebWorkerEnv","origin","utils","platform","toURLEncodedForm","helpers","parsePropPath","arrayToObject","formDataToJSON","buildPath","isNumericKey","isLast","stringifySafely","rawValue","parser","e","defaults","headers","contentType","hasJSONContentType","isObjectPayload","_FormData","transitional","forcedJSONParsing","JSONRequested","strictJSONParsing","status","method","defaults$1","ignoreDuplicateOf","parseHeaders","rawHeaders","parsed","line","$internals","normalizeHeader","header","normalizeValue","parseTokens","tokens","tokensRE","isValidHeaderName","matchHeaderValue","isHeaderNameFilter","formatHeader","w","char","buildAccessors","accessorName","methodName","arg1","arg2","arg3","AxiosHeaders","valueOrRewrite","rewrite","self","setHeader","_value","_header","_rewrite","lHeader","setHeaders","dest","entry","matcher","deleted","deleteHeader","normalized","targets","asStrings","first","computed","accessors","defineAccessor","mapped","headerValue","AxiosHeaders$1","transformData","fns","isCancel","CanceledError","settle","resolve","reject","validateStatus","parseProtocol","speedometer","samplesCount","min","bytes","timestamps","head","tail","firstSampleTS","chunkLength","now","startedAt","bytesCount","passed","throttle","freq","threshold","lastArgs","timer","invoke","args","progressEventReducer","listener","isDownloadStream","bytesNotified","_speedometer","loaded","total","progressBytes","rate","inRange","progressEventDecorator","throttled","lengthComputable","asyncDecorator","isURLSameOrigin","isMSIE","cookies","expires","domain","secure","cookie","isAbsoluteURL","combineURLs","baseURL","relativeURL","buildFullPath","requestedURL","allowAbsoluteUrls","isRelativeUrl","headersToObject","mergeConfig","config1","config2","getMergedValue","mergeDeepProperties","valueFromConfig2","defaultToConfig2","mergeDirectKeys","mergeMap","configValue","resolveConfig","newConfig","withXSRFToken","xsrfHeaderName","xsrfCookieName","auth","formHeaders","allowedHeaders","xsrfValue","xhrAdapter","_config","requestData","requestHeaders","responseType","onUploadProgress","onDownloadProgress","onCanceled","uploadThrottled","downloadThrottled","flushUpload","flushDownload","done","onloadend","responseHeaders","err","event","timeoutErrorMessage","cancel","protocol","composeSignals$1","signals","timeout","length","controller","aborted","onabort","reason","unsubscribe","signal","streamChunk","chunk","chunkSize","pos","end","readBytes","iterable","readStream","stream","reader","trackStream","onProgress","onFinish","_onFinish","loadedBytes","DEFAULT_CHUNK_SIZE","isFunction","globalFetchAPI","Request","Response","ReadableStream$1","TextEncoder","test","factory","env","envFetch","isFetchSupported","isRequestSupported","isResponseSupported","isReadableStreamSupported","encodeText","supportsRequestStream","duplexAccessed","hasContentType","supportsResponseStream","resolvers","res","getBodyLength","body","resolveBodyLength","cancelToken","withCredentials","fetchOptions","_fetch","composedSignal","requestContentLength","_request","contentTypeHeader","flush","isCredentialsSupported","resolvedOptions","isStreamResponse","responseContentLength","responseData","seedCache","getFetch","fetch","seeds","seed","map","knownAdapters","renderReason","isResolvedHandle","adapter","adapters","nameOrAdapter","rejectedReasons","reasons","state","s","throwIfCancellationRequested","dispatchRequest","VERSION","validators$1","deprecatedWarnings","validator","version","formatMessage","opt","desc","correctSpelling","assertOptions","schema","allowUnknown","validators","Axios","instanceConfig","configOrUrl","dummy","paramsSerializer","contextHeaders","requestInterceptorChain","synchronousRequestInterceptors","interceptor","responseInterceptorChain","promise","chain","onFulfilled","onRejected","fullPath","generateHTTPMethod","isForm","Axios$1","CancelToken","executor","resolvePromise","onfulfilled","_resolve","abort","c","CancelToken$1","spread","callback","isAxiosError","payload","HttpStatusCode","HttpStatusCode$1","createInstance","defaultConfig","instance","axios","promises","valid","major","require$$1","_interopDefault","valid__default","major__default","ProxyBus","bus2","handler","SimpleBus","bus","getBus","subscribe","emit","eventBus","browserStorage$1","observers","getRequestToken","onRequestTokenUpdate","observer","getCSPNonce","meta","token2","browserStorage","GuestUser","randomUUID","guest","displayName","currentUser$1","getGuestUser","getGuestNickname","setGuestNickname","nickname","r","currentUser","getAttribute","attribute","getCurrentUser","uid","n","u","U","R","o","f","g","v","d","_","router","require$$2","Axios__default","RETRY_KEY","onError$2","_a2","responseURL","RETRY_DELAY_KEY","onError$1","retryDelay","onError","_a","client","cancelableClient","__importDefault","this","mod","dist","capabilities_1","axios_1","event_bus_1","getSupportedTypes","capabilities","listen","setupGlobals","setupSocket","preAuth","_hoisted_5","timeoutId","language","relativeTime2","ignoreSeconds","relativeTime","ref","updateRelativeTime","diff","interval","keysOrFilter","validateKeyEvent","isKeyInLowerCase","isEventKeyInLowerCase","keyFilter","stopKeyDown","stopKeyUp","backgroundInvertIfDark","element","isDarkTheme","isDarkSystemTheme","updateIsDarkTheme","enforcedTheme","breakpoint","__emit","descriptionId","triggerId","focusTrap","isOpened","wrapperTag","contentContainerElement","headerMenuElement","triggerButtonInstance","ignore","onClickOutside","setMenuState","toggleMenu","addFocusTrap","clearFocusTrap","onFocusOut","_createElementBlock","_mergeProps","$props","$event","_createElementVNode","_openBlock","theming","getCapabilities","hexRegex","hexToHSL","hexColor","max","hue","sat","lum","isRedThemed","isOrangeThemed","_createBlock","timeOptions","relativeTimeOptions","title","formattedTime","$","as","out","unpair","object","flags","set","buffer","serialized","asString","TYPE","strict","json","entries","serialize","lossy","any","anyFactory","castFactory","tests","checks","parameters","check","tagName","testFunction","parent","parse","input","stringify","values","convert","ok","propsFactory","typeFactory","checkAsRecord","all","node","nodeAsRecord","looksLikeANode","color","empty","CONTINUE","EXIT","SKIP","visitParents","tree","reverse","is","step","parents","subresult","offset","grandparents","toResult","nodeAsParent","child","testOrVisitor","visitorOrReverse","maybeReverse","overload","emptyOptions","settings","protocols","contentRaw","relRaw","rel","properties","structuredClone","property","normal","space","definitions","definition","normalize","types","mask","normals","info","attributes","html","cap","Type","rest","dashes","$0","htmlBase","svgBase","COMMENT_REGEX","NEWLINE_REGEX","WHITESPACE_REGEX","PROPERTY_REGEX","COLON_REGEX","VALUE_REGEX","SEMICOLON_REGEX","TRIM_REGEX","NEWLINE","FORWARD_SLASH","ASTERISK","EMPTY_STRING","TYPE_COMMENT","TYPE_DECLARATION","style","lineno","column","updatePosition","lines","start","Position","whitespace","re","comments","rules","comment","declaration","declarations","decls","decl","cjs","StyleToObject","inline_style_parser_1","styleObject","hasIterator","CUSTOM_PROPERTY_REGEX","HYPHEN_REGEX","NO_HYPHEN_REGEX","VENDOR_PREFIX_REGEX","MS_VENDOR_PREFIX_REGEX","skipCamelCase","capitalize","character","trimHyphen","prefix","camelCase","style_to_object_1","utilities_1","StyleToJS","output","point","causeOrReason","optionsOrParentOrPlace","legacyCause","own","filePath","create","one","root","text","parentSchema","children","expression","assert","jsx","jsxs","jsxDEV","isStaticChildren","alignValue","objectExpression","countsByName","count","commas","spaces","cause","allowExpression","identifiers","isIdentifierName","place","domCasing","cssCasing","from","to","compiler","file","escapeStringRegexp","string","findAndReplace","list","ignored","pairs","toPairs","pairIndex","grandparent","siblings","find","replace","change","nodes","matchObject","tupleOrList","tuple","toExpression","toFunction","escape","includeImageAlt","includeHtml","characterReference","splice","remove","items","chunkStart","combineExtensions","extensions","syntaxExtension","extension","hook","left","right","constructs","existing","before","base","normalizeIdentifier","asciiAlpha","regexCheck","asciiAlphanumeric","asciiControl","markdownLineEnding","markdownLineEndingOrSpace","markdownSpace","unicodePunctuation","unicodeWhitespace","regex","skip","next","factorySpace","effects","limit","size","contentStart","afterContentStartConstruct","paragraphInitial","previous","lineStart","document","continued","childFlow","childToken","lineStartOffset","item","documentContinue","checkNewContainers","closeFlow","indexBeforeExits","indexBeforeFlow","exitContainers","documentContinued","flowStart","thereIsANewContainer","thereIsNoNewContainer","containerContinue","flowContinue","writeToChild","endOfFile","seen","nok","classifyCharacter","resolveAll","events","called","open","group","openingSequence","closingSequence","use","nextEvents","attentionMarkers","marker","inside","after","close","schemeOrEmailAtext","emailAtext","schemeInsideOrEmailAtext","urlInside","emailAtSignOrDot","emailLabel","emailValue","blankLine","tokenizeBlankLine","exit","contStart","contBefore","numeric","closeStart","tokenizeCloseStart","initialPrefix","sizeOpen","beforeSequenceOpen","sequenceOpen","infoBefore","atNonLazyBreak","metaBefore","contentBefore","beforeContentChunk","contentChunk","startBefore","beforeSequenceClose","sequenceClose","sequenceCloseAfter","afterPrefix","atBreak","furtherStart","tailExitIndex","headEnterIndex","enter","between","initial","stop","deleteCount","removed","eventsArray","jumps","lineIndex","otherIndex","otherEvent","subevents","more","eventIndex","startPosition","startPositions","tokenizer","childEvents","gaps","current","adjust","breaks","slice","chunkInside","contentEnd","contentContinue","startLookahead","prefixed","literalType","literalMarkerType","rawType","stringType","balance","enclosedBefore","raw","enclosed","enclosedEscape","rawEscape","markerType","labelInside","labelEscape","begin","identifier","labelAfter","markerAfter","destinationBefore","destinationAfter","afterWhitespace","titleBefore","beforeMarker","titleAfter","titleAfterOptionalWhitespace","sequenceFurther","closingTag","markerB","declarationOpen","tagCloseStart","continuationDeclarationInside","commentOpenInside","cdataOpenInside","continuation","slash","basicSelfClosing","completeClosingTagAfter","completeAttributeNameBefore","completeEnd","completeAttributeName","completeAttributeNameAfter","completeAttributeValueBefore","completeAttributeValueQuoted","completeAttributeValueUnquoted","completeAttributeValueQuotedAfter","completeAfter","continuationCommentInside","continuationRawTagOpen","continuationClose","continuationCdataInside","continuationAfter","continuationStart","continuationStartNonLazy","continuationBefore","continuationRawEndTag","returnState","instruction","tagOpen","commentEnd","commentClose","lineEndingBefore","cdata","cdataClose","cdataEnd","instructionClose","tagClose","tagCloseBetween","tagOpenBetween","tagOpenAttributeName","tagOpenAttributeNameAfter","tagOpenAttributeValueBefore","tagOpenAttributeValueQuoted","tagOpenAttributeValueUnquoted","tagOpenAttributeValueQuotedAfter","lineEndingAfter","lineEndingAfterPrefix","newEvents","media","label","labelStart","defined","labelEndNok","labelEndOk","referenceNotFull","resourceStart","resourceBefore","resourceOpen","resourceEnd","resourceDestinationAfter","resourceDestinationMissing","resourceBetween","resourceTitleAfter","referenceFull","referenceFullAfter","referenceFullMissing","referenceCollapsedStart","referenceCollapsedOpen","thematicBreak","sequence","tokenizeIndent","initialSize","atMarker","onBlank","endOfPrefix","otherPrefix","notBlank","notInCurrentItem","heading","paragraph","flow","atBlankEnding","afterConstruct","field","initializeText","notText","extraResolver","resolveAllText","chunks","bufferIndex","tabs","resolveText","initialize","columnStart","resolveAllConstructs","constructFactory","onsuccessfulconstruct","onsuccessfulcheck","consume","defineSkip","sliceSerialize","sliceStream","write","main","addResult","expandTabs","_bufferIndex","_index","accountForPotentialSkip","chunkIndex","go","fields","construct","onreturn","bogusState","listOfConstructs","constructIndex","currentConstruct","handleListOfConstructs","handleMapOfConstructs","handleConstruct","store","startPoint","startPrevious","startCurrentConstruct","startEventsIndex","startStack","restore","startIndex","startBufferIndex","endIndex","endBufferIndex","view","atTab","creator","atCarriageReturn","preprocessor","encoding","endPosition","$1","$2","hex","opener","link","onenterdata","blockQuote","codeFlow","codeText","emphasis","hardBreak","image","listItem","onenterlistitemvalue","onenterlistordered","onenterreference","strong","closer","onexitatxheadingsequence","onexitautolinkemail","onexitautolinkprotocol","onexitdata","onexitcharacterreferencemarker","onexitcharacterreferencevalue","onexitcharacterreference","onexitcodefenced","onexitcodefencedfence","onexitcodefencedfenceinfo","onexitcodefencedfencemeta","onexitcodeindented","onexitcodetext","onexitdefinitiondestinationstring","onexitdefinitionlabelstring","onexitdefinitiontitlestring","onexithardbreak","onexithtmlflow","onexithtmltext","onexitimage","onexitlabel","onexitlabeltext","onexitlineending","onexitlink","onexitreferencestring","onexitresourcedestinationstring","onexitresourcetitlestring","onexitresource","onexitsetextheading","onexitsetextheadinglinesequence","onexitsetextheadingtext","compile","resume","listStack","prepareList","containerBalance","listSpread","firstBlankLineIndex","tailIndex","tailEvent","and","errorHandler","onExitError","ancestor","depth","referenceType","fragment","combined","doc","blockquote","footnoteReference","clobberPrefix","safeId","counter","reuseCounter","sup","subtype","suffix","contents","imageReference","inlineCode","linkReference","results","loose","rows","firstRow","tableContent","align","cellIndex","cells","cell","search","last","rereferenceIndex","referenceIndex","footnoteBackContent","footnoteBackLabel","footnoteLabel","footnoteLabelTagName","footnoteLabelProperties","listItems","backReferences","counts","tailTail","definitionById","footnoteById","footnoteCounts","handlers","defaultHandlers","wrap","handle","shallow","hName","hChildren","hProperties","foot","destination","hastTree","proto","hasOwn","toStr","defineProperty","gOPD","hasOwnConstructor","hasIsPrototypeOf","setProperty","getProperty","src","copy","copyIsArray","clone","deep","pipeline","run","middlewareIndex","middelware","middleware","wrapped","fnExpectsCallback","exception","then","extname","assertPath","seenNonSlash","firstNonSlashEnd","extnameIndex","unmatchedSlash","startPart","startDot","preDotState","segments","joined","absolute","allowAboveRoot","lastSegmentLength","lastSlash","lastSlashIndex","fileUrlOrPath","pathname","third","isUint8Array","basename","dirname","stem","part","apply","attacher","transformer","realFile","parseTree","realDone","compileTree","compileResult","complete","transformers","outputTree","resultingTree","attachers","namespace","addPlugin","addList","addPreset","add","plugin","plugins","entryIndex","primary","currentPrimary","isPlainObj","frozen","asyncName","onDestroy","propsWithDefaults","logger","richObjectType","richObject","accessible","interactive","autolink","useMarkdown","useExtendedMarkdown","x","href","textAfter","textBefore","lastChar","joinedText","removePrefix","removePrefixes","prefixes","acc","isNonHttpLink","getBaseUrl","relativeUrl","relativeRouterBase","getRootUrl","potentialRouterPath","route","imagePath","_sfc_main$5","isVisible","widgetRoot","width","lineClamp","widget","_hoisted_1$5","_hoisted_2$4","_hoisted_3$3","_hoisted_4$2","_sfc_render$5","$setup","$data","$options","_component_NcButton","_sfc_main$1","isPublic","generateOcsUrl","_sfc_render","_component_NcReferenceWidget","reference","code2","index2","all2","node2","visit2","list2","replace2","domain2","path2","parts","atext","trailExec","trail2","closingParenIndex","openingParens","closingParens","email","tracker","exit2","subexit","firstLineBlank","footnoteDefinition","blank","table","stringLength","alignments","cellMatrix","sizeMatrix","longestCellByColumn","mostCellsPerRow","rowIndex","row2","sizes2","columnIndex2","columnIndex","row","sizes","pattern","none","_1","substring","expected","exit3","value2","quote","outside","outsideKind","insideKind","betweenHead","betweenTail","literalWithBreak","node3","rank","subexit2","alt","text2","bullet","bulletOther","bulletCurrent","useDifferentMarker","firstListItem","listItemIndent","map2","repetition","padding","alignDelimiters","around","inlineCodeWithTable","handleTable","handleTableCell","handleTableRow","serializeData","handleTableAsData","handleTableRowAsData","matrix","firstParaghraph","sibling","checkable","checkbox","ok2","dot","emailDomain","emailDomainAfter","emailDomainDot","wwwStart","wwwAfter","protocolStart","protocolPrefixInside","protocolSlashesInside","afterProtocol","protocolAfter","wwwPrefixInside","wwwPrefixAfter","underscoreInLastSegment","underscoreInLastLastSegment","domainInside","domainAfter","domainAtPunctuation","sizeClose","pathInside","pathAtPunctuation","trailCharacterReferenceStart","trailBracketAfter","trailCharacterReferenceInside","constructs2","call","replacement","callStart","callData","callEscape","labelAtMarker","whitespaceAfter","single","tokenizeStrikethrough","resolveAllStrikethrough","strikethrough","insideSpan","previous2","vecs","editMap","at","inDelimiterRow","alignIndex","sizeB","bodyRowStart","headRowBefore","headRowStart","headRowBreak","headDelimiterStart","headRowData","headRowEscape","headDelimiterBefore","headDelimiterValueBefore","headDelimiterCellBefore","headDelimiterNok","headDelimiterLeftAlignmentAfter","headDelimiterCellAfter","headDelimiterFiller","headDelimiterRightAlignmentAfter","bodyRowBreak","bodyRowData","bodyRowEscape","inFirstCellAwaitingPipe","rowKind","lastCell","afterHeadAwaitingFirstBodyRow","lastTableEnd","currentTable","currentBody","currentCell","range","rowEnd","previousCell","groupName","valueName","relatedStart","relatedEnd","valueToken","tableBody","exits","related","side","micromarkExtensions","fromMarkdownExtensions","toMarkdownExtensions","ast","placeholders","component","module","argumentId","argument","renderedMarkdown","remark2rehype","toHast","rehype2react","componentClass","nestedNode","inputNode","labelParts","nestedNodeIndex","propsToForward","inputComponent","placeholder","isWebLink","onClickActionButton","action","_unref","_createTextVNode","_toDisplayString","lastSlashPosition","firstSlashPosition","elRef","plain","cleanups","cleanup","register","firstParamTargets","stopWatch","_b","raw_targets","raw_events","raw_listeners","raw_options","optionsClone","window","capture","detectIframe","controls","listenerOptions","shouldListen","shouldIgnore","target2","hasMultipleRoots","vm","checkMultipleRoots","isProcessingClick","binding","ele","rawEvent","_target","initialState","isLocked","stopTouchMoveListener","initialOverflow","toRef","lock","unlock","isMounted","base64Js","byteLength","toByteArray","fromByteArray","lookup","revLookup","Arr","getLens","b64","validLen","placeHoldersLen","lens","_byteLength","tmp","curByte","tripletToBase64","num","encodeChunk","uint8","extraBytes","maxChunkLength","len2","ieee754","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","rt","base64","ieee754$1","customInspectSymbol","Buffer","SlowBuffer","K_MAX_LENGTH","GlobalUint8Array","GlobalArrayBuffer","GlobalSharedArrayBuffer","typedArraySupport","createBuffer","buf","arg","encodingOrOffset","allocUnsafe","fromString","fromArrayView","isInstance","fromArrayBuffer","valueOf","fromObject","assertSize","alloc","fill","checked","actual","fromArrayLike","array","arrayView","byteOffset","numberIsNaN","y","mustMatch","loweredCase","utf8ToBytes","base64ToBytes","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","thisStart","thisEnd","thisCopy","targetCopy","bidirectionalIndexOf","dir","arrayIndexOf","indexSize","arrLength","valLength","read","foundIndex","found","j","hexWrite","remaining","strLen","utf8Write","blitBuffer","asciiWrite","asciiToBytes","base64Write","ucs2Write","utf16leToBytes","firstByte","codePoint","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","decodeCodePointsArray","MAX_ARGUMENTS_LENGTH","codePoints","hexSliceLookupTable","newBuf","checkOffset","ext","noAssert","mul","defineBigIntMethod","validateNumber","boundsError","lo","hi","checkInt","maxBytes","wrtBigUInt64LE","checkIntBI","wrtBigUInt64BE","sub","checkIEEE754","writeFloat","littleEndian","writeDouble","targetStart","errors","E","sym","getMessage","Base","received","addNumericalSeparator","checkBounds","INVALID_BASE64_RE","base64clean","units","leadSurrogate","byteArray","dst","alphabet","i16","BufferBigIntNotDefined","copyProps","SafeBuffer","MAX_BYTES","MAX_UINT32","oldBrowser","crypto","browserModule","randomBytes","generated","inherits_browserModule","ctor","superCtor","TempCtor","ReflectApply","receiver","ReflectOwnKeys","ProcessEmitWarning","warning","NumberIsNaN","EventEmitter","eventsModule","once","defaultMaxListeners","checkListener","_getMaxListeners","that","doError","er","listeners","arrayClone","_addListener","prepend","onceWrapper","_onceWrap","originalListener","spliceOne","_listeners","unwrap","evlistener","unwrapListeners","emitter","listenerCount","errorListener","resolver","eventTargetAgnosticAddListener","addErrorHandlerIfEventEmitter","wrapListener","streamBrowser","shams","symObj","symVal","syms","hasSymbols","$isNaN","sign","number","$gOPD","$defineProperty","origSymbol","hasSymbolSham","$Object","ERROR_MESSAGE","funcType","concatty","slicy","arrLike","joiny","joiner","bound","binder","boundLength","boundArgs","Empty","implementation","$apply","$call","$reflectApply","require$$3","$TypeError","$actualApply","callBind","hasProtoAccessor","$getPrototypeOf","reflectGetProto","originalGetProto","getDunderProto","O","$hasOwn","undefined","$Error","$EvalError","$RangeError","$ReferenceError","require$$4","$SyntaxError","require$$5","require$$6","$URIError","require$$7","abs","require$$8","floor","require$$9","require$$10","require$$11","pow","require$$12","round","require$$13","require$$14","$Function","getEvalledConstructor","expressionSyntax","require$$15","require$$16","throwTypeError","ThrowTypeError","require$$17","getProto","require$$18","$ObjectGPO","require$$19","$ReflectGPO","require$$20","require$$21","require$$22","needsEval","INTRINSICS","errorProto","doEval","gen","LEGACY_ALIASES","require$$23","require$$24","$concat","$spliceApply","$replace","$strSlice","$exec","rePropName","reEscapeChar","stringToPath","subString","getBaseIntrinsic","allowMissing","intrinsicName","alias","intrinsicBaseName","intrinsic","intrinsicRealName","skipFurtherCaching","isOwn","GetIntrinsic","callBindBasic","$indexOf","hasToStringTag","callBound","$toString","isStandardArguments","isLegacyArguments","supportsStandardArguments","isRegexMarker","throwRegexMarker","badStringifier","hasLastIndexDataProperty","regexClass","isRegex","safeRegexTest","isFnRegex","fnToStr","getGeneratorFunc","GeneratorFunction","generatorFunc","reflectApply","badArrayLike","isCallableMarker","constructorRegex","isES6ClassFn","fnStr","tryFunctionObject","objectClass","fnClass","genClass","ddaClass","ddaClass2","ddaClass3","isIE68","isDDA","strClass","isCallable","forEachArray","forEachString","forEachObject","k","possibleNames","gopd","nonEnumerable","nonWritable","nonConfigurable","hasPropertyDescriptors","hasDescriptors","$floor","functionLengthIsConfigurable","functionLengthIsWritable","actualApply","setFunctionLength","applyBind","originalFunction","func","adjustedLength","availableTypedArrays","typedArrays","$slice","typedArray","superProto","tryTypedArrays","getter","trySlices","tag","whichTypedArray","isArgumentsObject","isGeneratorFunction","uncurryThis","BigIntSupported","SymbolSupported","ObjectToString","numberValue","stringValue","booleanValue","bigIntValue","symbolValue","checkBoxedPrimitive","prototypeValueOf","isPromise","isDataView","isUint8ClampedArray","isUint16Array","isUint32Array","isInt8Array","isInt16Array","isInt32Array","isFloat32Array","isFloat64Array","isBigInt64Array","isBigUint64Array","isMapToString","isMap","isSetToString","isSet","isWeakMapToString","isWeakMap","isWeakSetToString","isWeakSet","isArrayBufferToString","isDataViewToString","SharedArrayBufferCopy","isSharedArrayBufferToString","isSharedArrayBuffer","isAsyncFunction","isMapIterator","isSetIterator","isGeneratorObject","isWebAssemblyCompiledModule","isNumberObject","isStringObject","isBooleanObject","isBigIntObject","isSymbolObject","isBoxedPrimitive","isAnyArrayBuffer","getOwnPropertyDescriptors","formatRegExp","objects","inspect","isNull","warned","deprecated","debugs","debugEnvRegex","define_process_env_default","debugEnv","pid","ctx","stylizeNoColor","stylizeWithColor","formatValue","styleType","arrayToHash","hash","idx","recurseTimes","primitive","formatPrimitive","visibleKeys","isError","formatError","braces","formatArray","formatProperty","reduceToSingleString","simple","prev","cur","ar","isNullOrUndefined","isSymbol","objectToString","isPrimitive","pad","time","kCustomPromisifiedSymbol","original","promiseResolve","promiseReject","callbackifyOnRejected","newReason","callbackify","callbackified","maybeCb","rej","ownKeys","enumerableOnly","symbols","_objectSpread","_defineProperty","_toPropertyKey","_classCallCheck","Constructor","_defineProperties","_createClass","protoProps","staticProps","_toPrimitive","hint","prim","_require","_require2","custom","copyBuffer","BufferList","p","hasStrings","nb","destroy","_this","readableDestroyed","writableDestroyed","emitErrorNT","emitCloseNT","emitErrorAndCloseNT","undestroy","errorOrDestroy","rState","wState","destroy_1","_inheritsLoose","subClass","superClass","codes","createErrorType","NodeError","_Base","oneOf","startsWith","this_len","includes","determiner","ERR_INVALID_OPT_VALUE","highWaterMarkFrom","isDuplex","duplexKey","getHighWaterMark","hwm","browser","deprecate","_stream_writable","Writable","CorkedRequest","onCorkedFinish","Duplex","WritableState","internalUtil","Stream","OurUint8Array","_uint8ArrayToBuffer","_isUint8Array","destroyImpl","_require$codes","ERR_INVALID_ARG_TYPE","ERR_METHOD_NOT_IMPLEMENTED","ERR_MULTIPLE_CALLBACK","ERR_STREAM_CANNOT_PIPE","ERR_STREAM_DESTROYED","ERR_STREAM_NULL_VALUES","ERR_STREAM_WRITE_AFTER_END","ERR_UNKNOWN_ENCODING","nop","noDecode","onwrite","realHasInstance","writeAfterEnd","validChunk","isBuf","writeOrBuffer","clearBuffer","decodeChunk","newChunk","doWrite","writev","onwriteError","sync","finishMaybe","onwriteStateUpdate","finished","needFinish","afterWrite","onwriteDrain","holder","allBuffers","endWritable","callFinal","prefinish","need","corkReq","objectKeys","_stream_duplex","Readable","onend","onEndNT","isEncoding","_normalizeEncoding","enc","retried","normalizeEncoding","nenc","StringDecoder","utf16Text","utf16End","utf8FillLast","base64Text","base64End","simpleWrite","simpleEnd","utf8End","utf8Text","utf8CheckByte","byte","utf8CheckIncomplete","utf8CheckExtraBytes","ERR_STREAM_PREMATURE_CLOSE","_len","eos","readable","writable","onlegacyfinish","onfinish","writableEnded","readableEnded","onerror","onclose","onrequest","_Object$setPrototypeO","kLastResolve","kLastReject","kError","kEnded","kLastPromise","kHandlePromise","kStream","createIterResult","readAndResolve","iter","onReadable","wrapForNext","lastPromise","AsyncIteratorPrototype","ReadableStreamAsyncIteratorPrototype","_this2","createReadableStreamAsyncIterator","_Object$create","_stream_readable","ReadableState","EElistenerCount","debugUtil","debug","ERR_STREAM_PUSH_AFTER_EOF","ERR_STREAM_UNSHIFT_AFTER_END_EVENT","kProxyEvents","prependListener","skipChunkCheck","readableAddChunk","addToFront","onEofChunk","chunkInvalid","addChunk","maybeReadMore","emitReadable","decoder","MAX_HWM","computeNewHighWaterMark","howMuchToRead","nOrig","endReadable","doRead","fromList","emitReadable_","maybeReadMore_","pipeOpts","doEnd","endFn","unpipe","onunpipe","unpipeInfo","ondrain","pipeOnDrain","cleanedUp","ondata","indexOf","dests","ev","nReadingNextTick","updateReadableListening","resume_","paused","endReadableNT","xs","_stream_transform","Transform","ERR_TRANSFORM_ALREADY_TRANSFORMING","ERR_TRANSFORM_WITH_LENGTH_0","afterTransform","ts","rs","err2","_stream_passthrough","PassThrough","ERR_MISSING_ARGS","destroyer","reading","writing","closed","destroyed","pipe","popCallback","streams","destroys","EE","didOnEnd","HashBase","blockSize","useUint8Array","useArrayBuffer","toBuffer","block","carry","digest","hashBase","ARRAY16","MD5","M","fnF","fnG","fnH","fnI","rotl","zl","zr","sl","sr","hl","hr","RIPEMD160","words","al","bl","cl","dl","br","cr","dr","tl","tr","fn1","fn5","fn2","fn4","fn3","ripemd160","isarray","$typedArrayBuffer","typedArrayBuffer","isView","useFromArrayBuffer","isArr","Hash","finalSize","accum","assigned","remainder","rem","bits","lowBits","highBits","K","W","Sha","rotl5","rotl30","ft","H","sha","Sha1","rotl1","Sha256","ch","z","maj","sigma0","sigma1","gamma0","gamma1","T1","T2","sha256","Sha224","sha224","Sha512","Ch","xl","Gamma0","Gamma0l","Gamma1","Gamma1l","getCarry","ah","bh","dh","eh","fh","gh","hh","fl","gl","xh","gamma0l","gamma1l","Wi7h","Wi7l","Wi16h","Wi16l","Wil","Wih","majh","majl","sigma0h","sigma0l","sigma1h","sigma1l","Kih","Kil","chh","chl","t1l","t1h","t2l","t2h","writeInt64BE","sha512","SHA512","Sha384","sha384","algorithm","alg","Algorithm","CipherBase","hashMode","inputEnc","outputEnc","bufferData","outData","fin","ZEROS","blocksize","Hmac","ipad","opad","md5","Legacy","MAX_ALLOC","iterations","keylen","defaultEncoding","pVersionMajor","intSize","zeroBuffer","charSize","hashSize","makeHash","core_md5","olda","oldb","oldc","oldd","md5_ff","md5_gg","md5_hh","md5_ii","safe_add","md5_cmn","q","bit_rol","lsw","msw","cnt","checkParameters","mapping","rmd160Func","getDigest","shaFunc","saltLen","ipad1","pbkdf2","password","salt","lowerDigest","mappedDigest","hmac","DK","block1","destPos","hLen","T","ZERO_BUF","subtle","toBrowser","nextTick","getNextTick","browserPbkdf2","algo","checkNative","prom","resp","off","inL","inR","outL","outR","shift","pc2table","sTable","sb","permuteTable","Cipher","inputOff","outputOff","DESState","DES","shiftTable","kL","kR","inp","inOff","outOff","lStart","rStart","keyL","keyR","CBCState","iv","instantiate","CBC","cbc","EDEState","k1","k2","k3","EDE","des","modes","modeName","mode","xor","encryptStart","decrypt","encryptByte","byteParam","bit","shiftIn","getBlock","incr32","chunkNum","modeModules","asUInt32Array","scrubVec","cryptBlock","keySchedule","SUB_MIX","SBOX","nRounds","SUB_MIX0","SUB_MIX1","SUB_MIX2","SUB_MIX3","s0","s1","s2","s3","t0","t1","t2","t3","ksRow","RCON","G","INV_SBOX","INV_SUB_MIX","xi","sx","x2","x4","x8","AES","keyWords","keySize","ksRows","invKeySchedule","ik","ksR","tt","m1","ZEROES","fromArray","GHASH","Vi","Zi","lsbVi","abl","aes","xorTest","calcIv","ck","ghash","toPad","ivBits","StreamCipher","rump","EVP_BytesToKey","keyBits","ivLen","keyLen","used","keyStart","ivStart","MODES","AuthCipher","ebtk","Splitter","PADDING","setTo","padBuff","createCipheriv","suite","createCipher","Decipher","unpad","autoPadding","padded","createDecipheriv","createDecipher","ciphers","deciphers","getCiphers","aesModes","desModes","BN","endian","parseHex4Bits","parseHexByte","lowerBound","parseLength","parseBase","limbLen","limbPow","word","zeros","groupSizes","groupBases","groupSize","groupBase","ArrayType","reqLength","toBitArray","wbit","bytesNeeded","bitsLeft","cmp","smallMulTo","ncarry","rword","maxJ","comb10MulTo","mid","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","w0","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","fftm","FFTM","N","rb","rbt","rws","iws","rtws","itws","rtwdf","itwdf","rtwdf_","itwdf_","ie","ro","io","rx","odd","ws","ph","rwst","iwst","nrws","nrwst","niwst","rmws","carryMask","newCarry","extended","maskedWords","bhi","bhiBits","qj","positive","div","dm","half","r2","A","B","C","D","yp","xp","im","jm","x1","delta","negative","Red","primes","MPrime","rlen","K256","outLen","P224","P192","P25519","prime","mod3","nOne","lpow","inv","windowSize","wnd","currentLen","Mont","brorandModule","Rand","rand","bn","brorand","MillerRabin","min_bytes","red","rone","n1","rn1","findPrime","simpleSieve","fermatTest","TWENTYFOUR","millerRabin","ONE","TWO","FIVE","TEN","THREE","ELEVEN","FOUR","_getPrimes","sqrt","n2","SEVEN","DH","setPublicKey","pub","setPrivateKey","priv","primeCache","checkPrime","generator","malleable","other","secret","front","formatReturnValue","generatePrime","getDiffieHellman","ENCODINGS","createDiffieHellman","genc","processNextickArgsModule","util","pna","asyncWrite","writableHwm","defaultHwm","readableHwm","needMoreData","increasedAwaitDrain","fromListPartial","copyFromBufferString","copyFromBuffer","move","allocate","postfix","isNegNum","getr","blind","blinder","crt","blinds","blinded","c1","c2","qinv","m2","zero2","toHex","minAssert","minUtils","getNAF","naf","getJSF","jsf","d1","d2","m8","m14","m24","u1","u2","cachedProperty","computer","parseBytes","intFromLE","BaseCurve","conf","adjustCount","doubles","I","repr","nafW","nafPoints","defW","points","coeffs","jacobianResult","wndWidth","comb","ja","jb","zero","BasePoint","curve","compact","power","precomputed","dbl","ShortCurve","beta","lambda","betas","lambdas","basis","vec","tinv","ntinv","l1","l2","aprxSqrt","y1","y2","prevR","len1","v1","v2","q1","q2","isOdd","ax","rhs","npoints","ncoeffs","split","Point","isRed","pre","endoMul","obj2point","nx","ny","ys1","dyinv","_precompute","negate","JPoint","zinv","zinv2","ay","pz2","z2","h2","h3","nz","jx","jy","jz","jz4","jyd","jx2","jyd2","jyd4","dny","xx","yy","yyyy","yyyy8","c8","gamma","alpha","beta4","beta8","ggamma8","jy2","jxd4","jyd8","zz","mm","ee","yyu4","kbase","z3","pz3","zs","xc","MontCurve","aa","bb","da","EdwardsCurve","lhs","nt","zi","isSurrogatePair","htonl","toHex32","zero8","join32","split32","rotr32","rotl32","sum32","sum32_3","sum32_4","sum32_5","sum64","sum64_hi","sum64_lo","sum64_4_hi","sum64_4_lo","sum64_5_hi","sum64_5_lo","rotr64_hi","rotr64_lo","shr64_hi","shr64_lo","BlockHash","common","ft_1","ch32","p32","maj32","s0_256","s1_256","g0_256","g1_256","shaCommon","sha1_K","SHA1","sha256_K","SHA256","SHA224","sha512_K","c0_hi","g1_512_hi","c0_lo","g1_512_lo","c1_hi","c1_lo","c2_hi","g0_512_hi","c2_lo","g0_512_lo","c3_hi","c3_lo","s1_512_hi","s1_512_lo","ch64_hi","ch64_lo","c4_hi","c4_lo","T1_hi","T1_lo","s0_512_hi","s0_512_lo","maj64_hi","maj64_lo","T2_hi","T2_lo","yh","yl","zh","SHA384","Ah","Bh","Dh","Eh","rh","Kh","sh","curves","PresetCurve","defineCurve","HmacDRBG","entropy","nonce","pers","kmac","entropyEnc","addEnc","temp","KeyPair","ec","signature","Signature","getLength","octetLen","rmPadding","slen","constructLength","octets","backHalf","EC","drbg","ns2","truncOnly","bitLength","bkey","ns1","kp","kpX","recoveryParam","sinv","isYOdd","isSecondKey","rInv","Q","Qprime","eddsa","lastIx","sig","EDDSA","Rencoded","s_","S","SG","RplusAh","normed","xIsOdd","elliptic","iframe","win","wEval","wExecScript","winKeys","asn1","api","Entity","named","entity","reporter","Reporter","ReporterError","inherited","DecoderBuffer","save","fail","EncoderBuffer","tags","methods","overrided","Node","stateProps","cstate","newKey","present","prevKey","prevObj","explicit","cls","constants","bignum","der","DERDecoder","DERNode","der_1","decodedTag","derDecodeTag","derDecodeLen","possibleEnd","unused","numstr","printstr","relative","ident","subident","second","year","mon","day","hour","sec","oct","tagStr","PEMDecoder","pem","decoders","DEREncoder","encodedTag","encodeTag","lenOctets","objid","two","numArray","dataBuffer","PEMEncoder","encoders","asn","Time","AttributeTypeValue","AlgorithmIdentifier","SubjectPublicKeyInfo","RelativeDistinguishedName","RDNSequence","Name","Validity","Extension","TBSCertificate","X509Certificate","asn1_1","RSAPrivateKey","RSAPublicKey","PublicKey","PrivateKeyInfo","EncryptedPrivateKeyInfo","DSAPrivateKey","ECParameters","ECPrivateKey","findProc","startRegex","fullRegex","evp","okey","decrypted","cipherText","cipherKey","cipher","match2","aesid","fixProc","compat","iters","parseKeys","stripped","ndata","createHmac","RSA_PKCS1_PADDING","hashType","signType","ecSign","dsaSign","curveId","bits2int","kv","getKey","makeKey","makeR","toDER","hlen","hbits","bits2octets","obits","signModule","verify","ecVerify","dsaVerify","padNum","pubkey","unpacked","checkValue","montp","createHash","algorithms","Sign","Verify","sigBuffer","createSign","createVerify","ECDH","aliases","inenc","otherPub","_priv","i2ops","withPublic","paddedMsg","mgf","publicKey","oaep","pkcs1","iHash","hLen2","ps","dblen","maskedDb","maskedSeed","nonZero","privateKey","zBuffer","db","compare","dif","safeBuffer","randombytes","kBufferMaxLength","kMaxUint32","assertOffset","randomFill","randomFillSync","actualFill","ourBuf","uint","algos","algoKeys","hashes","publicEncrypt","rf","int","steps","color1","color2","palette","increment","yellow","blue","palette1","palette2","palette3","finalInt","username","finalPalette","Symbol","STATE_PLAINTEXT","STATE_HTML","STATE_COMMENT","ALLOWED_TAGS_REGEX","NORMALIZE_TAG_REGEX","striptags","allowable_tags","tag_replacement","init_context","striptags_internal","init_striptags_stream","parse_allowable_tags","tag_buffer","in_quote_char","normalize_tag","tag_set","user","guestUrl","themeUrl","generateUrl","isInvisible","ariaLabel","matchSvg","activeSvg","behavior","_hoisted_6","_hoisted_7","_hoisted_8","_component_NcIconSvgWrapper","_component_RouterLink","userId","icon","getBuilder","flag","initials","filteredChars","filtered","actions","emojiIcon","avatarUrl","srcset","userHasAvatar","img","_component_NcLoadingIcon","_component_IconDotsHorizontal","_component_NcActions","_component_NcUserStatusIcon","_directive_click_outside","isOpen","isAvatarUrl","isCustomAvatar","avatarStyle","hasUrl","contentComponent","contentStyle","attrs","_component_NcUserBubble","ActionButton","NcDateTime","parametersHaveLink","richParameters","executeEvent","_component_NcDateTime","_createVNode","_component_IconClose","_component_NcRichText","_normalizeClass","_Fragment","_component_ActionButton","_component_IconMessageOutline","tabId","lastETag","forceRefresh","hasNotifyPush","lastUpdated","lastTab","notification","requestConfig","HowlerGlobal","Howler","vol","setupAudioContext","ids","sound","muted","audioTest","mpegTest","ua","checkOpera","isOldOpera","checkSafari","safariVersion","isOldSafari","audioNode","testPlay","audio","handleSuspension","Howl","Sound","loadBuffer","sprite","internal","soundId","seek","duration","setParams","playWebAudio","playHtml5","play","loadedNoReadyState","currentTime","isGroup","stepLen","lastTick","tick","loop","playing","seekAndEmit","emitSeek","realTime","rateSeek","sounds","remCache","isId","task","isIOS","checkIE","howl","volume","loadSound","dataView","decodeAudioData","xhr","safeXhrSend","arraybuffer","success","iOS","appVersion","safari","pan","xUp","yUp","zUp","or","_super","pannerType","setupPanner","pa","panner","howlPayload","generateFilePath","primaryDeviceId","secondarySpeakerEnabled","secondaryDeviceId","soundDuped","IconNotification","notifications","pollInterval","temporary","permissions","_component_NcHeaderMenu","_component_IconNotification","_Transition","_TransitionGroup","_component_NotificationItem","_renderList","_component_NcEmptyContent","_component_IconBellOutline"],"ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,346,347,348,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,371,372,373,374,375,376,377,378,379,380,381,382,383,384,385,386,387,388,389,390,391,392,393,394,395,396,397,398,399,400,401,402,403,404,405,406,407,408,409,410,411,412,413,414,415,419],"sources":["../node_modules/@nextcloud/l10n/dist/index.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcIconSvgWrapper-5AA93z-F.mjs","../node_modules/@nextcloud/vue/dist/chunks/mdi-D_GPbmUY.mjs","../node_modules/@nextcloud/capabilities/node_modules/@nextcloud/initial-state/dist/index.cjs","../node_modules/@nextcloud/capabilities/dist/index.cjs","../node_modules/axios/dist/browser/axios.cjs","../node_modules/@nextcloud/event-bus/dist/index.cjs","../node_modules/@nextcloud/auth/dist/index.cjs","../node_modules/@nextcloud/router/dist/index.cjs","../node_modules/@nextcloud/axios/dist/index.cjs","../node_modules/@nextcloud/notify_push/dist/index.js","../node_modules/@nextcloud/vue/dist/chunks/NcEmptyContent-BdOezubv.mjs","../node_modules/@nextcloud/vue/dist/composables/useFormatDateTime/index.mjs","../node_modules/@nextcloud/vue/dist/chunks/platform-CC2ecGvV.mjs","../node_modules/@nextcloud/vue/dist/composables/useHotKey/index.mjs","../node_modules/@nextcloud/vue/dist/functions/isDarkTheme/index.mjs","../node_modules/@nextcloud/vue/dist/chunks/constants-Bls5liKo.mjs","../node_modules/@nextcloud/vue/dist/composables/useIsDarkTheme/index.mjs","../node_modules/@nextcloud/vue/dist/composables/useIsFullscreen/index.mjs","../node_modules/@nextcloud/vue/dist/composables/useIsMobile/index.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcHeaderMenu-DfO7ghiM.mjs","../node_modules/vue-material-design-icons/BellOutline.vue","../node_modules/vue-material-design-icons/Close.vue","../node_modules/vue-material-design-icons/MessageOutline.vue","../node_modules/@nextcloud/capabilities/node_modules/@nextcloud/initial-state/dist/index.mjs","../node_modules/@nextcloud/capabilities/dist/index.mjs","../node_modules/vue-material-design-icons/Bell.vue","../src/Components/IconNotification.vue","../node_modules/@nextcloud/vue/dist/chunks/NcDateTime.vue_vue_type_script_setup_true_lang-BhB8yA4U.mjs","../node_modules/@ungap/structured-clone/esm/types.js","../node_modules/@ungap/structured-clone/esm/deserialize.js","../node_modules/@ungap/structured-clone/esm/serialize.js","../node_modules/@ungap/structured-clone/esm/index.js","../node_modules/hast-util-is-element/lib/index.js","../node_modules/is-absolute-url/index.js","../node_modules/space-separated-tokens/index.js","../node_modules/unist-util-is/lib/index.js","../node_modules/unist-util-visit-parents/lib/color.js","../node_modules/unist-util-visit-parents/lib/index.js","../node_modules/unist-util-visit/lib/index.js","../node_modules/rehype-external-links/lib/index.js","../node_modules/comma-separated-tokens/index.js","../node_modules/devlop/lib/default.js","../node_modules/estree-util-is-identifier-name/lib/index.js","../node_modules/hast-util-whitespace/lib/index.js","../node_modules/property-information/lib/util/schema.js","../node_modules/property-information/lib/util/merge.js","../node_modules/property-information/lib/normalize.js","../node_modules/property-information/lib/util/info.js","../node_modules/property-information/lib/util/types.js","../node_modules/property-information/lib/util/defined-info.js","../node_modules/property-information/lib/util/create.js","../node_modules/property-information/lib/aria.js","../node_modules/property-information/lib/util/case-sensitive-transform.js","../node_modules/property-information/lib/util/case-insensitive-transform.js","../node_modules/property-information/lib/html.js","../node_modules/property-information/lib/svg.js","../node_modules/property-information/lib/xlink.js","../node_modules/property-information/lib/xmlns.js","../node_modules/property-information/lib/xml.js","../node_modules/property-information/lib/hast-to-react.js","../node_modules/property-information/lib/find.js","../node_modules/property-information/index.js","../node_modules/inline-style-parser/index.js","../node_modules/style-to-object/cjs/index.js","../node_modules/style-to-js/cjs/utilities.js","../node_modules/style-to-js/cjs/index.js","../node_modules/unist-util-position/lib/index.js","../node_modules/unist-util-stringify-position/lib/index.js","../node_modules/vfile-message/lib/index.js","../node_modules/hast-util-to-jsx-runtime/lib/index.js","../node_modules/rehype-react/lib/index.js","../node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp/index.js","../node_modules/mdast-util-find-and-replace/lib/index.js","../node_modules/mdast-util-newline-to-break/lib/index.js","../node_modules/remark-breaks/lib/index.js","../node_modules/mdast-util-to-string/lib/index.js","../node_modules/decode-named-character-reference/index.dom.js","../node_modules/micromark-util-chunked/index.js","../node_modules/micromark-util-combine-extensions/index.js","../node_modules/micromark-util-decode-numeric-character-reference/index.js","../node_modules/micromark-util-normalize-identifier/index.js","../node_modules/micromark-util-character/index.js","../node_modules/micromark-util-sanitize-uri/index.js","../node_modules/micromark-factory-space/index.js","../node_modules/micromark/lib/initialize/content.js","../node_modules/micromark/lib/initialize/document.js","../node_modules/micromark-util-classify-character/index.js","../node_modules/micromark-util-resolve-all/index.js","../node_modules/micromark-core-commonmark/lib/attention.js","../node_modules/micromark-core-commonmark/lib/autolink.js","../node_modules/micromark-core-commonmark/lib/blank-line.js","../node_modules/micromark-core-commonmark/lib/block-quote.js","../node_modules/micromark-core-commonmark/lib/character-escape.js","../node_modules/micromark-core-commonmark/lib/character-reference.js","../node_modules/micromark-core-commonmark/lib/code-fenced.js","../node_modules/micromark-core-commonmark/lib/code-indented.js","../node_modules/micromark-core-commonmark/lib/code-text.js","../node_modules/micromark-util-subtokenize/lib/splice-buffer.js","../node_modules/micromark-util-subtokenize/index.js","../node_modules/micromark-core-commonmark/lib/content.js","../node_modules/micromark-factory-destination/index.js","../node_modules/micromark-factory-label/index.js","../node_modules/micromark-factory-title/index.js","../node_modules/micromark-factory-whitespace/index.js","../node_modules/micromark-core-commonmark/lib/definition.js","../node_modules/micromark-core-commonmark/lib/hard-break-escape.js","../node_modules/micromark-core-commonmark/lib/heading-atx.js","../node_modules/micromark-util-html-tag-name/index.js","../node_modules/micromark-core-commonmark/lib/html-flow.js","../node_modules/micromark-core-commonmark/lib/html-text.js","../node_modules/micromark-core-commonmark/lib/label-end.js","../node_modules/micromark-core-commonmark/lib/label-start-image.js","../node_modules/micromark-core-commonmark/lib/label-start-link.js","../node_modules/micromark-core-commonmark/lib/line-ending.js","../node_modules/micromark-core-commonmark/lib/thematic-break.js","../node_modules/micromark-core-commonmark/lib/list.js","../node_modules/micromark-core-commonmark/lib/setext-underline.js","../node_modules/micromark/lib/initialize/flow.js","../node_modules/micromark/lib/initialize/text.js","../node_modules/micromark/lib/constructs.js","../node_modules/micromark/lib/create-tokenizer.js","../node_modules/micromark/lib/parse.js","../node_modules/micromark/lib/postprocess.js","../node_modules/micromark/lib/preprocess.js","../node_modules/micromark-util-decode-string/index.js","../node_modules/mdast-util-from-markdown/lib/index.js","../node_modules/remark-parse/lib/index.js","../node_modules/mdast-util-to-hast/lib/handlers/blockquote.js","../node_modules/mdast-util-to-hast/lib/handlers/break.js","../node_modules/mdast-util-to-hast/lib/handlers/code.js","../node_modules/mdast-util-to-hast/lib/handlers/delete.js","../node_modules/mdast-util-to-hast/lib/handlers/emphasis.js","../node_modules/mdast-util-to-hast/lib/handlers/footnote-reference.js","../node_modules/mdast-util-to-hast/lib/handlers/heading.js","../node_modules/mdast-util-to-hast/lib/handlers/html.js","../node_modules/mdast-util-to-hast/lib/revert.js","../node_modules/mdast-util-to-hast/lib/handlers/image-reference.js","../node_modules/mdast-util-to-hast/lib/handlers/image.js","../node_modules/mdast-util-to-hast/lib/handlers/inline-code.js","../node_modules/mdast-util-to-hast/lib/handlers/link-reference.js","../node_modules/mdast-util-to-hast/lib/handlers/link.js","../node_modules/mdast-util-to-hast/lib/handlers/list-item.js","../node_modules/mdast-util-to-hast/lib/handlers/list.js","../node_modules/mdast-util-to-hast/lib/handlers/paragraph.js","../node_modules/mdast-util-to-hast/lib/handlers/root.js","../node_modules/mdast-util-to-hast/lib/handlers/strong.js","../node_modules/mdast-util-to-hast/lib/handlers/table.js","../node_modules/mdast-util-to-hast/lib/handlers/table-row.js","../node_modules/mdast-util-to-hast/lib/handlers/table-cell.js","../node_modules/trim-lines/index.js","../node_modules/mdast-util-to-hast/lib/handlers/text.js","../node_modules/mdast-util-to-hast/lib/handlers/thematic-break.js","../node_modules/mdast-util-to-hast/lib/handlers/index.js","../node_modules/mdast-util-to-hast/lib/footer.js","../node_modules/mdast-util-to-hast/lib/state.js","../node_modules/mdast-util-to-hast/lib/index.js","../node_modules/remark-rehype/lib/index.js","../node_modules/mdast-squeeze-paragraphs/lib/index.js","../node_modules/remark-unlink-protocols/lib/index.js","../node_modules/bail/index.js","../node_modules/extend/index.js","../node_modules/is-plain-obj/index.js","../node_modules/trough/lib/index.js","../node_modules/vfile/lib/minpath.browser.js","../node_modules/vfile/lib/minproc.browser.js","../node_modules/vfile/lib/minurl.shared.js","../node_modules/vfile/lib/minurl.browser.js","../node_modules/vfile/lib/index.js","../node_modules/unified/lib/callable-instance.js","../node_modules/unified/lib/index.js","../node_modules/@nextcloud/vue/node_modules/@nextcloud/sharing/dist/public.js","../node_modules/@nextcloud/vue/dist/chunks/customPickerElements-4pQTZUnk.mjs","../node_modules/unist-builder/lib/index.js","../node_modules/@nextcloud/vue/dist/chunks/autolink-U5pBzLgI.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcTextField.vue_vue_type_script_setup_true_lang-C7tMhmsN.mjs","../node_modules/@nextcloud/vue/dist/chunks/referencePickerModal-B2XHvg0V.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcRichText-jQc4sfgS.mjs","../src/Components/ActionButton.vue","../src/Components/Parameters/DefaultParameter.vue","../src/Components/Parameters/FileParameter.vue","../node_modules/@vueuse/components/index.mjs","../node_modules/@nextcloud/vue/dist/functions/contactsMenu/index.mjs","../node_modules/vite-plugin-node-polyfills/shims/buffer/dist/index.cjs","../node_modules/safe-buffer/index.js","../node_modules/randombytes/browser.js","../node_modules/inherits/inherits_browser.js","../node_modules/events/events.js","../node_modules/readable-stream/lib/internal/streams/stream-browser.js","../node_modules/has-symbols/shams.js","../node_modules/has-tostringtag/shams.js","../node_modules/es-object-atoms/index.js","../node_modules/es-errors/index.js","../node_modules/es-errors/eval.js","../node_modules/es-errors/range.js","../node_modules/es-errors/ref.js","../node_modules/es-errors/syntax.js","../node_modules/es-errors/type.js","../node_modules/es-errors/uri.js","../node_modules/math-intrinsics/abs.js","../node_modules/math-intrinsics/floor.js","../node_modules/math-intrinsics/max.js","../node_modules/math-intrinsics/min.js","../node_modules/math-intrinsics/pow.js","../node_modules/math-intrinsics/round.js","../node_modules/math-intrinsics/isNaN.js","../node_modules/math-intrinsics/sign.js","../node_modules/gopd/gOPD.js","../node_modules/gopd/index.js","../node_modules/es-define-property/index.js","../node_modules/has-symbols/index.js","../node_modules/get-proto/Reflect.getPrototypeOf.js","../node_modules/get-proto/Object.getPrototypeOf.js","../node_modules/function-bind/implementation.js","../node_modules/function-bind/index.js","../node_modules/call-bind-apply-helpers/functionCall.js","../node_modules/call-bind-apply-helpers/functionApply.js","../node_modules/call-bind-apply-helpers/reflectApply.js","../node_modules/call-bind-apply-helpers/actualApply.js","../node_modules/call-bind-apply-helpers/index.js","../node_modules/dunder-proto/get.js","../node_modules/get-proto/index.js","../node_modules/hasown/index.js","../node_modules/get-intrinsic/index.js","../node_modules/call-bound/index.js","../node_modules/is-arguments/index.js","../node_modules/is-regex/index.js","../node_modules/safe-regex-test/index.js","../node_modules/is-generator-function/index.js","../node_modules/is-callable/index.js","../node_modules/for-each/index.js","../node_modules/possible-typed-array-names/index.js","../node_modules/available-typed-arrays/index.js","../node_modules/define-data-property/index.js","../node_modules/has-property-descriptors/index.js","../node_modules/set-function-length/index.js","../node_modules/call-bind-apply-helpers/applyBind.js","../node_modules/call-bind/index.js","../node_modules/which-typed-array/index.js","../node_modules/is-typed-array/index.js","../node_modules/util/support/types.js","../node_modules/util/support/isBufferBrowser.js","../node_modules/util/util.js","../node_modules/readable-stream/lib/internal/streams/buffer_list.js","../node_modules/readable-stream/lib/internal/streams/destroy.js","../node_modules/readable-stream/errors-browser.js","../node_modules/readable-stream/lib/internal/streams/state.js","../node_modules/util-deprecate/browser.js","../node_modules/readable-stream/lib/_stream_writable.js","../node_modules/readable-stream/lib/_stream_duplex.js","../node_modules/string_decoder/lib/string_decoder.js","../node_modules/readable-stream/lib/internal/streams/end-of-stream.js","../node_modules/readable-stream/lib/internal/streams/async_iterator.js","../node_modules/readable-stream/lib/internal/streams/from-browser.js","../node_modules/readable-stream/lib/_stream_readable.js","../node_modules/readable-stream/lib/_stream_transform.js","../node_modules/readable-stream/lib/_stream_passthrough.js","../node_modules/readable-stream/lib/internal/streams/pipeline.js","../node_modules/stream-browserify/index.js","../node_modules/hash-base/index.js","../node_modules/md5.js/index.js","../node_modules/ripemd160/index.js","../node_modules/to-buffer/node_modules/isarray/index.js","../node_modules/typed-array-buffer/index.js","../node_modules/to-buffer/index.js","../node_modules/sha.js/hash.js","../node_modules/sha.js/sha.js","../node_modules/sha.js/sha1.js","../node_modules/sha.js/sha256.js","../node_modules/sha.js/sha224.js","../node_modules/sha.js/sha512.js","../node_modules/sha.js/sha384.js","../node_modules/sha.js/index.js","../node_modules/cipher-base/index.js","../node_modules/create-hash/browser.js","../node_modules/create-hmac/legacy.js","../node_modules/create-hash/md5.js","../node_modules/create-hmac/browser.js","../node_modules/browserify-sign/algos.js","../node_modules/pbkdf2/lib/precondition.js","../node_modules/pbkdf2/lib/default-encoding.js","../node_modules/pbkdf2/node_modules/create-hash/make-hash.js","../node_modules/pbkdf2/node_modules/create-hash/md5.js","../node_modules/pbkdf2/node_modules/hash-base/index.js","../node_modules/pbkdf2/node_modules/ripemd160/index.js","../node_modules/pbkdf2/lib/to-buffer.js","../node_modules/pbkdf2/lib/sync-browser.js","../node_modules/pbkdf2/lib/async.js","../node_modules/pbkdf2/browser.js","../node_modules/des.js/lib/des/utils.js","../node_modules/minimalistic-assert/index.js","../node_modules/des.js/lib/des/cipher.js","../node_modules/des.js/lib/des/des.js","../node_modules/des.js/lib/des/cbc.js","../node_modules/des.js/lib/des/ede.js","../node_modules/des.js/lib/des.js","../node_modules/browserify-des/index.js","../node_modules/browserify-aes/modes/ecb.js","../node_modules/buffer-xor/index.js","../node_modules/browserify-aes/modes/cbc.js","../node_modules/browserify-aes/modes/cfb.js","../node_modules/browserify-aes/modes/cfb8.js","../node_modules/browserify-aes/modes/cfb1.js","../node_modules/browserify-aes/modes/ofb.js","../node_modules/browserify-aes/incr32.js","../node_modules/browserify-aes/modes/ctr.js","../node_modules/browserify-aes/modes/index.js","../node_modules/browserify-aes/aes.js","../node_modules/browserify-aes/ghash.js","../node_modules/browserify-aes/authCipher.js","../node_modules/browserify-aes/streamCipher.js","../node_modules/evp_bytestokey/index.js","../node_modules/browserify-aes/encrypter.js","../node_modules/browserify-aes/decrypter.js","../node_modules/browserify-aes/browser.js","../node_modules/browserify-des/modes.js","../node_modules/browserify-cipher/browser.js","../node_modules/diffie-hellman/node_modules/bn.js/lib/bn.js","../node_modules/miller-rabin/node_modules/bn.js/lib/bn.js","../node_modules/brorand/index.js","../node_modules/miller-rabin/lib/mr.js","../node_modules/diffie-hellman/lib/generatePrime.js","../node_modules/diffie-hellman/lib/dh.js","../node_modules/diffie-hellman/browser.js","../node_modules/process-nextick-args/index.js","../node_modules/isarray/index.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/internal/streams/stream-browser.js","../node_modules/browserify-sign/node_modules/readable-stream/node_modules/safe-buffer/index.js","../node_modules/core-util-is/lib/util.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/internal/streams/BufferList.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/internal/streams/destroy.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/_stream_writable.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/_stream_duplex.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/_stream_readable.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/_stream_transform.js","../node_modules/browserify-sign/node_modules/readable-stream/lib/_stream_passthrough.js","../node_modules/browserify-sign/node_modules/readable-stream/readable-browser.js","../node_modules/bn.js/lib/bn.js","../node_modules/browserify-rsa/index.js","../node_modules/elliptic/node_modules/bn.js/lib/bn.js","../node_modules/minimalistic-crypto-utils/lib/utils.js","../node_modules/elliptic/lib/elliptic/utils.js","../node_modules/elliptic/lib/elliptic/curve/base.js","../node_modules/elliptic/lib/elliptic/curve/short.js","../node_modules/elliptic/lib/elliptic/curve/mont.js","../node_modules/elliptic/lib/elliptic/curve/edwards.js","../node_modules/elliptic/lib/elliptic/curve/index.js","../node_modules/hash.js/lib/hash/utils.js","../node_modules/hash.js/lib/hash/common.js","../node_modules/hash.js/lib/hash/sha/common.js","../node_modules/hash.js/lib/hash/sha/1.js","../node_modules/hash.js/lib/hash/sha/256.js","../node_modules/hash.js/lib/hash/sha/224.js","../node_modules/hash.js/lib/hash/sha/512.js","../node_modules/hash.js/lib/hash/sha/384.js","../node_modules/hash.js/lib/hash/sha.js","../node_modules/hash.js/lib/hash/ripemd.js","../node_modules/hash.js/lib/hash/hmac.js","../node_modules/hash.js/lib/hash.js","../node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js","../node_modules/elliptic/lib/elliptic/curves.js","../node_modules/hmac-drbg/lib/hmac-drbg.js","../node_modules/elliptic/lib/elliptic/ec/key.js","../node_modules/elliptic/lib/elliptic/ec/signature.js","../node_modules/elliptic/lib/elliptic/ec/index.js","../node_modules/elliptic/lib/elliptic/eddsa/key.js","../node_modules/elliptic/lib/elliptic/eddsa/signature.js","../node_modules/elliptic/lib/elliptic/eddsa/index.js","../node_modules/elliptic/lib/elliptic.js","../node_modules/asn1.js/node_modules/bn.js/lib/bn.js","../node_modules/vm-browserify/index.js","../node_modules/asn1.js/lib/asn1/api.js","../node_modules/asn1.js/lib/asn1/base/reporter.js","../node_modules/asn1.js/lib/asn1/base/buffer.js","../node_modules/asn1.js/lib/asn1/base/node.js","../node_modules/asn1.js/lib/asn1/base/index.js","../node_modules/asn1.js/lib/asn1/constants/der.js","../node_modules/asn1.js/lib/asn1/constants/index.js","../node_modules/asn1.js/lib/asn1/decoders/der.js","../node_modules/asn1.js/lib/asn1/decoders/pem.js","../node_modules/asn1.js/lib/asn1/decoders/index.js","../node_modules/asn1.js/lib/asn1/encoders/der.js","../node_modules/asn1.js/lib/asn1/encoders/pem.js","../node_modules/asn1.js/lib/asn1/encoders/index.js","../node_modules/asn1.js/lib/asn1.js","../node_modules/parse-asn1/certificate.js","../node_modules/parse-asn1/asn1.js","../node_modules/parse-asn1/fixProc.js","../node_modules/parse-asn1/index.js","../node_modules/browserify-sign/browser/sign.js","../node_modules/browserify-sign/browser/verify.js","../node_modules/browserify-sign/browser/index.js","../node_modules/create-ecdh/node_modules/bn.js/lib/bn.js","../node_modules/create-ecdh/browser.js","../node_modules/public-encrypt/mgf.js","../node_modules/public-encrypt/xor.js","../node_modules/public-encrypt/node_modules/bn.js/lib/bn.js","../node_modules/public-encrypt/withPublic.js","../node_modules/public-encrypt/publicEncrypt.js","../node_modules/public-encrypt/privateDecrypt.js","../node_modules/public-encrypt/browser.js","../node_modules/randomfill/browser.js","../node_modules/crypto-browserify/index.js","../node_modules/@nextcloud/vue/dist/chunks/colors-BZi52VLk.mjs","../node_modules/@nextcloud/vue/dist/functions/usernameToColor/index.mjs","../node_modules/striptags/src/striptags.js","../node_modules/@nextcloud/vue/dist/chunks/NcMentionBubble.vue_vue_type_style_index_0_scoped_45238efd_lang-D6LzDiYf.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcUserStatusIcon-DiX6zPGT.mjs","../node_modules/@nextcloud/vue/dist/chunks/actionGlobal-BZFdtdJL.mjs","../node_modules/@nextcloud/vue/dist/chunks/actionText-DYzDdbVe.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcActionButton-D8JTFCmI.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcActionLink-afakPM_N.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcActionRouter-oT-YU_jf.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcActionText-uKvLcEY6.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcAvatar-Bdy7vKd8.mjs","../node_modules/@nextcloud/vue/dist/chunks/NcUserBubble-CklD5ttg.mjs","../src/Components/Parameters/UserParameter.vue","../src/Components/NotificationItem.vue","../src/services/notificationsService.js","../node_modules/howler/dist/howler.js","../src/services/webNotificationsService.js","../src/NotificationsApp.vue"],"sourcesContent":["import { g as getCanonicalLocale, a as getLanguage } from \"./chunks/translation-DoG5ZELJ.mjs\";\nimport { b, e, i, l, d, r, c, s, t, t as t2, d as d2, u } from \"./chunks/translation-DoG5ZELJ.mjs\";\n/*!\n * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: GPL-3.0-or-later\n */\nfunction getFirstDay() {\n if (typeof globalThis.firstDay !== \"undefined\") {\n return globalThis.firstDay;\n }\n const intl = new Intl.Locale(getCanonicalLocale());\n const weekInfo = intl.getWeekInfo?.() ?? intl.weekInfo;\n if (weekInfo) {\n return weekInfo.firstDay % 7;\n }\n return 1;\n}\nfunction getDayNames() {\n if (typeof globalThis.dayNames !== \"undefined\") {\n return globalThis.dayNames;\n }\n const locale = getCanonicalLocale();\n return [\n (/* @__PURE__ */ new Date(\"1970-01-04T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-01-05T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-01-06T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-01-07T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-01-08T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-01-09T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-01-10T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"long\" })\n ];\n}\nfunction getDayNamesShort() {\n if (typeof globalThis.dayNamesShort !== \"undefined\") {\n return globalThis.dayNamesShort;\n }\n const locale = getCanonicalLocale();\n return [\n (/* @__PURE__ */ new Date(\"1970-01-04T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-01-05T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-01-06T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-01-07T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-01-08T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-01-09T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-01-10T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"short\" })\n ];\n}\nfunction getDayNamesMin() {\n if (typeof globalThis.dayNamesMin !== \"undefined\") {\n return globalThis.dayNamesMin;\n }\n const locale = getCanonicalLocale();\n return [\n (/* @__PURE__ */ new Date(\"1970-01-04T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" }),\n (/* @__PURE__ */ new Date(\"1970-01-05T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" }),\n (/* @__PURE__ */ new Date(\"1970-01-06T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" }),\n (/* @__PURE__ */ new Date(\"1970-01-07T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" }),\n (/* @__PURE__ */ new Date(\"1970-01-08T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" }),\n (/* @__PURE__ */ new Date(\"1970-01-09T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" }),\n (/* @__PURE__ */ new Date(\"1970-01-10T00:00:00.000Z\")).toLocaleDateString(locale, { weekday: \"narrow\" })\n ];\n}\nfunction getMonthNames() {\n if (typeof globalThis.monthNames !== \"undefined\") {\n return globalThis.monthNames;\n }\n const locale = getCanonicalLocale();\n return [\n (/* @__PURE__ */ new Date(\"1970-01-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-02-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-03-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-04-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-05-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-06-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-07-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-08-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-09-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-10-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-11-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" }),\n (/* @__PURE__ */ new Date(\"1970-12-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"long\" })\n ];\n}\nfunction getMonthNamesShort() {\n if (typeof globalThis.monthNamesShort !== \"undefined\") {\n return globalThis.monthNamesShort;\n }\n const locale = getCanonicalLocale();\n return [\n (/* @__PURE__ */ new Date(\"1970-01-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-02-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-03-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-04-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-05-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-06-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-07-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-08-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-09-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-10-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-11-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" }),\n (/* @__PURE__ */ new Date(\"1970-12-01T00:00:00.000Z\")).toLocaleDateString(locale, { month: \"short\" })\n ];\n}\n/*!\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: GPL-3.0-or-later\n */\nfunction formatRelativeTime(timestamp = Date.now(), opts = {}) {\n const options = {\n ignoreSeconds: false,\n language: getLanguage(),\n relativeTime: \"long\",\n ...opts\n };\n const date = new Date(timestamp);\n const formatter = new Intl.RelativeTimeFormat([options.language, getLanguage()], { numeric: \"auto\", style: options.relativeTime });\n const diff = date.getTime() - Date.now();\n const seconds = diff / 1e3;\n if (Math.abs(seconds) < 59.5) {\n return options.ignoreSeconds || formatter.format(Math.round(seconds), \"second\");\n }\n const minutes = seconds / 60;\n if (Math.abs(minutes) <= 59) {\n return formatter.format(Math.round(minutes), \"minute\");\n }\n const hours = minutes / 60;\n if (Math.abs(hours) < 23.5) {\n return formatter.format(Math.round(hours), \"hour\");\n }\n const days = hours / 24;\n if (Math.abs(days) < 6.5) {\n return formatter.format(Math.round(days), \"day\");\n }\n if (Math.abs(days) < 27.5) {\n const weeks = days / 7;\n return formatter.format(Math.round(weeks), \"week\");\n }\n const months = days / 30;\n const format = Math.abs(months) < 11 ? { month: options.relativeTime, day: \"numeric\" } : { year: options.relativeTime === \"narrow\" ? \"2-digit\" : \"numeric\", month: options.relativeTime };\n const dateTimeFormatter = new Intl.DateTimeFormat([options.language, getLanguage()], format);\n return dateTimeFormatter.format(date);\n}\nexport {\n formatRelativeTime,\n getCanonicalLocale,\n getDayNames,\n getDayNamesMin,\n getDayNamesShort,\n getFirstDay,\n getLanguage,\n b as getLocale,\n getMonthNames,\n getMonthNamesShort,\n e as getPlural,\n i as isRTL,\n l as loadTranslations,\n d as n,\n r as register,\n c as setLanguage,\n s as setLocale,\n t,\n t2 as translate,\n d2 as translatePlural,\n u as unregister\n};\n//# sourceMappingURL=index.mjs.map\n","import '../assets/NcIconSvgWrapper-D6qXQDNo.css';\nimport { defineComponent, useCssVars, computed, warn, createElementBlock, openBlock, normalizeClass, createElementVNode } from \"vue\";\nimport DOMPurify from \"dompurify\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst _hoisted_1 = [\"aria-hidden\", \"aria-label\"];\nconst _hoisted_2 = {\n key: 0,\n viewBox: \"0 0 24 24\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_3 = [\"d\"];\nconst _hoisted_4 = [\"innerHTML\"];\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcIconSvgWrapper\",\n props: {\n directional: { type: Boolean },\n inline: { type: Boolean },\n svg: { default: \"\" },\n name: { default: void 0 },\n path: { default: \"\" },\n size: { default: 20 }\n },\n setup(__props) {\n useCssVars((_ctx) => ({\n \"0c3ef411\": iconSize.value\n }));\n const props = __props;\n const iconSize = computed(() => typeof props.size === \"number\" ? `${props.size}px` : props.size);\n const cleanSvg = computed(() => {\n if (!props.svg || props.path) {\n return;\n }\n const svg = DOMPurify.sanitize(props.svg);\n const svgDocument = new DOMParser().parseFromString(svg, \"image/svg+xml\");\n if (svgDocument.querySelector(\"parsererror\")) {\n warn(\"SVG is not valid\");\n return \"\";\n }\n if (svgDocument.documentElement.id) {\n svgDocument.documentElement.removeAttribute(\"id\");\n }\n return svgDocument.documentElement.outerHTML;\n });\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"span\", {\n \"aria-hidden\": _ctx.name ? void 0 : \"true\",\n \"aria-label\": _ctx.name || void 0,\n class: normalizeClass([\"icon-vue\", {\n \"icon-vue--directional\": _ctx.directional,\n \"icon-vue--inline\": _ctx.inline\n }]),\n role: \"img\"\n }, [\n !cleanSvg.value ? (openBlock(), createElementBlock(\"svg\", _hoisted_2, [\n createElementVNode(\"path\", { d: _ctx.path }, null, 8, _hoisted_3)\n ])) : (openBlock(), createElementBlock(\"span\", {\n key: 1,\n innerHTML: cleanSvg.value\n }, null, 8, _hoisted_4))\n ], 10, _hoisted_1);\n };\n }\n});\nconst NcIconSvgWrapper = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-5a43cff9\"]]);\nexport {\n NcIconSvgWrapper as N\n};\n//# sourceMappingURL=NcIconSvgWrapper-5AA93z-F.mjs.map\n","var mdiAlert = \"M13 14H11V9H13M13 18H11V16H13M1 21H23L12 2L1 21Z\";\nvar mdiAlertCircle = \"M13,13H11V7H13M13,17H11V15H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2Z\";\nvar mdiAlertDecagram = \"M23,12L20.56,9.22L20.9,5.54L17.29,4.72L15.4,1.54L12,3L8.6,1.54L6.71,4.72L3.1,5.53L3.44,9.21L1,12L3.44,14.78L3.1,18.47L6.71,19.29L8.6,22.47L12,21L15.4,22.46L17.29,19.28L20.9,18.46L20.56,14.78L23,12M13,17H11V15H13V17M13,13H11V7H13V13Z\";\nvar mdiArrowLeft = \"M20,11V13H8L13.5,18.5L12.08,19.92L4.16,12L12.08,4.08L13.5,5.5L8,11H20Z\";\nvar mdiArrowRight = \"M4,11V13H16L10.5,18.5L11.92,19.92L19.84,12L11.92,4.08L10.5,5.5L16,11H4Z\";\nvar mdiCalendarBlank = \"M19,19H5V8H19M16,1V3H8V1H6V3H5C3.89,3 3,3.89 3,5V19A2,2 0 0,0 5,21H19A2,2 0 0,0 21,19V5C21,3.89 20.1,3 19,3H18V1\";\nvar mdiCheck = \"M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z\";\nvar mdiCheckboxMarkedCircle = \"M10,17L5,12L6.41,10.58L10,14.17L17.59,6.58L19,8M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2Z\";\nvar mdiChevronDown = \"M7.41,8.58L12,13.17L16.59,8.58L18,10L12,16L6,10L7.41,8.58Z\";\nvar mdiChevronLeft = \"M15.41,16.58L10.83,12L15.41,7.41L14,6L8,12L14,18L15.41,16.58Z\";\nvar mdiChevronRight = \"M8.59,16.58L13.17,12L8.59,7.41L10,6L16,12L10,18L8.59,16.58Z\";\nvar mdiChevronUp = \"M7.41,15.41L12,10.83L16.59,15.41L18,14L12,8L6,14L7.41,15.41Z\";\nvar mdiClock = \"M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2M16.2,16.2L11,13V7H12.5V12.2L17,14.9L16.2,16.2Z\";\nvar mdiClose = \"M19,6.41L17.59,5L12,10.59L6.41,5L5,6.41L10.59,12L5,17.59L6.41,19L12,13.41L17.59,19L19,17.59L13.41,12L19,6.41Z\";\nvar mdiCog = \"M12,15.5A3.5,3.5 0 0,1 8.5,12A3.5,3.5 0 0,1 12,8.5A3.5,3.5 0 0,1 15.5,12A3.5,3.5 0 0,1 12,15.5M19.43,12.97C19.47,12.65 19.5,12.33 19.5,12C19.5,11.67 19.47,11.34 19.43,11L21.54,9.37C21.73,9.22 21.78,8.95 21.66,8.73L19.66,5.27C19.54,5.05 19.27,4.96 19.05,5.05L16.56,6.05C16.04,5.66 15.5,5.32 14.87,5.07L14.5,2.42C14.46,2.18 14.25,2 14,2H10C9.75,2 9.54,2.18 9.5,2.42L9.13,5.07C8.5,5.32 7.96,5.66 7.44,6.05L4.95,5.05C4.73,4.96 4.46,5.05 4.34,5.27L2.34,8.73C2.21,8.95 2.27,9.22 2.46,9.37L4.57,11C4.53,11.34 4.5,11.67 4.5,12C4.5,12.33 4.53,12.65 4.57,12.97L2.46,14.63C2.27,14.78 2.21,15.05 2.34,15.27L4.34,18.73C4.46,18.95 4.73,19.03 4.95,18.95L7.44,17.94C7.96,18.34 8.5,18.68 9.13,18.93L9.5,21.58C9.54,21.82 9.75,22 10,22H14C14.25,22 14.46,21.82 14.5,21.58L14.87,18.93C15.5,18.67 16.04,18.34 16.56,17.94L19.05,18.95C19.27,19.03 19.54,18.95 19.66,18.73L21.66,15.27C21.78,15.05 21.73,14.78 21.54,14.63L19.43,12.97Z\";\nvar mdiCogOutline = \"M12,8A4,4 0 0,1 16,12A4,4 0 0,1 12,16A4,4 0 0,1 8,12A4,4 0 0,1 12,8M12,10A2,2 0 0,0 10,12A2,2 0 0,0 12,14A2,2 0 0,0 14,12A2,2 0 0,0 12,10M10,22C9.75,22 9.54,21.82 9.5,21.58L9.13,18.93C8.5,18.68 7.96,18.34 7.44,17.94L4.95,18.95C4.73,19.03 4.46,18.95 4.34,18.73L2.34,15.27C2.21,15.05 2.27,14.78 2.46,14.63L4.57,12.97L4.5,12L4.57,11L2.46,9.37C2.27,9.22 2.21,8.95 2.34,8.73L4.34,5.27C4.46,5.05 4.73,4.96 4.95,5.05L7.44,6.05C7.96,5.66 8.5,5.32 9.13,5.07L9.5,2.42C9.54,2.18 9.75,2 10,2H14C14.25,2 14.46,2.18 14.5,2.42L14.87,5.07C15.5,5.32 16.04,5.66 16.56,6.05L19.05,5.05C19.27,4.96 19.54,5.05 19.66,5.27L21.66,8.73C21.79,8.95 21.73,9.22 21.54,9.37L19.43,11L19.5,12L19.43,13L21.54,14.63C21.73,14.78 21.79,15.05 21.66,15.27L19.66,18.73C19.54,18.95 19.27,19.04 19.05,18.95L16.56,17.95C16.04,18.34 15.5,18.68 14.87,18.93L14.5,21.58C14.46,21.82 14.25,22 14,22H10M11.25,4L10.88,6.61C9.68,6.86 8.62,7.5 7.85,8.39L5.44,7.35L4.69,8.65L6.8,10.2C6.4,11.37 6.4,12.64 6.8,13.8L4.68,15.36L5.43,16.66L7.86,15.62C8.63,16.5 9.68,17.14 10.87,17.38L11.24,20H12.76L13.13,17.39C14.32,17.14 15.37,16.5 16.14,15.62L18.57,16.66L19.32,15.36L17.2,13.81C17.6,12.64 17.6,11.37 17.2,10.2L19.31,8.65L18.56,7.35L16.15,8.39C15.38,7.5 14.32,6.86 13.12,6.62L12.75,4H11.25Z\";\nvar mdiCreation = \"M19,1L17.74,3.75L15,5L17.74,6.26L19,9L20.25,6.26L23,5L20.25,3.75M9,4L6.5,9.5L1,12L6.5,14.5L9,20L11.5,14.5L17,12L11.5,9.5M19,15L17.74,17.74L15,19L17.74,20.25L19,23L20.25,20.25L23,19L20.25,17.74\";\nvar mdiDotsHorizontal = \"M16,12A2,2 0 0,1 18,10A2,2 0 0,1 20,12A2,2 0 0,1 18,14A2,2 0 0,1 16,12M10,12A2,2 0 0,1 12,10A2,2 0 0,1 14,12A2,2 0 0,1 12,14A2,2 0 0,1 10,12M4,12A2,2 0 0,1 6,10A2,2 0 0,1 8,12A2,2 0 0,1 6,14A2,2 0 0,1 4,12Z\";\nvar mdiEye = \"M12,9A3,3 0 0,0 9,12A3,3 0 0,0 12,15A3,3 0 0,0 15,12A3,3 0 0,0 12,9M12,17A5,5 0 0,1 7,12A5,5 0 0,1 12,7A5,5 0 0,1 17,12A5,5 0 0,1 12,17M12,4.5C7,4.5 2.73,7.61 1,12C2.73,16.39 7,19.5 12,19.5C17,19.5 21.27,16.39 23,12C21.27,7.61 17,4.5 12,4.5Z\";\nvar mdiEyeOff = \"M11.83,9L15,12.16C15,12.11 15,12.05 15,12A3,3 0 0,0 12,9C11.94,9 11.89,9 11.83,9M7.53,9.8L9.08,11.35C9.03,11.56 9,11.77 9,12A3,3 0 0,0 12,15C12.22,15 12.44,14.97 12.65,14.92L14.2,16.47C13.53,16.8 12.79,17 12,17A5,5 0 0,1 7,12C7,11.21 7.2,10.47 7.53,9.8M2,4.27L4.28,6.55L4.73,7C3.08,8.3 1.78,10 1,12C2.73,16.39 7,19.5 12,19.5C13.55,19.5 15.03,19.2 16.38,18.66L16.81,19.08L19.73,22L21,20.73L3.27,3M12,7A5,5 0 0,1 17,12C17,12.64 16.87,13.26 16.64,13.82L19.57,16.75C21.07,15.5 22.27,13.86 23,12C21.27,7.61 17,4.5 12,4.5C10.6,4.5 9.26,4.75 8,5.2L10.17,7.35C10.74,7.13 11.35,7 12,7Z\";\nvar mdiInformation = \"M13,9H11V7H13M13,17H11V11H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2Z\";\nvar mdiMenu = \"M3,6H21V8H3V6M3,11H21V13H3V11M3,16H21V18H3V16Z\";\nvar mdiMenuOpen = \"M21,15.61L19.59,17L14.58,12L19.59,7L21,8.39L17.44,12L21,15.61M3,6H16V8H3V6M3,13V11H13V13H3M3,18V16H16V18H3Z\";\nvar mdiUndo = \"M12.5,8C9.85,8 7.45,9 5.6,10.6L2,7V16H11L7.38,12.38C8.77,11.22 10.54,10.5 12.5,10.5C16.04,10.5 19.05,12.81 20.1,16L22.47,15.22C21.08,11.03 17.15,8 12.5,8Z\";\nexport {\n mdiUndo as a,\n mdiClose as b,\n mdiChevronRight as c,\n mdiCheck as d,\n mdiAlertCircle as e,\n mdiAlert as f,\n mdiInformation as g,\n mdiCheckboxMarkedCircle as h,\n mdiAlertDecagram as i,\n mdiCreation as j,\n mdiEyeOff as k,\n mdiEye as l,\n mdiArrowRight as m,\n mdiArrowLeft as n,\n mdiDotsHorizontal as o,\n mdiChevronUp as p,\n mdiChevronDown as q,\n mdiChevronLeft as r,\n mdiClock as s,\n mdiCalendarBlank as t,\n mdiCog as u,\n mdiCogOutline as v,\n mdiMenuOpen as w,\n mdiMenu as x\n};\n//# sourceMappingURL=mdi-D_GPbmUY.mjs.map\n","\"use strict\";\nObject.defineProperty(exports, Symbol.toStringTag, { value: \"Module\" });\nfunction loadState(app, key, fallback) {\n const elem = document.querySelector(`#initial-state-${app}-${key}`);\n if (elem === null) {\n if (fallback !== void 0) {\n return fallback;\n }\n throw new Error(`Could not find initial state ${key} of ${app}`);\n }\n try {\n return JSON.parse(atob(elem.value));\n } catch (e) {\n throw new Error(`Could not parse initial state ${key} of ${app}`);\n }\n}\nexports.loadState = loadState;\n","\"use strict\";\nObject.defineProperty(exports, Symbol.toStringTag, { value: \"Module\" });\nconst i = require(\"@nextcloud/initial-state\");\nfunction t() {\n try {\n return i.loadState(\"core\", \"capabilities\");\n } catch {\n return console.debug(\"Could not find capabilities initial state fall back to _oc_capabilities\"), \"_oc_capabilities\" in window ? window._oc_capabilities : {};\n }\n}\nexports.getCapabilities = t;\n","/*! Axios v1.12.2 Copyright (c) 2025 Matt Zabriskie and contributors */\n'use strict';\n\nfunction bind(fn, thisArg) {\n return function wrap() {\n return fn.apply(thisArg, arguments);\n };\n}\n\n// utils is a library of generic helper functions non-specific to axios\n\nconst {toString} = Object.prototype;\nconst {getPrototypeOf} = Object;\nconst {iterator, toStringTag} = Symbol;\n\nconst kindOf = (cache => thing => {\n const str = toString.call(thing);\n return cache[str] || (cache[str] = str.slice(8, -1).toLowerCase());\n})(Object.create(null));\n\nconst kindOfTest = (type) => {\n type = type.toLowerCase();\n return (thing) => kindOf(thing) === type\n};\n\nconst typeOfTest = type => thing => typeof thing === type;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n *\n * @returns {boolean} True if value is an Array, otherwise false\n */\nconst {isArray} = Array;\n\n/**\n * Determine if a value is undefined\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nconst isUndefined = typeOfTest('undefined');\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n && isFunction$1(val.constructor.isBuffer) && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nconst isArrayBuffer = kindOfTest('ArrayBuffer');\n\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n let result;\n if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n result = ArrayBuffer.isView(val);\n } else {\n result = (val) && (val.buffer) && (isArrayBuffer(val.buffer));\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a String, otherwise false\n */\nconst isString = typeOfTest('string');\n\n/**\n * Determine if a value is a Function\n *\n * @param {*} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nconst isFunction$1 = typeOfTest('function');\n\n/**\n * Determine if a value is a Number\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Number, otherwise false\n */\nconst isNumber = typeOfTest('number');\n\n/**\n * Determine if a value is an Object\n *\n * @param {*} thing The value to test\n *\n * @returns {boolean} True if value is an Object, otherwise false\n */\nconst isObject = (thing) => thing !== null && typeof thing === 'object';\n\n/**\n * Determine if a value is a Boolean\n *\n * @param {*} thing The value to test\n * @returns {boolean} True if value is a Boolean, otherwise false\n */\nconst isBoolean = thing => thing === true || thing === false;\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a plain Object, otherwise false\n */\nconst isPlainObject = (val) => {\n if (kindOf(val) !== 'object') {\n return false;\n }\n\n const prototype = getPrototypeOf(val);\n return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(toStringTag in val) && !(iterator in val);\n};\n\n/**\n * Determine if a value is an empty object (safely handles Buffers)\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is an empty object, otherwise false\n */\nconst isEmptyObject = (val) => {\n // Early return for non-objects or Buffers to prevent RangeError\n if (!isObject(val) || isBuffer(val)) {\n return false;\n }\n\n try {\n return Object.keys(val).length === 0 && Object.getPrototypeOf(val) === Object.prototype;\n } catch (e) {\n // Fallback for any other objects that might cause RangeError with Object.keys()\n return false;\n }\n};\n\n/**\n * Determine if a value is a Date\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Date, otherwise false\n */\nconst isDate = kindOfTest('Date');\n\n/**\n * Determine if a value is a File\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a File, otherwise false\n */\nconst isFile = kindOfTest('File');\n\n/**\n * Determine if a value is a Blob\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nconst isBlob = kindOfTest('Blob');\n\n/**\n * Determine if a value is a FileList\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a File, otherwise false\n */\nconst isFileList = kindOfTest('FileList');\n\n/**\n * Determine if a value is a Stream\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nconst isStream = (val) => isObject(val) && isFunction$1(val.pipe);\n\n/**\n * Determine if a value is a FormData\n *\n * @param {*} thing The value to test\n *\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nconst isFormData = (thing) => {\n let kind;\n return thing && (\n (typeof FormData === 'function' && thing instanceof FormData) || (\n isFunction$1(thing.append) && (\n (kind = kindOf(thing)) === 'formdata' ||\n // detect form-data instance\n (kind === 'object' && isFunction$1(thing.toString) && thing.toString() === '[object FormData]')\n )\n )\n )\n};\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nconst isURLSearchParams = kindOfTest('URLSearchParams');\n\nconst [isReadableStream, isRequest, isResponse, isHeaders] = ['ReadableStream', 'Request', 'Response', 'Headers'].map(kindOfTest);\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n *\n * @returns {String} The String freed of excess whitespace\n */\nconst trim = (str) => str.trim ?\n str.trim() : str.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n *\n * @param {Boolean} [allOwnKeys = false]\n * @returns {any}\n */\nfunction forEach(obj, fn, {allOwnKeys = false} = {}) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n let i;\n let l;\n\n // Force an array if not already something iterable\n if (typeof obj !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n\n if (isArray(obj)) {\n // Iterate over array values\n for (i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Buffer check\n if (isBuffer(obj)) {\n return;\n }\n\n // Iterate over object keys\n const keys = allOwnKeys ? Object.getOwnPropertyNames(obj) : Object.keys(obj);\n const len = keys.length;\n let key;\n\n for (i = 0; i < len; i++) {\n key = keys[i];\n fn.call(null, obj[key], key, obj);\n }\n }\n}\n\nfunction findKey(obj, key) {\n if (isBuffer(obj)){\n return null;\n }\n\n key = key.toLowerCase();\n const keys = Object.keys(obj);\n let i = keys.length;\n let _key;\n while (i-- > 0) {\n _key = keys[i];\n if (key === _key.toLowerCase()) {\n return _key;\n }\n }\n return null;\n}\n\nconst _global = (() => {\n /*eslint no-undef:0*/\n if (typeof globalThis !== \"undefined\") return globalThis;\n return typeof self !== \"undefined\" ? self : (typeof window !== 'undefined' ? window : global)\n})();\n\nconst isContextDefined = (context) => !isUndefined(context) && context !== _global;\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n *\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n const {caseless, skipUndefined} = isContextDefined(this) && this || {};\n const result = {};\n const assignValue = (val, key) => {\n const targetKey = caseless && findKey(result, key) || key;\n if (isPlainObject(result[targetKey]) && isPlainObject(val)) {\n result[targetKey] = merge(result[targetKey], val);\n } else if (isPlainObject(val)) {\n result[targetKey] = merge({}, val);\n } else if (isArray(val)) {\n result[targetKey] = val.slice();\n } else if (!skipUndefined || !isUndefined(val)) {\n result[targetKey] = val;\n }\n };\n\n for (let i = 0, l = arguments.length; i < l; i++) {\n arguments[i] && forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n *\n * @param {Boolean} [allOwnKeys]\n * @returns {Object} The resulting value of object a\n */\nconst extend = (a, b, thisArg, {allOwnKeys}= {}) => {\n forEach(b, (val, key) => {\n if (thisArg && isFunction$1(val)) {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n }, {allOwnKeys});\n return a;\n};\n\n/**\n * Remove byte order marker. This catches EF BB BF (the UTF-8 BOM)\n *\n * @param {string} content with BOM\n *\n * @returns {string} content value without BOM\n */\nconst stripBOM = (content) => {\n if (content.charCodeAt(0) === 0xFEFF) {\n content = content.slice(1);\n }\n return content;\n};\n\n/**\n * Inherit the prototype methods from one constructor into another\n * @param {function} constructor\n * @param {function} superConstructor\n * @param {object} [props]\n * @param {object} [descriptors]\n *\n * @returns {void}\n */\nconst inherits = (constructor, superConstructor, props, descriptors) => {\n constructor.prototype = Object.create(superConstructor.prototype, descriptors);\n constructor.prototype.constructor = constructor;\n Object.defineProperty(constructor, 'super', {\n value: superConstructor.prototype\n });\n props && Object.assign(constructor.prototype, props);\n};\n\n/**\n * Resolve object with deep prototype chain to a flat object\n * @param {Object} sourceObj source object\n * @param {Object} [destObj]\n * @param {Function|Boolean} [filter]\n * @param {Function} [propFilter]\n *\n * @returns {Object}\n */\nconst toFlatObject = (sourceObj, destObj, filter, propFilter) => {\n let props;\n let i;\n let prop;\n const merged = {};\n\n destObj = destObj || {};\n // eslint-disable-next-line no-eq-null,eqeqeq\n if (sourceObj == null) return destObj;\n\n do {\n props = Object.getOwnPropertyNames(sourceObj);\n i = props.length;\n while (i-- > 0) {\n prop = props[i];\n if ((!propFilter || propFilter(prop, sourceObj, destObj)) && !merged[prop]) {\n destObj[prop] = sourceObj[prop];\n merged[prop] = true;\n }\n }\n sourceObj = filter !== false && getPrototypeOf(sourceObj);\n } while (sourceObj && (!filter || filter(sourceObj, destObj)) && sourceObj !== Object.prototype);\n\n return destObj;\n};\n\n/**\n * Determines whether a string ends with the characters of a specified string\n *\n * @param {String} str\n * @param {String} searchString\n * @param {Number} [position= 0]\n *\n * @returns {boolean}\n */\nconst endsWith = (str, searchString, position) => {\n str = String(str);\n if (position === undefined || position > str.length) {\n position = str.length;\n }\n position -= searchString.length;\n const lastIndex = str.indexOf(searchString, position);\n return lastIndex !== -1 && lastIndex === position;\n};\n\n\n/**\n * Returns new array from array like object or null if failed\n *\n * @param {*} [thing]\n *\n * @returns {?Array}\n */\nconst toArray = (thing) => {\n if (!thing) return null;\n if (isArray(thing)) return thing;\n let i = thing.length;\n if (!isNumber(i)) return null;\n const arr = new Array(i);\n while (i-- > 0) {\n arr[i] = thing[i];\n }\n return arr;\n};\n\n/**\n * Checking if the Uint8Array exists and if it does, it returns a function that checks if the\n * thing passed in is an instance of Uint8Array\n *\n * @param {TypedArray}\n *\n * @returns {Array}\n */\n// eslint-disable-next-line func-names\nconst isTypedArray = (TypedArray => {\n // eslint-disable-next-line func-names\n return thing => {\n return TypedArray && thing instanceof TypedArray;\n };\n})(typeof Uint8Array !== 'undefined' && getPrototypeOf(Uint8Array));\n\n/**\n * For each entry in the object, call the function with the key and value.\n *\n * @param {Object} obj - The object to iterate over.\n * @param {Function} fn - The function to call for each entry.\n *\n * @returns {void}\n */\nconst forEachEntry = (obj, fn) => {\n const generator = obj && obj[iterator];\n\n const _iterator = generator.call(obj);\n\n let result;\n\n while ((result = _iterator.next()) && !result.done) {\n const pair = result.value;\n fn.call(obj, pair[0], pair[1]);\n }\n};\n\n/**\n * It takes a regular expression and a string, and returns an array of all the matches\n *\n * @param {string} regExp - The regular expression to match against.\n * @param {string} str - The string to search.\n *\n * @returns {Array}\n */\nconst matchAll = (regExp, str) => {\n let matches;\n const arr = [];\n\n while ((matches = regExp.exec(str)) !== null) {\n arr.push(matches);\n }\n\n return arr;\n};\n\n/* Checking if the kindOfTest function returns true when passed an HTMLFormElement. */\nconst isHTMLForm = kindOfTest('HTMLFormElement');\n\nconst toCamelCase = str => {\n return str.toLowerCase().replace(/[-_\\s]([a-z\\d])(\\w*)/g,\n function replacer(m, p1, p2) {\n return p1.toUpperCase() + p2;\n }\n );\n};\n\n/* Creating a function that will check if an object has a property. */\nconst hasOwnProperty = (({hasOwnProperty}) => (obj, prop) => hasOwnProperty.call(obj, prop))(Object.prototype);\n\n/**\n * Determine if a value is a RegExp object\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a RegExp object, otherwise false\n */\nconst isRegExp = kindOfTest('RegExp');\n\nconst reduceDescriptors = (obj, reducer) => {\n const descriptors = Object.getOwnPropertyDescriptors(obj);\n const reducedDescriptors = {};\n\n forEach(descriptors, (descriptor, name) => {\n let ret;\n if ((ret = reducer(descriptor, name, obj)) !== false) {\n reducedDescriptors[name] = ret || descriptor;\n }\n });\n\n Object.defineProperties(obj, reducedDescriptors);\n};\n\n/**\n * Makes all methods read-only\n * @param {Object} obj\n */\n\nconst freezeMethods = (obj) => {\n reduceDescriptors(obj, (descriptor, name) => {\n // skip restricted props in strict mode\n if (isFunction$1(obj) && ['arguments', 'caller', 'callee'].indexOf(name) !== -1) {\n return false;\n }\n\n const value = obj[name];\n\n if (!isFunction$1(value)) return;\n\n descriptor.enumerable = false;\n\n if ('writable' in descriptor) {\n descriptor.writable = false;\n return;\n }\n\n if (!descriptor.set) {\n descriptor.set = () => {\n throw Error('Can not rewrite read-only method \\'' + name + '\\'');\n };\n }\n });\n};\n\nconst toObjectSet = (arrayOrString, delimiter) => {\n const obj = {};\n\n const define = (arr) => {\n arr.forEach(value => {\n obj[value] = true;\n });\n };\n\n isArray(arrayOrString) ? define(arrayOrString) : define(String(arrayOrString).split(delimiter));\n\n return obj;\n};\n\nconst noop = () => {};\n\nconst toFiniteNumber = (value, defaultValue) => {\n return value != null && Number.isFinite(value = +value) ? value : defaultValue;\n};\n\n\n\n/**\n * If the thing is a FormData object, return true, otherwise return false.\n *\n * @param {unknown} thing - The thing to check.\n *\n * @returns {boolean}\n */\nfunction isSpecCompliantForm(thing) {\n return !!(thing && isFunction$1(thing.append) && thing[toStringTag] === 'FormData' && thing[iterator]);\n}\n\nconst toJSONObject = (obj) => {\n const stack = new Array(10);\n\n const visit = (source, i) => {\n\n if (isObject(source)) {\n if (stack.indexOf(source) >= 0) {\n return;\n }\n\n //Buffer check\n if (isBuffer(source)) {\n return source;\n }\n\n if(!('toJSON' in source)) {\n stack[i] = source;\n const target = isArray(source) ? [] : {};\n\n forEach(source, (value, key) => {\n const reducedValue = visit(value, i + 1);\n !isUndefined(reducedValue) && (target[key] = reducedValue);\n });\n\n stack[i] = undefined;\n\n return target;\n }\n }\n\n return source;\n };\n\n return visit(obj, 0);\n};\n\nconst isAsyncFn = kindOfTest('AsyncFunction');\n\nconst isThenable = (thing) =>\n thing && (isObject(thing) || isFunction$1(thing)) && isFunction$1(thing.then) && isFunction$1(thing.catch);\n\n// original code\n// https://github.com/DigitalBrainJS/AxiosPromise/blob/16deab13710ec09779922131f3fa5954320f83ab/lib/utils.js#L11-L34\n\nconst _setImmediate = ((setImmediateSupported, postMessageSupported) => {\n if (setImmediateSupported) {\n return setImmediate;\n }\n\n return postMessageSupported ? ((token, callbacks) => {\n _global.addEventListener(\"message\", ({source, data}) => {\n if (source === _global && data === token) {\n callbacks.length && callbacks.shift()();\n }\n }, false);\n\n return (cb) => {\n callbacks.push(cb);\n _global.postMessage(token, \"*\");\n }\n })(`axios@${Math.random()}`, []) : (cb) => setTimeout(cb);\n})(\n typeof setImmediate === 'function',\n isFunction$1(_global.postMessage)\n);\n\nconst asap = typeof queueMicrotask !== 'undefined' ?\n queueMicrotask.bind(_global) : ( typeof process !== 'undefined' && process.nextTick || _setImmediate);\n\n// *********************\n\n\nconst isIterable = (thing) => thing != null && isFunction$1(thing[iterator]);\n\n\nvar utils$1 = {\n isArray,\n isArrayBuffer,\n isBuffer,\n isFormData,\n isArrayBufferView,\n isString,\n isNumber,\n isBoolean,\n isObject,\n isPlainObject,\n isEmptyObject,\n isReadableStream,\n isRequest,\n isResponse,\n isHeaders,\n isUndefined,\n isDate,\n isFile,\n isBlob,\n isRegExp,\n isFunction: isFunction$1,\n isStream,\n isURLSearchParams,\n isTypedArray,\n isFileList,\n forEach,\n merge,\n extend,\n trim,\n stripBOM,\n inherits,\n toFlatObject,\n kindOf,\n kindOfTest,\n endsWith,\n toArray,\n forEachEntry,\n matchAll,\n isHTMLForm,\n hasOwnProperty,\n hasOwnProp: hasOwnProperty, // an alias to avoid ESLint no-prototype-builtins detection\n reduceDescriptors,\n freezeMethods,\n toObjectSet,\n toCamelCase,\n noop,\n toFiniteNumber,\n findKey,\n global: _global,\n isContextDefined,\n isSpecCompliantForm,\n toJSONObject,\n isAsyncFn,\n isThenable,\n setImmediate: _setImmediate,\n asap,\n isIterable\n};\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [config] The config.\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n *\n * @returns {Error} The created error.\n */\nfunction AxiosError(message, code, config, request, response) {\n Error.call(this);\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n } else {\n this.stack = (new Error()).stack;\n }\n\n this.message = message;\n this.name = 'AxiosError';\n code && (this.code = code);\n config && (this.config = config);\n request && (this.request = request);\n if (response) {\n this.response = response;\n this.status = response.status ? response.status : null;\n }\n}\n\nutils$1.inherits(AxiosError, Error, {\n toJSON: function toJSON() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: utils$1.toJSONObject(this.config),\n code: this.code,\n status: this.status\n };\n }\n});\n\nconst prototype$1 = AxiosError.prototype;\nconst descriptors = {};\n\n[\n 'ERR_BAD_OPTION_VALUE',\n 'ERR_BAD_OPTION',\n 'ECONNABORTED',\n 'ETIMEDOUT',\n 'ERR_NETWORK',\n 'ERR_FR_TOO_MANY_REDIRECTS',\n 'ERR_DEPRECATED',\n 'ERR_BAD_RESPONSE',\n 'ERR_BAD_REQUEST',\n 'ERR_CANCELED',\n 'ERR_NOT_SUPPORT',\n 'ERR_INVALID_URL'\n// eslint-disable-next-line func-names\n].forEach(code => {\n descriptors[code] = {value: code};\n});\n\nObject.defineProperties(AxiosError, descriptors);\nObject.defineProperty(prototype$1, 'isAxiosError', {value: true});\n\n// eslint-disable-next-line func-names\nAxiosError.from = (error, code, config, request, response, customProps) => {\n const axiosError = Object.create(prototype$1);\n\n utils$1.toFlatObject(error, axiosError, function filter(obj) {\n return obj !== Error.prototype;\n }, prop => {\n return prop !== 'isAxiosError';\n });\n\n const msg = error && error.message ? error.message : 'Error';\n\n // Prefer explicit code; otherwise copy the low-level error's code (e.g. ECONNREFUSED)\n const errCode = code == null && error ? error.code : code;\n AxiosError.call(axiosError, msg, errCode, config, request, response);\n\n // Chain the original error on the standard field; non-enumerable to avoid JSON noise\n if (error && axiosError.cause == null) {\n Object.defineProperty(axiosError, 'cause', { value: error, configurable: true });\n }\n\n axiosError.name = (error && error.name) || 'Error';\n\n customProps && Object.assign(axiosError, customProps);\n\n return axiosError;\n};\n\n// eslint-disable-next-line strict\nvar httpAdapter = null;\n\n/**\n * Determines if the given thing is a array or js object.\n *\n * @param {string} thing - The object or array to be visited.\n *\n * @returns {boolean}\n */\nfunction isVisitable(thing) {\n return utils$1.isPlainObject(thing) || utils$1.isArray(thing);\n}\n\n/**\n * It removes the brackets from the end of a string\n *\n * @param {string} key - The key of the parameter.\n *\n * @returns {string} the key without the brackets.\n */\nfunction removeBrackets(key) {\n return utils$1.endsWith(key, '[]') ? key.slice(0, -2) : key;\n}\n\n/**\n * It takes a path, a key, and a boolean, and returns a string\n *\n * @param {string} path - The path to the current key.\n * @param {string} key - The key of the current object being iterated over.\n * @param {string} dots - If true, the key will be rendered with dots instead of brackets.\n *\n * @returns {string} The path to the current key.\n */\nfunction renderKey(path, key, dots) {\n if (!path) return key;\n return path.concat(key).map(function each(token, i) {\n // eslint-disable-next-line no-param-reassign\n token = removeBrackets(token);\n return !dots && i ? '[' + token + ']' : token;\n }).join(dots ? '.' : '');\n}\n\n/**\n * If the array is an array and none of its elements are visitable, then it's a flat array.\n *\n * @param {Array} arr - The array to check\n *\n * @returns {boolean}\n */\nfunction isFlatArray(arr) {\n return utils$1.isArray(arr) && !arr.some(isVisitable);\n}\n\nconst predicates = utils$1.toFlatObject(utils$1, {}, null, function filter(prop) {\n return /^is[A-Z]/.test(prop);\n});\n\n/**\n * Convert a data object to FormData\n *\n * @param {Object} obj\n * @param {?Object} [formData]\n * @param {?Object} [options]\n * @param {Function} [options.visitor]\n * @param {Boolean} [options.metaTokens = true]\n * @param {Boolean} [options.dots = false]\n * @param {?Boolean} [options.indexes = false]\n *\n * @returns {Object}\n **/\n\n/**\n * It converts an object into a FormData object\n *\n * @param {Object} obj - The object to convert to form data.\n * @param {string} formData - The FormData object to append to.\n * @param {Object} options\n *\n * @returns\n */\nfunction toFormData(obj, formData, options) {\n if (!utils$1.isObject(obj)) {\n throw new TypeError('target must be an object');\n }\n\n // eslint-disable-next-line no-param-reassign\n formData = formData || new (FormData)();\n\n // eslint-disable-next-line no-param-reassign\n options = utils$1.toFlatObject(options, {\n metaTokens: true,\n dots: false,\n indexes: false\n }, false, function defined(option, source) {\n // eslint-disable-next-line no-eq-null,eqeqeq\n return !utils$1.isUndefined(source[option]);\n });\n\n const metaTokens = options.metaTokens;\n // eslint-disable-next-line no-use-before-define\n const visitor = options.visitor || defaultVisitor;\n const dots = options.dots;\n const indexes = options.indexes;\n const _Blob = options.Blob || typeof Blob !== 'undefined' && Blob;\n const useBlob = _Blob && utils$1.isSpecCompliantForm(formData);\n\n if (!utils$1.isFunction(visitor)) {\n throw new TypeError('visitor must be a function');\n }\n\n function convertValue(value) {\n if (value === null) return '';\n\n if (utils$1.isDate(value)) {\n return value.toISOString();\n }\n\n if (utils$1.isBoolean(value)) {\n return value.toString();\n }\n\n if (!useBlob && utils$1.isBlob(value)) {\n throw new AxiosError('Blob is not supported. Use a Buffer instead.');\n }\n\n if (utils$1.isArrayBuffer(value) || utils$1.isTypedArray(value)) {\n return useBlob && typeof Blob === 'function' ? new Blob([value]) : Buffer.from(value);\n }\n\n return value;\n }\n\n /**\n * Default visitor.\n *\n * @param {*} value\n * @param {String|Number} key\n * @param {Array} path\n * @this {FormData}\n *\n * @returns {boolean} return true to visit the each prop of the value recursively\n */\n function defaultVisitor(value, key, path) {\n let arr = value;\n\n if (value && !path && typeof value === 'object') {\n if (utils$1.endsWith(key, '{}')) {\n // eslint-disable-next-line no-param-reassign\n key = metaTokens ? key : key.slice(0, -2);\n // eslint-disable-next-line no-param-reassign\n value = JSON.stringify(value);\n } else if (\n (utils$1.isArray(value) && isFlatArray(value)) ||\n ((utils$1.isFileList(value) || utils$1.endsWith(key, '[]')) && (arr = utils$1.toArray(value))\n )) {\n // eslint-disable-next-line no-param-reassign\n key = removeBrackets(key);\n\n arr.forEach(function each(el, index) {\n !(utils$1.isUndefined(el) || el === null) && formData.append(\n // eslint-disable-next-line no-nested-ternary\n indexes === true ? renderKey([key], index, dots) : (indexes === null ? key : key + '[]'),\n convertValue(el)\n );\n });\n return false;\n }\n }\n\n if (isVisitable(value)) {\n return true;\n }\n\n formData.append(renderKey(path, key, dots), convertValue(value));\n\n return false;\n }\n\n const stack = [];\n\n const exposedHelpers = Object.assign(predicates, {\n defaultVisitor,\n convertValue,\n isVisitable\n });\n\n function build(value, path) {\n if (utils$1.isUndefined(value)) return;\n\n if (stack.indexOf(value) !== -1) {\n throw Error('Circular reference detected in ' + path.join('.'));\n }\n\n stack.push(value);\n\n utils$1.forEach(value, function each(el, key) {\n const result = !(utils$1.isUndefined(el) || el === null) && visitor.call(\n formData, el, utils$1.isString(key) ? key.trim() : key, path, exposedHelpers\n );\n\n if (result === true) {\n build(el, path ? path.concat(key) : [key]);\n }\n });\n\n stack.pop();\n }\n\n if (!utils$1.isObject(obj)) {\n throw new TypeError('data must be an object');\n }\n\n build(obj);\n\n return formData;\n}\n\n/**\n * It encodes a string by replacing all characters that are not in the unreserved set with\n * their percent-encoded equivalents\n *\n * @param {string} str - The string to encode.\n *\n * @returns {string} The encoded string.\n */\nfunction encode$1(str) {\n const charMap = {\n '!': '%21',\n \"'\": '%27',\n '(': '%28',\n ')': '%29',\n '~': '%7E',\n '%20': '+',\n '%00': '\\x00'\n };\n return encodeURIComponent(str).replace(/[!'()~]|%20|%00/g, function replacer(match) {\n return charMap[match];\n });\n}\n\n/**\n * It takes a params object and converts it to a FormData object\n *\n * @param {Object} params - The parameters to be converted to a FormData object.\n * @param {Object} options - The options object passed to the Axios constructor.\n *\n * @returns {void}\n */\nfunction AxiosURLSearchParams(params, options) {\n this._pairs = [];\n\n params && toFormData(params, this, options);\n}\n\nconst prototype = AxiosURLSearchParams.prototype;\n\nprototype.append = function append(name, value) {\n this._pairs.push([name, value]);\n};\n\nprototype.toString = function toString(encoder) {\n const _encode = encoder ? function(value) {\n return encoder.call(this, value, encode$1);\n } : encode$1;\n\n return this._pairs.map(function each(pair) {\n return _encode(pair[0]) + '=' + _encode(pair[1]);\n }, '').join('&');\n};\n\n/**\n * It replaces all instances of the characters `:`, `$`, `,`, `+`, `[`, and `]` with their\n * URI encoded counterparts\n *\n * @param {string} val The value to be encoded.\n *\n * @returns {string} The encoded value.\n */\nfunction encode(val) {\n return encodeURIComponent(val).\n replace(/%3A/gi, ':').\n replace(/%24/g, '$').\n replace(/%2C/gi, ',').\n replace(/%20/g, '+');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @param {?(object|Function)} options\n *\n * @returns {string} The formatted url\n */\nfunction buildURL(url, params, options) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n \n const _encode = options && options.encode || encode;\n\n if (utils$1.isFunction(options)) {\n options = {\n serialize: options\n };\n } \n\n const serializeFn = options && options.serialize;\n\n let serializedParams;\n\n if (serializeFn) {\n serializedParams = serializeFn(params, options);\n } else {\n serializedParams = utils$1.isURLSearchParams(params) ?\n params.toString() :\n new AxiosURLSearchParams(params, options).toString(_encode);\n }\n\n if (serializedParams) {\n const hashmarkIndex = url.indexOf(\"#\");\n\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n\n return url;\n}\n\nclass InterceptorManager {\n constructor() {\n this.handlers = [];\n }\n\n /**\n * Add a new interceptor to the stack\n *\n * @param {Function} fulfilled The function to handle `then` for a `Promise`\n * @param {Function} rejected The function to handle `reject` for a `Promise`\n *\n * @return {Number} An ID used to remove interceptor later\n */\n use(fulfilled, rejected, options) {\n this.handlers.push({\n fulfilled,\n rejected,\n synchronous: options ? options.synchronous : false,\n runWhen: options ? options.runWhen : null\n });\n return this.handlers.length - 1;\n }\n\n /**\n * Remove an interceptor from the stack\n *\n * @param {Number} id The ID that was returned by `use`\n *\n * @returns {Boolean} `true` if the interceptor was removed, `false` otherwise\n */\n eject(id) {\n if (this.handlers[id]) {\n this.handlers[id] = null;\n }\n }\n\n /**\n * Clear all interceptors from the stack\n *\n * @returns {void}\n */\n clear() {\n if (this.handlers) {\n this.handlers = [];\n }\n }\n\n /**\n * Iterate over all the registered interceptors\n *\n * This method is particularly useful for skipping over any\n * interceptors that may have become `null` calling `eject`.\n *\n * @param {Function} fn The function to call for each interceptor\n *\n * @returns {void}\n */\n forEach(fn) {\n utils$1.forEach(this.handlers, function forEachHandler(h) {\n if (h !== null) {\n fn(h);\n }\n });\n }\n}\n\nvar InterceptorManager$1 = InterceptorManager;\n\nvar transitionalDefaults = {\n silentJSONParsing: true,\n forcedJSONParsing: true,\n clarifyTimeoutError: false\n};\n\nvar URLSearchParams$1 = typeof URLSearchParams !== 'undefined' ? URLSearchParams : AxiosURLSearchParams;\n\nvar FormData$1 = typeof FormData !== 'undefined' ? FormData : null;\n\nvar Blob$1 = typeof Blob !== 'undefined' ? Blob : null;\n\nvar platform$1 = {\n isBrowser: true,\n classes: {\n URLSearchParams: URLSearchParams$1,\n FormData: FormData$1,\n Blob: Blob$1\n },\n protocols: ['http', 'https', 'file', 'blob', 'url', 'data']\n};\n\nconst hasBrowserEnv = typeof window !== 'undefined' && typeof document !== 'undefined';\n\nconst _navigator = typeof navigator === 'object' && navigator || undefined;\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n *\n * @returns {boolean}\n */\nconst hasStandardBrowserEnv = hasBrowserEnv &&\n (!_navigator || ['ReactNative', 'NativeScript', 'NS'].indexOf(_navigator.product) < 0);\n\n/**\n * Determine if we're running in a standard browser webWorker environment\n *\n * Although the `isStandardBrowserEnv` method indicates that\n * `allows axios to run in a web worker`, the WebWorker will still be\n * filtered out due to its judgment standard\n * `typeof window !== 'undefined' && typeof document !== 'undefined'`.\n * This leads to a problem when axios post `FormData` in webWorker\n */\nconst hasStandardBrowserWebWorkerEnv = (() => {\n return (\n typeof WorkerGlobalScope !== 'undefined' &&\n // eslint-disable-next-line no-undef\n self instanceof WorkerGlobalScope &&\n typeof self.importScripts === 'function'\n );\n})();\n\nconst origin = hasBrowserEnv && window.location.href || 'http://localhost';\n\nvar utils = /*#__PURE__*/Object.freeze({\n __proto__: null,\n hasBrowserEnv: hasBrowserEnv,\n hasStandardBrowserWebWorkerEnv: hasStandardBrowserWebWorkerEnv,\n hasStandardBrowserEnv: hasStandardBrowserEnv,\n navigator: _navigator,\n origin: origin\n});\n\nvar platform = {\n ...utils,\n ...platform$1\n};\n\nfunction toURLEncodedForm(data, options) {\n return toFormData(data, new platform.classes.URLSearchParams(), {\n visitor: function(value, key, path, helpers) {\n if (platform.isNode && utils$1.isBuffer(value)) {\n this.append(key, value.toString('base64'));\n return false;\n }\n\n return helpers.defaultVisitor.apply(this, arguments);\n },\n ...options\n });\n}\n\n/**\n * It takes a string like `foo[x][y][z]` and returns an array like `['foo', 'x', 'y', 'z']\n *\n * @param {string} name - The name of the property to get.\n *\n * @returns An array of strings.\n */\nfunction parsePropPath(name) {\n // foo[x][y][z]\n // foo.x.y.z\n // foo-x-y-z\n // foo x y z\n return utils$1.matchAll(/\\w+|\\[(\\w*)]/g, name).map(match => {\n return match[0] === '[]' ? '' : match[1] || match[0];\n });\n}\n\n/**\n * Convert an array to an object.\n *\n * @param {Array} arr - The array to convert to an object.\n *\n * @returns An object with the same keys and values as the array.\n */\nfunction arrayToObject(arr) {\n const obj = {};\n const keys = Object.keys(arr);\n let i;\n const len = keys.length;\n let key;\n for (i = 0; i < len; i++) {\n key = keys[i];\n obj[key] = arr[key];\n }\n return obj;\n}\n\n/**\n * It takes a FormData object and returns a JavaScript object\n *\n * @param {string} formData The FormData object to convert to JSON.\n *\n * @returns {Object | null} The converted object.\n */\nfunction formDataToJSON(formData) {\n function buildPath(path, value, target, index) {\n let name = path[index++];\n\n if (name === '__proto__') return true;\n\n const isNumericKey = Number.isFinite(+name);\n const isLast = index >= path.length;\n name = !name && utils$1.isArray(target) ? target.length : name;\n\n if (isLast) {\n if (utils$1.hasOwnProp(target, name)) {\n target[name] = [target[name], value];\n } else {\n target[name] = value;\n }\n\n return !isNumericKey;\n }\n\n if (!target[name] || !utils$1.isObject(target[name])) {\n target[name] = [];\n }\n\n const result = buildPath(path, value, target[name], index);\n\n if (result && utils$1.isArray(target[name])) {\n target[name] = arrayToObject(target[name]);\n }\n\n return !isNumericKey;\n }\n\n if (utils$1.isFormData(formData) && utils$1.isFunction(formData.entries)) {\n const obj = {};\n\n utils$1.forEachEntry(formData, (name, value) => {\n buildPath(parsePropPath(name), value, obj, 0);\n });\n\n return obj;\n }\n\n return null;\n}\n\n/**\n * It takes a string, tries to parse it, and if it fails, it returns the stringified version\n * of the input\n *\n * @param {any} rawValue - The value to be stringified.\n * @param {Function} parser - A function that parses a string into a JavaScript object.\n * @param {Function} encoder - A function that takes a value and returns a string.\n *\n * @returns {string} A stringified version of the rawValue.\n */\nfunction stringifySafely(rawValue, parser, encoder) {\n if (utils$1.isString(rawValue)) {\n try {\n (parser || JSON.parse)(rawValue);\n return utils$1.trim(rawValue);\n } catch (e) {\n if (e.name !== 'SyntaxError') {\n throw e;\n }\n }\n }\n\n return (encoder || JSON.stringify)(rawValue);\n}\n\nconst defaults = {\n\n transitional: transitionalDefaults,\n\n adapter: ['xhr', 'http', 'fetch'],\n\n transformRequest: [function transformRequest(data, headers) {\n const contentType = headers.getContentType() || '';\n const hasJSONContentType = contentType.indexOf('application/json') > -1;\n const isObjectPayload = utils$1.isObject(data);\n\n if (isObjectPayload && utils$1.isHTMLForm(data)) {\n data = new FormData(data);\n }\n\n const isFormData = utils$1.isFormData(data);\n\n if (isFormData) {\n return hasJSONContentType ? JSON.stringify(formDataToJSON(data)) : data;\n }\n\n if (utils$1.isArrayBuffer(data) ||\n utils$1.isBuffer(data) ||\n utils$1.isStream(data) ||\n utils$1.isFile(data) ||\n utils$1.isBlob(data) ||\n utils$1.isReadableStream(data)\n ) {\n return data;\n }\n if (utils$1.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils$1.isURLSearchParams(data)) {\n headers.setContentType('application/x-www-form-urlencoded;charset=utf-8', false);\n return data.toString();\n }\n\n let isFileList;\n\n if (isObjectPayload) {\n if (contentType.indexOf('application/x-www-form-urlencoded') > -1) {\n return toURLEncodedForm(data, this.formSerializer).toString();\n }\n\n if ((isFileList = utils$1.isFileList(data)) || contentType.indexOf('multipart/form-data') > -1) {\n const _FormData = this.env && this.env.FormData;\n\n return toFormData(\n isFileList ? {'files[]': data} : data,\n _FormData && new _FormData(),\n this.formSerializer\n );\n }\n }\n\n if (isObjectPayload || hasJSONContentType ) {\n headers.setContentType('application/json', false);\n return stringifySafely(data);\n }\n\n return data;\n }],\n\n transformResponse: [function transformResponse(data) {\n const transitional = this.transitional || defaults.transitional;\n const forcedJSONParsing = transitional && transitional.forcedJSONParsing;\n const JSONRequested = this.responseType === 'json';\n\n if (utils$1.isResponse(data) || utils$1.isReadableStream(data)) {\n return data;\n }\n\n if (data && utils$1.isString(data) && ((forcedJSONParsing && !this.responseType) || JSONRequested)) {\n const silentJSONParsing = transitional && transitional.silentJSONParsing;\n const strictJSONParsing = !silentJSONParsing && JSONRequested;\n\n try {\n return JSON.parse(data, this.parseReviver);\n } catch (e) {\n if (strictJSONParsing) {\n if (e.name === 'SyntaxError') {\n throw AxiosError.from(e, AxiosError.ERR_BAD_RESPONSE, this, null, this.response);\n }\n throw e;\n }\n }\n }\n\n return data;\n }],\n\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n\n maxContentLength: -1,\n maxBodyLength: -1,\n\n env: {\n FormData: platform.classes.FormData,\n Blob: platform.classes.Blob\n },\n\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n },\n\n headers: {\n common: {\n 'Accept': 'application/json, text/plain, */*',\n 'Content-Type': undefined\n }\n }\n};\n\nutils$1.forEach(['delete', 'get', 'head', 'post', 'put', 'patch'], (method) => {\n defaults.headers[method] = {};\n});\n\nvar defaults$1 = defaults;\n\n// RawAxiosHeaders whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nconst ignoreDuplicateOf = utils$1.toObjectSet([\n 'age', 'authorization', 'content-length', 'content-type', 'etag',\n 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n 'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n 'referer', 'retry-after', 'user-agent'\n]);\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} rawHeaders Headers needing to be parsed\n *\n * @returns {Object} Headers parsed into an object\n */\nvar parseHeaders = rawHeaders => {\n const parsed = {};\n let key;\n let val;\n let i;\n\n rawHeaders && rawHeaders.split('\\n').forEach(function parser(line) {\n i = line.indexOf(':');\n key = line.substring(0, i).trim().toLowerCase();\n val = line.substring(i + 1).trim();\n\n if (!key || (parsed[key] && ignoreDuplicateOf[key])) {\n return;\n }\n\n if (key === 'set-cookie') {\n if (parsed[key]) {\n parsed[key].push(val);\n } else {\n parsed[key] = [val];\n }\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n });\n\n return parsed;\n};\n\nconst $internals = Symbol('internals');\n\nfunction normalizeHeader(header) {\n return header && String(header).trim().toLowerCase();\n}\n\nfunction normalizeValue(value) {\n if (value === false || value == null) {\n return value;\n }\n\n return utils$1.isArray(value) ? value.map(normalizeValue) : String(value);\n}\n\nfunction parseTokens(str) {\n const tokens = Object.create(null);\n const tokensRE = /([^\\s,;=]+)\\s*(?:=\\s*([^,;]+))?/g;\n let match;\n\n while ((match = tokensRE.exec(str))) {\n tokens[match[1]] = match[2];\n }\n\n return tokens;\n}\n\nconst isValidHeaderName = (str) => /^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(str.trim());\n\nfunction matchHeaderValue(context, value, header, filter, isHeaderNameFilter) {\n if (utils$1.isFunction(filter)) {\n return filter.call(this, value, header);\n }\n\n if (isHeaderNameFilter) {\n value = header;\n }\n\n if (!utils$1.isString(value)) return;\n\n if (utils$1.isString(filter)) {\n return value.indexOf(filter) !== -1;\n }\n\n if (utils$1.isRegExp(filter)) {\n return filter.test(value);\n }\n}\n\nfunction formatHeader(header) {\n return header.trim()\n .toLowerCase().replace(/([a-z\\d])(\\w*)/g, (w, char, str) => {\n return char.toUpperCase() + str;\n });\n}\n\nfunction buildAccessors(obj, header) {\n const accessorName = utils$1.toCamelCase(' ' + header);\n\n ['get', 'set', 'has'].forEach(methodName => {\n Object.defineProperty(obj, methodName + accessorName, {\n value: function(arg1, arg2, arg3) {\n return this[methodName].call(this, header, arg1, arg2, arg3);\n },\n configurable: true\n });\n });\n}\n\nclass AxiosHeaders {\n constructor(headers) {\n headers && this.set(headers);\n }\n\n set(header, valueOrRewrite, rewrite) {\n const self = this;\n\n function setHeader(_value, _header, _rewrite) {\n const lHeader = normalizeHeader(_header);\n\n if (!lHeader) {\n throw new Error('header name must be a non-empty string');\n }\n\n const key = utils$1.findKey(self, lHeader);\n\n if(!key || self[key] === undefined || _rewrite === true || (_rewrite === undefined && self[key] !== false)) {\n self[key || _header] = normalizeValue(_value);\n }\n }\n\n const setHeaders = (headers, _rewrite) =>\n utils$1.forEach(headers, (_value, _header) => setHeader(_value, _header, _rewrite));\n\n if (utils$1.isPlainObject(header) || header instanceof this.constructor) {\n setHeaders(header, valueOrRewrite);\n } else if(utils$1.isString(header) && (header = header.trim()) && !isValidHeaderName(header)) {\n setHeaders(parseHeaders(header), valueOrRewrite);\n } else if (utils$1.isObject(header) && utils$1.isIterable(header)) {\n let obj = {}, dest, key;\n for (const entry of header) {\n if (!utils$1.isArray(entry)) {\n throw TypeError('Object iterator must return a key-value pair');\n }\n\n obj[key = entry[0]] = (dest = obj[key]) ?\n (utils$1.isArray(dest) ? [...dest, entry[1]] : [dest, entry[1]]) : entry[1];\n }\n\n setHeaders(obj, valueOrRewrite);\n } else {\n header != null && setHeader(valueOrRewrite, header, rewrite);\n }\n\n return this;\n }\n\n get(header, parser) {\n header = normalizeHeader(header);\n\n if (header) {\n const key = utils$1.findKey(this, header);\n\n if (key) {\n const value = this[key];\n\n if (!parser) {\n return value;\n }\n\n if (parser === true) {\n return parseTokens(value);\n }\n\n if (utils$1.isFunction(parser)) {\n return parser.call(this, value, key);\n }\n\n if (utils$1.isRegExp(parser)) {\n return parser.exec(value);\n }\n\n throw new TypeError('parser must be boolean|regexp|function');\n }\n }\n }\n\n has(header, matcher) {\n header = normalizeHeader(header);\n\n if (header) {\n const key = utils$1.findKey(this, header);\n\n return !!(key && this[key] !== undefined && (!matcher || matchHeaderValue(this, this[key], key, matcher)));\n }\n\n return false;\n }\n\n delete(header, matcher) {\n const self = this;\n let deleted = false;\n\n function deleteHeader(_header) {\n _header = normalizeHeader(_header);\n\n if (_header) {\n const key = utils$1.findKey(self, _header);\n\n if (key && (!matcher || matchHeaderValue(self, self[key], key, matcher))) {\n delete self[key];\n\n deleted = true;\n }\n }\n }\n\n if (utils$1.isArray(header)) {\n header.forEach(deleteHeader);\n } else {\n deleteHeader(header);\n }\n\n return deleted;\n }\n\n clear(matcher) {\n const keys = Object.keys(this);\n let i = keys.length;\n let deleted = false;\n\n while (i--) {\n const key = keys[i];\n if(!matcher || matchHeaderValue(this, this[key], key, matcher, true)) {\n delete this[key];\n deleted = true;\n }\n }\n\n return deleted;\n }\n\n normalize(format) {\n const self = this;\n const headers = {};\n\n utils$1.forEach(this, (value, header) => {\n const key = utils$1.findKey(headers, header);\n\n if (key) {\n self[key] = normalizeValue(value);\n delete self[header];\n return;\n }\n\n const normalized = format ? formatHeader(header) : String(header).trim();\n\n if (normalized !== header) {\n delete self[header];\n }\n\n self[normalized] = normalizeValue(value);\n\n headers[normalized] = true;\n });\n\n return this;\n }\n\n concat(...targets) {\n return this.constructor.concat(this, ...targets);\n }\n\n toJSON(asStrings) {\n const obj = Object.create(null);\n\n utils$1.forEach(this, (value, header) => {\n value != null && value !== false && (obj[header] = asStrings && utils$1.isArray(value) ? value.join(', ') : value);\n });\n\n return obj;\n }\n\n [Symbol.iterator]() {\n return Object.entries(this.toJSON())[Symbol.iterator]();\n }\n\n toString() {\n return Object.entries(this.toJSON()).map(([header, value]) => header + ': ' + value).join('\\n');\n }\n\n getSetCookie() {\n return this.get(\"set-cookie\") || [];\n }\n\n get [Symbol.toStringTag]() {\n return 'AxiosHeaders';\n }\n\n static from(thing) {\n return thing instanceof this ? thing : new this(thing);\n }\n\n static concat(first, ...targets) {\n const computed = new this(first);\n\n targets.forEach((target) => computed.set(target));\n\n return computed;\n }\n\n static accessor(header) {\n const internals = this[$internals] = (this[$internals] = {\n accessors: {}\n });\n\n const accessors = internals.accessors;\n const prototype = this.prototype;\n\n function defineAccessor(_header) {\n const lHeader = normalizeHeader(_header);\n\n if (!accessors[lHeader]) {\n buildAccessors(prototype, _header);\n accessors[lHeader] = true;\n }\n }\n\n utils$1.isArray(header) ? header.forEach(defineAccessor) : defineAccessor(header);\n\n return this;\n }\n}\n\nAxiosHeaders.accessor(['Content-Type', 'Content-Length', 'Accept', 'Accept-Encoding', 'User-Agent', 'Authorization']);\n\n// reserved names hotfix\nutils$1.reduceDescriptors(AxiosHeaders.prototype, ({value}, key) => {\n let mapped = key[0].toUpperCase() + key.slice(1); // map `set` => `Set`\n return {\n get: () => value,\n set(headerValue) {\n this[mapped] = headerValue;\n }\n }\n});\n\nutils$1.freezeMethods(AxiosHeaders);\n\nvar AxiosHeaders$1 = AxiosHeaders;\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Array|Function} fns A single function or Array of functions\n * @param {?Object} response The response object\n *\n * @returns {*} The resulting transformed data\n */\nfunction transformData(fns, response) {\n const config = this || defaults$1;\n const context = response || config;\n const headers = AxiosHeaders$1.from(context.headers);\n let data = context.data;\n\n utils$1.forEach(fns, function transform(fn) {\n data = fn.call(config, data, headers.normalize(), response ? response.status : undefined);\n });\n\n headers.normalize();\n\n return data;\n}\n\nfunction isCancel(value) {\n return !!(value && value.__CANCEL__);\n}\n\n/**\n * A `CanceledError` is an object that is thrown when an operation is canceled.\n *\n * @param {string=} message The message.\n * @param {Object=} config The config.\n * @param {Object=} request The request.\n *\n * @returns {CanceledError} The created error.\n */\nfunction CanceledError(message, config, request) {\n // eslint-disable-next-line no-eq-null,eqeqeq\n AxiosError.call(this, message == null ? 'canceled' : message, AxiosError.ERR_CANCELED, config, request);\n this.name = 'CanceledError';\n}\n\nutils$1.inherits(CanceledError, AxiosError, {\n __CANCEL__: true\n});\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n *\n * @returns {object} The response.\n */\nfunction settle(resolve, reject, response) {\n const validateStatus = response.config.validateStatus;\n if (!response.status || !validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(new AxiosError(\n 'Request failed with status code ' + response.status,\n [AxiosError.ERR_BAD_REQUEST, AxiosError.ERR_BAD_RESPONSE][Math.floor(response.status / 100) - 4],\n response.config,\n response.request,\n response\n ));\n }\n}\n\nfunction parseProtocol(url) {\n const match = /^([-+\\w]{1,25})(:?\\/\\/|:)/.exec(url);\n return match && match[1] || '';\n}\n\n/**\n * Calculate data maxRate\n * @param {Number} [samplesCount= 10]\n * @param {Number} [min= 1000]\n * @returns {Function}\n */\nfunction speedometer(samplesCount, min) {\n samplesCount = samplesCount || 10;\n const bytes = new Array(samplesCount);\n const timestamps = new Array(samplesCount);\n let head = 0;\n let tail = 0;\n let firstSampleTS;\n\n min = min !== undefined ? min : 1000;\n\n return function push(chunkLength) {\n const now = Date.now();\n\n const startedAt = timestamps[tail];\n\n if (!firstSampleTS) {\n firstSampleTS = now;\n }\n\n bytes[head] = chunkLength;\n timestamps[head] = now;\n\n let i = tail;\n let bytesCount = 0;\n\n while (i !== head) {\n bytesCount += bytes[i++];\n i = i % samplesCount;\n }\n\n head = (head + 1) % samplesCount;\n\n if (head === tail) {\n tail = (tail + 1) % samplesCount;\n }\n\n if (now - firstSampleTS < min) {\n return;\n }\n\n const passed = startedAt && now - startedAt;\n\n return passed ? Math.round(bytesCount * 1000 / passed) : undefined;\n };\n}\n\n/**\n * Throttle decorator\n * @param {Function} fn\n * @param {Number} freq\n * @return {Function}\n */\nfunction throttle(fn, freq) {\n let timestamp = 0;\n let threshold = 1000 / freq;\n let lastArgs;\n let timer;\n\n const invoke = (args, now = Date.now()) => {\n timestamp = now;\n lastArgs = null;\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n fn(...args);\n };\n\n const throttled = (...args) => {\n const now = Date.now();\n const passed = now - timestamp;\n if ( passed >= threshold) {\n invoke(args, now);\n } else {\n lastArgs = args;\n if (!timer) {\n timer = setTimeout(() => {\n timer = null;\n invoke(lastArgs);\n }, threshold - passed);\n }\n }\n };\n\n const flush = () => lastArgs && invoke(lastArgs);\n\n return [throttled, flush];\n}\n\nconst progressEventReducer = (listener, isDownloadStream, freq = 3) => {\n let bytesNotified = 0;\n const _speedometer = speedometer(50, 250);\n\n return throttle(e => {\n const loaded = e.loaded;\n const total = e.lengthComputable ? e.total : undefined;\n const progressBytes = loaded - bytesNotified;\n const rate = _speedometer(progressBytes);\n const inRange = loaded <= total;\n\n bytesNotified = loaded;\n\n const data = {\n loaded,\n total,\n progress: total ? (loaded / total) : undefined,\n bytes: progressBytes,\n rate: rate ? rate : undefined,\n estimated: rate && total && inRange ? (total - loaded) / rate : undefined,\n event: e,\n lengthComputable: total != null,\n [isDownloadStream ? 'download' : 'upload']: true\n };\n\n listener(data);\n }, freq);\n};\n\nconst progressEventDecorator = (total, throttled) => {\n const lengthComputable = total != null;\n\n return [(loaded) => throttled[0]({\n lengthComputable,\n total,\n loaded\n }), throttled[1]];\n};\n\nconst asyncDecorator = (fn) => (...args) => utils$1.asap(() => fn(...args));\n\nvar isURLSameOrigin = platform.hasStandardBrowserEnv ? ((origin, isMSIE) => (url) => {\n url = new URL(url, platform.origin);\n\n return (\n origin.protocol === url.protocol &&\n origin.host === url.host &&\n (isMSIE || origin.port === url.port)\n );\n})(\n new URL(platform.origin),\n platform.navigator && /(msie|trident)/i.test(platform.navigator.userAgent)\n) : () => true;\n\nvar cookies = platform.hasStandardBrowserEnv ?\n\n // Standard browser envs support document.cookie\n {\n write(name, value, expires, path, domain, secure) {\n const cookie = [name + '=' + encodeURIComponent(value)];\n\n utils$1.isNumber(expires) && cookie.push('expires=' + new Date(expires).toGMTString());\n\n utils$1.isString(path) && cookie.push('path=' + path);\n\n utils$1.isString(domain) && cookie.push('domain=' + domain);\n\n secure === true && cookie.push('secure');\n\n document.cookie = cookie.join('; ');\n },\n\n read(name) {\n const match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return (match ? decodeURIComponent(match[3]) : null);\n },\n\n remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n }\n\n :\n\n // Non-standard browser env (web workers, react-native) lack needed support.\n {\n write() {},\n read() {\n return null;\n },\n remove() {}\n };\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n *\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nfunction isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"://\" or \"//\" (protocol-relative URL).\n // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n // by any combination of letters, digits, plus, period, or hyphen.\n return /^([a-z][a-z\\d+\\-.]*:)?\\/\\//i.test(url);\n}\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n *\n * @returns {string} The combined URL\n */\nfunction combineURLs(baseURL, relativeURL) {\n return relativeURL\n ? baseURL.replace(/\\/?\\/$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n : baseURL;\n}\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n *\n * @returns {string} The combined full path\n */\nfunction buildFullPath(baseURL, requestedURL, allowAbsoluteUrls) {\n let isRelativeUrl = !isAbsoluteURL(requestedURL);\n if (baseURL && (isRelativeUrl || allowAbsoluteUrls == false)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n}\n\nconst headersToObject = (thing) => thing instanceof AxiosHeaders$1 ? { ...thing } : thing;\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n *\n * @returns {Object} New object resulting from merging config2 to config1\n */\nfunction mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n const config = {};\n\n function getMergedValue(target, source, prop, caseless) {\n if (utils$1.isPlainObject(target) && utils$1.isPlainObject(source)) {\n return utils$1.merge.call({caseless}, target, source);\n } else if (utils$1.isPlainObject(source)) {\n return utils$1.merge({}, source);\n } else if (utils$1.isArray(source)) {\n return source.slice();\n }\n return source;\n }\n\n // eslint-disable-next-line consistent-return\n function mergeDeepProperties(a, b, prop , caseless) {\n if (!utils$1.isUndefined(b)) {\n return getMergedValue(a, b, prop , caseless);\n } else if (!utils$1.isUndefined(a)) {\n return getMergedValue(undefined, a, prop , caseless);\n }\n }\n\n // eslint-disable-next-line consistent-return\n function valueFromConfig2(a, b) {\n if (!utils$1.isUndefined(b)) {\n return getMergedValue(undefined, b);\n }\n }\n\n // eslint-disable-next-line consistent-return\n function defaultToConfig2(a, b) {\n if (!utils$1.isUndefined(b)) {\n return getMergedValue(undefined, b);\n } else if (!utils$1.isUndefined(a)) {\n return getMergedValue(undefined, a);\n }\n }\n\n // eslint-disable-next-line consistent-return\n function mergeDirectKeys(a, b, prop) {\n if (prop in config2) {\n return getMergedValue(a, b);\n } else if (prop in config1) {\n return getMergedValue(undefined, a);\n }\n }\n\n const mergeMap = {\n url: valueFromConfig2,\n method: valueFromConfig2,\n data: valueFromConfig2,\n baseURL: defaultToConfig2,\n transformRequest: defaultToConfig2,\n transformResponse: defaultToConfig2,\n paramsSerializer: defaultToConfig2,\n timeout: defaultToConfig2,\n timeoutMessage: defaultToConfig2,\n withCredentials: defaultToConfig2,\n withXSRFToken: defaultToConfig2,\n adapter: defaultToConfig2,\n responseType: defaultToConfig2,\n xsrfCookieName: defaultToConfig2,\n xsrfHeaderName: defaultToConfig2,\n onUploadProgress: defaultToConfig2,\n onDownloadProgress: defaultToConfig2,\n decompress: defaultToConfig2,\n maxContentLength: defaultToConfig2,\n maxBodyLength: defaultToConfig2,\n beforeRedirect: defaultToConfig2,\n transport: defaultToConfig2,\n httpAgent: defaultToConfig2,\n httpsAgent: defaultToConfig2,\n cancelToken: defaultToConfig2,\n socketPath: defaultToConfig2,\n responseEncoding: defaultToConfig2,\n validateStatus: mergeDirectKeys,\n headers: (a, b , prop) => mergeDeepProperties(headersToObject(a), headersToObject(b),prop, true)\n };\n\n utils$1.forEach(Object.keys({...config1, ...config2}), function computeConfigValue(prop) {\n const merge = mergeMap[prop] || mergeDeepProperties;\n const configValue = merge(config1[prop], config2[prop], prop);\n (utils$1.isUndefined(configValue) && merge !== mergeDirectKeys) || (config[prop] = configValue);\n });\n\n return config;\n}\n\nvar resolveConfig = (config) => {\n const newConfig = mergeConfig({}, config);\n\n let { data, withXSRFToken, xsrfHeaderName, xsrfCookieName, headers, auth } = newConfig;\n\n newConfig.headers = headers = AxiosHeaders$1.from(headers);\n\n newConfig.url = buildURL(buildFullPath(newConfig.baseURL, newConfig.url, newConfig.allowAbsoluteUrls), config.params, config.paramsSerializer);\n\n // HTTP basic authentication\n if (auth) {\n headers.set('Authorization', 'Basic ' +\n btoa((auth.username || '') + ':' + (auth.password ? unescape(encodeURIComponent(auth.password)) : ''))\n );\n }\n\n if (utils$1.isFormData(data)) {\n if (platform.hasStandardBrowserEnv || platform.hasStandardBrowserWebWorkerEnv) {\n headers.setContentType(undefined); // browser handles it\n } else if (utils$1.isFunction(data.getHeaders)) {\n // Node.js FormData (like form-data package)\n const formHeaders = data.getHeaders();\n // Only set safe headers to avoid overwriting security headers\n const allowedHeaders = ['content-type', 'content-length'];\n Object.entries(formHeaders).forEach(([key, val]) => {\n if (allowedHeaders.includes(key.toLowerCase())) {\n headers.set(key, val);\n }\n });\n }\n } \n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n\n if (platform.hasStandardBrowserEnv) {\n withXSRFToken && utils$1.isFunction(withXSRFToken) && (withXSRFToken = withXSRFToken(newConfig));\n\n if (withXSRFToken || (withXSRFToken !== false && isURLSameOrigin(newConfig.url))) {\n // Add xsrf header\n const xsrfValue = xsrfHeaderName && xsrfCookieName && cookies.read(xsrfCookieName);\n\n if (xsrfValue) {\n headers.set(xsrfHeaderName, xsrfValue);\n }\n }\n }\n\n return newConfig;\n};\n\nconst isXHRAdapterSupported = typeof XMLHttpRequest !== 'undefined';\n\nvar xhrAdapter = isXHRAdapterSupported && function (config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n const _config = resolveConfig(config);\n let requestData = _config.data;\n const requestHeaders = AxiosHeaders$1.from(_config.headers).normalize();\n let {responseType, onUploadProgress, onDownloadProgress} = _config;\n let onCanceled;\n let uploadThrottled, downloadThrottled;\n let flushUpload, flushDownload;\n\n function done() {\n flushUpload && flushUpload(); // flush events\n flushDownload && flushDownload(); // flush events\n\n _config.cancelToken && _config.cancelToken.unsubscribe(onCanceled);\n\n _config.signal && _config.signal.removeEventListener('abort', onCanceled);\n }\n\n let request = new XMLHttpRequest();\n\n request.open(_config.method.toUpperCase(), _config.url, true);\n\n // Set the request timeout in MS\n request.timeout = _config.timeout;\n\n function onloadend() {\n if (!request) {\n return;\n }\n // Prepare the response\n const responseHeaders = AxiosHeaders$1.from(\n 'getAllResponseHeaders' in request && request.getAllResponseHeaders()\n );\n const responseData = !responseType || responseType === 'text' || responseType === 'json' ?\n request.responseText : request.response;\n const response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config,\n request\n };\n\n settle(function _resolve(value) {\n resolve(value);\n done();\n }, function _reject(err) {\n reject(err);\n done();\n }, response);\n\n // Clean up request\n request = null;\n }\n\n if ('onloadend' in request) {\n // Use onloadend if available\n request.onloadend = onloadend;\n } else {\n // Listen for ready state to emulate onloadend\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n // readystate handler is calling before onerror or ontimeout handlers,\n // so we should call onloadend on the next 'tick'\n setTimeout(onloadend);\n };\n }\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n\n reject(new AxiosError('Request aborted', AxiosError.ECONNABORTED, config, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError(event) {\n // Browsers deliver a ProgressEvent in XHR onerror\n // (message may be empty; when present, surface it)\n // See https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/error_event\n const msg = event && event.message ? event.message : 'Network Error';\n const err = new AxiosError(msg, AxiosError.ERR_NETWORK, config, request);\n // attach the underlying event for consumers who want details\n err.event = event || null;\n reject(err);\n request = null;\n };\n \n // Handle timeout\n request.ontimeout = function handleTimeout() {\n let timeoutErrorMessage = _config.timeout ? 'timeout of ' + _config.timeout + 'ms exceeded' : 'timeout exceeded';\n const transitional = _config.transitional || transitionalDefaults;\n if (_config.timeoutErrorMessage) {\n timeoutErrorMessage = _config.timeoutErrorMessage;\n }\n reject(new AxiosError(\n timeoutErrorMessage,\n transitional.clarifyTimeoutError ? AxiosError.ETIMEDOUT : AxiosError.ECONNABORTED,\n config,\n request));\n\n // Clean up request\n request = null;\n };\n\n // Remove Content-Type if data is undefined\n requestData === undefined && requestHeaders.setContentType(null);\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils$1.forEach(requestHeaders.toJSON(), function setRequestHeader(val, key) {\n request.setRequestHeader(key, val);\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils$1.isUndefined(_config.withCredentials)) {\n request.withCredentials = !!_config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (responseType && responseType !== 'json') {\n request.responseType = _config.responseType;\n }\n\n // Handle progress if needed\n if (onDownloadProgress) {\n ([downloadThrottled, flushDownload] = progressEventReducer(onDownloadProgress, true));\n request.addEventListener('progress', downloadThrottled);\n }\n\n // Not all browsers support upload events\n if (onUploadProgress && request.upload) {\n ([uploadThrottled, flushUpload] = progressEventReducer(onUploadProgress));\n\n request.upload.addEventListener('progress', uploadThrottled);\n\n request.upload.addEventListener('loadend', flushUpload);\n }\n\n if (_config.cancelToken || _config.signal) {\n // Handle cancellation\n // eslint-disable-next-line func-names\n onCanceled = cancel => {\n if (!request) {\n return;\n }\n reject(!cancel || cancel.type ? new CanceledError(null, config, request) : cancel);\n request.abort();\n request = null;\n };\n\n _config.cancelToken && _config.cancelToken.subscribe(onCanceled);\n if (_config.signal) {\n _config.signal.aborted ? onCanceled() : _config.signal.addEventListener('abort', onCanceled);\n }\n }\n\n const protocol = parseProtocol(_config.url);\n\n if (protocol && platform.protocols.indexOf(protocol) === -1) {\n reject(new AxiosError('Unsupported protocol ' + protocol + ':', AxiosError.ERR_BAD_REQUEST, config));\n return;\n }\n\n\n // Send the request\n request.send(requestData || null);\n });\n};\n\nconst composeSignals = (signals, timeout) => {\n const {length} = (signals = signals ? signals.filter(Boolean) : []);\n\n if (timeout || length) {\n let controller = new AbortController();\n\n let aborted;\n\n const onabort = function (reason) {\n if (!aborted) {\n aborted = true;\n unsubscribe();\n const err = reason instanceof Error ? reason : this.reason;\n controller.abort(err instanceof AxiosError ? err : new CanceledError(err instanceof Error ? err.message : err));\n }\n };\n\n let timer = timeout && setTimeout(() => {\n timer = null;\n onabort(new AxiosError(`timeout ${timeout} of ms exceeded`, AxiosError.ETIMEDOUT));\n }, timeout);\n\n const unsubscribe = () => {\n if (signals) {\n timer && clearTimeout(timer);\n timer = null;\n signals.forEach(signal => {\n signal.unsubscribe ? signal.unsubscribe(onabort) : signal.removeEventListener('abort', onabort);\n });\n signals = null;\n }\n };\n\n signals.forEach((signal) => signal.addEventListener('abort', onabort));\n\n const {signal} = controller;\n\n signal.unsubscribe = () => utils$1.asap(unsubscribe);\n\n return signal;\n }\n};\n\nvar composeSignals$1 = composeSignals;\n\nconst streamChunk = function* (chunk, chunkSize) {\n let len = chunk.byteLength;\n\n if (!chunkSize || len < chunkSize) {\n yield chunk;\n return;\n }\n\n let pos = 0;\n let end;\n\n while (pos < len) {\n end = pos + chunkSize;\n yield chunk.slice(pos, end);\n pos = end;\n }\n};\n\nconst readBytes = async function* (iterable, chunkSize) {\n for await (const chunk of readStream(iterable)) {\n yield* streamChunk(chunk, chunkSize);\n }\n};\n\nconst readStream = async function* (stream) {\n if (stream[Symbol.asyncIterator]) {\n yield* stream;\n return;\n }\n\n const reader = stream.getReader();\n try {\n for (;;) {\n const {done, value} = await reader.read();\n if (done) {\n break;\n }\n yield value;\n }\n } finally {\n await reader.cancel();\n }\n};\n\nconst trackStream = (stream, chunkSize, onProgress, onFinish) => {\n const iterator = readBytes(stream, chunkSize);\n\n let bytes = 0;\n let done;\n let _onFinish = (e) => {\n if (!done) {\n done = true;\n onFinish && onFinish(e);\n }\n };\n\n return new ReadableStream({\n async pull(controller) {\n try {\n const {done, value} = await iterator.next();\n\n if (done) {\n _onFinish();\n controller.close();\n return;\n }\n\n let len = value.byteLength;\n if (onProgress) {\n let loadedBytes = bytes += len;\n onProgress(loadedBytes);\n }\n controller.enqueue(new Uint8Array(value));\n } catch (err) {\n _onFinish(err);\n throw err;\n }\n },\n cancel(reason) {\n _onFinish(reason);\n return iterator.return();\n }\n }, {\n highWaterMark: 2\n })\n};\n\nconst DEFAULT_CHUNK_SIZE = 64 * 1024;\n\nconst {isFunction} = utils$1;\n\nconst globalFetchAPI = (({Request, Response}) => ({\n Request, Response\n}))(utils$1.global);\n\nconst {\n ReadableStream: ReadableStream$1, TextEncoder\n} = utils$1.global;\n\n\nconst test = (fn, ...args) => {\n try {\n return !!fn(...args);\n } catch (e) {\n return false\n }\n};\n\nconst factory = (env) => {\n env = utils$1.merge.call({\n skipUndefined: true\n }, globalFetchAPI, env);\n\n const {fetch: envFetch, Request, Response} = env;\n const isFetchSupported = envFetch ? isFunction(envFetch) : typeof fetch === 'function';\n const isRequestSupported = isFunction(Request);\n const isResponseSupported = isFunction(Response);\n\n if (!isFetchSupported) {\n return false;\n }\n\n const isReadableStreamSupported = isFetchSupported && isFunction(ReadableStream$1);\n\n const encodeText = isFetchSupported && (typeof TextEncoder === 'function' ?\n ((encoder) => (str) => encoder.encode(str))(new TextEncoder()) :\n async (str) => new Uint8Array(await new Request(str).arrayBuffer())\n );\n\n const supportsRequestStream = isRequestSupported && isReadableStreamSupported && test(() => {\n let duplexAccessed = false;\n\n const hasContentType = new Request(platform.origin, {\n body: new ReadableStream$1(),\n method: 'POST',\n get duplex() {\n duplexAccessed = true;\n return 'half';\n },\n }).headers.has('Content-Type');\n\n return duplexAccessed && !hasContentType;\n });\n\n const supportsResponseStream = isResponseSupported && isReadableStreamSupported &&\n test(() => utils$1.isReadableStream(new Response('').body));\n\n const resolvers = {\n stream: supportsResponseStream && ((res) => res.body)\n };\n\n isFetchSupported && ((() => {\n ['text', 'arrayBuffer', 'blob', 'formData', 'stream'].forEach(type => {\n !resolvers[type] && (resolvers[type] = (res, config) => {\n let method = res && res[type];\n\n if (method) {\n return method.call(res);\n }\n\n throw new AxiosError(`Response type '${type}' is not supported`, AxiosError.ERR_NOT_SUPPORT, config);\n });\n });\n })());\n\n const getBodyLength = async (body) => {\n if (body == null) {\n return 0;\n }\n\n if (utils$1.isBlob(body)) {\n return body.size;\n }\n\n if (utils$1.isSpecCompliantForm(body)) {\n const _request = new Request(platform.origin, {\n method: 'POST',\n body,\n });\n return (await _request.arrayBuffer()).byteLength;\n }\n\n if (utils$1.isArrayBufferView(body) || utils$1.isArrayBuffer(body)) {\n return body.byteLength;\n }\n\n if (utils$1.isURLSearchParams(body)) {\n body = body + '';\n }\n\n if (utils$1.isString(body)) {\n return (await encodeText(body)).byteLength;\n }\n };\n\n const resolveBodyLength = async (headers, body) => {\n const length = utils$1.toFiniteNumber(headers.getContentLength());\n\n return length == null ? getBodyLength(body) : length;\n };\n\n return async (config) => {\n let {\n url,\n method,\n data,\n signal,\n cancelToken,\n timeout,\n onDownloadProgress,\n onUploadProgress,\n responseType,\n headers,\n withCredentials = 'same-origin',\n fetchOptions\n } = resolveConfig(config);\n\n let _fetch = envFetch || fetch;\n\n responseType = responseType ? (responseType + '').toLowerCase() : 'text';\n\n let composedSignal = composeSignals$1([signal, cancelToken && cancelToken.toAbortSignal()], timeout);\n\n let request = null;\n\n const unsubscribe = composedSignal && composedSignal.unsubscribe && (() => {\n composedSignal.unsubscribe();\n });\n\n let requestContentLength;\n\n try {\n if (\n onUploadProgress && supportsRequestStream && method !== 'get' && method !== 'head' &&\n (requestContentLength = await resolveBodyLength(headers, data)) !== 0\n ) {\n let _request = new Request(url, {\n method: 'POST',\n body: data,\n duplex: \"half\"\n });\n\n let contentTypeHeader;\n\n if (utils$1.isFormData(data) && (contentTypeHeader = _request.headers.get('content-type'))) {\n headers.setContentType(contentTypeHeader);\n }\n\n if (_request.body) {\n const [onProgress, flush] = progressEventDecorator(\n requestContentLength,\n progressEventReducer(asyncDecorator(onUploadProgress))\n );\n\n data = trackStream(_request.body, DEFAULT_CHUNK_SIZE, onProgress, flush);\n }\n }\n\n if (!utils$1.isString(withCredentials)) {\n withCredentials = withCredentials ? 'include' : 'omit';\n }\n\n // Cloudflare Workers throws when credentials are defined\n // see https://github.com/cloudflare/workerd/issues/902\n const isCredentialsSupported = isRequestSupported && \"credentials\" in Request.prototype;\n\n const resolvedOptions = {\n ...fetchOptions,\n signal: composedSignal,\n method: method.toUpperCase(),\n headers: headers.normalize().toJSON(),\n body: data,\n duplex: \"half\",\n credentials: isCredentialsSupported ? withCredentials : undefined\n };\n\n request = isRequestSupported && new Request(url, resolvedOptions);\n\n let response = await (isRequestSupported ? _fetch(request, fetchOptions) : _fetch(url, resolvedOptions));\n\n const isStreamResponse = supportsResponseStream && (responseType === 'stream' || responseType === 'response');\n\n if (supportsResponseStream && (onDownloadProgress || (isStreamResponse && unsubscribe))) {\n const options = {};\n\n ['status', 'statusText', 'headers'].forEach(prop => {\n options[prop] = response[prop];\n });\n\n const responseContentLength = utils$1.toFiniteNumber(response.headers.get('content-length'));\n\n const [onProgress, flush] = onDownloadProgress && progressEventDecorator(\n responseContentLength,\n progressEventReducer(asyncDecorator(onDownloadProgress), true)\n ) || [];\n\n response = new Response(\n trackStream(response.body, DEFAULT_CHUNK_SIZE, onProgress, () => {\n flush && flush();\n unsubscribe && unsubscribe();\n }),\n options\n );\n }\n\n responseType = responseType || 'text';\n\n let responseData = await resolvers[utils$1.findKey(resolvers, responseType) || 'text'](response, config);\n\n !isStreamResponse && unsubscribe && unsubscribe();\n\n return await new Promise((resolve, reject) => {\n settle(resolve, reject, {\n data: responseData,\n headers: AxiosHeaders$1.from(response.headers),\n status: response.status,\n statusText: response.statusText,\n config,\n request\n });\n })\n } catch (err) {\n unsubscribe && unsubscribe();\n\n if (err && err.name === 'TypeError' && /Load failed|fetch/i.test(err.message)) {\n throw Object.assign(\n new AxiosError('Network Error', AxiosError.ERR_NETWORK, config, request),\n {\n cause: err.cause || err\n }\n )\n }\n\n throw AxiosError.from(err, err && err.code, config, request);\n }\n }\n};\n\nconst seedCache = new Map();\n\nconst getFetch = (config) => {\n let env = config ? config.env : {};\n const {fetch, Request, Response} = env;\n const seeds = [\n Request, Response, fetch\n ];\n\n let len = seeds.length, i = len,\n seed, target, map = seedCache;\n\n while (i--) {\n seed = seeds[i];\n target = map.get(seed);\n\n target === undefined && map.set(seed, target = (i ? new Map() : factory(env)));\n\n map = target;\n }\n\n return target;\n};\n\ngetFetch();\n\nconst knownAdapters = {\n http: httpAdapter,\n xhr: xhrAdapter,\n fetch: {\n get: getFetch,\n }\n};\n\nutils$1.forEach(knownAdapters, (fn, value) => {\n if (fn) {\n try {\n Object.defineProperty(fn, 'name', {value});\n } catch (e) {\n // eslint-disable-next-line no-empty\n }\n Object.defineProperty(fn, 'adapterName', {value});\n }\n});\n\nconst renderReason = (reason) => `- ${reason}`;\n\nconst isResolvedHandle = (adapter) => utils$1.isFunction(adapter) || adapter === null || adapter === false;\n\nvar adapters = {\n getAdapter: (adapters, config) => {\n adapters = utils$1.isArray(adapters) ? adapters : [adapters];\n\n const {length} = adapters;\n let nameOrAdapter;\n let adapter;\n\n const rejectedReasons = {};\n\n for (let i = 0; i < length; i++) {\n nameOrAdapter = adapters[i];\n let id;\n\n adapter = nameOrAdapter;\n\n if (!isResolvedHandle(nameOrAdapter)) {\n adapter = knownAdapters[(id = String(nameOrAdapter)).toLowerCase()];\n\n if (adapter === undefined) {\n throw new AxiosError(`Unknown adapter '${id}'`);\n }\n }\n\n if (adapter && (utils$1.isFunction(adapter) || (adapter = adapter.get(config)))) {\n break;\n }\n\n rejectedReasons[id || '#' + i] = adapter;\n }\n\n if (!adapter) {\n\n const reasons = Object.entries(rejectedReasons)\n .map(([id, state]) => `adapter ${id} ` +\n (state === false ? 'is not supported by the environment' : 'is not available in the build')\n );\n\n let s = length ?\n (reasons.length > 1 ? 'since :\\n' + reasons.map(renderReason).join('\\n') : ' ' + renderReason(reasons[0])) :\n 'as no adapter specified';\n\n throw new AxiosError(\n `There is no suitable adapter to dispatch the request ` + s,\n 'ERR_NOT_SUPPORT'\n );\n }\n\n return adapter;\n },\n adapters: knownAdapters\n};\n\n/**\n * Throws a `CanceledError` if cancellation has been requested.\n *\n * @param {Object} config The config that is to be used for the request\n *\n * @returns {void}\n */\nfunction throwIfCancellationRequested(config) {\n if (config.cancelToken) {\n config.cancelToken.throwIfRequested();\n }\n\n if (config.signal && config.signal.aborted) {\n throw new CanceledError(null, config);\n }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n *\n * @returns {Promise} The Promise to be fulfilled\n */\nfunction dispatchRequest(config) {\n throwIfCancellationRequested(config);\n\n config.headers = AxiosHeaders$1.from(config.headers);\n\n // Transform request data\n config.data = transformData.call(\n config,\n config.transformRequest\n );\n\n if (['post', 'put', 'patch'].indexOf(config.method) !== -1) {\n config.headers.setContentType('application/x-www-form-urlencoded', false);\n }\n\n const adapter = adapters.getAdapter(config.adapter || defaults$1.adapter, config);\n\n return adapter(config).then(function onAdapterResolution(response) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n response.data = transformData.call(\n config,\n config.transformResponse,\n response\n );\n\n response.headers = AxiosHeaders$1.from(response.headers);\n\n return response;\n }, function onAdapterRejection(reason) {\n if (!isCancel(reason)) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n if (reason && reason.response) {\n reason.response.data = transformData.call(\n config,\n config.transformResponse,\n reason.response\n );\n reason.response.headers = AxiosHeaders$1.from(reason.response.headers);\n }\n }\n\n return Promise.reject(reason);\n });\n}\n\nconst VERSION = \"1.12.2\";\n\nconst validators$1 = {};\n\n// eslint-disable-next-line func-names\n['object', 'boolean', 'number', 'function', 'string', 'symbol'].forEach((type, i) => {\n validators$1[type] = function validator(thing) {\n return typeof thing === type || 'a' + (i < 1 ? 'n ' : ' ') + type;\n };\n});\n\nconst deprecatedWarnings = {};\n\n/**\n * Transitional option validator\n *\n * @param {function|boolean?} validator - set to false if the transitional option has been removed\n * @param {string?} version - deprecated version / removed since version\n * @param {string?} message - some message with additional info\n *\n * @returns {function}\n */\nvalidators$1.transitional = function transitional(validator, version, message) {\n function formatMessage(opt, desc) {\n return '[Axios v' + VERSION + '] Transitional option \\'' + opt + '\\'' + desc + (message ? '. ' + message : '');\n }\n\n // eslint-disable-next-line func-names\n return (value, opt, opts) => {\n if (validator === false) {\n throw new AxiosError(\n formatMessage(opt, ' has been removed' + (version ? ' in ' + version : '')),\n AxiosError.ERR_DEPRECATED\n );\n }\n\n if (version && !deprecatedWarnings[opt]) {\n deprecatedWarnings[opt] = true;\n // eslint-disable-next-line no-console\n console.warn(\n formatMessage(\n opt,\n ' has been deprecated since v' + version + ' and will be removed in the near future'\n )\n );\n }\n\n return validator ? validator(value, opt, opts) : true;\n };\n};\n\nvalidators$1.spelling = function spelling(correctSpelling) {\n return (value, opt) => {\n // eslint-disable-next-line no-console\n console.warn(`${opt} is likely a misspelling of ${correctSpelling}`);\n return true;\n }\n};\n\n/**\n * Assert object's properties type\n *\n * @param {object} options\n * @param {object} schema\n * @param {boolean?} allowUnknown\n *\n * @returns {object}\n */\n\nfunction assertOptions(options, schema, allowUnknown) {\n if (typeof options !== 'object') {\n throw new AxiosError('options must be an object', AxiosError.ERR_BAD_OPTION_VALUE);\n }\n const keys = Object.keys(options);\n let i = keys.length;\n while (i-- > 0) {\n const opt = keys[i];\n const validator = schema[opt];\n if (validator) {\n const value = options[opt];\n const result = value === undefined || validator(value, opt, options);\n if (result !== true) {\n throw new AxiosError('option ' + opt + ' must be ' + result, AxiosError.ERR_BAD_OPTION_VALUE);\n }\n continue;\n }\n if (allowUnknown !== true) {\n throw new AxiosError('Unknown option ' + opt, AxiosError.ERR_BAD_OPTION);\n }\n }\n}\n\nvar validator = {\n assertOptions,\n validators: validators$1\n};\n\nconst validators = validator.validators;\n\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n *\n * @return {Axios} A new instance of Axios\n */\nclass Axios {\n constructor(instanceConfig) {\n this.defaults = instanceConfig || {};\n this.interceptors = {\n request: new InterceptorManager$1(),\n response: new InterceptorManager$1()\n };\n }\n\n /**\n * Dispatch a request\n *\n * @param {String|Object} configOrUrl The config specific for this request (merged with this.defaults)\n * @param {?Object} config\n *\n * @returns {Promise} The Promise to be fulfilled\n */\n async request(configOrUrl, config) {\n try {\n return await this._request(configOrUrl, config);\n } catch (err) {\n if (err instanceof Error) {\n let dummy = {};\n\n Error.captureStackTrace ? Error.captureStackTrace(dummy) : (dummy = new Error());\n\n // slice off the Error: ... line\n const stack = dummy.stack ? dummy.stack.replace(/^.+\\n/, '') : '';\n try {\n if (!err.stack) {\n err.stack = stack;\n // match without the 2 top stack lines\n } else if (stack && !String(err.stack).endsWith(stack.replace(/^.+\\n.+\\n/, ''))) {\n err.stack += '\\n' + stack;\n }\n } catch (e) {\n // ignore the case where \"stack\" is an un-writable property\n }\n }\n\n throw err;\n }\n }\n\n _request(configOrUrl, config) {\n /*eslint no-param-reassign:0*/\n // Allow for axios('example/url'[, config]) a la fetch API\n if (typeof configOrUrl === 'string') {\n config = config || {};\n config.url = configOrUrl;\n } else {\n config = configOrUrl || {};\n }\n\n config = mergeConfig(this.defaults, config);\n\n const {transitional, paramsSerializer, headers} = config;\n\n if (transitional !== undefined) {\n validator.assertOptions(transitional, {\n silentJSONParsing: validators.transitional(validators.boolean),\n forcedJSONParsing: validators.transitional(validators.boolean),\n clarifyTimeoutError: validators.transitional(validators.boolean)\n }, false);\n }\n\n if (paramsSerializer != null) {\n if (utils$1.isFunction(paramsSerializer)) {\n config.paramsSerializer = {\n serialize: paramsSerializer\n };\n } else {\n validator.assertOptions(paramsSerializer, {\n encode: validators.function,\n serialize: validators.function\n }, true);\n }\n }\n\n // Set config.allowAbsoluteUrls\n if (config.allowAbsoluteUrls !== undefined) ; else if (this.defaults.allowAbsoluteUrls !== undefined) {\n config.allowAbsoluteUrls = this.defaults.allowAbsoluteUrls;\n } else {\n config.allowAbsoluteUrls = true;\n }\n\n validator.assertOptions(config, {\n baseUrl: validators.spelling('baseURL'),\n withXsrfToken: validators.spelling('withXSRFToken')\n }, true);\n\n // Set config.method\n config.method = (config.method || this.defaults.method || 'get').toLowerCase();\n\n // Flatten headers\n let contextHeaders = headers && utils$1.merge(\n headers.common,\n headers[config.method]\n );\n\n headers && utils$1.forEach(\n ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n (method) => {\n delete headers[method];\n }\n );\n\n config.headers = AxiosHeaders$1.concat(contextHeaders, headers);\n\n // filter out skipped interceptors\n const requestInterceptorChain = [];\n let synchronousRequestInterceptors = true;\n this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n if (typeof interceptor.runWhen === 'function' && interceptor.runWhen(config) === false) {\n return;\n }\n\n synchronousRequestInterceptors = synchronousRequestInterceptors && interceptor.synchronous;\n\n requestInterceptorChain.unshift(interceptor.fulfilled, interceptor.rejected);\n });\n\n const responseInterceptorChain = [];\n this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n responseInterceptorChain.push(interceptor.fulfilled, interceptor.rejected);\n });\n\n let promise;\n let i = 0;\n let len;\n\n if (!synchronousRequestInterceptors) {\n const chain = [dispatchRequest.bind(this), undefined];\n chain.unshift(...requestInterceptorChain);\n chain.push(...responseInterceptorChain);\n len = chain.length;\n\n promise = Promise.resolve(config);\n\n while (i < len) {\n promise = promise.then(chain[i++], chain[i++]);\n }\n\n return promise;\n }\n\n len = requestInterceptorChain.length;\n\n let newConfig = config;\n\n while (i < len) {\n const onFulfilled = requestInterceptorChain[i++];\n const onRejected = requestInterceptorChain[i++];\n try {\n newConfig = onFulfilled(newConfig);\n } catch (error) {\n onRejected.call(this, error);\n break;\n }\n }\n\n try {\n promise = dispatchRequest.call(this, newConfig);\n } catch (error) {\n return Promise.reject(error);\n }\n\n i = 0;\n len = responseInterceptorChain.length;\n\n while (i < len) {\n promise = promise.then(responseInterceptorChain[i++], responseInterceptorChain[i++]);\n }\n\n return promise;\n }\n\n getUri(config) {\n config = mergeConfig(this.defaults, config);\n const fullPath = buildFullPath(config.baseURL, config.url, config.allowAbsoluteUrls);\n return buildURL(fullPath, config.params, config.paramsSerializer);\n }\n}\n\n// Provide aliases for supported request methods\nutils$1.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, config) {\n return this.request(mergeConfig(config || {}, {\n method,\n url,\n data: (config || {}).data\n }));\n };\n});\n\nutils$1.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n /*eslint func-names:0*/\n\n function generateHTTPMethod(isForm) {\n return function httpMethod(url, data, config) {\n return this.request(mergeConfig(config || {}, {\n method,\n headers: isForm ? {\n 'Content-Type': 'multipart/form-data'\n } : {},\n url,\n data\n }));\n };\n }\n\n Axios.prototype[method] = generateHTTPMethod();\n\n Axios.prototype[method + 'Form'] = generateHTTPMethod(true);\n});\n\nvar Axios$1 = Axios;\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @param {Function} executor The executor function.\n *\n * @returns {CancelToken}\n */\nclass CancelToken {\n constructor(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n\n let resolvePromise;\n\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n\n const token = this;\n\n // eslint-disable-next-line func-names\n this.promise.then(cancel => {\n if (!token._listeners) return;\n\n let i = token._listeners.length;\n\n while (i-- > 0) {\n token._listeners[i](cancel);\n }\n token._listeners = null;\n });\n\n // eslint-disable-next-line func-names\n this.promise.then = onfulfilled => {\n let _resolve;\n // eslint-disable-next-line func-names\n const promise = new Promise(resolve => {\n token.subscribe(resolve);\n _resolve = resolve;\n }).then(onfulfilled);\n\n promise.cancel = function reject() {\n token.unsubscribe(_resolve);\n };\n\n return promise;\n };\n\n executor(function cancel(message, config, request) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n\n token.reason = new CanceledError(message, config, request);\n resolvePromise(token.reason);\n });\n }\n\n /**\n * Throws a `CanceledError` if cancellation has been requested.\n */\n throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n }\n\n /**\n * Subscribe to the cancel signal\n */\n\n subscribe(listener) {\n if (this.reason) {\n listener(this.reason);\n return;\n }\n\n if (this._listeners) {\n this._listeners.push(listener);\n } else {\n this._listeners = [listener];\n }\n }\n\n /**\n * Unsubscribe from the cancel signal\n */\n\n unsubscribe(listener) {\n if (!this._listeners) {\n return;\n }\n const index = this._listeners.indexOf(listener);\n if (index !== -1) {\n this._listeners.splice(index, 1);\n }\n }\n\n toAbortSignal() {\n const controller = new AbortController();\n\n const abort = (err) => {\n controller.abort(err);\n };\n\n this.subscribe(abort);\n\n controller.signal.unsubscribe = () => this.unsubscribe(abort);\n\n return controller.signal;\n }\n\n /**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\n static source() {\n let cancel;\n const token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token,\n cancel\n };\n }\n}\n\nvar CancelToken$1 = CancelToken;\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n *\n * @returns {Function}\n */\nfunction spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n}\n\n/**\n * Determines whether the payload is an error thrown by Axios\n *\n * @param {*} payload The value to test\n *\n * @returns {boolean} True if the payload is an error thrown by Axios, otherwise false\n */\nfunction isAxiosError(payload) {\n return utils$1.isObject(payload) && (payload.isAxiosError === true);\n}\n\nconst HttpStatusCode = {\n Continue: 100,\n SwitchingProtocols: 101,\n Processing: 102,\n EarlyHints: 103,\n Ok: 200,\n Created: 201,\n Accepted: 202,\n NonAuthoritativeInformation: 203,\n NoContent: 204,\n ResetContent: 205,\n PartialContent: 206,\n MultiStatus: 207,\n AlreadyReported: 208,\n ImUsed: 226,\n MultipleChoices: 300,\n MovedPermanently: 301,\n Found: 302,\n SeeOther: 303,\n NotModified: 304,\n UseProxy: 305,\n Unused: 306,\n TemporaryRedirect: 307,\n PermanentRedirect: 308,\n BadRequest: 400,\n Unauthorized: 401,\n PaymentRequired: 402,\n Forbidden: 403,\n NotFound: 404,\n MethodNotAllowed: 405,\n NotAcceptable: 406,\n ProxyAuthenticationRequired: 407,\n RequestTimeout: 408,\n Conflict: 409,\n Gone: 410,\n LengthRequired: 411,\n PreconditionFailed: 412,\n PayloadTooLarge: 413,\n UriTooLong: 414,\n UnsupportedMediaType: 415,\n RangeNotSatisfiable: 416,\n ExpectationFailed: 417,\n ImATeapot: 418,\n MisdirectedRequest: 421,\n UnprocessableEntity: 422,\n Locked: 423,\n FailedDependency: 424,\n TooEarly: 425,\n UpgradeRequired: 426,\n PreconditionRequired: 428,\n TooManyRequests: 429,\n RequestHeaderFieldsTooLarge: 431,\n UnavailableForLegalReasons: 451,\n InternalServerError: 500,\n NotImplemented: 501,\n BadGateway: 502,\n ServiceUnavailable: 503,\n GatewayTimeout: 504,\n HttpVersionNotSupported: 505,\n VariantAlsoNegotiates: 506,\n InsufficientStorage: 507,\n LoopDetected: 508,\n NotExtended: 510,\n NetworkAuthenticationRequired: 511,\n};\n\nObject.entries(HttpStatusCode).forEach(([key, value]) => {\n HttpStatusCode[value] = key;\n});\n\nvar HttpStatusCode$1 = HttpStatusCode;\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n *\n * @returns {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n const context = new Axios$1(defaultConfig);\n const instance = bind(Axios$1.prototype.request, context);\n\n // Copy axios.prototype to instance\n utils$1.extend(instance, Axios$1.prototype, context, {allOwnKeys: true});\n\n // Copy context to instance\n utils$1.extend(instance, context, null, {allOwnKeys: true});\n\n // Factory for creating new instances\n instance.create = function create(instanceConfig) {\n return createInstance(mergeConfig(defaultConfig, instanceConfig));\n };\n\n return instance;\n}\n\n// Create the default instance to be exported\nconst axios = createInstance(defaults$1);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios$1;\n\n// Expose Cancel & CancelToken\naxios.CanceledError = CanceledError;\naxios.CancelToken = CancelToken$1;\naxios.isCancel = isCancel;\naxios.VERSION = VERSION;\naxios.toFormData = toFormData;\n\n// Expose AxiosError class\naxios.AxiosError = AxiosError;\n\n// alias for CanceledError for backward compatibility\naxios.Cancel = axios.CanceledError;\n\n// Expose all/spread\naxios.all = function all(promises) {\n return Promise.all(promises);\n};\n\naxios.spread = spread;\n\n// Expose isAxiosError\naxios.isAxiosError = isAxiosError;\n\n// Expose mergeConfig\naxios.mergeConfig = mergeConfig;\n\naxios.AxiosHeaders = AxiosHeaders$1;\n\naxios.formToJSON = thing => formDataToJSON(utils$1.isHTMLForm(thing) ? new FormData(thing) : thing);\n\naxios.getAdapter = adapters.getAdapter;\n\naxios.HttpStatusCode = HttpStatusCode$1;\n\naxios.default = axios;\n\nmodule.exports = axios;\n//# sourceMappingURL=axios.cjs.map\n","\"use strict\";\nObject.defineProperty(exports, Symbol.toStringTag, { value: \"Module\" });\nconst valid = require(\"semver/functions/valid.js\");\nconst major = require(\"semver/functions/major.js\");\nconst _interopDefault = (e) => e && e.__esModule ? e : { default: e };\nconst valid__default = /* @__PURE__ */ _interopDefault(valid);\nconst major__default = /* @__PURE__ */ _interopDefault(major);\nclass ProxyBus {\n bus;\n constructor(bus2) {\n if (typeof bus2.getVersion !== \"function\" || !valid__default.default(bus2.getVersion())) {\n console.warn(\"Proxying an event bus with an unknown or invalid version\");\n } else if (major__default.default(bus2.getVersion()) !== major__default.default(this.getVersion())) {\n console.warn(\n \"Proxying an event bus of version \" + bus2.getVersion() + \" with \" + this.getVersion()\n );\n }\n this.bus = bus2;\n }\n getVersion() {\n return \"3.3.2\";\n }\n subscribe(name, handler) {\n this.bus.subscribe(name, handler);\n }\n unsubscribe(name, handler) {\n this.bus.unsubscribe(name, handler);\n }\n emit(name, ...event) {\n this.bus.emit(name, ...event);\n }\n}\nclass SimpleBus {\n handlers = /* @__PURE__ */ new Map();\n getVersion() {\n return \"3.3.2\";\n }\n subscribe(name, handler) {\n this.handlers.set(\n name,\n (this.handlers.get(name) || []).concat(\n handler\n )\n );\n }\n unsubscribe(name, handler) {\n this.handlers.set(\n name,\n (this.handlers.get(name) || []).filter((h) => h !== handler)\n );\n }\n emit(name, ...event) {\n const handlers = this.handlers.get(name) || [];\n handlers.forEach((h) => {\n try {\n ;\n h(event[0]);\n } catch (e) {\n console.error(\"could not invoke event listener\", e);\n }\n });\n }\n}\nlet bus = null;\nfunction getBus() {\n if (bus !== null) {\n return bus;\n }\n if (typeof window === \"undefined\") {\n return new Proxy({}, {\n get: () => {\n return () => console.error(\n \"Window not available, EventBus can not be established!\"\n );\n }\n });\n }\n if (window.OC?._eventBus && typeof window._nc_event_bus === \"undefined\") {\n console.warn(\n \"found old event bus instance at OC._eventBus. Update your version!\"\n );\n window._nc_event_bus = window.OC._eventBus;\n }\n if (typeof window?._nc_event_bus !== \"undefined\") {\n bus = new ProxyBus(window._nc_event_bus);\n } else {\n bus = window._nc_event_bus = new SimpleBus();\n }\n return bus;\n}\nfunction subscribe(name, handler) {\n getBus().subscribe(name, handler);\n}\nfunction unsubscribe(name, handler) {\n getBus().unsubscribe(name, handler);\n}\nfunction emit(name, ...event) {\n getBus().emit(name, ...event);\n}\nexports.ProxyBus = ProxyBus;\nexports.SimpleBus = SimpleBus;\nexports.emit = emit;\nexports.subscribe = subscribe;\nexports.unsubscribe = unsubscribe;\n","\"use strict\";\nObject.defineProperty(exports, Symbol.toStringTag, { value: \"Module\" });\nconst eventBus = require(\"@nextcloud/event-bus\");\nconst browserStorage$1 = require(\"@nextcloud/browser-storage\");\nlet token;\nconst observers = [];\nfunction getRequestToken() {\n if (token === void 0) {\n token = document.head.dataset.requesttoken ?? null;\n }\n return token;\n}\nfunction onRequestTokenUpdate(observer) {\n observers.push(observer);\n}\neventBus.subscribe(\"csrf-token-update\", (e) => {\n token = e.token;\n observers.forEach((observer) => {\n try {\n observer(token);\n } catch (error) {\n console.error(\"Error updating CSRF token observer\", error);\n }\n });\n});\nfunction getCSPNonce() {\n const meta = document?.querySelector('meta[name=\"csp-nonce\"]');\n if (!meta) {\n const token2 = getRequestToken();\n return token2 ? btoa(token2) : void 0;\n }\n return meta.nonce;\n}\n/*!\n * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: GPL-3.0-or-later\n */\nconst browserStorage = browserStorage$1.getBuilder(\"public\").persist().build();\nclass GuestUser {\n _displayName;\n uid;\n isAdmin;\n constructor() {\n if (!browserStorage.getItem(\"guestUid\")) {\n browserStorage.setItem(\"guestUid\", randomUUID());\n }\n this._displayName = browserStorage.getItem(\"guestNickname\") || \"\";\n this.uid = browserStorage.getItem(\"guestUid\") || randomUUID();\n this.isAdmin = false;\n eventBus.subscribe(\"user:info:changed\", (guest) => {\n this._displayName = guest.displayName;\n browserStorage.setItem(\"guestNickname\", guest.displayName || \"\");\n });\n }\n get displayName() {\n return this._displayName;\n }\n set displayName(displayName) {\n this._displayName = displayName;\n browserStorage.setItem(\"guestNickname\", displayName);\n eventBus.emit(\"user:info:changed\", this);\n }\n}\nlet currentUser$1;\nfunction getGuestUser() {\n if (!currentUser$1) {\n currentUser$1 = new GuestUser();\n }\n return currentUser$1;\n}\nfunction getGuestNickname() {\n return getGuestUser()?.displayName || null;\n}\nfunction setGuestNickname(nickname) {\n if (!nickname || nickname.trim().length === 0) {\n throw new Error(\"Nickname cannot be empty\");\n }\n getGuestUser().displayName = nickname;\n}\nfunction randomUUID() {\n if (globalThis.crypto?.randomUUID) {\n return globalThis.crypto.randomUUID();\n }\n return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n const v = c === \"x\" ? r : r & 3 | 8;\n return v.toString(16);\n });\n}\nlet currentUser;\nfunction getAttribute(el, attribute) {\n if (el) {\n return el.getAttribute(attribute);\n }\n return null;\n}\nfunction getCurrentUser() {\n if (currentUser !== void 0) {\n return currentUser;\n }\n const head = document?.getElementsByTagName(\"head\")[0];\n if (!head) {\n return null;\n }\n const uid = getAttribute(head, \"data-user\");\n if (uid === null) {\n currentUser = null;\n return currentUser;\n }\n currentUser = {\n uid,\n displayName: getAttribute(head, \"data-user-displayname\"),\n isAdmin: !!window._oc_isadmin\n };\n return currentUser;\n}\nexports.getCSPNonce = getCSPNonce;\nexports.getCurrentUser = getCurrentUser;\nexports.getGuestNickname = getGuestNickname;\nexports.getGuestUser = getGuestUser;\nexports.getRequestToken = getRequestToken;\nexports.onRequestTokenUpdate = onRequestTokenUpdate;\nexports.setGuestNickname = setGuestNickname;\n//# sourceMappingURL=index.cjs.map\n","\"use strict\";\nObject.defineProperty(exports, Symbol.toStringTag, { value: \"Module\" });\nconst w = (e, n) => u(e, \"\", n), U = (e) => \"/remote.php/\" + e, R = (e, n) => {\n var o;\n return ((o = n == null ? void 0 : n.baseURL) != null ? o : f()) + U(e);\n}, h = (e, n, o) => {\n var r;\n const c = Object.assign({\n ocsVersion: 2\n }, o || {}).ocsVersion === 1 ? 1 : 2;\n return ((r = o == null ? void 0 : o.baseURL) != null ? r : f()) + \"/ocs/v\" + c + \".php\" + g(e, n, o);\n}, g = (e, n, o) => {\n const r = Object.assign({\n escape: !0\n }, o || {}), s = function(c, i) {\n return i = i || {}, c.replace(\n /{([^{}]*)}/g,\n function(l, t) {\n const a = i[t];\n return r.escape ? encodeURIComponent(typeof a == \"string\" || typeof a == \"number\" ? a.toString() : l) : typeof a == \"string\" || typeof a == \"number\" ? a.toString() : l;\n }\n );\n };\n return e.charAt(0) !== \"/\" && (e = \"/\" + e), s(e, n || {});\n}, v = (e, n, o) => {\n var r, s, c;\n const i = Object.assign({\n noRewrite: !1\n }, o || {}), l = (r = o == null ? void 0 : o.baseURL) != null ? r : d();\n return ((c = (s = window == null ? void 0 : window.OC) == null ? void 0 : s.config) == null ? void 0 : c.modRewriteWorking) === !0 && !i.noRewrite ? l + g(e, n, o) : l + \"/index.php\" + g(e, n, o);\n}, _ = (e, n) => n.includes(\".\") ? u(e, \"img\", n) : u(e, \"img\", \"\".concat(n, \".svg\")), u = (e, n, o) => {\n var r, s, c;\n const i = (c = (s = (r = window == null ? void 0 : window.OC) == null ? void 0 : r.coreApps) == null ? void 0 : s.includes(e)) != null ? c : !1, l = o.slice(-3) === \"php\";\n let t = d();\n return l && !i ? (t += \"/index.php/apps/\".concat(e), n && (t += \"/\".concat(encodeURI(n))), o !== \"index.php\" && (t += \"/\".concat(o))) : !l && !i ? (t = b(e), n && (t += \"/\".concat(n, \"/\")), t.at(-1) !== \"/\" && (t += \"/\"), t += o) : ((e === \"settings\" || e === \"core\" || e === \"search\") && n === \"ajax\" && (t += \"/index.php\"), e && (t += \"/\".concat(e)), n && (t += \"/\".concat(n)), t += \"/\".concat(o)), t;\n}, f = () => window.location.protocol + \"//\" + window.location.host + d();\nfunction d() {\n let e = window._oc_webroot;\n if (typeof e > \"u\") {\n e = location.pathname;\n const n = e.indexOf(\"/index.php/\");\n if (n !== -1)\n e = e.slice(0, n);\n else {\n const o = e.indexOf(\"/\", 1);\n e = e.slice(0, o > 0 ? o : void 0);\n }\n }\n return e;\n}\nfunction b(e) {\n var n, o;\n return (o = ((n = window._oc_appswebroots) != null ? n : {})[e]) != null ? o : \"\";\n}\nexports.generateFilePath = u;\nexports.generateOcsUrl = h;\nexports.generateRemoteUrl = R;\nexports.generateUrl = v;\nexports.getAppRootUrl = b;\nexports.getBaseUrl = f;\nexports.getRootUrl = d;\nexports.imagePath = _;\nexports.linkTo = w;\n","\"use strict\";\nObject.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: \"Module\" } });\nconst Axios = require(\"axios\");\nconst auth = require(\"@nextcloud/auth\");\nconst router = require(\"@nextcloud/router\");\nconst _interopDefault = (e) => e && e.__esModule ? e : { default: e };\nconst Axios__default = /* @__PURE__ */ _interopDefault(Axios);\nconst RETRY_KEY = Symbol(\"csrf-retry\");\nconst onError$2 = (axios) => async (error) => {\n var _a2;\n const { config, response, request } = error;\n const responseURL = request == null ? void 0 : request.responseURL;\n const status = response == null ? void 0 : response.status;\n if (status === 412 && ((_a2 = response == null ? void 0 : response.data) == null ? void 0 : _a2.message) === \"CSRF check failed\" && config[RETRY_KEY] === void 0) {\n console.warn(\"Request to \".concat(responseURL, \" failed because of a CSRF mismatch. Fetching a new token\"));\n const { data: { token } } = await axios.get(router.generateUrl(\"/csrftoken\"));\n console.debug(\"New request token \".concat(token, \" fetched\"));\n axios.defaults.headers.requesttoken = token;\n return axios({\n ...config,\n headers: {\n ...config.headers,\n requesttoken: token\n },\n [RETRY_KEY]: true\n });\n }\n return Promise.reject(error);\n};\nconst RETRY_DELAY_KEY = Symbol(\"retryDelay\");\nconst onError$1 = (axios) => async (error) => {\n var _a2;\n const { config, response, request } = error;\n const responseURL = request == null ? void 0 : request.responseURL;\n const status = response == null ? void 0 : response.status;\n const headers = response == null ? void 0 : response.headers;\n if (status === 503 && headers[\"x-nextcloud-maintenance-mode\"] === \"1\" && config.retryIfMaintenanceMode && (!config[RETRY_DELAY_KEY] || config[RETRY_DELAY_KEY] <= 32)) {\n const retryDelay = ((_a2 = config[RETRY_DELAY_KEY]) != null ? _a2 : 1) * 2;\n console.warn(\"Request to \".concat(responseURL, \" failed because of maintenance mode. Retrying in \").concat(retryDelay, \"s\"));\n await new Promise((resolve) => {\n setTimeout(resolve, retryDelay * 1e3);\n });\n return axios({\n ...config,\n [RETRY_DELAY_KEY]: retryDelay\n });\n }\n return Promise.reject(error);\n};\nconst onError = async (error) => {\n var _a2;\n const { config, response, request } = error;\n const responseURL = request == null ? void 0 : request.responseURL;\n const status = response == null ? void 0 : response.status;\n if (status === 401 && ((_a2 = response == null ? void 0 : response.data) == null ? void 0 : _a2.message) === \"Current user is not logged in\" && config.reloadExpiredSession && (window == null ? void 0 : window.location)) {\n console.error(\"Request to \".concat(responseURL, \" failed because the user session expired. Reloading the page …\"));\n window.location.reload();\n }\n return Promise.reject(error);\n};\nvar _a;\nconst client = Axios__default.default.create({\n headers: {\n requesttoken: (_a = auth.getRequestToken()) != null ? _a : \"\",\n \"X-Requested-With\": \"XMLHttpRequest\"\n }\n});\nconst cancelableClient = Object.assign(client, {\n CancelToken: Axios__default.default.CancelToken,\n isCancel: Axios__default.default.isCancel\n});\ncancelableClient.interceptors.response.use((r) => r, onError$2(cancelableClient));\ncancelableClient.interceptors.response.use((r) => r, onError$1(cancelableClient));\ncancelableClient.interceptors.response.use((r) => r, onError);\nauth.onRequestTokenUpdate((token) => {\n client.defaults.headers.requesttoken = token;\n});\nObject.defineProperty(exports, \"isAxiosError\", {\n enumerable: true,\n get: () => Axios.isAxiosError\n});\nObject.defineProperty(exports, \"isCancel\", {\n enumerable: true,\n get: () => Axios.isCancel\n});\nexports.default = cancelableClient;\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.listen = exports.getSupportedTypes = void 0;\nconst capabilities_1 = require(\"@nextcloud/capabilities\");\nconst axios_1 = __importDefault(require(\"@nextcloud/axios\"));\nconst event_bus_1 = require(\"@nextcloud/event-bus\");\n/**\n * Get the list of supported notification types as reported by the server\n *\n * @return string[]\n */\nfunction getSupportedTypes() {\n const capabilities = (0, capabilities_1.getCapabilities)();\n if (capabilities.notify_push) {\n return capabilities.notify_push.type;\n }\n else {\n return [];\n }\n}\nexports.getSupportedTypes = getSupportedTypes;\n/**\n * Register a listener for notify_push events\n *\n * @param name name of the event\n * @param handler callback invoked for every matching event pushed\n * @param [options]\n * @param [options.credentials] optional credentials used instead of the pre_auth request\n * @param [options.credentials.username] username\n * @param [options.credentials.password] app password\n * @return boolean whether push is set up correctly\n */\nfunction listen(name, handler, options = {}) {\n setupGlobals(options);\n if (!window._notify_push_listeners[name]) {\n window._notify_push_listeners[name] = [];\n }\n window._notify_push_listeners[name].push(handler);\n if (window._notify_push_ws !== null && typeof window._notify_push_ws === \"object\") {\n window._notify_push_ws.send('listen ' + name);\n }\n else {\n setupSocket(options);\n }\n return window._notify_push_available;\n}\nexports.listen = listen;\nfunction setupGlobals(options = {}) {\n if (typeof window._notify_push_listeners === \"undefined\") {\n window._notify_push_listeners = {};\n window._notify_push_ws = null;\n window._notify_push_online = true;\n window._notify_push_available = false;\n window._notify_push_error_count = 0;\n (0, event_bus_1.subscribe)('networkOffline', () => {\n window._notify_push_online = false;\n window._notify_push_ws = null;\n });\n (0, event_bus_1.subscribe)('networkOnline', () => {\n window._notify_push_error_count = 0;\n window._notify_push_online = true;\n setupSocket(options);\n });\n }\n}\nasync function setupSocket(options = {}) {\n if (window._notify_push_ws) {\n return true;\n }\n window._notify_push_ws = true;\n const capabilities = (0, capabilities_1.getCapabilities)();\n if (!capabilities.notify_push) {\n window._notify_push_available = false;\n window._notify_push_ws = null;\n return false;\n }\n window._notify_push_available = true;\n let preAuth;\n if (!options.credentials) {\n const response = await axios_1.default.post(capabilities.notify_push.endpoints.pre_auth);\n preAuth = response.data;\n }\n window._notify_push_ws = new WebSocket(capabilities.notify_push.endpoints.websocket);\n window._notify_push_ws.onopen = () => {\n if (typeof window._notify_push_ws === \"object\" && window._notify_push_ws) {\n if (preAuth) {\n window._notify_push_ws.send('');\n window._notify_push_ws.send(preAuth);\n }\n else if (options.credentials) {\n window._notify_push_ws.send(options.credentials.username);\n window._notify_push_ws.send(options.credentials.password);\n }\n for (let name in window._notify_push_listeners) {\n window._notify_push_ws.send('listen ' + name);\n }\n }\n };\n window._notify_push_ws.onmessage = message => {\n if (message.data === \"authenticated\") {\n window._notify_push_error_count = 0;\n }\n else {\n const i = message.data.indexOf(' ');\n let [event, body] = i > 0 ? [message.data.slice(0, i), message.data.slice(i + 1)] : [message.data, null];\n if (body) {\n body = JSON.parse(body);\n }\n if (window._notify_push_listeners[event]) {\n for (let cb of window._notify_push_listeners[event]) {\n cb(event, body);\n }\n }\n }\n };\n window._notify_push_ws.onerror = window._notify_push_ws.onclose = () => {\n window._notify_push_ws = null;\n window._notify_push_error_count += 1;\n setTimeout(() => {\n if (window._notify_push_online) {\n setupSocket(options);\n }\n }, 1000 * window._notify_push_error_count);\n };\n return true;\n}\n","import '../assets/NcEmptyContent-q-geAf0w.css';\nimport { defineComponent, createElementBlock, openBlock, createCommentVNode, renderSlot, toDisplayString, createTextVNode } from \"vue\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst _hoisted_1 = {\n class: \"empty-content\",\n role: \"note\"\n};\nconst _hoisted_2 = {\n key: 0,\n class: \"empty-content__icon\",\n \"aria-hidden\": \"true\"\n};\nconst _hoisted_3 = {\n key: 0,\n class: \"empty-content__name\"\n};\nconst _hoisted_4 = {\n key: 1,\n class: \"empty-content__description\"\n};\nconst _hoisted_5 = {\n key: 2,\n class: \"empty-content__action\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcEmptyContent\",\n props: {\n description: { default: \"\" },\n name: { default: \"\" }\n },\n setup(__props) {\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"div\", _hoisted_1, [\n _ctx.$slots.icon ? (openBlock(), createElementBlock(\"div\", _hoisted_2, [\n renderSlot(_ctx.$slots, \"icon\", {}, void 0, true)\n ])) : createCommentVNode(\"\", true),\n renderSlot(_ctx.$slots, \"name\", {}, () => [\n _ctx.name !== \"\" ? (openBlock(), createElementBlock(\"span\", _hoisted_3, toDisplayString(_ctx.name), 1)) : createCommentVNode(\"\", true)\n ], true),\n _ctx.description !== \"\" || _ctx.$slots.description ? (openBlock(), createElementBlock(\"p\", _hoisted_4, [\n renderSlot(_ctx.$slots, \"description\", {}, () => [\n createTextVNode(toDisplayString(_ctx.description), 1)\n ], true)\n ])) : createCommentVNode(\"\", true),\n _ctx.$slots.action ? (openBlock(), createElementBlock(\"div\", _hoisted_5, [\n renderSlot(_ctx.$slots, \"action\", {}, void 0, true)\n ])) : createCommentVNode(\"\", true)\n ]);\n };\n }\n});\nconst NcEmptyContent = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-697cfd8f\"]]);\nexport {\n NcEmptyContent as N\n};\n//# sourceMappingURL=NcEmptyContent-BdOezubv.mjs.map\n","import { formatRelativeTime, getCanonicalLocale } from \"@nextcloud/l10n\";\nimport { computed, toValue, ref, watchEffect, onUnmounted, readonly } from \"vue\";\nimport { r as register, b as t2, a as t } from \"../../chunks/_l10n-CeXHJQB0.mjs\";\nregister(t2);\nconst FEW_SECONDS_AGO = {\n long: t(\"a few seconds ago\"),\n short: t(\"seconds ago\"),\n // FOR TRANSLATORS: Shorter version of 'a few seconds ago'\n narrow: t(\"sec. ago\")\n // FOR TRANSLATORS: If possible in your language an even shorter version of 'a few seconds ago'\n};\nfunction useFormatRelativeTime(timestamp = Date.now(), opts = {}) {\n let timeoutId;\n const date = computed(() => new Date(toValue(timestamp)));\n const options = computed(() => {\n const { language, relativeTime: relativeTime2, ignoreSeconds } = toValue(opts);\n return {\n ...language && { language },\n ...relativeTime2 && { relativeTime: relativeTime2 },\n ignoreSeconds: ignoreSeconds ? FEW_SECONDS_AGO[relativeTime2 || \"long\"] : false\n };\n });\n const relativeTime = ref(\"\");\n watchEffect(() => updateRelativeTime());\n function updateRelativeTime() {\n relativeTime.value = formatRelativeTime(date.value, options.value);\n if (toValue(opts).update !== false) {\n const diff = Math.abs(Date.now() - new Date(toValue(timestamp)).getTime());\n const interval = diff > 12e4 || options.value.ignoreSeconds ? Math.min(diff / 60, 18e5) : 1e3;\n timeoutId = window.setTimeout(updateRelativeTime, interval);\n }\n }\n onUnmounted(() => timeoutId && window.clearTimeout(timeoutId));\n return readonly(relativeTime);\n}\nfunction useFormatTime(timestamp, opts) {\n const options = computed(() => ({\n locale: getCanonicalLocale(),\n format: { dateStyle: \"short\", timeStyle: \"medium\" },\n ...toValue(opts)\n }));\n const formatter = computed(() => new Intl.DateTimeFormat(options.value.locale, options.value.format));\n return computed(() => formatter.value.format(toValue(timestamp)));\n}\nexport {\n useFormatRelativeTime,\n useFormatTime\n};\n//# sourceMappingURL=index.mjs.map\n","const isMac = /mac|ipad|iphone|darwin/i.test(navigator.userAgent);\nexport {\n isMac as i\n};\n//# sourceMappingURL=platform-CC2ecGvV.mjs.map\n","import { onKeyStroke } from \"@vueuse/core\";\nimport { i as isMac } from \"../../chunks/platform-CC2ecGvV.mjs\";\nconst disableKeyboardShortcuts = window.OCP?.Accessibility?.disableKeyboardShortcuts?.();\nconst derivedKeysRegex = /^[a-zA-Z0-9]$/;\nconst nonAsciiPrintableRegex = /^[^\\x20-\\x7F]$/;\nfunction shouldIgnoreEvent(event) {\n if (!(event.target instanceof HTMLElement) || event.target instanceof HTMLInputElement || event.target instanceof HTMLTextAreaElement || event.target instanceof HTMLSelectElement || event.target.isContentEditable) {\n return true;\n }\n return document.getElementsByClassName(\"modal-mask\").length !== 0;\n}\nfunction eventHandler(callback, options) {\n return (event) => {\n const ctrlKeyPressed = isMac ? event.metaKey : event.ctrlKey;\n if (ctrlKeyPressed !== Boolean(options.ctrl)) {\n return;\n } else if (event.altKey !== Boolean(options.alt)) {\n return;\n } else if (options.shift !== void 0 && event.shiftKey !== Boolean(options.shift)) {\n return;\n } else if (shouldIgnoreEvent(event)) {\n return;\n }\n if (options.prevent) {\n event.preventDefault();\n }\n if (options.stop) {\n event.stopPropagation();\n }\n callback(event);\n };\n}\nfunction useHotKey(keysOrFilter, callback = () => {\n}, options = {}) {\n if (disableKeyboardShortcuts) {\n return () => {\n };\n }\n const validateKeyEvent = (event, key) => {\n if (event.key === key) {\n return true;\n }\n if (options.caseSensitive) {\n const isKeyInLowerCase = key === key.toLowerCase();\n const isEventKeyInLowerCase = event.key === event.key.toLowerCase();\n if (isKeyInLowerCase !== isEventKeyInLowerCase) {\n return false;\n }\n }\n if (derivedKeysRegex.test(key) && nonAsciiPrintableRegex.test(event.key)) {\n return event.code.replace(/^(?:Key|Digit|Numpad)/, \"\") === key.toUpperCase();\n }\n return event.key.toLowerCase() === key.toLowerCase();\n };\n const keyFilter = (event) => {\n if (typeof keysOrFilter === \"function\") {\n return keysOrFilter(event);\n } else if (typeof keysOrFilter === \"string\") {\n return validateKeyEvent(event, keysOrFilter);\n } else if (Array.isArray(keysOrFilter)) {\n return keysOrFilter.some((key) => validateKeyEvent(event, key));\n } else {\n return true;\n }\n };\n const stopKeyDown = onKeyStroke(keyFilter, eventHandler(callback, options), {\n eventName: \"keydown\",\n dedupe: true,\n passive: !options.prevent\n });\n const stopKeyUp = options.push ? onKeyStroke(keyFilter, eventHandler(callback, options), {\n eventName: \"keyup\",\n passive: !options.prevent\n }) : () => {\n };\n return () => {\n stopKeyDown();\n stopKeyUp();\n };\n}\nexport {\n useHotKey\n};\n//# sourceMappingURL=index.mjs.map\n","function checkIfDarkTheme(el = document.body) {\n const backgroundInvertIfDark = window.getComputedStyle(el).getPropertyValue(\"--background-invert-if-dark\");\n if (backgroundInvertIfDark !== void 0) {\n return backgroundInvertIfDark === \"invert(100%)\";\n }\n return false;\n}\nconst isDarkTheme = checkIfDarkTheme();\nexport {\n checkIfDarkTheme,\n isDarkTheme\n};\n//# sourceMappingURL=index.mjs.map\n","/*!\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nconst INJECTION_KEY_THEME = Symbol.for(\"nc:theme:enforced\");\nexport {\n INJECTION_KEY_THEME as I\n};\n//# sourceMappingURL=constants-Bls5liKo.mjs.map\n","import { createSharedComposable, usePreferredDark, useMutationObserver } from \"@vueuse/core\";\nimport { computed, toValue, ref, watch, readonly, inject } from \"vue\";\nimport { checkIfDarkTheme } from \"../../functions/isDarkTheme/index.mjs\";\nimport { I as INJECTION_KEY_THEME } from \"../../chunks/constants-Bls5liKo.mjs\";\n/*!\n * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction useIsDarkThemeElement(el) {\n const element = computed(() => toValue(el) ?? document.body);\n const isDarkTheme = ref(checkIfDarkTheme(element.value));\n const isDarkSystemTheme = usePreferredDark();\n function updateIsDarkTheme() {\n isDarkTheme.value = checkIfDarkTheme(element.value);\n }\n useMutationObserver(element, updateIsDarkTheme, { attributes: true });\n watch(element, updateIsDarkTheme);\n watch(isDarkSystemTheme, updateIsDarkTheme, { immediate: true });\n return readonly(isDarkTheme);\n}\nconst useInternalIsDarkTheme = createSharedComposable(() => useIsDarkThemeElement());\nfunction useIsDarkTheme() {\n const isDarkTheme = useInternalIsDarkTheme();\n const enforcedTheme = inject(INJECTION_KEY_THEME, void 0);\n return computed(() => {\n if (enforcedTheme?.value) {\n return enforcedTheme.value === \"dark\";\n }\n return isDarkTheme.value;\n });\n}\nexport {\n useIsDarkTheme,\n useIsDarkThemeElement\n};\n//# sourceMappingURL=index.mjs.map\n","import { ref, readonly } from \"vue\";\nconst isFullscreen = ref(checkIfIsFullscreen());\nwindow.addEventListener(\"resize\", () => {\n isFullscreen.value = checkIfIsFullscreen();\n});\nfunction checkIfIsFullscreen() {\n return window.outerHeight === window.screen.height;\n}\nfunction useIsFullscreen() {\n return readonly(isFullscreen);\n}\nexport {\n useIsFullscreen\n};\n//# sourceMappingURL=index.mjs.map\n","import { ref, readonly } from \"vue\";\nconst MOBILE_BREAKPOINT = 1024;\nconst MOBILE_SMALL_BREAKPOINT = MOBILE_BREAKPOINT / 2;\nconst isLessThanBreakpoint = (breakpoint) => document.documentElement.clientWidth < breakpoint;\nconst isMobile = ref(isLessThanBreakpoint(MOBILE_BREAKPOINT));\nconst isSmallMobile = ref(isLessThanBreakpoint(MOBILE_SMALL_BREAKPOINT));\nwindow.addEventListener(\"resize\", () => {\n isMobile.value = isLessThanBreakpoint(MOBILE_BREAKPOINT);\n isSmallMobile.value = isLessThanBreakpoint(MOBILE_SMALL_BREAKPOINT);\n}, { passive: true });\nfunction useIsMobile() {\n return readonly(isMobile);\n}\nfunction useIsSmallMobile() {\n return readonly(isSmallMobile);\n}\nexport {\n MOBILE_BREAKPOINT,\n MOBILE_SMALL_BREAKPOINT,\n useIsMobile,\n useIsSmallMobile\n};\n//# sourceMappingURL=index.mjs.map\n","import '../assets/NcHeaderMenu-Hy0UKyUu.css';\nimport { defineComponent, ref, computed, useTemplateRef, watch, nextTick, createBlock, openBlock, resolveDynamicComponent, normalizeClass, unref, withCtx, createVNode, createElementBlock, createCommentVNode, withDirectives, withModifiers, renderSlot, toDisplayString, createElementVNode, vShow } from \"vue\";\nimport { onClickOutside } from \"@vueuse/core\";\nimport { createFocusTrap } from \"focus-trap\";\nimport \"../composables/useFormatDateTime/index.mjs\";\nimport { useHotKey } from \"../composables/useHotKey/index.mjs\";\nimport \"../composables/useIsDarkTheme/index.mjs\";\nimport \"../composables/useIsFullscreen/index.mjs\";\nimport \"../composables/useIsMobile/index.mjs\";\nimport { u as useTrapStackControl } from \"./useTrapStackControl-B6cEicto.mjs\";\nimport { c as createElementId } from \"./createElementId-DhjFt1I9.mjs\";\nimport { g as getTrapStack } from \"./focusTrap-HJQ4pqHV.mjs\";\nimport { N as NcButton } from \"./NcButton-DkC5k3Lb.mjs\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst _hoisted_1 = [\"id\"];\nconst _hoisted_2 = { class: \"header-menu__caret\" };\nconst _hoisted_3 = [\"id\"];\nconst _hoisted_4 = {\n ref: \"contentContainer\",\n class: \"header-menu__content\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcHeaderMenu\",\n props: {\n id: {},\n ariaLabel: { default: () => void 0 },\n open: { type: Boolean, default: false },\n isNav: { type: Boolean, default: false },\n description: { default: () => void 0 },\n excludeClickOutsideSelectors: { default: () => [] }\n },\n emits: [\"closed\", \"opened\", \"update:open\"],\n setup(__props, { emit: __emit }) {\n const emit = __emit;\n const descriptionId = createElementId();\n const triggerId = createElementId();\n const focusTrap = ref();\n const isOpened = ref(__props.open);\n const wrapperTag = computed(() => __props.isNav ? \"nav\" : \"div\");\n const contentContainerElement = useTemplateRef(\"contentContainer\");\n const headerMenuElement = useTemplateRef(\"headerMenu\");\n const triggerButtonInstance = useTemplateRef(\"triggerButton\");\n const ignore = computed(() => Array.isArray(__props.excludeClickOutsideSelectors) ? __props.excludeClickOutsideSelectors : __props.excludeClickOutsideSelectors.split(\" \"));\n onClickOutside(headerMenuElement, () => setMenuState(false), { ignore });\n useHotKey(\"Escape\", () => setMenuState(false), { prevent: true });\n useTrapStackControl(isOpened, {\n disabled: () => !__props.isNav\n });\n watch(() => __props.open, (state) => setMenuState(state));\n function toggleMenu() {\n setMenuState(!isOpened.value);\n }\n async function setMenuState(state) {\n if (state === isOpened.value) {\n return;\n }\n isOpened.value = state;\n emit(\"update:open\", state);\n await nextTick();\n await (state ? addFocusTrap() : clearFocusTrap());\n emit(state ? \"opened\" : \"closed\");\n }\n function onFocusOut(event) {\n if (!__props.isNav) {\n return;\n }\n if (!(event.relatedTarget instanceof Node)) {\n return;\n }\n if (headerMenuElement.value?.contains(event.relatedTarget)) {\n setMenuState(false);\n }\n }\n async function addFocusTrap() {\n if (__props.isNav || focusTrap.value) {\n return;\n }\n focusTrap.value = createFocusTrap(contentContainerElement.value, {\n allowOutsideClick: true,\n trapStack: getTrapStack(),\n fallbackFocus: triggerButtonInstance.value?.$el\n });\n focusTrap.value.activate();\n }\n function clearFocusTrap() {\n focusTrap.value?.deactivate();\n focusTrap.value = void 0;\n }\n return (_ctx, _cache) => {\n return openBlock(), createBlock(resolveDynamicComponent(wrapperTag.value), {\n id: _ctx.id,\n ref: \"headerMenu\",\n \"aria-labelledby\": _ctx.isNav ? unref(triggerId) : null,\n class: normalizeClass([{ \"header-menu--opened\": isOpened.value }, \"header-menu\"]),\n onFocusout: onFocusOut\n }, {\n default: withCtx(() => [\n createVNode(unref(NcButton), {\n id: _ctx.isNav ? unref(triggerId) : null,\n ref: \"triggerButton\",\n \"aria-controls\": `header-menu-${_ctx.id}`,\n \"aria-expanded\": isOpened.value.toString(),\n \"aria-label\": _ctx.ariaLabel,\n class: \"header-menu__trigger\",\n size: \"large\",\n variant: \"tertiary-no-background\",\n onClick: withModifiers(toggleMenu, [\"prevent\"])\n }, {\n icon: withCtx(() => [\n renderSlot(_ctx.$slots, \"trigger\", {}, void 0, true)\n ]),\n _: 3\n }, 8, [\"id\", \"aria-controls\", \"aria-expanded\", \"aria-label\"]),\n _ctx.description ? (openBlock(), createElementBlock(\"span\", {\n key: 0,\n id: unref(descriptionId),\n class: \"header-menu__description hidden-visually\"\n }, toDisplayString(_ctx.description), 9, _hoisted_1)) : createCommentVNode(\"\", true),\n withDirectives(createElementVNode(\"div\", _hoisted_2, null, 512), [\n [vShow, isOpened.value]\n ]),\n withDirectives(createElementVNode(\"div\", {\n id: `header-menu-${_ctx.id}`,\n class: \"header-menu__wrapper\"\n }, [\n createElementVNode(\"div\", _hoisted_4, [\n renderSlot(_ctx.$slots, \"default\", {}, void 0, true)\n ], 512)\n ], 8, _hoisted_3), [\n [vShow, isOpened.value]\n ])\n ]),\n _: 3\n }, 40, [\"id\", \"aria-labelledby\", \"class\"]);\n };\n }\n});\nconst NcHeaderMenu = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-d45c5788\"]]);\nexport {\n NcHeaderMenu as N\n};\n//# sourceMappingURL=NcHeaderMenu-DfO7ghiM.mjs.map\n","\n\n","\n\n","\n\n","function loadState(app, key, fallback) {\n const elem = document.querySelector(`#initial-state-${app}-${key}`);\n if (elem === null) {\n if (fallback !== void 0) {\n return fallback;\n }\n throw new Error(`Could not find initial state ${key} of ${app}`);\n }\n try {\n return JSON.parse(atob(elem.value));\n } catch (e) {\n throw new Error(`Could not parse initial state ${key} of ${app}`);\n }\n}\nexport {\n loadState\n};\n","import { loadState as i } from \"@nextcloud/initial-state\";\nfunction e() {\n try {\n return i(\"core\", \"capabilities\");\n } catch {\n return console.debug(\"Could not find capabilities initial state fall back to _oc_capabilities\"), \"_oc_capabilities\" in window ? window._oc_capabilities : {};\n }\n}\nexport {\n e as getCapabilities\n};\n","\n\n","\n\n\n\n\n","import { defineComponent, computed, toRef, createElementBlock, openBlock, toDisplayString, unref } from \"vue\";\nimport { useFormatTime, useFormatRelativeTime } from \"../composables/useFormatDateTime/index.mjs\";\nconst _hoisted_1 = [\"data-timestamp\", \"title\", \"textContent\"];\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcDateTime\",\n props: {\n timestamp: {},\n format: { default: () => ({ timeStyle: \"medium\", dateStyle: \"short\" }) },\n relativeTime: { type: [Boolean, String], default: \"long\" },\n ignoreSeconds: { type: Boolean }\n },\n setup(__props) {\n const props = __props;\n const timeOptions = computed(() => ({ format: props.format }));\n const relativeTimeOptions = computed(() => ({\n ignoreSeconds: props.ignoreSeconds,\n relativeTime: props.relativeTime || \"long\",\n update: props.relativeTime !== false\n }));\n const title = useFormatTime(toRef(() => props.timestamp), timeOptions);\n const relativeTime = useFormatRelativeTime(toRef(() => props.timestamp), relativeTimeOptions);\n const formattedTime = computed(() => props.relativeTime ? relativeTime.value : title.value);\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"span\", {\n class: \"nc-datetime\",\n dir: \"auto\",\n \"data-timestamp\": _ctx.timestamp,\n title: unref(title),\n textContent: toDisplayString(formattedTime.value)\n }, null, 8, _hoisted_1);\n };\n }\n});\nexport {\n _sfc_main as _\n};\n//# sourceMappingURL=NcDateTime.vue_vue_type_script_setup_true_lang-BhB8yA4U.mjs.map\n","export const VOID = -1;\nexport const PRIMITIVE = 0;\nexport const ARRAY = 1;\nexport const OBJECT = 2;\nexport const DATE = 3;\nexport const REGEXP = 4;\nexport const MAP = 5;\nexport const SET = 6;\nexport const ERROR = 7;\nexport const BIGINT = 8;\n// export const SYMBOL = 9;\n","import {\n VOID, PRIMITIVE,\n ARRAY, OBJECT,\n DATE, REGEXP, MAP, SET,\n ERROR, BIGINT\n} from './types.js';\n\nconst env = typeof self === 'object' ? self : globalThis;\n\nconst deserializer = ($, _) => {\n const as = (out, index) => {\n $.set(index, out);\n return out;\n };\n\n const unpair = index => {\n if ($.has(index))\n return $.get(index);\n\n const [type, value] = _[index];\n switch (type) {\n case PRIMITIVE:\n case VOID:\n return as(value, index);\n case ARRAY: {\n const arr = as([], index);\n for (const index of value)\n arr.push(unpair(index));\n return arr;\n }\n case OBJECT: {\n const object = as({}, index);\n for (const [key, index] of value)\n object[unpair(key)] = unpair(index);\n return object;\n }\n case DATE:\n return as(new Date(value), index);\n case REGEXP: {\n const {source, flags} = value;\n return as(new RegExp(source, flags), index);\n }\n case MAP: {\n const map = as(new Map, index);\n for (const [key, index] of value)\n map.set(unpair(key), unpair(index));\n return map;\n }\n case SET: {\n const set = as(new Set, index);\n for (const index of value)\n set.add(unpair(index));\n return set;\n }\n case ERROR: {\n const {name, message} = value;\n return as(new env[name](message), index);\n }\n case BIGINT:\n return as(BigInt(value), index);\n case 'BigInt':\n return as(Object(BigInt(value)), index);\n case 'ArrayBuffer':\n return as(new Uint8Array(value).buffer, value);\n case 'DataView': {\n const { buffer } = new Uint8Array(value);\n return as(new DataView(buffer), value);\n }\n }\n return as(new env[type](value), index);\n };\n\n return unpair;\n};\n\n/**\n * @typedef {Array} Record a type representation\n */\n\n/**\n * Returns a deserialized value from a serialized array of Records.\n * @param {Record[]} serialized a previously serialized value.\n * @returns {any}\n */\nexport const deserialize = serialized => deserializer(new Map, serialized)(0);\n","import {\n VOID, PRIMITIVE,\n ARRAY, OBJECT,\n DATE, REGEXP, MAP, SET,\n ERROR, BIGINT\n} from './types.js';\n\nconst EMPTY = '';\n\nconst {toString} = {};\nconst {keys} = Object;\n\nconst typeOf = value => {\n const type = typeof value;\n if (type !== 'object' || !value)\n return [PRIMITIVE, type];\n\n const asString = toString.call(value).slice(8, -1);\n switch (asString) {\n case 'Array':\n return [ARRAY, EMPTY];\n case 'Object':\n return [OBJECT, EMPTY];\n case 'Date':\n return [DATE, EMPTY];\n case 'RegExp':\n return [REGEXP, EMPTY];\n case 'Map':\n return [MAP, EMPTY];\n case 'Set':\n return [SET, EMPTY];\n case 'DataView':\n return [ARRAY, asString];\n }\n\n if (asString.includes('Array'))\n return [ARRAY, asString];\n\n if (asString.includes('Error'))\n return [ERROR, asString];\n\n return [OBJECT, asString];\n};\n\nconst shouldSkip = ([TYPE, type]) => (\n TYPE === PRIMITIVE &&\n (type === 'function' || type === 'symbol')\n);\n\nconst serializer = (strict, json, $, _) => {\n\n const as = (out, value) => {\n const index = _.push(out) - 1;\n $.set(value, index);\n return index;\n };\n\n const pair = value => {\n if ($.has(value))\n return $.get(value);\n\n let [TYPE, type] = typeOf(value);\n switch (TYPE) {\n case PRIMITIVE: {\n let entry = value;\n switch (type) {\n case 'bigint':\n TYPE = BIGINT;\n entry = value.toString();\n break;\n case 'function':\n case 'symbol':\n if (strict)\n throw new TypeError('unable to serialize ' + type);\n entry = null;\n break;\n case 'undefined':\n return as([VOID], value);\n }\n return as([TYPE, entry], value);\n }\n case ARRAY: {\n if (type) {\n let spread = value;\n if (type === 'DataView') {\n spread = new Uint8Array(value.buffer);\n }\n else if (type === 'ArrayBuffer') {\n spread = new Uint8Array(value);\n }\n return as([type, [...spread]], value);\n }\n\n const arr = [];\n const index = as([TYPE, arr], value);\n for (const entry of value)\n arr.push(pair(entry));\n return index;\n }\n case OBJECT: {\n if (type) {\n switch (type) {\n case 'BigInt':\n return as([type, value.toString()], value);\n case 'Boolean':\n case 'Number':\n case 'String':\n return as([type, value.valueOf()], value);\n }\n }\n\n if (json && ('toJSON' in value))\n return pair(value.toJSON());\n\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const key of keys(value)) {\n if (strict || !shouldSkip(typeOf(value[key])))\n entries.push([pair(key), pair(value[key])]);\n }\n return index;\n }\n case DATE:\n return as([TYPE, value.toISOString()], value);\n case REGEXP: {\n const {source, flags} = value;\n return as([TYPE, {source, flags}], value);\n }\n case MAP: {\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const [key, entry] of value) {\n if (strict || !(shouldSkip(typeOf(key)) || shouldSkip(typeOf(entry))))\n entries.push([pair(key), pair(entry)]);\n }\n return index;\n }\n case SET: {\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const entry of value) {\n if (strict || !shouldSkip(typeOf(entry)))\n entries.push(pair(entry));\n }\n return index;\n }\n }\n\n const {message} = value;\n return as([TYPE, {name: type, message}], value);\n };\n\n return pair;\n};\n\n/**\n * @typedef {Array} Record a type representation\n */\n\n/**\n * Returns an array of serialized Records.\n * @param {any} value a serializable value.\n * @param {{json?: boolean, lossy?: boolean}?} options an object with a `lossy` or `json` property that,\n * if `true`, will not throw errors on incompatible types, and behave more\n * like JSON stringify would behave. Symbol and Function will be discarded.\n * @returns {Record[]}\n */\n export const serialize = (value, {json, lossy} = {}) => {\n const _ = [];\n return serializer(!(json || lossy), !!json, new Map, _)(value), _;\n};\n","import {deserialize} from './deserialize.js';\nimport {serialize} from './serialize.js';\n\n/**\n * @typedef {Array} Record a type representation\n */\n\n/**\n * Returns an array of serialized Records.\n * @param {any} any a serializable value.\n * @param {{transfer?: any[], json?: boolean, lossy?: boolean}?} options an object with\n * a transfer option (ignored when polyfilled) and/or non standard fields that\n * fallback to the polyfill if present.\n * @returns {Record[]}\n */\nexport default typeof structuredClone === \"function\" ?\n /* c8 ignore start */\n (any, options) => (\n options && ('json' in options || 'lossy' in options) ?\n deserialize(serialize(any, options)) : structuredClone(any)\n ) :\n (any, options) => deserialize(serialize(any, options));\n /* c8 ignore stop */\n\nexport {deserialize, serialize};\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Parents} Parents\n */\n\n/**\n * @template Fn\n * @template Fallback\n * @typedef {Fn extends (value: any) => value is infer Thing ? Thing : Fallback} Predicate\n */\n\n/**\n * @callback Check\n * Check that an arbitrary value is an element.\n * @param {unknown} this\n * Context object (`this`) to call `test` with\n * @param {unknown} [element]\n * Anything (typically a node).\n * @param {number | null | undefined} [index]\n * Position of `element` in its parent.\n * @param {Parents | null | undefined} [parent]\n * Parent of `element`.\n * @returns {boolean}\n * Whether this is an element and passes a test.\n *\n * @typedef {Array | TestFunction | string | null | undefined} Test\n * Check for an arbitrary element.\n *\n * * when `string`, checks that the element has that tag name\n * * when `function`, see `TestFunction`\n * * when `Array`, checks if one of the subtests pass\n *\n * @callback TestFunction\n * Check if an element passes a test.\n * @param {unknown} this\n * The given context.\n * @param {Element} element\n * An element.\n * @param {number | undefined} [index]\n * Position of `element` in its parent.\n * @param {Parents | undefined} [parent]\n * Parent of `element`.\n * @returns {boolean | undefined | void}\n * Whether this element passes the test.\n *\n * Note: `void` is included until TS sees no return as `undefined`.\n */\n\n/**\n * Check if `element` is an `Element` and whether it passes the given test.\n *\n * @param element\n * Thing to check, typically `element`.\n * @param test\n * Check for a specific element.\n * @param index\n * Position of `element` in its parent.\n * @param parent\n * Parent of `element`.\n * @param context\n * Context object (`this`) to call `test` with.\n * @returns\n * Whether `element` is an `Element` and passes a test.\n * @throws\n * When an incorrect `test`, `index`, or `parent` is given; there is no error\n * thrown when `element` is not a node or not an element.\n */\nexport const isElement =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((element: unknown, test: Condition, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => element is Element & Predicate) &\n * ((element: unknown, test: Condition, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => element is Element & {tagName: Condition}) &\n * ((element?: null | undefined) => false) &\n * ((element: unknown, test?: null | undefined, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => element is Element) &\n * ((element: unknown, test?: Test, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => boolean)\n * )}\n */\n (\n /**\n * @param {unknown} [element]\n * @param {Test | undefined} [test]\n * @param {number | null | undefined} [index]\n * @param {Parents | null | undefined} [parent]\n * @param {unknown} [context]\n * @returns {boolean}\n */\n // eslint-disable-next-line max-params\n function (element, test, index, parent, context) {\n const check = convertElement(test)\n\n if (\n index !== null &&\n index !== undefined &&\n (typeof index !== 'number' ||\n index < 0 ||\n index === Number.POSITIVE_INFINITY)\n ) {\n throw new Error('Expected positive finite `index`')\n }\n\n if (\n parent !== null &&\n parent !== undefined &&\n (!parent.type || !parent.children)\n ) {\n throw new Error('Expected valid `parent`')\n }\n\n if (\n (index === null || index === undefined) !==\n (parent === null || parent === undefined)\n ) {\n throw new Error('Expected both `index` and `parent`')\n }\n\n return looksLikeAnElement(element)\n ? check.call(context, element, index, parent)\n : false\n }\n )\n\n/**\n * Generate a check from a test.\n *\n * Useful if you’re going to test many nodes, for example when creating a\n * utility where something else passes a compatible test.\n *\n * The created function is a bit faster because it expects valid input only:\n * an `element`, `index`, and `parent`.\n *\n * @param test\n * A test for a specific element.\n * @returns\n * A check.\n */\nexport const convertElement =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((test: Condition) => (element: unknown, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => element is Element & Predicate) &\n * ((test: Condition) => (element: unknown, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => element is Element & {tagName: Condition}) &\n * ((test?: null | undefined) => (element?: unknown, index?: number | null | undefined, parent?: Parents | null | undefined, context?: unknown) => element is Element) &\n * ((test?: Test) => Check)\n * )}\n */\n (\n /**\n * @param {Test | null | undefined} [test]\n * @returns {Check}\n */\n function (test) {\n if (test === null || test === undefined) {\n return element\n }\n\n if (typeof test === 'string') {\n return tagNameFactory(test)\n }\n\n // Assume array.\n if (typeof test === 'object') {\n return anyFactory(test)\n }\n\n if (typeof test === 'function') {\n return castFactory(test)\n }\n\n throw new Error('Expected function, string, or array as `test`')\n }\n )\n\n/**\n * Handle multiple tests.\n *\n * @param {Array} tests\n * @returns {Check}\n */\nfunction anyFactory(tests) {\n /** @type {Array} */\n const checks = []\n let index = -1\n\n while (++index < tests.length) {\n checks[index] = convertElement(tests[index])\n }\n\n return castFactory(any)\n\n /**\n * @this {unknown}\n * @type {TestFunction}\n */\n function any(...parameters) {\n let index = -1\n\n while (++index < checks.length) {\n if (checks[index].apply(this, parameters)) return true\n }\n\n return false\n }\n}\n\n/**\n * Turn a string into a test for an element with a certain type.\n *\n * @param {string} check\n * @returns {Check}\n */\nfunction tagNameFactory(check) {\n return castFactory(tagName)\n\n /**\n * @param {Element} element\n * @returns {boolean}\n */\n function tagName(element) {\n return element.tagName === check\n }\n}\n\n/**\n * Turn a custom test into a test for an element that passes that test.\n *\n * @param {TestFunction} testFunction\n * @returns {Check}\n */\nfunction castFactory(testFunction) {\n return check\n\n /**\n * @this {unknown}\n * @type {Check}\n */\n function check(value, index, parent) {\n return Boolean(\n looksLikeAnElement(value) &&\n testFunction.call(\n this,\n value,\n typeof index === 'number' ? index : undefined,\n parent || undefined\n )\n )\n }\n}\n\n/**\n * Make sure something is an element.\n *\n * @param {unknown} element\n * @returns {element is Element}\n */\nfunction element(element) {\n return Boolean(\n element &&\n typeof element === 'object' &&\n 'type' in element &&\n element.type === 'element' &&\n 'tagName' in element &&\n typeof element.tagName === 'string'\n )\n}\n\n/**\n * @param {unknown} value\n * @returns {value is Element}\n */\nfunction looksLikeAnElement(value) {\n return (\n value !== null &&\n typeof value === 'object' &&\n 'type' in value &&\n 'tagName' in value\n )\n}\n","// Scheme: https://tools.ietf.org/html/rfc3986#section-3.1\n// Absolute URL: https://tools.ietf.org/html/rfc3986#section-4.3\nconst ABSOLUTE_URL_REGEX = /^[a-zA-Z][a-zA-Z\\d+\\-.]*?:/;\n\n// Windows paths like `c:\\`\nconst WINDOWS_PATH_REGEX = /^[a-zA-Z]:\\\\/;\n\nexport default function isAbsoluteUrl(url) {\n\tif (typeof url !== 'string') {\n\t\tthrow new TypeError(`Expected a \\`string\\`, got \\`${typeof url}\\``);\n\t}\n\n\tif (WINDOWS_PATH_REGEX.test(url)) {\n\t\treturn false;\n\t}\n\n\treturn ABSOLUTE_URL_REGEX.test(url);\n}\n","/**\n * Parse space-separated tokens to an array of strings.\n *\n * @param {string} value\n * Space-separated tokens.\n * @returns {Array}\n * List of tokens.\n */\nexport function parse(value) {\n const input = String(value || '').trim()\n return input ? input.split(/[ \\t\\n\\r\\f]+/g) : []\n}\n\n/**\n * Serialize an array of strings as space separated-tokens.\n *\n * @param {Array} values\n * List of tokens.\n * @returns {string}\n * Space-separated tokens.\n */\nexport function stringify(values) {\n return values.join(' ').trim()\n}\n","/**\n * @typedef {import('unist').Node} Node\n * @typedef {import('unist').Parent} Parent\n */\n\n/**\n * @template Fn\n * @template Fallback\n * @typedef {Fn extends (value: any) => value is infer Thing ? Thing : Fallback} Predicate\n */\n\n/**\n * @callback Check\n * Check that an arbitrary value is a node.\n * @param {unknown} this\n * The given context.\n * @param {unknown} [node]\n * Anything (typically a node).\n * @param {number | null | undefined} [index]\n * The node’s position in its parent.\n * @param {Parent | null | undefined} [parent]\n * The node’s parent.\n * @returns {boolean}\n * Whether this is a node and passes a test.\n *\n * @typedef {Record | Node} Props\n * Object to check for equivalence.\n *\n * Note: `Node` is included as it is common but is not indexable.\n *\n * @typedef {Array | Props | TestFunction | string | null | undefined} Test\n * Check for an arbitrary node.\n *\n * @callback TestFunction\n * Check if a node passes a test.\n * @param {unknown} this\n * The given context.\n * @param {Node} node\n * A node.\n * @param {number | undefined} [index]\n * The node’s position in its parent.\n * @param {Parent | undefined} [parent]\n * The node’s parent.\n * @returns {boolean | undefined | void}\n * Whether this node passes the test.\n *\n * Note: `void` is included until TS sees no return as `undefined`.\n */\n\n/**\n * Check if `node` is a `Node` and whether it passes the given test.\n *\n * @param {unknown} node\n * Thing to check, typically `Node`.\n * @param {Test} test\n * A check for a specific node.\n * @param {number | null | undefined} index\n * The node’s position in its parent.\n * @param {Parent | null | undefined} parent\n * The node’s parent.\n * @param {unknown} context\n * Context object (`this`) to pass to `test` functions.\n * @returns {boolean}\n * Whether `node` is a node and passes a test.\n */\nexport const is =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * ((node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * ((node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate) &\n * ((node?: null | undefined) => false) &\n * ((node: unknown, test?: null | undefined, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((node: unknown, test?: Test, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => boolean)\n * )}\n */\n (\n /**\n * @param {unknown} [node]\n * @param {Test} [test]\n * @param {number | null | undefined} [index]\n * @param {Parent | null | undefined} [parent]\n * @param {unknown} [context]\n * @returns {boolean}\n */\n // eslint-disable-next-line max-params\n function (node, test, index, parent, context) {\n const check = convert(test)\n\n if (\n index !== undefined &&\n index !== null &&\n (typeof index !== 'number' ||\n index < 0 ||\n index === Number.POSITIVE_INFINITY)\n ) {\n throw new Error('Expected positive finite index')\n }\n\n if (\n parent !== undefined &&\n parent !== null &&\n (!is(parent) || !parent.children)\n ) {\n throw new Error('Expected parent node')\n }\n\n if (\n (parent === undefined || parent === null) !==\n (index === undefined || index === null)\n ) {\n throw new Error('Expected both parent and index')\n }\n\n return looksLikeANode(node)\n ? check.call(context, node, index, parent)\n : false\n }\n )\n\n/**\n * Generate an assertion from a test.\n *\n * Useful if you’re going to test many nodes, for example when creating a\n * utility where something else passes a compatible test.\n *\n * The created function is a bit faster because it expects valid input only:\n * a `node`, `index`, and `parent`.\n *\n * @param {Test} test\n * * when nullish, checks if `node` is a `Node`.\n * * when `string`, works like passing `(node) => node.type === test`.\n * * when `function` checks if function passed the node is true.\n * * when `object`, checks that all keys in test are in node, and that they have (strictly) equal values.\n * * when `array`, checks if any one of the subtests pass.\n * @returns {Check}\n * An assertion.\n */\nexport const convert =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate) &\n * ((test?: null | undefined) => (node?: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((test?: Test) => Check)\n * )}\n */\n (\n /**\n * @param {Test} [test]\n * @returns {Check}\n */\n function (test) {\n if (test === null || test === undefined) {\n return ok\n }\n\n if (typeof test === 'function') {\n return castFactory(test)\n }\n\n if (typeof test === 'object') {\n return Array.isArray(test) ? anyFactory(test) : propsFactory(test)\n }\n\n if (typeof test === 'string') {\n return typeFactory(test)\n }\n\n throw new Error('Expected function, string, or object as test')\n }\n )\n\n/**\n * @param {Array} tests\n * @returns {Check}\n */\nfunction anyFactory(tests) {\n /** @type {Array} */\n const checks = []\n let index = -1\n\n while (++index < tests.length) {\n checks[index] = convert(tests[index])\n }\n\n return castFactory(any)\n\n /**\n * @this {unknown}\n * @type {TestFunction}\n */\n function any(...parameters) {\n let index = -1\n\n while (++index < checks.length) {\n if (checks[index].apply(this, parameters)) return true\n }\n\n return false\n }\n}\n\n/**\n * Turn an object into a test for a node with a certain fields.\n *\n * @param {Props} check\n * @returns {Check}\n */\nfunction propsFactory(check) {\n const checkAsRecord = /** @type {Record} */ (check)\n\n return castFactory(all)\n\n /**\n * @param {Node} node\n * @returns {boolean}\n */\n function all(node) {\n const nodeAsRecord = /** @type {Record} */ (\n /** @type {unknown} */ (node)\n )\n\n /** @type {string} */\n let key\n\n for (key in check) {\n if (nodeAsRecord[key] !== checkAsRecord[key]) return false\n }\n\n return true\n }\n}\n\n/**\n * Turn a string into a test for a node with a certain type.\n *\n * @param {string} check\n * @returns {Check}\n */\nfunction typeFactory(check) {\n return castFactory(type)\n\n /**\n * @param {Node} node\n */\n function type(node) {\n return node && node.type === check\n }\n}\n\n/**\n * Turn a custom test into a test for a node that passes that test.\n *\n * @param {TestFunction} testFunction\n * @returns {Check}\n */\nfunction castFactory(testFunction) {\n return check\n\n /**\n * @this {unknown}\n * @type {Check}\n */\n function check(value, index, parent) {\n return Boolean(\n looksLikeANode(value) &&\n testFunction.call(\n this,\n value,\n typeof index === 'number' ? index : undefined,\n parent || undefined\n )\n )\n }\n}\n\nfunction ok() {\n return true\n}\n\n/**\n * @param {unknown} value\n * @returns {value is Node}\n */\nfunction looksLikeANode(value) {\n return value !== null && typeof value === 'object' && 'type' in value\n}\n","/**\n * @param {string} d\n * @returns {string}\n */\nexport function color(d) {\n return d\n}\n","/**\n * @typedef {import('unist').Node} UnistNode\n * @typedef {import('unist').Parent} UnistParent\n */\n\n/**\n * @typedef {Exclude | undefined} Test\n * Test from `unist-util-is`.\n *\n * Note: we have remove and add `undefined`, because otherwise when generating\n * automatic `.d.ts` files, TS tries to flatten paths from a local perspective,\n * which doesn’t work when publishing on npm.\n */\n\n/**\n * @typedef {(\n * Fn extends (value: any) => value is infer Thing\n * ? Thing\n * : Fallback\n * )} Predicate\n * Get the value of a type guard `Fn`.\n * @template Fn\n * Value; typically function that is a type guard (such as `(x): x is Y`).\n * @template Fallback\n * Value to yield if `Fn` is not a type guard.\n */\n\n/**\n * @typedef {(\n * Check extends null | undefined // No test.\n * ? Value\n * : Value extends {type: Check} // String (type) test.\n * ? Value\n * : Value extends Check // Partial test.\n * ? Value\n * : Check extends Function // Function test.\n * ? Predicate extends Value\n * ? Predicate\n * : never\n * : never // Some other test?\n * )} MatchesOne\n * Check whether a node matches a primitive check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test, but not arrays.\n */\n\n/**\n * @typedef {(\n * Check extends Array\n * ? MatchesOne\n * : MatchesOne\n * )} Matches\n * Check whether a node matches a check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test.\n */\n\n/**\n * @typedef {0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10} Uint\n * Number; capped reasonably.\n */\n\n/**\n * @typedef {I extends 0 ? 1 : I extends 1 ? 2 : I extends 2 ? 3 : I extends 3 ? 4 : I extends 4 ? 5 : I extends 5 ? 6 : I extends 6 ? 7 : I extends 7 ? 8 : I extends 8 ? 9 : 10} Increment\n * Increment a number in the type system.\n * @template {Uint} [I=0]\n * Index.\n */\n\n/**\n * @typedef {(\n * Node extends UnistParent\n * ? Node extends {children: Array}\n * ? Child extends Children ? Node : never\n * : never\n * : never\n * )} InternalParent\n * Collect nodes that can be parents of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {InternalParent, Child>} Parent\n * Collect nodes in `Tree` that can be parents of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Depth extends Max\n * ? never\n * :\n * | InternalParent\n * | InternalAncestor, Max, Increment>\n * )} InternalAncestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {InternalAncestor, Child>} Ancestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Tree extends UnistParent\n * ? Depth extends Max\n * ? Tree\n * : Tree | InclusiveDescendant>\n * : Tree\n * )} InclusiveDescendant\n * Collect all (inclusive) descendants of `Tree`.\n *\n * > 👉 **Note**: for performance reasons, this seems to be the fastest way to\n * > recurse without actually running into an infinite loop, which the\n * > previous version did.\n * >\n * > Practically, a max of `2` is typically enough assuming a `Root` is\n * > passed, but it doesn’t improve performance.\n * > It gets higher with `List > ListItem > Table > TableRow > TableCell`.\n * > Using up to `10` doesn’t hurt or help either.\n * @template {UnistNode} Tree\n * Tree type.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {'skip' | boolean} Action\n * Union of the action types.\n *\n * @typedef {number} Index\n * Move to the sibling at `index` next (after node itself is completely\n * traversed).\n *\n * Useful if mutating the tree, such as removing the node the visitor is\n * currently on, or any of its previous siblings.\n * Results less than 0 or greater than or equal to `children.length` stop\n * traversing the parent.\n *\n * @typedef {[(Action | null | undefined | void)?, (Index | null | undefined)?]} ActionTuple\n * List with one or two values, the first an action, the second an index.\n *\n * @typedef {Action | ActionTuple | Index | null | undefined | void} VisitorResult\n * Any value that can be returned from a visitor.\n */\n\n/**\n * @callback Visitor\n * Handle a node (matching `test`, if given).\n *\n * Visitors are free to transform `node`.\n * They can also transform the parent of node (the last of `ancestors`).\n *\n * Replacing `node` itself, if `SKIP` is not returned, still causes its\n * descendants to be walked (which is a bug).\n *\n * When adding or removing previous siblings of `node` (or next siblings, in\n * case of reverse), the `Visitor` should return a new `Index` to specify the\n * sibling to traverse after `node` is traversed.\n * Adding or removing next siblings of `node` (or previous siblings, in case\n * of reverse) is handled as expected without needing to return a new `Index`.\n *\n * Removing the children property of an ancestor still results in them being\n * traversed.\n * @param {Visited} node\n * Found node.\n * @param {Array} ancestors\n * Ancestors of `node`.\n * @returns {VisitorResult}\n * What to do next.\n *\n * An `Index` is treated as a tuple of `[CONTINUE, Index]`.\n * An `Action` is treated as a tuple of `[Action]`.\n *\n * Passing a tuple back only makes sense if the `Action` is `SKIP`.\n * When the `Action` is `EXIT`, that action can be returned.\n * When the `Action` is `CONTINUE`, `Index` can be returned.\n * @template {UnistNode} [Visited=UnistNode]\n * Visited node type.\n * @template {UnistParent} [VisitedParents=UnistParent]\n * Ancestor type.\n */\n\n/**\n * @typedef {Visitor, Check>, Ancestor, Check>>>} BuildVisitor\n * Build a typed `Visitor` function from a tree and a test.\n *\n * It will infer which values are passed as `node` and which as `parents`.\n * @template {UnistNode} [Tree=UnistNode]\n * Tree type.\n * @template {Test} [Check=Test]\n * Test type.\n */\n\nimport {convert} from 'unist-util-is'\nimport {color} from 'unist-util-visit-parents/do-not-use-color'\n\n/** @type {Readonly} */\nconst empty = []\n\n/**\n * Continue traversing as normal.\n */\nexport const CONTINUE = true\n\n/**\n * Stop traversing immediately.\n */\nexport const EXIT = false\n\n/**\n * Do not traverse this node’s children.\n */\nexport const SKIP = 'skip'\n\n/**\n * Visit nodes, with ancestral information.\n *\n * This algorithm performs *depth-first* *tree traversal* in *preorder*\n * (**NLR**) or if `reverse` is given, in *reverse preorder* (**NRL**).\n *\n * You can choose for which nodes `visitor` is called by passing a `test`.\n * For complex tests, you should test yourself in `visitor`, as it will be\n * faster and will have improved type information.\n *\n * Walking the tree is an intensive task.\n * Make use of the return values of the visitor when possible.\n * Instead of walking a tree multiple times, walk it once, use `unist-util-is`\n * to check if a node matches, and then perform different operations.\n *\n * You can change the tree.\n * See `Visitor` for more info.\n *\n * @overload\n * @param {Tree} tree\n * @param {Check} check\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @overload\n * @param {Tree} tree\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @param {UnistNode} tree\n * Tree to traverse.\n * @param {Visitor | Test} test\n * `unist-util-is`-compatible test\n * @param {Visitor | boolean | null | undefined} [visitor]\n * Handle each node.\n * @param {boolean | null | undefined} [reverse]\n * Traverse in reverse preorder (NRL) instead of the default preorder (NLR).\n * @returns {undefined}\n * Nothing.\n *\n * @template {UnistNode} Tree\n * Node type.\n * @template {Test} Check\n * `unist-util-is`-compatible test.\n */\nexport function visitParents(tree, test, visitor, reverse) {\n /** @type {Test} */\n let check\n\n if (typeof test === 'function' && typeof visitor !== 'function') {\n reverse = visitor\n // @ts-expect-error no visitor given, so `visitor` is test.\n visitor = test\n } else {\n // @ts-expect-error visitor given, so `test` isn’t a visitor.\n check = test\n }\n\n const is = convert(check)\n const step = reverse ? -1 : 1\n\n factory(tree, undefined, [])()\n\n /**\n * @param {UnistNode} node\n * @param {number | undefined} index\n * @param {Array} parents\n */\n function factory(node, index, parents) {\n const value = /** @type {Record} */ (\n node && typeof node === 'object' ? node : {}\n )\n\n if (typeof value.type === 'string') {\n const name =\n // `hast`\n typeof value.tagName === 'string'\n ? value.tagName\n : // `xast`\n typeof value.name === 'string'\n ? value.name\n : undefined\n\n Object.defineProperty(visit, 'name', {\n value:\n 'node (' + color(node.type + (name ? '<' + name + '>' : '')) + ')'\n })\n }\n\n return visit\n\n function visit() {\n /** @type {Readonly} */\n let result = empty\n /** @type {Readonly} */\n let subresult\n /** @type {number} */\n let offset\n /** @type {Array} */\n let grandparents\n\n if (!test || is(node, index, parents[parents.length - 1] || undefined)) {\n // @ts-expect-error: `visitor` is now a visitor.\n result = toResult(visitor(node, parents))\n\n if (result[0] === EXIT) {\n return result\n }\n }\n\n if ('children' in node && node.children) {\n const nodeAsParent = /** @type {UnistParent} */ (node)\n\n if (nodeAsParent.children && result[0] !== SKIP) {\n offset = (reverse ? nodeAsParent.children.length : -1) + step\n grandparents = parents.concat(nodeAsParent)\n\n while (offset > -1 && offset < nodeAsParent.children.length) {\n const child = nodeAsParent.children[offset]\n\n subresult = factory(child, offset, grandparents)()\n\n if (subresult[0] === EXIT) {\n return subresult\n }\n\n offset =\n typeof subresult[1] === 'number' ? subresult[1] : offset + step\n }\n }\n }\n\n return result\n }\n }\n}\n\n/**\n * Turn a return value into a clean result.\n *\n * @param {VisitorResult} value\n * Valid return values from visitors.\n * @returns {Readonly}\n * Clean result.\n */\nfunction toResult(value) {\n if (Array.isArray(value)) {\n return value\n }\n\n if (typeof value === 'number') {\n return [CONTINUE, value]\n }\n\n return value === null || value === undefined ? empty : [value]\n}\n","/**\n * @typedef {import('unist').Node} UnistNode\n * @typedef {import('unist').Parent} UnistParent\n * @typedef {import('unist-util-visit-parents').VisitorResult} VisitorResult\n */\n\n/**\n * @typedef {Exclude | undefined} Test\n * Test from `unist-util-is`.\n *\n * Note: we have remove and add `undefined`, because otherwise when generating\n * automatic `.d.ts` files, TS tries to flatten paths from a local perspective,\n * which doesn’t work when publishing on npm.\n */\n\n// To do: use types from `unist-util-visit-parents` when it’s released.\n\n/**\n * @typedef {(\n * Fn extends (value: any) => value is infer Thing\n * ? Thing\n * : Fallback\n * )} Predicate\n * Get the value of a type guard `Fn`.\n * @template Fn\n * Value; typically function that is a type guard (such as `(x): x is Y`).\n * @template Fallback\n * Value to yield if `Fn` is not a type guard.\n */\n\n/**\n * @typedef {(\n * Check extends null | undefined // No test.\n * ? Value\n * : Value extends {type: Check} // String (type) test.\n * ? Value\n * : Value extends Check // Partial test.\n * ? Value\n * : Check extends Function // Function test.\n * ? Predicate extends Value\n * ? Predicate\n * : never\n * : never // Some other test?\n * )} MatchesOne\n * Check whether a node matches a primitive check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test, but not arrays.\n */\n\n/**\n * @typedef {(\n * Check extends Array\n * ? MatchesOne\n * : MatchesOne\n * )} Matches\n * Check whether a node matches a check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test.\n */\n\n/**\n * @typedef {0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10} Uint\n * Number; capped reasonably.\n */\n\n/**\n * @typedef {I extends 0 ? 1 : I extends 1 ? 2 : I extends 2 ? 3 : I extends 3 ? 4 : I extends 4 ? 5 : I extends 5 ? 6 : I extends 6 ? 7 : I extends 7 ? 8 : I extends 8 ? 9 : 10} Increment\n * Increment a number in the type system.\n * @template {Uint} [I=0]\n * Index.\n */\n\n/**\n * @typedef {(\n * Node extends UnistParent\n * ? Node extends {children: Array}\n * ? Child extends Children ? Node : never\n * : never\n * : never\n * )} InternalParent\n * Collect nodes that can be parents of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {InternalParent, Child>} Parent\n * Collect nodes in `Tree` that can be parents of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Depth extends Max\n * ? never\n * :\n * | InternalParent\n * | InternalAncestor, Max, Increment>\n * )} InternalAncestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {(\n * Tree extends UnistParent\n * ? Depth extends Max\n * ? Tree\n * : Tree | InclusiveDescendant>\n * : Tree\n * )} InclusiveDescendant\n * Collect all (inclusive) descendants of `Tree`.\n *\n * > 👉 **Note**: for performance reasons, this seems to be the fastest way to\n * > recurse without actually running into an infinite loop, which the\n * > previous version did.\n * >\n * > Practically, a max of `2` is typically enough assuming a `Root` is\n * > passed, but it doesn’t improve performance.\n * > It gets higher with `List > ListItem > Table > TableRow > TableCell`.\n * > Using up to `10` doesn’t hurt or help either.\n * @template {UnistNode} Tree\n * Tree type.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @callback Visitor\n * Handle a node (matching `test`, if given).\n *\n * Visitors are free to transform `node`.\n * They can also transform `parent`.\n *\n * Replacing `node` itself, if `SKIP` is not returned, still causes its\n * descendants to be walked (which is a bug).\n *\n * When adding or removing previous siblings of `node` (or next siblings, in\n * case of reverse), the `Visitor` should return a new `Index` to specify the\n * sibling to traverse after `node` is traversed.\n * Adding or removing next siblings of `node` (or previous siblings, in case\n * of reverse) is handled as expected without needing to return a new `Index`.\n *\n * Removing the children property of `parent` still results in them being\n * traversed.\n * @param {Visited} node\n * Found node.\n * @param {Visited extends UnistNode ? number | undefined : never} index\n * Index of `node` in `parent`.\n * @param {Ancestor extends UnistParent ? Ancestor | undefined : never} parent\n * Parent of `node`.\n * @returns {VisitorResult}\n * What to do next.\n *\n * An `Index` is treated as a tuple of `[CONTINUE, Index]`.\n * An `Action` is treated as a tuple of `[Action]`.\n *\n * Passing a tuple back only makes sense if the `Action` is `SKIP`.\n * When the `Action` is `EXIT`, that action can be returned.\n * When the `Action` is `CONTINUE`, `Index` can be returned.\n * @template {UnistNode} [Visited=UnistNode]\n * Visited node type.\n * @template {UnistParent} [Ancestor=UnistParent]\n * Ancestor type.\n */\n\n/**\n * @typedef {Visitor>} BuildVisitorFromMatch\n * Build a typed `Visitor` function from a node and all possible parents.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} Visited\n * Node type.\n * @template {UnistParent} Ancestor\n * Parent type.\n */\n\n/**\n * @typedef {(\n * BuildVisitorFromMatch<\n * Matches,\n * Extract\n * >\n * )} BuildVisitorFromDescendants\n * Build a typed `Visitor` function from a list of descendants and a test.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} Descendant\n * Node type.\n * @template {Test} Check\n * Test type.\n */\n\n/**\n * @typedef {(\n * BuildVisitorFromDescendants<\n * InclusiveDescendant,\n * Check\n * >\n * )} BuildVisitor\n * Build a typed `Visitor` function from a tree and a test.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} [Tree=UnistNode]\n * Node type.\n * @template {Test} [Check=Test]\n * Test type.\n */\n\nimport {visitParents} from 'unist-util-visit-parents'\n\nexport {CONTINUE, EXIT, SKIP} from 'unist-util-visit-parents'\n\n/**\n * Visit nodes.\n *\n * This algorithm performs *depth-first* *tree traversal* in *preorder*\n * (**NLR**) or if `reverse` is given, in *reverse preorder* (**NRL**).\n *\n * You can choose for which nodes `visitor` is called by passing a `test`.\n * For complex tests, you should test yourself in `visitor`, as it will be\n * faster and will have improved type information.\n *\n * Walking the tree is an intensive task.\n * Make use of the return values of the visitor when possible.\n * Instead of walking a tree multiple times, walk it once, use `unist-util-is`\n * to check if a node matches, and then perform different operations.\n *\n * You can change the tree.\n * See `Visitor` for more info.\n *\n * @overload\n * @param {Tree} tree\n * @param {Check} check\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @overload\n * @param {Tree} tree\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @param {UnistNode} tree\n * Tree to traverse.\n * @param {Visitor | Test} testOrVisitor\n * `unist-util-is`-compatible test (optional, omit to pass a visitor).\n * @param {Visitor | boolean | null | undefined} [visitorOrReverse]\n * Handle each node (when test is omitted, pass `reverse`).\n * @param {boolean | null | undefined} [maybeReverse=false]\n * Traverse in reverse preorder (NRL) instead of the default preorder (NLR).\n * @returns {undefined}\n * Nothing.\n *\n * @template {UnistNode} Tree\n * Node type.\n * @template {Test} Check\n * `unist-util-is`-compatible test.\n */\nexport function visit(tree, testOrVisitor, visitorOrReverse, maybeReverse) {\n /** @type {boolean | null | undefined} */\n let reverse\n /** @type {Test} */\n let test\n /** @type {Visitor} */\n let visitor\n\n if (\n typeof testOrVisitor === 'function' &&\n typeof visitorOrReverse !== 'function'\n ) {\n test = undefined\n visitor = testOrVisitor\n reverse = visitorOrReverse\n } else {\n // @ts-expect-error: assume the overload with test was given.\n test = testOrVisitor\n // @ts-expect-error: assume the overload with test was given.\n visitor = visitorOrReverse\n reverse = maybeReverse\n }\n\n visitParents(tree, test, overload, reverse)\n\n /**\n * @param {UnistNode} node\n * @param {Array} parents\n */\n function overload(node, parents) {\n const parent = parents[parents.length - 1]\n const index = parent ? parent.children.indexOf(node) : undefined\n return visitor(node, index, parent)\n }\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('hast').Root} Root\n * @typedef {import('hast-util-is-element').Test} Test\n */\n\n/**\n * @callback CreateContent\n * Create a target for the element.\n * @param {Element} element\n * Element to check.\n * @returns {Array | ElementContent | null | undefined}\n * Content to add.\n *\n * @callback CreateProperties\n * Create properties for an element.\n * @param {Element} element\n * Element to check.\n * @returns {Properties | null | undefined}\n * Properties to add.\n *\n * @callback CreateRel\n * Create a `rel` for the element.\n * @param {Element} element\n * Element to check.\n * @returns {Array | string | null | undefined}\n * `rel` to use.\n *\n * @callback CreateTarget\n * Create a `target` for the element.\n * @param {Element} element\n * Element to check.\n * @returns {Target | null | undefined}\n * `target` to use.\n *\n * @typedef Options\n * Configuration.\n * @property {Array | CreateContent | ElementContent | null | undefined} [content]\n * Content to insert at the end of external links (optional); will be\n * inserted in a `` element; useful for improving accessibility by\n * giving users advanced warning when opening a new window.\n * @property {CreateProperties | Properties | null | undefined} [contentProperties]\n * Properties to add to the `span` wrapping `content` (optional).\n * @property {CreateProperties | Properties | null | undefined} [properties]\n * Properties to add to the link itself (optional).\n * @property {Array | null | undefined} [protocols=['http', 'https']]\n * Protocols to check, such as `mailto` or `tel` (default: `['http',\n * 'https']`).\n * @property {Array | CreateRel | string | null | undefined} [rel=['nofollow']]\n * Link types to hint about the referenced documents (default:\n * `['nofollow']`); pass an empty array (`[]`) to not set `rel`s on links;\n * when using a `target`, add `noopener` and `noreferrer` to avoid\n * exploitation of the `window.opener` API.\n * @property {CreateTarget | Target | null | undefined} [target]\n * How to display referenced documents; the default (nothing) is to not set\n * `target`s on links.\n * @property {Test | null | undefined} [test]\n * Extra test to define which external link elements are modified (optional);\n * any test that can be given to `hast-util-is-element` is supported.\n *\n * @typedef {'_blank' | '_parent' | '_self' | '_top'} Target\n * Target.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {convertElement} from 'hast-util-is-element'\nimport isAbsoluteUrl from 'is-absolute-url'\nimport {parse} from 'space-separated-tokens'\nimport {visit} from 'unist-util-visit'\n\nconst defaultProtocols = ['http', 'https']\nconst defaultRel = ['nofollow']\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Automatically add `rel` (and `target`?) to external links.\n *\n * ###### Notes\n *\n * You should [likely not configure `target`][css-tricks].\n *\n * You should at least set `rel` to `['nofollow']`.\n * When using a `target`, add `noopener` and `noreferrer` to avoid exploitation\n * of the `window.opener` API.\n *\n * When using a `target`, you should set `content` to adhere to accessibility\n * guidelines by giving users advanced warning when opening a new window.\n *\n * [css-tricks]: https://css-tricks.com/use-target_blank/\n *\n * @param {Readonly | null | undefined} [options]\n * Configuration (optional).\n * @returns\n * Transform.\n */\nexport default function rehypeExternalLinks(options) {\n const settings = options || emptyOptions\n const protocols = settings.protocols || defaultProtocols\n const is = convertElement(settings.test)\n\n /**\n * Transform.\n *\n * @param {Root} tree\n * Tree.\n * @returns {undefined}\n * Nothing.\n */\n return function (tree) {\n visit(tree, 'element', function (node, index, parent) {\n if (\n node.tagName === 'a' &&\n typeof node.properties.href === 'string' &&\n is(node, index, parent)\n ) {\n const url = node.properties.href\n\n if (\n isAbsoluteUrl(url)\n ? protocols.includes(url.slice(0, url.indexOf(':')))\n : url.startsWith('//')\n ) {\n const contentRaw = createIfNeeded(settings.content, node)\n const content =\n contentRaw && !Array.isArray(contentRaw) ? [contentRaw] : contentRaw\n const relRaw = createIfNeeded(settings.rel, node) || defaultRel\n const rel = typeof relRaw === 'string' ? parse(relRaw) : relRaw\n const target = createIfNeeded(settings.target, node)\n\n const properties = createIfNeeded(settings.properties, node)\n\n if (properties) {\n Object.assign(node.properties, structuredClone(properties))\n }\n\n if (rel.length > 0) {\n node.properties.rel = [...rel]\n }\n\n if (target) {\n node.properties.target = target\n }\n\n if (content) {\n const properties =\n createIfNeeded(settings.contentProperties, node) || {}\n\n node.children.push({\n type: 'element',\n tagName: 'span',\n properties: structuredClone(properties),\n children: structuredClone(content)\n })\n }\n }\n }\n })\n }\n}\n\n/**\n * Call a function to get a return value or use the value.\n *\n * @template T\n * Type of value.\n * @param {T} value\n * Value.\n * @param {Element} element\n * Element.\n * @returns {T extends Function ? ReturnType : T}\n * Result.\n */\nfunction createIfNeeded(value, element) {\n return typeof value === 'function' ? value(element) : value\n}\n","/**\n * @typedef Options\n * Configuration for `stringify`.\n * @property {boolean} [padLeft=true]\n * Whether to pad a space before a token.\n * @property {boolean} [padRight=false]\n * Whether to pad a space after a token.\n */\n\n/**\n * @typedef {Options} StringifyOptions\n * Please use `StringifyOptions` instead.\n */\n\n/**\n * Parse comma-separated tokens to an array.\n *\n * @param {string} value\n * Comma-separated tokens.\n * @returns {Array}\n * List of tokens.\n */\nexport function parse(value) {\n /** @type {Array} */\n const tokens = []\n const input = String(value || '')\n let index = input.indexOf(',')\n let start = 0\n /** @type {boolean} */\n let end = false\n\n while (!end) {\n if (index === -1) {\n index = input.length\n end = true\n }\n\n const token = input.slice(start, index).trim()\n\n if (token || !end) {\n tokens.push(token)\n }\n\n start = index + 1\n index = input.indexOf(',', start)\n }\n\n return tokens\n}\n\n/**\n * Serialize an array of strings or numbers to comma-separated tokens.\n *\n * @param {Array} values\n * List of tokens.\n * @param {Options} [options]\n * Configuration for `stringify` (optional).\n * @returns {string}\n * Comma-separated tokens.\n */\nexport function stringify(values, options) {\n const settings = options || {}\n\n // Ensure the last empty entry is seen.\n const input = values[values.length - 1] === '' ? [...values, ''] : values\n\n return input\n .join(\n (settings.padRight ? ' ' : '') +\n ',' +\n (settings.padLeft === false ? '' : ' ')\n )\n .trim()\n}\n","export function deprecate(fn) {\n return fn\n}\n\nexport function equal() {}\n\nexport function ok() {}\n\nexport function unreachable() {}\n","/**\n * @typedef Options\n * Configuration.\n * @property {boolean | null | undefined} [jsx=false]\n * Support JSX identifiers (default: `false`).\n */\n\nconst startRe = /[$_\\p{ID_Start}]/u\nconst contRe = /[$_\\u{200C}\\u{200D}\\p{ID_Continue}]/u\nconst contReJsx = /[-$_\\u{200C}\\u{200D}\\p{ID_Continue}]/u\nconst nameRe = /^[$_\\p{ID_Start}][$_\\u{200C}\\u{200D}\\p{ID_Continue}]*$/u\nconst nameReJsx = /^[$_\\p{ID_Start}][-$_\\u{200C}\\u{200D}\\p{ID_Continue}]*$/u\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Checks if the given code point can start an identifier.\n *\n * @param {number | undefined} code\n * Code point to check.\n * @returns {boolean}\n * Whether `code` can start an identifier.\n */\n// Note: `undefined` is supported so you can pass the result from `''.codePointAt`.\nexport function start(code) {\n return code ? startRe.test(String.fromCodePoint(code)) : false\n}\n\n/**\n * Checks if the given code point can continue an identifier.\n *\n * @param {number | undefined} code\n * Code point to check.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {boolean}\n * Whether `code` can continue an identifier.\n */\n// Note: `undefined` is supported so you can pass the result from `''.codePointAt`.\nexport function cont(code, options) {\n const settings = options || emptyOptions\n const re = settings.jsx ? contReJsx : contRe\n return code ? re.test(String.fromCodePoint(code)) : false\n}\n\n/**\n * Checks if the given value is a valid identifier name.\n *\n * @param {string} name\n * Identifier to check.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {boolean}\n * Whether `name` can be an identifier.\n */\nexport function name(name, options) {\n const settings = options || emptyOptions\n const re = settings.jsx ? nameReJsx : nameRe\n return re.test(name)\n}\n","/**\n * @typedef {import('hast').Nodes} Nodes\n */\n\n// HTML whitespace expression.\n// See .\nconst re = /[ \\t\\n\\f\\r]/g\n\n/**\n * Check if the given value is *inter-element whitespace*.\n *\n * @param {Nodes | string} thing\n * Thing to check (`Node` or `string`).\n * @returns {boolean}\n * Whether the `value` is inter-element whitespace (`boolean`): consisting of\n * zero or more of space, tab (`\\t`), line feed (`\\n`), carriage return\n * (`\\r`), or form feed (`\\f`); if a node is passed it must be a `Text` node,\n * whose `value` field is checked.\n */\nexport function whitespace(thing) {\n return typeof thing === 'object'\n ? thing.type === 'text'\n ? empty(thing.value)\n : false\n : empty(thing)\n}\n\n/**\n * @param {string} value\n * @returns {boolean}\n */\nfunction empty(value) {\n return value.replace(re, '') === ''\n}\n","/**\n * @import {Schema as SchemaType, Space} from 'property-information'\n */\n\n/** @type {SchemaType} */\nexport class Schema {\n /**\n * @param {SchemaType['property']} property\n * Property.\n * @param {SchemaType['normal']} normal\n * Normal.\n * @param {Space | undefined} [space]\n * Space.\n * @returns\n * Schema.\n */\n constructor(property, normal, space) {\n this.normal = normal\n this.property = property\n\n if (space) {\n this.space = space\n }\n }\n}\n\nSchema.prototype.normal = {}\nSchema.prototype.property = {}\nSchema.prototype.space = undefined\n","/**\n * @import {Info, Space} from 'property-information'\n */\n\nimport {Schema} from './schema.js'\n\n/**\n * @param {ReadonlyArray} definitions\n * Definitions.\n * @param {Space | undefined} [space]\n * Space.\n * @returns {Schema}\n * Schema.\n */\nexport function merge(definitions, space) {\n /** @type {Record} */\n const property = {}\n /** @type {Record} */\n const normal = {}\n\n for (const definition of definitions) {\n Object.assign(property, definition.property)\n Object.assign(normal, definition.normal)\n }\n\n return new Schema(property, normal, space)\n}\n","/**\n * Get the cleaned case insensitive form of an attribute or property.\n *\n * @param {string} value\n * An attribute-like or property-like name.\n * @returns {string}\n * Value that can be used to look up the properly cased property on a\n * `Schema`.\n */\nexport function normalize(value) {\n return value.toLowerCase()\n}\n","/**\n * @import {Info as InfoType} from 'property-information'\n */\n\n/** @type {InfoType} */\nexport class Info {\n /**\n * @param {string} property\n * Property.\n * @param {string} attribute\n * Attribute.\n * @returns\n * Info.\n */\n constructor(property, attribute) {\n this.attribute = attribute\n this.property = property\n }\n}\n\nInfo.prototype.attribute = ''\nInfo.prototype.booleanish = false\nInfo.prototype.boolean = false\nInfo.prototype.commaOrSpaceSeparated = false\nInfo.prototype.commaSeparated = false\nInfo.prototype.defined = false\nInfo.prototype.mustUseProperty = false\nInfo.prototype.number = false\nInfo.prototype.overloadedBoolean = false\nInfo.prototype.property = ''\nInfo.prototype.spaceSeparated = false\nInfo.prototype.space = undefined\n","let powers = 0\n\nexport const boolean = increment()\nexport const booleanish = increment()\nexport const overloadedBoolean = increment()\nexport const number = increment()\nexport const spaceSeparated = increment()\nexport const commaSeparated = increment()\nexport const commaOrSpaceSeparated = increment()\n\nfunction increment() {\n return 2 ** ++powers\n}\n","/**\n * @import {Space} from 'property-information'\n */\n\nimport {Info} from './info.js'\nimport * as types from './types.js'\n\nconst checks = /** @type {ReadonlyArray} */ (\n Object.keys(types)\n)\n\nexport class DefinedInfo extends Info {\n /**\n * @constructor\n * @param {string} property\n * Property.\n * @param {string} attribute\n * Attribute.\n * @param {number | null | undefined} [mask]\n * Mask.\n * @param {Space | undefined} [space]\n * Space.\n * @returns\n * Info.\n */\n constructor(property, attribute, mask, space) {\n let index = -1\n\n super(property, attribute)\n\n mark(this, 'space', space)\n\n if (typeof mask === 'number') {\n while (++index < checks.length) {\n const check = checks[index]\n mark(this, checks[index], (mask & types[check]) === types[check])\n }\n }\n }\n}\n\nDefinedInfo.prototype.defined = true\n\n/**\n * @template {keyof DefinedInfo} Key\n * Key type.\n * @param {DefinedInfo} values\n * Info.\n * @param {Key} key\n * Key.\n * @param {DefinedInfo[Key]} value\n * Value.\n * @returns {undefined}\n * Nothing.\n */\nfunction mark(values, key, value) {\n if (value) {\n values[key] = value\n }\n}\n","/**\n * @import {Info, Space} from 'property-information'\n */\n\n/**\n * @typedef Definition\n * Definition of a schema.\n * @property {Record | undefined} [attributes]\n * Normalzed names to special attribute case.\n * @property {ReadonlyArray | undefined} [mustUseProperty]\n * Normalized names that must be set as properties.\n * @property {Record} properties\n * Property names to their types.\n * @property {Space | undefined} [space]\n * Space.\n * @property {Transform} transform\n * Transform a property name.\n */\n\n/**\n * @callback Transform\n * Transform.\n * @param {Record} attributes\n * Attributes.\n * @param {string} property\n * Property.\n * @returns {string}\n * Attribute.\n */\n\nimport {normalize} from '../normalize.js'\nimport {DefinedInfo} from './defined-info.js'\nimport {Schema} from './schema.js'\n\n/**\n * @param {Definition} definition\n * Definition.\n * @returns {Schema}\n * Schema.\n */\nexport function create(definition) {\n /** @type {Record} */\n const properties = {}\n /** @type {Record} */\n const normals = {}\n\n for (const [property, value] of Object.entries(definition.properties)) {\n const info = new DefinedInfo(\n property,\n definition.transform(definition.attributes || {}, property),\n value,\n definition.space\n )\n\n if (\n definition.mustUseProperty &&\n definition.mustUseProperty.includes(property)\n ) {\n info.mustUseProperty = true\n }\n\n properties[property] = info\n\n normals[normalize(property)] = property\n normals[normalize(info.attribute)] = property\n }\n\n return new Schema(properties, normals, definition.space)\n}\n","import {create} from './util/create.js'\nimport {booleanish, number, spaceSeparated} from './util/types.js'\n\nexport const aria = create({\n properties: {\n ariaActiveDescendant: null,\n ariaAtomic: booleanish,\n ariaAutoComplete: null,\n ariaBusy: booleanish,\n ariaChecked: booleanish,\n ariaColCount: number,\n ariaColIndex: number,\n ariaColSpan: number,\n ariaControls: spaceSeparated,\n ariaCurrent: null,\n ariaDescribedBy: spaceSeparated,\n ariaDetails: null,\n ariaDisabled: booleanish,\n ariaDropEffect: spaceSeparated,\n ariaErrorMessage: null,\n ariaExpanded: booleanish,\n ariaFlowTo: spaceSeparated,\n ariaGrabbed: booleanish,\n ariaHasPopup: null,\n ariaHidden: booleanish,\n ariaInvalid: null,\n ariaKeyShortcuts: null,\n ariaLabel: null,\n ariaLabelledBy: spaceSeparated,\n ariaLevel: number,\n ariaLive: null,\n ariaModal: booleanish,\n ariaMultiLine: booleanish,\n ariaMultiSelectable: booleanish,\n ariaOrientation: null,\n ariaOwns: spaceSeparated,\n ariaPlaceholder: null,\n ariaPosInSet: number,\n ariaPressed: booleanish,\n ariaReadOnly: booleanish,\n ariaRelevant: null,\n ariaRequired: booleanish,\n ariaRoleDescription: spaceSeparated,\n ariaRowCount: number,\n ariaRowIndex: number,\n ariaRowSpan: number,\n ariaSelected: booleanish,\n ariaSetSize: number,\n ariaSort: null,\n ariaValueMax: number,\n ariaValueMin: number,\n ariaValueNow: number,\n ariaValueText: null,\n role: null\n },\n transform(_, property) {\n return property === 'role'\n ? property\n : 'aria-' + property.slice(4).toLowerCase()\n }\n})\n","/**\n * @param {Record} attributes\n * Attributes.\n * @param {string} attribute\n * Attribute.\n * @returns {string}\n * Transformed attribute.\n */\nexport function caseSensitiveTransform(attributes, attribute) {\n return attribute in attributes ? attributes[attribute] : attribute\n}\n","import {caseSensitiveTransform} from './case-sensitive-transform.js'\n\n/**\n * @param {Record} attributes\n * Attributes.\n * @param {string} property\n * Property.\n * @returns {string}\n * Transformed property.\n */\nexport function caseInsensitiveTransform(attributes, property) {\n return caseSensitiveTransform(attributes, property.toLowerCase())\n}\n","import {caseInsensitiveTransform} from './util/case-insensitive-transform.js'\nimport {create} from './util/create.js'\nimport {\n booleanish,\n boolean,\n commaSeparated,\n number,\n overloadedBoolean,\n spaceSeparated\n} from './util/types.js'\n\nexport const html = create({\n attributes: {\n acceptcharset: 'accept-charset',\n classname: 'class',\n htmlfor: 'for',\n httpequiv: 'http-equiv'\n },\n mustUseProperty: ['checked', 'multiple', 'muted', 'selected'],\n properties: {\n // Standard Properties.\n abbr: null,\n accept: commaSeparated,\n acceptCharset: spaceSeparated,\n accessKey: spaceSeparated,\n action: null,\n allow: null,\n allowFullScreen: boolean,\n allowPaymentRequest: boolean,\n allowUserMedia: boolean,\n alt: null,\n as: null,\n async: boolean,\n autoCapitalize: null,\n autoComplete: spaceSeparated,\n autoFocus: boolean,\n autoPlay: boolean,\n blocking: spaceSeparated,\n capture: null,\n charSet: null,\n checked: boolean,\n cite: null,\n className: spaceSeparated,\n cols: number,\n colSpan: null,\n content: null,\n contentEditable: booleanish,\n controls: boolean,\n controlsList: spaceSeparated,\n coords: number | commaSeparated,\n crossOrigin: null,\n data: null,\n dateTime: null,\n decoding: null,\n default: boolean,\n defer: boolean,\n dir: null,\n dirName: null,\n disabled: boolean,\n download: overloadedBoolean,\n draggable: booleanish,\n encType: null,\n enterKeyHint: null,\n fetchPriority: null,\n form: null,\n formAction: null,\n formEncType: null,\n formMethod: null,\n formNoValidate: boolean,\n formTarget: null,\n headers: spaceSeparated,\n height: number,\n hidden: overloadedBoolean,\n high: number,\n href: null,\n hrefLang: null,\n htmlFor: spaceSeparated,\n httpEquiv: spaceSeparated,\n id: null,\n imageSizes: null,\n imageSrcSet: null,\n inert: boolean,\n inputMode: null,\n integrity: null,\n is: null,\n isMap: boolean,\n itemId: null,\n itemProp: spaceSeparated,\n itemRef: spaceSeparated,\n itemScope: boolean,\n itemType: spaceSeparated,\n kind: null,\n label: null,\n lang: null,\n language: null,\n list: null,\n loading: null,\n loop: boolean,\n low: number,\n manifest: null,\n max: null,\n maxLength: number,\n media: null,\n method: null,\n min: null,\n minLength: number,\n multiple: boolean,\n muted: boolean,\n name: null,\n nonce: null,\n noModule: boolean,\n noValidate: boolean,\n onAbort: null,\n onAfterPrint: null,\n onAuxClick: null,\n onBeforeMatch: null,\n onBeforePrint: null,\n onBeforeToggle: null,\n onBeforeUnload: null,\n onBlur: null,\n onCancel: null,\n onCanPlay: null,\n onCanPlayThrough: null,\n onChange: null,\n onClick: null,\n onClose: null,\n onContextLost: null,\n onContextMenu: null,\n onContextRestored: null,\n onCopy: null,\n onCueChange: null,\n onCut: null,\n onDblClick: null,\n onDrag: null,\n onDragEnd: null,\n onDragEnter: null,\n onDragExit: null,\n onDragLeave: null,\n onDragOver: null,\n onDragStart: null,\n onDrop: null,\n onDurationChange: null,\n onEmptied: null,\n onEnded: null,\n onError: null,\n onFocus: null,\n onFormData: null,\n onHashChange: null,\n onInput: null,\n onInvalid: null,\n onKeyDown: null,\n onKeyPress: null,\n onKeyUp: null,\n onLanguageChange: null,\n onLoad: null,\n onLoadedData: null,\n onLoadedMetadata: null,\n onLoadEnd: null,\n onLoadStart: null,\n onMessage: null,\n onMessageError: null,\n onMouseDown: null,\n onMouseEnter: null,\n onMouseLeave: null,\n onMouseMove: null,\n onMouseOut: null,\n onMouseOver: null,\n onMouseUp: null,\n onOffline: null,\n onOnline: null,\n onPageHide: null,\n onPageShow: null,\n onPaste: null,\n onPause: null,\n onPlay: null,\n onPlaying: null,\n onPopState: null,\n onProgress: null,\n onRateChange: null,\n onRejectionHandled: null,\n onReset: null,\n onResize: null,\n onScroll: null,\n onScrollEnd: null,\n onSecurityPolicyViolation: null,\n onSeeked: null,\n onSeeking: null,\n onSelect: null,\n onSlotChange: null,\n onStalled: null,\n onStorage: null,\n onSubmit: null,\n onSuspend: null,\n onTimeUpdate: null,\n onToggle: null,\n onUnhandledRejection: null,\n onUnload: null,\n onVolumeChange: null,\n onWaiting: null,\n onWheel: null,\n open: boolean,\n optimum: number,\n pattern: null,\n ping: spaceSeparated,\n placeholder: null,\n playsInline: boolean,\n popover: null,\n popoverTarget: null,\n popoverTargetAction: null,\n poster: null,\n preload: null,\n readOnly: boolean,\n referrerPolicy: null,\n rel: spaceSeparated,\n required: boolean,\n reversed: boolean,\n rows: number,\n rowSpan: number,\n sandbox: spaceSeparated,\n scope: null,\n scoped: boolean,\n seamless: boolean,\n selected: boolean,\n shadowRootClonable: boolean,\n shadowRootDelegatesFocus: boolean,\n shadowRootMode: null,\n shape: null,\n size: number,\n sizes: null,\n slot: null,\n span: number,\n spellCheck: booleanish,\n src: null,\n srcDoc: null,\n srcLang: null,\n srcSet: null,\n start: number,\n step: null,\n style: null,\n tabIndex: number,\n target: null,\n title: null,\n translate: null,\n type: null,\n typeMustMatch: boolean,\n useMap: null,\n value: booleanish,\n width: number,\n wrap: null,\n writingSuggestions: null,\n\n // Legacy.\n // See: https://html.spec.whatwg.org/#other-elements,-attributes-and-apis\n align: null, // Several. Use CSS `text-align` instead,\n aLink: null, // ``. Use CSS `a:active {color}` instead\n archive: spaceSeparated, // ``. List of URIs to archives\n axis: null, // `` and ``. Use `scope` on ``\n background: null, // ``. Use CSS `background-image` instead\n bgColor: null, // `` and table elements. Use CSS `background-color` instead\n border: number, // ``. Use CSS `border-width` instead,\n borderColor: null, // `
`. Use CSS `border-color` instead,\n bottomMargin: number, // ``\n cellPadding: null, // `
`\n cellSpacing: null, // `
`\n char: null, // Several table elements. When `align=char`, sets the character to align on\n charOff: null, // Several table elements. When `char`, offsets the alignment\n classId: null, // ``\n clear: null, // `
`. Use CSS `clear` instead\n code: null, // ``\n codeBase: null, // ``\n codeType: null, // ``\n color: null, // `` and `
`. Use CSS instead\n compact: boolean, // Lists. Use CSS to reduce space between items instead\n declare: boolean, // ``\n event: null, // `\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationRawTagOpen(code) {\n if (code === 47) {\n effects.consume(code);\n buffer = '';\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In raw continuation, after ` | \n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function continuationRawEndTag(code) {\n if (code === 62) {\n const name = buffer.toLowerCase();\n if (htmlRawNames.includes(name)) {\n effects.consume(code);\n return continuationClose;\n }\n return continuation(code);\n }\n if (asciiAlpha(code) && buffer.length < 8) {\n // Always the case.\n effects.consume(code);\n buffer += String.fromCharCode(code);\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In cdata continuation, after `]`, expecting `]>`.\n *\n * ```markdown\n * > | &<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationCdataInside(code) {\n if (code === 93) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In declaration or instruction continuation, at `>`.\n *\n * ```markdown\n * > | \n * ^\n * > | \n * ^\n * > | \n * ^\n * > | \n * ^\n * > | &<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationDeclarationInside(code) {\n if (code === 62) {\n effects.consume(code);\n return continuationClose;\n }\n\n // More dashes.\n if (code === 45 && marker === 2) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In closed continuation: everything we get until the eol/eof is part of it.\n *\n * ```markdown\n * > | \n * ^\n * ```\n *\n * @type {State}\n */\n function continuationClose(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"htmlFlowData\");\n return continuationAfter(code);\n }\n effects.consume(code);\n return continuationClose;\n }\n\n /**\n * Done.\n *\n * ```markdown\n * > | \n * ^\n * ```\n *\n * @type {State}\n */\n function continuationAfter(code) {\n effects.exit(\"htmlFlow\");\n // // Feel free to interrupt.\n // tokenizer.interrupt = false\n // // No longer concrete.\n // tokenizer.concrete = false\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeNonLazyContinuationStart(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * At eol, before continuation.\n *\n * ```markdown\n * > | * ```js\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * A continuation.\n *\n * ```markdown\n * | * ```js\n * > | b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n return self.parser.lazy[self.now().line] ? nok(code) : ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlankLineBefore(effects, ok, nok) {\n return start;\n\n /**\n * Before eol, expecting blank line.\n *\n * ```markdown\n * > |
\n * ^\n * |\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return effects.attempt(blankLine, ok, nok);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiAlphanumeric, asciiAlpha, markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const htmlText = {\n name: 'htmlText',\n tokenize: tokenizeHtmlText\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHtmlText(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable | undefined} */\n let marker;\n /** @type {number} */\n let index;\n /** @type {State} */\n let returnState;\n return start;\n\n /**\n * Start of HTML (text).\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"htmlText\");\n effects.enter(\"htmlTextData\");\n effects.consume(code);\n return open;\n }\n\n /**\n * After `<`, at tag name or other stuff.\n *\n * ```markdown\n * > | a c\n * ^\n * > | a c\n * ^\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 33) {\n effects.consume(code);\n return declarationOpen;\n }\n if (code === 47) {\n effects.consume(code);\n return tagCloseStart;\n }\n if (code === 63) {\n effects.consume(code);\n return instruction;\n }\n\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagOpen;\n }\n return nok(code);\n }\n\n /**\n * After ` | a c\n * ^\n * > | a c\n * ^\n * > | a &<]]> c\n * ^\n * ```\n *\n * @type {State}\n */\n function declarationOpen(code) {\n if (code === 45) {\n effects.consume(code);\n return commentOpenInside;\n }\n if (code === 91) {\n effects.consume(code);\n index = 0;\n return cdataOpenInside;\n }\n if (asciiAlpha(code)) {\n effects.consume(code);\n return declaration;\n }\n return nok(code);\n }\n\n /**\n * In a comment, after ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentOpenInside(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return nok(code);\n }\n\n /**\n * In comment.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function comment(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 45) {\n effects.consume(code);\n return commentClose;\n }\n if (markdownLineEnding(code)) {\n returnState = comment;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return comment;\n }\n\n /**\n * In comment, after `-`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentClose(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return comment(code);\n }\n\n /**\n * In comment, after `--`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentEnd(code) {\n return code === 62 ? end(code) : code === 45 ? commentClose(code) : comment(code);\n }\n\n /**\n * After ` | a &<]]> b\n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function cdataOpenInside(code) {\n const value = \"CDATA[\";\n if (code === value.charCodeAt(index++)) {\n effects.consume(code);\n return index === value.length ? cdata : cdataOpenInside;\n }\n return nok(code);\n }\n\n /**\n * In CDATA.\n *\n * ```markdown\n * > | a &<]]> b\n * ^^^\n * ```\n *\n * @type {State}\n */\n function cdata(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataClose;\n }\n if (markdownLineEnding(code)) {\n returnState = cdata;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return cdata;\n }\n\n /**\n * In CDATA, after `]`, at another `]`.\n *\n * ```markdown\n * > | a &<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataClose(code) {\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In CDATA, after `]]`, at `>`.\n *\n * ```markdown\n * > | a &<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataEnd(code) {\n if (code === 62) {\n return end(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In declaration.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function declaration(code) {\n if (code === null || code === 62) {\n return end(code);\n }\n if (markdownLineEnding(code)) {\n returnState = declaration;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return declaration;\n }\n\n /**\n * In instruction.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function instruction(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 63) {\n effects.consume(code);\n return instructionClose;\n }\n if (markdownLineEnding(code)) {\n returnState = instruction;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return instruction;\n }\n\n /**\n * In instruction, after `?`, at `>`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function instructionClose(code) {\n return code === 62 ? end(code) : instruction(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseStart(code) {\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagClose;\n }\n return nok(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagClose(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagClose;\n }\n return tagCloseBetween(code);\n }\n\n /**\n * In closing tag, after tag name.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseBetween(code) {\n if (markdownLineEnding(code)) {\n returnState = tagCloseBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagCloseBetween;\n }\n return end(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpen(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpen;\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In opening tag, after tag name.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenBetween(code) {\n if (code === 47) {\n effects.consume(code);\n return end;\n }\n\n // ASCII alphabetical and `:` and `_`.\n if (code === 58 || code === 95 || asciiAlpha(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenBetween;\n }\n return end(code);\n }\n\n /**\n * In attribute name.\n *\n * ```markdown\n * > | a d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeName(code) {\n // ASCII alphabetical and `-`, `.`, `:`, and `_`.\n if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n return tagOpenAttributeNameAfter(code);\n }\n\n /**\n * After attribute name, before initializer, the end of the tag, or\n * whitespace.\n *\n * ```markdown\n * > | a d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeNameAfter(code) {\n if (code === 61) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeNameAfter;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeNameAfter;\n }\n return tagOpenBetween(code);\n }\n\n /**\n * Before unquoted, double quoted, or single quoted attribute value, allowing\n * whitespace.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueBefore(code) {\n if (code === null || code === 60 || code === 61 || code === 62 || code === 96) {\n return nok(code);\n }\n if (code === 34 || code === 39) {\n effects.consume(code);\n marker = code;\n return tagOpenAttributeValueQuoted;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueBefore;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * In double or single quoted attribute value.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuoted(code) {\n if (code === marker) {\n effects.consume(code);\n marker = undefined;\n return tagOpenAttributeValueQuotedAfter;\n }\n if (code === null) {\n return nok(code);\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueQuoted;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueQuoted;\n }\n\n /**\n * In unquoted attribute value.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueUnquoted(code) {\n if (code === null || code === 34 || code === 39 || code === 60 || code === 61 || code === 96) {\n return nok(code);\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * After double or single quoted attribute value, before whitespace or the end\n * of the tag.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuotedAfter(code) {\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In certain circumstances of a tag where only an `>` is allowed.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function end(code) {\n if (code === 62) {\n effects.consume(code);\n effects.exit(\"htmlTextData\");\n effects.exit(\"htmlText\");\n return ok;\n }\n return nok(code);\n }\n\n /**\n * At eol.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * > | a \n * ```\n *\n * @type {State}\n */\n function lineEndingBefore(code) {\n effects.exit(\"htmlTextData\");\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return lineEndingAfter;\n }\n\n /**\n * After eol, at optional whitespace.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a \n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfter(code) {\n // Always populated by defaults.\n\n return markdownSpace(code) ? factorySpace(effects, lineEndingAfterPrefix, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code) : lineEndingAfterPrefix(code);\n }\n\n /**\n * After eol, after optional whitespace.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a \n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfterPrefix(code) {\n effects.enter(\"htmlTextData\");\n return returnState(code);\n }\n}","/**\n * @import {\n * Construct,\n * Event,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factoryDestination } from 'micromark-factory-destination';\nimport { factoryLabel } from 'micromark-factory-label';\nimport { factoryTitle } from 'micromark-factory-title';\nimport { factoryWhitespace } from 'micromark-factory-whitespace';\nimport { markdownLineEndingOrSpace } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/** @type {Construct} */\nexport const labelEnd = {\n name: 'labelEnd',\n resolveAll: resolveAllLabelEnd,\n resolveTo: resolveToLabelEnd,\n tokenize: tokenizeLabelEnd\n};\n\n/** @type {Construct} */\nconst resourceConstruct = {\n tokenize: tokenizeResource\n};\n/** @type {Construct} */\nconst referenceFullConstruct = {\n tokenize: tokenizeReferenceFull\n};\n/** @type {Construct} */\nconst referenceCollapsedConstruct = {\n tokenize: tokenizeReferenceCollapsed\n};\n\n/** @type {Resolver} */\nfunction resolveAllLabelEnd(events) {\n let index = -1;\n /** @type {Array} */\n const newEvents = [];\n while (++index < events.length) {\n const token = events[index][1];\n newEvents.push(events[index]);\n if (token.type === \"labelImage\" || token.type === \"labelLink\" || token.type === \"labelEnd\") {\n // Remove the marker.\n const offset = token.type === \"labelImage\" ? 4 : 2;\n token.type = \"data\";\n index += offset;\n }\n }\n\n // If the events are equal, we don't have to copy newEvents to events\n if (events.length !== newEvents.length) {\n splice(events, 0, events.length, newEvents);\n }\n return events;\n}\n\n/** @type {Resolver} */\nfunction resolveToLabelEnd(events, context) {\n let index = events.length;\n let offset = 0;\n /** @type {Token} */\n let token;\n /** @type {number | undefined} */\n let open;\n /** @type {number | undefined} */\n let close;\n /** @type {Array} */\n let media;\n\n // Find an opening.\n while (index--) {\n token = events[index][1];\n if (open) {\n // If we see another link, or inactive link label, we’ve been here before.\n if (token.type === \"link\" || token.type === \"labelLink\" && token._inactive) {\n break;\n }\n\n // Mark other link openings as inactive, as we can’t have links in\n // links.\n if (events[index][0] === 'enter' && token.type === \"labelLink\") {\n token._inactive = true;\n }\n } else if (close) {\n if (events[index][0] === 'enter' && (token.type === \"labelImage\" || token.type === \"labelLink\") && !token._balanced) {\n open = index;\n if (token.type !== \"labelLink\") {\n offset = 2;\n break;\n }\n }\n } else if (token.type === \"labelEnd\") {\n close = index;\n }\n }\n const group = {\n type: events[open][1].type === \"labelLink\" ? \"link\" : \"image\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n const label = {\n type: \"label\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[close][1].end\n }\n };\n const text = {\n type: \"labelText\",\n start: {\n ...events[open + offset + 2][1].end\n },\n end: {\n ...events[close - 2][1].start\n }\n };\n media = [['enter', group, context], ['enter', label, context]];\n\n // Opening marker.\n media = push(media, events.slice(open + 1, open + offset + 3));\n\n // Text open.\n media = push(media, [['enter', text, context]]);\n\n // Always populated by defaults.\n\n // Between.\n media = push(media, resolveAll(context.parser.constructs.insideSpan.null, events.slice(open + offset + 4, close - 3), context));\n\n // Text close, marker close, label close.\n media = push(media, [['exit', text, context], events[close - 2], events[close - 1], ['exit', label, context]]);\n\n // Reference, resource, or so.\n media = push(media, events.slice(close + 1));\n\n // Media close.\n media = push(media, [['exit', group, context]]);\n splice(events, open, events.length, media);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelEnd(effects, ok, nok) {\n const self = this;\n let index = self.events.length;\n /** @type {Token} */\n let labelStart;\n /** @type {boolean} */\n let defined;\n\n // Find an opening.\n while (index--) {\n if ((self.events[index][1].type === \"labelImage\" || self.events[index][1].type === \"labelLink\") && !self.events[index][1]._balanced) {\n labelStart = self.events[index][1];\n break;\n }\n }\n return start;\n\n /**\n * Start of label end.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // If there is not an okay opening.\n if (!labelStart) {\n return nok(code);\n }\n\n // If the corresponding label (link) start is marked as inactive,\n // it means we’d be wrapping a link, like this:\n //\n // ```markdown\n // > | a [b [c](d) e](f) g.\n // ^\n // ```\n //\n // We can’t have that, so it’s just balanced brackets.\n if (labelStart._inactive) {\n return labelEndNok(code);\n }\n defined = self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n })));\n effects.enter(\"labelEnd\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelEnd\");\n return after;\n }\n\n /**\n * After `]`.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // Note: `markdown-rs` also parses GFM footnotes here, which for us is in\n // an extension.\n\n // Resource (`[asd](fgh)`)?\n if (code === 40) {\n return effects.attempt(resourceConstruct, labelEndOk, defined ? labelEndOk : labelEndNok)(code);\n }\n\n // Full (`[asd][fgh]`) or collapsed (`[asd][]`) reference?\n if (code === 91) {\n return effects.attempt(referenceFullConstruct, labelEndOk, defined ? referenceNotFull : labelEndNok)(code);\n }\n\n // Shortcut (`[asd]`) reference?\n return defined ? labelEndOk(code) : labelEndNok(code);\n }\n\n /**\n * After `]`, at `[`, but not at a full reference.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceNotFull(code) {\n return effects.attempt(referenceCollapsedConstruct, labelEndOk, labelEndNok)(code);\n }\n\n /**\n * Done, we found something.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndOk(code) {\n // Note: `markdown-rs` does a bunch of stuff here.\n return ok(code);\n }\n\n /**\n * Done, it’s nothing.\n *\n * There was an okay opening, but we didn’t match anything.\n *\n * ```markdown\n * > | [a](b c\n * ^\n * > | [a][b c\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndNok(code) {\n labelStart._balanced = true;\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeResource(effects, ok, nok) {\n return resourceStart;\n\n /**\n * At a resource.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceStart(code) {\n effects.enter(\"resource\");\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n return resourceBefore;\n }\n\n /**\n * In resource, after `(`, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBefore(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceOpen)(code) : resourceOpen(code);\n }\n\n /**\n * In resource, after optional whitespace, at `)` or a destination.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceOpen(code) {\n if (code === 41) {\n return resourceEnd(code);\n }\n return factoryDestination(effects, resourceDestinationAfter, resourceDestinationMissing, \"resourceDestination\", \"resourceDestinationLiteral\", \"resourceDestinationLiteralMarker\", \"resourceDestinationRaw\", \"resourceDestinationString\", 32)(code);\n }\n\n /**\n * In resource, after destination, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceBetween)(code) : resourceEnd(code);\n }\n\n /**\n * At invalid destination.\n *\n * ```markdown\n * > | [a](<<) b\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationMissing(code) {\n return nok(code);\n }\n\n /**\n * In resource, after destination and whitespace, at `(` or title.\n *\n * ```markdown\n * > | [a](b ) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBetween(code) {\n if (code === 34 || code === 39 || code === 40) {\n return factoryTitle(effects, resourceTitleAfter, nok, \"resourceTitle\", \"resourceTitleMarker\", \"resourceTitleString\")(code);\n }\n return resourceEnd(code);\n }\n\n /**\n * In resource, after title, at optional whitespace.\n *\n * ```markdown\n * > | [a](b \"c\") d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceTitleAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceEnd)(code) : resourceEnd(code);\n }\n\n /**\n * In resource, at `)`.\n *\n * ```markdown\n * > | [a](b) d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceEnd(code) {\n if (code === 41) {\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n effects.exit(\"resource\");\n return ok;\n }\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceFull(effects, ok, nok) {\n const self = this;\n return referenceFull;\n\n /**\n * In a reference (full), at the `[`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFull(code) {\n return factoryLabel.call(self, effects, referenceFullAfter, referenceFullMissing, \"reference\", \"referenceMarker\", \"referenceString\")(code);\n }\n\n /**\n * In a reference (full), after `]`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullAfter(code) {\n return self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize(self.events[self.events.length - 1][1]).slice(1, -1))) ? ok(code) : nok(code);\n }\n\n /**\n * In reference (full) that was missing.\n *\n * ```markdown\n * > | [a][b d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullMissing(code) {\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceCollapsed(effects, ok, nok) {\n return referenceCollapsedStart;\n\n /**\n * In reference (collapsed), at `[`.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedStart(code) {\n // We only attempt a collapsed label if there’s a `[`.\n\n effects.enter(\"reference\");\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n return referenceCollapsedOpen;\n }\n\n /**\n * In reference (collapsed), at `]`.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedOpen(code) {\n if (code === 93) {\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n effects.exit(\"reference\");\n return ok;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartImage = {\n name: 'labelStartImage',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartImage\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartImage(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (image) start.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelImage\");\n effects.enter(\"labelImageMarker\");\n effects.consume(code);\n effects.exit(\"labelImageMarker\");\n return open;\n }\n\n /**\n * After `!`, at `[`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 91) {\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelImage\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * After `![`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * This is needed in because, when GFM footnotes are enabled, images never\n * form when started with a `^`.\n * Instead, links form:\n *\n * ```markdown\n * ![^a](b)\n *\n * ![^a][b]\n *\n * [b]: c\n * ```\n *\n * ```html\n *

!^a

\n *

!^a

\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // To do: use a new field to do this, this is still needed for\n // `micromark-extension-gfm-footnote`, but the `label-start-link`\n // behavior isn’t.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartLink = {\n name: 'labelStartLink',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartLink\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartLink(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (link) start.\n *\n * ```markdown\n * > | a [b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelLink\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelLink\");\n return after;\n }\n\n /** @type {State} */\n function after(code) {\n // To do: this isn’t needed in `micromark-extension-gfm-footnote`,\n // remove.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const lineEnding = {\n name: 'lineEnding',\n tokenize: tokenizeLineEnding\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLineEnding(effects, ok) {\n return start;\n\n /** @type {State} */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, ok, \"linePrefix\");\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const thematicBreak = {\n name: 'thematicBreak',\n tokenize: tokenizeThematicBreak\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeThematicBreak(effects, ok, nok) {\n let size = 0;\n /** @type {NonNullable} */\n let marker;\n return start;\n\n /**\n * Start of thematic break.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"thematicBreak\");\n // To do: parse indent like `markdown-rs`.\n return before(code);\n }\n\n /**\n * After optional whitespace, at marker.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n marker = code;\n return atBreak(code);\n }\n\n /**\n * After something, before something else.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (code === marker) {\n effects.enter(\"thematicBreakSequence\");\n return sequence(code);\n }\n if (size >= 3 && (code === null || markdownLineEnding(code))) {\n effects.exit(\"thematicBreak\");\n return ok(code);\n }\n return nok(code);\n }\n\n /**\n * In sequence.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function sequence(code) {\n if (code === marker) {\n effects.consume(code);\n size++;\n return sequence;\n }\n effects.exit(\"thematicBreakSequence\");\n return markdownSpace(code) ? factorySpace(effects, atBreak, \"whitespace\")(code) : atBreak(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Exiter,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiDigit, markdownSpace } from 'micromark-util-character';\nimport { blankLine } from './blank-line.js';\nimport { thematicBreak } from './thematic-break.js';\n\n/** @type {Construct} */\nexport const list = {\n continuation: {\n tokenize: tokenizeListContinuation\n },\n exit: tokenizeListEnd,\n name: 'list',\n tokenize: tokenizeListStart\n};\n\n/** @type {Construct} */\nconst listItemPrefixWhitespaceConstruct = {\n partial: true,\n tokenize: tokenizeListItemPrefixWhitespace\n};\n\n/** @type {Construct} */\nconst indentConstruct = {\n partial: true,\n tokenize: tokenizeIndent\n};\n\n// To do: `markdown-rs` parses list items on their own and later stitches them\n// together.\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListStart(effects, ok, nok) {\n const self = this;\n const tail = self.events[self.events.length - 1];\n let initialSize = tail && tail[1].type === \"linePrefix\" ? tail[2].sliceSerialize(tail[1], true).length : 0;\n let size = 0;\n return start;\n\n /** @type {State} */\n function start(code) {\n const kind = self.containerState.type || (code === 42 || code === 43 || code === 45 ? \"listUnordered\" : \"listOrdered\");\n if (kind === \"listUnordered\" ? !self.containerState.marker || code === self.containerState.marker : asciiDigit(code)) {\n if (!self.containerState.type) {\n self.containerState.type = kind;\n effects.enter(kind, {\n _container: true\n });\n }\n if (kind === \"listUnordered\") {\n effects.enter(\"listItemPrefix\");\n return code === 42 || code === 45 ? effects.check(thematicBreak, nok, atMarker)(code) : atMarker(code);\n }\n if (!self.interrupt || code === 49) {\n effects.enter(\"listItemPrefix\");\n effects.enter(\"listItemValue\");\n return inside(code);\n }\n }\n return nok(code);\n }\n\n /** @type {State} */\n function inside(code) {\n if (asciiDigit(code) && ++size < 10) {\n effects.consume(code);\n return inside;\n }\n if ((!self.interrupt || size < 2) && (self.containerState.marker ? code === self.containerState.marker : code === 41 || code === 46)) {\n effects.exit(\"listItemValue\");\n return atMarker(code);\n }\n return nok(code);\n }\n\n /**\n * @type {State}\n **/\n function atMarker(code) {\n effects.enter(\"listItemMarker\");\n effects.consume(code);\n effects.exit(\"listItemMarker\");\n self.containerState.marker = self.containerState.marker || code;\n return effects.check(blankLine,\n // Can’t be empty when interrupting.\n self.interrupt ? nok : onBlank, effects.attempt(listItemPrefixWhitespaceConstruct, endOfPrefix, otherPrefix));\n }\n\n /** @type {State} */\n function onBlank(code) {\n self.containerState.initialBlankLine = true;\n initialSize++;\n return endOfPrefix(code);\n }\n\n /** @type {State} */\n function otherPrefix(code) {\n if (markdownSpace(code)) {\n effects.enter(\"listItemPrefixWhitespace\");\n effects.consume(code);\n effects.exit(\"listItemPrefixWhitespace\");\n return endOfPrefix;\n }\n return nok(code);\n }\n\n /** @type {State} */\n function endOfPrefix(code) {\n self.containerState.size = initialSize + self.sliceSerialize(effects.exit(\"listItemPrefix\"), true).length;\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListContinuation(effects, ok, nok) {\n const self = this;\n self.containerState._closeFlow = undefined;\n return effects.check(blankLine, onBlank, notBlank);\n\n /** @type {State} */\n function onBlank(code) {\n self.containerState.furtherBlankLines = self.containerState.furtherBlankLines || self.containerState.initialBlankLine;\n\n // We have a blank line.\n // Still, try to consume at most the items size.\n return factorySpace(effects, ok, \"listItemIndent\", self.containerState.size + 1)(code);\n }\n\n /** @type {State} */\n function notBlank(code) {\n if (self.containerState.furtherBlankLines || !markdownSpace(code)) {\n self.containerState.furtherBlankLines = undefined;\n self.containerState.initialBlankLine = undefined;\n return notInCurrentItem(code);\n }\n self.containerState.furtherBlankLines = undefined;\n self.containerState.initialBlankLine = undefined;\n return effects.attempt(indentConstruct, ok, notInCurrentItem)(code);\n }\n\n /** @type {State} */\n function notInCurrentItem(code) {\n // While we do continue, we signal that the flow should be closed.\n self.containerState._closeFlow = true;\n // As we’re closing flow, we’re no longer interrupting.\n self.interrupt = undefined;\n // Always populated by defaults.\n\n return factorySpace(effects, effects.attempt(list, ok, nok), \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeIndent(effects, ok, nok) {\n const self = this;\n return factorySpace(effects, afterPrefix, \"listItemIndent\", self.containerState.size + 1);\n\n /** @type {State} */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"listItemIndent\" && tail[2].sliceSerialize(tail[1], true).length === self.containerState.size ? ok(code) : nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Exiter}\n */\nfunction tokenizeListEnd(effects) {\n effects.exit(this.containerState.type);\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListItemPrefixWhitespace(effects, ok, nok) {\n const self = this;\n\n // Always populated by defaults.\n\n return factorySpace(effects, afterPrefix, \"listItemPrefixWhitespace\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4 + 1);\n\n /** @type {State} */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return !markdownSpace(code) && tail && tail[1].type === \"listItemPrefixWhitespace\" ? ok(code) : nok(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const setextUnderline = {\n name: 'setextUnderline',\n resolveTo: resolveToSetextUnderline,\n tokenize: tokenizeSetextUnderline\n};\n\n/** @type {Resolver} */\nfunction resolveToSetextUnderline(events, context) {\n // To do: resolve like `markdown-rs`.\n let index = events.length;\n /** @type {number | undefined} */\n let content;\n /** @type {number | undefined} */\n let text;\n /** @type {number | undefined} */\n let definition;\n\n // Find the opening of the content.\n // It’ll always exist: we don’t tokenize if it isn’t there.\n while (index--) {\n if (events[index][0] === 'enter') {\n if (events[index][1].type === \"content\") {\n content = index;\n break;\n }\n if (events[index][1].type === \"paragraph\") {\n text = index;\n }\n }\n // Exit\n else {\n if (events[index][1].type === \"content\") {\n // Remove the content end (if needed we’ll add it later)\n events.splice(index, 1);\n }\n if (!definition && events[index][1].type === \"definition\") {\n definition = index;\n }\n }\n }\n const heading = {\n type: \"setextHeading\",\n start: {\n ...events[content][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n\n // Change the paragraph to setext heading text.\n events[text][1].type = \"setextHeadingText\";\n\n // If we have definitions in the content, we’ll keep on having content,\n // but we need move it.\n if (definition) {\n events.splice(text, 0, ['enter', heading, context]);\n events.splice(definition + 1, 0, ['exit', events[content][1], context]);\n events[content][1].end = {\n ...events[definition][1].end\n };\n } else {\n events[content][1] = heading;\n }\n\n // Add the heading exit at the end.\n events.push(['exit', heading, context]);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeSetextUnderline(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable} */\n let marker;\n return start;\n\n /**\n * At start of heading (setext) underline.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n let index = self.events.length;\n /** @type {boolean | undefined} */\n let paragraph;\n // Find an opening.\n while (index--) {\n // Skip enter/exit of line ending, line prefix, and content.\n // We can now either have a definition or a paragraph.\n if (self.events[index][1].type !== \"lineEnding\" && self.events[index][1].type !== \"linePrefix\" && self.events[index][1].type !== \"content\") {\n paragraph = self.events[index][1].type === \"paragraph\";\n break;\n }\n }\n\n // To do: handle lazy/pierce like `markdown-rs`.\n // To do: parse indent like `markdown-rs`.\n if (!self.parser.lazy[self.now().line] && (self.interrupt || paragraph)) {\n effects.enter(\"setextHeadingLine\");\n marker = code;\n return before(code);\n }\n return nok(code);\n }\n\n /**\n * After optional whitespace, at `-` or `=`.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n effects.enter(\"setextHeadingLineSequence\");\n return inside(code);\n }\n\n /**\n * In sequence.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n if (code === marker) {\n effects.consume(code);\n return inside;\n }\n effects.exit(\"setextHeadingLineSequence\");\n return markdownSpace(code) ? factorySpace(effects, after, \"lineSuffix\")(code) : after(code);\n }\n\n /**\n * After sequence, after optional whitespace.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"setextHeadingLine\");\n return ok(code);\n }\n return nok(code);\n }\n}","/**\n * @import {\n * InitialConstruct,\n * Initializer,\n * State,\n * TokenizeContext\n * } from 'micromark-util-types'\n */\n\nimport { blankLine, content } from 'micromark-core-commonmark';\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {InitialConstruct} */\nexport const flow = {\n tokenize: initializeFlow\n};\n\n/**\n * @this {TokenizeContext}\n * Self.\n * @type {Initializer}\n * Initializer.\n */\nfunction initializeFlow(effects) {\n const self = this;\n const initial = effects.attempt(\n // Try to parse a blank line.\n blankLine, atBlankEnding,\n // Try to parse initial flow (essentially, only code).\n effects.attempt(this.parser.constructs.flowInitial, afterConstruct, factorySpace(effects, effects.attempt(this.parser.constructs.flow, afterConstruct, effects.attempt(content, afterConstruct)), \"linePrefix\")));\n return initial;\n\n /** @type {State} */\n function atBlankEnding(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEndingBlank\");\n effects.consume(code);\n effects.exit(\"lineEndingBlank\");\n self.currentConstruct = undefined;\n return initial;\n }\n\n /** @type {State} */\n function afterConstruct(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n self.currentConstruct = undefined;\n return initial;\n }\n}","/**\n * @import {\n * Code,\n * InitialConstruct,\n * Initializer,\n * Resolver,\n * State,\n * TokenizeContext\n * } from 'micromark-util-types'\n */\n\nexport const resolver = {\n resolveAll: createResolver()\n};\nexport const string = initializeFactory('string');\nexport const text = initializeFactory('text');\n\n/**\n * @param {'string' | 'text'} field\n * Field.\n * @returns {InitialConstruct}\n * Construct.\n */\nfunction initializeFactory(field) {\n return {\n resolveAll: createResolver(field === 'text' ? resolveAllLineSuffixes : undefined),\n tokenize: initializeText\n };\n\n /**\n * @this {TokenizeContext}\n * Context.\n * @type {Initializer}\n */\n function initializeText(effects) {\n const self = this;\n const constructs = this.parser.constructs[field];\n const text = effects.attempt(constructs, start, notText);\n return start;\n\n /** @type {State} */\n function start(code) {\n return atBreak(code) ? text(code) : notText(code);\n }\n\n /** @type {State} */\n function notText(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"data\");\n effects.consume(code);\n return data;\n }\n\n /** @type {State} */\n function data(code) {\n if (atBreak(code)) {\n effects.exit(\"data\");\n return text(code);\n }\n\n // Data.\n effects.consume(code);\n return data;\n }\n\n /**\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether the code is a break.\n */\n function atBreak(code) {\n if (code === null) {\n return true;\n }\n const list = constructs[code];\n let index = -1;\n if (list) {\n // Always populated by defaults.\n\n while (++index < list.length) {\n const item = list[index];\n if (!item.previous || item.previous.call(self, self.previous)) {\n return true;\n }\n }\n }\n return false;\n }\n }\n}\n\n/**\n * @param {Resolver | undefined} [extraResolver]\n * Resolver.\n * @returns {Resolver}\n * Resolver.\n */\nfunction createResolver(extraResolver) {\n return resolveAllText;\n\n /** @type {Resolver} */\n function resolveAllText(events, context) {\n let index = -1;\n /** @type {number | undefined} */\n let enter;\n\n // A rather boring computation (to merge adjacent `data` events) which\n // improves mm performance by 29%.\n while (++index <= events.length) {\n if (enter === undefined) {\n if (events[index] && events[index][1].type === \"data\") {\n enter = index;\n index++;\n }\n } else if (!events[index] || events[index][1].type !== \"data\") {\n // Don’t do anything if there is one data token.\n if (index !== enter + 2) {\n events[enter][1].end = events[index - 1][1].end;\n events.splice(enter + 2, index - enter - 2);\n index = enter + 2;\n }\n enter = undefined;\n }\n }\n return extraResolver ? extraResolver(events, context) : events;\n }\n}\n\n/**\n * A rather ugly set of instructions which again looks at chunks in the input\n * stream.\n * The reason to do this here is that it is *much* faster to parse in reverse.\n * And that we can’t hook into `null` to split the line suffix before an EOF.\n * To do: figure out if we can make this into a clean utility, or even in core.\n * As it will be useful for GFMs literal autolink extension (and maybe even\n * tables?)\n *\n * @type {Resolver}\n */\nfunction resolveAllLineSuffixes(events, context) {\n let eventIndex = 0; // Skip first.\n\n while (++eventIndex <= events.length) {\n if ((eventIndex === events.length || events[eventIndex][1].type === \"lineEnding\") && events[eventIndex - 1][1].type === \"data\") {\n const data = events[eventIndex - 1][1];\n const chunks = context.sliceStream(data);\n let index = chunks.length;\n let bufferIndex = -1;\n let size = 0;\n /** @type {boolean | undefined} */\n let tabs;\n while (index--) {\n const chunk = chunks[index];\n if (typeof chunk === 'string') {\n bufferIndex = chunk.length;\n while (chunk.charCodeAt(bufferIndex - 1) === 32) {\n size++;\n bufferIndex--;\n }\n if (bufferIndex) break;\n bufferIndex = -1;\n }\n // Number\n else if (chunk === -2) {\n tabs = true;\n size++;\n } else if (chunk === -1) {\n // Empty\n } else {\n // Replacement character, exit.\n index++;\n break;\n }\n }\n\n // Allow final trailing whitespace.\n if (context._contentTypeTextTrailing && eventIndex === events.length) {\n size = 0;\n }\n if (size) {\n const token = {\n type: eventIndex === events.length || tabs || size < 2 ? \"lineSuffix\" : \"hardBreakTrailing\",\n start: {\n _bufferIndex: index ? bufferIndex : data.start._bufferIndex + bufferIndex,\n _index: data.start._index + index,\n line: data.end.line,\n column: data.end.column - size,\n offset: data.end.offset - size\n },\n end: {\n ...data.end\n }\n };\n data.end = {\n ...token.start\n };\n if (data.start.offset === data.end.offset) {\n Object.assign(data, token);\n } else {\n events.splice(eventIndex, 0, ['enter', token, context], ['exit', token, context]);\n eventIndex += 2;\n }\n }\n eventIndex++;\n }\n }\n return events;\n}","/**\n * @import {Extension} from 'micromark-util-types'\n */\n\nimport { attention, autolink, blockQuote, characterEscape, characterReference, codeFenced, codeIndented, codeText, definition, hardBreakEscape, headingAtx, htmlFlow, htmlText, labelEnd, labelStartImage, labelStartLink, lineEnding, list, setextUnderline, thematicBreak } from 'micromark-core-commonmark';\nimport { resolver as resolveText } from './initialize/text.js';\n\n/** @satisfies {Extension['document']} */\nexport const document = {\n [42]: list,\n [43]: list,\n [45]: list,\n [48]: list,\n [49]: list,\n [50]: list,\n [51]: list,\n [52]: list,\n [53]: list,\n [54]: list,\n [55]: list,\n [56]: list,\n [57]: list,\n [62]: blockQuote\n};\n\n/** @satisfies {Extension['contentInitial']} */\nexport const contentInitial = {\n [91]: definition\n};\n\n/** @satisfies {Extension['flowInitial']} */\nexport const flowInitial = {\n [-2]: codeIndented,\n [-1]: codeIndented,\n [32]: codeIndented\n};\n\n/** @satisfies {Extension['flow']} */\nexport const flow = {\n [35]: headingAtx,\n [42]: thematicBreak,\n [45]: [setextUnderline, thematicBreak],\n [60]: htmlFlow,\n [61]: setextUnderline,\n [95]: thematicBreak,\n [96]: codeFenced,\n [126]: codeFenced\n};\n\n/** @satisfies {Extension['string']} */\nexport const string = {\n [38]: characterReference,\n [92]: characterEscape\n};\n\n/** @satisfies {Extension['text']} */\nexport const text = {\n [-5]: lineEnding,\n [-4]: lineEnding,\n [-3]: lineEnding,\n [33]: labelStartImage,\n [38]: characterReference,\n [42]: attention,\n [60]: [autolink, htmlText],\n [91]: labelStartLink,\n [92]: [hardBreakEscape, characterEscape],\n [93]: labelEnd,\n [95]: attention,\n [96]: codeText\n};\n\n/** @satisfies {Extension['insideSpan']} */\nexport const insideSpan = {\n null: [attention, resolveText]\n};\n\n/** @satisfies {Extension['attentionMarkers']} */\nexport const attentionMarkers = {\n null: [42, 95]\n};\n\n/** @satisfies {Extension['disable']} */\nexport const disable = {\n null: []\n};","/**\n * @import {\n * Chunk,\n * Code,\n * ConstructRecord,\n * Construct,\n * Effects,\n * InitialConstruct,\n * ParseContext,\n * Point,\n * State,\n * TokenizeContext,\n * Token\n * } from 'micromark-util-types'\n */\n\n/**\n * @callback Restore\n * Restore the state.\n * @returns {undefined}\n * Nothing.\n *\n * @typedef Info\n * Info.\n * @property {Restore} restore\n * Restore.\n * @property {number} from\n * From.\n *\n * @callback ReturnHandle\n * Handle a successful run.\n * @param {Construct} construct\n * Construct.\n * @param {Info} info\n * Info.\n * @returns {undefined}\n * Nothing.\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/**\n * Create a tokenizer.\n * Tokenizers deal with one type of data (e.g., containers, flow, text).\n * The parser is the object dealing with it all.\n * `initialize` works like other constructs, except that only its `tokenize`\n * function is used, in which case it doesn’t receive an `ok` or `nok`.\n * `from` can be given to set the point before the first character, although\n * when further lines are indented, they must be set with `defineSkip`.\n *\n * @param {ParseContext} parser\n * Parser.\n * @param {InitialConstruct} initialize\n * Construct.\n * @param {Omit | undefined} [from]\n * Point (optional).\n * @returns {TokenizeContext}\n * Context.\n */\nexport function createTokenizer(parser, initialize, from) {\n /** @type {Point} */\n let point = {\n _bufferIndex: -1,\n _index: 0,\n line: from && from.line || 1,\n column: from && from.column || 1,\n offset: from && from.offset || 0\n };\n /** @type {Record} */\n const columnStart = {};\n /** @type {Array} */\n const resolveAllConstructs = [];\n /** @type {Array} */\n let chunks = [];\n /** @type {Array} */\n let stack = [];\n /** @type {boolean | undefined} */\n let consumed = true;\n\n /**\n * Tools used for tokenizing.\n *\n * @type {Effects}\n */\n const effects = {\n attempt: constructFactory(onsuccessfulconstruct),\n check: constructFactory(onsuccessfulcheck),\n consume,\n enter,\n exit,\n interrupt: constructFactory(onsuccessfulcheck, {\n interrupt: true\n })\n };\n\n /**\n * State and tools for resolving and serializing.\n *\n * @type {TokenizeContext}\n */\n const context = {\n code: null,\n containerState: {},\n defineSkip,\n events: [],\n now,\n parser,\n previous: null,\n sliceSerialize,\n sliceStream,\n write\n };\n\n /**\n * The state function.\n *\n * @type {State | undefined}\n */\n let state = initialize.tokenize.call(context, effects);\n\n /**\n * Track which character we expect to be consumed, to catch bugs.\n *\n * @type {Code}\n */\n let expectedCode;\n if (initialize.resolveAll) {\n resolveAllConstructs.push(initialize);\n }\n return context;\n\n /** @type {TokenizeContext['write']} */\n function write(slice) {\n chunks = push(chunks, slice);\n main();\n\n // Exit if we’re not done, resolve might change stuff.\n if (chunks[chunks.length - 1] !== null) {\n return [];\n }\n addResult(initialize, 0);\n\n // Otherwise, resolve, and exit.\n context.events = resolveAll(resolveAllConstructs, context.events, context);\n return context.events;\n }\n\n //\n // Tools.\n //\n\n /** @type {TokenizeContext['sliceSerialize']} */\n function sliceSerialize(token, expandTabs) {\n return serializeChunks(sliceStream(token), expandTabs);\n }\n\n /** @type {TokenizeContext['sliceStream']} */\n function sliceStream(token) {\n return sliceChunks(chunks, token);\n }\n\n /** @type {TokenizeContext['now']} */\n function now() {\n // This is a hot path, so we clone manually instead of `Object.assign({}, point)`\n const {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n } = point;\n return {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n };\n }\n\n /** @type {TokenizeContext['defineSkip']} */\n function defineSkip(value) {\n columnStart[value.line] = value.column;\n accountForPotentialSkip();\n }\n\n //\n // State management.\n //\n\n /**\n * Main loop (note that `_index` and `_bufferIndex` in `point` are modified by\n * `consume`).\n * Here is where we walk through the chunks, which either include strings of\n * several characters, or numerical character codes.\n * The reason to do this in a loop instead of a call is so the stack can\n * drain.\n *\n * @returns {undefined}\n * Nothing.\n */\n function main() {\n /** @type {number} */\n let chunkIndex;\n while (point._index < chunks.length) {\n const chunk = chunks[point._index];\n\n // If we’re in a buffer chunk, loop through it.\n if (typeof chunk === 'string') {\n chunkIndex = point._index;\n if (point._bufferIndex < 0) {\n point._bufferIndex = 0;\n }\n while (point._index === chunkIndex && point._bufferIndex < chunk.length) {\n go(chunk.charCodeAt(point._bufferIndex));\n }\n } else {\n go(chunk);\n }\n }\n }\n\n /**\n * Deal with one code.\n *\n * @param {Code} code\n * Code.\n * @returns {undefined}\n * Nothing.\n */\n function go(code) {\n consumed = undefined;\n expectedCode = code;\n state = state(code);\n }\n\n /** @type {Effects['consume']} */\n function consume(code) {\n if (markdownLineEnding(code)) {\n point.line++;\n point.column = 1;\n point.offset += code === -3 ? 2 : 1;\n accountForPotentialSkip();\n } else if (code !== -1) {\n point.column++;\n point.offset++;\n }\n\n // Not in a string chunk.\n if (point._bufferIndex < 0) {\n point._index++;\n } else {\n point._bufferIndex++;\n\n // At end of string chunk.\n if (point._bufferIndex ===\n // Points w/ non-negative `_bufferIndex` reference\n // strings.\n /** @type {string} */\n chunks[point._index].length) {\n point._bufferIndex = -1;\n point._index++;\n }\n }\n\n // Expose the previous character.\n context.previous = code;\n\n // Mark as consumed.\n consumed = true;\n }\n\n /** @type {Effects['enter']} */\n function enter(type, fields) {\n /** @type {Token} */\n // @ts-expect-error Patch instead of assign required fields to help GC.\n const token = fields || {};\n token.type = type;\n token.start = now();\n context.events.push(['enter', token, context]);\n stack.push(token);\n return token;\n }\n\n /** @type {Effects['exit']} */\n function exit(type) {\n const token = stack.pop();\n token.end = now();\n context.events.push(['exit', token, context]);\n return token;\n }\n\n /**\n * Use results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulconstruct(construct, info) {\n addResult(construct, info.from);\n }\n\n /**\n * Discard results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulcheck(_, info) {\n info.restore();\n }\n\n /**\n * Factory to attempt/check/interrupt.\n *\n * @param {ReturnHandle} onreturn\n * Callback.\n * @param {{interrupt?: boolean | undefined} | undefined} [fields]\n * Fields.\n */\n function constructFactory(onreturn, fields) {\n return hook;\n\n /**\n * Handle either an object mapping codes to constructs, a list of\n * constructs, or a single construct.\n *\n * @param {Array | ConstructRecord | Construct} constructs\n * Constructs.\n * @param {State} returnState\n * State.\n * @param {State | undefined} [bogusState]\n * State.\n * @returns {State}\n * State.\n */\n function hook(constructs, returnState, bogusState) {\n /** @type {ReadonlyArray} */\n let listOfConstructs;\n /** @type {number} */\n let constructIndex;\n /** @type {Construct} */\n let currentConstruct;\n /** @type {Info} */\n let info;\n return Array.isArray(constructs) ? /* c8 ignore next 1 */\n handleListOfConstructs(constructs) : 'tokenize' in constructs ?\n // Looks like a construct.\n handleListOfConstructs([(/** @type {Construct} */constructs)]) : handleMapOfConstructs(constructs);\n\n /**\n * Handle a list of construct.\n *\n * @param {ConstructRecord} map\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleMapOfConstructs(map) {\n return start;\n\n /** @type {State} */\n function start(code) {\n const left = code !== null && map[code];\n const all = code !== null && map.null;\n const list = [\n // To do: add more extension tests.\n /* c8 ignore next 2 */\n ...(Array.isArray(left) ? left : left ? [left] : []), ...(Array.isArray(all) ? all : all ? [all] : [])];\n return handleListOfConstructs(list)(code);\n }\n }\n\n /**\n * Handle a list of construct.\n *\n * @param {ReadonlyArray} list\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleListOfConstructs(list) {\n listOfConstructs = list;\n constructIndex = 0;\n if (list.length === 0) {\n return bogusState;\n }\n return handleConstruct(list[constructIndex]);\n }\n\n /**\n * Handle a single construct.\n *\n * @param {Construct} construct\n * Construct.\n * @returns {State}\n * State.\n */\n function handleConstruct(construct) {\n return start;\n\n /** @type {State} */\n function start(code) {\n // To do: not needed to store if there is no bogus state, probably?\n // Currently doesn’t work because `inspect` in document does a check\n // w/o a bogus, which doesn’t make sense. But it does seem to help perf\n // by not storing.\n info = store();\n currentConstruct = construct;\n if (!construct.partial) {\n context.currentConstruct = construct;\n }\n\n // Always populated by defaults.\n\n if (construct.name && context.parser.constructs.disable.null.includes(construct.name)) {\n return nok(code);\n }\n return construct.tokenize.call(\n // If we do have fields, create an object w/ `context` as its\n // prototype.\n // This allows a “live binding”, which is needed for `interrupt`.\n fields ? Object.assign(Object.create(context), fields) : context, effects, ok, nok)(code);\n }\n }\n\n /** @type {State} */\n function ok(code) {\n consumed = true;\n onreturn(currentConstruct, info);\n return returnState;\n }\n\n /** @type {State} */\n function nok(code) {\n consumed = true;\n info.restore();\n if (++constructIndex < listOfConstructs.length) {\n return handleConstruct(listOfConstructs[constructIndex]);\n }\n return bogusState;\n }\n }\n }\n\n /**\n * @param {Construct} construct\n * Construct.\n * @param {number} from\n * From.\n * @returns {undefined}\n * Nothing.\n */\n function addResult(construct, from) {\n if (construct.resolveAll && !resolveAllConstructs.includes(construct)) {\n resolveAllConstructs.push(construct);\n }\n if (construct.resolve) {\n splice(context.events, from, context.events.length - from, construct.resolve(context.events.slice(from), context));\n }\n if (construct.resolveTo) {\n context.events = construct.resolveTo(context.events, context);\n }\n }\n\n /**\n * Store state.\n *\n * @returns {Info}\n * Info.\n */\n function store() {\n const startPoint = now();\n const startPrevious = context.previous;\n const startCurrentConstruct = context.currentConstruct;\n const startEventsIndex = context.events.length;\n const startStack = Array.from(stack);\n return {\n from: startEventsIndex,\n restore\n };\n\n /**\n * Restore state.\n *\n * @returns {undefined}\n * Nothing.\n */\n function restore() {\n point = startPoint;\n context.previous = startPrevious;\n context.currentConstruct = startCurrentConstruct;\n context.events.length = startEventsIndex;\n stack = startStack;\n accountForPotentialSkip();\n }\n }\n\n /**\n * Move the current point a bit forward in the line when it’s on a column\n * skip.\n *\n * @returns {undefined}\n * Nothing.\n */\n function accountForPotentialSkip() {\n if (point.line in columnStart && point.column < 2) {\n point.column = columnStart[point.line];\n point.offset += columnStart[point.line] - 1;\n }\n }\n}\n\n/**\n * Get the chunks from a slice of chunks in the range of a token.\n *\n * @param {ReadonlyArray} chunks\n * Chunks.\n * @param {Pick} token\n * Token.\n * @returns {Array}\n * Chunks.\n */\nfunction sliceChunks(chunks, token) {\n const startIndex = token.start._index;\n const startBufferIndex = token.start._bufferIndex;\n const endIndex = token.end._index;\n const endBufferIndex = token.end._bufferIndex;\n /** @type {Array} */\n let view;\n if (startIndex === endIndex) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view = [chunks[startIndex].slice(startBufferIndex, endBufferIndex)];\n } else {\n view = chunks.slice(startIndex, endIndex);\n if (startBufferIndex > -1) {\n const head = view[0];\n if (typeof head === 'string') {\n view[0] = head.slice(startBufferIndex);\n /* c8 ignore next 4 -- used to be used, no longer */\n } else {\n view.shift();\n }\n }\n if (endBufferIndex > 0) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view.push(chunks[endIndex].slice(0, endBufferIndex));\n }\n }\n return view;\n}\n\n/**\n * Get the string value of a slice of chunks.\n *\n * @param {ReadonlyArray} chunks\n * Chunks.\n * @param {boolean | undefined} [expandTabs=false]\n * Whether to expand tabs (default: `false`).\n * @returns {string}\n * Result.\n */\nfunction serializeChunks(chunks, expandTabs) {\n let index = -1;\n /** @type {Array} */\n const result = [];\n /** @type {boolean | undefined} */\n let atTab;\n while (++index < chunks.length) {\n const chunk = chunks[index];\n /** @type {string} */\n let value;\n if (typeof chunk === 'string') {\n value = chunk;\n } else switch (chunk) {\n case -5:\n {\n value = \"\\r\";\n break;\n }\n case -4:\n {\n value = \"\\n\";\n break;\n }\n case -3:\n {\n value = \"\\r\" + \"\\n\";\n break;\n }\n case -2:\n {\n value = expandTabs ? \" \" : \"\\t\";\n break;\n }\n case -1:\n {\n if (!expandTabs && atTab) continue;\n value = \" \";\n break;\n }\n default:\n {\n // Currently only replacement character.\n value = String.fromCharCode(chunk);\n }\n }\n atTab = chunk === -2;\n result.push(value);\n }\n return result.join('');\n}","/**\n * @import {\n * Create,\n * FullNormalizedExtension,\n * InitialConstruct,\n * ParseContext,\n * ParseOptions\n * } from 'micromark-util-types'\n */\n\nimport { combineExtensions } from 'micromark-util-combine-extensions';\nimport { content } from './initialize/content.js';\nimport { document } from './initialize/document.js';\nimport { flow } from './initialize/flow.js';\nimport { string, text } from './initialize/text.js';\nimport * as defaultConstructs from './constructs.js';\nimport { createTokenizer } from './create-tokenizer.js';\n\n/**\n * @param {ParseOptions | null | undefined} [options]\n * Configuration (optional).\n * @returns {ParseContext}\n * Parser.\n */\nexport function parse(options) {\n const settings = options || {};\n const constructs = /** @type {FullNormalizedExtension} */\n combineExtensions([defaultConstructs, ...(settings.extensions || [])]);\n\n /** @type {ParseContext} */\n const parser = {\n constructs,\n content: create(content),\n defined: [],\n document: create(document),\n flow: create(flow),\n lazy: {},\n string: create(string),\n text: create(text)\n };\n return parser;\n\n /**\n * @param {InitialConstruct} initial\n * Construct to start with.\n * @returns {Create}\n * Create a tokenizer.\n */\n function create(initial) {\n return creator;\n /** @type {Create} */\n function creator(from) {\n return createTokenizer(parser, initial, from);\n }\n }\n}","/**\n * @import {Event} from 'micromark-util-types'\n */\n\nimport { subtokenize } from 'micromark-util-subtokenize';\n\n/**\n * @param {Array} events\n * Events.\n * @returns {Array}\n * Events.\n */\nexport function postprocess(events) {\n while (!subtokenize(events)) {\n // Empty\n }\n return events;\n}","/**\n * @import {Chunk, Code, Encoding, Value} from 'micromark-util-types'\n */\n\n/**\n * @callback Preprocessor\n * Preprocess a value.\n * @param {Value} value\n * Value.\n * @param {Encoding | null | undefined} [encoding]\n * Encoding when `value` is a typed array (optional).\n * @param {boolean | null | undefined} [end=false]\n * Whether this is the last chunk (default: `false`).\n * @returns {Array}\n * Chunks.\n */\n\nconst search = /[\\0\\t\\n\\r]/g;\n\n/**\n * @returns {Preprocessor}\n * Preprocess a value.\n */\nexport function preprocess() {\n let column = 1;\n let buffer = '';\n /** @type {boolean | undefined} */\n let start = true;\n /** @type {boolean | undefined} */\n let atCarriageReturn;\n return preprocessor;\n\n /** @type {Preprocessor} */\n // eslint-disable-next-line complexity\n function preprocessor(value, encoding, end) {\n /** @type {Array} */\n const chunks = [];\n /** @type {RegExpMatchArray | null} */\n let match;\n /** @type {number} */\n let next;\n /** @type {number} */\n let startPosition;\n /** @type {number} */\n let endPosition;\n /** @type {Code} */\n let code;\n value = buffer + (typeof value === 'string' ? value.toString() : new TextDecoder(encoding || undefined).decode(value));\n startPosition = 0;\n buffer = '';\n if (start) {\n // To do: `markdown-rs` actually parses BOMs (byte order mark).\n if (value.charCodeAt(0) === 65279) {\n startPosition++;\n }\n start = undefined;\n }\n while (startPosition < value.length) {\n search.lastIndex = startPosition;\n match = search.exec(value);\n endPosition = match && match.index !== undefined ? match.index : value.length;\n code = value.charCodeAt(endPosition);\n if (!match) {\n buffer = value.slice(startPosition);\n break;\n }\n if (code === 10 && startPosition === endPosition && atCarriageReturn) {\n chunks.push(-3);\n atCarriageReturn = undefined;\n } else {\n if (atCarriageReturn) {\n chunks.push(-5);\n atCarriageReturn = undefined;\n }\n if (startPosition < endPosition) {\n chunks.push(value.slice(startPosition, endPosition));\n column += endPosition - startPosition;\n }\n switch (code) {\n case 0:\n {\n chunks.push(65533);\n column++;\n break;\n }\n case 9:\n {\n next = Math.ceil(column / 4) * 4;\n chunks.push(-2);\n while (column++ < next) chunks.push(-1);\n break;\n }\n case 10:\n {\n chunks.push(-4);\n column = 1;\n break;\n }\n default:\n {\n atCarriageReturn = true;\n column = 1;\n }\n }\n }\n startPosition = endPosition + 1;\n }\n if (end) {\n if (atCarriageReturn) chunks.push(-5);\n if (buffer) chunks.push(buffer);\n chunks.push(null);\n }\n return chunks;\n }\n}","import { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nconst characterEscapeOrReference = /\\\\([!-/:-@[-`{-~])|&(#(?:\\d{1,7}|x[\\da-f]{1,6})|[\\da-z]{1,31});/gi;\n\n/**\n * Decode markdown strings (which occur in places such as fenced code info\n * strings, destinations, labels, and titles).\n *\n * The “string” content type allows character escapes and -references.\n * This decodes those.\n *\n * @param {string} value\n * Value to decode.\n * @returns {string}\n * Decoded value.\n */\nexport function decodeString(value) {\n return value.replace(characterEscapeOrReference, decode);\n}\n\n/**\n * @param {string} $0\n * Match.\n * @param {string} $1\n * Character escape.\n * @param {string} $2\n * Character reference.\n * @returns {string}\n * Decoded value\n */\nfunction decode($0, $1, $2) {\n if ($1) {\n // Escape.\n return $1;\n }\n\n // Reference.\n const head = $2.charCodeAt(0);\n if (head === 35) {\n const head = $2.charCodeAt(1);\n const hex = head === 120 || head === 88;\n return decodeNumericCharacterReference($2.slice(hex ? 2 : 1), hex ? 16 : 10);\n }\n return decodeNamedCharacterReference($2) || $0;\n}","/**\n * @import {\n * Break,\n * Blockquote,\n * Code,\n * Definition,\n * Emphasis,\n * Heading,\n * Html,\n * Image,\n * InlineCode,\n * Link,\n * ListItem,\n * List,\n * Nodes,\n * Paragraph,\n * PhrasingContent,\n * ReferenceType,\n * Root,\n * Strong,\n * Text,\n * ThematicBreak\n * } from 'mdast'\n * @import {\n * Encoding,\n * Event,\n * Token,\n * Value\n * } from 'micromark-util-types'\n * @import {Point} from 'unist'\n * @import {\n * CompileContext,\n * CompileData,\n * Config,\n * Extension,\n * Handle,\n * OnEnterError,\n * Options\n * } from './types.js'\n */\n\nimport { toString } from 'mdast-util-to-string';\nimport { parse, postprocess, preprocess } from 'micromark';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nimport { decodeString } from 'micromark-util-decode-string';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { stringifyPosition } from 'unist-util-stringify-position';\nconst own = {}.hasOwnProperty;\n\n/**\n * Turn markdown into a syntax tree.\n *\n * @overload\n * @param {Value} value\n * @param {Encoding | null | undefined} [encoding]\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @overload\n * @param {Value} value\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @param {Value} value\n * Markdown to parse.\n * @param {Encoding | Options | null | undefined} [encoding]\n * Character encoding for when `value` is `Buffer`.\n * @param {Options | null | undefined} [options]\n * Configuration.\n * @returns {Root}\n * mdast tree.\n */\nexport function fromMarkdown(value, encoding, options) {\n if (typeof encoding !== 'string') {\n options = encoding;\n encoding = undefined;\n }\n return compiler(options)(postprocess(parse(options).document().write(preprocess()(value, encoding, true))));\n}\n\n/**\n * Note this compiler only understand complete buffering, not streaming.\n *\n * @param {Options | null | undefined} [options]\n */\nfunction compiler(options) {\n /** @type {Config} */\n const config = {\n transforms: [],\n canContainEols: ['emphasis', 'fragment', 'heading', 'paragraph', 'strong'],\n enter: {\n autolink: opener(link),\n autolinkProtocol: onenterdata,\n autolinkEmail: onenterdata,\n atxHeading: opener(heading),\n blockQuote: opener(blockQuote),\n characterEscape: onenterdata,\n characterReference: onenterdata,\n codeFenced: opener(codeFlow),\n codeFencedFenceInfo: buffer,\n codeFencedFenceMeta: buffer,\n codeIndented: opener(codeFlow, buffer),\n codeText: opener(codeText, buffer),\n codeTextData: onenterdata,\n data: onenterdata,\n codeFlowValue: onenterdata,\n definition: opener(definition),\n definitionDestinationString: buffer,\n definitionLabelString: buffer,\n definitionTitleString: buffer,\n emphasis: opener(emphasis),\n hardBreakEscape: opener(hardBreak),\n hardBreakTrailing: opener(hardBreak),\n htmlFlow: opener(html, buffer),\n htmlFlowData: onenterdata,\n htmlText: opener(html, buffer),\n htmlTextData: onenterdata,\n image: opener(image),\n label: buffer,\n link: opener(link),\n listItem: opener(listItem),\n listItemValue: onenterlistitemvalue,\n listOrdered: opener(list, onenterlistordered),\n listUnordered: opener(list),\n paragraph: opener(paragraph),\n reference: onenterreference,\n referenceString: buffer,\n resourceDestinationString: buffer,\n resourceTitleString: buffer,\n setextHeading: opener(heading),\n strong: opener(strong),\n thematicBreak: opener(thematicBreak)\n },\n exit: {\n atxHeading: closer(),\n atxHeadingSequence: onexitatxheadingsequence,\n autolink: closer(),\n autolinkEmail: onexitautolinkemail,\n autolinkProtocol: onexitautolinkprotocol,\n blockQuote: closer(),\n characterEscapeValue: onexitdata,\n characterReferenceMarkerHexadecimal: onexitcharacterreferencemarker,\n characterReferenceMarkerNumeric: onexitcharacterreferencemarker,\n characterReferenceValue: onexitcharacterreferencevalue,\n characterReference: onexitcharacterreference,\n codeFenced: closer(onexitcodefenced),\n codeFencedFence: onexitcodefencedfence,\n codeFencedFenceInfo: onexitcodefencedfenceinfo,\n codeFencedFenceMeta: onexitcodefencedfencemeta,\n codeFlowValue: onexitdata,\n codeIndented: closer(onexitcodeindented),\n codeText: closer(onexitcodetext),\n codeTextData: onexitdata,\n data: onexitdata,\n definition: closer(),\n definitionDestinationString: onexitdefinitiondestinationstring,\n definitionLabelString: onexitdefinitionlabelstring,\n definitionTitleString: onexitdefinitiontitlestring,\n emphasis: closer(),\n hardBreakEscape: closer(onexithardbreak),\n hardBreakTrailing: closer(onexithardbreak),\n htmlFlow: closer(onexithtmlflow),\n htmlFlowData: onexitdata,\n htmlText: closer(onexithtmltext),\n htmlTextData: onexitdata,\n image: closer(onexitimage),\n label: onexitlabel,\n labelText: onexitlabeltext,\n lineEnding: onexitlineending,\n link: closer(onexitlink),\n listItem: closer(),\n listOrdered: closer(),\n listUnordered: closer(),\n paragraph: closer(),\n referenceString: onexitreferencestring,\n resourceDestinationString: onexitresourcedestinationstring,\n resourceTitleString: onexitresourcetitlestring,\n resource: onexitresource,\n setextHeading: closer(onexitsetextheading),\n setextHeadingLineSequence: onexitsetextheadinglinesequence,\n setextHeadingText: onexitsetextheadingtext,\n strong: closer(),\n thematicBreak: closer()\n }\n };\n configure(config, (options || {}).mdastExtensions || []);\n\n /** @type {CompileData} */\n const data = {};\n return compile;\n\n /**\n * Turn micromark events into an mdast tree.\n *\n * @param {Array} events\n * Events.\n * @returns {Root}\n * mdast tree.\n */\n function compile(events) {\n /** @type {Root} */\n let tree = {\n type: 'root',\n children: []\n };\n /** @type {Omit} */\n const context = {\n stack: [tree],\n tokenStack: [],\n config,\n enter,\n exit,\n buffer,\n resume,\n data\n };\n /** @type {Array} */\n const listStack = [];\n let index = -1;\n while (++index < events.length) {\n // We preprocess lists to add `listItem` tokens, and to infer whether\n // items the list itself are spread out.\n if (events[index][1].type === \"listOrdered\" || events[index][1].type === \"listUnordered\") {\n if (events[index][0] === 'enter') {\n listStack.push(index);\n } else {\n const tail = listStack.pop();\n index = prepareList(events, tail, index);\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n const handler = config[events[index][0]];\n if (own.call(handler, events[index][1].type)) {\n handler[events[index][1].type].call(Object.assign({\n sliceSerialize: events[index][2].sliceSerialize\n }, context), events[index][1]);\n }\n }\n\n // Handle tokens still being open.\n if (context.tokenStack.length > 0) {\n const tail = context.tokenStack[context.tokenStack.length - 1];\n const handler = tail[1] || defaultOnError;\n handler.call(context, undefined, tail[0]);\n }\n\n // Figure out `root` position.\n tree.position = {\n start: point(events.length > 0 ? events[0][1].start : {\n line: 1,\n column: 1,\n offset: 0\n }),\n end: point(events.length > 0 ? events[events.length - 2][1].end : {\n line: 1,\n column: 1,\n offset: 0\n })\n };\n\n // Call transforms.\n index = -1;\n while (++index < config.transforms.length) {\n tree = config.transforms[index](tree) || tree;\n }\n return tree;\n }\n\n /**\n * @param {Array} events\n * @param {number} start\n * @param {number} length\n * @returns {number}\n */\n function prepareList(events, start, length) {\n let index = start - 1;\n let containerBalance = -1;\n let listSpread = false;\n /** @type {Token | undefined} */\n let listItem;\n /** @type {number | undefined} */\n let lineIndex;\n /** @type {number | undefined} */\n let firstBlankLineIndex;\n /** @type {boolean | undefined} */\n let atMarker;\n while (++index <= length) {\n const event = events[index];\n switch (event[1].type) {\n case \"listUnordered\":\n case \"listOrdered\":\n case \"blockQuote\":\n {\n if (event[0] === 'enter') {\n containerBalance++;\n } else {\n containerBalance--;\n }\n atMarker = undefined;\n break;\n }\n case \"lineEndingBlank\":\n {\n if (event[0] === 'enter') {\n if (listItem && !atMarker && !containerBalance && !firstBlankLineIndex) {\n firstBlankLineIndex = index;\n }\n atMarker = undefined;\n }\n break;\n }\n case \"linePrefix\":\n case \"listItemValue\":\n case \"listItemMarker\":\n case \"listItemPrefix\":\n case \"listItemPrefixWhitespace\":\n {\n // Empty.\n\n break;\n }\n default:\n {\n atMarker = undefined;\n }\n }\n if (!containerBalance && event[0] === 'enter' && event[1].type === \"listItemPrefix\" || containerBalance === -1 && event[0] === 'exit' && (event[1].type === \"listUnordered\" || event[1].type === \"listOrdered\")) {\n if (listItem) {\n let tailIndex = index;\n lineIndex = undefined;\n while (tailIndex--) {\n const tailEvent = events[tailIndex];\n if (tailEvent[1].type === \"lineEnding\" || tailEvent[1].type === \"lineEndingBlank\") {\n if (tailEvent[0] === 'exit') continue;\n if (lineIndex) {\n events[lineIndex][1].type = \"lineEndingBlank\";\n listSpread = true;\n }\n tailEvent[1].type = \"lineEnding\";\n lineIndex = tailIndex;\n } else if (tailEvent[1].type === \"linePrefix\" || tailEvent[1].type === \"blockQuotePrefix\" || tailEvent[1].type === \"blockQuotePrefixWhitespace\" || tailEvent[1].type === \"blockQuoteMarker\" || tailEvent[1].type === \"listItemIndent\") {\n // Empty\n } else {\n break;\n }\n }\n if (firstBlankLineIndex && (!lineIndex || firstBlankLineIndex < lineIndex)) {\n listItem._spread = true;\n }\n\n // Fix position.\n listItem.end = Object.assign({}, lineIndex ? events[lineIndex][1].start : event[1].end);\n events.splice(lineIndex || index, 0, ['exit', listItem, event[2]]);\n index++;\n length++;\n }\n\n // Create a new list item.\n if (event[1].type === \"listItemPrefix\") {\n /** @type {Token} */\n const item = {\n type: 'listItem',\n _spread: false,\n start: Object.assign({}, event[1].start),\n // @ts-expect-error: we’ll add `end` in a second.\n end: undefined\n };\n listItem = item;\n events.splice(index, 0, ['enter', item, event[2]]);\n index++;\n length++;\n firstBlankLineIndex = undefined;\n atMarker = true;\n }\n }\n }\n events[start][1]._spread = listSpread;\n return length;\n }\n\n /**\n * Create an opener handle.\n *\n * @param {(token: Token) => Nodes} create\n * Create a node.\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function opener(create, and) {\n return open;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function open(token) {\n enter.call(this, create(token), token);\n if (and) and.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['buffer']}\n */\n function buffer() {\n this.stack.push({\n type: 'fragment',\n children: []\n });\n }\n\n /**\n * @type {CompileContext['enter']}\n */\n function enter(node, token, errorHandler) {\n const parent = this.stack[this.stack.length - 1];\n /** @type {Array} */\n const siblings = parent.children;\n siblings.push(node);\n this.stack.push(node);\n this.tokenStack.push([token, errorHandler || undefined]);\n node.position = {\n start: point(token.start),\n // @ts-expect-error: `end` will be patched later.\n end: undefined\n };\n }\n\n /**\n * Create a closer handle.\n *\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function closer(and) {\n return close;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function close(token) {\n if (and) and.call(this, token);\n exit.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['exit']}\n */\n function exit(token, onExitError) {\n const node = this.stack.pop();\n const open = this.tokenStack.pop();\n if (!open) {\n throw new Error('Cannot close `' + token.type + '` (' + stringifyPosition({\n start: token.start,\n end: token.end\n }) + '): it’s not open');\n } else if (open[0].type !== token.type) {\n if (onExitError) {\n onExitError.call(this, token, open[0]);\n } else {\n const handler = open[1] || defaultOnError;\n handler.call(this, token, open[0]);\n }\n }\n node.position.end = point(token.end);\n }\n\n /**\n * @type {CompileContext['resume']}\n */\n function resume() {\n return toString(this.stack.pop());\n }\n\n //\n // Handlers.\n //\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistordered() {\n this.data.expectingFirstListItemValue = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistitemvalue(token) {\n if (this.data.expectingFirstListItemValue) {\n const ancestor = this.stack[this.stack.length - 2];\n ancestor.start = Number.parseInt(this.sliceSerialize(token), 10);\n this.data.expectingFirstListItemValue = undefined;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfenceinfo() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.lang = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfencemeta() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.meta = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfence() {\n // Exit if this is the closing fence.\n if (this.data.flowCodeInside) return;\n this.buffer();\n this.data.flowCodeInside = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefenced() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, '');\n this.data.flowCodeInside = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodeindented() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/(\\r?\\n|\\r)$/g, '');\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitionlabelstring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.label = label;\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiontitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiondestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitatxheadingsequence(token) {\n const node = this.stack[this.stack.length - 1];\n if (!node.depth) {\n const depth = this.sliceSerialize(token).length;\n node.depth = depth;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadingtext() {\n this.data.setextHeadingSlurpLineEnding = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadinglinesequence(token) {\n const node = this.stack[this.stack.length - 1];\n node.depth = this.sliceSerialize(token).codePointAt(0) === 61 ? 1 : 2;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheading() {\n this.data.setextHeadingSlurpLineEnding = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterdata(token) {\n const node = this.stack[this.stack.length - 1];\n /** @type {Array} */\n const siblings = node.children;\n let tail = siblings[siblings.length - 1];\n if (!tail || tail.type !== 'text') {\n // Add a new text node.\n tail = text();\n tail.position = {\n start: point(token.start),\n // @ts-expect-error: we’ll add `end` later.\n end: undefined\n };\n siblings.push(tail);\n }\n this.stack.push(tail);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitdata(token) {\n const tail = this.stack.pop();\n tail.value += this.sliceSerialize(token);\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlineending(token) {\n const context = this.stack[this.stack.length - 1];\n // If we’re at a hard break, include the line ending in there.\n if (this.data.atHardBreak) {\n const tail = context.children[context.children.length - 1];\n tail.position.end = point(token.end);\n this.data.atHardBreak = undefined;\n return;\n }\n if (!this.data.setextHeadingSlurpLineEnding && config.canContainEols.includes(context.type)) {\n onenterdata.call(this, token);\n onexitdata.call(this, token);\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithardbreak() {\n this.data.atHardBreak = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmlflow() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmltext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcodetext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlink() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitimage() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabeltext(token) {\n const string = this.sliceSerialize(token);\n const ancestor = this.stack[this.stack.length - 2];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n ancestor.label = decodeString(string);\n // @ts-expect-error: same as above.\n ancestor.identifier = normalizeIdentifier(string).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabel() {\n const fragment = this.stack[this.stack.length - 1];\n const value = this.resume();\n const node = this.stack[this.stack.length - 1];\n // Assume a reference.\n this.data.inReference = true;\n if (node.type === 'link') {\n /** @type {Array} */\n const children = fragment.children;\n node.children = children;\n } else {\n node.alt = value;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcedestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcetitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresource() {\n this.data.inReference = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterreference() {\n this.data.referenceType = 'collapsed';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitreferencestring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n node.label = label;\n // @ts-expect-error: same as above.\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n this.data.referenceType = 'full';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcharacterreferencemarker(token) {\n this.data.characterReferenceType = token.type;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreferencevalue(token) {\n const data = this.sliceSerialize(token);\n const type = this.data.characterReferenceType;\n /** @type {string} */\n let value;\n if (type) {\n value = decodeNumericCharacterReference(data, type === \"characterReferenceMarkerNumeric\" ? 10 : 16);\n this.data.characterReferenceType = undefined;\n } else {\n const result = decodeNamedCharacterReference(data);\n value = result;\n }\n const tail = this.stack[this.stack.length - 1];\n tail.value += value;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreference(token) {\n const tail = this.stack.pop();\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkprotocol(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = this.sliceSerialize(token);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkemail(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = 'mailto:' + this.sliceSerialize(token);\n }\n\n //\n // Creaters.\n //\n\n /** @returns {Blockquote} */\n function blockQuote() {\n return {\n type: 'blockquote',\n children: []\n };\n }\n\n /** @returns {Code} */\n function codeFlow() {\n return {\n type: 'code',\n lang: null,\n meta: null,\n value: ''\n };\n }\n\n /** @returns {InlineCode} */\n function codeText() {\n return {\n type: 'inlineCode',\n value: ''\n };\n }\n\n /** @returns {Definition} */\n function definition() {\n return {\n type: 'definition',\n identifier: '',\n label: null,\n title: null,\n url: ''\n };\n }\n\n /** @returns {Emphasis} */\n function emphasis() {\n return {\n type: 'emphasis',\n children: []\n };\n }\n\n /** @returns {Heading} */\n function heading() {\n return {\n type: 'heading',\n // @ts-expect-error `depth` will be set later.\n depth: 0,\n children: []\n };\n }\n\n /** @returns {Break} */\n function hardBreak() {\n return {\n type: 'break'\n };\n }\n\n /** @returns {Html} */\n function html() {\n return {\n type: 'html',\n value: ''\n };\n }\n\n /** @returns {Image} */\n function image() {\n return {\n type: 'image',\n title: null,\n url: '',\n alt: null\n };\n }\n\n /** @returns {Link} */\n function link() {\n return {\n type: 'link',\n title: null,\n url: '',\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {List}\n */\n function list(token) {\n return {\n type: 'list',\n ordered: token.type === 'listOrdered',\n start: null,\n spread: token._spread,\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {ListItem}\n */\n function listItem(token) {\n return {\n type: 'listItem',\n spread: token._spread,\n checked: null,\n children: []\n };\n }\n\n /** @returns {Paragraph} */\n function paragraph() {\n return {\n type: 'paragraph',\n children: []\n };\n }\n\n /** @returns {Strong} */\n function strong() {\n return {\n type: 'strong',\n children: []\n };\n }\n\n /** @returns {Text} */\n function text() {\n return {\n type: 'text',\n value: ''\n };\n }\n\n /** @returns {ThematicBreak} */\n function thematicBreak() {\n return {\n type: 'thematicBreak'\n };\n }\n}\n\n/**\n * Copy a point-like value.\n *\n * @param {Point} d\n * Point-like value.\n * @returns {Point}\n * unist point.\n */\nfunction point(d) {\n return {\n line: d.line,\n column: d.column,\n offset: d.offset\n };\n}\n\n/**\n * @param {Config} combined\n * @param {Array | Extension>} extensions\n * @returns {undefined}\n */\nfunction configure(combined, extensions) {\n let index = -1;\n while (++index < extensions.length) {\n const value = extensions[index];\n if (Array.isArray(value)) {\n configure(combined, value);\n } else {\n extension(combined, value);\n }\n }\n}\n\n/**\n * @param {Config} combined\n * @param {Extension} extension\n * @returns {undefined}\n */\nfunction extension(combined, extension) {\n /** @type {keyof Extension} */\n let key;\n for (key in extension) {\n if (own.call(extension, key)) {\n switch (key) {\n case 'canContainEols':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'transforms':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'enter':\n case 'exit':\n {\n const right = extension[key];\n if (right) {\n Object.assign(combined[key], right);\n }\n break;\n }\n // No default\n }\n }\n }\n}\n\n/** @type {OnEnterError} */\nfunction defaultOnError(left, right) {\n if (left) {\n throw new Error('Cannot close `' + left.type + '` (' + stringifyPosition({\n start: left.start,\n end: left.end\n }) + '): a different token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is open');\n } else {\n throw new Error('Cannot close document, a token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is still open');\n }\n}","/**\n * @typedef {import('mdast').Root} Root\n * @typedef {import('mdast-util-from-markdown').Options} FromMarkdownOptions\n * @typedef {import('unified').Parser} Parser\n * @typedef {import('unified').Processor} Processor\n */\n\n/**\n * @typedef {Omit} Options\n */\n\nimport {fromMarkdown} from 'mdast-util-from-markdown'\n\n/**\n * Aadd support for parsing from markdown.\n *\n * @param {Readonly | null | undefined} [options]\n * Configuration (optional).\n * @returns {undefined}\n * Nothing.\n */\nexport default function remarkParse(options) {\n /** @type {Processor} */\n // @ts-expect-error: TS in JSDoc generates wrong types if `this` is typed regularly.\n const self = this\n\n self.parser = parser\n\n /**\n * @type {Parser}\n */\n function parser(doc) {\n return fromMarkdown(doc, {\n ...self.data('settings'),\n ...options,\n // Note: these options are not in the readme.\n // The goal is for them to be set by plugins on `data` instead of being\n // passed by users.\n extensions: self.data('micromarkExtensions') || [],\n mdastExtensions: self.data('fromMarkdownExtensions') || []\n })\n }\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Blockquote} Blockquote\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `blockquote` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Blockquote} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function blockquote(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'blockquote',\n properties: {},\n children: state.wrap(state.all(node), true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Text} Text\n * @typedef {import('mdast').Break} Break\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `break` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Break} node\n * mdast node.\n * @returns {Array}\n * hast element content.\n */\nexport function hardBreak(state, node) {\n /** @type {Element} */\n const result = {type: 'element', tagName: 'br', properties: {}, children: []}\n state.patch(node, result)\n return [state.applyData(node, result), {type: 'text', value: '\\n'}]\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Code} Code\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `code` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Code} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function code(state, node) {\n const value = node.value ? node.value + '\\n' : ''\n /** @type {Properties} */\n const properties = {}\n\n if (node.lang) {\n properties.className = ['language-' + node.lang]\n }\n\n // Create ``.\n /** @type {Element} */\n let result = {\n type: 'element',\n tagName: 'code',\n properties,\n children: [{type: 'text', value}]\n }\n\n if (node.meta) {\n result.data = {meta: node.meta}\n }\n\n state.patch(node, result)\n result = state.applyData(node, result)\n\n // Create `
`.\n  result = {type: 'element', tagName: 'pre', properties: {}, children: [result]}\n  state.patch(node, result)\n  return result\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Delete} Delete\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `delete` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Delete} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function strikethrough(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'del',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Emphasis} Emphasis\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `emphasis` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Emphasis} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function emphasis(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'em',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').FootnoteReference} FootnoteReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `footnoteReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {FootnoteReference} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function footnoteReference(state, node) {\n  const clobberPrefix =\n    typeof state.options.clobberPrefix === 'string'\n      ? state.options.clobberPrefix\n      : 'user-content-'\n  const id = String(node.identifier).toUpperCase()\n  const safeId = normalizeUri(id.toLowerCase())\n  const index = state.footnoteOrder.indexOf(id)\n  /** @type {number} */\n  let counter\n\n  let reuseCounter = state.footnoteCounts.get(id)\n\n  if (reuseCounter === undefined) {\n    reuseCounter = 0\n    state.footnoteOrder.push(id)\n    counter = state.footnoteOrder.length\n  } else {\n    counter = index + 1\n  }\n\n  reuseCounter += 1\n  state.footnoteCounts.set(id, reuseCounter)\n\n  /** @type {Element} */\n  const link = {\n    type: 'element',\n    tagName: 'a',\n    properties: {\n      href: '#' + clobberPrefix + 'fn-' + safeId,\n      id:\n        clobberPrefix +\n        'fnref-' +\n        safeId +\n        (reuseCounter > 1 ? '-' + reuseCounter : ''),\n      dataFootnoteRef: true,\n      ariaDescribedBy: ['footnote-label']\n    },\n    children: [{type: 'text', value: String(counter)}]\n  }\n  state.patch(node, link)\n\n  /** @type {Element} */\n  const sup = {\n    type: 'element',\n    tagName: 'sup',\n    properties: {},\n    children: [link]\n  }\n  state.patch(node, sup)\n  return state.applyData(node, sup)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Heading} Heading\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `heading` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Heading} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function heading(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'h' + node.depth,\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Html} Html\n * @typedef {import('../state.js').State} State\n * @typedef {import('../../index.js').Raw} Raw\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `html` node into hast (`raw` node in dangerous mode, otherwise\n * nothing).\n *\n * @param {State} state\n *   Info passed around.\n * @param {Html} node\n *   mdast node.\n * @returns {Element | Raw | undefined}\n *   hast node.\n */\nexport function html(state, node) {\n  if (state.options.allowDangerousHtml) {\n    /** @type {Raw} */\n    const result = {type: 'raw', value: node.value}\n    state.patch(node, result)\n    return state.applyData(node, result)\n  }\n\n  return undefined\n}\n","/**\n * @typedef {import('hast').ElementContent} ElementContent\n *\n * @typedef {import('mdast').Nodes} Nodes\n * @typedef {import('mdast').Reference} Reference\n *\n * @typedef {import('./state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Return the content of a reference without definition as plain text.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Extract} node\n *   Reference node (image, link).\n * @returns {Array}\n *   hast content.\n */\nexport function revert(state, node) {\n  const subtype = node.referenceType\n  let suffix = ']'\n\n  if (subtype === 'collapsed') {\n    suffix += '[]'\n  } else if (subtype === 'full') {\n    suffix += '[' + (node.label || node.identifier) + ']'\n  }\n\n  if (node.type === 'imageReference') {\n    return [{type: 'text', value: '![' + node.alt + suffix}]\n  }\n\n  const contents = state.all(node)\n  const head = contents[0]\n\n  if (head && head.type === 'text') {\n    head.value = '[' + head.value\n  } else {\n    contents.unshift({type: 'text', value: '['})\n  }\n\n  const tail = contents[contents.length - 1]\n\n  if (tail && tail.type === 'text') {\n    tail.value += suffix\n  } else {\n    contents.push({type: 'text', value: suffix})\n  }\n\n  return contents\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').ImageReference} ImageReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `imageReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ImageReference} node\n *   mdast node.\n * @returns {Array | ElementContent}\n *   hast node.\n */\nexport function imageReference(state, node) {\n  const id = String(node.identifier).toUpperCase()\n  const definition = state.definitionById.get(id)\n\n  if (!definition) {\n    return revert(state, node)\n  }\n\n  /** @type {Properties} */\n  const properties = {src: normalizeUri(definition.url || ''), alt: node.alt}\n\n  if (definition.title !== null && definition.title !== undefined) {\n    properties.title = definition.title\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'img', properties, children: []}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Image} Image\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `image` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Image} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function image(state, node) {\n  /** @type {Properties} */\n  const properties = {src: normalizeUri(node.url)}\n\n  if (node.alt !== null && node.alt !== undefined) {\n    properties.alt = node.alt\n  }\n\n  if (node.title !== null && node.title !== undefined) {\n    properties.title = node.title\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'img', properties, children: []}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Text} Text\n * @typedef {import('mdast').InlineCode} InlineCode\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `inlineCode` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {InlineCode} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function inlineCode(state, node) {\n  /** @type {Text} */\n  const text = {type: 'text', value: node.value.replace(/\\r?\\n|\\r/g, ' ')}\n  state.patch(node, text)\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'code',\n    properties: {},\n    children: [text]\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').LinkReference} LinkReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `linkReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {LinkReference} node\n *   mdast node.\n * @returns {Array | ElementContent}\n *   hast node.\n */\nexport function linkReference(state, node) {\n  const id = String(node.identifier).toUpperCase()\n  const definition = state.definitionById.get(id)\n\n  if (!definition) {\n    return revert(state, node)\n  }\n\n  /** @type {Properties} */\n  const properties = {href: normalizeUri(definition.url || '')}\n\n  if (definition.title !== null && definition.title !== undefined) {\n    properties.title = definition.title\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'a',\n    properties,\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Link} Link\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `link` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Link} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function link(state, node) {\n  /** @type {Properties} */\n  const properties = {href: normalizeUri(node.url)}\n\n  if (node.title !== null && node.title !== undefined) {\n    properties.title = node.title\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'a',\n    properties,\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').ListItem} ListItem\n * @typedef {import('mdast').Parents} Parents\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `listItem` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ListItem} node\n *   mdast node.\n * @param {Parents | undefined} parent\n *   Parent of `node`.\n * @returns {Element}\n *   hast node.\n */\nexport function listItem(state, node, parent) {\n  const results = state.all(node)\n  const loose = parent ? listLoose(parent) : listItemLoose(node)\n  /** @type {Properties} */\n  const properties = {}\n  /** @type {Array} */\n  const children = []\n\n  if (typeof node.checked === 'boolean') {\n    const head = results[0]\n    /** @type {Element} */\n    let paragraph\n\n    if (head && head.type === 'element' && head.tagName === 'p') {\n      paragraph = head\n    } else {\n      paragraph = {type: 'element', tagName: 'p', properties: {}, children: []}\n      results.unshift(paragraph)\n    }\n\n    if (paragraph.children.length > 0) {\n      paragraph.children.unshift({type: 'text', value: ' '})\n    }\n\n    paragraph.children.unshift({\n      type: 'element',\n      tagName: 'input',\n      properties: {type: 'checkbox', checked: node.checked, disabled: true},\n      children: []\n    })\n\n    // According to github-markdown-css, this class hides bullet.\n    // See: .\n    properties.className = ['task-list-item']\n  }\n\n  let index = -1\n\n  while (++index < results.length) {\n    const child = results[index]\n\n    // Add eols before nodes, except if this is a loose, first paragraph.\n    if (\n      loose ||\n      index !== 0 ||\n      child.type !== 'element' ||\n      child.tagName !== 'p'\n    ) {\n      children.push({type: 'text', value: '\\n'})\n    }\n\n    if (child.type === 'element' && child.tagName === 'p' && !loose) {\n      children.push(...child.children)\n    } else {\n      children.push(child)\n    }\n  }\n\n  const tail = results[results.length - 1]\n\n  // Add a final eol.\n  if (tail && (loose || tail.type !== 'element' || tail.tagName !== 'p')) {\n    children.push({type: 'text', value: '\\n'})\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'li', properties, children}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n\n/**\n * @param {Parents} node\n * @return {Boolean}\n */\nfunction listLoose(node) {\n  let loose = false\n  if (node.type === 'list') {\n    loose = node.spread || false\n    const children = node.children\n    let index = -1\n\n    while (!loose && ++index < children.length) {\n      loose = listItemLoose(children[index])\n    }\n  }\n\n  return loose\n}\n\n/**\n * @param {ListItem} node\n * @return {Boolean}\n */\nfunction listItemLoose(node) {\n  const spread = node.spread\n\n  return spread === null || spread === undefined\n    ? node.children.length > 1\n    : spread\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').List} List\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `list` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {List} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function list(state, node) {\n  /** @type {Properties} */\n  const properties = {}\n  const results = state.all(node)\n  let index = -1\n\n  if (typeof node.start === 'number' && node.start !== 1) {\n    properties.start = node.start\n  }\n\n  // Like GitHub, add a class for custom styling.\n  while (++index < results.length) {\n    const child = results[index]\n\n    if (\n      child.type === 'element' &&\n      child.tagName === 'li' &&\n      child.properties &&\n      Array.isArray(child.properties.className) &&\n      child.properties.className.includes('task-list-item')\n    ) {\n      properties.className = ['contains-task-list']\n      break\n    }\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: node.ordered ? 'ol' : 'ul',\n    properties,\n    children: state.wrap(results, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Paragraph} Paragraph\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `paragraph` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Paragraph} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function paragraph(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'p',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Parents} HastParents\n * @typedef {import('hast').Root} HastRoot\n * @typedef {import('mdast').Root} MdastRoot\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `root` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {MdastRoot} node\n *   mdast node.\n * @returns {HastParents}\n *   hast node.\n */\nexport function root(state, node) {\n  /** @type {HastRoot} */\n  const result = {type: 'root', children: state.wrap(state.all(node))}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Strong} Strong\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `strong` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Strong} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function strong(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'strong',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Table} Table\n * @typedef {import('../state.js').State} State\n */\n\nimport {pointEnd, pointStart} from 'unist-util-position'\n\n/**\n * Turn an mdast `table` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Table} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function table(state, node) {\n  const rows = state.all(node)\n  const firstRow = rows.shift()\n  /** @type {Array} */\n  const tableContent = []\n\n  if (firstRow) {\n    /** @type {Element} */\n    const head = {\n      type: 'element',\n      tagName: 'thead',\n      properties: {},\n      children: state.wrap([firstRow], true)\n    }\n    state.patch(node.children[0], head)\n    tableContent.push(head)\n  }\n\n  if (rows.length > 0) {\n    /** @type {Element} */\n    const body = {\n      type: 'element',\n      tagName: 'tbody',\n      properties: {},\n      children: state.wrap(rows, true)\n    }\n\n    const start = pointStart(node.children[1])\n    const end = pointEnd(node.children[node.children.length - 1])\n    if (start && end) body.position = {start, end}\n    tableContent.push(body)\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'table',\n    properties: {},\n    children: state.wrap(tableContent, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Parents} Parents\n * @typedef {import('mdast').TableRow} TableRow\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `tableRow` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {TableRow} node\n *   mdast node.\n * @param {Parents | undefined} parent\n *   Parent of `node`.\n * @returns {Element}\n *   hast node.\n */\nexport function tableRow(state, node, parent) {\n  const siblings = parent ? parent.children : undefined\n  // Generate a body row when without parent.\n  const rowIndex = siblings ? siblings.indexOf(node) : 1\n  const tagName = rowIndex === 0 ? 'th' : 'td'\n  // To do: option to use `style`?\n  const align = parent && parent.type === 'table' ? parent.align : undefined\n  const length = align ? align.length : node.children.length\n  let cellIndex = -1\n  /** @type {Array} */\n  const cells = []\n\n  while (++cellIndex < length) {\n    // Note: can also be undefined.\n    const cell = node.children[cellIndex]\n    /** @type {Properties} */\n    const properties = {}\n    const alignValue = align ? align[cellIndex] : undefined\n\n    if (alignValue) {\n      properties.align = alignValue\n    }\n\n    /** @type {Element} */\n    let result = {type: 'element', tagName, properties, children: []}\n\n    if (cell) {\n      result.children = state.all(cell)\n      state.patch(cell, result)\n      result = state.applyData(cell, result)\n    }\n\n    cells.push(result)\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'tr',\n    properties: {},\n    children: state.wrap(cells, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').TableCell} TableCell\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `tableCell` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {TableCell} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function tableCell(state, node) {\n  // Note: this function is normally not called: see `table-row` for how rows\n  // and their cells are compiled.\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'td', // Assume body cell.\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","const tab = 9 /* `\\t` */\nconst space = 32 /* ` ` */\n\n/**\n * Remove initial and final spaces and tabs at the line breaks in `value`.\n * Does not trim initial and final spaces and tabs of the value itself.\n *\n * @param {string} value\n *   Value to trim.\n * @returns {string}\n *   Trimmed value.\n */\nexport function trimLines(value) {\n  const source = String(value)\n  const search = /\\r?\\n|\\r/g\n  let match = search.exec(source)\n  let last = 0\n  /** @type {Array} */\n  const lines = []\n\n  while (match) {\n    lines.push(\n      trimLine(source.slice(last, match.index), last > 0, true),\n      match[0]\n    )\n\n    last = match.index + match[0].length\n    match = search.exec(source)\n  }\n\n  lines.push(trimLine(source.slice(last), last > 0, false))\n\n  return lines.join('')\n}\n\n/**\n * @param {string} value\n *   Line to trim.\n * @param {boolean} start\n *   Whether to trim the start of the line.\n * @param {boolean} end\n *   Whether to trim the end of the line.\n * @returns {string}\n *   Trimmed line.\n */\nfunction trimLine(value, start, end) {\n  let startIndex = 0\n  let endIndex = value.length\n\n  if (start) {\n    let code = value.codePointAt(startIndex)\n\n    while (code === tab || code === space) {\n      startIndex++\n      code = value.codePointAt(startIndex)\n    }\n  }\n\n  if (end) {\n    let code = value.codePointAt(endIndex - 1)\n\n    while (code === tab || code === space) {\n      endIndex--\n      code = value.codePointAt(endIndex - 1)\n    }\n  }\n\n  return endIndex > startIndex ? value.slice(startIndex, endIndex) : ''\n}\n","/**\n * @typedef {import('hast').Element} HastElement\n * @typedef {import('hast').Text} HastText\n * @typedef {import('mdast').Text} MdastText\n * @typedef {import('../state.js').State} State\n */\n\nimport {trimLines} from 'trim-lines'\n\n/**\n * Turn an mdast `text` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {MdastText} node\n *   mdast node.\n * @returns {HastElement | HastText}\n *   hast node.\n */\nexport function text(state, node) {\n  /** @type {HastText} */\n  const result = {type: 'text', value: trimLines(String(node.value))}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').ThematicBreak} ThematicBreak\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `thematicBreak` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ThematicBreak} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function thematicBreak(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'hr',\n    properties: {},\n    children: []\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","import {blockquote} from './blockquote.js'\nimport {hardBreak} from './break.js'\nimport {code} from './code.js'\nimport {strikethrough} from './delete.js'\nimport {emphasis} from './emphasis.js'\nimport {footnoteReference} from './footnote-reference.js'\nimport {heading} from './heading.js'\nimport {html} from './html.js'\nimport {imageReference} from './image-reference.js'\nimport {image} from './image.js'\nimport {inlineCode} from './inline-code.js'\nimport {linkReference} from './link-reference.js'\nimport {link} from './link.js'\nimport {listItem} from './list-item.js'\nimport {list} from './list.js'\nimport {paragraph} from './paragraph.js'\nimport {root} from './root.js'\nimport {strong} from './strong.js'\nimport {table} from './table.js'\nimport {tableRow} from './table-row.js'\nimport {tableCell} from './table-cell.js'\nimport {text} from './text.js'\nimport {thematicBreak} from './thematic-break.js'\n\n/**\n * Default handlers for nodes.\n *\n * @satisfies {import('../state.js').Handlers}\n */\nexport const handlers = {\n  blockquote,\n  break: hardBreak,\n  code,\n  delete: strikethrough,\n  emphasis,\n  footnoteReference,\n  heading,\n  html,\n  imageReference,\n  image,\n  inlineCode,\n  linkReference,\n  link,\n  listItem,\n  list,\n  paragraph,\n  // @ts-expect-error: root is different, but hard to type.\n  root,\n  strong,\n  table,\n  tableCell,\n  tableRow,\n  text,\n  thematicBreak,\n  toml: ignore,\n  yaml: ignore,\n  definition: ignore,\n  footnoteDefinition: ignore\n}\n\n// Return nothing for nodes that are ignored.\nfunction ignore() {\n  return undefined\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n *\n * @typedef {import('./state.js').State} State\n */\n\n/**\n * @callback FootnoteBackContentTemplate\n *   Generate content for the backreference dynamically.\n *\n *   For the following markdown:\n *\n *   ```markdown\n *   Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n *   [^remark]: things about remark\n *   [^micromark]: things about micromark\n *   ```\n *\n *   This function will be called with:\n *\n *   *  `0` and `0` for the backreference from `things about micromark` to\n *      `alpha`, as it is the first used definition, and the first call to it\n *   *  `0` and `1` for the backreference from `things about micromark` to\n *      `bravo`, as it is the first used definition, and the second call to it\n *   *  `1` and `0` for the backreference from `things about remark` to\n *      `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {Array | ElementContent | string}\n *   Content for the backreference when linking back from definitions to their\n *   reference.\n *\n * @callback FootnoteBackLabelTemplate\n *   Generate a back label dynamically.\n *\n *   For the following markdown:\n *\n *   ```markdown\n *   Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n *   [^remark]: things about remark\n *   [^micromark]: things about micromark\n *   ```\n *\n *   This function will be called with:\n *\n *   *  `0` and `0` for the backreference from `things about micromark` to\n *      `alpha`, as it is the first used definition, and the first call to it\n *   *  `0` and `1` for the backreference from `things about micromark` to\n *      `bravo`, as it is the first used definition, and the second call to it\n *   *  `1` and `0` for the backreference from `things about remark` to\n *      `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {string}\n *   Back label to use when linking back from definitions to their reference.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Generate the default content that GitHub uses on backreferences.\n *\n * @param {number} _\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {Array}\n *   Content.\n */\nexport function defaultFootnoteBackContent(_, rereferenceIndex) {\n  /** @type {Array} */\n  const result = [{type: 'text', value: '↩'}]\n\n  if (rereferenceIndex > 1) {\n    result.push({\n      type: 'element',\n      tagName: 'sup',\n      properties: {},\n      children: [{type: 'text', value: String(rereferenceIndex)}]\n    })\n  }\n\n  return result\n}\n\n/**\n * Generate the default label that GitHub uses on backreferences.\n *\n * @param {number} referenceIndex\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {string}\n *   Label.\n */\nexport function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n  return (\n    'Back to reference ' +\n    (referenceIndex + 1) +\n    (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n  )\n}\n\n/**\n * Generate a hast footer for called footnote definitions.\n *\n * @param {State} state\n *   Info passed around.\n * @returns {Element | undefined}\n *   `section` element or `undefined`.\n */\n// eslint-disable-next-line complexity\nexport function footer(state) {\n  const clobberPrefix =\n    typeof state.options.clobberPrefix === 'string'\n      ? state.options.clobberPrefix\n      : 'user-content-'\n  const footnoteBackContent =\n    state.options.footnoteBackContent || defaultFootnoteBackContent\n  const footnoteBackLabel =\n    state.options.footnoteBackLabel || defaultFootnoteBackLabel\n  const footnoteLabel = state.options.footnoteLabel || 'Footnotes'\n  const footnoteLabelTagName = state.options.footnoteLabelTagName || 'h2'\n  const footnoteLabelProperties = state.options.footnoteLabelProperties || {\n    className: ['sr-only']\n  }\n  /** @type {Array} */\n  const listItems = []\n  let referenceIndex = -1\n\n  while (++referenceIndex < state.footnoteOrder.length) {\n    const definition = state.footnoteById.get(\n      state.footnoteOrder[referenceIndex]\n    )\n\n    if (!definition) {\n      continue\n    }\n\n    const content = state.all(definition)\n    const id = String(definition.identifier).toUpperCase()\n    const safeId = normalizeUri(id.toLowerCase())\n    let rereferenceIndex = 0\n    /** @type {Array} */\n    const backReferences = []\n    const counts = state.footnoteCounts.get(id)\n\n    // eslint-disable-next-line no-unmodified-loop-condition\n    while (counts !== undefined && ++rereferenceIndex <= counts) {\n      if (backReferences.length > 0) {\n        backReferences.push({type: 'text', value: ' '})\n      }\n\n      let children =\n        typeof footnoteBackContent === 'string'\n          ? footnoteBackContent\n          : footnoteBackContent(referenceIndex, rereferenceIndex)\n\n      if (typeof children === 'string') {\n        children = {type: 'text', value: children}\n      }\n\n      backReferences.push({\n        type: 'element',\n        tagName: 'a',\n        properties: {\n          href:\n            '#' +\n            clobberPrefix +\n            'fnref-' +\n            safeId +\n            (rereferenceIndex > 1 ? '-' + rereferenceIndex : ''),\n          dataFootnoteBackref: '',\n          ariaLabel:\n            typeof footnoteBackLabel === 'string'\n              ? footnoteBackLabel\n              : footnoteBackLabel(referenceIndex, rereferenceIndex),\n          className: ['data-footnote-backref']\n        },\n        children: Array.isArray(children) ? children : [children]\n      })\n    }\n\n    const tail = content[content.length - 1]\n\n    if (tail && tail.type === 'element' && tail.tagName === 'p') {\n      const tailTail = tail.children[tail.children.length - 1]\n      if (tailTail && tailTail.type === 'text') {\n        tailTail.value += ' '\n      } else {\n        tail.children.push({type: 'text', value: ' '})\n      }\n\n      tail.children.push(...backReferences)\n    } else {\n      content.push(...backReferences)\n    }\n\n    /** @type {Element} */\n    const listItem = {\n      type: 'element',\n      tagName: 'li',\n      properties: {id: clobberPrefix + 'fn-' + safeId},\n      children: state.wrap(content, true)\n    }\n\n    state.patch(definition, listItem)\n\n    listItems.push(listItem)\n  }\n\n  if (listItems.length === 0) {\n    return\n  }\n\n  return {\n    type: 'element',\n    tagName: 'section',\n    properties: {dataFootnotes: true, className: ['footnotes']},\n    children: [\n      {\n        type: 'element',\n        tagName: footnoteLabelTagName,\n        properties: {\n          ...structuredClone(footnoteLabelProperties),\n          id: 'footnote-label'\n        },\n        children: [{type: 'text', value: footnoteLabel}]\n      },\n      {type: 'text', value: '\\n'},\n      {\n        type: 'element',\n        tagName: 'ol',\n        properties: {},\n        children: state.wrap(listItems, true)\n      },\n      {type: 'text', value: '\\n'}\n    ]\n  }\n}\n","/**\n * @typedef {import('hast').Element} HastElement\n * @typedef {import('hast').ElementContent} HastElementContent\n * @typedef {import('hast').Nodes} HastNodes\n * @typedef {import('hast').Properties} HastProperties\n * @typedef {import('hast').RootContent} HastRootContent\n * @typedef {import('hast').Text} HastText\n *\n * @typedef {import('mdast').Definition} MdastDefinition\n * @typedef {import('mdast').FootnoteDefinition} MdastFootnoteDefinition\n * @typedef {import('mdast').Nodes} MdastNodes\n * @typedef {import('mdast').Parents} MdastParents\n *\n * @typedef {import('vfile').VFile} VFile\n *\n * @typedef {import('./footer.js').FootnoteBackContentTemplate} FootnoteBackContentTemplate\n * @typedef {import('./footer.js').FootnoteBackLabelTemplate} FootnoteBackLabelTemplate\n */\n\n/**\n * @callback Handler\n *   Handle a node.\n * @param {State} state\n *   Info passed around.\n * @param {any} node\n *   mdast node to handle.\n * @param {MdastParents | undefined} parent\n *   Parent of `node`.\n * @returns {Array | HastElementContent | undefined}\n *   hast node.\n *\n * @typedef {Partial>} Handlers\n *   Handle nodes.\n *\n * @typedef Options\n *   Configuration (optional).\n * @property {boolean | null | undefined} [allowDangerousHtml=false]\n *   Whether to persist raw HTML in markdown in the hast tree (default:\n *   `false`).\n * @property {string | null | undefined} [clobberPrefix='user-content-']\n *   Prefix to use before the `id` property on footnotes to prevent them from\n *   *clobbering* (default: `'user-content-'`).\n *\n *   Pass `''` for trusted markdown and when you are careful with\n *   polyfilling.\n *   You could pass a different prefix.\n *\n *   DOM clobbering is this:\n *\n *   ```html\n *   

\n * \n * ```\n *\n * The above example shows that elements are made available by browsers, by\n * their ID, on the `window` object.\n * This is a security risk because you might be expecting some other variable\n * at that place.\n * It can also break polyfills.\n * Using a prefix solves these problems.\n * @property {VFile | null | undefined} [file]\n * Corresponding virtual file representing the input document (optional).\n * @property {FootnoteBackContentTemplate | string | null | undefined} [footnoteBackContent]\n * Content of the backreference back to references (default: `defaultFootnoteBackContent`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackContent(_, rereferenceIndex) {\n * const result = [{type: 'text', value: '↩'}]\n *\n * if (rereferenceIndex > 1) {\n * result.push({\n * type: 'element',\n * tagName: 'sup',\n * properties: {},\n * children: [{type: 'text', value: String(rereferenceIndex)}]\n * })\n * }\n *\n * return result\n * }\n * ```\n *\n * This content is used in the `a` element of each backreference (the `↩`\n * links).\n * @property {FootnoteBackLabelTemplate | string | null | undefined} [footnoteBackLabel]\n * Label to describe the backreference back to references (default:\n * `defaultFootnoteBackLabel`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n * return (\n * 'Back to reference ' +\n * (referenceIndex + 1) +\n * (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n * )\n * }\n * ```\n *\n * Change it when the markdown is not in English.\n *\n * This label is used in the `ariaLabel` property on each backreference\n * (the `↩` links).\n * It affects users of assistive technology.\n * @property {string | null | undefined} [footnoteLabel='Footnotes']\n * Textual label to use for the footnotes section (default: `'Footnotes'`).\n *\n * Change it when the markdown is not in English.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {HastProperties | null | undefined} [footnoteLabelProperties={className: ['sr-only']}]\n * Properties to use on the footnote label (default: `{className:\n * ['sr-only']}`).\n *\n * Change it to show the label and add other properties.\n *\n * This label is typically hidden visually (assuming an `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass an empty string.\n * You can also add different properties.\n *\n * > **Note**: `id: 'footnote-label'` is always added, because footnote\n * > calls use it with `aria-describedby` to provide an accessible label.\n * @property {string | null | undefined} [footnoteLabelTagName='h2']\n * HTML tag name to use for the footnote label element (default: `'h2'`).\n *\n * Change it to match your document structure.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {Handlers | null | undefined} [handlers]\n * Extra handlers for nodes (optional).\n * @property {Array | null | undefined} [passThrough]\n * List of custom mdast node types to pass through (keep) in hast (note that\n * the node itself is passed, but eventual children are transformed)\n * (optional).\n * @property {Handler | null | undefined} [unknownHandler]\n * Handler for all unknown nodes (optional).\n *\n * @typedef State\n * Info passed around.\n * @property {(node: MdastNodes) => Array} all\n * Transform the children of an mdast parent to hast.\n * @property {(from: MdastNodes, to: Type) => HastElement | Type} applyData\n * Honor the `data` of `from`, and generate an element instead of `node`.\n * @property {Map} definitionById\n * Definitions by their identifier.\n * @property {Map} footnoteById\n * Footnote definitions by their identifier.\n * @property {Map} footnoteCounts\n * Counts for how often the same footnote was called.\n * @property {Array} footnoteOrder\n * Identifiers of order when footnote calls first appear in tree order.\n * @property {Handlers} handlers\n * Applied handlers.\n * @property {(node: MdastNodes, parent: MdastParents | undefined) => Array | HastElementContent | undefined} one\n * Transform an mdast node to hast.\n * @property {Options} options\n * Configuration.\n * @property {(from: MdastNodes, node: HastNodes) => undefined} patch\n * Copy a node’s positional info.\n * @property {(nodes: Array, loose?: boolean | undefined) => Array} wrap\n * Wrap `nodes` with line endings between each node, adds initial/final line endings when `loose`.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {visit} from 'unist-util-visit'\nimport {position} from 'unist-util-position'\nimport {handlers as defaultHandlers} from './handlers/index.js'\n\nconst own = {}.hasOwnProperty\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Create `state` from an mdast tree.\n *\n * @param {MdastNodes} tree\n * mdast node to transform.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {State}\n * `state` function.\n */\nexport function createState(tree, options) {\n const settings = options || emptyOptions\n /** @type {Map} */\n const definitionById = new Map()\n /** @type {Map} */\n const footnoteById = new Map()\n /** @type {Map} */\n const footnoteCounts = new Map()\n /** @type {Handlers} */\n // @ts-expect-error: the root handler returns a root.\n // Hard to type.\n const handlers = {...defaultHandlers, ...settings.handlers}\n\n /** @type {State} */\n const state = {\n all,\n applyData,\n definitionById,\n footnoteById,\n footnoteCounts,\n footnoteOrder: [],\n handlers,\n one,\n options: settings,\n patch,\n wrap\n }\n\n visit(tree, function (node) {\n if (node.type === 'definition' || node.type === 'footnoteDefinition') {\n const map = node.type === 'definition' ? definitionById : footnoteById\n const id = String(node.identifier).toUpperCase()\n\n // Mimick CM behavior of link definitions.\n // See: .\n if (!map.has(id)) {\n // @ts-expect-error: node type matches map.\n map.set(id, node)\n }\n }\n })\n\n return state\n\n /**\n * Transform an mdast node into a hast node.\n *\n * @param {MdastNodes} node\n * mdast node.\n * @param {MdastParents | undefined} [parent]\n * Parent of `node`.\n * @returns {Array | HastElementContent | undefined}\n * Resulting hast node.\n */\n function one(node, parent) {\n const type = node.type\n const handle = state.handlers[type]\n\n if (own.call(state.handlers, type) && handle) {\n return handle(state, node, parent)\n }\n\n if (state.options.passThrough && state.options.passThrough.includes(type)) {\n if ('children' in node) {\n const {children, ...shallow} = node\n const result = structuredClone(shallow)\n // @ts-expect-error: TS doesn’t understand…\n result.children = state.all(node)\n // @ts-expect-error: TS doesn’t understand…\n return result\n }\n\n // @ts-expect-error: it’s custom.\n return structuredClone(node)\n }\n\n const unknown = state.options.unknownHandler || defaultUnknownHandler\n\n return unknown(state, node, parent)\n }\n\n /**\n * Transform the children of an mdast node into hast nodes.\n *\n * @param {MdastNodes} parent\n * mdast node to compile\n * @returns {Array}\n * Resulting hast nodes.\n */\n function all(parent) {\n /** @type {Array} */\n const values = []\n\n if ('children' in parent) {\n const nodes = parent.children\n let index = -1\n while (++index < nodes.length) {\n const result = state.one(nodes[index], parent)\n\n // To do: see if we van clean this? Can we merge texts?\n if (result) {\n if (index && nodes[index - 1].type === 'break') {\n if (!Array.isArray(result) && result.type === 'text') {\n result.value = trimMarkdownSpaceStart(result.value)\n }\n\n if (!Array.isArray(result) && result.type === 'element') {\n const head = result.children[0]\n\n if (head && head.type === 'text') {\n head.value = trimMarkdownSpaceStart(head.value)\n }\n }\n }\n\n if (Array.isArray(result)) {\n values.push(...result)\n } else {\n values.push(result)\n }\n }\n }\n }\n\n return values\n }\n}\n\n/**\n * Copy a node’s positional info.\n *\n * @param {MdastNodes} from\n * mdast node to copy from.\n * @param {HastNodes} to\n * hast node to copy into.\n * @returns {undefined}\n * Nothing.\n */\nfunction patch(from, to) {\n if (from.position) to.position = position(from)\n}\n\n/**\n * Honor the `data` of `from` and maybe generate an element instead of `to`.\n *\n * @template {HastNodes} Type\n * Node type.\n * @param {MdastNodes} from\n * mdast node to use data from.\n * @param {Type} to\n * hast node to change.\n * @returns {HastElement | Type}\n * Nothing.\n */\nfunction applyData(from, to) {\n /** @type {HastElement | Type} */\n let result = to\n\n // Handle `data.hName`, `data.hProperties, `data.hChildren`.\n if (from && from.data) {\n const hName = from.data.hName\n const hChildren = from.data.hChildren\n const hProperties = from.data.hProperties\n\n if (typeof hName === 'string') {\n // Transforming the node resulted in an element with a different name\n // than wanted:\n if (result.type === 'element') {\n result.tagName = hName\n }\n // Transforming the node resulted in a non-element, which happens for\n // raw, text, and root nodes (unless custom handlers are passed).\n // The intent of `hName` is to create an element, but likely also to keep\n // the content around (otherwise: pass `hChildren`).\n else {\n /** @type {Array} */\n // @ts-expect-error: assume no doctypes in `root`.\n const children = 'children' in result ? result.children : [result]\n result = {type: 'element', tagName: hName, properties: {}, children}\n }\n }\n\n if (result.type === 'element' && hProperties) {\n Object.assign(result.properties, structuredClone(hProperties))\n }\n\n if (\n 'children' in result &&\n result.children &&\n hChildren !== null &&\n hChildren !== undefined\n ) {\n result.children = hChildren\n }\n }\n\n return result\n}\n\n/**\n * Transform an unknown node.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdastNodes} node\n * Unknown mdast node.\n * @returns {HastElement | HastText}\n * Resulting hast node.\n */\nfunction defaultUnknownHandler(state, node) {\n const data = node.data || {}\n /** @type {HastElement | HastText} */\n const result =\n 'value' in node &&\n !(own.call(data, 'hProperties') || own.call(data, 'hChildren'))\n ? {type: 'text', value: node.value}\n : {\n type: 'element',\n tagName: 'div',\n properties: {},\n children: state.all(node)\n }\n\n state.patch(node, result)\n return state.applyData(node, result)\n}\n\n/**\n * Wrap `nodes` with line endings between each node.\n *\n * @template {HastRootContent} Type\n * Node type.\n * @param {Array} nodes\n * List of nodes to wrap.\n * @param {boolean | undefined} [loose=false]\n * Whether to add line endings at start and end (default: `false`).\n * @returns {Array}\n * Wrapped nodes.\n */\nexport function wrap(nodes, loose) {\n /** @type {Array} */\n const result = []\n let index = -1\n\n if (loose) {\n result.push({type: 'text', value: '\\n'})\n }\n\n while (++index < nodes.length) {\n if (index) result.push({type: 'text', value: '\\n'})\n result.push(nodes[index])\n }\n\n if (loose && nodes.length > 0) {\n result.push({type: 'text', value: '\\n'})\n }\n\n return result\n}\n\n/**\n * Trim spaces and tabs at the start of `value`.\n *\n * @param {string} value\n * Value to trim.\n * @returns {string}\n * Result.\n */\nfunction trimMarkdownSpaceStart(value) {\n let index = 0\n let code = value.charCodeAt(index)\n\n while (code === 9 || code === 32) {\n index++\n code = value.charCodeAt(index)\n }\n\n return value.slice(index)\n}\n","/**\n * @typedef {import('hast').Nodes} HastNodes\n * @typedef {import('mdast').Nodes} MdastNodes\n * @typedef {import('./state.js').Options} Options\n */\n\nimport {ok as assert} from 'devlop'\nimport {footer} from './footer.js'\nimport {createState} from './state.js'\n\n/**\n * Transform mdast to hast.\n *\n * ##### Notes\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most utilities ignore `raw` nodes but two notable ones don’t:\n *\n * * `hast-util-to-html` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful\n * if you completely trust authors\n * * `hast-util-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc).\n * This is a heavy task as it needs a full HTML parser, but it is the only\n * way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark, which we follow by default.\n * They are supported by GitHub, so footnotes can be enabled in markdown with\n * `mdast-util-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes, which is hidden for sighted users but shown to\n * assistive technology.\n * When your page is not in English, you must define translated values.\n *\n * Back references use ARIA attributes, but the section label itself uses a\n * heading that is hidden with an `sr-only` class.\n * To show it to sighted users, define different attributes in\n * `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem, as it links footnote calls to footnote\n * definitions on the page through `id` attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n *

\n * \n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * Example: headings (DOM clobbering) in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value` (and doesn’t have `data.hName`,\n * `data.hProperties`, or `data.hChildren`, see later), create a hast `text`\n * node\n * * otherwise, create a `
` element (which could be changed with\n * `data.hName`), with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @param {MdastNodes} tree\n * mdast tree.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {HastNodes}\n * hast tree.\n */\nexport function toHast(tree, options) {\n const state = createState(tree, options)\n const node = state.one(tree, undefined)\n const foot = footer(state)\n /** @type {HastNodes} */\n const result = Array.isArray(node)\n ? {type: 'root', children: node}\n : node || {type: 'root', children: []}\n\n if (foot) {\n // If there’s a footer, there were definitions, meaning block\n // content.\n // So `result` is a parent node.\n assert('children' in result)\n result.children.push({type: 'text', value: '\\n'}, foot)\n }\n\n return result\n}\n","/**\n * @import {Root as HastRoot} from 'hast'\n * @import {Root as MdastRoot} from 'mdast'\n * @import {Options as ToHastOptions} from 'mdast-util-to-hast'\n * @import {Processor} from 'unified'\n * @import {VFile} from 'vfile'\n */\n\n/**\n * @typedef {Omit} Options\n *\n * @callback TransformBridge\n * Bridge-mode.\n *\n * Runs the destination with the new hast tree.\n * Discards result.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {Promise}\n * Nothing.\n *\n * @callback TransformMutate\n * Mutate-mode.\n *\n * Further transformers run on the hast tree.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {HastRoot}\n * Tree (hast).\n */\n\nimport {toHast} from 'mdast-util-to-hast'\n\n/**\n * Turn markdown into HTML.\n *\n * ##### Notes\n *\n * ###### Signature\n *\n * * if a processor is given,\n * runs the (rehype) plugins used on it with a hast tree,\n * then discards the result (*bridge mode*)\n * * otherwise,\n * returns a hast tree,\n * the plugins used after `remarkRehype` are rehype plugins (*mutate mode*)\n *\n * > 👉 **Note**:\n * > It’s highly unlikely that you want to pass a `processor`.\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most plugins ignore `raw` nodes but two notable ones don’t:\n *\n * * `rehype-stringify` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful if\n * you completely trust authors\n * * `rehype-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc);\n * this is a heavy task as it needs a full HTML parser,\n * but it is the only way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark,\n * which we follow by default.\n * They are supported by GitHub,\n * so footnotes can be enabled in markdown with `remark-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes,\n * which is hidden for sighted users but shown to assistive technology.\n * When your page is not in English,\n * you must define translated values.\n *\n * Back references use ARIA attributes,\n * but the section label itself uses a heading that is hidden with an\n * `sr-only` class.\n * To show it to sighted users,\n * define different attributes in `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem,\n * as it links footnote calls to footnote definitions on the page through `id`\n * attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n *

\n * \n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * *Example: headings (DOM clobbering)* in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value`\n * (and doesn’t have `data.hName`, `data.hProperties`, or `data.hChildren`,\n * see later),\n * create a hast `text` node\n * * otherwise,\n * create a `
` element (which could be changed with `data.hName`),\n * with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @overload\n * @param {Processor} processor\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformBridge}\n *\n * @overload\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformMutate}\n *\n * @overload\n * @param {Readonly | Processor | null | undefined} [destination]\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformBridge | TransformMutate}\n *\n * @param {Readonly | Processor | null | undefined} [destination]\n * Processor or configuration (optional).\n * @param {Readonly | null | undefined} [options]\n * When a processor was given,\n * configuration (optional).\n * @returns {TransformBridge | TransformMutate}\n * Transform.\n */\nexport default function remarkRehype(destination, options) {\n if (destination && 'run' in destination) {\n /**\n * @type {TransformBridge}\n */\n return async function (tree, file) {\n // Cast because root in -> root out.\n const hastTree = /** @type {HastRoot} */ (\n toHast(tree, {file, ...options})\n )\n await destination.run(hastTree, file)\n }\n }\n\n /**\n * @type {TransformMutate}\n */\n return function (tree, file) {\n // Cast because root in -> root out.\n // To do: in the future, disallow ` || options` fallback.\n // With `unified-engine`, `destination` can be `undefined` but\n // `options` will be the file set.\n // We should not pass that as `options`.\n return /** @type {HastRoot} */ (\n toHast(tree, {file, ...(destination || options)})\n )\n }\n}\n","/**\n * @typedef {import('mdast').Nodes} Nodes\n */\n\nimport {visit} from 'unist-util-visit'\n\n/**\n * Remove empty paragraphs in `tree`.\n *\n * @param {Nodes} tree\n * Tree to change.\n * @returns {undefined}\n * Nothing.\n */\nexport function squeezeParagraphs(tree) {\n visit(tree, function (node, index, parent) {\n if (\n index !== undefined &&\n parent &&\n node.type === 'paragraph' &&\n node.children.every(function (child) {\n return child.type === 'text' && /^\\s*$/.test(child.value)\n })\n ) {\n parent.children.splice(index, 1)\n return index\n }\n })\n}\n","/**\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: MIT\n */\n\n/**\n * @typedef {import('mdast').PhrasingContent} PhrasingContent\n * @typedef {import('mdast').Root} Root\n */\n\nimport {squeezeParagraphs} from 'mdast-squeeze-paragraphs'\nimport {visit} from 'unist-util-visit'\n\n/**\n * Only keep links with the given protocols.\n *\n * @param {object} options Options\n * @param {string[]} options.except - Protocols to exclude. Defauls to `['http', 'https']`.\n * @returns\n * Transform.\n */\nexport default function remarkUnlinkProtocols(\n options = {except: ['http', 'https']}\n) {\n /**\n * Transform.\n *\n * @param {Root} tree\n * Tree.\n * @returns {undefined}\n * Nothing.\n */\n return function (tree) {\n /** @type {Map} */\n const definitions = new Map()\n\n // Find definitions to look up linkReferences.\n visit(tree, 'definition', function (node, index, parent) {\n definitions.set(node.identifier, node.url)\n if (parent && typeof index === 'number') {\n const url = node.url\n if (\n url &&\n url.includes(':') &&\n !options.except.some((proto) => url.startsWith(`${proto}:`))\n ) {\n parent.children.splice(index, 1)\n return index\n }\n }\n })\n\n visit(tree, function (node, index, parent) {\n if (\n parent &&\n typeof index === 'number' &&\n (node.type === 'link' || node.type === 'linkReference')\n ) {\n const url =\n node.type === 'link' ? node.url : definitions.get(node.identifier)\n if (\n url &&\n url.includes(':') &&\n !options.except.some((proto) => url.startsWith(`${proto}:`))\n ) {\n parent.children.splice(index, 1, ...node.children)\n return index\n }\n }\n })\n\n squeezeParagraphs(tree)\n }\n}\n","/**\n * Throw a given error.\n *\n * @param {Error|null|undefined} [error]\n * Maybe error.\n * @returns {asserts error is null|undefined}\n */\nexport function bail(error) {\n if (error) {\n throw error\n }\n}\n","'use strict';\n\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar toStr = Object.prototype.toString;\nvar defineProperty = Object.defineProperty;\nvar gOPD = Object.getOwnPropertyDescriptor;\n\nvar isArray = function isArray(arr) {\n\tif (typeof Array.isArray === 'function') {\n\t\treturn Array.isArray(arr);\n\t}\n\n\treturn toStr.call(arr) === '[object Array]';\n};\n\nvar isPlainObject = function isPlainObject(obj) {\n\tif (!obj || toStr.call(obj) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tvar hasOwnConstructor = hasOwn.call(obj, 'constructor');\n\tvar hasIsPrototypeOf = obj.constructor && obj.constructor.prototype && hasOwn.call(obj.constructor.prototype, 'isPrototypeOf');\n\t// Not own constructor property must be Object\n\tif (obj.constructor && !hasOwnConstructor && !hasIsPrototypeOf) {\n\t\treturn false;\n\t}\n\n\t// Own properties are enumerated firstly, so to speed up,\n\t// if last one is own, then all properties are own.\n\tvar key;\n\tfor (key in obj) { /**/ }\n\n\treturn typeof key === 'undefined' || hasOwn.call(obj, key);\n};\n\n// If name is '__proto__', and Object.defineProperty is available, define __proto__ as an own property on target\nvar setProperty = function setProperty(target, options) {\n\tif (defineProperty && options.name === '__proto__') {\n\t\tdefineProperty(target, options.name, {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: true,\n\t\t\tvalue: options.newValue,\n\t\t\twritable: true\n\t\t});\n\t} else {\n\t\ttarget[options.name] = options.newValue;\n\t}\n};\n\n// Return undefined instead of __proto__ if '__proto__' is not an own property\nvar getProperty = function getProperty(obj, name) {\n\tif (name === '__proto__') {\n\t\tif (!hasOwn.call(obj, name)) {\n\t\t\treturn void 0;\n\t\t} else if (gOPD) {\n\t\t\t// In early versions of node, obj['__proto__'] is buggy when obj has\n\t\t\t// __proto__ as an own property. Object.getOwnPropertyDescriptor() works.\n\t\t\treturn gOPD(obj, name).value;\n\t\t}\n\t}\n\n\treturn obj[name];\n};\n\nmodule.exports = function extend() {\n\tvar options, name, src, copy, copyIsArray, clone;\n\tvar target = arguments[0];\n\tvar i = 1;\n\tvar length = arguments.length;\n\tvar deep = false;\n\n\t// Handle a deep copy situation\n\tif (typeof target === 'boolean') {\n\t\tdeep = target;\n\t\ttarget = arguments[1] || {};\n\t\t// skip the boolean and the target\n\t\ti = 2;\n\t}\n\tif (target == null || (typeof target !== 'object' && typeof target !== 'function')) {\n\t\ttarget = {};\n\t}\n\n\tfor (; i < length; ++i) {\n\t\toptions = arguments[i];\n\t\t// Only deal with non-null/undefined values\n\t\tif (options != null) {\n\t\t\t// Extend the base object\n\t\t\tfor (name in options) {\n\t\t\t\tsrc = getProperty(target, name);\n\t\t\t\tcopy = getProperty(options, name);\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif (target !== copy) {\n\t\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\t\tif (deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {\n\t\t\t\t\t\tif (copyIsArray) {\n\t\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\t\tclone = src && isArray(src) ? src : [];\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tclone = src && isPlainObject(src) ? src : {};\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\t\tsetProperty(target, { name: name, newValue: extend(deep, clone, copy) });\n\n\t\t\t\t\t// Don't bring in undefined values\n\t\t\t\t\t} else if (typeof copy !== 'undefined') {\n\t\t\t\t\t\tsetProperty(target, { name: name, newValue: copy });\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n","export default function isPlainObject(value) {\n\tif (typeof value !== 'object' || value === null) {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in value) && !(Symbol.iterator in value);\n}\n","// To do: remove `void`s\n// To do: remove `null` from output of our APIs, allow it as user APIs.\n\n/**\n * @typedef {(error?: Error | null | undefined, ...output: Array) => void} Callback\n * Callback.\n *\n * @typedef {(...input: Array) => any} Middleware\n * Ware.\n *\n * @typedef Pipeline\n * Pipeline.\n * @property {Run} run\n * Run the pipeline.\n * @property {Use} use\n * Add middleware.\n *\n * @typedef {(...input: Array) => void} Run\n * Call all middleware.\n *\n * Calls `done` on completion with either an error or the output of the\n * last middleware.\n *\n * > 👉 **Note**: as the length of input defines whether async functions get a\n * > `next` function,\n * > it’s recommended to keep `input` at one value normally.\n\n *\n * @typedef {(fn: Middleware) => Pipeline} Use\n * Add middleware.\n */\n\n/**\n * Create new middleware.\n *\n * @returns {Pipeline}\n * Pipeline.\n */\nexport function trough() {\n /** @type {Array} */\n const fns = []\n /** @type {Pipeline} */\n const pipeline = {run, use}\n\n return pipeline\n\n /** @type {Run} */\n function run(...values) {\n let middlewareIndex = -1\n /** @type {Callback} */\n const callback = values.pop()\n\n if (typeof callback !== 'function') {\n throw new TypeError('Expected function as last argument, not ' + callback)\n }\n\n next(null, ...values)\n\n /**\n * Run the next `fn`, or we’re done.\n *\n * @param {Error | null | undefined} error\n * @param {Array} output\n */\n function next(error, ...output) {\n const fn = fns[++middlewareIndex]\n let index = -1\n\n if (error) {\n callback(error)\n return\n }\n\n // Copy non-nullish input into values.\n while (++index < values.length) {\n if (output[index] === null || output[index] === undefined) {\n output[index] = values[index]\n }\n }\n\n // Save the newly created `output` for the next call.\n values = output\n\n // Next or done.\n if (fn) {\n wrap(fn, next)(...output)\n } else {\n callback(null, ...output)\n }\n }\n }\n\n /** @type {Use} */\n function use(middelware) {\n if (typeof middelware !== 'function') {\n throw new TypeError(\n 'Expected `middelware` to be a function, not ' + middelware\n )\n }\n\n fns.push(middelware)\n return pipeline\n }\n}\n\n/**\n * Wrap `middleware` into a uniform interface.\n *\n * You can pass all input to the resulting function.\n * `callback` is then called with the output of `middleware`.\n *\n * If `middleware` accepts more arguments than the later given in input,\n * an extra `done` function is passed to it after that input,\n * which must be called by `middleware`.\n *\n * The first value in `input` is the main input value.\n * All other input values are the rest input values.\n * The values given to `callback` are the input values,\n * merged with every non-nullish output value.\n *\n * * if `middleware` throws an error,\n * returns a promise that is rejected,\n * or calls the given `done` function with an error,\n * `callback` is called with that error\n * * if `middleware` returns a value or returns a promise that is resolved,\n * that value is the main output value\n * * if `middleware` calls `done`,\n * all non-nullish values except for the first one (the error) overwrite the\n * output values\n *\n * @param {Middleware} middleware\n * Function to wrap.\n * @param {Callback} callback\n * Callback called with the output of `middleware`.\n * @returns {Run}\n * Wrapped middleware.\n */\nexport function wrap(middleware, callback) {\n /** @type {boolean} */\n let called\n\n return wrapped\n\n /**\n * Call `middleware`.\n * @this {any}\n * @param {Array} parameters\n * @returns {void}\n */\n function wrapped(...parameters) {\n const fnExpectsCallback = middleware.length > parameters.length\n /** @type {any} */\n let result\n\n if (fnExpectsCallback) {\n parameters.push(done)\n }\n\n try {\n result = middleware.apply(this, parameters)\n } catch (error) {\n const exception = /** @type {Error} */ (error)\n\n // Well, this is quite the pickle.\n // `middleware` received a callback and called it synchronously, but that\n // threw an error.\n // The only thing left to do is to throw the thing instead.\n if (fnExpectsCallback && called) {\n throw exception\n }\n\n return done(exception)\n }\n\n if (!fnExpectsCallback) {\n if (result && result.then && typeof result.then === 'function') {\n result.then(then, done)\n } else if (result instanceof Error) {\n done(result)\n } else {\n then(result)\n }\n }\n }\n\n /**\n * Call `callback`, only once.\n *\n * @type {Callback}\n */\n function done(error, ...output) {\n if (!called) {\n called = true\n callback(error, ...output)\n }\n }\n\n /**\n * Call `done` with one value.\n *\n * @param {any} [value]\n */\n function then(value) {\n done(null, value)\n }\n}\n","// A derivative work based on:\n// .\n// Which is licensed:\n//\n// MIT License\n//\n// Copyright (c) 2013 James Halliday\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of\n// this software and associated documentation files (the \"Software\"), to deal in\n// the Software without restriction, including without limitation the rights to\n// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\n// the Software, and to permit persons to whom the Software is furnished to do so,\n// subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\n// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\n// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\n// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\n// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A derivative work based on:\n//\n// Parts of that are extracted from Node’s internal `path` module:\n// .\n// Which is licensed:\n//\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nexport const minpath = {basename, dirname, extname, join, sep: '/'}\n\n/* eslint-disable max-depth, complexity */\n\n/**\n * Get the basename from a path.\n *\n * @param {string} path\n * File path.\n * @param {string | null | undefined} [extname]\n * Extension to strip.\n * @returns {string}\n * Stem or basename.\n */\nfunction basename(path, extname) {\n if (extname !== undefined && typeof extname !== 'string') {\n throw new TypeError('\"ext\" argument must be a string')\n }\n\n assertPath(path)\n let start = 0\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let seenNonSlash\n\n if (\n extname === undefined ||\n extname.length === 0 ||\n extname.length > path.length\n ) {\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // path component.\n seenNonSlash = true\n end = index + 1\n }\n }\n\n return end < 0 ? '' : path.slice(start, end)\n }\n\n if (extname === path) {\n return ''\n }\n\n let firstNonSlashEnd = -1\n let extnameIndex = extname.length - 1\n\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else {\n if (firstNonSlashEnd < 0) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching.\n seenNonSlash = true\n firstNonSlashEnd = index + 1\n }\n\n if (extnameIndex > -1) {\n // Try to match the explicit extension.\n if (path.codePointAt(index) === extname.codePointAt(extnameIndex--)) {\n if (extnameIndex < 0) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = index\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extnameIndex = -1\n end = firstNonSlashEnd\n }\n }\n }\n }\n\n if (start === end) {\n end = firstNonSlashEnd\n } else if (end < 0) {\n end = path.length\n }\n\n return path.slice(start, end)\n}\n\n/**\n * Get the dirname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\nfunction dirname(path) {\n assertPath(path)\n\n if (path.length === 0) {\n return '.'\n }\n\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n // Prefix `--` is important to not run on `0`.\n while (--index) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n if (unmatchedSlash) {\n end = index\n break\n }\n } else if (!unmatchedSlash) {\n // We saw the first non-path separator\n unmatchedSlash = true\n }\n }\n\n return end < 0\n ? path.codePointAt(0) === 47 /* `/` */\n ? '/'\n : '.'\n : end === 1 && path.codePointAt(0) === 47 /* `/` */\n ? '//'\n : path.slice(0, end)\n}\n\n/**\n * Get an extname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * Extname.\n */\nfunction extname(path) {\n assertPath(path)\n\n let index = path.length\n\n let end = -1\n let startPart = 0\n let startDot = -1\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find.\n let preDotState = 0\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n while (index--) {\n const code = path.codePointAt(index)\n\n if (code === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (unmatchedSlash) {\n startPart = index + 1\n break\n }\n\n continue\n }\n\n if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // extension.\n unmatchedSlash = true\n end = index + 1\n }\n\n if (code === 46 /* `.` */) {\n // If this is our first dot, mark it as the start of our extension.\n if (startDot < 0) {\n startDot = index\n } else if (preDotState !== 1) {\n preDotState = 1\n }\n } else if (startDot > -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension.\n preDotState = -1\n }\n }\n\n if (\n startDot < 0 ||\n end < 0 ||\n // We saw a non-dot character immediately before the dot.\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly `..`.\n (preDotState === 1 && startDot === end - 1 && startDot === startPart + 1)\n ) {\n return ''\n }\n\n return path.slice(startDot, end)\n}\n\n/**\n * Join segments from a path.\n *\n * @param {Array} segments\n * Path segments.\n * @returns {string}\n * File path.\n */\nfunction join(...segments) {\n let index = -1\n /** @type {string | undefined} */\n let joined\n\n while (++index < segments.length) {\n assertPath(segments[index])\n\n if (segments[index]) {\n joined =\n joined === undefined ? segments[index] : joined + '/' + segments[index]\n }\n }\n\n return joined === undefined ? '.' : normalize(joined)\n}\n\n/**\n * Normalize a basic file path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\n// Note: `normalize` is not exposed as `path.normalize`, so some code is\n// manually removed from it.\nfunction normalize(path) {\n assertPath(path)\n\n const absolute = path.codePointAt(0) === 47 /* `/` */\n\n // Normalize the path according to POSIX rules.\n let value = normalizeString(path, !absolute)\n\n if (value.length === 0 && !absolute) {\n value = '.'\n }\n\n if (value.length > 0 && path.codePointAt(path.length - 1) === 47 /* / */) {\n value += '/'\n }\n\n return absolute ? '/' + value : value\n}\n\n/**\n * Resolve `.` and `..` elements in a path with directory names.\n *\n * @param {string} path\n * File path.\n * @param {boolean} allowAboveRoot\n * Whether `..` can move above root.\n * @returns {string}\n * File path.\n */\nfunction normalizeString(path, allowAboveRoot) {\n let result = ''\n let lastSegmentLength = 0\n let lastSlash = -1\n let dots = 0\n let index = -1\n /** @type {number | undefined} */\n let code\n /** @type {number} */\n let lastSlashIndex\n\n while (++index <= path.length) {\n if (index < path.length) {\n code = path.codePointAt(index)\n } else if (code === 47 /* `/` */) {\n break\n } else {\n code = 47 /* `/` */\n }\n\n if (code === 47 /* `/` */) {\n if (lastSlash === index - 1 || dots === 1) {\n // Empty.\n } else if (lastSlash !== index - 1 && dots === 2) {\n if (\n result.length < 2 ||\n lastSegmentLength !== 2 ||\n result.codePointAt(result.length - 1) !== 46 /* `.` */ ||\n result.codePointAt(result.length - 2) !== 46 /* `.` */\n ) {\n if (result.length > 2) {\n lastSlashIndex = result.lastIndexOf('/')\n\n if (lastSlashIndex !== result.length - 1) {\n if (lastSlashIndex < 0) {\n result = ''\n lastSegmentLength = 0\n } else {\n result = result.slice(0, lastSlashIndex)\n lastSegmentLength = result.length - 1 - result.lastIndexOf('/')\n }\n\n lastSlash = index\n dots = 0\n continue\n }\n } else if (result.length > 0) {\n result = ''\n lastSegmentLength = 0\n lastSlash = index\n dots = 0\n continue\n }\n }\n\n if (allowAboveRoot) {\n result = result.length > 0 ? result + '/..' : '..'\n lastSegmentLength = 2\n }\n } else {\n if (result.length > 0) {\n result += '/' + path.slice(lastSlash + 1, index)\n } else {\n result = path.slice(lastSlash + 1, index)\n }\n\n lastSegmentLength = index - lastSlash - 1\n }\n\n lastSlash = index\n dots = 0\n } else if (code === 46 /* `.` */ && dots > -1) {\n dots++\n } else {\n dots = -1\n }\n }\n\n return result\n}\n\n/**\n * Make sure `path` is a string.\n *\n * @param {string} path\n * File path.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError(\n 'Path must be a string. Received ' + JSON.stringify(path)\n )\n }\n}\n\n/* eslint-enable max-depth, complexity */\n","// Somewhat based on:\n// .\n// But I don’t think one tiny line of code can be copyrighted. 😅\nexport const minproc = {cwd}\n\nfunction cwd() {\n return '/'\n}\n","/**\n * Checks if a value has the shape of a WHATWG URL object.\n *\n * Using a symbol or instanceof would not be able to recognize URL objects\n * coming from other implementations (e.g. in Electron), so instead we are\n * checking some well known properties for a lack of a better test.\n *\n * We use `href` and `protocol` as they are the only properties that are\n * easy to retrieve and calculate due to the lazy nature of the getters.\n *\n * We check for auth attribute to distinguish legacy url instance with\n * WHATWG URL instance.\n *\n * @param {unknown} fileUrlOrPath\n * File path or URL.\n * @returns {fileUrlOrPath is URL}\n * Whether it’s a URL.\n */\n// From: \nexport function isUrl(fileUrlOrPath) {\n return Boolean(\n fileUrlOrPath !== null &&\n typeof fileUrlOrPath === 'object' &&\n 'href' in fileUrlOrPath &&\n fileUrlOrPath.href &&\n 'protocol' in fileUrlOrPath &&\n fileUrlOrPath.protocol &&\n // @ts-expect-error: indexing is fine.\n fileUrlOrPath.auth === undefined\n )\n}\n","import {isUrl} from './minurl.shared.js'\n\nexport {isUrl} from './minurl.shared.js'\n\n// See: \n\n/**\n * @param {URL | string} path\n * File URL.\n * @returns {string}\n * File URL.\n */\nexport function urlToPath(path) {\n if (typeof path === 'string') {\n path = new URL(path)\n } else if (!isUrl(path)) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'The \"path\" argument must be of type string or an instance of URL. Received `' +\n path +\n '`'\n )\n error.code = 'ERR_INVALID_ARG_TYPE'\n throw error\n }\n\n if (path.protocol !== 'file:') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError('The URL must be of scheme file')\n error.code = 'ERR_INVALID_URL_SCHEME'\n throw error\n }\n\n return getPathFromURLPosix(path)\n}\n\n/**\n * Get a path from a POSIX URL.\n *\n * @param {URL} url\n * URL.\n * @returns {string}\n * File path.\n */\nfunction getPathFromURLPosix(url) {\n if (url.hostname !== '') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL host must be \"localhost\" or empty on darwin'\n )\n error.code = 'ERR_INVALID_FILE_URL_HOST'\n throw error\n }\n\n const pathname = url.pathname\n let index = -1\n\n while (++index < pathname.length) {\n if (\n pathname.codePointAt(index) === 37 /* `%` */ &&\n pathname.codePointAt(index + 1) === 50 /* `2` */\n ) {\n const third = pathname.codePointAt(index + 2)\n if (third === 70 /* `F` */ || third === 102 /* `f` */) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL path must not include encoded / characters'\n )\n error.code = 'ERR_INVALID_FILE_URL_PATH'\n throw error\n }\n }\n }\n\n return decodeURIComponent(pathname)\n}\n","/**\n * @import {Node, Point, Position} from 'unist'\n * @import {Options as MessageOptions} from 'vfile-message'\n * @import {Compatible, Data, Map, Options, Value} from 'vfile'\n */\n\n/**\n * @typedef {object & {type: string, position?: Position | undefined}} NodeLike\n */\n\nimport {VFileMessage} from 'vfile-message'\nimport {minpath} from '#minpath'\nimport {minproc} from '#minproc'\nimport {urlToPath, isUrl} from '#minurl'\n\n/**\n * Order of setting (least specific to most), we need this because otherwise\n * `{stem: 'a', path: '~/b.js'}` would throw, as a path is needed before a\n * stem can be set.\n */\nconst order = /** @type {const} */ ([\n 'history',\n 'path',\n 'basename',\n 'stem',\n 'extname',\n 'dirname'\n])\n\nexport class VFile {\n /**\n * Create a new virtual file.\n *\n * `options` is treated as:\n *\n * * `string` or `Uint8Array` — `{value: options}`\n * * `URL` — `{path: options}`\n * * `VFile` — shallow copies its data over to the new file\n * * `object` — all fields are shallow copied over to the new file\n *\n * Path related fields are set in the following order (least specific to\n * most specific): `history`, `path`, `basename`, `stem`, `extname`,\n * `dirname`.\n *\n * You cannot set `dirname` or `extname` without setting either `history`,\n * `path`, `basename`, or `stem` too.\n *\n * @param {Compatible | null | undefined} [value]\n * File value.\n * @returns\n * New instance.\n */\n constructor(value) {\n /** @type {Options | VFile} */\n let options\n\n if (!value) {\n options = {}\n } else if (isUrl(value)) {\n options = {path: value}\n } else if (typeof value === 'string' || isUint8Array(value)) {\n options = {value}\n } else {\n options = value\n }\n\n /* eslint-disable no-unused-expressions */\n\n /**\n * Base of `path` (default: `process.cwd()` or `'/'` in browsers).\n *\n * @type {string}\n */\n // Prevent calling `cwd` (which could be expensive) if it’s not needed;\n // the empty string will be overridden in the next block.\n this.cwd = 'cwd' in options ? '' : minproc.cwd()\n\n /**\n * Place to store custom info (default: `{}`).\n *\n * It’s OK to store custom data directly on the file but moving it to\n * `data` is recommended.\n *\n * @type {Data}\n */\n this.data = {}\n\n /**\n * List of file paths the file moved between.\n *\n * The first is the original path and the last is the current path.\n *\n * @type {Array}\n */\n this.history = []\n\n /**\n * List of messages associated with the file.\n *\n * @type {Array}\n */\n this.messages = []\n\n /**\n * Raw value.\n *\n * @type {Value}\n */\n this.value\n\n // The below are non-standard, they are “well-known”.\n // As in, used in several tools.\n /**\n * Source map.\n *\n * This type is equivalent to the `RawSourceMap` type from the `source-map`\n * module.\n *\n * @type {Map | null | undefined}\n */\n this.map\n\n /**\n * Custom, non-string, compiled, representation.\n *\n * This is used by unified to store non-string results.\n * One example is when turning markdown into React nodes.\n *\n * @type {unknown}\n */\n this.result\n\n /**\n * Whether a file was saved to disk.\n *\n * This is used by vfile reporters.\n *\n * @type {boolean}\n */\n this.stored\n /* eslint-enable no-unused-expressions */\n\n // Set path related properties in the correct order.\n let index = -1\n\n while (++index < order.length) {\n const field = order[index]\n\n // Note: we specifically use `in` instead of `hasOwnProperty` to accept\n // `vfile`s too.\n if (\n field in options &&\n options[field] !== undefined &&\n options[field] !== null\n ) {\n // @ts-expect-error: TS doesn’t understand basic reality.\n this[field] = field === 'history' ? [...options[field]] : options[field]\n }\n }\n\n /** @type {string} */\n let field\n\n // Set non-path related properties.\n for (field in options) {\n // @ts-expect-error: fine to set other things.\n if (!order.includes(field)) {\n // @ts-expect-error: fine to set other things.\n this[field] = options[field]\n }\n }\n }\n\n /**\n * Get the basename (including extname) (example: `'index.min.js'`).\n *\n * @returns {string | undefined}\n * Basename.\n */\n get basename() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path)\n : undefined\n }\n\n /**\n * Set basename (including extname) (`'index.min.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} basename\n * Basename.\n * @returns {undefined}\n * Nothing.\n */\n set basename(basename) {\n assertNonEmpty(basename, 'basename')\n assertPart(basename, 'basename')\n this.path = minpath.join(this.dirname || '', basename)\n }\n\n /**\n * Get the parent path (example: `'~'`).\n *\n * @returns {string | undefined}\n * Dirname.\n */\n get dirname() {\n return typeof this.path === 'string'\n ? minpath.dirname(this.path)\n : undefined\n }\n\n /**\n * Set the parent path (example: `'~'`).\n *\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} dirname\n * Dirname.\n * @returns {undefined}\n * Nothing.\n */\n set dirname(dirname) {\n assertPath(this.basename, 'dirname')\n this.path = minpath.join(dirname || '', this.basename)\n }\n\n /**\n * Get the extname (including dot) (example: `'.js'`).\n *\n * @returns {string | undefined}\n * Extname.\n */\n get extname() {\n return typeof this.path === 'string'\n ? minpath.extname(this.path)\n : undefined\n }\n\n /**\n * Set the extname (including dot) (example: `'.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} extname\n * Extname.\n * @returns {undefined}\n * Nothing.\n */\n set extname(extname) {\n assertPart(extname, 'extname')\n assertPath(this.dirname, 'extname')\n\n if (extname) {\n if (extname.codePointAt(0) !== 46 /* `.` */) {\n throw new Error('`extname` must start with `.`')\n }\n\n if (extname.includes('.', 1)) {\n throw new Error('`extname` cannot contain multiple dots')\n }\n }\n\n this.path = minpath.join(this.dirname, this.stem + (extname || ''))\n }\n\n /**\n * Get the full path (example: `'~/index.min.js'`).\n *\n * @returns {string}\n * Path.\n */\n get path() {\n return this.history[this.history.length - 1]\n }\n\n /**\n * Set the full path (example: `'~/index.min.js'`).\n *\n * Cannot be nullified.\n * You can set a file URL (a `URL` object with a `file:` protocol) which will\n * be turned into a path with `url.fileURLToPath`.\n *\n * @param {URL | string} path\n * Path.\n * @returns {undefined}\n * Nothing.\n */\n set path(path) {\n if (isUrl(path)) {\n path = urlToPath(path)\n }\n\n assertNonEmpty(path, 'path')\n\n if (this.path !== path) {\n this.history.push(path)\n }\n }\n\n /**\n * Get the stem (basename w/o extname) (example: `'index.min'`).\n *\n * @returns {string | undefined}\n * Stem.\n */\n get stem() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path, this.extname)\n : undefined\n }\n\n /**\n * Set the stem (basename w/o extname) (example: `'index.min'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} stem\n * Stem.\n * @returns {undefined}\n * Nothing.\n */\n set stem(stem) {\n assertNonEmpty(stem, 'stem')\n assertPart(stem, 'stem')\n this.path = minpath.join(this.dirname || '', stem + (this.extname || ''))\n }\n\n // Normal prototypal methods.\n /**\n * Create a fatal message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `true` (error; file not usable)\n * and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {never}\n * Never.\n * @throws {VFileMessage}\n * Message.\n */\n fail(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = true\n\n throw message\n }\n\n /**\n * Create an info message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `undefined` (info; change\n * likely not needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n info(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = undefined\n\n return message\n }\n\n /**\n * Create a message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `false` (warning; change may be\n * needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n message(causeOrReason, optionsOrParentOrPlace, origin) {\n const message = new VFileMessage(\n // @ts-expect-error: the overloads are fine.\n causeOrReason,\n optionsOrParentOrPlace,\n origin\n )\n\n if (this.path) {\n message.name = this.path + ':' + message.name\n message.file = this.path\n }\n\n message.fatal = false\n\n this.messages.push(message)\n\n return message\n }\n\n /**\n * Serialize the file.\n *\n * > **Note**: which encodings are supported depends on the engine.\n * > For info on Node.js, see:\n * > .\n *\n * @param {string | null | undefined} [encoding='utf8']\n * Character encoding to understand `value` as when it’s a `Uint8Array`\n * (default: `'utf-8'`).\n * @returns {string}\n * Serialized file.\n */\n toString(encoding) {\n if (this.value === undefined) {\n return ''\n }\n\n if (typeof this.value === 'string') {\n return this.value\n }\n\n const decoder = new TextDecoder(encoding || undefined)\n return decoder.decode(this.value)\n }\n}\n\n/**\n * Assert that `part` is not a path (as in, does not contain `path.sep`).\n *\n * @param {string | null | undefined} part\n * File path part.\n * @param {string} name\n * Part name.\n * @returns {undefined}\n * Nothing.\n */\nfunction assertPart(part, name) {\n if (part && part.includes(minpath.sep)) {\n throw new Error(\n '`' + name + '` cannot be a path: did not expect `' + minpath.sep + '`'\n )\n }\n}\n\n/**\n * Assert that `part` is not empty.\n *\n * @param {string | undefined} part\n * Thing.\n * @param {string} name\n * Part name.\n * @returns {asserts part is string}\n * Nothing.\n */\nfunction assertNonEmpty(part, name) {\n if (!part) {\n throw new Error('`' + name + '` cannot be empty')\n }\n}\n\n/**\n * Assert `path` exists.\n *\n * @param {string | undefined} path\n * Path.\n * @param {string} name\n * Dependency name.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path, name) {\n if (!path) {\n throw new Error('Setting `' + name + '` requires `path` to be set too')\n }\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","export const CallableInstance =\n /**\n * @type {new , Result>(property: string | symbol) => (...parameters: Parameters) => Result}\n */\n (\n /** @type {unknown} */\n (\n /**\n * @this {Function}\n * @param {string | symbol} property\n * @returns {(...parameters: Array) => unknown}\n */\n function (property) {\n const self = this\n const constr = self.constructor\n const proto = /** @type {Record} */ (\n // Prototypes do exist.\n // type-coverage:ignore-next-line\n constr.prototype\n )\n const value = proto[property]\n /** @type {(...parameters: Array) => unknown} */\n const apply = function () {\n return value.apply(apply, arguments)\n }\n\n Object.setPrototypeOf(apply, proto)\n\n // Not needed for us in `unified`: we only call this on the `copy`\n // function,\n // and we don't need to add its fields (`length`, `name`)\n // over.\n // See also: GH-246.\n // const names = Object.getOwnPropertyNames(value)\n //\n // for (const p of names) {\n // const descriptor = Object.getOwnPropertyDescriptor(value, p)\n // if (descriptor) Object.defineProperty(apply, p, descriptor)\n // }\n\n return apply\n }\n )\n )\n","/**\n * @typedef {import('trough').Pipeline} Pipeline\n *\n * @typedef {import('unist').Node} Node\n *\n * @typedef {import('vfile').Compatible} Compatible\n * @typedef {import('vfile').Value} Value\n *\n * @typedef {import('../index.js').CompileResultMap} CompileResultMap\n * @typedef {import('../index.js').Data} Data\n * @typedef {import('../index.js').Settings} Settings\n */\n\n/**\n * @typedef {CompileResultMap[keyof CompileResultMap]} CompileResults\n * Acceptable results from compilers.\n *\n * To register custom results, add them to\n * {@linkcode CompileResultMap}.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the compiler receives (default: `Node`).\n * @template {CompileResults} [Result=CompileResults]\n * The thing that the compiler yields (default: `CompileResults`).\n * @callback Compiler\n * A **compiler** handles the compiling of a syntax tree to something else\n * (in most cases, text) (TypeScript type).\n *\n * It is used in the stringify phase and called with a {@linkcode Node}\n * and {@linkcode VFile} representation of the document to compile.\n * It should return the textual representation of the given tree (typically\n * `string`).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n * @param {Tree} tree\n * Tree to compile.\n * @param {VFile} file\n * File associated with `tree`.\n * @returns {Result}\n * New content: compiled text (`string` or `Uint8Array`, for `file.value`) or\n * something else (for `file.result`).\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the parser yields (default: `Node`)\n * @callback Parser\n * A **parser** handles the parsing of text to a syntax tree.\n *\n * It is used in the parse phase and is called with a `string` and\n * {@linkcode VFile} of the document to parse.\n * It must return the syntax tree representation of the given file\n * ({@linkcode Node}).\n * @param {string} document\n * Document to parse.\n * @param {VFile} file\n * File associated with `document`.\n * @returns {Tree}\n * Node representing the given file.\n */\n\n/**\n * @typedef {(\n * Plugin, any, any> |\n * PluginTuple, any, any> |\n * Preset\n * )} Pluggable\n * Union of the different ways to add plugins and settings.\n */\n\n/**\n * @typedef {Array} PluggableList\n * List of plugins and presets.\n */\n\n// Note: we can’t use `callback` yet as it messes up `this`:\n// .\n/**\n * @template {Array} [PluginParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=Node]\n * Value that is expected as input (default: `Node`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=Input]\n * Value that is yielded as output (default: `Input`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * (this: Processor, ...parameters: PluginParameters) =>\n * Input extends string ? // Parser.\n * Output extends Node | undefined ? undefined | void : never :\n * Output extends CompileResults ? // Compiler.\n * Input extends Node | undefined ? undefined | void : never :\n * Transformer<\n * Input extends Node ? Input : Node,\n * Output extends Node ? Output : Node\n * > | undefined | void\n * )} Plugin\n * Single plugin.\n *\n * Plugins configure the processors they are applied on in the following\n * ways:\n *\n * * they change the processor, such as the parser, the compiler, or by\n * configuring data\n * * they specify how to handle trees and files\n *\n * In practice, they are functions that can receive options and configure the\n * processor (`this`).\n *\n * > **Note**: plugins are called when the processor is *frozen*, not when\n * > they are applied.\n */\n\n/**\n * Tuple of a plugin and its configuration.\n *\n * The first item is a plugin, the rest are its parameters.\n *\n * @template {Array} [TupleParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=undefined]\n * Value that is expected as input (optional).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=undefined] (optional).\n * Value that is yielded as output.\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * [\n * plugin: Plugin,\n * ...parameters: TupleParameters\n * ]\n * )} PluginTuple\n */\n\n/**\n * @typedef Preset\n * Sharable configuration.\n *\n * They can contain plugins and settings.\n * @property {PluggableList | undefined} [plugins]\n * List of plugins and presets (optional).\n * @property {Settings | undefined} [settings]\n * Shared settings for parsers and compilers (optional).\n */\n\n/**\n * @template {VFile} [File=VFile]\n * The file that the callback receives (default: `VFile`).\n * @callback ProcessCallback\n * Callback called when the process is done.\n *\n * Called with either an error or a result.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {File | undefined} [file]\n * Processed file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The tree that the callback receives (default: `Node`).\n * @callback RunCallback\n * Callback called when transformers are done.\n *\n * Called with either an error or results.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {Tree | undefined} [tree]\n * Transformed tree (optional).\n * @param {VFile | undefined} [file]\n * File (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Output=Node]\n * Node type that the transformer yields (default: `Node`).\n * @callback TransformCallback\n * Callback passed to transforms.\n *\n * If the signature of a `transformer` accepts a third argument, the\n * transformer may perform asynchronous operations, and must call it.\n * @param {Error | undefined} [error]\n * Fatal error to stop the process (optional).\n * @param {Output | undefined} [tree]\n * New, changed, tree (optional).\n * @param {VFile | undefined} [file]\n * New, changed, file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Input=Node]\n * Node type that the transformer expects (default: `Node`).\n * @template {Node} [Output=Input]\n * Node type that the transformer yields (default: `Input`).\n * @callback Transformer\n * Transformers handle syntax trees and files.\n *\n * They are functions that are called each time a syntax tree and file are\n * passed through the run phase.\n * When an error occurs in them (either because it’s thrown, returned,\n * rejected, or passed to `next`), the process stops.\n *\n * The run phase is handled by [`trough`][trough], see its documentation for\n * the exact semantics of these functions.\n *\n * > **Note**: you should likely ignore `next`: don’t accept it.\n * > it supports callback-style async work.\n * > But promises are likely easier to reason about.\n *\n * [trough]: https://github.com/wooorm/trough#function-fninput-next\n * @param {Input} tree\n * Tree to handle.\n * @param {VFile} file\n * File to handle.\n * @param {TransformCallback} next\n * Callback.\n * @returns {(\n * Promise |\n * Promise | // For some reason this is needed separately.\n * Output |\n * Error |\n * undefined |\n * void\n * )}\n * If you accept `next`, nothing.\n * Otherwise:\n *\n * * `Error` — fatal error to stop the process\n * * `Promise` or `undefined` — the next transformer keeps using\n * same tree\n * * `Promise` or `Node` — new, changed, tree\n */\n\n/**\n * @template {Node | undefined} ParseTree\n * Output of `parse`.\n * @template {Node | undefined} HeadTree\n * Input for `run`.\n * @template {Node | undefined} TailTree\n * Output for `run`.\n * @template {Node | undefined} CompileTree\n * Input of `stringify`.\n * @template {CompileResults | undefined} CompileResult\n * Output of `stringify`.\n * @template {Node | string | undefined} Input\n * Input of plugin.\n * @template Output\n * Output of plugin (optional).\n * @typedef {(\n * Input extends string\n * ? Output extends Node | undefined\n * ? // Parser.\n * Processor<\n * Output extends undefined ? ParseTree : Output,\n * HeadTree,\n * TailTree,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor\n * : Output extends CompileResults\n * ? Input extends Node | undefined\n * ? // Compiler.\n * Processor<\n * ParseTree,\n * HeadTree,\n * TailTree,\n * Input extends undefined ? CompileTree : Input,\n * Output extends undefined ? CompileResult : Output\n * >\n * : // Unknown.\n * Processor\n * : Input extends Node | undefined\n * ? Output extends Node | undefined\n * ? // Transform.\n * Processor<\n * ParseTree,\n * HeadTree extends undefined ? Input : HeadTree,\n * Output extends undefined ? TailTree : Output,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor\n * : // Unknown.\n * Processor\n * )} UsePlugin\n * Create a processor based on the input/output of a {@link Plugin plugin}.\n */\n\n/**\n * @template {CompileResults | undefined} Result\n * Node type that the transformer yields.\n * @typedef {(\n * Result extends Value | undefined ?\n * VFile :\n * VFile & {result: Result}\n * )} VFileWithOutput\n * Type to generate a {@linkcode VFile} corresponding to a compiler result.\n *\n * If a result that is not acceptable on a `VFile` is used, that will\n * be stored on the `result` field of {@linkcode VFile}.\n */\n\nimport {bail} from 'bail'\nimport extend from 'extend'\nimport {ok as assert} from 'devlop'\nimport isPlainObj from 'is-plain-obj'\nimport {trough} from 'trough'\nimport {VFile} from 'vfile'\nimport {CallableInstance} from './callable-instance.js'\n\n// To do: next major: drop `Compiler`, `Parser`: prefer lowercase.\n\n// To do: we could start yielding `never` in TS when a parser is missing and\n// `parse` is called.\n// Currently, we allow directly setting `processor.parser`, which is untyped.\n\nconst own = {}.hasOwnProperty\n\n/**\n * @template {Node | undefined} [ParseTree=undefined]\n * Output of `parse` (optional).\n * @template {Node | undefined} [HeadTree=undefined]\n * Input for `run` (optional).\n * @template {Node | undefined} [TailTree=undefined]\n * Output for `run` (optional).\n * @template {Node | undefined} [CompileTree=undefined]\n * Input of `stringify` (optional).\n * @template {CompileResults | undefined} [CompileResult=undefined]\n * Output of `stringify` (optional).\n * @extends {CallableInstance<[], Processor>}\n */\nexport class Processor extends CallableInstance {\n /**\n * Create a processor.\n */\n constructor() {\n // If `Processor()` is called (w/o new), `copy` is called instead.\n super('copy')\n\n /**\n * Compiler to use (deprecated).\n *\n * @deprecated\n * Use `compiler` instead.\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.Compiler = undefined\n\n /**\n * Parser to use (deprecated).\n *\n * @deprecated\n * Use `parser` instead.\n * @type {(\n * Parser |\n * undefined\n * )}\n */\n this.Parser = undefined\n\n // Note: the following fields are considered private.\n // However, they are needed for tests, and TSC generates an untyped\n // `private freezeIndex` field for, which trips `type-coverage` up.\n // Instead, we use `@deprecated` to visualize that they shouldn’t be used.\n /**\n * Internal list of configured plugins.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Array>>}\n */\n this.attachers = []\n\n /**\n * Compiler to use.\n *\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.compiler = undefined\n\n /**\n * Internal state to track where we are while freezing.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {number}\n */\n this.freezeIndex = -1\n\n /**\n * Internal state to track whether we’re frozen.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {boolean | undefined}\n */\n this.frozen = undefined\n\n /**\n * Internal state.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Data}\n */\n this.namespace = {}\n\n /**\n * Parser to use.\n *\n * @type {(\n * Parser |\n * undefined\n * )}\n */\n this.parser = undefined\n\n /**\n * Internal list of configured transformers.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Pipeline}\n */\n this.transformers = trough()\n }\n\n /**\n * Copy a processor.\n *\n * @deprecated\n * This is a private internal method and should not be used.\n * @returns {Processor}\n * New *unfrozen* processor ({@linkcode Processor}) that is\n * configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\n copy() {\n // Cast as the type parameters will be the same after attaching.\n const destination =\n /** @type {Processor} */ (\n new Processor()\n )\n let index = -1\n\n while (++index < this.attachers.length) {\n const attacher = this.attachers[index]\n destination.use(...attacher)\n }\n\n destination.data(extend(true, {}, this.namespace))\n\n return destination\n }\n\n /**\n * Configure the processor with info available to all plugins.\n * Information is stored in an object.\n *\n * Typically, options can be given to a specific plugin, but sometimes it\n * makes sense to have information shared with several plugins.\n * For example, a list of HTML elements that are self-closing, which is\n * needed during all phases.\n *\n * > **Note**: setting information cannot occur on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * > **Note**: to register custom data in TypeScript, augment the\n * > {@linkcode Data} interface.\n *\n * @example\n * This example show how to get and set info:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * const processor = unified().data('alpha', 'bravo')\n *\n * processor.data('alpha') // => 'bravo'\n *\n * processor.data() // => {alpha: 'bravo'}\n *\n * processor.data({charlie: 'delta'})\n *\n * processor.data() // => {charlie: 'delta'}\n * ```\n *\n * @template {keyof Data} Key\n *\n * @overload\n * @returns {Data}\n *\n * @overload\n * @param {Data} dataset\n * @returns {Processor}\n *\n * @overload\n * @param {Key} key\n * @returns {Data[Key]}\n *\n * @overload\n * @param {Key} key\n * @param {Data[Key]} value\n * @returns {Processor}\n *\n * @param {Data | Key} [key]\n * Key to get or set, or entire dataset to set, or nothing to get the\n * entire dataset (optional).\n * @param {Data[Key]} [value]\n * Value to set (optional).\n * @returns {unknown}\n * The current processor when setting, the value at `key` when getting, or\n * the entire dataset when getting without key.\n */\n data(key, value) {\n if (typeof key === 'string') {\n // Set `key`.\n if (arguments.length === 2) {\n assertUnfrozen('data', this.frozen)\n this.namespace[key] = value\n return this\n }\n\n // Get `key`.\n return (own.call(this.namespace, key) && this.namespace[key]) || undefined\n }\n\n // Set space.\n if (key) {\n assertUnfrozen('data', this.frozen)\n this.namespace = key\n return this\n }\n\n // Get space.\n return this.namespace\n }\n\n /**\n * Freeze a processor.\n *\n * Frozen processors are meant to be extended and not to be configured\n * directly.\n *\n * When a processor is frozen it cannot be unfrozen.\n * New processors working the same way can be created by calling the\n * processor.\n *\n * It’s possible to freeze processors explicitly by calling `.freeze()`.\n * Processors freeze automatically when `.parse()`, `.run()`, `.runSync()`,\n * `.stringify()`, `.process()`, or `.processSync()` are called.\n *\n * @returns {Processor}\n * The current processor.\n */\n freeze() {\n if (this.frozen) {\n return this\n }\n\n // Cast so that we can type plugins easier.\n // Plugins are supposed to be usable on different processors, not just on\n // this exact processor.\n const self = /** @type {Processor} */ (/** @type {unknown} */ (this))\n\n while (++this.freezeIndex < this.attachers.length) {\n const [attacher, ...options] = this.attachers[this.freezeIndex]\n\n if (options[0] === false) {\n continue\n }\n\n if (options[0] === true) {\n options[0] = undefined\n }\n\n const transformer = attacher.call(self, ...options)\n\n if (typeof transformer === 'function') {\n this.transformers.use(transformer)\n }\n }\n\n this.frozen = true\n this.freezeIndex = Number.POSITIVE_INFINITY\n\n return this\n }\n\n /**\n * Parse text to a syntax tree.\n *\n * > **Note**: `parse` freezes the processor if not already *frozen*.\n *\n * > **Note**: `parse` performs the parse phase, not the run phase or other\n * > phases.\n *\n * @param {Compatible | undefined} [file]\n * file to parse (optional); typically `string` or `VFile`; any value\n * accepted as `x` in `new VFile(x)`.\n * @returns {ParseTree extends undefined ? Node : ParseTree}\n * Syntax tree representing `file`.\n */\n parse(file) {\n this.freeze()\n const realFile = vfile(file)\n const parser = this.parser || this.Parser\n assertParser('parse', parser)\n return parser(String(realFile), realFile)\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * > **Note**: `process` freezes the processor if not already *frozen*.\n *\n * > **Note**: `process` performs the parse, run, and stringify phases.\n *\n * @overload\n * @param {Compatible | undefined} file\n * @param {ProcessCallback>} done\n * @returns {undefined}\n *\n * @overload\n * @param {Compatible | undefined} [file]\n * @returns {Promise>}\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`]; any value accepted as\n * `x` in `new VFile(x)`.\n * @param {ProcessCallback> | undefined} [done]\n * Callback (optional).\n * @returns {Promise | undefined}\n * Nothing if `done` is given.\n * Otherwise a promise, rejected with a fatal error or resolved with the\n * processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n process(file, done) {\n const self = this\n\n this.freeze()\n assertParser('process', this.parser || this.Parser)\n assertCompiler('process', this.compiler || this.Compiler)\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {((file: VFileWithOutput) => undefined | void) | undefined} resolve\n * @param {(error: Error | undefined) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n const realFile = vfile(file)\n // Assume `ParseTree` (the result of the parser) matches `HeadTree` (the\n // input of the first transform).\n const parseTree =\n /** @type {HeadTree extends undefined ? Node : HeadTree} */ (\n /** @type {unknown} */ (self.parse(realFile))\n )\n\n self.run(parseTree, realFile, function (error, tree, file) {\n if (error || !tree || !file) {\n return realDone(error)\n }\n\n // Assume `TailTree` (the output of the last transform) matches\n // `CompileTree` (the input of the compiler).\n const compileTree =\n /** @type {CompileTree extends undefined ? Node : CompileTree} */ (\n /** @type {unknown} */ (tree)\n )\n\n const compileResult = self.stringify(compileTree, file)\n\n if (looksLikeAValue(compileResult)) {\n file.value = compileResult\n } else {\n file.result = compileResult\n }\n\n realDone(error, /** @type {VFileWithOutput} */ (file))\n })\n\n /**\n * @param {Error | undefined} error\n * @param {VFileWithOutput | undefined} [file]\n * @returns {undefined}\n */\n function realDone(error, file) {\n if (error || !file) {\n reject(error)\n } else if (resolve) {\n resolve(file)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, file)\n }\n }\n }\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `processSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `processSync` performs the parse, run, and stringify phases.\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`; any value accepted as\n * `x` in `new VFile(x)`.\n * @returns {VFileWithOutput}\n * The processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n processSync(file) {\n /** @type {boolean} */\n let complete = false\n /** @type {VFileWithOutput | undefined} */\n let result\n\n this.freeze()\n assertParser('processSync', this.parser || this.Parser)\n assertCompiler('processSync', this.compiler || this.Compiler)\n\n this.process(file, realDone)\n assertDone('processSync', 'process', complete)\n assert(result, 'we either bailed on an error or have a tree')\n\n return result\n\n /**\n * @type {ProcessCallback>}\n */\n function realDone(error, file) {\n complete = true\n bail(error)\n result = file\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * > **Note**: `run` freezes the processor if not already *frozen*.\n *\n * > **Note**: `run` performs the run phase, not other phases.\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {RunCallback} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} file\n * @param {RunCallback} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} [file]\n * @returns {Promise}\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {(\n * RunCallback |\n * Compatible\n * )} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @param {RunCallback} [done]\n * Callback (optional).\n * @returns {Promise | undefined}\n * Nothing if `done` is given.\n * Otherwise, a promise rejected with a fatal error or resolved with the\n * transformed tree.\n */\n run(tree, file, done) {\n assertNode(tree)\n this.freeze()\n\n const transformers = this.transformers\n\n if (!done && typeof file === 'function') {\n done = file\n file = undefined\n }\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {(\n * ((tree: TailTree extends undefined ? Node : TailTree) => undefined | void) |\n * undefined\n * )} resolve\n * @param {(error: Error) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n assert(\n typeof file !== 'function',\n '`file` can’t be a `done` anymore, we checked'\n )\n const realFile = vfile(file)\n transformers.run(tree, realFile, realDone)\n\n /**\n * @param {Error | undefined} error\n * @param {Node} outputTree\n * @param {VFile} file\n * @returns {undefined}\n */\n function realDone(error, outputTree, file) {\n const resultingTree =\n /** @type {TailTree extends undefined ? Node : TailTree} */ (\n outputTree || tree\n )\n\n if (error) {\n reject(error)\n } else if (resolve) {\n resolve(resultingTree)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, resultingTree, file)\n }\n }\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `runSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `runSync` performs the run phase, not other phases.\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {TailTree extends undefined ? Node : TailTree}\n * Transformed tree.\n */\n runSync(tree, file) {\n /** @type {boolean} */\n let complete = false\n /** @type {(TailTree extends undefined ? Node : TailTree) | undefined} */\n let result\n\n this.run(tree, file, realDone)\n\n assertDone('runSync', 'run', complete)\n assert(result, 'we either bailed on an error or have a tree')\n return result\n\n /**\n * @type {RunCallback}\n */\n function realDone(error, tree) {\n bail(error)\n result = tree\n complete = true\n }\n }\n\n /**\n * Compile a syntax tree.\n *\n * > **Note**: `stringify` freezes the processor if not already *frozen*.\n *\n * > **Note**: `stringify` performs the stringify phase, not the run phase\n * > or other phases.\n *\n * @param {CompileTree extends undefined ? Node : CompileTree} tree\n * Tree to compile.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {CompileResult extends undefined ? Value : CompileResult}\n * Textual representation of the tree (see note).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n stringify(tree, file) {\n this.freeze()\n const realFile = vfile(file)\n const compiler = this.compiler || this.Compiler\n assertCompiler('stringify', compiler)\n assertNode(tree)\n\n return compiler(tree, realFile)\n }\n\n /**\n * Configure the processor to use a plugin, a list of usable values, or a\n * preset.\n *\n * If the processor is already using a plugin, the previous plugin\n * configuration is changed based on the options that are passed in.\n * In other words, the plugin is not added a second time.\n *\n * > **Note**: `use` cannot be called on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * @example\n * There are many ways to pass plugins to `.use()`.\n * This example gives an overview:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * unified()\n * // Plugin with options:\n * .use(pluginA, {x: true, y: true})\n * // Passing the same plugin again merges configuration (to `{x: true, y: false, z: true}`):\n * .use(pluginA, {y: false, z: true})\n * // Plugins:\n * .use([pluginB, pluginC])\n * // Two plugins, the second with options:\n * .use([pluginD, [pluginE, {}]])\n * // Preset with plugins and settings:\n * .use({plugins: [pluginF, [pluginG, {}]], settings: {position: false}})\n * // Settings only:\n * .use({settings: {position: false}})\n * ```\n *\n * @template {Array} [Parameters=[]]\n * @template {Node | string | undefined} [Input=undefined]\n * @template [Output=Input]\n *\n * @overload\n * @param {Preset | null | undefined} [preset]\n * @returns {Processor}\n *\n * @overload\n * @param {PluggableList} list\n * @returns {Processor}\n *\n * @overload\n * @param {Plugin} plugin\n * @param {...(Parameters | [boolean])} parameters\n * @returns {UsePlugin}\n *\n * @param {PluggableList | Plugin | Preset | null | undefined} value\n * Usable value.\n * @param {...unknown} parameters\n * Parameters, when a plugin is given as a usable value.\n * @returns {Processor}\n * Current processor.\n */\n use(value, ...parameters) {\n const attachers = this.attachers\n const namespace = this.namespace\n\n assertUnfrozen('use', this.frozen)\n\n if (value === null || value === undefined) {\n // Empty.\n } else if (typeof value === 'function') {\n addPlugin(value, parameters)\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n addList(value)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n\n return this\n\n /**\n * @param {Pluggable} value\n * @returns {undefined}\n */\n function add(value) {\n if (typeof value === 'function') {\n addPlugin(value, [])\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n const [plugin, ...parameters] =\n /** @type {PluginTuple>} */ (value)\n addPlugin(plugin, parameters)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n }\n\n /**\n * @param {Preset} result\n * @returns {undefined}\n */\n function addPreset(result) {\n if (!('plugins' in result) && !('settings' in result)) {\n throw new Error(\n 'Expected usable value but received an empty preset, which is probably a mistake: presets typically come with `plugins` and sometimes with `settings`, but this has neither'\n )\n }\n\n addList(result.plugins)\n\n if (result.settings) {\n namespace.settings = extend(true, namespace.settings, result.settings)\n }\n }\n\n /**\n * @param {PluggableList | null | undefined} plugins\n * @returns {undefined}\n */\n function addList(plugins) {\n let index = -1\n\n if (plugins === null || plugins === undefined) {\n // Empty.\n } else if (Array.isArray(plugins)) {\n while (++index < plugins.length) {\n const thing = plugins[index]\n add(thing)\n }\n } else {\n throw new TypeError('Expected a list of plugins, not `' + plugins + '`')\n }\n }\n\n /**\n * @param {Plugin} plugin\n * @param {Array} parameters\n * @returns {undefined}\n */\n function addPlugin(plugin, parameters) {\n let index = -1\n let entryIndex = -1\n\n while (++index < attachers.length) {\n if (attachers[index][0] === plugin) {\n entryIndex = index\n break\n }\n }\n\n if (entryIndex === -1) {\n attachers.push([plugin, ...parameters])\n }\n // Only set if there was at least a `primary` value, otherwise we’d change\n // `arguments.length`.\n else if (parameters.length > 0) {\n let [primary, ...rest] = parameters\n const currentPrimary = attachers[entryIndex][1]\n if (isPlainObj(currentPrimary) && isPlainObj(primary)) {\n primary = extend(true, currentPrimary, primary)\n }\n\n attachers[entryIndex] = [plugin, primary, ...rest]\n }\n }\n }\n}\n\n// Note: this returns a *callable* instance.\n// That’s why it’s documented as a function.\n/**\n * Create a new processor.\n *\n * @example\n * This example shows how a new processor can be created (from `remark`) and linked\n * to **stdin**(4) and **stdout**(4).\n *\n * ```js\n * import process from 'node:process'\n * import concatStream from 'concat-stream'\n * import {remark} from 'remark'\n *\n * process.stdin.pipe(\n * concatStream(function (buf) {\n * process.stdout.write(String(remark().processSync(buf)))\n * })\n * )\n * ```\n *\n * @returns\n * New *unfrozen* processor (`processor`).\n *\n * This processor is configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\nexport const unified = new Processor().freeze()\n\n/**\n * Assert a parser is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Parser}\n */\nfunction assertParser(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `parser`')\n }\n}\n\n/**\n * Assert a compiler is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Compiler}\n */\nfunction assertCompiler(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `compiler`')\n }\n}\n\n/**\n * Assert the processor is not frozen.\n *\n * @param {string} name\n * @param {unknown} frozen\n * @returns {asserts frozen is false}\n */\nfunction assertUnfrozen(name, frozen) {\n if (frozen) {\n throw new Error(\n 'Cannot call `' +\n name +\n '` on a frozen processor.\\nCreate a new processor first, by calling it: use `processor()` instead of `processor`.'\n )\n }\n}\n\n/**\n * Assert `node` is a unist node.\n *\n * @param {unknown} node\n * @returns {asserts node is Node}\n */\nfunction assertNode(node) {\n // `isPlainObj` unfortunately uses `any` instead of `unknown`.\n // type-coverage:ignore-next-line\n if (!isPlainObj(node) || typeof node.type !== 'string') {\n throw new TypeError('Expected node, got `' + node + '`')\n // Fine.\n }\n}\n\n/**\n * Assert that `complete` is `true`.\n *\n * @param {string} name\n * @param {string} asyncName\n * @param {unknown} complete\n * @returns {asserts complete is true}\n */\nfunction assertDone(name, asyncName, complete) {\n if (!complete) {\n throw new Error(\n '`' + name + '` finished async. Use `' + asyncName + '` instead'\n )\n }\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {VFile}\n */\nfunction vfile(value) {\n return looksLikeAVFile(value) ? value : new VFile(value)\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {value is VFile}\n */\nfunction looksLikeAVFile(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'message' in value &&\n 'messages' in value\n )\n}\n\n/**\n * @param {unknown} [value]\n * @returns {value is Value}\n */\nfunction looksLikeAValue(value) {\n return typeof value === 'string' || isUint8Array(value)\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","/*!\n * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: GPL-3.0-or-later\n */\n/**\n * @module public\n */\nimport { loadState } from '@nextcloud/initial-state';\n/**\n * Check if the current page is on a public share\n */\nexport function isPublicShare() {\n // check both the new initial state version and fallback to legacy input\n return (loadState('files_sharing', 'isPublic', null)\n ?? document.querySelector('input#isPublic[type=\"hidden\"][name=\"isPublic\"][value=\"1\"]') !== null);\n}\n/**\n * Get the sharing token for the current public share\n */\nexport function getSharingToken() {\n return (loadState('files_sharing', 'sharingToken', null)\n ?? document.querySelector('input#sharingToken[type=\"hidden\"]')?.value\n ?? null);\n}\n","import { l as logger } from \"./logger-D3RVzcfQ.mjs\";\nwindow._vue_richtext_widgets ??= {};\nwindow._registerWidget ??= (id, callback, onDestroy, props) => {\n registerWidget(id, callback, onDestroy, props);\n};\nfunction registerWidget(id, callback, onDestroy = () => {\n}, props) {\n const propsWithDefaults = {\n hasInteractiveView: true,\n fullWidth: false,\n ...props\n };\n if (window._vue_richtext_widgets[id]) {\n logger.error(`[ReferencePicker]: Widget for id ${id} already registered`);\n return;\n }\n window._vue_richtext_widgets[id] = {\n id,\n callback,\n onDestroy,\n ...propsWithDefaults\n };\n}\nfunction renderWidget(el, options) {\n const { richObjectType, richObject, accessible, interactive } = options;\n if (richObjectType === \"open-graph\") {\n return;\n }\n if (!window._vue_richtext_widgets[richObjectType]) {\n logger.error(\"Widget for rich object type \" + richObjectType + \" not registered\");\n return;\n }\n window._vue_richtext_widgets[richObjectType].callback(el, { richObjectType, richObject, accessible, interactive });\n}\nfunction destroyWidget(richObjectType, el) {\n if (richObjectType === \"open-graph\") {\n return;\n }\n if (!window._vue_richtext_widgets[richObjectType]) {\n return;\n }\n window._vue_richtext_widgets[richObjectType].onDestroy(el);\n}\nfunction isWidgetRegistered(id) {\n return !!window._vue_richtext_widgets[id];\n}\nfunction hasInteractiveView(id) {\n return !!window._vue_richtext_widgets[id]?.hasInteractiveView;\n}\nfunction hasFullWidth(id) {\n return !!window._vue_richtext_widgets[id]?.fullWidth;\n}\nwindow._vue_richtext_custom_picker_elements ??= {};\nwindow._registerCustomPickerElement ??= registerCustomPickerElement;\nclass NcCustomPickerRenderResult {\n element;\n object;\n /**\n * @param element - The HTML element\n * @param object - The object\n */\n constructor(element, object) {\n this.element = element;\n this.object = object;\n }\n}\nfunction isCustomPickerElementRegistered(id) {\n return !!window._vue_richtext_custom_picker_elements[id];\n}\nfunction getCustomPickerElementSize(id) {\n const size = window._vue_richtext_custom_picker_elements[id]?.size;\n if (size && [\"small\", \"normal\", \"large\", \"full\"].includes(size)) {\n return size;\n }\n return null;\n}\nfunction registerCustomPickerElement(id, callback, onDestroy = () => {\n}, size = \"large\") {\n if (window._vue_richtext_custom_picker_elements[id]) {\n logger.error(`Custom reference picker element for id ${id} already registered`);\n return;\n }\n window._vue_richtext_custom_picker_elements[id] = {\n id,\n callback,\n onDestroy,\n size\n };\n}\nfunction renderCustomPickerElement(el, options) {\n const { providerId, accessible } = options;\n if (!window._vue_richtext_custom_picker_elements[providerId]) {\n logger.error(`Custom reference picker element for reference provider ID ${providerId} not registered`);\n return;\n }\n return window._vue_richtext_custom_picker_elements[providerId].callback(el, { providerId, accessible });\n}\nfunction destroyCustomPickerElement(providerId, el, renderResult) {\n if (!window._vue_richtext_custom_picker_elements[providerId]) {\n return;\n }\n window._vue_richtext_custom_picker_elements[providerId].onDestroy(el, renderResult);\n}\nexport {\n NcCustomPickerRenderResult as N,\n renderWidget as a,\n destroyCustomPickerElement as b,\n isCustomPickerElementRegistered as c,\n destroyWidget as d,\n registerCustomPickerElement as e,\n renderCustomPickerElement as f,\n getCustomPickerElementSize as g,\n hasInteractiveView as h,\n isWidgetRegistered as i,\n hasFullWidth as j,\n registerWidget as r\n};\n//# sourceMappingURL=customPickerElements-4pQTZUnk.mjs.map\n","/**\n * @typedef {import('unist').Node} Node\n */\n\n/**\n * @typedef {Array | string} ChildrenOrValue\n * List to use as `children` or value to use as `value`.\n *\n * @typedef {Record} Props\n * Other fields to add to the node.\n */\n\n/**\n * Build a node.\n *\n * @template {string} T\n * @template {Props} P\n * @template {Array} C\n *\n * @overload\n * @param {T} type\n * @returns {{type: T}}\n *\n * @overload\n * @param {T} type\n * @param {P} props\n * @returns {{type: T} & P}\n *\n * @overload\n * @param {T} type\n * @param {string} value\n * @returns {{type: T, value: string}}\n *\n * @overload\n * @param {T} type\n * @param {P} props\n * @param {string} value\n * @returns {{type: T, value: string} & P}\n *\n * @overload\n * @param {T} type\n * @param {C} children\n * @returns {{type: T, children: C}}\n *\n * @overload\n * @param {T} type\n * @param {P} props\n * @param {C} children\n * @returns {{type: T, children: C} & P}\n *\n * @param {string} type\n * Node type.\n * @param {ChildrenOrValue | Props | null | undefined} [props]\n * Fields assigned to node (default: `undefined`).\n * @param {ChildrenOrValue | null | undefined} [value]\n * Children of node or value of `node` (cast to string).\n * @returns {Node}\n * Built node.\n */\nexport function u(type, props, value) {\n /** @type {Node} */\n const node = {type: String(type)}\n\n if (\n (value === undefined || value === null) &&\n (typeof props === 'string' || Array.isArray(props))\n ) {\n value = props\n } else {\n Object.assign(node, props)\n }\n\n if (Array.isArray(value)) {\n // @ts-expect-error: create a parent.\n node.children = value\n } else if (value !== undefined && value !== null) {\n // @ts-expect-error: create a literal.\n node.value = String(value)\n }\n\n return node\n}\n","import { getBaseUrl, getRootUrl } from \"@nextcloud/router\";\nimport { u } from \"unist-builder\";\nimport { visit, SKIP } from \"unist-util-visit\";\nimport { defineComponent, h } from \"vue\";\nimport { l as logger } from \"./logger-D3RVzcfQ.mjs\";\n/*!\n * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nconst URL_PATTERN = /(\\s|^)(https?:\\/\\/)([-A-Z0-9+_.]+(?::[0-9]+)?(?:\\/[-A-Z0-9+&@#%?=~_|!:,.;()]*)*)(\\s|$)/ig;\nconst URL_PATTERN_AUTOLINK = /(\\s|\\(|^)((https?:\\/\\/)([-A-Z0-9+_.]+[-A-Z0-9]+(?::[0-9]+)?(?:\\/[-A-Z0-9+&@#%?=~_|!:,.;()]*)*))(?=\\s|\\)|$)/ig;\nconst NcLink = defineComponent({\n name: \"NcLink\",\n props: {\n href: {\n type: String,\n required: true\n }\n },\n render() {\n return h(\"a\", {\n href: this.href,\n rel: \"noopener noreferrer\",\n target: \"_blank\",\n class: \"rich-text--external-link\"\n }, [this.href.trim()]);\n }\n});\nfunction remarkAutolink({ autolink, useMarkdown, useExtendedMarkdown }) {\n return function(tree) {\n if (useExtendedMarkdown || !useMarkdown || !autolink) {\n return;\n }\n visit(tree, (node) => node.type === \"text\", (node, index, parent) => {\n let parsed = parseUrl(node.value);\n if (typeof parsed === \"string\") {\n parsed = [u(\"text\", parsed)];\n } else {\n parsed = parsed.map((n) => {\n if (typeof n === \"string\") {\n return u(\"text\", n);\n }\n return u(\"link\", {\n url: n.props.href\n }, [u(\"text\", n.props.href)]);\n }).filter((x) => x).flat();\n }\n parent.children.splice(index, 1, ...parsed);\n return [SKIP, (index ?? 0) + parsed.length];\n });\n };\n}\nfunction parseUrl(text) {\n let match = URL_PATTERN_AUTOLINK.exec(text);\n const list = [];\n let start = 0;\n while (match !== null) {\n let href = match[2];\n let textAfter;\n let textBefore = text.substring(start, match.index + match[1].length);\n if (href[0] === \" \") {\n textBefore += href[0];\n href = href.substring(1).trim();\n }\n const lastChar = href[href.length - 1];\n if (lastChar === \".\" || lastChar === \",\" || lastChar === \";\" || match[0][0] === \"(\" && lastChar === \")\") {\n href = href.substring(0, href.length - 1);\n textAfter = lastChar;\n }\n list.push(textBefore);\n list.push({ component: NcLink, props: { href } });\n if (textAfter) {\n list.push(textAfter);\n }\n start = match.index + match[0].length;\n match = URL_PATTERN_AUTOLINK.exec(text);\n }\n list.push(text.substring(start));\n const joinedText = list.map((item) => typeof item === \"string\" ? item : item.props.href).join(\"\");\n if (text === joinedText) {\n return list;\n }\n logger.error(\"[NcRichText] Failed to reassemble the chunked text: \" + text);\n return text;\n}\nfunction getRoute(router, url) {\n const removePrefix = (str, prefix) => str.startsWith(prefix) ? str.slice(prefix.length) : str;\n const removePrefixes = (str, ...prefixes) => prefixes.reduce((acc, prefix) => removePrefix(acc, prefix), str);\n if (!router) {\n return null;\n }\n const isAbsoluteURL = /^https?:\\/\\//.test(url);\n const isNonHttpLink = /^[a-z][a-z0-9+.-]*:.+/.test(url);\n if (!isAbsoluteURL && isNonHttpLink) {\n return null;\n }\n if (isAbsoluteURL && !url.startsWith(getBaseUrl())) {\n return null;\n }\n if (!isAbsoluteURL && !url.startsWith(\"/\")) {\n return null;\n }\n const relativeUrl = isAbsoluteURL ? removePrefixes(url, getBaseUrl(), \"/index.php\") : url;\n const relativeRouterBase = removePrefixes(router.options.history.base, getRootUrl(), \"/index.php\");\n const potentialRouterPath = removePrefixes(relativeUrl, relativeRouterBase) || \"/\";\n const route = router.resolve(potentialRouterPath);\n if (!route.matched.length) {\n return null;\n }\n return route.fullPath;\n}\nexport {\n URL_PATTERN as U,\n getRoute as g,\n parseUrl as p,\n remarkAutolink as r\n};\n//# sourceMappingURL=autolink-U5pBzLgI.mjs.map\n","import { defineComponent, mergeModels, useModel, useTemplateRef, computed, createBlock, openBlock, unref, mergeProps, createSlots, withCtx, renderSlot } from \"vue\";\nimport { m as mdiArrowRight, a as mdiUndo, b as mdiClose } from \"./mdi-D_GPbmUY.mjs\";\nimport { r as register, a as t } from \"./_l10n-CeXHJQB0.mjs\";\nimport { N as NcIconSvgWrapper } from \"./NcIconSvgWrapper-5AA93z-F.mjs\";\nimport { N as NcInputField } from \"./NcInputField-D5lRaUiK.mjs\";\nregister();\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcTextField\",\n props: /* @__PURE__ */ mergeModels({\n class: {},\n inputClass: {},\n id: {},\n label: {},\n labelOutside: { type: Boolean },\n type: {},\n placeholder: {},\n showTrailingButton: { type: Boolean },\n trailingButtonLabel: { default: void 0 },\n success: { type: Boolean },\n error: { type: Boolean },\n helperText: {},\n disabled: { type: Boolean },\n pill: { type: Boolean },\n trailingButtonIcon: { default: \"close\" }\n }, {\n \"modelValue\": { default: \"\" },\n \"modelModifiers\": {}\n }),\n emits: [\"update:modelValue\"],\n setup(__props, { expose: __expose }) {\n const modelValue = useModel(__props, \"modelValue\");\n const props = __props;\n __expose({\n focus,\n select\n });\n const inputFieldInstance = useTemplateRef(\"inputField\");\n const defaultTrailingButtonLabels = {\n arrowEnd: t(\"Save changes\"),\n close: t(\"Clear text\"),\n undo: t(\"Undo changes\")\n };\n const NcInputFieldPropNames = new Set(Object.keys(NcInputField.props));\n const propsToForward = computed(() => {\n const sharedProps = Object.fromEntries(Object.entries(props).filter(([key]) => NcInputFieldPropNames.has(key)));\n sharedProps.trailingButtonLabel ??= defaultTrailingButtonLabels[props.trailingButtonIcon];\n return sharedProps;\n });\n function focus(options) {\n inputFieldInstance.value.focus(options);\n }\n function select() {\n inputFieldInstance.value.select();\n }\n return (_ctx, _cache) => {\n return openBlock(), createBlock(unref(NcInputField), mergeProps(propsToForward.value, {\n ref: \"inputField\",\n modelValue: modelValue.value,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => modelValue.value = $event)\n }), createSlots({ _: 2 }, [\n !!_ctx.$slots.icon ? {\n name: \"icon\",\n fn: withCtx(() => [\n renderSlot(_ctx.$slots, \"icon\")\n ]),\n key: \"0\"\n } : void 0,\n _ctx.type !== \"search\" ? {\n name: \"trailing-button-icon\",\n fn: withCtx(() => [\n _ctx.trailingButtonIcon === \"arrowEnd\" ? (openBlock(), createBlock(unref(NcIconSvgWrapper), {\n key: 0,\n directional: \"\",\n path: unref(mdiArrowRight)\n }, null, 8, [\"path\"])) : (openBlock(), createBlock(unref(NcIconSvgWrapper), {\n key: 1,\n path: _ctx.trailingButtonIcon === \"undo\" ? unref(mdiUndo) : unref(mdiClose)\n }, null, 8, [\"path\"]))\n ]),\n key: \"1\"\n } : void 0\n ]), 1040, [\"modelValue\"]);\n };\n }\n});\nexport {\n _sfc_main as _\n};\n//# sourceMappingURL=NcTextField.vue_vue_type_script_setup_true_lang-C7tMhmsN.mjs.map\n","import '../assets/referencePickerModal-B9tq1n_R.css';\nimport { createElementBlock, openBlock, mergeProps, createElementVNode, createCommentVNode, toDisplayString, resolveComponent, createVNode, withCtx, ref, nextTick, normalizeClass, createBlock, resolveDynamicComponent, normalizeStyle, createTextVNode, withKeys, withModifiers, createApp } from \"vue\";\nimport { emit } from \"@nextcloud/event-bus\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nimport { I as IconClose } from \"./Close-D6ngJ4t9.mjs\";\nimport { f as renderCustomPickerElement, b as destroyCustomPickerElement, c as isCustomPickerElementRegistered, d as destroyWidget, a as renderWidget, i as isWidgetRegistered, h as hasInteractiveView, j as hasFullWidth, g as getCustomPickerElementSize } from \"./customPickerElements-4pQTZUnk.mjs\";\nimport axios from \"@nextcloud/axios\";\nimport { loadState } from \"@nextcloud/initial-state\";\nimport { imagePath, generateOcsUrl } from \"@nextcloud/router\";\nimport { r as register, F as t8, a as t, G as t43, H as t39, I as t23, J as t24, j as t41, K as t31, p as t19, L as t12 } from \"./_l10n-CeXHJQB0.mjs\";\nimport { l as logger } from \"./logger-D3RVzcfQ.mjs\";\nimport { N as NcEmptyContent } from \"./NcEmptyContent-BdOezubv.mjs\";\nimport { _ as _sfc_main$a } from \"./NcHighlight.vue_vue_type_script_lang-DnWQDM_2.mjs\";\nimport { N as NcSelect } from \"./NcSelect-D8ZEOizf.mjs\";\nimport debounce from \"debounce\";\nimport { useElementSize, useIntersectionObserver } from \"@vueuse/core\";\nimport { RouterLink } from \"vue-router\";\nimport { N as NcButton } from \"./NcButton-DkC5k3Lb.mjs\";\nimport { g as getRoute } from \"./autolink-U5pBzLgI.mjs\";\nimport { N as NcLoadingIcon } from \"./NcLoadingIcon-b_ajZ_nQ.mjs\";\nimport { _ as _sfc_main$b } from \"./NcTextField.vue_vue_type_script_setup_true_lang-C7tMhmsN.mjs\";\nimport { I as IconDotsHorizontal } from \"./NcActions-B1Zg0lCE.mjs\";\nimport { N as NcModal } from \"./NcModal-vyUsS1qu.mjs\";\nconst _sfc_main$9 = {\n name: \"ArrowLeftIcon\",\n emits: [\"click\"],\n props: {\n title: {\n type: String\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n};\nconst _hoisted_1$9 = [\"aria-hidden\", \"aria-label\"];\nconst _hoisted_2$7 = [\"fill\", \"width\", \"height\"];\nconst _hoisted_3$6 = { d: \"M20,11V13H8L13.5,18.5L12.08,19.92L4.16,12L12.08,4.08L13.5,5.5L8,11H20Z\" };\nconst _hoisted_4$5 = { key: 0 };\nfunction _sfc_render$9(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"span\", mergeProps(_ctx.$attrs, {\n \"aria-hidden\": $props.title ? null : \"true\",\n \"aria-label\": $props.title,\n class: \"material-design-icon arrow-left-icon\",\n role: \"img\",\n onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit(\"click\", $event))\n }), [\n (openBlock(), createElementBlock(\"svg\", {\n fill: $props.fillColor,\n class: \"material-design-icon__svg\",\n width: $props.size,\n height: $props.size,\n viewBox: \"0 0 24 24\"\n }, [\n createElementVNode(\"path\", _hoisted_3$6, [\n $props.title ? (openBlock(), createElementBlock(\"title\", _hoisted_4$5, toDisplayString($props.title), 1)) : createCommentVNode(\"\", true)\n ])\n ], 8, _hoisted_2$7))\n ], 16, _hoisted_1$9);\n}\nconst ArrowLeftIcon = /* @__PURE__ */ _export_sfc(_sfc_main$9, [[\"render\", _sfc_render$9]]);\nconst _sfc_main$8 = {\n name: \"NcCustomPickerElement\",\n props: {\n /**\n * The reference provider\n */\n provider: {\n type: Object,\n required: true\n }\n },\n emits: [\n \"cancel\",\n \"submit\"\n ],\n data() {\n return {\n isRegistered: isCustomPickerElementRegistered(this.provider.id),\n renderResult: null\n };\n },\n mounted() {\n if (this.isRegistered) {\n this.renderElement();\n }\n },\n beforeUnmount() {\n if (this.isRegistered) {\n destroyCustomPickerElement(this.provider.id, this.$el, this.renderResult);\n }\n },\n methods: {\n renderElement() {\n if (this.$refs.domElement) {\n this.$refs.domElement.innerHTML = \"\";\n }\n const renderFunctionResult = renderCustomPickerElement(this.$refs.domElement, { providerId: this.provider.id, accessible: false });\n Promise.resolve(renderFunctionResult).then((result) => {\n this.renderResult = result;\n if (this.renderResult.object?._isVue && this.renderResult.object?.$on) {\n this.renderResult.object.$on(\"submit\", this.onSubmit);\n this.renderResult.object.$on(\"cancel\", this.onCancel);\n }\n this.renderResult.element.addEventListener(\"submit\", (e) => {\n this.onSubmit(e.detail);\n });\n this.renderResult.element.addEventListener(\"cancel\", this.onCancel);\n });\n },\n onSubmit(value) {\n this.$emit(\"submit\", value);\n },\n onCancel() {\n this.$emit(\"cancel\");\n }\n }\n};\nconst _hoisted_1$8 = { ref: \"domElement\" };\nfunction _sfc_render$8(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"div\", _hoisted_1$8, null, 512);\n}\nconst NcCustomPickerElement = /* @__PURE__ */ _export_sfc(_sfc_main$8, [[\"render\", _sfc_render$8], [\"__scopeId\", \"data-v-e408867a\"]]);\nconst _sfc_main$7 = {\n name: \"LinkVariantIcon\",\n emits: [\"click\"],\n props: {\n title: {\n type: String\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n};\nconst _hoisted_1$7 = [\"aria-hidden\", \"aria-label\"];\nconst _hoisted_2$6 = [\"fill\", \"width\", \"height\"];\nconst _hoisted_3$5 = { d: \"M10.59,13.41C11,13.8 11,14.44 10.59,14.83C10.2,15.22 9.56,15.22 9.17,14.83C7.22,12.88 7.22,9.71 9.17,7.76V7.76L12.71,4.22C14.66,2.27 17.83,2.27 19.78,4.22C21.73,6.17 21.73,9.34 19.78,11.29L18.29,12.78C18.3,11.96 18.17,11.14 17.89,10.36L18.36,9.88C19.54,8.71 19.54,6.81 18.36,5.64C17.19,4.46 15.29,4.46 14.12,5.64L10.59,9.17C9.41,10.34 9.41,12.24 10.59,13.41M13.41,9.17C13.8,8.78 14.44,8.78 14.83,9.17C16.78,11.12 16.78,14.29 14.83,16.24V16.24L11.29,19.78C9.34,21.73 6.17,21.73 4.22,19.78C2.27,17.83 2.27,14.66 4.22,12.71L5.71,11.22C5.7,12.04 5.83,12.86 6.11,13.65L5.64,14.12C4.46,15.29 4.46,17.19 5.64,18.36C6.81,19.54 8.71,19.54 9.88,18.36L13.41,14.83C14.59,13.66 14.59,11.76 13.41,10.59C13,10.2 13,9.56 13.41,9.17Z\" };\nconst _hoisted_4$4 = { key: 0 };\nfunction _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"span\", mergeProps(_ctx.$attrs, {\n \"aria-hidden\": $props.title ? null : \"true\",\n \"aria-label\": $props.title,\n class: \"material-design-icon link-variant-icon\",\n role: \"img\",\n onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit(\"click\", $event))\n }), [\n (openBlock(), createElementBlock(\"svg\", {\n fill: $props.fillColor,\n class: \"material-design-icon__svg\",\n width: $props.size,\n height: $props.size,\n viewBox: \"0 0 24 24\"\n }, [\n createElementVNode(\"path\", _hoisted_3$5, [\n $props.title ? (openBlock(), createElementBlock(\"title\", _hoisted_4$4, toDisplayString($props.title), 1)) : createCommentVNode(\"\", true)\n ])\n ], 8, _hoisted_2$6))\n ], 16, _hoisted_1$7);\n}\nconst LinkVariantIcon = /* @__PURE__ */ _export_sfc(_sfc_main$7, [[\"render\", _sfc_render$7]]);\nregister(t8);\nconst anyLinkProviderId = \"any-link\";\nconst anyLinkProvider = {\n id: anyLinkProviderId,\n title: t(\"Any link\"),\n order: 0,\n icon_url: imagePath(\"core\", \"filetypes/link.svg\")\n};\nwindow._vue_richtext_reference_providers ??= loadState(\"core\", \"reference-provider-list\", []);\nwindow._vue_richtext_reference_provider_timestamps ??= loadState(\"core\", \"reference-provider-timestamps\", {});\nfunction getProvider(providerId) {\n if (providerId === anyLinkProviderId) {\n return anyLinkProvider;\n }\n return getProviders().find((p) => p.id === providerId);\n}\nfunction getProviders() {\n return window._vue_richtext_reference_providers.filter((p) => {\n const keep = !!p.search_providers_ids && p.search_providers_ids.length > 0 || isCustomPickerElementRegistered(p.id);\n if (!keep) {\n logger.debug(`[smart picker] ${p.id} reference provider is discoverable but does not have any related search provider or custom picker component registered`);\n }\n return keep;\n });\n}\nfunction sortProviders(providerList) {\n const timestamps = window._vue_richtext_reference_provider_timestamps;\n return providerList.sort((a, b) => {\n return a.order === b.order ? 0 : a.order > b.order ? 1 : -1;\n }).sort((a, b) => {\n const ta = timestamps[a.id];\n const tb = timestamps[b.id];\n return ta === tb ? 0 : tb === void 0 ? -1 : ta === void 0 ? 1 : ta > tb ? -1 : 1;\n });\n}\nfunction searchProvider(query, limit) {\n const providers = getProviders();\n const escapedQuery = query.replace(/[/\\-\\\\^$*+?.()|[\\]{}]/g, \"\\\\$&\");\n const regexp = new RegExp(escapedQuery, \"i\");\n const sortedProviders = sortProviders(providers);\n const filteredSortedProviders = sortedProviders.filter((p) => {\n return p.title.match(regexp);\n });\n const searchResult = limit ? filteredSortedProviders.slice(0, limit) : filteredSortedProviders;\n if (query === \"\" || searchResult.length === 0) {\n searchResult.push(anyLinkProvider);\n }\n return searchResult;\n}\nasync function touchProvider(providerId) {\n const timestamp = Math.floor(Date.now() / 1e3);\n const url = generateOcsUrl(\"references/provider/{providerId}\", { providerId });\n await axios.put(url, { timestamp });\n window._vue_richtext_reference_provider_timestamps[providerId] = timestamp;\n}\nregister(t39, t43);\n/*!\n * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction isUrl(str) {\n try {\n return Boolean(new URL(str));\n } catch {\n return false;\n }\n}\nconst _sfc_main$6 = {\n name: \"NcProviderList\",\n components: {\n NcSelect,\n NcHighlight: _sfc_main$a,\n NcEmptyContent,\n LinkVariantIcon\n },\n emits: [\n \"selectProvider\",\n \"submit\"\n ],\n data() {\n return {\n selectedProvider: null,\n query: \"\",\n multiselectPlaceholder: t(\"Select provider\"),\n providerIconAlt: t(\"Provider icon\")\n };\n },\n computed: {\n options() {\n const result = [];\n if (this.query !== \"\" && isUrl(this.query)) {\n result.push({\n id: this.query,\n title: this.query,\n isLink: true\n });\n }\n result.push(...searchProvider(this.query));\n return result;\n }\n },\n methods: {\n focus() {\n setTimeout(() => {\n this.$refs[\"provider-select\"]?.$el?.querySelector(\"#provider-select-input\")?.focus();\n }, 300);\n },\n onProviderSelected(p) {\n if (p !== null) {\n if (p.isLink) {\n this.$emit(\"submit\", p.title);\n } else {\n this.$emit(\"selectProvider\", p);\n }\n this.selectedProvider = null;\n }\n },\n onSearch(query) {\n this.query = query;\n }\n }\n};\nconst _hoisted_1$6 = { class: \"provider-list\" };\nconst _hoisted_2$5 = {\n key: 0,\n class: \"provider\"\n};\nconst _hoisted_3$4 = {\n key: 1,\n class: \"provider\"\n};\nconst _hoisted_4$3 = [\"src\", \"alt\"];\nfunction _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_LinkVariantIcon = resolveComponent(\"LinkVariantIcon\");\n const _component_NcHighlight = resolveComponent(\"NcHighlight\");\n const _component_NcSelect = resolveComponent(\"NcSelect\");\n const _component_NcEmptyContent = resolveComponent(\"NcEmptyContent\");\n return openBlock(), createElementBlock(\"div\", _hoisted_1$6, [\n createVNode(_component_NcSelect, {\n ref: \"provider-select\",\n modelValue: $data.selectedProvider,\n \"onUpdate:modelValue\": [\n _cache[0] || (_cache[0] = ($event) => $data.selectedProvider = $event),\n $options.onProviderSelected\n ],\n class: \"provider-list--select\",\n \"input-id\": \"provider-select-input\",\n label: \"title\",\n placeholder: $data.multiselectPlaceholder,\n options: $options.options,\n \"append-to-body\": false,\n \"clear-search-on-select\": true,\n \"clear-search-on-blur\": () => false,\n filterable: false,\n onSearch: $options.onSearch\n }, {\n option: withCtx((option) => [\n option.isLink ? (openBlock(), createElementBlock(\"div\", _hoisted_2$5, [\n createVNode(_component_LinkVariantIcon, {\n class: \"link-icon\",\n size: 20\n }),\n createElementVNode(\"span\", null, toDisplayString(option.title), 1)\n ])) : (openBlock(), createElementBlock(\"div\", _hoisted_3$4, [\n createElementVNode(\"img\", {\n class: \"provider-icon\",\n src: option.icon_url,\n alt: $data.providerIconAlt\n }, null, 8, _hoisted_4$3),\n createVNode(_component_NcHighlight, {\n class: \"option-text\",\n search: $data.query,\n text: option.title\n }, null, 8, [\"search\", \"text\"])\n ]))\n ]),\n _: 1\n }, 8, [\"modelValue\", \"placeholder\", \"options\", \"onSearch\", \"onUpdate:modelValue\"]),\n createVNode(_component_NcEmptyContent, { class: \"provider-list--empty-content\" }, {\n icon: withCtx(() => [\n createVNode(_component_LinkVariantIcon)\n ]),\n _: 1\n })\n ]);\n}\nconst NcProviderList = /* @__PURE__ */ _export_sfc(_sfc_main$6, [[\"render\", _sfc_render$6], [\"__scopeId\", \"data-v-90c6aa3b\"]]);\nregister(t23);\nconst IDLE_TIMEOUT = 3 * 60 * 1e3;\nconst _sfc_main$5 = {\n name: \"NcReferenceWidget\",\n components: {\n NcButton\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n reference: {\n type: Object,\n required: true\n },\n interactive: {\n type: Boolean,\n default: true\n },\n interactiveOptIn: {\n type: Boolean,\n default: false\n }\n },\n setup() {\n const isVisible = ref(false);\n const widgetRoot = ref();\n const { width } = useElementSize(widgetRoot);\n useIntersectionObserver(widgetRoot, ([entry]) => {\n nextTick(() => {\n isVisible.value = entry.isIntersecting;\n });\n });\n return {\n width,\n isVisible,\n widgetRoot\n };\n },\n data() {\n return {\n showInteractive: false,\n rendered: false,\n idleTimeout: null\n };\n },\n computed: {\n isInteractive() {\n return !this.interactiveOptIn && this.interactive || this.showInteractive;\n },\n hasFullWidth() {\n return hasFullWidth(this.reference.richObjectType);\n },\n hasCustomWidget() {\n return isWidgetRegistered(this.reference.richObjectType);\n },\n hasInteractiveView() {\n return isWidgetRegistered(this.reference.richObjectType) && hasInteractiveView(this.reference.richObjectType);\n },\n noAccess() {\n return this.reference && !this.reference.accessible;\n },\n descriptionStyle() {\n if (this.numberOfLines === 0) {\n return {\n display: \"none\"\n };\n }\n const lineClamp = this.numberOfLines;\n return {\n lineClamp,\n webkitLineClamp: lineClamp\n };\n },\n numberOfLines() {\n const lineCountOffsets = [450, 550, 650, Infinity];\n return lineCountOffsets.findIndex((max) => this.width < max);\n },\n compactLink() {\n const link = this.reference.openGraphObject.link;\n if (!link) {\n return \"\";\n }\n if (link.startsWith(\"https://\")) {\n return link.substring(8);\n }\n if (link.startsWith(\"http://\")) {\n return link.substring(7);\n }\n return link;\n },\n route() {\n return getRoute(this.$router, this.reference.openGraphObject.link);\n },\n referenceWidgetLinkComponent() {\n return this.route ? RouterLink : \"a\";\n },\n referenceWidgetLinkProps() {\n return this.route ? { to: this.route } : { href: this.reference.openGraphObject.link, target: \"_blank\" };\n }\n },\n watch: {\n isVisible: {\n handler(val) {\n if (!val) {\n this.idleTimeout = setTimeout(() => {\n if (!this.isVisible) {\n this.destroyWidget();\n }\n }, IDLE_TIMEOUT);\n return;\n }\n if (this.idleTimeout) {\n clearTimeout(this.idleTimeout);\n this.idleTimeout = null;\n }\n if (!this.rendered) {\n this.renderWidget();\n }\n },\n immediate: true\n }\n },\n beforeUnmount() {\n this.destroyWidget();\n },\n methods: {\n t,\n enableInteractive() {\n this.showInteractive = true;\n this.renderWidget();\n },\n renderWidget() {\n if (!this.$refs.customWidget) {\n return;\n }\n if (this?.reference?.richObjectType === \"open-graph\") {\n return;\n }\n this.$refs.customWidget.innerHTML = \"\";\n const widget = document.createElement(\"div\");\n widget.style = \"width: 100%;\";\n this.$refs.customWidget.appendChild(widget);\n this.$nextTick(() => {\n renderWidget(widget, {\n ...this.reference,\n interactive: this.isInteractive\n });\n this.rendered = true;\n });\n },\n destroyWidget() {\n if (this.rendered) {\n destroyWidget(this.reference.richObjectType, this.$el);\n this.rendered = false;\n }\n }\n }\n};\nconst _hoisted_1$5 = [\"src\"];\nconst _hoisted_2$4 = { class: \"widget-default--details\" };\nconst _hoisted_3$3 = { class: \"widget-default--name\" };\nconst _hoisted_4$2 = { class: \"widget-default--link\" };\nfunction _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcButton = resolveComponent(\"NcButton\");\n return openBlock(), createElementBlock(\"div\", {\n ref: \"widgetRoot\",\n class: normalizeClass({ \"toggle-interactive\": $options.hasInteractiveView && !$options.isInteractive })\n }, [\n $props.reference && $options.hasCustomWidget ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n ref: \"customWidget\",\n class: normalizeClass([\"widget-custom\", { \"full-width\": $options.hasFullWidth }])\n }, null, 2)) : !$options.noAccess && $props.reference && $props.reference.openGraphObject && !$options.hasCustomWidget ? (openBlock(), createBlock(resolveDynamicComponent($options.referenceWidgetLinkComponent), mergeProps({ key: 1 }, $options.referenceWidgetLinkProps, {\n rel: \"noopener noreferrer\",\n class: \"widget-default\"\n }), {\n default: withCtx(() => [\n $props.reference.openGraphObject.thumb ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"widget-default--image\",\n src: $props.reference.openGraphObject.thumb\n }, null, 8, _hoisted_1$5)) : createCommentVNode(\"\", true),\n createElementVNode(\"div\", _hoisted_2$4, [\n createElementVNode(\"p\", _hoisted_3$3, toDisplayString($props.reference.openGraphObject.name), 1),\n createElementVNode(\"p\", {\n class: \"widget-default--description\",\n style: normalizeStyle($options.descriptionStyle)\n }, toDisplayString($props.reference.openGraphObject.description), 5),\n createElementVNode(\"p\", _hoisted_4$2, toDisplayString($options.compactLink), 1)\n ])\n ]),\n _: 1\n }, 16)) : createCommentVNode(\"\", true),\n $props.interactiveOptIn && $options.hasInteractiveView && !$options.isInteractive ? (openBlock(), createBlock(_component_NcButton, {\n key: 2,\n class: \"toggle-interactive--button\",\n onClick: $options.enableInteractive\n }, {\n default: withCtx(() => [\n createTextVNode(toDisplayString($options.t(\"Enable interactive view\")), 1)\n ]),\n _: 1\n }, 8, [\"onClick\"])) : createCommentVNode(\"\", true)\n ], 2);\n}\nconst NcReferenceWidget = /* @__PURE__ */ _export_sfc(_sfc_main$5, [[\"render\", _sfc_render$5], [\"__scopeId\", \"data-v-17076b70\"]]);\nregister(t24);\nconst _sfc_main$4 = {\n name: \"NcRawLinkInput\",\n components: {\n LinkVariantIcon,\n NcEmptyContent,\n NcLoadingIcon,\n NcReferenceWidget,\n NcTextField: _sfc_main$b\n },\n props: {\n /**\n * The reference provider\n */\n provider: {\n type: Object,\n required: true\n }\n },\n emits: [\n \"submit\"\n ],\n data() {\n return {\n inputValue: \"\",\n loading: false,\n reference: null,\n abortController: null,\n inputPlaceholder: t(\"Enter link\")\n };\n },\n computed: {\n isLinkValid() {\n return isUrl(this.inputValue);\n },\n debouncedUpdateReference() {\n return debounce(this.updateReference, 500);\n }\n },\n methods: {\n focus() {\n this.$refs[\"url-input\"].$el.getElementsByTagName(\"input\")[0]?.focus();\n },\n onSubmit(e) {\n const value = e.target.value;\n if (this.isLinkValid) {\n this.$emit(\"submit\", value);\n }\n },\n onClear() {\n this.inputValue = \"\";\n this.reference = null;\n },\n onInput() {\n this.reference = null;\n if (this.abortController) {\n this.abortController.abort();\n }\n if (this.isLinkValid) {\n this.debouncedUpdateReference();\n }\n },\n updateReference() {\n this.loading = true;\n this.abortController = new AbortController();\n axios.get(generateOcsUrl(\"references/resolve\", 2) + \"?reference=\" + encodeURIComponent(this.inputValue), {\n signal: this.abortController.signal\n }).then((response) => {\n this.reference = response.data.ocs.data.references[this.inputValue];\n }).catch((error) => {\n logger.error(\"[NcRawLinkInput] Failed to update reference\", { error });\n }).then(() => {\n this.loading = false;\n });\n }\n }\n};\nconst _hoisted_1$4 = { class: \"raw-link\" };\nconst _hoisted_2$3 = { class: \"input-wrapper\" };\nconst _hoisted_3$2 = [\"src\"];\nfunction _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcLoadingIcon = resolveComponent(\"NcLoadingIcon\");\n const _component_LinkVariantIcon = resolveComponent(\"LinkVariantIcon\");\n const _component_NcTextField = resolveComponent(\"NcTextField\");\n const _component_NcReferenceWidget = resolveComponent(\"NcReferenceWidget\");\n const _component_NcEmptyContent = resolveComponent(\"NcEmptyContent\");\n return openBlock(), createElementBlock(\"div\", _hoisted_1$4, [\n createElementVNode(\"div\", _hoisted_2$3, [\n createVNode(_component_NcTextField, {\n ref: \"url-input\",\n modelValue: $data.inputValue,\n \"onUpdate:modelValue\": [\n _cache[0] || (_cache[0] = ($event) => $data.inputValue = $event),\n $options.onInput\n ],\n \"show-trailing-button\": $data.inputValue !== \"\",\n label: $data.inputPlaceholder,\n onTrailingButtonClick: $options.onClear,\n onKeyup: withKeys($options.onSubmit, [\"enter\"])\n }, {\n default: withCtx(() => [\n $data.loading ? (openBlock(), createBlock(_component_NcLoadingIcon, {\n key: 0,\n size: 16\n })) : (openBlock(), createBlock(_component_LinkVariantIcon, {\n key: 1,\n size: 16\n }))\n ]),\n _: 1\n }, 8, [\"modelValue\", \"show-trailing-button\", \"label\", \"onTrailingButtonClick\", \"onUpdate:modelValue\", \"onKeyup\"])\n ]),\n $data.reference !== null ? (openBlock(), createBlock(_component_NcReferenceWidget, {\n key: 0,\n class: \"reference-widget\",\n reference: $data.reference\n }, null, 8, [\"reference\"])) : (openBlock(), createBlock(_component_NcEmptyContent, {\n key: 1,\n class: \"raw-link--empty-content\"\n }, {\n icon: withCtx(() => [\n $props.provider.icon_url ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"provider-icon\",\n src: $props.provider.icon_url\n }, null, 8, _hoisted_3$2)) : (openBlock(), createBlock(_component_LinkVariantIcon, { key: 1 }))\n ]),\n _: 1\n }))\n ]);\n}\nconst NcRawLinkInput = /* @__PURE__ */ _export_sfc(_sfc_main$4, [[\"render\", _sfc_render$4], [\"__scopeId\", \"data-v-6d7fc06a\"]]);\nconst _sfc_main$3 = {\n name: \"NcSearchResult\",\n components: {\n NcHighlight: _sfc_main$a\n },\n props: {\n /**\n * Unified search result entry\n */\n entry: {\n type: Object,\n required: true\n },\n /**\n * The query that led to getting this result\n * Used to highlight the entry text\n */\n query: {\n type: String,\n required: true\n }\n }\n};\nconst _hoisted_1$3 = { class: \"result\" };\nconst _hoisted_2$2 = [\"src\"];\nconst _hoisted_3$1 = { class: \"result--content\" };\nconst _hoisted_4$1 = { class: \"result--content--name\" };\nconst _hoisted_5$1 = { class: \"result--content--subline\" };\nfunction _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcHighlight = resolveComponent(\"NcHighlight\");\n return openBlock(), createElementBlock(\"div\", _hoisted_1$3, [\n $props.entry.icon ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n class: normalizeClass([{ [$props.entry.icon]: true, rounded: $props.entry.rounded }, \"result--icon-class\"])\n }, null, 2)) : (openBlock(), createElementBlock(\"img\", {\n key: 1,\n class: normalizeClass([\"result--image\", { rounded: $props.entry.rounded }]),\n src: $props.entry.thumbnailUrl\n }, null, 10, _hoisted_2$2)),\n createElementVNode(\"div\", _hoisted_3$1, [\n createElementVNode(\"span\", _hoisted_4$1, [\n createVNode(_component_NcHighlight, {\n search: $props.query,\n text: $props.entry.title\n }, null, 8, [\"search\", \"text\"])\n ]),\n createElementVNode(\"span\", _hoisted_5$1, [\n createVNode(_component_NcHighlight, {\n search: $props.query,\n text: $props.entry.subline\n }, null, 8, [\"search\", \"text\"])\n ])\n ])\n ]);\n}\nconst NcSearchResult = /* @__PURE__ */ _export_sfc(_sfc_main$3, [[\"render\", _sfc_render$3], [\"__scopeId\", \"data-v-059edcfb\"]]);\nregister(t31, t39, t41);\nconst LIMIT = 5;\nconst _sfc_main$2 = {\n name: \"NcSearch\",\n components: {\n LinkVariantIcon,\n DotsHorizontalIcon: IconDotsHorizontal,\n NcEmptyContent,\n NcSelect,\n NcSearchResult\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n /**\n * The selected reference provider\n */\n provider: {\n type: Object,\n required: true\n },\n showEmptyContent: {\n type: Boolean,\n default: true\n },\n /**\n * Placeholder of the search\n */\n searchPlaceholder: {\n type: String,\n default: null\n }\n },\n emits: [\n \"submit\"\n ],\n data() {\n return {\n searchQuery: \"\",\n selectedResult: null,\n resultsBySearchProvider: {},\n searching: false,\n searchingMoreOf: null,\n abortController: null,\n noOptionsText: t(\"Start typing to search\"),\n providerIconAlt: t(\"Provider icon\")\n };\n },\n computed: {\n mySearchPlaceholder() {\n return this.searchPlaceholder || t(\"Search\");\n },\n searchProviderIds() {\n return this.provider.search_providers_ids;\n },\n options() {\n if (this.searchQuery === \"\") {\n return [];\n }\n const options = [];\n if (isUrl(this.searchQuery)) {\n options.push(this.rawLinkEntry);\n }\n options.push(...this.formattedSearchResults);\n return options;\n },\n rawLinkEntry() {\n return {\n id: \"rawLinkEntry\",\n resourceUrl: this.searchQuery,\n isRawLink: true\n };\n },\n formattedSearchResults() {\n const results = [];\n this.searchProviderIds.forEach((pid) => {\n if (this.resultsBySearchProvider[pid].entries.length > 0) {\n if (this.searchProviderIds.length > 1 || this.resultsBySearchProvider[pid].entries.length > 1) {\n results.push({\n id: \"groupTitle-\" + pid,\n name: this.resultsBySearchProvider[pid].name,\n isCustomGroupTitle: true,\n providerId: pid\n });\n }\n const providerEntriesWithId = this.resultsBySearchProvider[pid].entries.map((entry, index) => {\n return {\n id: \"provider-\" + pid + \"-entry-\" + index,\n ...entry\n };\n });\n results.push(...providerEntriesWithId);\n if (this.resultsBySearchProvider[pid].isPaginated) {\n results.push({\n id: \"moreOf-\" + pid,\n name: this.resultsBySearchProvider[pid].name,\n isMore: true,\n providerId: pid,\n isLoading: this.searchingMoreOf === pid\n });\n }\n }\n });\n return results;\n },\n debouncedUpdateSearch() {\n return debounce(this.updateSearch, 500);\n }\n },\n mounted() {\n this.resetResults();\n },\n beforeUnmount() {\n this.cancelSearchRequests();\n },\n methods: {\n t,\n resetResults() {\n const resultsBySearchProvider = {};\n this.searchProviderIds.forEach((pid) => {\n resultsBySearchProvider[pid] = {\n entries: []\n };\n });\n this.resultsBySearchProvider = resultsBySearchProvider;\n },\n focus() {\n setTimeout(() => {\n this.$refs[\"search-select\"]?.$el?.querySelector(\"#search-select-input\")?.focus();\n }, 300);\n },\n cancelSearchRequests() {\n if (this.abortController) {\n this.abortController.abort();\n }\n },\n onSearchInput(query) {\n this.searchQuery = query;\n this.debouncedUpdateSearch();\n },\n onSelectResultSelected(item) {\n if (item !== null) {\n if (item.resourceUrl) {\n this.cancelSearchRequests();\n this.$emit(\"submit\", item.resourceUrl);\n } else if (item.isMore) {\n this.searchMoreOf(item.providerId).then(() => {\n this.selectedResult = null;\n });\n }\n }\n },\n searchMoreOf(searchProviderId) {\n this.searchingMoreOf = searchProviderId;\n this.cancelSearchRequests();\n return this.searchProviders(searchProviderId);\n },\n updateSearch() {\n this.cancelSearchRequests();\n this.resetResults();\n if (this.searchQuery === \"\") {\n this.searching = false;\n return;\n }\n return this.searchProviders();\n },\n searchProviders(searchProviderId = null) {\n this.abortController = new AbortController();\n this.searching = true;\n const searchPromises = searchProviderId === null ? [...this.searchProviderIds].map((pid) => {\n return this.searchOneProvider(pid);\n }) : [this.searchOneProvider(searchProviderId, this.resultsBySearchProvider[searchProviderId]?.cursor ?? null)];\n return Promise.allSettled(searchPromises).then((promises) => {\n const isOneCanceled = !!promises.find((p) => {\n return p.status === \"rejected\" && (p.reason.name === \"CanceledError\" || p.reason.code === \"ERR_CANCELED\");\n });\n if (!isOneCanceled) {\n this.searching = false;\n this.searchingMoreOf = null;\n }\n });\n },\n searchOneProvider(providerId, cursor = null) {\n const url = cursor === null ? generateOcsUrl(\"search/providers/{providerId}/search?term={term}&limit={limit}\", { providerId, term: this.searchQuery, limit: LIMIT }) : generateOcsUrl(\"search/providers/{providerId}/search?term={term}&limit={limit}&cursor={cursor}\", { providerId, term: this.searchQuery, limit: LIMIT, cursor });\n return axios.get(url, {\n signal: this.abortController.signal\n }).then((response) => {\n const data = response.data.ocs.data;\n this.resultsBySearchProvider[providerId].name = data.name;\n this.resultsBySearchProvider[providerId].cursor = data.cursor;\n this.resultsBySearchProvider[providerId].isPaginated = data.isPaginated;\n this.resultsBySearchProvider[providerId].entries.push(...data.entries);\n });\n }\n }\n};\nconst _hoisted_1$2 = {\n key: 0,\n class: \"custom-option\"\n};\nconst _hoisted_2$1 = { class: \"option-text\" };\nconst _hoisted_3 = {\n key: 2,\n class: \"custom-option group-name\"\n};\nconst _hoisted_4 = [\"src\"];\nconst _hoisted_5 = { class: \"option-text\" };\nconst _hoisted_6 = {\n key: 3,\n class: \"custom-option\"\n};\nconst _hoisted_7 = {\n key: 0,\n class: \"option-simple-icon icon-loading-small\"\n};\nconst _hoisted_8 = { class: \"option-text\" };\nconst _hoisted_9 = [\"alt\", \"src\"];\nfunction _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_LinkVariantIcon = resolveComponent(\"LinkVariantIcon\");\n const _component_NcSearchResult = resolveComponent(\"NcSearchResult\");\n const _component_DotsHorizontalIcon = resolveComponent(\"DotsHorizontalIcon\");\n const _component_NcSelect = resolveComponent(\"NcSelect\");\n const _component_NcEmptyContent = resolveComponent(\"NcEmptyContent\");\n return openBlock(), createElementBlock(\"div\", {\n class: normalizeClass([\"smart-picker-search\", { \"with-empty-content\": $props.showEmptyContent }])\n }, [\n createVNode(_component_NcSelect, {\n ref: \"search-select\",\n modelValue: $data.selectedResult,\n \"onUpdate:modelValue\": [\n _cache[0] || (_cache[0] = ($event) => $data.selectedResult = $event),\n $options.onSelectResultSelected\n ],\n class: \"smart-picker-search--select\",\n \"input-id\": \"search-select-input\",\n label: \"name\",\n placeholder: $options.mySearchPlaceholder,\n options: $options.options,\n \"append-to-body\": false,\n \"close-on-select\": false,\n \"clear-search-on-select\": false,\n \"clear-search-on-blur\": () => false,\n \"reset-focus-on-options-change\": false,\n filterable: false,\n autoscroll: true,\n \"reset-on-options-change\": false,\n loading: $data.searching,\n onSearch: $options.onSearchInput\n }, {\n option: withCtx((option) => [\n option.isRawLink ? (openBlock(), createElementBlock(\"div\", _hoisted_1$2, [\n createVNode(_component_LinkVariantIcon, {\n class: \"option-simple-icon\",\n size: 20\n }),\n createElementVNode(\"span\", _hoisted_2$1, toDisplayString($options.t(\"Raw link {options}\", { options: option.resourceUrl })), 1)\n ])) : option.resourceUrl ? (openBlock(), createBlock(_component_NcSearchResult, {\n key: 1,\n class: \"search-result\",\n entry: option,\n query: $data.searchQuery\n }, null, 8, [\"entry\", \"query\"])) : option.isCustomGroupTitle ? (openBlock(), createElementBlock(\"span\", _hoisted_3, [\n $props.provider.icon_url ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"provider-icon group-name-icon\",\n src: $props.provider.icon_url\n }, null, 8, _hoisted_4)) : createCommentVNode(\"\", true),\n createElementVNode(\"span\", _hoisted_5, [\n createElementVNode(\"strong\", null, toDisplayString(option.name), 1)\n ])\n ])) : option.isMore ? (openBlock(), createElementBlock(\"span\", _hoisted_6, [\n option.isLoading ? (openBlock(), createElementBlock(\"span\", _hoisted_7)) : (openBlock(), createBlock(_component_DotsHorizontalIcon, {\n key: 1,\n class: \"option-simple-icon\",\n size: 20\n })),\n createElementVNode(\"span\", _hoisted_8, toDisplayString($options.t('Load more \"{options}\"', { options: option.name })), 1)\n ])) : createCommentVNode(\"\", true)\n ]),\n \"no-options\": withCtx(() => [\n createTextVNode(toDisplayString($data.noOptionsText), 1)\n ]),\n _: 1\n }, 8, [\"modelValue\", \"placeholder\", \"options\", \"loading\", \"onSearch\", \"onUpdate:modelValue\"]),\n $props.showEmptyContent ? (openBlock(), createBlock(_component_NcEmptyContent, {\n key: 0,\n class: \"smart-picker-search--empty-content\"\n }, {\n icon: withCtx(() => [\n $props.provider.icon_url ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"provider-icon\",\n alt: $data.providerIconAlt,\n src: $props.provider.icon_url\n }, null, 8, _hoisted_9)) : (openBlock(), createBlock(_component_LinkVariantIcon, { key: 1 }))\n ]),\n _: 1\n })) : createCommentVNode(\"\", true)\n ], 2);\n}\nconst NcSearch = /* @__PURE__ */ _export_sfc(_sfc_main$2, [[\"render\", _sfc_render$2], [\"__scopeId\", \"data-v-e8abf1d4\"]]);\nconst MODES = {\n providerList: 1,\n standardLinkInput: 2,\n searchInput: 3,\n customElement: 4\n};\nconst _sfc_main$1 = {\n name: \"NcReferencePicker\",\n components: {\n NcCustomPickerElement,\n NcProviderList,\n NcRawLinkInput,\n NcSearch\n },\n props: {\n /**\n * Provider to select on creation\n * Default: null. Show the provider list\n */\n initialProvider: {\n type: Object,\n default: () => null\n },\n /**\n * Optional width in pixels\n * Default: 100%\n */\n width: {\n type: Number,\n default: null\n },\n /**\n * Focus on the provider list select input on creation\n * Default: true\n */\n focusOnCreate: {\n type: Boolean,\n default: true\n }\n },\n emits: [\n \"cancel\",\n \"cancelRawLink\",\n \"cancelSearch\",\n \"providerSelected\",\n \"submit\"\n ],\n data() {\n return {\n MODES,\n selectedProvider: this.initialProvider\n };\n },\n computed: {\n mode() {\n return this.selectedProvider === null ? MODES.providerList : isCustomPickerElementRegistered(this.selectedProvider.id) ? MODES.customElement : this.selectedProvider.search_providers_ids ? MODES.searchInput : MODES.standardLinkInput;\n },\n pickerWrapperStyle() {\n return {\n width: this.width ? this.width + \"px\" : void 0\n };\n }\n },\n mounted() {\n if (this.focusOnCreate) {\n if (this.initialProvider) {\n setTimeout(() => {\n this.$refs[\"url-input\"]?.focus();\n }, 300);\n } else {\n this.$nextTick(() => {\n this.$refs[\"provider-list\"]?.focus();\n });\n }\n }\n },\n methods: {\n onEscapePressed() {\n if (this.selectedProvider !== null) {\n this.deselectProvider();\n } else {\n this.cancelProviderSelection();\n }\n },\n onProviderSelected(provider) {\n this.selectedProvider = provider;\n this.$emit(\"providerSelected\", provider);\n this.$nextTick(() => {\n this.$refs[\"url-input\"]?.focus();\n });\n },\n cancelCustomElement() {\n this.deselectProvider();\n },\n cancelSearch() {\n this.$emit(\"cancelSearch\", this.selectedProvider?.title);\n this.deselectProvider();\n },\n cancelRawLinkInput() {\n this.$emit(\"cancelRawLink\", this.selectedProvider?.title);\n this.deselectProvider();\n },\n cancelProviderSelection() {\n this.$emit(\"cancel\");\n },\n submitLink(link) {\n if (this.selectedProvider !== null) {\n touchProvider(this.selectedProvider.id);\n }\n this.$emit(\"submit\", link);\n this.deselectProvider();\n },\n deselectProvider() {\n this.selectedProvider = null;\n this.$emit(\"providerSelected\", null);\n setTimeout(() => {\n this.$refs[\"provider-list\"]?.focus();\n }, 300);\n }\n }\n};\nconst _hoisted_1$1 = {\n key: 3,\n class: \"custom-element-wrapper\"\n};\nfunction _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcProviderList = resolveComponent(\"NcProviderList\");\n const _component_NcRawLinkInput = resolveComponent(\"NcRawLinkInput\");\n const _component_NcSearch = resolveComponent(\"NcSearch\");\n const _component_NcCustomPickerElement = resolveComponent(\"NcCustomPickerElement\");\n return openBlock(), createElementBlock(\"div\", {\n class: \"reference-picker\",\n style: normalizeStyle($options.pickerWrapperStyle),\n tabindex: \"-1\",\n onKeydown: _cache[0] || (_cache[0] = withKeys(withModifiers((...args) => $options.onEscapePressed && $options.onEscapePressed(...args), [\"stop\", \"prevent\"]), [\"esc\"]))\n }, [\n $options.mode === $data.MODES.providerList ? (openBlock(), createBlock(_component_NcProviderList, {\n key: 0,\n ref: \"provider-list\",\n onSelectProvider: $options.onProviderSelected,\n onSubmit: $options.submitLink,\n onCancel: $options.cancelProviderSelection\n }, null, 8, [\"onSelectProvider\", \"onSubmit\", \"onCancel\"])) : $options.mode === $data.MODES.standardLinkInput ? (openBlock(), createBlock(_component_NcRawLinkInput, {\n key: 1,\n ref: \"url-input\",\n provider: $data.selectedProvider,\n onSubmit: $options.submitLink,\n onCancel: $options.cancelRawLinkInput\n }, null, 8, [\"provider\", \"onSubmit\", \"onCancel\"])) : $options.mode === $data.MODES.searchInput ? (openBlock(), createBlock(_component_NcSearch, {\n key: 2,\n ref: \"url-input\",\n provider: $data.selectedProvider,\n onCancel: $options.cancelSearch,\n onSubmit: $options.submitLink\n }, null, 8, [\"provider\", \"onCancel\", \"onSubmit\"])) : $options.mode === $data.MODES.customElement ? (openBlock(), createElementBlock(\"div\", _hoisted_1$1, [\n createVNode(_component_NcCustomPickerElement, {\n provider: $data.selectedProvider,\n class: \"custom-element\",\n onSubmit: $options.submitLink,\n onCancel: $options.cancelCustomElement\n }, null, 8, [\"provider\", \"onSubmit\", \"onCancel\"])\n ])) : createCommentVNode(\"\", true)\n ], 36);\n}\nconst NcReferencePicker = /* @__PURE__ */ _export_sfc(_sfc_main$1, [[\"render\", _sfc_render$1], [\"__scopeId\", \"data-v-b193005a\"]]);\nregister(t12, t19);\nconst _sfc_main = {\n name: \"NcReferencePickerModal\",\n components: {\n NcReferencePicker,\n NcModal,\n NcButton,\n ArrowLeftIcon,\n CloseIcon: IconClose\n },\n props: {\n /**\n * Provider to select on creation\n * Show the provider list if no initial one is provided\n */\n initialProvider: {\n type: Object,\n default: () => null\n },\n /**\n * Focus on the input item on create\n */\n focusOnCreate: {\n type: Boolean,\n default: true\n },\n /**\n * If true, add the modal content to the Viewer trap elements via the event-bus\n */\n isInsideViewer: {\n type: Boolean,\n default: false\n }\n },\n emits: [\n \"cancel\",\n \"submit\"\n ],\n data() {\n return {\n show: true,\n selectedProvider: this.initialProvider,\n backButtonTitle: t(\"Back to provider selection\"),\n closeButtonTitle: t(\"Close\"),\n closeButtonLabel: t(\"Close Smart Picker\")\n };\n },\n computed: {\n isProviderSelected() {\n return this.selectedProvider !== null;\n },\n showBackButton() {\n return this.initialProvider === null && this.isProviderSelected;\n },\n modalSize() {\n return this.isProviderSelected && isCustomPickerElementRegistered(this.selectedProvider.id) ? getCustomPickerElementSize(this.selectedProvider.id) ?? \"large\" : \"normal\";\n },\n showModalName() {\n return !this.isProviderSelected || !isCustomPickerElementRegistered(this.selectedProvider.id);\n },\n modalName() {\n return this.isProviderSelected ? this.selectedProvider.title : t(\"Smart Picker\");\n }\n },\n mounted() {\n if (this.isInsideViewer) {\n const elem = this.$refs.modal_content;\n emit(\"viewer:trapElements:changed\", elem);\n }\n },\n methods: {\n onCancel() {\n this.show = false;\n this.$emit(\"cancel\");\n },\n onSubmit(value) {\n this.show = false;\n this.$emit(\"submit\", value);\n },\n onProviderSelect(provider) {\n this.selectedProvider = provider;\n if (provider === null && this.initialProvider !== null) {\n this.onCancel();\n }\n },\n onBackClicked() {\n this.$refs.referencePicker.deselectProvider();\n }\n }\n};\nconst _hoisted_1 = {\n ref: \"modal_content\",\n class: \"reference-picker-modal--content\"\n};\nconst _hoisted_2 = { key: 1 };\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_ArrowLeftIcon = resolveComponent(\"ArrowLeftIcon\");\n const _component_NcButton = resolveComponent(\"NcButton\");\n const _component_CloseIcon = resolveComponent(\"CloseIcon\");\n const _component_NcReferencePicker = resolveComponent(\"NcReferencePicker\");\n const _component_NcModal = resolveComponent(\"NcModal\");\n return $data.show ? (openBlock(), createBlock(_component_NcModal, {\n key: 0,\n size: $options.modalSize,\n class: \"reference-picker-modal\",\n onClose: $options.onCancel\n }, {\n default: withCtx(() => [\n createElementVNode(\"div\", _hoisted_1, [\n $options.showBackButton ? (openBlock(), createBlock(_component_NcButton, {\n key: 0,\n \"aria-label\": $data.backButtonTitle,\n title: $data.backButtonTitle,\n class: \"back-button\",\n onClick: $options.onBackClicked\n }, {\n icon: withCtx(() => [\n createVNode(_component_ArrowLeftIcon)\n ]),\n _: 1\n }, 8, [\"aria-label\", \"title\", \"onClick\"])) : createCommentVNode(\"\", true),\n createVNode(_component_NcButton, {\n class: \"close-button\",\n \"aria-label\": $data.closeButtonLabel,\n title: $data.closeButtonTitle,\n variant: \"tertiary\",\n onClick: $options.onCancel\n }, {\n icon: withCtx(() => [\n createVNode(_component_CloseIcon)\n ]),\n _: 1\n }, 8, [\"aria-label\", \"title\", \"onClick\"]),\n $options.showModalName ? (openBlock(), createElementBlock(\"h2\", _hoisted_2, toDisplayString($options.modalName), 1)) : createCommentVNode(\"\", true),\n createVNode(_component_NcReferencePicker, {\n ref: \"referencePicker\",\n \"initial-provider\": $props.initialProvider,\n \"focus-on-create\": $props.focusOnCreate,\n onProviderSelected: $options.onProviderSelect,\n onSubmit: $options.onSubmit,\n onCancel: $options.onCancel\n }, null, 8, [\"initial-provider\", \"focus-on-create\", \"onProviderSelected\", \"onSubmit\", \"onCancel\"])\n ], 512)\n ]),\n _: 1\n }, 8, [\"size\", \"onClose\"])) : createCommentVNode(\"\", true);\n}\nconst NcReferencePickerModal = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render], [\"__scopeId\", \"data-v-15018516\"]]);\nasync function getLinkWithPicker(providerId, isInsideViewer) {\n const modalId = \"referencePickerModal\";\n const modalElement = document.createElement(\"div\");\n modalElement.id = modalId;\n document.body.append(modalElement);\n const { promise, reject, resolve } = Promise.withResolvers();\n const initialProvider = providerId && getProvider(providerId) || null;\n const view = createApp(NcReferencePickerModal, {\n initialProvider,\n isInsideViewer,\n onCancel() {\n view.unmount();\n reject(new Error(\"User cancellation\"));\n },\n onSubmit(link) {\n view.unmount();\n resolve(link);\n }\n });\n view.mount(modalElement);\n return promise;\n}\nexport {\n NcReferencePicker as N,\n anyLinkProviderId as a,\n getProvider as b,\n getProviders as c,\n sortProviders as d,\n NcReferencePickerModal as e,\n NcReferenceWidget as f,\n getLinkWithPicker as g,\n NcSearch as h,\n searchProvider as s\n};\n//# sourceMappingURL=referencePickerModal-B2XHvg0V.mjs.map\n","import '../assets/NcRichText-Bx--sR58.css';\nimport rehypeExternalLinks from \"rehype-external-links\";\nimport rehype2react from \"rehype-react\";\nimport breaks from \"remark-breaks\";\nimport remarkParse from \"remark-parse\";\nimport remark2rehype from \"remark-rehype\";\nimport remarkUnlinkProtocols from \"remark-unlink-protocols\";\nimport { unified } from \"unified\";\nimport { resolveComponent, createElementBlock, createCommentVNode, openBlock, normalizeClass, Fragment, renderList, createBlock, ref, h } from \"vue\";\nimport { RouterLink } from \"vue-router\";\nimport { N as NcCheckboxRadioSwitch } from \"./NcCheckboxRadioSwitch-DdIGHhQz.mjs\";\nimport { getCurrentUser } from \"@nextcloud/auth\";\nimport axios from \"@nextcloud/axios\";\nimport { generateOcsUrl } from \"@nextcloud/router\";\nimport { getSharingToken } from \"@nextcloud/sharing/public\";\nimport { f as NcReferenceWidget } from \"./referencePickerModal-B2XHvg0V.mjs\";\nimport { U as URL_PATTERN, g as getRoute, p as parseUrl, r as remarkAutolink } from \"./autolink-U5pBzLgI.mjs\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nimport { c as createElementId } from \"./createElementId-DhjFt1I9.mjs\";\nimport { u } from \"unist-builder\";\nimport { visit, EXIT as EXIT$1, SKIP as SKIP$1 } from \"unist-util-visit\";\nconst _sfc_main$1 = {\n name: \"NcReferenceList\",\n components: {\n NcReferenceWidget\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n text: {\n type: String,\n default: \"\"\n },\n referenceData: {\n type: Array,\n default: null\n },\n limit: {\n type: Number,\n default: 1\n },\n displayFallback: {\n type: Boolean,\n default: false\n },\n interactive: {\n type: Boolean,\n default: true\n },\n interactiveOptIn: {\n type: Boolean,\n default: false\n }\n },\n emits: [\"loaded\"],\n data() {\n return {\n references: null,\n loading: true\n };\n },\n computed: {\n isVisible() {\n return this.loading || this.displayedReferences.length !== 0;\n },\n values() {\n if (this.referenceData) {\n return this.referenceData;\n }\n if (this.displayFallback && !this.loading && !this.references) {\n return [this.fallbackReference];\n }\n return this.references ? Object.values(this.references) : [];\n },\n firstReference() {\n return this.values[0] ?? null;\n },\n displayedReferences() {\n return this.values.filter(Boolean).slice(0, this.limit);\n },\n fallbackReference() {\n return {\n accessible: true,\n openGraphObject: {\n id: this.text,\n link: this.text,\n name: this.text\n },\n richObjectType: \"open-graph\"\n };\n }\n },\n watch: {\n text: \"fetch\"\n },\n mounted() {\n this.fetch();\n },\n methods: {\n fetch() {\n this.loading = true;\n if (this.referenceData) {\n this.references = null;\n this.loading = false;\n return;\n }\n if (!new RegExp(URL_PATTERN).exec(this.text)) {\n this.references = null;\n this.loading = false;\n return;\n }\n this.resolve().then((response) => {\n this.references = response.data.ocs.data.references;\n this.loading = false;\n this.$emit(\"loaded\");\n }).catch((error) => {\n logger.error(\"[NcReferenceList] Failed to extract references\", { error });\n this.loading = false;\n this.$emit(\"loaded\");\n });\n },\n resolve() {\n const match = new RegExp(URL_PATTERN).exec(this.text.trim());\n const isPublic = getCurrentUser() === null;\n if (this.limit === 1 && match) {\n return isPublic ? axios.get(generateOcsUrl(\"references/resolvePublic\") + `?reference=${encodeURIComponent(match[0])}&sharingToken=${getSharingToken()}`) : axios.get(generateOcsUrl(\"references/resolve\") + `?reference=${encodeURIComponent(match[0])}`);\n }\n return isPublic ? axios.post(generateOcsUrl(\"references/extractPublic\"), {\n text: this.text,\n resolve: true,\n limit: this.limit,\n sharingToken: getSharingToken()\n }) : axios.post(generateOcsUrl(\"references/extract\"), {\n text: this.text,\n resolve: true,\n limit: this.limit\n });\n }\n }\n};\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcReferenceWidget = resolveComponent(\"NcReferenceWidget\");\n return $options.isVisible ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n class: normalizeClass([\"widgets--list\", { \"icon-loading\": $data.loading }])\n }, [\n (openBlock(true), createElementBlock(Fragment, null, renderList($options.displayedReferences, (reference) => {\n return openBlock(), createBlock(_component_NcReferenceWidget, {\n key: reference.openGraphObject?.id,\n reference,\n interactive: $props.interactive,\n \"interactive-opt-in\": $props.interactiveOptIn\n }, null, 8, [\"reference\", \"interactive\", \"interactive-opt-in\"]);\n }), 128))\n ], 2)) : createCommentVNode(\"\", true);\n}\nconst NcReferenceList = /* @__PURE__ */ _export_sfc(_sfc_main$1, [[\"render\", _sfc_render], [\"__scopeId\", \"data-v-ddd65c9e\"]]);\nfunction ccount(value, character) {\n const source = String(value);\n if (typeof character !== \"string\") {\n throw new TypeError(\"Expected character\");\n }\n let count = 0;\n let index = source.indexOf(character);\n while (index !== -1) {\n count++;\n index = source.indexOf(character, index + character.length);\n }\n return count;\n}\nfunction ok$1() {\n}\nconst asciiAlpha = regexCheck(/[A-Za-z]/);\nconst asciiAlphanumeric = regexCheck(/[\\dA-Za-z]/);\nfunction asciiControl(code2) {\n return (\n // Special whitespace codes (which have negative values), C0 and Control\n // character DEL\n code2 !== null && (code2 < 32 || code2 === 127)\n );\n}\nfunction markdownLineEnding(code2) {\n return code2 !== null && code2 < -2;\n}\nfunction markdownLineEndingOrSpace(code2) {\n return code2 !== null && (code2 < 0 || code2 === 32);\n}\nfunction markdownSpace(code2) {\n return code2 === -2 || code2 === -1 || code2 === 32;\n}\nconst unicodePunctuation = regexCheck(new RegExp(\"\\\\p{P}|\\\\p{S}\", \"u\"));\nconst unicodeWhitespace = regexCheck(/\\s/);\nfunction regexCheck(regex) {\n return check;\n function check(code2) {\n return code2 !== null && code2 > -1 && regex.test(String.fromCharCode(code2));\n }\n}\nfunction escapeStringRegexp(string) {\n if (typeof string !== \"string\") {\n throw new TypeError(\"Expected a string\");\n }\n return string.replace(/[|\\\\{}()[\\]^$+*?.]/g, \"\\\\$&\").replace(/-/g, \"\\\\x2d\");\n}\nconst convert = (\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate) &\n * ((test?: null | undefined) => (node?: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((test?: Test) => Check)\n * )}\n */\n /**\n * @param {Test} [test]\n * @returns {Check}\n */\n (function(test) {\n if (test === null || test === void 0) {\n return ok;\n }\n if (typeof test === \"function\") {\n return castFactory(test);\n }\n if (typeof test === \"object\") {\n return Array.isArray(test) ? anyFactory(test) : propsFactory(test);\n }\n if (typeof test === \"string\") {\n return typeFactory(test);\n }\n throw new Error(\"Expected function, string, or object as test\");\n })\n);\nfunction anyFactory(tests) {\n const checks = [];\n let index = -1;\n while (++index < tests.length) {\n checks[index] = convert(tests[index]);\n }\n return castFactory(any);\n function any(...parameters) {\n let index2 = -1;\n while (++index2 < checks.length) {\n if (checks[index2].apply(this, parameters)) return true;\n }\n return false;\n }\n}\nfunction propsFactory(check) {\n const checkAsRecord = (\n /** @type {Record} */\n check\n );\n return castFactory(all2);\n function all2(node2) {\n const nodeAsRecord = (\n /** @type {Record} */\n /** @type {unknown} */\n node2\n );\n let key;\n for (key in check) {\n if (nodeAsRecord[key] !== checkAsRecord[key]) return false;\n }\n return true;\n }\n}\nfunction typeFactory(check) {\n return castFactory(type);\n function type(node2) {\n return node2 && node2.type === check;\n }\n}\nfunction castFactory(testFunction) {\n return check;\n function check(value, index, parent) {\n return Boolean(\n looksLikeANode(value) && testFunction.call(\n this,\n value,\n typeof index === \"number\" ? index : void 0,\n parent || void 0\n )\n );\n }\n}\nfunction ok() {\n return true;\n}\nfunction looksLikeANode(value) {\n return value !== null && typeof value === \"object\" && \"type\" in value;\n}\nfunction color(d) {\n return d;\n}\nconst empty = [];\nconst CONTINUE = true;\nconst EXIT = false;\nconst SKIP = \"skip\";\nfunction visitParents(tree, test, visitor, reverse) {\n let check;\n {\n check = test;\n }\n const is = convert(check);\n const step = 1;\n factory(tree, void 0, [])();\n function factory(node2, index, parents) {\n const value = (\n /** @type {Record} */\n node2 && typeof node2 === \"object\" ? node2 : {}\n );\n if (typeof value.type === \"string\") {\n const name = (\n // `hast`\n typeof value.tagName === \"string\" ? value.tagName : (\n // `xast`\n typeof value.name === \"string\" ? value.name : void 0\n )\n );\n Object.defineProperty(visit2, \"name\", {\n value: \"node (\" + color(node2.type + (name ? \"<\" + name + \">\" : \"\")) + \")\"\n });\n }\n return visit2;\n function visit2() {\n let result = empty;\n let subresult;\n let offset;\n let grandparents;\n if (is(node2, index, parents[parents.length - 1] || void 0)) {\n result = toResult(visitor(node2, parents));\n if (result[0] === EXIT) {\n return result;\n }\n }\n if (\"children\" in node2 && node2.children) {\n const nodeAsParent = (\n /** @type {UnistParent} */\n node2\n );\n if (nodeAsParent.children && result[0] !== SKIP) {\n offset = -1 + step;\n grandparents = parents.concat(nodeAsParent);\n while (offset > -1 && offset < nodeAsParent.children.length) {\n const child = nodeAsParent.children[offset];\n subresult = factory(child, offset, grandparents)();\n if (subresult[0] === EXIT) {\n return subresult;\n }\n offset = typeof subresult[1] === \"number\" ? subresult[1] : offset + step;\n }\n }\n }\n return result;\n }\n }\n}\nfunction toResult(value) {\n if (Array.isArray(value)) {\n return value;\n }\n if (typeof value === \"number\") {\n return [CONTINUE, value];\n }\n return value === null || value === void 0 ? empty : [value];\n}\nfunction findAndReplace(tree, list2, options) {\n const settings = options || {};\n const ignored = convert(settings.ignore || []);\n const pairs = toPairs(list2);\n let pairIndex = -1;\n while (++pairIndex < pairs.length) {\n visitParents(tree, \"text\", visitor);\n }\n function visitor(node2, parents) {\n let index = -1;\n let grandparent;\n while (++index < parents.length) {\n const parent = parents[index];\n const siblings = grandparent ? grandparent.children : void 0;\n if (ignored(\n parent,\n siblings ? siblings.indexOf(parent) : void 0,\n grandparent\n )) {\n return;\n }\n grandparent = parent;\n }\n if (grandparent) {\n return handler(node2, parents);\n }\n }\n function handler(node2, parents) {\n const parent = parents[parents.length - 1];\n const find = pairs[pairIndex][0];\n const replace2 = pairs[pairIndex][1];\n let start = 0;\n const siblings = parent.children;\n const index = siblings.indexOf(node2);\n let change = false;\n let nodes = [];\n find.lastIndex = 0;\n let match = find.exec(node2.value);\n while (match) {\n const position = match.index;\n const matchObject = {\n index: match.index,\n input: match.input,\n stack: [...parents, node2]\n };\n let value = replace2(...match, matchObject);\n if (typeof value === \"string\") {\n value = value.length > 0 ? { type: \"text\", value } : void 0;\n }\n if (value === false) {\n find.lastIndex = position + 1;\n } else {\n if (start !== position) {\n nodes.push({\n type: \"text\",\n value: node2.value.slice(start, position)\n });\n }\n if (Array.isArray(value)) {\n nodes.push(...value);\n } else if (value) {\n nodes.push(value);\n }\n start = position + match[0].length;\n change = true;\n }\n if (!find.global) {\n break;\n }\n match = find.exec(node2.value);\n }\n if (change) {\n if (start < node2.value.length) {\n nodes.push({ type: \"text\", value: node2.value.slice(start) });\n }\n parent.children.splice(index, 1, ...nodes);\n } else {\n nodes = [node2];\n }\n return index + nodes.length;\n }\n}\nfunction toPairs(tupleOrList) {\n const result = [];\n if (!Array.isArray(tupleOrList)) {\n throw new TypeError(\"Expected find and replace tuple or list of tuples\");\n }\n const list2 = !tupleOrList[0] || Array.isArray(tupleOrList[0]) ? tupleOrList : [tupleOrList];\n let index = -1;\n while (++index < list2.length) {\n const tuple = list2[index];\n result.push([toExpression(tuple[0]), toFunction(tuple[1])]);\n }\n return result;\n}\nfunction toExpression(find) {\n return typeof find === \"string\" ? new RegExp(escapeStringRegexp(find), \"g\") : find;\n}\nfunction toFunction(replace2) {\n return typeof replace2 === \"function\" ? replace2 : function() {\n return replace2;\n };\n}\nconst inConstruct = \"phrasing\";\nconst notInConstruct = [\"autolink\", \"link\", \"image\", \"label\"];\nfunction gfmAutolinkLiteralFromMarkdown() {\n return {\n transforms: [transformGfmAutolinkLiterals],\n enter: {\n literalAutolink: enterLiteralAutolink,\n literalAutolinkEmail: enterLiteralAutolinkValue,\n literalAutolinkHttp: enterLiteralAutolinkValue,\n literalAutolinkWww: enterLiteralAutolinkValue\n },\n exit: {\n literalAutolink: exitLiteralAutolink,\n literalAutolinkEmail: exitLiteralAutolinkEmail,\n literalAutolinkHttp: exitLiteralAutolinkHttp,\n literalAutolinkWww: exitLiteralAutolinkWww\n }\n };\n}\nfunction gfmAutolinkLiteralToMarkdown() {\n return {\n unsafe: [\n {\n character: \"@\",\n before: \"[+\\\\-.\\\\w]\",\n after: \"[\\\\-.\\\\w]\",\n inConstruct,\n notInConstruct\n },\n {\n character: \".\",\n before: \"[Ww]\",\n after: \"[\\\\-.\\\\w]\",\n inConstruct,\n notInConstruct\n },\n {\n character: \":\",\n before: \"[ps]\",\n after: \"\\\\/\",\n inConstruct,\n notInConstruct\n }\n ]\n };\n}\nfunction enterLiteralAutolink(token) {\n this.enter({ type: \"link\", title: null, url: \"\", children: [] }, token);\n}\nfunction enterLiteralAutolinkValue(token) {\n this.config.enter.autolinkProtocol.call(this, token);\n}\nfunction exitLiteralAutolinkHttp(token) {\n this.config.exit.autolinkProtocol.call(this, token);\n}\nfunction exitLiteralAutolinkWww(token) {\n this.config.exit.data.call(this, token);\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"link\");\n node2.url = \"http://\" + this.sliceSerialize(token);\n}\nfunction exitLiteralAutolinkEmail(token) {\n this.config.exit.autolinkEmail.call(this, token);\n}\nfunction exitLiteralAutolink(token) {\n this.exit(token);\n}\nfunction transformGfmAutolinkLiterals(tree) {\n findAndReplace(\n tree,\n [\n [/(https?:\\/\\/|www(?=\\.))([-.\\w]+)([^ \\t\\r\\n]*)/gi, findUrl],\n [/([-.\\w+]+)@([-\\w]+(?:\\.[-\\w]+)+)/g, findEmail]\n ],\n { ignore: [\"link\", \"linkReference\"] }\n );\n}\nfunction findUrl(_, protocol, domain2, path2, match) {\n let prefix = \"\";\n if (!previous(match)) {\n return false;\n }\n if (/^w/i.test(protocol)) {\n domain2 = protocol + domain2;\n protocol = \"\";\n prefix = \"http://\";\n }\n if (!isCorrectDomain(domain2)) {\n return false;\n }\n const parts = splitUrl(domain2 + path2);\n if (!parts[0]) return false;\n const result = {\n type: \"link\",\n title: null,\n url: prefix + protocol + parts[0],\n children: [{ type: \"text\", value: protocol + parts[0] }]\n };\n if (parts[1]) {\n return [result, { type: \"text\", value: parts[1] }];\n }\n return result;\n}\nfunction findEmail(_, atext, label, match) {\n if (\n // Not an expected previous character.\n !previous(match, true) || // Label ends in not allowed character.\n /[-\\d_]$/.test(label)\n ) {\n return false;\n }\n return {\n type: \"link\",\n title: null,\n url: \"mailto:\" + atext + \"@\" + label,\n children: [{ type: \"text\", value: atext + \"@\" + label }]\n };\n}\nfunction isCorrectDomain(domain2) {\n const parts = domain2.split(\".\");\n if (parts.length < 2 || parts[parts.length - 1] && (/_/.test(parts[parts.length - 1]) || !/[a-zA-Z\\d]/.test(parts[parts.length - 1])) || parts[parts.length - 2] && (/_/.test(parts[parts.length - 2]) || !/[a-zA-Z\\d]/.test(parts[parts.length - 2]))) {\n return false;\n }\n return true;\n}\nfunction splitUrl(url) {\n const trailExec = /[!\"&'),.:;<>?\\]}]+$/.exec(url);\n if (!trailExec) {\n return [url, void 0];\n }\n url = url.slice(0, trailExec.index);\n let trail2 = trailExec[0];\n let closingParenIndex = trail2.indexOf(\")\");\n const openingParens = ccount(url, \"(\");\n let closingParens = ccount(url, \")\");\n while (closingParenIndex !== -1 && openingParens > closingParens) {\n url += trail2.slice(0, closingParenIndex + 1);\n trail2 = trail2.slice(closingParenIndex + 1);\n closingParenIndex = trail2.indexOf(\")\");\n closingParens++;\n }\n return [url, trail2];\n}\nfunction previous(match, email) {\n const code2 = match.input.charCodeAt(match.index - 1);\n return (match.index === 0 || unicodeWhitespace(code2) || unicodePunctuation(code2)) && (!email || code2 !== 47);\n}\nfunction normalizeIdentifier(value) {\n return value.replace(/[\\t\\n\\r ]+/g, \" \").replace(/^ | $/g, \"\").toLowerCase().toUpperCase();\n}\nfootnoteReference.peek = footnoteReferencePeek;\nfunction enterFootnoteCallString() {\n this.buffer();\n}\nfunction enterFootnoteCall(token) {\n this.enter({ type: \"footnoteReference\", identifier: \"\", label: \"\" }, token);\n}\nfunction enterFootnoteDefinitionLabelString() {\n this.buffer();\n}\nfunction enterFootnoteDefinition(token) {\n this.enter(\n { type: \"footnoteDefinition\", identifier: \"\", label: \"\", children: [] },\n token\n );\n}\nfunction exitFootnoteCallString(token) {\n const label = this.resume();\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"footnoteReference\");\n node2.identifier = normalizeIdentifier(\n this.sliceSerialize(token)\n ).toLowerCase();\n node2.label = label;\n}\nfunction exitFootnoteCall(token) {\n this.exit(token);\n}\nfunction exitFootnoteDefinitionLabelString(token) {\n const label = this.resume();\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"footnoteDefinition\");\n node2.identifier = normalizeIdentifier(\n this.sliceSerialize(token)\n ).toLowerCase();\n node2.label = label;\n}\nfunction exitFootnoteDefinition(token) {\n this.exit(token);\n}\nfunction footnoteReferencePeek() {\n return \"[\";\n}\nfunction footnoteReference(node2, _, state, info) {\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[^\");\n const exit2 = state.enter(\"footnoteReference\");\n const subexit = state.enter(\"reference\");\n value += tracker.move(\n state.safe(state.associationId(node2), { after: \"]\", before: value })\n );\n subexit();\n exit2();\n value += tracker.move(\"]\");\n return value;\n}\nfunction gfmFootnoteFromMarkdown() {\n return {\n enter: {\n gfmFootnoteCallString: enterFootnoteCallString,\n gfmFootnoteCall: enterFootnoteCall,\n gfmFootnoteDefinitionLabelString: enterFootnoteDefinitionLabelString,\n gfmFootnoteDefinition: enterFootnoteDefinition\n },\n exit: {\n gfmFootnoteCallString: exitFootnoteCallString,\n gfmFootnoteCall: exitFootnoteCall,\n gfmFootnoteDefinitionLabelString: exitFootnoteDefinitionLabelString,\n gfmFootnoteDefinition: exitFootnoteDefinition\n }\n };\n}\nfunction gfmFootnoteToMarkdown(options) {\n let firstLineBlank = false;\n if (options && options.firstLineBlank) {\n firstLineBlank = true;\n }\n return {\n handlers: { footnoteDefinition, footnoteReference },\n // This is on by default already.\n unsafe: [{ character: \"[\", inConstruct: [\"label\", \"phrasing\", \"reference\"] }]\n };\n function footnoteDefinition(node2, _, state, info) {\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[^\");\n const exit2 = state.enter(\"footnoteDefinition\");\n const subexit = state.enter(\"label\");\n value += tracker.move(\n state.safe(state.associationId(node2), { before: value, after: \"]\" })\n );\n subexit();\n value += tracker.move(\"]:\");\n if (node2.children && node2.children.length > 0) {\n tracker.shift(4);\n value += tracker.move(\n (firstLineBlank ? \"\\n\" : \" \") + state.indentLines(\n state.containerFlow(node2, tracker.current()),\n firstLineBlank ? mapAll : mapExceptFirst\n )\n );\n }\n exit2();\n return value;\n }\n}\nfunction mapExceptFirst(line, index, blank) {\n return index === 0 ? line : mapAll(line, index, blank);\n}\nfunction mapAll(line, index, blank) {\n return (blank ? \"\" : \" \") + line;\n}\nconst constructsWithoutStrikethrough = [\n \"autolink\",\n \"destinationLiteral\",\n \"destinationRaw\",\n \"reference\",\n \"titleQuote\",\n \"titleApostrophe\"\n];\nhandleDelete.peek = peekDelete;\nfunction gfmStrikethroughFromMarkdown() {\n return {\n canContainEols: [\"delete\"],\n enter: { strikethrough: enterStrikethrough },\n exit: { strikethrough: exitStrikethrough }\n };\n}\nfunction gfmStrikethroughToMarkdown() {\n return {\n unsafe: [\n {\n character: \"~\",\n inConstruct: \"phrasing\",\n notInConstruct: constructsWithoutStrikethrough\n }\n ],\n handlers: { delete: handleDelete }\n };\n}\nfunction enterStrikethrough(token) {\n this.enter({ type: \"delete\", children: [] }, token);\n}\nfunction exitStrikethrough(token) {\n this.exit(token);\n}\nfunction handleDelete(node2, _, state, info) {\n const tracker = state.createTracker(info);\n const exit2 = state.enter(\"strikethrough\");\n let value = tracker.move(\"~~\");\n value += state.containerPhrasing(node2, {\n ...tracker.current(),\n before: value,\n after: \"~\"\n });\n value += tracker.move(\"~~\");\n exit2();\n return value;\n}\nfunction peekDelete() {\n return \"~\";\n}\nfunction defaultStringLength(value) {\n return value.length;\n}\nfunction markdownTable(table, options) {\n const settings = options || {};\n const align = (settings.align || []).concat();\n const stringLength = settings.stringLength || defaultStringLength;\n const alignments = [];\n const cellMatrix = [];\n const sizeMatrix = [];\n const longestCellByColumn = [];\n let mostCellsPerRow = 0;\n let rowIndex = -1;\n while (++rowIndex < table.length) {\n const row2 = [];\n const sizes2 = [];\n let columnIndex2 = -1;\n if (table[rowIndex].length > mostCellsPerRow) {\n mostCellsPerRow = table[rowIndex].length;\n }\n while (++columnIndex2 < table[rowIndex].length) {\n const cell = serialize(table[rowIndex][columnIndex2]);\n if (settings.alignDelimiters !== false) {\n const size = stringLength(cell);\n sizes2[columnIndex2] = size;\n if (longestCellByColumn[columnIndex2] === void 0 || size > longestCellByColumn[columnIndex2]) {\n longestCellByColumn[columnIndex2] = size;\n }\n }\n row2.push(cell);\n }\n cellMatrix[rowIndex] = row2;\n sizeMatrix[rowIndex] = sizes2;\n }\n let columnIndex = -1;\n if (typeof align === \"object\" && \"length\" in align) {\n while (++columnIndex < mostCellsPerRow) {\n alignments[columnIndex] = toAlignment(align[columnIndex]);\n }\n } else {\n const code2 = toAlignment(align);\n while (++columnIndex < mostCellsPerRow) {\n alignments[columnIndex] = code2;\n }\n }\n columnIndex = -1;\n const row = [];\n const sizes = [];\n while (++columnIndex < mostCellsPerRow) {\n const code2 = alignments[columnIndex];\n let before = \"\";\n let after = \"\";\n if (code2 === 99) {\n before = \":\";\n after = \":\";\n } else if (code2 === 108) {\n before = \":\";\n } else if (code2 === 114) {\n after = \":\";\n }\n let size = settings.alignDelimiters === false ? 1 : Math.max(\n 1,\n longestCellByColumn[columnIndex] - before.length - after.length\n );\n const cell = before + \"-\".repeat(size) + after;\n if (settings.alignDelimiters !== false) {\n size = before.length + size + after.length;\n if (size > longestCellByColumn[columnIndex]) {\n longestCellByColumn[columnIndex] = size;\n }\n sizes[columnIndex] = size;\n }\n row[columnIndex] = cell;\n }\n cellMatrix.splice(1, 0, row);\n sizeMatrix.splice(1, 0, sizes);\n rowIndex = -1;\n const lines = [];\n while (++rowIndex < cellMatrix.length) {\n const row2 = cellMatrix[rowIndex];\n const sizes2 = sizeMatrix[rowIndex];\n columnIndex = -1;\n const line = [];\n while (++columnIndex < mostCellsPerRow) {\n const cell = row2[columnIndex] || \"\";\n let before = \"\";\n let after = \"\";\n if (settings.alignDelimiters !== false) {\n const size = longestCellByColumn[columnIndex] - (sizes2[columnIndex] || 0);\n const code2 = alignments[columnIndex];\n if (code2 === 114) {\n before = \" \".repeat(size);\n } else if (code2 === 99) {\n if (size % 2) {\n before = \" \".repeat(size / 2 + 0.5);\n after = \" \".repeat(size / 2 - 0.5);\n } else {\n before = \" \".repeat(size / 2);\n after = before;\n }\n } else {\n after = \" \".repeat(size);\n }\n }\n if (settings.delimiterStart !== false && !columnIndex) {\n line.push(\"|\");\n }\n if (settings.padding !== false && // Don’t add the opening space if we’re not aligning and the cell is\n // empty: there will be a closing space.\n !(settings.alignDelimiters === false && cell === \"\") && (settings.delimiterStart !== false || columnIndex)) {\n line.push(\" \");\n }\n if (settings.alignDelimiters !== false) {\n line.push(before);\n }\n line.push(cell);\n if (settings.alignDelimiters !== false) {\n line.push(after);\n }\n if (settings.padding !== false) {\n line.push(\" \");\n }\n if (settings.delimiterEnd !== false || columnIndex !== mostCellsPerRow - 1) {\n line.push(\"|\");\n }\n }\n lines.push(\n settings.delimiterEnd === false ? line.join(\"\").replace(/ +$/, \"\") : line.join(\"\")\n );\n }\n return lines.join(\"\\n\");\n}\nfunction serialize(value) {\n return value === null || value === void 0 ? \"\" : String(value);\n}\nfunction toAlignment(value) {\n const code2 = typeof value === \"string\" ? value.codePointAt(0) : 0;\n return code2 === 67 || code2 === 99 ? 99 : code2 === 76 || code2 === 108 ? 108 : code2 === 82 || code2 === 114 ? 114 : 0;\n}\nfunction blockquote(node2, _, state, info) {\n const exit2 = state.enter(\"blockquote\");\n const tracker = state.createTracker(info);\n tracker.move(\"> \");\n tracker.shift(2);\n const value = state.indentLines(\n state.containerFlow(node2, tracker.current()),\n map$1\n );\n exit2();\n return value;\n}\nfunction map$1(line, _, blank) {\n return \">\" + (blank ? \"\" : \" \") + line;\n}\nfunction patternInScope(stack, pattern) {\n return listInScope(stack, pattern.inConstruct, true) && !listInScope(stack, pattern.notInConstruct, false);\n}\nfunction listInScope(stack, list2, none) {\n if (typeof list2 === \"string\") {\n list2 = [list2];\n }\n if (!list2 || list2.length === 0) {\n return none;\n }\n let index = -1;\n while (++index < list2.length) {\n if (stack.includes(list2[index])) {\n return true;\n }\n }\n return false;\n}\nfunction hardBreak(_, _1, state, info) {\n let index = -1;\n while (++index < state.unsafe.length) {\n if (state.unsafe[index].character === \"\\n\" && patternInScope(state.stack, state.unsafe[index])) {\n return /[ \\t]/.test(info.before) ? \"\" : \" \";\n }\n }\n return \"\\\\\\n\";\n}\nfunction longestStreak(value, substring) {\n const source = String(value);\n let index = source.indexOf(substring);\n let expected = index;\n let count = 0;\n let max = 0;\n if (typeof substring !== \"string\") {\n throw new TypeError(\"Expected substring\");\n }\n while (index !== -1) {\n if (index === expected) {\n if (++count > max) {\n max = count;\n }\n } else {\n count = 1;\n }\n expected = index + substring.length;\n index = source.indexOf(substring, expected);\n }\n return max;\n}\nfunction formatCodeAsIndented(node2, state) {\n return Boolean(\n state.options.fences === false && node2.value && // If there’s no info…\n !node2.lang && // And there’s a non-whitespace character…\n /[^ \\r\\n]/.test(node2.value) && // And the value doesn’t start or end in a blank…\n !/^[\\t ]*(?:[\\r\\n]|$)|(?:^|[\\r\\n])[\\t ]*$/.test(node2.value)\n );\n}\nfunction checkFence(state) {\n const marker = state.options.fence || \"`\";\n if (marker !== \"`\" && marker !== \"~\") {\n throw new Error(\n \"Cannot serialize code with `\" + marker + \"` for `options.fence`, expected `` ` `` or `~`\"\n );\n }\n return marker;\n}\nfunction code$1(node2, _, state, info) {\n const marker = checkFence(state);\n const raw = node2.value || \"\";\n const suffix = marker === \"`\" ? \"GraveAccent\" : \"Tilde\";\n if (formatCodeAsIndented(node2, state)) {\n const exit3 = state.enter(\"codeIndented\");\n const value2 = state.indentLines(raw, map);\n exit3();\n return value2;\n }\n const tracker = state.createTracker(info);\n const sequence = marker.repeat(Math.max(longestStreak(raw, marker) + 1, 3));\n const exit2 = state.enter(\"codeFenced\");\n let value = tracker.move(sequence);\n if (node2.lang) {\n const subexit = state.enter(`codeFencedLang${suffix}`);\n value += tracker.move(\n state.safe(node2.lang, {\n before: value,\n after: \" \",\n encode: [\"`\"],\n ...tracker.current()\n })\n );\n subexit();\n }\n if (node2.lang && node2.meta) {\n const subexit = state.enter(`codeFencedMeta${suffix}`);\n value += tracker.move(\" \");\n value += tracker.move(\n state.safe(node2.meta, {\n before: value,\n after: \"\\n\",\n encode: [\"`\"],\n ...tracker.current()\n })\n );\n subexit();\n }\n value += tracker.move(\"\\n\");\n if (raw) {\n value += tracker.move(raw + \"\\n\");\n }\n value += tracker.move(sequence);\n exit2();\n return value;\n}\nfunction map(line, _, blank) {\n return (blank ? \"\" : \" \") + line;\n}\nfunction checkQuote(state) {\n const marker = state.options.quote || '\"';\n if (marker !== '\"' && marker !== \"'\") {\n throw new Error(\n \"Cannot serialize title with `\" + marker + \"` for `options.quote`, expected `\\\"`, or `'`\"\n );\n }\n return marker;\n}\nfunction definition(node2, _, state, info) {\n const quote = checkQuote(state);\n const suffix = quote === '\"' ? \"Quote\" : \"Apostrophe\";\n const exit2 = state.enter(\"definition\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[\");\n value += tracker.move(\n state.safe(state.associationId(node2), {\n before: value,\n after: \"]\",\n ...tracker.current()\n })\n );\n value += tracker.move(\"]: \");\n subexit();\n if (\n // If there’s no url, or…\n !node2.url || // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node2.url)\n ) {\n subexit = state.enter(\"destinationLiteral\");\n value += tracker.move(\"<\");\n value += tracker.move(\n state.safe(node2.url, { before: value, after: \">\", ...tracker.current() })\n );\n value += tracker.move(\">\");\n } else {\n subexit = state.enter(\"destinationRaw\");\n value += tracker.move(\n state.safe(node2.url, {\n before: value,\n after: node2.title ? \" \" : \"\\n\",\n ...tracker.current()\n })\n );\n }\n subexit();\n if (node2.title) {\n subexit = state.enter(`title${suffix}`);\n value += tracker.move(\" \" + quote);\n value += tracker.move(\n state.safe(node2.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n );\n value += tracker.move(quote);\n subexit();\n }\n exit2();\n return value;\n}\nfunction checkEmphasis(state) {\n const marker = state.options.emphasis || \"*\";\n if (marker !== \"*\" && marker !== \"_\") {\n throw new Error(\n \"Cannot serialize emphasis with `\" + marker + \"` for `options.emphasis`, expected `*`, or `_`\"\n );\n }\n return marker;\n}\nfunction encodeCharacterReference(code2) {\n return \"&#x\" + code2.toString(16).toUpperCase() + \";\";\n}\nfunction classifyCharacter(code2) {\n if (code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)) {\n return 1;\n }\n if (unicodePunctuation(code2)) {\n return 2;\n }\n}\nfunction encodeInfo(outside, inside, marker) {\n const outsideKind = classifyCharacter(outside);\n const insideKind = classifyCharacter(inside);\n if (outsideKind === void 0) {\n return insideKind === void 0 ? (\n // Letter inside:\n // we have to encode *both* letters for `_` as it is looser.\n // it already forms for `*` (and GFMs `~`).\n marker === \"_\" ? { inside: true, outside: true } : { inside: false, outside: false }\n ) : insideKind === 1 ? (\n // Whitespace inside: encode both (letter, whitespace).\n { inside: true, outside: true }\n ) : (\n // Punctuation inside: encode outer (letter)\n { inside: false, outside: true }\n );\n }\n if (outsideKind === 1) {\n return insideKind === void 0 ? (\n // Letter inside: already forms.\n { inside: false, outside: false }\n ) : insideKind === 1 ? (\n // Whitespace inside: encode both (whitespace).\n { inside: true, outside: true }\n ) : (\n // Punctuation inside: already forms.\n { inside: false, outside: false }\n );\n }\n return insideKind === void 0 ? (\n // Letter inside: already forms.\n { inside: false, outside: false }\n ) : insideKind === 1 ? (\n // Whitespace inside: encode inner (whitespace).\n { inside: true, outside: false }\n ) : (\n // Punctuation inside: already forms.\n { inside: false, outside: false }\n );\n}\nemphasis.peek = emphasisPeek;\nfunction emphasis(node2, _, state, info) {\n const marker = checkEmphasis(state);\n const exit2 = state.enter(\"emphasis\");\n const tracker = state.createTracker(info);\n const before = tracker.move(marker);\n let between = tracker.move(\n state.containerPhrasing(node2, {\n after: marker,\n before,\n ...tracker.current()\n })\n );\n const betweenHead = between.charCodeAt(0);\n const open = encodeInfo(\n info.before.charCodeAt(info.before.length - 1),\n betweenHead,\n marker\n );\n if (open.inside) {\n between = encodeCharacterReference(betweenHead) + between.slice(1);\n }\n const betweenTail = between.charCodeAt(between.length - 1);\n const close = encodeInfo(info.after.charCodeAt(0), betweenTail, marker);\n if (close.inside) {\n between = between.slice(0, -1) + encodeCharacterReference(betweenTail);\n }\n const after = tracker.move(marker);\n exit2();\n state.attentionEncodeSurroundingInfo = {\n after: close.outside,\n before: open.outside\n };\n return before + between + after;\n}\nfunction emphasisPeek(_, _1, state) {\n return state.options.emphasis || \"*\";\n}\nconst emptyOptions$1 = {};\nfunction toString(value, options) {\n const settings = emptyOptions$1;\n const includeImageAlt = typeof settings.includeImageAlt === \"boolean\" ? settings.includeImageAlt : true;\n const includeHtml = typeof settings.includeHtml === \"boolean\" ? settings.includeHtml : true;\n return one(value, includeImageAlt, includeHtml);\n}\nfunction one(value, includeImageAlt, includeHtml) {\n if (node(value)) {\n if (\"value\" in value) {\n return value.type === \"html\" && !includeHtml ? \"\" : value.value;\n }\n if (includeImageAlt && \"alt\" in value && value.alt) {\n return value.alt;\n }\n if (\"children\" in value) {\n return all(value.children, includeImageAlt, includeHtml);\n }\n }\n if (Array.isArray(value)) {\n return all(value, includeImageAlt, includeHtml);\n }\n return \"\";\n}\nfunction all(values, includeImageAlt, includeHtml) {\n const result = [];\n let index = -1;\n while (++index < values.length) {\n result[index] = one(values[index], includeImageAlt, includeHtml);\n }\n return result.join(\"\");\n}\nfunction node(value) {\n return Boolean(value && typeof value === \"object\");\n}\nfunction formatHeadingAsSetext(node2, state) {\n let literalWithBreak = false;\n visit(node2, function(node3) {\n if (\"value\" in node3 && /\\r?\\n|\\r/.test(node3.value) || node3.type === \"break\") {\n literalWithBreak = true;\n return EXIT$1;\n }\n });\n return Boolean(\n (!node2.depth || node2.depth < 3) && toString(node2) && (state.options.setext || literalWithBreak)\n );\n}\nfunction heading(node2, _, state, info) {\n const rank = Math.max(Math.min(6, node2.depth || 1), 1);\n const tracker = state.createTracker(info);\n if (formatHeadingAsSetext(node2, state)) {\n const exit3 = state.enter(\"headingSetext\");\n const subexit2 = state.enter(\"phrasing\");\n const value2 = state.containerPhrasing(node2, {\n ...tracker.current(),\n before: \"\\n\",\n after: \"\\n\"\n });\n subexit2();\n exit3();\n return value2 + \"\\n\" + (rank === 1 ? \"=\" : \"-\").repeat(\n // The whole size…\n value2.length - // Minus the position of the character after the last EOL (or\n // 0 if there is none)…\n (Math.max(value2.lastIndexOf(\"\\r\"), value2.lastIndexOf(\"\\n\")) + 1)\n );\n }\n const sequence = \"#\".repeat(rank);\n const exit2 = state.enter(\"headingAtx\");\n const subexit = state.enter(\"phrasing\");\n tracker.move(sequence + \" \");\n let value = state.containerPhrasing(node2, {\n before: \"# \",\n after: \"\\n\",\n ...tracker.current()\n });\n if (/^[\\t ]/.test(value)) {\n value = encodeCharacterReference(value.charCodeAt(0)) + value.slice(1);\n }\n value = value ? sequence + \" \" + value : sequence;\n if (state.options.closeAtx) {\n value += \" \" + sequence;\n }\n subexit();\n exit2();\n return value;\n}\nhtml.peek = htmlPeek;\nfunction html(node2) {\n return node2.value || \"\";\n}\nfunction htmlPeek() {\n return \"<\";\n}\nimage.peek = imagePeek;\nfunction image(node2, _, state, info) {\n const quote = checkQuote(state);\n const suffix = quote === '\"' ? \"Quote\" : \"Apostrophe\";\n const exit2 = state.enter(\"image\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"![\");\n value += tracker.move(\n state.safe(node2.alt, { before: value, after: \"]\", ...tracker.current() })\n );\n value += tracker.move(\"](\");\n subexit();\n if (\n // If there’s no url but there is a title…\n !node2.url && node2.title || // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node2.url)\n ) {\n subexit = state.enter(\"destinationLiteral\");\n value += tracker.move(\"<\");\n value += tracker.move(\n state.safe(node2.url, { before: value, after: \">\", ...tracker.current() })\n );\n value += tracker.move(\">\");\n } else {\n subexit = state.enter(\"destinationRaw\");\n value += tracker.move(\n state.safe(node2.url, {\n before: value,\n after: node2.title ? \" \" : \")\",\n ...tracker.current()\n })\n );\n }\n subexit();\n if (node2.title) {\n subexit = state.enter(`title${suffix}`);\n value += tracker.move(\" \" + quote);\n value += tracker.move(\n state.safe(node2.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n );\n value += tracker.move(quote);\n subexit();\n }\n value += tracker.move(\")\");\n exit2();\n return value;\n}\nfunction imagePeek() {\n return \"!\";\n}\nimageReference.peek = imageReferencePeek;\nfunction imageReference(node2, _, state, info) {\n const type = node2.referenceType;\n const exit2 = state.enter(\"imageReference\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"![\");\n const alt = state.safe(node2.alt, {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n value += tracker.move(alt + \"][\");\n subexit();\n const stack = state.stack;\n state.stack = [];\n subexit = state.enter(\"reference\");\n const reference = state.safe(state.associationId(node2), {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n subexit();\n state.stack = stack;\n exit2();\n if (type === \"full\" || !alt || alt !== reference) {\n value += tracker.move(reference + \"]\");\n } else if (type === \"shortcut\") {\n value = value.slice(0, -1);\n } else {\n value += tracker.move(\"]\");\n }\n return value;\n}\nfunction imageReferencePeek() {\n return \"!\";\n}\ninlineCode.peek = inlineCodePeek;\nfunction inlineCode(node2, _, state) {\n let value = node2.value || \"\";\n let sequence = \"`\";\n let index = -1;\n while (new RegExp(\"(^|[^`])\" + sequence + \"([^`]|$)\").test(value)) {\n sequence += \"`\";\n }\n if (/[^ \\r\\n]/.test(value) && (/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value) || /^`|`$/.test(value))) {\n value = \" \" + value + \" \";\n }\n while (++index < state.unsafe.length) {\n const pattern = state.unsafe[index];\n const expression = state.compilePattern(pattern);\n let match;\n if (!pattern.atBreak) continue;\n while (match = expression.exec(value)) {\n let position = match.index;\n if (value.charCodeAt(position) === 10 && value.charCodeAt(position - 1) === 13) {\n position--;\n }\n value = value.slice(0, position) + \" \" + value.slice(match.index + 1);\n }\n }\n return sequence + value + sequence;\n}\nfunction inlineCodePeek() {\n return \"`\";\n}\nfunction formatLinkAsAutolink(node2, state) {\n const raw = toString(node2);\n return Boolean(\n !state.options.resourceLink && // If there’s a url…\n node2.url && // And there’s a no title…\n !node2.title && // And the content of `node` is a single text node…\n node2.children && node2.children.length === 1 && node2.children[0].type === \"text\" && // And if the url is the same as the content…\n (raw === node2.url || \"mailto:\" + raw === node2.url) && // And that starts w/ a protocol…\n /^[a-z][a-z+.-]+:/i.test(node2.url) && // And that doesn’t contain ASCII control codes (character escapes and\n // references don’t work), space, or angle brackets…\n !/[\\0- <>\\u007F]/.test(node2.url)\n );\n}\nlink.peek = linkPeek;\nfunction link(node2, _, state, info) {\n const quote = checkQuote(state);\n const suffix = quote === '\"' ? \"Quote\" : \"Apostrophe\";\n const tracker = state.createTracker(info);\n let exit2;\n let subexit;\n if (formatLinkAsAutolink(node2, state)) {\n const stack = state.stack;\n state.stack = [];\n exit2 = state.enter(\"autolink\");\n let value2 = tracker.move(\"<\");\n value2 += tracker.move(\n state.containerPhrasing(node2, {\n before: value2,\n after: \">\",\n ...tracker.current()\n })\n );\n value2 += tracker.move(\">\");\n exit2();\n state.stack = stack;\n return value2;\n }\n exit2 = state.enter(\"link\");\n subexit = state.enter(\"label\");\n let value = tracker.move(\"[\");\n value += tracker.move(\n state.containerPhrasing(node2, {\n before: value,\n after: \"](\",\n ...tracker.current()\n })\n );\n value += tracker.move(\"](\");\n subexit();\n if (\n // If there’s no url but there is a title…\n !node2.url && node2.title || // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node2.url)\n ) {\n subexit = state.enter(\"destinationLiteral\");\n value += tracker.move(\"<\");\n value += tracker.move(\n state.safe(node2.url, { before: value, after: \">\", ...tracker.current() })\n );\n value += tracker.move(\">\");\n } else {\n subexit = state.enter(\"destinationRaw\");\n value += tracker.move(\n state.safe(node2.url, {\n before: value,\n after: node2.title ? \" \" : \")\",\n ...tracker.current()\n })\n );\n }\n subexit();\n if (node2.title) {\n subexit = state.enter(`title${suffix}`);\n value += tracker.move(\" \" + quote);\n value += tracker.move(\n state.safe(node2.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n );\n value += tracker.move(quote);\n subexit();\n }\n value += tracker.move(\")\");\n exit2();\n return value;\n}\nfunction linkPeek(node2, _, state) {\n return formatLinkAsAutolink(node2, state) ? \"<\" : \"[\";\n}\nlinkReference.peek = linkReferencePeek;\nfunction linkReference(node2, _, state, info) {\n const type = node2.referenceType;\n const exit2 = state.enter(\"linkReference\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[\");\n const text2 = state.containerPhrasing(node2, {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n value += tracker.move(text2 + \"][\");\n subexit();\n const stack = state.stack;\n state.stack = [];\n subexit = state.enter(\"reference\");\n const reference = state.safe(state.associationId(node2), {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n subexit();\n state.stack = stack;\n exit2();\n if (type === \"full\" || !text2 || text2 !== reference) {\n value += tracker.move(reference + \"]\");\n } else if (type === \"shortcut\") {\n value = value.slice(0, -1);\n } else {\n value += tracker.move(\"]\");\n }\n return value;\n}\nfunction linkReferencePeek() {\n return \"[\";\n}\nfunction checkBullet(state) {\n const marker = state.options.bullet || \"*\";\n if (marker !== \"*\" && marker !== \"+\" && marker !== \"-\") {\n throw new Error(\n \"Cannot serialize items with `\" + marker + \"` for `options.bullet`, expected `*`, `+`, or `-`\"\n );\n }\n return marker;\n}\nfunction checkBulletOther(state) {\n const bullet = checkBullet(state);\n const bulletOther = state.options.bulletOther;\n if (!bulletOther) {\n return bullet === \"*\" ? \"-\" : \"*\";\n }\n if (bulletOther !== \"*\" && bulletOther !== \"+\" && bulletOther !== \"-\") {\n throw new Error(\n \"Cannot serialize items with `\" + bulletOther + \"` for `options.bulletOther`, expected `*`, `+`, or `-`\"\n );\n }\n if (bulletOther === bullet) {\n throw new Error(\n \"Expected `bullet` (`\" + bullet + \"`) and `bulletOther` (`\" + bulletOther + \"`) to be different\"\n );\n }\n return bulletOther;\n}\nfunction checkBulletOrdered(state) {\n const marker = state.options.bulletOrdered || \".\";\n if (marker !== \".\" && marker !== \")\") {\n throw new Error(\n \"Cannot serialize items with `\" + marker + \"` for `options.bulletOrdered`, expected `.` or `)`\"\n );\n }\n return marker;\n}\nfunction checkRule(state) {\n const marker = state.options.rule || \"*\";\n if (marker !== \"*\" && marker !== \"-\" && marker !== \"_\") {\n throw new Error(\n \"Cannot serialize rules with `\" + marker + \"` for `options.rule`, expected `*`, `-`, or `_`\"\n );\n }\n return marker;\n}\nfunction list(node2, parent, state, info) {\n const exit2 = state.enter(\"list\");\n const bulletCurrent = state.bulletCurrent;\n let bullet = node2.ordered ? checkBulletOrdered(state) : checkBullet(state);\n const bulletOther = node2.ordered ? bullet === \".\" ? \")\" : \".\" : checkBulletOther(state);\n let useDifferentMarker = parent && state.bulletLastUsed ? bullet === state.bulletLastUsed : false;\n if (!node2.ordered) {\n const firstListItem = node2.children ? node2.children[0] : void 0;\n if (\n // Bullet could be used as a thematic break marker:\n (bullet === \"*\" || bullet === \"-\") && // Empty first list item:\n firstListItem && (!firstListItem.children || !firstListItem.children[0]) && // Directly in two other list items:\n state.stack[state.stack.length - 1] === \"list\" && state.stack[state.stack.length - 2] === \"listItem\" && state.stack[state.stack.length - 3] === \"list\" && state.stack[state.stack.length - 4] === \"listItem\" && // That are each the first child.\n state.indexStack[state.indexStack.length - 1] === 0 && state.indexStack[state.indexStack.length - 2] === 0 && state.indexStack[state.indexStack.length - 3] === 0\n ) {\n useDifferentMarker = true;\n }\n if (checkRule(state) === bullet && firstListItem) {\n let index = -1;\n while (++index < node2.children.length) {\n const item = node2.children[index];\n if (item && item.type === \"listItem\" && item.children && item.children[0] && item.children[0].type === \"thematicBreak\") {\n useDifferentMarker = true;\n break;\n }\n }\n }\n }\n if (useDifferentMarker) {\n bullet = bulletOther;\n }\n state.bulletCurrent = bullet;\n const value = state.containerFlow(node2, info);\n state.bulletLastUsed = bullet;\n state.bulletCurrent = bulletCurrent;\n exit2();\n return value;\n}\nfunction checkListItemIndent(state) {\n const style = state.options.listItemIndent || \"one\";\n if (style !== \"tab\" && style !== \"one\" && style !== \"mixed\") {\n throw new Error(\n \"Cannot serialize items with `\" + style + \"` for `options.listItemIndent`, expected `tab`, `one`, or `mixed`\"\n );\n }\n return style;\n}\nfunction listItem(node2, parent, state, info) {\n const listItemIndent = checkListItemIndent(state);\n let bullet = state.bulletCurrent || checkBullet(state);\n if (parent && parent.type === \"list\" && parent.ordered) {\n bullet = (typeof parent.start === \"number\" && parent.start > -1 ? parent.start : 1) + (state.options.incrementListMarker === false ? 0 : parent.children.indexOf(node2)) + bullet;\n }\n let size = bullet.length + 1;\n if (listItemIndent === \"tab\" || listItemIndent === \"mixed\" && (parent && parent.type === \"list\" && parent.spread || node2.spread)) {\n size = Math.ceil(size / 4) * 4;\n }\n const tracker = state.createTracker(info);\n tracker.move(bullet + \" \".repeat(size - bullet.length));\n tracker.shift(size);\n const exit2 = state.enter(\"listItem\");\n const value = state.indentLines(\n state.containerFlow(node2, tracker.current()),\n map2\n );\n exit2();\n return value;\n function map2(line, index, blank) {\n if (index) {\n return (blank ? \"\" : \" \".repeat(size)) + line;\n }\n return (blank ? bullet : bullet + \" \".repeat(size - bullet.length)) + line;\n }\n}\nfunction paragraph(node2, _, state, info) {\n const exit2 = state.enter(\"paragraph\");\n const subexit = state.enter(\"phrasing\");\n const value = state.containerPhrasing(node2, info);\n subexit();\n exit2();\n return value;\n}\nconst phrasing = (\n /** @type {(node?: unknown) => node is Exclude} */\n convert([\n \"break\",\n \"delete\",\n \"emphasis\",\n // To do: next major: removed since footnotes were added to GFM.\n \"footnote\",\n \"footnoteReference\",\n \"image\",\n \"imageReference\",\n \"inlineCode\",\n // Enabled by `mdast-util-math`:\n \"inlineMath\",\n \"link\",\n \"linkReference\",\n // Enabled by `mdast-util-mdx`:\n \"mdxJsxTextElement\",\n // Enabled by `mdast-util-mdx`:\n \"mdxTextExpression\",\n \"strong\",\n \"text\",\n // Enabled by `mdast-util-directive`:\n \"textDirective\"\n ])\n);\nfunction root(node2, _, state, info) {\n const hasPhrasing = node2.children.some(function(d) {\n return phrasing(d);\n });\n const container = hasPhrasing ? state.containerPhrasing : state.containerFlow;\n return container.call(state, node2, info);\n}\nfunction checkStrong(state) {\n const marker = state.options.strong || \"*\";\n if (marker !== \"*\" && marker !== \"_\") {\n throw new Error(\n \"Cannot serialize strong with `\" + marker + \"` for `options.strong`, expected `*`, or `_`\"\n );\n }\n return marker;\n}\nstrong.peek = strongPeek;\nfunction strong(node2, _, state, info) {\n const marker = checkStrong(state);\n const exit2 = state.enter(\"strong\");\n const tracker = state.createTracker(info);\n const before = tracker.move(marker + marker);\n let between = tracker.move(\n state.containerPhrasing(node2, {\n after: marker,\n before,\n ...tracker.current()\n })\n );\n const betweenHead = between.charCodeAt(0);\n const open = encodeInfo(\n info.before.charCodeAt(info.before.length - 1),\n betweenHead,\n marker\n );\n if (open.inside) {\n between = encodeCharacterReference(betweenHead) + between.slice(1);\n }\n const betweenTail = between.charCodeAt(between.length - 1);\n const close = encodeInfo(info.after.charCodeAt(0), betweenTail, marker);\n if (close.inside) {\n between = between.slice(0, -1) + encodeCharacterReference(betweenTail);\n }\n const after = tracker.move(marker + marker);\n exit2();\n state.attentionEncodeSurroundingInfo = {\n after: close.outside,\n before: open.outside\n };\n return before + between + after;\n}\nfunction strongPeek(_, _1, state) {\n return state.options.strong || \"*\";\n}\nfunction text$1(node2, _, state, info) {\n return state.safe(node2.value, info);\n}\nfunction checkRuleRepetition(state) {\n const repetition = state.options.ruleRepetition || 3;\n if (repetition < 3) {\n throw new Error(\n \"Cannot serialize rules with repetition `\" + repetition + \"` for `options.ruleRepetition`, expected `3` or more\"\n );\n }\n return repetition;\n}\nfunction thematicBreak(_, _1, state) {\n const value = (checkRule(state) + (state.options.ruleSpaces ? \" \" : \"\")).repeat(checkRuleRepetition(state));\n return state.options.ruleSpaces ? value.slice(0, -1) : value;\n}\nconst handle = {\n blockquote,\n break: hardBreak,\n code: code$1,\n definition,\n emphasis,\n hardBreak,\n heading,\n html,\n image,\n imageReference,\n inlineCode,\n link,\n linkReference,\n list,\n listItem,\n paragraph,\n root,\n strong,\n text: text$1,\n thematicBreak\n};\nfunction gfmTableFromMarkdown() {\n return {\n enter: {\n table: enterTable,\n tableData: enterCell,\n tableHeader: enterCell,\n tableRow: enterRow\n },\n exit: {\n codeText: exitCodeText,\n table: exitTable,\n tableData: exit,\n tableHeader: exit,\n tableRow: exit\n }\n };\n}\nfunction enterTable(token) {\n const align = token._align;\n this.enter(\n {\n type: \"table\",\n align: align.map(function(d) {\n return d === \"none\" ? null : d;\n }),\n children: []\n },\n token\n );\n this.data.inTable = true;\n}\nfunction exitTable(token) {\n this.exit(token);\n this.data.inTable = void 0;\n}\nfunction enterRow(token) {\n this.enter({ type: \"tableRow\", children: [] }, token);\n}\nfunction exit(token) {\n this.exit(token);\n}\nfunction enterCell(token) {\n this.enter({ type: \"tableCell\", children: [] }, token);\n}\nfunction exitCodeText(token) {\n let value = this.resume();\n if (this.data.inTable) {\n value = value.replace(/\\\\([\\\\|])/g, replace);\n }\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"inlineCode\");\n node2.value = value;\n this.exit(token);\n}\nfunction replace($0, $1) {\n return $1 === \"|\" ? $1 : $0;\n}\nfunction gfmTableToMarkdown(options) {\n const settings = options || {};\n const padding = settings.tableCellPadding;\n const alignDelimiters = settings.tablePipeAlign;\n const stringLength = settings.stringLength;\n const around = padding ? \" \" : \"|\";\n return {\n unsafe: [\n { character: \"\\r\", inConstruct: \"tableCell\" },\n { character: \"\\n\", inConstruct: \"tableCell\" },\n // A pipe, when followed by a tab or space (padding), or a dash or colon\n // (unpadded delimiter row), could result in a table.\n { atBreak: true, character: \"|\", after: \"[\t :-]\" },\n // A pipe in a cell must be encoded.\n { character: \"|\", inConstruct: \"tableCell\" },\n // A colon must be followed by a dash, in which case it could start a\n // delimiter row.\n { atBreak: true, character: \":\", after: \"-\" },\n // A delimiter row can also start with a dash, when followed by more\n // dashes, a colon, or a pipe.\n // This is a stricter version than the built in check for lists, thematic\n // breaks, and setex heading underlines though:\n // \n { atBreak: true, character: \"-\", after: \"[:|-]\" }\n ],\n handlers: {\n inlineCode: inlineCodeWithTable,\n table: handleTable,\n tableCell: handleTableCell,\n tableRow: handleTableRow\n }\n };\n function handleTable(node2, _, state, info) {\n return serializeData(handleTableAsData(node2, state, info), node2.align);\n }\n function handleTableRow(node2, _, state, info) {\n const row = handleTableRowAsData(node2, state, info);\n const value = serializeData([row]);\n return value.slice(0, value.indexOf(\"\\n\"));\n }\n function handleTableCell(node2, _, state, info) {\n const exit2 = state.enter(\"tableCell\");\n const subexit = state.enter(\"phrasing\");\n const value = state.containerPhrasing(node2, {\n ...info,\n before: around,\n after: around\n });\n subexit();\n exit2();\n return value;\n }\n function serializeData(matrix, align) {\n return markdownTable(matrix, {\n align,\n // @ts-expect-error: `markdown-table` types should support `null`.\n alignDelimiters,\n // @ts-expect-error: `markdown-table` types should support `null`.\n padding,\n // @ts-expect-error: `markdown-table` types should support `null`.\n stringLength\n });\n }\n function handleTableAsData(node2, state, info) {\n const children = node2.children;\n let index = -1;\n const result = [];\n const subexit = state.enter(\"table\");\n while (++index < children.length) {\n result[index] = handleTableRowAsData(children[index], state, info);\n }\n subexit();\n return result;\n }\n function handleTableRowAsData(node2, state, info) {\n const children = node2.children;\n let index = -1;\n const result = [];\n const subexit = state.enter(\"tableRow\");\n while (++index < children.length) {\n result[index] = handleTableCell(children[index], node2, state, info);\n }\n subexit();\n return result;\n }\n function inlineCodeWithTable(node2, parent, state) {\n let value = handle.inlineCode(node2, parent, state);\n if (state.stack.includes(\"tableCell\")) {\n value = value.replace(/\\|/g, \"\\\\$&\");\n }\n return value;\n }\n}\nfunction gfmTaskListItemFromMarkdown() {\n return {\n exit: {\n taskListCheckValueChecked: exitCheck,\n taskListCheckValueUnchecked: exitCheck,\n paragraph: exitParagraphWithTaskListItem\n }\n };\n}\nfunction gfmTaskListItemToMarkdown() {\n return {\n unsafe: [{ atBreak: true, character: \"-\", after: \"[:|-]\" }],\n handlers: { listItem: listItemWithTaskListItem }\n };\n}\nfunction exitCheck(token) {\n const node2 = this.stack[this.stack.length - 2];\n ok$1(node2.type === \"listItem\");\n node2.checked = token.type === \"taskListCheckValueChecked\";\n}\nfunction exitParagraphWithTaskListItem(token) {\n const parent = this.stack[this.stack.length - 2];\n if (parent && parent.type === \"listItem\" && typeof parent.checked === \"boolean\") {\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"paragraph\");\n const head = node2.children[0];\n if (head && head.type === \"text\") {\n const siblings = parent.children;\n let index = -1;\n let firstParaghraph;\n while (++index < siblings.length) {\n const sibling = siblings[index];\n if (sibling.type === \"paragraph\") {\n firstParaghraph = sibling;\n break;\n }\n }\n if (firstParaghraph === node2) {\n head.value = head.value.slice(1);\n if (head.value.length === 0) {\n node2.children.shift();\n } else if (node2.position && head.position && typeof head.position.start.offset === \"number\") {\n head.position.start.column++;\n head.position.start.offset++;\n node2.position.start = Object.assign({}, head.position.start);\n }\n }\n }\n }\n this.exit(token);\n}\nfunction listItemWithTaskListItem(node2, parent, state, info) {\n const head = node2.children[0];\n const checkable = typeof node2.checked === \"boolean\" && head && head.type === \"paragraph\";\n const checkbox = \"[\" + (node2.checked ? \"x\" : \" \") + \"] \";\n const tracker = state.createTracker(info);\n if (checkable) {\n tracker.move(checkbox);\n }\n let value = handle.listItem(node2, parent, state, {\n ...info,\n ...tracker.current()\n });\n if (checkable) {\n value = value.replace(/^(?:[*+-]|\\d+\\.)([\\r\\n]| {1,3})/, check);\n }\n return value;\n function check($0) {\n return $0 + checkbox;\n }\n}\nfunction gfmFromMarkdown() {\n return [\n gfmAutolinkLiteralFromMarkdown(),\n gfmFootnoteFromMarkdown(),\n gfmStrikethroughFromMarkdown(),\n gfmTableFromMarkdown(),\n gfmTaskListItemFromMarkdown()\n ];\n}\nfunction gfmToMarkdown(options) {\n return {\n extensions: [\n gfmAutolinkLiteralToMarkdown(),\n gfmFootnoteToMarkdown(options),\n gfmStrikethroughToMarkdown(),\n gfmTableToMarkdown(options),\n gfmTaskListItemToMarkdown()\n ]\n };\n}\nfunction splice(list2, start, remove, items) {\n const end = list2.length;\n let chunkStart = 0;\n let parameters;\n if (start < 0) {\n start = -start > end ? 0 : end + start;\n } else {\n start = start > end ? end : start;\n }\n remove = remove > 0 ? remove : 0;\n if (items.length < 1e4) {\n parameters = Array.from(items);\n parameters.unshift(start, remove);\n list2.splice(...parameters);\n } else {\n if (remove) list2.splice(start, remove);\n while (chunkStart < items.length) {\n parameters = items.slice(chunkStart, chunkStart + 1e4);\n parameters.unshift(start, 0);\n list2.splice(...parameters);\n chunkStart += 1e4;\n start += 1e4;\n }\n }\n}\nconst hasOwnProperty = {}.hasOwnProperty;\nfunction combineExtensions(extensions) {\n const all2 = {};\n let index = -1;\n while (++index < extensions.length) {\n syntaxExtension(all2, extensions[index]);\n }\n return all2;\n}\nfunction syntaxExtension(all2, extension) {\n let hook;\n for (hook in extension) {\n const maybe = hasOwnProperty.call(all2, hook) ? all2[hook] : void 0;\n const left = maybe || (all2[hook] = {});\n const right = extension[hook];\n let code2;\n if (right) {\n for (code2 in right) {\n if (!hasOwnProperty.call(left, code2)) left[code2] = [];\n const value = right[code2];\n constructs(\n // @ts-expect-error Looks like a list.\n left[code2],\n Array.isArray(value) ? value : value ? [value] : []\n );\n }\n }\n }\n}\nfunction constructs(existing, list2) {\n let index = -1;\n const before = [];\n while (++index < list2.length) {\n (list2[index].add === \"after\" ? existing : before).push(list2[index]);\n }\n splice(existing, 0, 0, before);\n}\nconst wwwPrefix = {\n tokenize: tokenizeWwwPrefix,\n partial: true\n};\nconst domain = {\n tokenize: tokenizeDomain,\n partial: true\n};\nconst path = {\n tokenize: tokenizePath,\n partial: true\n};\nconst trail = {\n tokenize: tokenizeTrail,\n partial: true\n};\nconst emailDomainDotTrail = {\n tokenize: tokenizeEmailDomainDotTrail,\n partial: true\n};\nconst wwwAutolink = {\n name: \"wwwAutolink\",\n tokenize: tokenizeWwwAutolink,\n previous: previousWww\n};\nconst protocolAutolink = {\n name: \"protocolAutolink\",\n tokenize: tokenizeProtocolAutolink,\n previous: previousProtocol\n};\nconst emailAutolink = {\n name: \"emailAutolink\",\n tokenize: tokenizeEmailAutolink,\n previous: previousEmail\n};\nconst text = {};\nfunction gfmAutolinkLiteral() {\n return {\n text\n };\n}\nlet code = 48;\nwhile (code < 123) {\n text[code] = emailAutolink;\n code++;\n if (code === 58) code = 65;\n else if (code === 91) code = 97;\n}\ntext[43] = emailAutolink;\ntext[45] = emailAutolink;\ntext[46] = emailAutolink;\ntext[95] = emailAutolink;\ntext[72] = [emailAutolink, protocolAutolink];\ntext[104] = [emailAutolink, protocolAutolink];\ntext[87] = [emailAutolink, wwwAutolink];\ntext[119] = [emailAutolink, wwwAutolink];\nfunction tokenizeEmailAutolink(effects, ok2, nok) {\n const self = this;\n let dot;\n let data;\n return start;\n function start(code2) {\n if (!gfmAtext(code2) || !previousEmail.call(self, self.previous) || previousUnbalanced(self.events)) {\n return nok(code2);\n }\n effects.enter(\"literalAutolink\");\n effects.enter(\"literalAutolinkEmail\");\n return atext(code2);\n }\n function atext(code2) {\n if (gfmAtext(code2)) {\n effects.consume(code2);\n return atext;\n }\n if (code2 === 64) {\n effects.consume(code2);\n return emailDomain;\n }\n return nok(code2);\n }\n function emailDomain(code2) {\n if (code2 === 46) {\n return effects.check(emailDomainDotTrail, emailDomainAfter, emailDomainDot)(code2);\n }\n if (code2 === 45 || code2 === 95 || asciiAlphanumeric(code2)) {\n data = true;\n effects.consume(code2);\n return emailDomain;\n }\n return emailDomainAfter(code2);\n }\n function emailDomainDot(code2) {\n effects.consume(code2);\n dot = true;\n return emailDomain;\n }\n function emailDomainAfter(code2) {\n if (data && dot && asciiAlpha(self.previous)) {\n effects.exit(\"literalAutolinkEmail\");\n effects.exit(\"literalAutolink\");\n return ok2(code2);\n }\n return nok(code2);\n }\n}\nfunction tokenizeWwwAutolink(effects, ok2, nok) {\n const self = this;\n return wwwStart;\n function wwwStart(code2) {\n if (code2 !== 87 && code2 !== 119 || !previousWww.call(self, self.previous) || previousUnbalanced(self.events)) {\n return nok(code2);\n }\n effects.enter(\"literalAutolink\");\n effects.enter(\"literalAutolinkWww\");\n return effects.check(wwwPrefix, effects.attempt(domain, effects.attempt(path, wwwAfter), nok), nok)(code2);\n }\n function wwwAfter(code2) {\n effects.exit(\"literalAutolinkWww\");\n effects.exit(\"literalAutolink\");\n return ok2(code2);\n }\n}\nfunction tokenizeProtocolAutolink(effects, ok2, nok) {\n const self = this;\n let buffer = \"\";\n let seen = false;\n return protocolStart;\n function protocolStart(code2) {\n if ((code2 === 72 || code2 === 104) && previousProtocol.call(self, self.previous) && !previousUnbalanced(self.events)) {\n effects.enter(\"literalAutolink\");\n effects.enter(\"literalAutolinkHttp\");\n buffer += String.fromCodePoint(code2);\n effects.consume(code2);\n return protocolPrefixInside;\n }\n return nok(code2);\n }\n function protocolPrefixInside(code2) {\n if (asciiAlpha(code2) && buffer.length < 5) {\n buffer += String.fromCodePoint(code2);\n effects.consume(code2);\n return protocolPrefixInside;\n }\n if (code2 === 58) {\n const protocol = buffer.toLowerCase();\n if (protocol === \"http\" || protocol === \"https\") {\n effects.consume(code2);\n return protocolSlashesInside;\n }\n }\n return nok(code2);\n }\n function protocolSlashesInside(code2) {\n if (code2 === 47) {\n effects.consume(code2);\n if (seen) {\n return afterProtocol;\n }\n seen = true;\n return protocolSlashesInside;\n }\n return nok(code2);\n }\n function afterProtocol(code2) {\n return code2 === null || asciiControl(code2) || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2) || unicodePunctuation(code2) ? nok(code2) : effects.attempt(domain, effects.attempt(path, protocolAfter), nok)(code2);\n }\n function protocolAfter(code2) {\n effects.exit(\"literalAutolinkHttp\");\n effects.exit(\"literalAutolink\");\n return ok2(code2);\n }\n}\nfunction tokenizeWwwPrefix(effects, ok2, nok) {\n let size = 0;\n return wwwPrefixInside;\n function wwwPrefixInside(code2) {\n if ((code2 === 87 || code2 === 119) && size < 3) {\n size++;\n effects.consume(code2);\n return wwwPrefixInside;\n }\n if (code2 === 46 && size === 3) {\n effects.consume(code2);\n return wwwPrefixAfter;\n }\n return nok(code2);\n }\n function wwwPrefixAfter(code2) {\n return code2 === null ? nok(code2) : ok2(code2);\n }\n}\nfunction tokenizeDomain(effects, ok2, nok) {\n let underscoreInLastSegment;\n let underscoreInLastLastSegment;\n let seen;\n return domainInside;\n function domainInside(code2) {\n if (code2 === 46 || code2 === 95) {\n return effects.check(trail, domainAfter, domainAtPunctuation)(code2);\n }\n if (code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2) || code2 !== 45 && unicodePunctuation(code2)) {\n return domainAfter(code2);\n }\n seen = true;\n effects.consume(code2);\n return domainInside;\n }\n function domainAtPunctuation(code2) {\n if (code2 === 95) {\n underscoreInLastSegment = true;\n } else {\n underscoreInLastLastSegment = underscoreInLastSegment;\n underscoreInLastSegment = void 0;\n }\n effects.consume(code2);\n return domainInside;\n }\n function domainAfter(code2) {\n if (underscoreInLastLastSegment || underscoreInLastSegment || !seen) {\n return nok(code2);\n }\n return ok2(code2);\n }\n}\nfunction tokenizePath(effects, ok2) {\n let sizeOpen = 0;\n let sizeClose = 0;\n return pathInside;\n function pathInside(code2) {\n if (code2 === 40) {\n sizeOpen++;\n effects.consume(code2);\n return pathInside;\n }\n if (code2 === 41 && sizeClose < sizeOpen) {\n return pathAtPunctuation(code2);\n }\n if (code2 === 33 || code2 === 34 || code2 === 38 || code2 === 39 || code2 === 41 || code2 === 42 || code2 === 44 || code2 === 46 || code2 === 58 || code2 === 59 || code2 === 60 || code2 === 63 || code2 === 93 || code2 === 95 || code2 === 126) {\n return effects.check(trail, ok2, pathAtPunctuation)(code2);\n }\n if (code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)) {\n return ok2(code2);\n }\n effects.consume(code2);\n return pathInside;\n }\n function pathAtPunctuation(code2) {\n if (code2 === 41) {\n sizeClose++;\n }\n effects.consume(code2);\n return pathInside;\n }\n}\nfunction tokenizeTrail(effects, ok2, nok) {\n return trail2;\n function trail2(code2) {\n if (code2 === 33 || code2 === 34 || code2 === 39 || code2 === 41 || code2 === 42 || code2 === 44 || code2 === 46 || code2 === 58 || code2 === 59 || code2 === 63 || code2 === 95 || code2 === 126) {\n effects.consume(code2);\n return trail2;\n }\n if (code2 === 38) {\n effects.consume(code2);\n return trailCharacterReferenceStart;\n }\n if (code2 === 93) {\n effects.consume(code2);\n return trailBracketAfter;\n }\n if (\n // `<` is an end.\n code2 === 60 || // So is whitespace.\n code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)\n ) {\n return ok2(code2);\n }\n return nok(code2);\n }\n function trailBracketAfter(code2) {\n if (code2 === null || code2 === 40 || code2 === 91 || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)) {\n return ok2(code2);\n }\n return trail2(code2);\n }\n function trailCharacterReferenceStart(code2) {\n return asciiAlpha(code2) ? trailCharacterReferenceInside(code2) : nok(code2);\n }\n function trailCharacterReferenceInside(code2) {\n if (code2 === 59) {\n effects.consume(code2);\n return trail2;\n }\n if (asciiAlpha(code2)) {\n effects.consume(code2);\n return trailCharacterReferenceInside;\n }\n return nok(code2);\n }\n}\nfunction tokenizeEmailDomainDotTrail(effects, ok2, nok) {\n return start;\n function start(code2) {\n effects.consume(code2);\n return after;\n }\n function after(code2) {\n return asciiAlphanumeric(code2) ? nok(code2) : ok2(code2);\n }\n}\nfunction previousWww(code2) {\n return code2 === null || code2 === 40 || code2 === 42 || code2 === 95 || code2 === 91 || code2 === 93 || code2 === 126 || markdownLineEndingOrSpace(code2);\n}\nfunction previousProtocol(code2) {\n return !asciiAlpha(code2);\n}\nfunction previousEmail(code2) {\n return !(code2 === 47 || gfmAtext(code2));\n}\nfunction gfmAtext(code2) {\n return code2 === 43 || code2 === 45 || code2 === 46 || code2 === 95 || asciiAlphanumeric(code2);\n}\nfunction previousUnbalanced(events) {\n let index = events.length;\n let result = false;\n while (index--) {\n const token = events[index][1];\n if ((token.type === \"labelLink\" || token.type === \"labelImage\") && !token._balanced) {\n result = true;\n break;\n }\n if (token._gfmAutolinkLiteralWalkedInto) {\n result = false;\n break;\n }\n }\n if (events.length > 0 && !result) {\n events[events.length - 1][1]._gfmAutolinkLiteralWalkedInto = true;\n }\n return result;\n}\nfunction resolveAll(constructs2, events, context) {\n const called = [];\n let index = -1;\n while (++index < constructs2.length) {\n const resolve = constructs2[index].resolveAll;\n if (resolve && !called.includes(resolve)) {\n events = resolve(events, context);\n called.push(resolve);\n }\n }\n return events;\n}\nfunction factorySpace(effects, ok2, type, max) {\n const limit = max ? max - 1 : Number.POSITIVE_INFINITY;\n let size = 0;\n return start;\n function start(code2) {\n if (markdownSpace(code2)) {\n effects.enter(type);\n return prefix(code2);\n }\n return ok2(code2);\n }\n function prefix(code2) {\n if (markdownSpace(code2) && size++ < limit) {\n effects.consume(code2);\n return prefix;\n }\n effects.exit(type);\n return ok2(code2);\n }\n}\nconst blankLine = {\n partial: true,\n tokenize: tokenizeBlankLine\n};\nfunction tokenizeBlankLine(effects, ok2, nok) {\n return start;\n function start(code2) {\n return markdownSpace(code2) ? factorySpace(effects, after, \"linePrefix\")(code2) : after(code2);\n }\n function after(code2) {\n return code2 === null || markdownLineEnding(code2) ? ok2(code2) : nok(code2);\n }\n}\nconst indent = {\n tokenize: tokenizeIndent,\n partial: true\n};\nfunction gfmFootnote() {\n return {\n document: {\n [91]: {\n name: \"gfmFootnoteDefinition\",\n tokenize: tokenizeDefinitionStart,\n continuation: {\n tokenize: tokenizeDefinitionContinuation\n },\n exit: gfmFootnoteDefinitionEnd\n }\n },\n text: {\n [91]: {\n name: \"gfmFootnoteCall\",\n tokenize: tokenizeGfmFootnoteCall\n },\n [93]: {\n name: \"gfmPotentialFootnoteCall\",\n add: \"after\",\n tokenize: tokenizePotentialGfmFootnoteCall,\n resolveTo: resolveToPotentialGfmFootnoteCall\n }\n }\n };\n}\nfunction tokenizePotentialGfmFootnoteCall(effects, ok2, nok) {\n const self = this;\n let index = self.events.length;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let labelStart;\n while (index--) {\n const token = self.events[index][1];\n if (token.type === \"labelImage\") {\n labelStart = token;\n break;\n }\n if (token.type === \"gfmFootnoteCall\" || token.type === \"labelLink\" || token.type === \"label\" || token.type === \"image\" || token.type === \"link\") {\n break;\n }\n }\n return start;\n function start(code2) {\n if (!labelStart || !labelStart._balanced) {\n return nok(code2);\n }\n const id = normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n }));\n if (id.codePointAt(0) !== 94 || !defined.includes(id.slice(1))) {\n return nok(code2);\n }\n effects.enter(\"gfmFootnoteCallLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallLabelMarker\");\n return ok2(code2);\n }\n}\nfunction resolveToPotentialGfmFootnoteCall(events, context) {\n let index = events.length;\n while (index--) {\n if (events[index][1].type === \"labelImage\" && events[index][0] === \"enter\") {\n events[index][1];\n break;\n }\n }\n events[index + 1][1].type = \"data\";\n events[index + 3][1].type = \"gfmFootnoteCallLabelMarker\";\n const call = {\n type: \"gfmFootnoteCall\",\n start: Object.assign({}, events[index + 3][1].start),\n end: Object.assign({}, events[events.length - 1][1].end)\n };\n const marker = {\n type: \"gfmFootnoteCallMarker\",\n start: Object.assign({}, events[index + 3][1].end),\n end: Object.assign({}, events[index + 3][1].end)\n };\n marker.end.column++;\n marker.end.offset++;\n marker.end._bufferIndex++;\n const string = {\n type: \"gfmFootnoteCallString\",\n start: Object.assign({}, marker.end),\n end: Object.assign({}, events[events.length - 1][1].start)\n };\n const chunk = {\n type: \"chunkString\",\n contentType: \"string\",\n start: Object.assign({}, string.start),\n end: Object.assign({}, string.end)\n };\n const replacement = [\n // Take the `labelImageMarker` (now `data`, the `!`)\n events[index + 1],\n events[index + 2],\n [\"enter\", call, context],\n // The `[`\n events[index + 3],\n events[index + 4],\n // The `^`.\n [\"enter\", marker, context],\n [\"exit\", marker, context],\n // Everything in between.\n [\"enter\", string, context],\n [\"enter\", chunk, context],\n [\"exit\", chunk, context],\n [\"exit\", string, context],\n // The ending (`]`, properly parsed and labelled).\n events[events.length - 2],\n events[events.length - 1],\n [\"exit\", call, context]\n ];\n events.splice(index, events.length - index + 1, ...replacement);\n return events;\n}\nfunction tokenizeGfmFootnoteCall(effects, ok2, nok) {\n const self = this;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let size = 0;\n let data;\n return start;\n function start(code2) {\n effects.enter(\"gfmFootnoteCall\");\n effects.enter(\"gfmFootnoteCallLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallLabelMarker\");\n return callStart;\n }\n function callStart(code2) {\n if (code2 !== 94) return nok(code2);\n effects.enter(\"gfmFootnoteCallMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallMarker\");\n effects.enter(\"gfmFootnoteCallString\");\n effects.enter(\"chunkString\").contentType = \"string\";\n return callData;\n }\n function callData(code2) {\n if (\n // Too long.\n size > 999 || // Closing brace with nothing.\n code2 === 93 && !data || // Space or tab is not supported by GFM for some reason.\n // `\\n` and `[` not being supported makes sense.\n code2 === null || code2 === 91 || markdownLineEndingOrSpace(code2)\n ) {\n return nok(code2);\n }\n if (code2 === 93) {\n effects.exit(\"chunkString\");\n const token = effects.exit(\"gfmFootnoteCallString\");\n if (!defined.includes(normalizeIdentifier(self.sliceSerialize(token)))) {\n return nok(code2);\n }\n effects.enter(\"gfmFootnoteCallLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallLabelMarker\");\n effects.exit(\"gfmFootnoteCall\");\n return ok2;\n }\n if (!markdownLineEndingOrSpace(code2)) {\n data = true;\n }\n size++;\n effects.consume(code2);\n return code2 === 92 ? callEscape : callData;\n }\n function callEscape(code2) {\n if (code2 === 91 || code2 === 92 || code2 === 93) {\n effects.consume(code2);\n size++;\n return callData;\n }\n return callData(code2);\n }\n}\nfunction tokenizeDefinitionStart(effects, ok2, nok) {\n const self = this;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let identifier;\n let size = 0;\n let data;\n return start;\n function start(code2) {\n effects.enter(\"gfmFootnoteDefinition\")._container = true;\n effects.enter(\"gfmFootnoteDefinitionLabel\");\n effects.enter(\"gfmFootnoteDefinitionLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteDefinitionLabelMarker\");\n return labelAtMarker;\n }\n function labelAtMarker(code2) {\n if (code2 === 94) {\n effects.enter(\"gfmFootnoteDefinitionMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteDefinitionMarker\");\n effects.enter(\"gfmFootnoteDefinitionLabelString\");\n effects.enter(\"chunkString\").contentType = \"string\";\n return labelInside;\n }\n return nok(code2);\n }\n function labelInside(code2) {\n if (\n // Too long.\n size > 999 || // Closing brace with nothing.\n code2 === 93 && !data || // Space or tab is not supported by GFM for some reason.\n // `\\n` and `[` not being supported makes sense.\n code2 === null || code2 === 91 || markdownLineEndingOrSpace(code2)\n ) {\n return nok(code2);\n }\n if (code2 === 93) {\n effects.exit(\"chunkString\");\n const token = effects.exit(\"gfmFootnoteDefinitionLabelString\");\n identifier = normalizeIdentifier(self.sliceSerialize(token));\n effects.enter(\"gfmFootnoteDefinitionLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteDefinitionLabelMarker\");\n effects.exit(\"gfmFootnoteDefinitionLabel\");\n return labelAfter;\n }\n if (!markdownLineEndingOrSpace(code2)) {\n data = true;\n }\n size++;\n effects.consume(code2);\n return code2 === 92 ? labelEscape : labelInside;\n }\n function labelEscape(code2) {\n if (code2 === 91 || code2 === 92 || code2 === 93) {\n effects.consume(code2);\n size++;\n return labelInside;\n }\n return labelInside(code2);\n }\n function labelAfter(code2) {\n if (code2 === 58) {\n effects.enter(\"definitionMarker\");\n effects.consume(code2);\n effects.exit(\"definitionMarker\");\n if (!defined.includes(identifier)) {\n defined.push(identifier);\n }\n return factorySpace(effects, whitespaceAfter, \"gfmFootnoteDefinitionWhitespace\");\n }\n return nok(code2);\n }\n function whitespaceAfter(code2) {\n return ok2(code2);\n }\n}\nfunction tokenizeDefinitionContinuation(effects, ok2, nok) {\n return effects.check(blankLine, ok2, effects.attempt(indent, ok2, nok));\n}\nfunction gfmFootnoteDefinitionEnd(effects) {\n effects.exit(\"gfmFootnoteDefinition\");\n}\nfunction tokenizeIndent(effects, ok2, nok) {\n const self = this;\n return factorySpace(effects, afterPrefix, \"gfmFootnoteDefinitionIndent\", 4 + 1);\n function afterPrefix(code2) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"gfmFootnoteDefinitionIndent\" && tail[2].sliceSerialize(tail[1], true).length === 4 ? ok2(code2) : nok(code2);\n }\n}\nfunction gfmStrikethrough(options) {\n const options_ = options || {};\n let single = options_.singleTilde;\n const tokenizer = {\n name: \"strikethrough\",\n tokenize: tokenizeStrikethrough,\n resolveAll: resolveAllStrikethrough\n };\n if (single === null || single === void 0) {\n single = true;\n }\n return {\n text: {\n [126]: tokenizer\n },\n insideSpan: {\n null: [tokenizer]\n },\n attentionMarkers: {\n null: [126]\n }\n };\n function resolveAllStrikethrough(events, context) {\n let index = -1;\n while (++index < events.length) {\n if (events[index][0] === \"enter\" && events[index][1].type === \"strikethroughSequenceTemporary\" && events[index][1]._close) {\n let open = index;\n while (open--) {\n if (events[open][0] === \"exit\" && events[open][1].type === \"strikethroughSequenceTemporary\" && events[open][1]._open && // If the sizes are the same:\n events[index][1].end.offset - events[index][1].start.offset === events[open][1].end.offset - events[open][1].start.offset) {\n events[index][1].type = \"strikethroughSequence\";\n events[open][1].type = \"strikethroughSequence\";\n const strikethrough = {\n type: \"strikethrough\",\n start: Object.assign({}, events[open][1].start),\n end: Object.assign({}, events[index][1].end)\n };\n const text2 = {\n type: \"strikethroughText\",\n start: Object.assign({}, events[open][1].end),\n end: Object.assign({}, events[index][1].start)\n };\n const nextEvents = [[\"enter\", strikethrough, context], [\"enter\", events[open][1], context], [\"exit\", events[open][1], context], [\"enter\", text2, context]];\n const insideSpan = context.parser.constructs.insideSpan.null;\n if (insideSpan) {\n splice(nextEvents, nextEvents.length, 0, resolveAll(insideSpan, events.slice(open + 1, index), context));\n }\n splice(nextEvents, nextEvents.length, 0, [[\"exit\", text2, context], [\"enter\", events[index][1], context], [\"exit\", events[index][1], context], [\"exit\", strikethrough, context]]);\n splice(events, open - 1, index - open + 3, nextEvents);\n index = open + nextEvents.length - 2;\n break;\n }\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n if (events[index][1].type === \"strikethroughSequenceTemporary\") {\n events[index][1].type = \"data\";\n }\n }\n return events;\n }\n function tokenizeStrikethrough(effects, ok2, nok) {\n const previous2 = this.previous;\n const events = this.events;\n let size = 0;\n return start;\n function start(code2) {\n if (previous2 === 126 && events[events.length - 1][1].type !== \"characterEscape\") {\n return nok(code2);\n }\n effects.enter(\"strikethroughSequenceTemporary\");\n return more(code2);\n }\n function more(code2) {\n const before = classifyCharacter(previous2);\n if (code2 === 126) {\n if (size > 1) return nok(code2);\n effects.consume(code2);\n size++;\n return more;\n }\n if (size < 2 && !single) return nok(code2);\n const token = effects.exit(\"strikethroughSequenceTemporary\");\n const after = classifyCharacter(code2);\n token._open = !after || after === 2 && Boolean(before);\n token._close = !before || before === 2 && Boolean(after);\n return ok2(code2);\n }\n }\n}\nclass EditMap {\n /**\n * Create a new edit map.\n */\n constructor() {\n this.map = [];\n }\n /**\n * Create an edit: a remove and/or add at a certain place.\n *\n * @param {number} index\n * @param {number} remove\n * @param {Array} add\n * @returns {undefined}\n */\n add(index, remove, add) {\n addImplementation(this, index, remove, add);\n }\n // To do: add this when moving to `micromark`.\n // /**\n // * Create an edit: but insert `add` before existing additions.\n // *\n // * @param {number} index\n // * @param {number} remove\n // * @param {Array} add\n // * @returns {undefined}\n // */\n // addBefore(index, remove, add) {\n // addImplementation(this, index, remove, add, true)\n // }\n /**\n * Done, change the events.\n *\n * @param {Array} events\n * @returns {undefined}\n */\n consume(events) {\n this.map.sort(function(a, b) {\n return a[0] - b[0];\n });\n if (this.map.length === 0) {\n return;\n }\n let index = this.map.length;\n const vecs = [];\n while (index > 0) {\n index -= 1;\n vecs.push(events.slice(this.map[index][0] + this.map[index][1]), this.map[index][2]);\n events.length = this.map[index][0];\n }\n vecs.push(events.slice());\n events.length = 0;\n let slice = vecs.pop();\n while (slice) {\n for (const element of slice) {\n events.push(element);\n }\n slice = vecs.pop();\n }\n this.map.length = 0;\n }\n}\nfunction addImplementation(editMap, at, remove, add) {\n let index = 0;\n if (remove === 0 && add.length === 0) {\n return;\n }\n while (index < editMap.map.length) {\n if (editMap.map[index][0] === at) {\n editMap.map[index][1] += remove;\n editMap.map[index][2].push(...add);\n return;\n }\n index += 1;\n }\n editMap.map.push([at, remove, add]);\n}\nfunction gfmTableAlign(events, index) {\n let inDelimiterRow = false;\n const align = [];\n while (index < events.length) {\n const event = events[index];\n if (inDelimiterRow) {\n if (event[0] === \"enter\") {\n if (event[1].type === \"tableContent\") {\n align.push(events[index + 1][1].type === \"tableDelimiterMarker\" ? \"left\" : \"none\");\n }\n } else if (event[1].type === \"tableContent\") {\n if (events[index - 1][1].type === \"tableDelimiterMarker\") {\n const alignIndex = align.length - 1;\n align[alignIndex] = align[alignIndex] === \"left\" ? \"center\" : \"right\";\n }\n } else if (event[1].type === \"tableDelimiterRow\") {\n break;\n }\n } else if (event[0] === \"enter\" && event[1].type === \"tableDelimiterRow\") {\n inDelimiterRow = true;\n }\n index += 1;\n }\n return align;\n}\nfunction gfmTable() {\n return {\n flow: {\n null: {\n name: \"table\",\n tokenize: tokenizeTable,\n resolveAll: resolveTable\n }\n }\n };\n}\nfunction tokenizeTable(effects, ok2, nok) {\n const self = this;\n let size = 0;\n let sizeB = 0;\n let seen;\n return start;\n function start(code2) {\n let index = self.events.length - 1;\n while (index > -1) {\n const type = self.events[index][1].type;\n if (type === \"lineEnding\" || // Note: markdown-rs uses `whitespace` instead of `linePrefix`\n type === \"linePrefix\") index--;\n else break;\n }\n const tail = index > -1 ? self.events[index][1].type : null;\n const next = tail === \"tableHead\" || tail === \"tableRow\" ? bodyRowStart : headRowBefore;\n if (next === bodyRowStart && self.parser.lazy[self.now().line]) {\n return nok(code2);\n }\n return next(code2);\n }\n function headRowBefore(code2) {\n effects.enter(\"tableHead\");\n effects.enter(\"tableRow\");\n return headRowStart(code2);\n }\n function headRowStart(code2) {\n if (code2 === 124) {\n return headRowBreak(code2);\n }\n seen = true;\n sizeB += 1;\n return headRowBreak(code2);\n }\n function headRowBreak(code2) {\n if (code2 === null) {\n return nok(code2);\n }\n if (markdownLineEnding(code2)) {\n if (sizeB > 1) {\n sizeB = 0;\n self.interrupt = true;\n effects.exit(\"tableRow\");\n effects.enter(\"lineEnding\");\n effects.consume(code2);\n effects.exit(\"lineEnding\");\n return headDelimiterStart;\n }\n return nok(code2);\n }\n if (markdownSpace(code2)) {\n return factorySpace(effects, headRowBreak, \"whitespace\")(code2);\n }\n sizeB += 1;\n if (seen) {\n seen = false;\n size += 1;\n }\n if (code2 === 124) {\n effects.enter(\"tableCellDivider\");\n effects.consume(code2);\n effects.exit(\"tableCellDivider\");\n seen = true;\n return headRowBreak;\n }\n effects.enter(\"data\");\n return headRowData(code2);\n }\n function headRowData(code2) {\n if (code2 === null || code2 === 124 || markdownLineEndingOrSpace(code2)) {\n effects.exit(\"data\");\n return headRowBreak(code2);\n }\n effects.consume(code2);\n return code2 === 92 ? headRowEscape : headRowData;\n }\n function headRowEscape(code2) {\n if (code2 === 92 || code2 === 124) {\n effects.consume(code2);\n return headRowData;\n }\n return headRowData(code2);\n }\n function headDelimiterStart(code2) {\n self.interrupt = false;\n if (self.parser.lazy[self.now().line]) {\n return nok(code2);\n }\n effects.enter(\"tableDelimiterRow\");\n seen = false;\n if (markdownSpace(code2)) {\n return factorySpace(effects, headDelimiterBefore, \"linePrefix\", self.parser.constructs.disable.null.includes(\"codeIndented\") ? void 0 : 4)(code2);\n }\n return headDelimiterBefore(code2);\n }\n function headDelimiterBefore(code2) {\n if (code2 === 45 || code2 === 58) {\n return headDelimiterValueBefore(code2);\n }\n if (code2 === 124) {\n seen = true;\n effects.enter(\"tableCellDivider\");\n effects.consume(code2);\n effects.exit(\"tableCellDivider\");\n return headDelimiterCellBefore;\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterCellBefore(code2) {\n if (markdownSpace(code2)) {\n return factorySpace(effects, headDelimiterValueBefore, \"whitespace\")(code2);\n }\n return headDelimiterValueBefore(code2);\n }\n function headDelimiterValueBefore(code2) {\n if (code2 === 58) {\n sizeB += 1;\n seen = true;\n effects.enter(\"tableDelimiterMarker\");\n effects.consume(code2);\n effects.exit(\"tableDelimiterMarker\");\n return headDelimiterLeftAlignmentAfter;\n }\n if (code2 === 45) {\n sizeB += 1;\n return headDelimiterLeftAlignmentAfter(code2);\n }\n if (code2 === null || markdownLineEnding(code2)) {\n return headDelimiterCellAfter(code2);\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterLeftAlignmentAfter(code2) {\n if (code2 === 45) {\n effects.enter(\"tableDelimiterFiller\");\n return headDelimiterFiller(code2);\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterFiller(code2) {\n if (code2 === 45) {\n effects.consume(code2);\n return headDelimiterFiller;\n }\n if (code2 === 58) {\n seen = true;\n effects.exit(\"tableDelimiterFiller\");\n effects.enter(\"tableDelimiterMarker\");\n effects.consume(code2);\n effects.exit(\"tableDelimiterMarker\");\n return headDelimiterRightAlignmentAfter;\n }\n effects.exit(\"tableDelimiterFiller\");\n return headDelimiterRightAlignmentAfter(code2);\n }\n function headDelimiterRightAlignmentAfter(code2) {\n if (markdownSpace(code2)) {\n return factorySpace(effects, headDelimiterCellAfter, \"whitespace\")(code2);\n }\n return headDelimiterCellAfter(code2);\n }\n function headDelimiterCellAfter(code2) {\n if (code2 === 124) {\n return headDelimiterBefore(code2);\n }\n if (code2 === null || markdownLineEnding(code2)) {\n if (!seen || size !== sizeB) {\n return headDelimiterNok(code2);\n }\n effects.exit(\"tableDelimiterRow\");\n effects.exit(\"tableHead\");\n return ok2(code2);\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterNok(code2) {\n return nok(code2);\n }\n function bodyRowStart(code2) {\n effects.enter(\"tableRow\");\n return bodyRowBreak(code2);\n }\n function bodyRowBreak(code2) {\n if (code2 === 124) {\n effects.enter(\"tableCellDivider\");\n effects.consume(code2);\n effects.exit(\"tableCellDivider\");\n return bodyRowBreak;\n }\n if (code2 === null || markdownLineEnding(code2)) {\n effects.exit(\"tableRow\");\n return ok2(code2);\n }\n if (markdownSpace(code2)) {\n return factorySpace(effects, bodyRowBreak, \"whitespace\")(code2);\n }\n effects.enter(\"data\");\n return bodyRowData(code2);\n }\n function bodyRowData(code2) {\n if (code2 === null || code2 === 124 || markdownLineEndingOrSpace(code2)) {\n effects.exit(\"data\");\n return bodyRowBreak(code2);\n }\n effects.consume(code2);\n return code2 === 92 ? bodyRowEscape : bodyRowData;\n }\n function bodyRowEscape(code2) {\n if (code2 === 92 || code2 === 124) {\n effects.consume(code2);\n return bodyRowData;\n }\n return bodyRowData(code2);\n }\n}\nfunction resolveTable(events, context) {\n let index = -1;\n let inFirstCellAwaitingPipe = true;\n let rowKind = 0;\n let lastCell = [0, 0, 0, 0];\n let cell = [0, 0, 0, 0];\n let afterHeadAwaitingFirstBodyRow = false;\n let lastTableEnd = 0;\n let currentTable;\n let currentBody;\n let currentCell;\n const map2 = new EditMap();\n while (++index < events.length) {\n const event = events[index];\n const token = event[1];\n if (event[0] === \"enter\") {\n if (token.type === \"tableHead\") {\n afterHeadAwaitingFirstBodyRow = false;\n if (lastTableEnd !== 0) {\n flushTableEnd(map2, context, lastTableEnd, currentTable, currentBody);\n currentBody = void 0;\n lastTableEnd = 0;\n }\n currentTable = {\n type: \"table\",\n start: Object.assign({}, token.start),\n // Note: correct end is set later.\n end: Object.assign({}, token.end)\n };\n map2.add(index, 0, [[\"enter\", currentTable, context]]);\n } else if (token.type === \"tableRow\" || token.type === \"tableDelimiterRow\") {\n inFirstCellAwaitingPipe = true;\n currentCell = void 0;\n lastCell = [0, 0, 0, 0];\n cell = [0, index + 1, 0, 0];\n if (afterHeadAwaitingFirstBodyRow) {\n afterHeadAwaitingFirstBodyRow = false;\n currentBody = {\n type: \"tableBody\",\n start: Object.assign({}, token.start),\n // Note: correct end is set later.\n end: Object.assign({}, token.end)\n };\n map2.add(index, 0, [[\"enter\", currentBody, context]]);\n }\n rowKind = token.type === \"tableDelimiterRow\" ? 2 : currentBody ? 3 : 1;\n } else if (rowKind && (token.type === \"data\" || token.type === \"tableDelimiterMarker\" || token.type === \"tableDelimiterFiller\")) {\n inFirstCellAwaitingPipe = false;\n if (cell[2] === 0) {\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map2, context, lastCell, rowKind, void 0, currentCell);\n lastCell = [0, 0, 0, 0];\n }\n cell[2] = index;\n }\n } else if (token.type === \"tableCellDivider\") {\n if (inFirstCellAwaitingPipe) {\n inFirstCellAwaitingPipe = false;\n } else {\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map2, context, lastCell, rowKind, void 0, currentCell);\n }\n lastCell = cell;\n cell = [lastCell[1], index, 0, 0];\n }\n }\n } else if (token.type === \"tableHead\") {\n afterHeadAwaitingFirstBodyRow = true;\n lastTableEnd = index;\n } else if (token.type === \"tableRow\" || token.type === \"tableDelimiterRow\") {\n lastTableEnd = index;\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map2, context, lastCell, rowKind, index, currentCell);\n } else if (cell[1] !== 0) {\n currentCell = flushCell(map2, context, cell, rowKind, index, currentCell);\n }\n rowKind = 0;\n } else if (rowKind && (token.type === \"data\" || token.type === \"tableDelimiterMarker\" || token.type === \"tableDelimiterFiller\")) {\n cell[3] = index;\n }\n }\n if (lastTableEnd !== 0) {\n flushTableEnd(map2, context, lastTableEnd, currentTable, currentBody);\n }\n map2.consume(context.events);\n index = -1;\n while (++index < context.events.length) {\n const event = context.events[index];\n if (event[0] === \"enter\" && event[1].type === \"table\") {\n event[1]._align = gfmTableAlign(context.events, index);\n }\n }\n return events;\n}\nfunction flushCell(map2, context, range, rowKind, rowEnd, previousCell) {\n const groupName = rowKind === 1 ? \"tableHeader\" : rowKind === 2 ? \"tableDelimiter\" : \"tableData\";\n const valueName = \"tableContent\";\n if (range[0] !== 0) {\n previousCell.end = Object.assign({}, getPoint(context.events, range[0]));\n map2.add(range[0], 0, [[\"exit\", previousCell, context]]);\n }\n const now = getPoint(context.events, range[1]);\n previousCell = {\n type: groupName,\n start: Object.assign({}, now),\n // Note: correct end is set later.\n end: Object.assign({}, now)\n };\n map2.add(range[1], 0, [[\"enter\", previousCell, context]]);\n if (range[2] !== 0) {\n const relatedStart = getPoint(context.events, range[2]);\n const relatedEnd = getPoint(context.events, range[3]);\n const valueToken = {\n type: valueName,\n start: Object.assign({}, relatedStart),\n end: Object.assign({}, relatedEnd)\n };\n map2.add(range[2], 0, [[\"enter\", valueToken, context]]);\n if (rowKind !== 2) {\n const start = context.events[range[2]];\n const end = context.events[range[3]];\n start[1].end = Object.assign({}, end[1].end);\n start[1].type = \"chunkText\";\n start[1].contentType = \"text\";\n if (range[3] > range[2] + 1) {\n const a = range[2] + 1;\n const b = range[3] - range[2] - 1;\n map2.add(a, b, []);\n }\n }\n map2.add(range[3] + 1, 0, [[\"exit\", valueToken, context]]);\n }\n if (rowEnd !== void 0) {\n previousCell.end = Object.assign({}, getPoint(context.events, rowEnd));\n map2.add(rowEnd, 0, [[\"exit\", previousCell, context]]);\n previousCell = void 0;\n }\n return previousCell;\n}\nfunction flushTableEnd(map2, context, index, table, tableBody) {\n const exits = [];\n const related = getPoint(context.events, index);\n if (tableBody) {\n tableBody.end = Object.assign({}, related);\n exits.push([\"exit\", tableBody, context]);\n }\n table.end = Object.assign({}, related);\n exits.push([\"exit\", table, context]);\n map2.add(index + 1, 0, exits);\n}\nfunction getPoint(events, index) {\n const event = events[index];\n const side = event[0] === \"enter\" ? \"start\" : \"end\";\n return event[1][side];\n}\nconst tasklistCheck = {\n name: \"tasklistCheck\",\n tokenize: tokenizeTasklistCheck\n};\nfunction gfmTaskListItem() {\n return {\n text: {\n [91]: tasklistCheck\n }\n };\n}\nfunction tokenizeTasklistCheck(effects, ok2, nok) {\n const self = this;\n return open;\n function open(code2) {\n if (\n // Exit if there’s stuff before.\n self.previous !== null || // Exit if not in the first content that is the first child of a list\n // item.\n !self._gfmTasklistFirstContentOfListItem\n ) {\n return nok(code2);\n }\n effects.enter(\"taskListCheck\");\n effects.enter(\"taskListCheckMarker\");\n effects.consume(code2);\n effects.exit(\"taskListCheckMarker\");\n return inside;\n }\n function inside(code2) {\n if (markdownLineEndingOrSpace(code2)) {\n effects.enter(\"taskListCheckValueUnchecked\");\n effects.consume(code2);\n effects.exit(\"taskListCheckValueUnchecked\");\n return close;\n }\n if (code2 === 88 || code2 === 120) {\n effects.enter(\"taskListCheckValueChecked\");\n effects.consume(code2);\n effects.exit(\"taskListCheckValueChecked\");\n return close;\n }\n return nok(code2);\n }\n function close(code2) {\n if (code2 === 93) {\n effects.enter(\"taskListCheckMarker\");\n effects.consume(code2);\n effects.exit(\"taskListCheckMarker\");\n effects.exit(\"taskListCheck\");\n return after;\n }\n return nok(code2);\n }\n function after(code2) {\n if (markdownLineEnding(code2)) {\n return ok2(code2);\n }\n if (markdownSpace(code2)) {\n return effects.check({\n tokenize: spaceThenNonSpace\n }, ok2, nok)(code2);\n }\n return nok(code2);\n }\n}\nfunction spaceThenNonSpace(effects, ok2, nok) {\n return factorySpace(effects, after, \"whitespace\");\n function after(code2) {\n return code2 === null ? nok(code2) : ok2(code2);\n }\n}\nfunction gfm(options) {\n return combineExtensions([\n gfmAutolinkLiteral(),\n gfmFootnote(),\n gfmStrikethrough(options),\n gfmTable(),\n gfmTaskListItem()\n ]);\n}\nconst emptyOptions = {};\nfunction remarkGfm(options) {\n const self = (\n /** @type {Processor} */\n this\n );\n const settings = options || emptyOptions;\n const data = self.data();\n const micromarkExtensions = data.micromarkExtensions || (data.micromarkExtensions = []);\n const fromMarkdownExtensions = data.fromMarkdownExtensions || (data.fromMarkdownExtensions = []);\n const toMarkdownExtensions = data.toMarkdownExtensions || (data.toMarkdownExtensions = []);\n micromarkExtensions.push(gfm(settings));\n fromMarkdownExtensions.push(gfmFromMarkdown());\n toMarkdownExtensions.push(gfmToMarkdown(settings));\n}\n/*!\n * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction isTextNode$1(node2) {\n return node2.type === \"text\";\n}\nconst transformPlaceholders = function(ast) {\n visit(ast, isTextNode$1, visitor);\n function visitor(node2, index, parent) {\n const placeholders = node2.value.split(/(\\{[a-z\\-_.0-9]+\\})/ig).map((entry) => {\n const matches = entry.match(/^\\{([a-z\\-_.0-9]+)\\}$/i);\n if (!matches) {\n return u(\"text\", entry);\n }\n const [, component] = matches;\n return u(\"element\", {\n tagName: `#${component}`,\n children: []\n });\n });\n parent.children.splice(index, 1, ...placeholders);\n }\n};\nconst remarkPlaceholder = () => transformPlaceholders;\n/*!\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction isTextNode(node2) {\n return [\"text\", \"code\", \"inlineCode\"].includes(node2.type);\n}\nconst remarkUnescape = function() {\n return function(tree) {\n visit(tree, isTextNode, (node2, index, parent) => {\n parent.children.splice(index, 1, {\n ...node2,\n value: node2.value.replace(/</gmi, \"<\").replace(/>/gmi, \">\")\n });\n return [SKIP$1, index + 1];\n });\n };\n};\nconst LINK_PROTOCOLS = [\"http\", \"https\", \"mailto\", \"tel\"];\nconst rehypeHighlight = ref(null);\nasync function importRehypeHighlightLibrary() {\n const module = await import(\"rehype-highlight\");\n rehypeHighlight.value = module.default;\n}\nconst _sfc_main = {\n name: \"NcRichText\",\n components: {\n NcReferenceList\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n /**\n * The main text\n */\n text: {\n type: String,\n default: \"\"\n },\n arguments: {\n type: Object,\n default: () => {\n return {};\n }\n },\n referenceLimit: {\n type: Number,\n default: 0\n },\n referenceInteractive: {\n type: Boolean,\n default: true\n },\n referenceInteractiveOptIn: {\n type: Boolean,\n default: false\n },\n /** Provide data upfront to avoid extra http request */\n references: {\n type: Array,\n default: null\n },\n /** Provide basic Markdown syntax */\n useMarkdown: {\n type: Boolean,\n default: false\n },\n /** Provide GitHub Flavored Markdown syntax */\n useExtendedMarkdown: {\n type: Boolean,\n default: false\n },\n /** Provide event from rendered markdown inputs */\n interactive: {\n type: Boolean,\n default: false\n },\n /**\n * Automatically convert link-like text to markdown links\n */\n autolink: {\n type: Boolean,\n default: true\n }\n },\n emits: [\n \"interactTodo\"\n ],\n data() {\n return {\n parentId: createElementId()\n };\n },\n methods: {\n renderPlaintext() {\n const placeholders = this.text.split(/(\\{[a-z\\-_.0-9]+\\})/ig).map((entry) => {\n const matches = entry.match(/^\\{([a-z\\-_.0-9]+)\\}$/i);\n if (!matches) {\n return this.prepareTextNode(entry);\n }\n const argumentId = matches[1];\n const argument = this.arguments[argumentId];\n if (typeof argument === \"object\") {\n const { component, props } = argument;\n return h(typeof component === \"string\" ? resolveComponent(component) : component, {\n ...props,\n class: \"rich-text--component\"\n });\n }\n if (argument) {\n return h(\"span\", { class: \"rich-text--fallback\" }, argument);\n }\n return entry;\n });\n return h(\"div\", { class: \"rich-text--wrapper\" }, [\n h(\"div\", {}, placeholders.flat()),\n this.referenceLimit > 0 ? h(\"div\", { class: \"rich-text--reference-widget\" }, [\n h(NcReferenceList, {\n text: this.text,\n referenceData: this.references,\n interactive: this.referenceInteractive,\n interactiveOptIn: this.referenceInteractiveOptIn\n })\n ]) : null\n ]);\n },\n renderMarkdown() {\n const renderedMarkdown = unified().use(remarkParse).use(remarkAutolink, {\n autolink: this.autolink,\n useMarkdown: this.useMarkdown,\n useExtendedMarkdown: this.useExtendedMarkdown\n }).use(remarkUnescape).use(this.useExtendedMarkdown ? remarkGfm : void 0).use(breaks).use(remarkUnlinkProtocols, { except: LINK_PROTOCOLS }).use(remark2rehype, {\n handlers: {\n component(toHast, node2) {\n return toHast(node2, node2.component, { value: node2.value });\n }\n }\n }).use(this.useExtendedMarkdown ? rehypeHighlight.value : void 0).use(remarkPlaceholder).use(rehypeExternalLinks, {\n target: \"_blank\",\n rel: [\"noopener noreferrer\"]\n }).use(rehype2react, {\n Fragment,\n jsx: this.createElement,\n jsxs: this.createElement,\n elementAttributeNameCase: \"html\",\n prefix: false\n }).processSync(this.text.replace(/<[^>]+>/g, (match) => match.replace(/\")).result;\n return h(\"div\", { class: \"rich-text--wrapper rich-text--wrapper-markdown\" }, [\n renderedMarkdown,\n this.referenceLimit > 0 ? h(\"div\", { class: \"rich-text--reference-widget\" }, [\n h(NcReferenceList, {\n text: this.text,\n referenceData: this.references,\n interactive: this.referenceInteractive,\n interactiveOptIn: this.referenceInteractiveOptIn\n })\n ]) : null\n ]);\n },\n /**\n * Render plain text nodes\n *\n * @param {string} text - Content of the node\n */\n prepareTextNode(text2) {\n if (this.autolink) {\n text2 = parseUrl(text2);\n }\n if (Array.isArray(text2)) {\n return text2.map((entry) => {\n if (typeof entry === \"string\") {\n return entry;\n }\n const { component, props } = entry;\n const componentClass = component.name === \"NcLink\" ? void 0 : \"rich-text--component\";\n return h(component, {\n ...props,\n class: componentClass\n });\n });\n }\n return text2;\n },\n createElement(type, props, key) {\n if (key) {\n props.key = key;\n }\n const children = props.children ?? [];\n delete props.children;\n if (!String(type).startsWith(\"#\")) {\n let nestedNode = null;\n if (this.useExtendedMarkdown) {\n if (String(type) === \"code\" && !rehypeHighlight.value && props?.class?.includes(\"language\")) {\n importRehypeHighlightLibrary();\n }\n if (String(type) === \"li\" && Array.isArray(children) && children.length !== 0 && children[0].type === \"input\" && children[0].props.type === \"checkbox\") {\n const [inputNode, , ...labelParts] = children;\n const nestedNodeIndex = labelParts.findIndex((child) => [\"ul\", \"ol\", \"li\", \"blockquote\", \"pre\"].includes(child.type));\n if (nestedNodeIndex !== -1) {\n nestedNode = labelParts[nestedNodeIndex];\n labelParts.splice(nestedNodeIndex);\n }\n const id = this.parentId + \"-markdown-input-\" + createElementId();\n const propsToForward = { ...inputNode.props };\n delete propsToForward.checked;\n const inputComponent = h(NcCheckboxRadioSwitch, {\n ...propsToForward,\n modelValue: inputNode.props.checked,\n id,\n disabled: !this.interactive,\n \"onUpdate:modelValue\": () => {\n this.$emit(\"interactTodo\", id);\n }\n }, { default: () => labelParts });\n return h(type, props, [inputComponent, nestedNode]);\n }\n }\n if (String(type) === \"a\") {\n const route = getRoute(this.$router, props.href);\n if (route) {\n delete props.href;\n delete props.target;\n return h(RouterLink, {\n ...props,\n to: route\n }, { default: () => children });\n }\n }\n return h(type, props, children);\n }\n const placeholder = this.arguments[type.slice(1)];\n if (!placeholder) {\n return h(\"span\", { ...props, class: \"rich-text--fallback\" }, [`{${type.slice(1)}}`]);\n }\n if (!placeholder.component) {\n return h(\"span\", { ...props }, [placeholder]);\n }\n return h(\n typeof placeholder.component === \"string\" ? resolveComponent(placeholder.component) : placeholder.component,\n {\n ...props,\n ...placeholder.props,\n class: \"rich-text--component\"\n },\n { default: () => children }\n );\n }\n },\n render() {\n return this.useMarkdown || this.useExtendedMarkdown ? this.renderMarkdown() : this.renderPlaintext();\n }\n};\nconst NcRichText = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-bfd4d4b7\"]]);\nexport {\n NcRichText as N,\n NcReferenceList as a\n};\n//# sourceMappingURL=NcRichText-jQc4sfgS.mjs.map\n","\n\n\n\n\n","\n\n\n\n\n\n\n","\n\n\n\n\n","import { onClickOutside as onClickOutside$1, useActiveElement, useBattery, useBrowserLocation, useClipboard, useDark, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDocumentVisibility, useStorage as useStorage$1, isClient as isClient$1, useDraggable, useElementBounding as useElementBounding$1, useElementSize as useElementSize$1, useElementVisibility as useElementVisibility$1, useEyeDropper, useFullscreen, useGeolocation, useIdle, useMouse as useMouse$1, useMouseInElement as useMouseInElement$1, useMousePressed, useNetwork, useNow, useObjectUrl, useOffsetPagination, useOnline, usePageLeave, usePointer, usePointerLock, usePreferredColorScheme, usePreferredContrast, usePreferredDark as usePreferredDark$1, usePreferredLanguages, usePreferredReducedMotion, usePreferredReducedTransparency, useTimeAgo, useTimestamp, useVirtualList, useWindowFocus, useWindowSize } from '@vueuse/core';\nimport { defineComponent, shallowRef, h, toValue, computed, unref, reactive, hasInjectionContext, getCurrentInstance, onMounted, watchEffect, ref, watch, nextTick, toRefs } from 'vue';\nimport { isClient, toArray, watchImmediate, isObject, tryOnScopeDispose, noop, isIOS, injectLocal, pxValue, pausableWatch, tryOnMounted, toRef, useToggle, notNullish, watchOnce, promiseTimeout, until, useDebounceFn, useThrottleFn, tryOnUnmounted, reactiveOmit } from '@vueuse/shared';\n\nconst OnClickOutside = /* @__PURE__ */ defineComponent({\n name: \"OnClickOutside\",\n props: [\"as\", \"options\"],\n emits: [\"trigger\"],\n setup(props, { slots, emit }) {\n const target = shallowRef();\n onClickOutside$1(target, (e) => {\n emit(\"trigger\", e);\n }, props.options);\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default());\n };\n }\n});\n\nconst defaultWindow = isClient ? window : void 0;\n\nfunction unrefElement(elRef) {\n var _a;\n const plain = toValue(elRef);\n return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\n}\n\nfunction useEventListener(...args) {\n const cleanups = [];\n const cleanup = () => {\n cleanups.forEach((fn) => fn());\n cleanups.length = 0;\n };\n const register = (el, event, listener, options) => {\n el.addEventListener(event, listener, options);\n return () => el.removeEventListener(event, listener, options);\n };\n const firstParamTargets = computed(() => {\n const test = toArray(toValue(args[0])).filter((e) => e != null);\n return test.every((e) => typeof e !== \"string\") ? test : void 0;\n });\n const stopWatch = watchImmediate(\n () => {\n var _a, _b;\n return [\n (_b = (_a = firstParamTargets.value) == null ? void 0 : _a.map((e) => unrefElement(e))) != null ? _b : [defaultWindow].filter((e) => e != null),\n toArray(toValue(firstParamTargets.value ? args[1] : args[0])),\n toArray(unref(firstParamTargets.value ? args[2] : args[1])),\n // @ts-expect-error - TypeScript gets the correct types, but somehow still complains\n toValue(firstParamTargets.value ? args[3] : args[2])\n ];\n },\n ([raw_targets, raw_events, raw_listeners, raw_options]) => {\n cleanup();\n if (!(raw_targets == null ? void 0 : raw_targets.length) || !(raw_events == null ? void 0 : raw_events.length) || !(raw_listeners == null ? void 0 : raw_listeners.length))\n return;\n const optionsClone = isObject(raw_options) ? { ...raw_options } : raw_options;\n cleanups.push(\n ...raw_targets.flatMap(\n (el) => raw_events.flatMap(\n (event) => raw_listeners.map((listener) => register(el, event, listener, optionsClone))\n )\n )\n );\n },\n { flush: \"post\" }\n );\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(cleanup);\n return stop;\n}\n\nlet _iOSWorkaround = false;\nfunction onClickOutside(target, handler, options = {}) {\n const { window = defaultWindow, ignore = [], capture = true, detectIframe = false, controls = false } = options;\n if (!window) {\n return controls ? { stop: noop, cancel: noop, trigger: noop } : noop;\n }\n if (isIOS && !_iOSWorkaround) {\n _iOSWorkaround = true;\n const listenerOptions = { passive: true };\n Array.from(window.document.body.children).forEach((el) => el.addEventListener(\"click\", noop, listenerOptions));\n window.document.documentElement.addEventListener(\"click\", noop, listenerOptions);\n }\n let shouldListen = true;\n const shouldIgnore = (event) => {\n return toValue(ignore).some((target2) => {\n if (typeof target2 === \"string\") {\n return Array.from(window.document.querySelectorAll(target2)).some((el) => el === event.target || event.composedPath().includes(el));\n } else {\n const el = unrefElement(target2);\n return el && (event.target === el || event.composedPath().includes(el));\n }\n });\n };\n function hasMultipleRoots(target2) {\n const vm = toValue(target2);\n return vm && vm.$.subTree.shapeFlag === 16;\n }\n function checkMultipleRoots(target2, event) {\n const vm = toValue(target2);\n const children = vm.$.subTree && vm.$.subTree.children;\n if (children == null || !Array.isArray(children))\n return false;\n return children.some((child) => child.el === event.target || event.composedPath().includes(child.el));\n }\n const listener = (event) => {\n const el = unrefElement(target);\n if (event.target == null)\n return;\n if (!(el instanceof Element) && hasMultipleRoots(target) && checkMultipleRoots(target, event))\n return;\n if (!el || el === event.target || event.composedPath().includes(el))\n return;\n if (\"detail\" in event && event.detail === 0)\n shouldListen = !shouldIgnore(event);\n if (!shouldListen) {\n shouldListen = true;\n return;\n }\n handler(event);\n };\n let isProcessingClick = false;\n const cleanup = [\n useEventListener(window, \"click\", (event) => {\n if (!isProcessingClick) {\n isProcessingClick = true;\n setTimeout(() => {\n isProcessingClick = false;\n }, 0);\n listener(event);\n }\n }, { passive: true, capture }),\n useEventListener(window, \"pointerdown\", (e) => {\n const el = unrefElement(target);\n shouldListen = !shouldIgnore(e) && !!(el && !e.composedPath().includes(el));\n }, { passive: true }),\n detectIframe && useEventListener(window, \"blur\", (event) => {\n setTimeout(() => {\n var _a;\n const el = unrefElement(target);\n if (((_a = window.document.activeElement) == null ? void 0 : _a.tagName) === \"IFRAME\" && !(el == null ? void 0 : el.contains(window.document.activeElement))) {\n handler(event);\n }\n }, 0);\n }, { passive: true })\n ].filter(Boolean);\n const stop = () => cleanup.forEach((fn) => fn());\n if (controls) {\n return {\n stop,\n cancel: () => {\n shouldListen = false;\n },\n trigger: (event) => {\n shouldListen = true;\n listener(event);\n shouldListen = false;\n }\n };\n }\n return stop;\n}\n\nconst stopClickOutsideMap = /* @__PURE__ */ new WeakMap();\nconst vOnClickOutside = {\n mounted(el, binding) {\n const capture = !binding.modifiers.bubble;\n let stop;\n if (typeof binding.value === \"function\") {\n stop = onClickOutside(el, binding.value, { capture });\n } else {\n const [handler, options] = binding.value;\n stop = onClickOutside(el, handler, Object.assign({ capture }, options));\n }\n stopClickOutsideMap.set(el, stop);\n },\n unmounted(el) {\n const stop = stopClickOutsideMap.get(el);\n if (stop && typeof stop === \"function\") {\n stop();\n } else {\n stop == null ? void 0 : stop.stop();\n }\n stopClickOutsideMap.delete(el);\n }\n};\n\nfunction createKeyPredicate(keyFilter) {\n if (typeof keyFilter === \"function\")\n return keyFilter;\n else if (typeof keyFilter === \"string\")\n return (event) => event.key === keyFilter;\n else if (Array.isArray(keyFilter))\n return (event) => keyFilter.includes(event.key);\n return () => true;\n}\nfunction onKeyStroke(...args) {\n let key;\n let handler;\n let options = {};\n if (args.length === 3) {\n key = args[0];\n handler = args[1];\n options = args[2];\n } else if (args.length === 2) {\n if (typeof args[1] === \"object\") {\n key = true;\n handler = args[0];\n options = args[1];\n } else {\n key = args[0];\n handler = args[1];\n }\n } else {\n key = true;\n handler = args[0];\n }\n const {\n target = defaultWindow,\n eventName = \"keydown\",\n passive = false,\n dedupe = false\n } = options;\n const predicate = createKeyPredicate(key);\n const listener = (e) => {\n if (e.repeat && toValue(dedupe))\n return;\n if (predicate(e))\n handler(e);\n };\n return useEventListener(target, eventName, listener, passive);\n}\n\nconst vOnKeyStroke = {\n mounted(el, binding) {\n var _a, _b;\n const keys = (_b = (_a = binding.arg) == null ? void 0 : _a.split(\",\")) != null ? _b : true;\n if (typeof binding.value === \"function\") {\n onKeyStroke(keys, binding.value, {\n target: el\n });\n } else {\n const [handler, options] = binding.value;\n onKeyStroke(keys, handler, {\n target: el,\n ...options\n });\n }\n }\n};\n\nconst DEFAULT_DELAY = 500;\nconst DEFAULT_THRESHOLD = 10;\nfunction onLongPress(target, handler, options) {\n var _a, _b;\n const elementRef = computed(() => unrefElement(target));\n let timeout;\n let posStart;\n let startTimestamp;\n let hasLongPressed = false;\n function clear() {\n if (timeout) {\n clearTimeout(timeout);\n timeout = void 0;\n }\n posStart = void 0;\n startTimestamp = void 0;\n hasLongPressed = false;\n }\n function getDelay(ev) {\n const delay = options == null ? void 0 : options.delay;\n if (typeof delay === \"function\") {\n return delay(ev);\n }\n return delay != null ? delay : DEFAULT_DELAY;\n }\n function onRelease(ev) {\n var _a2, _b2, _c;\n const [_startTimestamp, _posStart, _hasLongPressed] = [startTimestamp, posStart, hasLongPressed];\n clear();\n if (!(options == null ? void 0 : options.onMouseUp) || !_posStart || !_startTimestamp)\n return;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - _posStart.x;\n const dy = ev.y - _posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n options.onMouseUp(ev.timeStamp - _startTimestamp, distance, _hasLongPressed);\n }\n function onDown(ev) {\n var _a2, _b2, _c;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n clear();\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n posStart = {\n x: ev.x,\n y: ev.y\n };\n startTimestamp = ev.timeStamp;\n timeout = setTimeout(\n () => {\n hasLongPressed = true;\n handler(ev);\n },\n getDelay(ev)\n );\n }\n function onMove(ev) {\n var _a2, _b2, _c, _d;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if (!posStart || (options == null ? void 0 : options.distanceThreshold) === false)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - posStart.x;\n const dy = ev.y - posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n if (distance >= ((_d = options == null ? void 0 : options.distanceThreshold) != null ? _d : DEFAULT_THRESHOLD))\n clear();\n }\n const listenerOptions = {\n capture: (_a = options == null ? void 0 : options.modifiers) == null ? void 0 : _a.capture,\n once: (_b = options == null ? void 0 : options.modifiers) == null ? void 0 : _b.once\n };\n const cleanup = [\n useEventListener(elementRef, \"pointerdown\", onDown, listenerOptions),\n useEventListener(elementRef, \"pointermove\", onMove, listenerOptions),\n useEventListener(elementRef, [\"pointerup\", \"pointerleave\"], onRelease, listenerOptions)\n ];\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nconst OnLongPress = /* @__PURE__ */ defineComponent({\n name: \"OnLongPress\",\n props: [\"as\", \"options\"],\n emits: [\"trigger\"],\n setup(props, { slots, emit }) {\n const target = shallowRef();\n onLongPress(\n target,\n (e) => {\n emit(\"trigger\", e);\n },\n props.options\n );\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default());\n };\n }\n});\n\nconst vOnLongPress = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n onLongPress(el, binding.value, { modifiers: binding.modifiers });\n else\n onLongPress(el, ...binding.value);\n }\n};\n\nconst UseActiveElement = /* @__PURE__ */ defineComponent({\n name: \"UseActiveElement\",\n setup(props, { slots }) {\n const data = reactive({\n element: useActiveElement()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseBattery = /* @__PURE__ */ defineComponent({\n name: \"UseBattery\",\n setup(props, { slots }) {\n const data = reactive(useBattery(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseBrowserLocation = /* @__PURE__ */ defineComponent({\n name: \"UseBrowserLocation\",\n setup(props, { slots }) {\n const data = reactive(useBrowserLocation());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseClipboard = /* @__PURE__ */ defineComponent({\n name: \"UseClipboard\",\n props: [\n \"source\",\n \"read\",\n \"navigator\",\n \"copiedDuring\",\n \"legacy\"\n ],\n setup(props, { slots }) {\n const data = reactive(useClipboard(props));\n return () => {\n var _a;\n return (_a = slots.default) == null ? void 0 : _a.call(slots, data);\n };\n }\n});\n\nconst _global = typeof globalThis !== \"undefined\" ? globalThis : typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : {};\nconst globalKey = \"__vueuse_ssr_handlers__\";\nconst handlers = /* @__PURE__ */ getHandlers();\nfunction getHandlers() {\n if (!(globalKey in _global))\n _global[globalKey] = _global[globalKey] || {};\n return _global[globalKey];\n}\nfunction getSSRHandler(key, fallback) {\n return handlers[key] || fallback;\n}\n\nconst ssrWidthSymbol = Symbol(\"vueuse-ssr-width\");\n// @__NO_SIDE_EFFECTS__\nfunction useSSRWidth() {\n const ssrWidth = hasInjectionContext() ? injectLocal(ssrWidthSymbol, null) : null;\n return typeof ssrWidth === \"number\" ? ssrWidth : void 0;\n}\n\n// @__NO_SIDE_EFFECTS__\nfunction useMounted() {\n const isMounted = shallowRef(false);\n const instance = getCurrentInstance();\n if (instance) {\n onMounted(() => {\n isMounted.value = true;\n }, instance);\n }\n return isMounted;\n}\n\n// @__NO_SIDE_EFFECTS__\nfunction useSupported(callback) {\n const isMounted = useMounted();\n return computed(() => {\n isMounted.value;\n return Boolean(callback());\n });\n}\n\nfunction useMediaQuery(query, options = {}) {\n const { window = defaultWindow, ssrWidth = useSSRWidth() } = options;\n const isSupported = useSupported(() => window && \"matchMedia\" in window && typeof window.matchMedia === \"function\");\n const ssrSupport = shallowRef(typeof ssrWidth === \"number\");\n const mediaQuery = shallowRef();\n const matches = shallowRef(false);\n const handler = (event) => {\n matches.value = event.matches;\n };\n watchEffect(() => {\n if (ssrSupport.value) {\n ssrSupport.value = !isSupported.value;\n const queryStrings = toValue(query).split(\",\");\n matches.value = queryStrings.some((queryString) => {\n const not = queryString.includes(\"not all\");\n const minWidth = queryString.match(/\\(\\s*min-width:\\s*(-?\\d+(?:\\.\\d*)?[a-z]+\\s*)\\)/);\n const maxWidth = queryString.match(/\\(\\s*max-width:\\s*(-?\\d+(?:\\.\\d*)?[a-z]+\\s*)\\)/);\n let res = Boolean(minWidth || maxWidth);\n if (minWidth && res) {\n res = ssrWidth >= pxValue(minWidth[1]);\n }\n if (maxWidth && res) {\n res = ssrWidth <= pxValue(maxWidth[1]);\n }\n return not ? !res : res;\n });\n return;\n }\n if (!isSupported.value)\n return;\n mediaQuery.value = window.matchMedia(toValue(query));\n matches.value = mediaQuery.value.matches;\n });\n useEventListener(mediaQuery, \"change\", handler, { passive: true });\n return computed(() => matches.value);\n}\n\n// @__NO_SIDE_EFFECTS__\nfunction usePreferredDark(options) {\n return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nfunction guessSerializerType(rawInit) {\n return rawInit == null ? \"any\" : rawInit instanceof Set ? \"set\" : rawInit instanceof Map ? \"map\" : rawInit instanceof Date ? \"date\" : typeof rawInit === \"boolean\" ? \"boolean\" : typeof rawInit === \"string\" ? \"string\" : typeof rawInit === \"object\" ? \"object\" : !Number.isNaN(rawInit) ? \"number\" : \"any\";\n}\n\nconst StorageSerializers = {\n boolean: {\n read: (v) => v === \"true\",\n write: (v) => String(v)\n },\n object: {\n read: (v) => JSON.parse(v),\n write: (v) => JSON.stringify(v)\n },\n number: {\n read: (v) => Number.parseFloat(v),\n write: (v) => String(v)\n },\n any: {\n read: (v) => v,\n write: (v) => String(v)\n },\n string: {\n read: (v) => v,\n write: (v) => String(v)\n },\n map: {\n read: (v) => new Map(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v.entries()))\n },\n set: {\n read: (v) => new Set(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v))\n },\n date: {\n read: (v) => new Date(v),\n write: (v) => v.toISOString()\n }\n};\nconst customStorageEventName = \"vueuse-storage\";\nfunction useStorage(key, defaults, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n mergeDefaults = false,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n },\n initOnMounted\n } = options;\n const data = (shallow ? shallowRef : ref)(typeof defaults === \"function\" ? defaults() : defaults);\n const keyComputed = computed(() => toValue(key));\n if (!storage) {\n try {\n storage = getSSRHandler(\"getDefaultStorage\", () => {\n var _a2;\n return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n })();\n } catch (e) {\n onError(e);\n }\n }\n if (!storage)\n return data;\n const rawInit = toValue(defaults);\n const type = guessSerializerType(rawInit);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(\n data,\n (newValue) => write(newValue),\n { flush, deep, eventFilter }\n );\n watch(keyComputed, () => update(), { flush });\n let firstMounted = false;\n const onStorageEvent = (ev) => {\n if (initOnMounted && !firstMounted) {\n return;\n }\n update(ev);\n };\n const onStorageCustomEvent = (ev) => {\n if (initOnMounted && !firstMounted) {\n return;\n }\n updateFromCustomEvent(ev);\n };\n if (window && listenToStorageChanges) {\n if (storage instanceof Storage)\n useEventListener(window, \"storage\", onStorageEvent, { passive: true });\n else\n useEventListener(window, customStorageEventName, onStorageCustomEvent);\n }\n if (initOnMounted) {\n tryOnMounted(() => {\n firstMounted = true;\n update();\n });\n } else {\n update();\n }\n function dispatchWriteEvent(oldValue, newValue) {\n if (window) {\n const payload = {\n key: keyComputed.value,\n oldValue,\n newValue,\n storageArea: storage\n };\n window.dispatchEvent(storage instanceof Storage ? new StorageEvent(\"storage\", payload) : new CustomEvent(customStorageEventName, {\n detail: payload\n }));\n }\n }\n function write(v) {\n try {\n const oldValue = storage.getItem(keyComputed.value);\n if (v == null) {\n dispatchWriteEvent(oldValue, null);\n storage.removeItem(keyComputed.value);\n } else {\n const serialized = serializer.write(v);\n if (oldValue !== serialized) {\n storage.setItem(keyComputed.value, serialized);\n dispatchWriteEvent(oldValue, serialized);\n }\n }\n } catch (e) {\n onError(e);\n }\n }\n function read(event) {\n const rawValue = event ? event.newValue : storage.getItem(keyComputed.value);\n if (rawValue == null) {\n if (writeDefaults && rawInit != null)\n storage.setItem(keyComputed.value, serializer.write(rawInit));\n return rawInit;\n } else if (!event && mergeDefaults) {\n const value = serializer.read(rawValue);\n if (typeof mergeDefaults === \"function\")\n return mergeDefaults(value, rawInit);\n else if (type === \"object\" && !Array.isArray(value))\n return { ...rawInit, ...value };\n return value;\n } else if (typeof rawValue !== \"string\") {\n return rawValue;\n } else {\n return serializer.read(rawValue);\n }\n }\n function update(event) {\n if (event && event.storageArea !== storage)\n return;\n if (event && event.key == null) {\n data.value = rawInit;\n return;\n }\n if (event && event.key !== keyComputed.value) {\n return;\n }\n pauseWatch();\n try {\n const serializedData = serializer.write(data.value);\n if (event === void 0 || (event == null ? void 0 : event.newValue) !== serializedData) {\n data.value = read(event);\n }\n } catch (e) {\n onError(e);\n } finally {\n if (event)\n nextTick(resumeWatch);\n else\n resumeWatch();\n }\n }\n function updateFromCustomEvent(event) {\n update(event.detail);\n }\n return data;\n}\n\nconst CSS_DISABLE_TRANS = \"*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}\";\nfunction useColorMode(options = {}) {\n const {\n selector = \"html\",\n attribute = \"class\",\n initialValue = \"auto\",\n window = defaultWindow,\n storage,\n storageKey = \"vueuse-color-scheme\",\n listenToStorageChanges = true,\n storageRef,\n emitAuto,\n disableTransition = true\n } = options;\n const modes = {\n auto: \"\",\n light: \"light\",\n dark: \"dark\",\n ...options.modes || {}\n };\n const preferredDark = usePreferredDark({ window });\n const system = computed(() => preferredDark.value ? \"dark\" : \"light\");\n const store = storageRef || (storageKey == null ? toRef(initialValue) : useStorage(storageKey, initialValue, storage, { window, listenToStorageChanges }));\n const state = computed(() => store.value === \"auto\" ? system.value : store.value);\n const updateHTMLAttrs = getSSRHandler(\n \"updateHTMLAttrs\",\n (selector2, attribute2, value) => {\n const el = typeof selector2 === \"string\" ? window == null ? void 0 : window.document.querySelector(selector2) : unrefElement(selector2);\n if (!el)\n return;\n const classesToAdd = /* @__PURE__ */ new Set();\n const classesToRemove = /* @__PURE__ */ new Set();\n let attributeToChange = null;\n if (attribute2 === \"class\") {\n const current = value.split(/\\s/g);\n Object.values(modes).flatMap((i) => (i || \"\").split(/\\s/g)).filter(Boolean).forEach((v) => {\n if (current.includes(v))\n classesToAdd.add(v);\n else\n classesToRemove.add(v);\n });\n } else {\n attributeToChange = { key: attribute2, value };\n }\n if (classesToAdd.size === 0 && classesToRemove.size === 0 && attributeToChange === null)\n return;\n let style;\n if (disableTransition) {\n style = window.document.createElement(\"style\");\n style.appendChild(document.createTextNode(CSS_DISABLE_TRANS));\n window.document.head.appendChild(style);\n }\n for (const c of classesToAdd) {\n el.classList.add(c);\n }\n for (const c of classesToRemove) {\n el.classList.remove(c);\n }\n if (attributeToChange) {\n el.setAttribute(attributeToChange.key, attributeToChange.value);\n }\n if (disableTransition) {\n window.getComputedStyle(style).opacity;\n document.head.removeChild(style);\n }\n }\n );\n function defaultOnChanged(mode) {\n var _a;\n updateHTMLAttrs(selector, attribute, (_a = modes[mode]) != null ? _a : mode);\n }\n function onChanged(mode) {\n if (options.onChanged)\n options.onChanged(mode, defaultOnChanged);\n else\n defaultOnChanged(mode);\n }\n watch(state, onChanged, { flush: \"post\", immediate: true });\n tryOnMounted(() => onChanged(state.value));\n const auto = computed({\n get() {\n return emitAuto ? store.value : state.value;\n },\n set(v) {\n store.value = v;\n }\n });\n return Object.assign(auto, { store, system, state });\n}\n\nconst UseColorMode = /* @__PURE__ */ defineComponent({\n name: \"UseColorMode\",\n props: [\"selector\", \"attribute\", \"modes\", \"onChanged\", \"storageKey\", \"storage\", \"emitAuto\"],\n setup(props, { slots }) {\n const mode = useColorMode(props);\n const data = reactive({\n mode,\n system: mode.system,\n store: mode.store\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDark = /* @__PURE__ */ defineComponent({\n name: \"UseDark\",\n props: [\"selector\", \"attribute\", \"valueDark\", \"valueLight\", \"onChanged\", \"storageKey\", \"storage\"],\n setup(props, { slots }) {\n const isDark = useDark(props);\n const data = reactive({\n isDark,\n toggleDark: useToggle(isDark)\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDeviceMotion = /* @__PURE__ */ defineComponent({\n name: \"UseDeviceMotion\",\n setup(props, { slots }) {\n const data = useDeviceMotion();\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDeviceOrientation = /* @__PURE__ */ defineComponent({\n name: \"UseDeviceOrientation\",\n setup(props, { slots }) {\n const data = reactive(useDeviceOrientation());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDevicePixelRatio = /* @__PURE__ */ defineComponent({\n name: \"UseDevicePixelRatio\",\n setup(props, { slots }) {\n const data = reactive({\n pixelRatio: useDevicePixelRatio()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDevicesList = /* @__PURE__ */ defineComponent({\n name: \"UseDevicesList\",\n props: [\"onUpdated\", \"requestPermissions\", \"constraints\"],\n setup(props, { slots }) {\n const data = reactive(useDevicesList(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDocumentVisibility = /* @__PURE__ */ defineComponent({\n name: \"UseDocumentVisibility\",\n setup(props, { slots }) {\n const data = reactive({\n visibility: useDocumentVisibility()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDraggable = /* @__PURE__ */ defineComponent({\n name: \"UseDraggable\",\n props: [\n \"storageKey\",\n \"storageType\",\n \"initialValue\",\n \"exact\",\n \"preventDefault\",\n \"stopPropagation\",\n \"pointerTypes\",\n \"as\",\n \"handle\",\n \"axis\",\n \"onStart\",\n \"onMove\",\n \"onEnd\",\n \"disabled\",\n \"buttons\",\n \"containerElement\",\n \"capture\"\n ],\n setup(props, { slots }) {\n const target = shallowRef();\n const handle = computed(() => {\n var _a;\n return (_a = toValue(props.handle)) != null ? _a : target.value;\n });\n const containerElement = computed(() => {\n var _a;\n return (_a = props.containerElement) != null ? _a : void 0;\n });\n const disabled = computed(() => !!props.disabled);\n const storageValue = props.storageKey && useStorage$1(\n props.storageKey,\n toValue(props.initialValue) || { x: 0, y: 0 },\n isClient$1 ? props.storageType === \"session\" ? sessionStorage : localStorage : void 0\n );\n const initialValue = storageValue || props.initialValue || { x: 0, y: 0 };\n const onEnd = (position, event) => {\n var _a;\n (_a = props.onEnd) == null ? void 0 : _a.call(props, position, event);\n if (!storageValue)\n return;\n storageValue.value.x = position.x;\n storageValue.value.y = position.y;\n };\n const data = reactive(useDraggable(target, {\n ...props,\n handle,\n initialValue,\n onEnd,\n disabled,\n containerElement\n }));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target, style: `touch-action:none;${data.style}` }, slots.default(data));\n };\n }\n});\n\nconst UseElementBounding = /* @__PURE__ */ defineComponent({\n name: \"UseElementBounding\",\n props: [\"box\", \"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useElementBounding$1(target));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nfunction useMutationObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...mutationOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"MutationObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const value = toValue(target);\n const items = toArray(value).map(unrefElement).filter(notNullish);\n return new Set(items);\n });\n const stopWatch = watch(\n targets,\n (newTargets) => {\n cleanup();\n if (isSupported.value && newTargets.size) {\n observer = new MutationObserver(callback);\n newTargets.forEach((el) => observer.observe(el, mutationOptions));\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const takeRecords = () => {\n return observer == null ? void 0 : observer.takeRecords();\n };\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop,\n takeRecords\n };\n}\n\nfunction useResizeObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...observerOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"ResizeObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const _targets = toValue(target);\n return Array.isArray(_targets) ? _targets.map((el) => unrefElement(el)) : [unrefElement(_targets)];\n });\n const stopWatch = watch(\n targets,\n (els) => {\n cleanup();\n if (isSupported.value && window) {\n observer = new ResizeObserver(callback);\n for (const _el of els) {\n if (_el)\n observer.observe(_el, observerOptions);\n }\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\n };\n}\n\nfunction useElementBounding(target, options = {}) {\n const {\n reset = true,\n windowResize = true,\n windowScroll = true,\n immediate = true,\n updateTiming = \"sync\"\n } = options;\n const height = shallowRef(0);\n const bottom = shallowRef(0);\n const left = shallowRef(0);\n const right = shallowRef(0);\n const top = shallowRef(0);\n const width = shallowRef(0);\n const x = shallowRef(0);\n const y = shallowRef(0);\n function recalculate() {\n const el = unrefElement(target);\n if (!el) {\n if (reset) {\n height.value = 0;\n bottom.value = 0;\n left.value = 0;\n right.value = 0;\n top.value = 0;\n width.value = 0;\n x.value = 0;\n y.value = 0;\n }\n return;\n }\n const rect = el.getBoundingClientRect();\n height.value = rect.height;\n bottom.value = rect.bottom;\n left.value = rect.left;\n right.value = rect.right;\n top.value = rect.top;\n width.value = rect.width;\n x.value = rect.x;\n y.value = rect.y;\n }\n function update() {\n if (updateTiming === \"sync\")\n recalculate();\n else if (updateTiming === \"next-frame\")\n requestAnimationFrame(() => recalculate());\n }\n useResizeObserver(target, update);\n watch(() => unrefElement(target), (ele) => !ele && update());\n useMutationObserver(target, update, {\n attributeFilter: [\"style\", \"class\"]\n });\n if (windowScroll)\n useEventListener(\"scroll\", update, { capture: true, passive: true });\n if (windowResize)\n useEventListener(\"resize\", update, { passive: true });\n tryOnMounted(() => {\n if (immediate)\n update();\n });\n return {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y,\n update\n };\n}\n\nconst vElementBounding = {\n mounted(el, binding) {\n const [handler, options] = typeof binding.value === \"function\" ? [binding.value, {}] : binding.value;\n const {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y\n } = useElementBounding(el, options);\n watch([height, bottom, left, right, top, width, x, y], () => handler({ height, bottom, left, right, top, width, x, y }));\n }\n};\n\nfunction onElementRemoval(target, callback, options = {}) {\n const {\n window = defaultWindow,\n document = window == null ? void 0 : window.document,\n flush = \"sync\"\n } = options;\n if (!window || !document)\n return noop;\n let stopFn;\n const cleanupAndUpdate = (fn) => {\n stopFn == null ? void 0 : stopFn();\n stopFn = fn;\n };\n const stopWatch = watchEffect(() => {\n const el = unrefElement(target);\n if (el) {\n const { stop } = useMutationObserver(\n document,\n (mutationsList) => {\n const targetRemoved = mutationsList.map((mutation) => [...mutation.removedNodes]).flat().some((node) => node === el || node.contains(el));\n if (targetRemoved) {\n callback(mutationsList);\n }\n },\n {\n window,\n childList: true,\n subtree: true\n }\n );\n cleanupAndUpdate(stop);\n }\n }, { flush });\n const stopHandle = () => {\n stopWatch();\n cleanupAndUpdate();\n };\n tryOnScopeDispose(stopHandle);\n return stopHandle;\n}\n\nfunction useElementHover(el, options = {}) {\n const {\n delayEnter = 0,\n delayLeave = 0,\n triggerOnRemoval = false,\n window = defaultWindow\n } = options;\n const isHovered = shallowRef(false);\n let timer;\n const toggle = (entering) => {\n const delay = entering ? delayEnter : delayLeave;\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n }\n if (delay)\n timer = setTimeout(() => isHovered.value = entering, delay);\n else\n isHovered.value = entering;\n };\n if (!window)\n return isHovered;\n useEventListener(el, \"mouseenter\", () => toggle(true), { passive: true });\n useEventListener(el, \"mouseleave\", () => toggle(false), { passive: true });\n if (triggerOnRemoval) {\n onElementRemoval(\n computed(() => unrefElement(el)),\n () => toggle(false)\n );\n }\n return isHovered;\n}\n\nconst vElementHover = {\n mounted(el, binding) {\n const value = binding.value;\n if (typeof value === \"function\") {\n const isHovered = useElementHover(el);\n watch(isHovered, (v) => value(v));\n } else {\n const [handler, options] = value;\n const isHovered = useElementHover(el, options);\n watch(isHovered, (v) => handler(v));\n }\n }\n};\n\nconst UseElementSize = /* @__PURE__ */ defineComponent({\n name: \"UseElementSize\",\n props: [\"width\", \"height\", \"box\", \"as\"],\n setup(props, { slots }) {\n var _a, _b;\n const target = shallowRef();\n const data = reactive(useElementSize$1(target, { width: (_a = props.width) != null ? _a : 0, height: (_b = props.height) != null ? _b : 0 }, { box: props.box }));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n const { window = defaultWindow, box = \"content-box\" } = options;\n const isSVG = computed(() => {\n var _a, _b;\n return (_b = (_a = unrefElement(target)) == null ? void 0 : _a.namespaceURI) == null ? void 0 : _b.includes(\"svg\");\n });\n const width = shallowRef(initialSize.width);\n const height = shallowRef(initialSize.height);\n const { stop: stop1 } = useResizeObserver(\n target,\n ([entry]) => {\n const boxSize = box === \"border-box\" ? entry.borderBoxSize : box === \"content-box\" ? entry.contentBoxSize : entry.devicePixelContentBoxSize;\n if (window && isSVG.value) {\n const $elem = unrefElement(target);\n if ($elem) {\n const rect = $elem.getBoundingClientRect();\n width.value = rect.width;\n height.value = rect.height;\n }\n } else {\n if (boxSize) {\n const formatBoxSize = toArray(boxSize);\n width.value = formatBoxSize.reduce((acc, { inlineSize }) => acc + inlineSize, 0);\n height.value = formatBoxSize.reduce((acc, { blockSize }) => acc + blockSize, 0);\n } else {\n width.value = entry.contentRect.width;\n height.value = entry.contentRect.height;\n }\n }\n },\n options\n );\n tryOnMounted(() => {\n const ele = unrefElement(target);\n if (ele) {\n width.value = \"offsetWidth\" in ele ? ele.offsetWidth : initialSize.width;\n height.value = \"offsetHeight\" in ele ? ele.offsetHeight : initialSize.height;\n }\n });\n const stop2 = watch(\n () => unrefElement(target),\n (ele) => {\n width.value = ele ? initialSize.width : 0;\n height.value = ele ? initialSize.height : 0;\n }\n );\n function stop() {\n stop1();\n stop2();\n }\n return {\n width,\n height,\n stop\n };\n}\n\nconst vElementSize = {\n mounted(el, binding) {\n var _a;\n const handler = typeof binding.value === \"function\" ? binding.value : (_a = binding.value) == null ? void 0 : _a[0];\n const options = typeof binding.value === \"function\" ? [] : binding.value.slice(1);\n const { width, height } = useElementSize(el, ...options);\n watch([width, height], ([width2, height2]) => handler({ width: width2, height: height2 }));\n }\n};\n\nconst UseElementVisibility = /* @__PURE__ */ defineComponent({\n name: \"UseElementVisibility\",\n props: [\"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive({\n isVisible: useElementVisibility$1(target)\n });\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n const {\n root,\n rootMargin = \"0px\",\n threshold = 0,\n window = defaultWindow,\n immediate = true\n } = options;\n const isSupported = useSupported(() => window && \"IntersectionObserver\" in window);\n const targets = computed(() => {\n const _target = toValue(target);\n return toArray(_target).map(unrefElement).filter(notNullish);\n });\n let cleanup = noop;\n const isActive = shallowRef(immediate);\n const stopWatch = isSupported.value ? watch(\n () => [targets.value, unrefElement(root), isActive.value],\n ([targets2, root2]) => {\n cleanup();\n if (!isActive.value)\n return;\n if (!targets2.length)\n return;\n const observer = new IntersectionObserver(\n callback,\n {\n root: unrefElement(root2),\n rootMargin,\n threshold\n }\n );\n targets2.forEach((el) => el && observer.observe(el));\n cleanup = () => {\n observer.disconnect();\n cleanup = noop;\n };\n },\n { immediate, flush: \"post\" }\n ) : noop;\n const stop = () => {\n cleanup();\n stopWatch();\n isActive.value = false;\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n isActive,\n pause() {\n cleanup();\n isActive.value = false;\n },\n resume() {\n isActive.value = true;\n },\n stop\n };\n}\n\nfunction useElementVisibility(element, options = {}) {\n const {\n window = defaultWindow,\n scrollTarget,\n threshold = 0,\n rootMargin,\n once = false\n } = options;\n const elementIsVisible = shallowRef(false);\n const { stop } = useIntersectionObserver(\n element,\n (intersectionObserverEntries) => {\n let isIntersecting = elementIsVisible.value;\n let latestTime = 0;\n for (const entry of intersectionObserverEntries) {\n if (entry.time >= latestTime) {\n latestTime = entry.time;\n isIntersecting = entry.isIntersecting;\n }\n }\n elementIsVisible.value = isIntersecting;\n if (once) {\n watchOnce(elementIsVisible, () => {\n stop();\n });\n }\n },\n {\n root: scrollTarget,\n window,\n threshold,\n rootMargin: toValue(rootMargin)\n }\n );\n return elementIsVisible;\n}\n\nconst vElementVisibility = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\") {\n const handler = binding.value;\n const isVisible = useElementVisibility(el);\n watch(isVisible, (v) => handler(v), { immediate: true });\n } else {\n const [handler, options] = binding.value;\n const isVisible = useElementVisibility(el, options);\n watch(isVisible, (v) => handler(v), { immediate: true });\n }\n }\n};\n\nconst UseEyeDropper = /* @__PURE__ */ defineComponent({\n name: \"UseEyeDropper\",\n props: {\n sRGBHex: String\n },\n setup(props, { slots }) {\n const data = reactive(useEyeDropper());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseFullscreen = /* @__PURE__ */ defineComponent({\n name: \"UseFullscreen\",\n props: [\"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useFullscreen(target));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UseGeolocation = /* @__PURE__ */ defineComponent({\n name: \"UseGeolocation\",\n props: [\"enableHighAccuracy\", \"maximumAge\", \"timeout\", \"navigator\"],\n setup(props, { slots }) {\n const data = reactive(useGeolocation(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseIdle = /* @__PURE__ */ defineComponent({\n name: \"UseIdle\",\n props: [\"timeout\", \"events\", \"listenForVisibilityChange\", \"initialState\"],\n setup(props, { slots }) {\n const data = reactive(useIdle(props.timeout, props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nfunction useAsyncState(promise, initialState, options) {\n var _a;\n const {\n immediate = true,\n delay = 0,\n onError = (_a = globalThis.reportError) != null ? _a : noop,\n onSuccess = noop,\n resetOnExecute = true,\n shallow = true,\n throwError\n } = options != null ? options : {};\n const state = shallow ? shallowRef(initialState) : ref(initialState);\n const isReady = shallowRef(false);\n const isLoading = shallowRef(false);\n const error = shallowRef(void 0);\n async function execute(delay2 = 0, ...args) {\n if (resetOnExecute)\n state.value = toValue(initialState);\n error.value = void 0;\n isReady.value = false;\n isLoading.value = true;\n if (delay2 > 0)\n await promiseTimeout(delay2);\n const _promise = typeof promise === \"function\" ? promise(...args) : promise;\n try {\n const data = await _promise;\n state.value = data;\n isReady.value = true;\n onSuccess(data);\n } catch (e) {\n error.value = e;\n onError(e);\n if (throwError)\n throw e;\n } finally {\n isLoading.value = false;\n }\n return state.value;\n }\n if (immediate) {\n execute(delay);\n }\n const shell = {\n state,\n isReady,\n isLoading,\n error,\n execute,\n executeImmediate: (...args) => execute(0, ...args)\n };\n function waitUntilIsLoaded() {\n return new Promise((resolve, reject) => {\n until(isLoading).toBe(false).then(() => resolve(shell)).catch(reject);\n });\n }\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilIsLoaded().then(onFulfilled, onRejected);\n }\n };\n}\n\nasync function loadImage(options) {\n return new Promise((resolve, reject) => {\n const img = new Image();\n const { src, srcset, sizes, class: clazz, loading, crossorigin, referrerPolicy, width, height, decoding, fetchPriority, ismap, usemap } = options;\n img.src = src;\n if (srcset != null)\n img.srcset = srcset;\n if (sizes != null)\n img.sizes = sizes;\n if (clazz != null)\n img.className = clazz;\n if (loading != null)\n img.loading = loading;\n if (crossorigin != null)\n img.crossOrigin = crossorigin;\n if (referrerPolicy != null)\n img.referrerPolicy = referrerPolicy;\n if (width != null)\n img.width = width;\n if (height != null)\n img.height = height;\n if (decoding != null)\n img.decoding = decoding;\n if (fetchPriority != null)\n img.fetchPriority = fetchPriority;\n if (ismap != null)\n img.isMap = ismap;\n if (usemap != null)\n img.useMap = usemap;\n img.onload = () => resolve(img);\n img.onerror = reject;\n });\n}\nfunction useImage(options, asyncStateOptions = {}) {\n const state = useAsyncState(\n () => loadImage(toValue(options)),\n void 0,\n {\n resetOnExecute: true,\n ...asyncStateOptions\n }\n );\n watch(\n () => toValue(options),\n () => state.execute(asyncStateOptions.delay),\n { deep: true }\n );\n return state;\n}\n\nconst UseImage = /* @__PURE__ */ defineComponent({\n name: \"UseImage\",\n props: [\n \"src\",\n \"srcset\",\n \"sizes\",\n \"as\",\n \"alt\",\n \"class\",\n \"loading\",\n \"crossorigin\",\n \"referrerPolicy\",\n \"width\",\n \"height\",\n \"decoding\",\n \"fetchPriority\",\n \"ismap\",\n \"usemap\"\n ],\n setup(props, { slots }) {\n const data = reactive(useImage(props));\n return () => {\n if (data.isLoading && slots.loading)\n return slots.loading(data);\n else if (data.error && slots.error)\n return slots.error(data.error);\n if (slots.default)\n return slots.default(data);\n return h(props.as || \"img\", props);\n };\n }\n});\n\nfunction resolveElement(el) {\n if (typeof Window !== \"undefined\" && el instanceof Window)\n return el.document.documentElement;\n if (typeof Document !== \"undefined\" && el instanceof Document)\n return el.documentElement;\n return el;\n}\n\nconst ARRIVED_STATE_THRESHOLD_PIXELS = 1;\nfunction useScroll(element, options = {}) {\n const {\n throttle = 0,\n idle = 200,\n onStop = noop,\n onScroll = noop,\n offset = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n },\n observe: _observe = {\n mutation: false\n },\n eventListenerOptions = {\n capture: false,\n passive: true\n },\n behavior = \"auto\",\n window = defaultWindow,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const observe = typeof _observe === \"boolean\" ? {\n mutation: _observe\n } : _observe;\n const internalX = shallowRef(0);\n const internalY = shallowRef(0);\n const x = computed({\n get() {\n return internalX.value;\n },\n set(x2) {\n scrollTo(x2, void 0);\n }\n });\n const y = computed({\n get() {\n return internalY.value;\n },\n set(y2) {\n scrollTo(void 0, y2);\n }\n });\n function scrollTo(_x, _y) {\n var _a, _b, _c, _d;\n if (!window)\n return;\n const _element = toValue(element);\n if (!_element)\n return;\n (_c = _element instanceof Document ? window.document.body : _element) == null ? void 0 : _c.scrollTo({\n top: (_a = toValue(_y)) != null ? _a : y.value,\n left: (_b = toValue(_x)) != null ? _b : x.value,\n behavior: toValue(behavior)\n });\n const scrollContainer = ((_d = _element == null ? void 0 : _element.document) == null ? void 0 : _d.documentElement) || (_element == null ? void 0 : _element.documentElement) || _element;\n if (x != null)\n internalX.value = scrollContainer.scrollLeft;\n if (y != null)\n internalY.value = scrollContainer.scrollTop;\n }\n const isScrolling = shallowRef(false);\n const arrivedState = reactive({\n left: true,\n right: false,\n top: true,\n bottom: false\n });\n const directions = reactive({\n left: false,\n right: false,\n top: false,\n bottom: false\n });\n const onScrollEnd = (e) => {\n if (!isScrolling.value)\n return;\n isScrolling.value = false;\n directions.left = false;\n directions.right = false;\n directions.top = false;\n directions.bottom = false;\n onStop(e);\n };\n const onScrollEndDebounced = useDebounceFn(onScrollEnd, throttle + idle);\n const setArrivedState = (target) => {\n var _a;\n if (!window)\n return;\n const el = ((_a = target == null ? void 0 : target.document) == null ? void 0 : _a.documentElement) || (target == null ? void 0 : target.documentElement) || unrefElement(target);\n const { display, flexDirection, direction } = getComputedStyle(el);\n const directionMultipler = direction === \"rtl\" ? -1 : 1;\n const scrollLeft = el.scrollLeft;\n directions.left = scrollLeft < internalX.value;\n directions.right = scrollLeft > internalX.value;\n const left = Math.abs(scrollLeft * directionMultipler) <= (offset.left || 0);\n const right = Math.abs(scrollLeft * directionMultipler) + el.clientWidth >= el.scrollWidth - (offset.right || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"row-reverse\") {\n arrivedState.left = right;\n arrivedState.right = left;\n } else {\n arrivedState.left = left;\n arrivedState.right = right;\n }\n internalX.value = scrollLeft;\n let scrollTop = el.scrollTop;\n if (target === window.document && !scrollTop)\n scrollTop = window.document.body.scrollTop;\n directions.top = scrollTop < internalY.value;\n directions.bottom = scrollTop > internalY.value;\n const top = Math.abs(scrollTop) <= (offset.top || 0);\n const bottom = Math.abs(scrollTop) + el.clientHeight >= el.scrollHeight - (offset.bottom || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"column-reverse\") {\n arrivedState.top = bottom;\n arrivedState.bottom = top;\n } else {\n arrivedState.top = top;\n arrivedState.bottom = bottom;\n }\n internalY.value = scrollTop;\n };\n const onScrollHandler = (e) => {\n var _a;\n if (!window)\n return;\n const eventTarget = (_a = e.target.documentElement) != null ? _a : e.target;\n setArrivedState(eventTarget);\n isScrolling.value = true;\n onScrollEndDebounced(e);\n onScroll(e);\n };\n useEventListener(\n element,\n \"scroll\",\n throttle ? useThrottleFn(onScrollHandler, throttle, true, false) : onScrollHandler,\n eventListenerOptions\n );\n tryOnMounted(() => {\n try {\n const _element = toValue(element);\n if (!_element)\n return;\n setArrivedState(_element);\n } catch (e) {\n onError(e);\n }\n });\n if ((observe == null ? void 0 : observe.mutation) && element != null && element !== window && element !== document) {\n useMutationObserver(\n element,\n () => {\n const _element = toValue(element);\n if (!_element)\n return;\n setArrivedState(_element);\n },\n {\n attributes: true,\n childList: true,\n subtree: true\n }\n );\n }\n useEventListener(\n element,\n \"scrollend\",\n onScrollEnd,\n eventListenerOptions\n );\n return {\n x,\n y,\n isScrolling,\n arrivedState,\n directions,\n measure() {\n const _element = toValue(element);\n if (window && _element)\n setArrivedState(_element);\n }\n };\n}\n\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n var _a;\n const {\n direction = \"bottom\",\n interval = 100,\n canLoadMore = () => true\n } = options;\n const state = reactive(useScroll(\n element,\n {\n ...options,\n offset: {\n [direction]: (_a = options.distance) != null ? _a : 0,\n ...options.offset\n }\n }\n ));\n const promise = ref();\n const isLoading = computed(() => !!promise.value);\n const observedElement = computed(() => {\n return resolveElement(toValue(element));\n });\n const isElementVisible = useElementVisibility(observedElement);\n function checkAndLoad() {\n state.measure();\n if (!observedElement.value || !isElementVisible.value || !canLoadMore(observedElement.value))\n return;\n const { scrollHeight, clientHeight, scrollWidth, clientWidth } = observedElement.value;\n const isNarrower = direction === \"bottom\" || direction === \"top\" ? scrollHeight <= clientHeight : scrollWidth <= clientWidth;\n if (state.arrivedState[direction] || isNarrower) {\n if (!promise.value) {\n promise.value = Promise.all([\n onLoadMore(state),\n new Promise((resolve) => setTimeout(resolve, interval))\n ]).finally(() => {\n promise.value = null;\n nextTick(() => checkAndLoad());\n });\n }\n }\n }\n const stop = watch(\n () => [state.arrivedState[direction], isElementVisible.value],\n checkAndLoad,\n { immediate: true }\n );\n tryOnUnmounted(stop);\n return {\n isLoading,\n reset() {\n nextTick(() => checkAndLoad());\n }\n };\n}\n\nconst vInfiniteScroll = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n useInfiniteScroll(el, binding.value);\n else\n useInfiniteScroll(el, ...binding.value);\n }\n};\n\nconst vIntersectionObserver = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n useIntersectionObserver(el, binding.value);\n else\n useIntersectionObserver(el, ...binding.value);\n }\n};\n\nconst UseMouse = /* @__PURE__ */ defineComponent({\n name: \"UseMouse\",\n props: [\"touch\", \"resetOnTouchEnds\", \"initialValue\"],\n setup(props, { slots }) {\n const data = reactive(useMouse$1(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseMouseInElement = /* @__PURE__ */ defineComponent({\n name: \"UseMouseElement\",\n props: [\"handleOutside\", \"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useMouseInElement$1(target, props));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UseMouseBuiltinExtractors = {\n page: (event) => [event.pageX, event.pageY],\n client: (event) => [event.clientX, event.clientY],\n screen: (event) => [event.screenX, event.screenY],\n movement: (event) => event instanceof MouseEvent ? [event.movementX, event.movementY] : null\n};\nfunction useMouse(options = {}) {\n const {\n type = \"page\",\n touch = true,\n resetOnTouchEnds = false,\n initialValue = { x: 0, y: 0 },\n window = defaultWindow,\n target = window,\n scroll = true,\n eventFilter\n } = options;\n let _prevMouseEvent = null;\n let _prevScrollX = 0;\n let _prevScrollY = 0;\n const x = shallowRef(initialValue.x);\n const y = shallowRef(initialValue.y);\n const sourceType = shallowRef(null);\n const extractor = typeof type === \"function\" ? type : UseMouseBuiltinExtractors[type];\n const mouseHandler = (event) => {\n const result = extractor(event);\n _prevMouseEvent = event;\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"mouse\";\n }\n if (window) {\n _prevScrollX = window.scrollX;\n _prevScrollY = window.scrollY;\n }\n };\n const touchHandler = (event) => {\n if (event.touches.length > 0) {\n const result = extractor(event.touches[0]);\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"touch\";\n }\n }\n };\n const scrollHandler = () => {\n if (!_prevMouseEvent || !window)\n return;\n const pos = extractor(_prevMouseEvent);\n if (_prevMouseEvent instanceof MouseEvent && pos) {\n x.value = pos[0] + window.scrollX - _prevScrollX;\n y.value = pos[1] + window.scrollY - _prevScrollY;\n }\n };\n const reset = () => {\n x.value = initialValue.x;\n y.value = initialValue.y;\n };\n const mouseHandlerWrapper = eventFilter ? (event) => eventFilter(() => mouseHandler(event), {}) : (event) => mouseHandler(event);\n const touchHandlerWrapper = eventFilter ? (event) => eventFilter(() => touchHandler(event), {}) : (event) => touchHandler(event);\n const scrollHandlerWrapper = eventFilter ? () => eventFilter(() => scrollHandler(), {}) : () => scrollHandler();\n if (target) {\n const listenerOptions = { passive: true };\n useEventListener(target, [\"mousemove\", \"dragover\"], mouseHandlerWrapper, listenerOptions);\n if (touch && type !== \"movement\") {\n useEventListener(target, [\"touchstart\", \"touchmove\"], touchHandlerWrapper, listenerOptions);\n if (resetOnTouchEnds)\n useEventListener(target, \"touchend\", reset, listenerOptions);\n }\n if (scroll && type === \"page\")\n useEventListener(window, \"scroll\", scrollHandlerWrapper, listenerOptions);\n }\n return {\n x,\n y,\n sourceType\n };\n}\n\nfunction useMouseInElement(target, options = {}) {\n const {\n windowResize = true,\n windowScroll = true,\n handleOutside = true,\n window = defaultWindow\n } = options;\n const type = options.type || \"page\";\n const { x, y, sourceType } = useMouse(options);\n const targetRef = shallowRef(target != null ? target : window == null ? void 0 : window.document.body);\n const elementX = shallowRef(0);\n const elementY = shallowRef(0);\n const elementPositionX = shallowRef(0);\n const elementPositionY = shallowRef(0);\n const elementHeight = shallowRef(0);\n const elementWidth = shallowRef(0);\n const isOutside = shallowRef(true);\n function update() {\n if (!window)\n return;\n const el = unrefElement(targetRef);\n if (!el || !(el instanceof Element))\n return;\n const {\n left,\n top,\n width,\n height\n } = el.getBoundingClientRect();\n elementPositionX.value = left + (type === \"page\" ? window.pageXOffset : 0);\n elementPositionY.value = top + (type === \"page\" ? window.pageYOffset : 0);\n elementHeight.value = height;\n elementWidth.value = width;\n const elX = x.value - elementPositionX.value;\n const elY = y.value - elementPositionY.value;\n isOutside.value = width === 0 || height === 0 || elX < 0 || elY < 0 || elX > width || elY > height;\n if (handleOutside || !isOutside.value) {\n elementX.value = elX;\n elementY.value = elY;\n }\n }\n const stopFnList = [];\n function stop() {\n stopFnList.forEach((fn) => fn());\n stopFnList.length = 0;\n }\n tryOnMounted(() => {\n update();\n });\n if (window) {\n const {\n stop: stopResizeObserver\n } = useResizeObserver(targetRef, update);\n const {\n stop: stopMutationObserver\n } = useMutationObserver(targetRef, update, {\n attributeFilter: [\"style\", \"class\"]\n });\n const stopWatch = watch(\n [targetRef, x, y],\n update\n );\n stopFnList.push(\n stopResizeObserver,\n stopMutationObserver,\n stopWatch\n );\n useEventListener(\n document,\n \"mouseleave\",\n () => isOutside.value = true,\n { passive: true }\n );\n if (windowScroll) {\n stopFnList.push(\n useEventListener(\"scroll\", update, { capture: true, passive: true })\n );\n }\n if (windowResize) {\n stopFnList.push(\n useEventListener(\"resize\", update, { passive: true })\n );\n }\n }\n return {\n x,\n y,\n sourceType,\n elementX,\n elementY,\n elementPositionX,\n elementPositionY,\n elementHeight,\n elementWidth,\n isOutside,\n stop\n };\n}\n\nconst vMouseInElement = {\n mounted(el, binding) {\n const [handler, options] = typeof binding.value === \"function\" ? [binding.value, {}] : binding.value;\n const state = reactiveOmit(reactive(useMouseInElement(el, options)), \"stop\");\n watch(state, (val) => handler(val));\n }\n};\n\nconst UseMousePressed = /* @__PURE__ */ defineComponent({\n name: \"UseMousePressed\",\n props: [\"touch\", \"initialValue\", \"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useMousePressed({ ...props, target }));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UseNetwork = /* @__PURE__ */ defineComponent({\n name: \"UseNetwork\",\n setup(props, { slots }) {\n const data = reactive(useNetwork());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseNow = /* @__PURE__ */ defineComponent({\n name: \"UseNow\",\n props: [\"interval\"],\n setup(props, { slots }) {\n const data = reactive(useNow({ ...props, controls: true }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseObjectUrl = /* @__PURE__ */ defineComponent({\n name: \"UseObjectUrl\",\n props: [\n \"object\"\n ],\n setup(props, { slots }) {\n const object = toRef(props, \"object\");\n const url = useObjectUrl(object);\n return () => {\n if (slots.default && url.value)\n return slots.default(url);\n };\n }\n});\n\nconst UseOffsetPagination = /* @__PURE__ */ defineComponent({\n name: \"UseOffsetPagination\",\n props: [\n \"total\",\n \"page\",\n \"pageSize\",\n \"onPageChange\",\n \"onPageSizeChange\",\n \"onPageCountChange\"\n ],\n emits: [\n \"page-change\",\n \"page-size-change\",\n \"page-count-change\"\n ],\n setup(props, { slots, emit }) {\n const data = reactive(useOffsetPagination({\n ...props,\n onPageChange(...args) {\n var _a;\n (_a = props.onPageChange) == null ? void 0 : _a.call(props, ...args);\n emit(\"page-change\", ...args);\n },\n onPageSizeChange(...args) {\n var _a;\n (_a = props.onPageSizeChange) == null ? void 0 : _a.call(props, ...args);\n emit(\"page-size-change\", ...args);\n },\n onPageCountChange(...args) {\n var _a;\n (_a = props.onPageCountChange) == null ? void 0 : _a.call(props, ...args);\n emit(\"page-count-change\", ...args);\n }\n }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseOnline = /* @__PURE__ */ defineComponent({\n name: \"UseOnline\",\n setup(props, { slots }) {\n const data = reactive({\n isOnline: useOnline()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePageLeave = /* @__PURE__ */ defineComponent({\n name: \"UsePageLeave\",\n setup(props, { slots }) {\n const data = reactive({\n isLeft: usePageLeave()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePointer = /* @__PURE__ */ defineComponent({\n name: \"UsePointer\",\n props: [\n \"pointerTypes\",\n \"initialValue\",\n \"target\"\n ],\n setup(props, { slots }) {\n const el = shallowRef(null);\n const data = reactive(usePointer({\n ...props,\n target: props.target === \"self\" ? el : defaultWindow\n }));\n return () => {\n if (slots.default)\n return slots.default(data, { ref: el });\n };\n }\n});\n\nconst UsePointerLock = /*@__PURE__*/ defineComponent({\n name: \"UsePointerLock\",\n props: [\"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(usePointerLock(target));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UsePreferredColorScheme = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredColorScheme\",\n setup(props, { slots }) {\n const data = reactive({\n colorScheme: usePreferredColorScheme()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredContrast = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredContrast\",\n setup(props, { slots }) {\n const data = reactive({\n contrast: usePreferredContrast()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredDark = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredDark\",\n setup(props, { slots }) {\n const data = reactive({\n prefersDark: usePreferredDark$1()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredLanguages = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredLanguages\",\n setup(props, { slots }) {\n const data = reactive({\n languages: usePreferredLanguages()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredReducedMotion = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredReducedMotion\",\n setup(props, { slots }) {\n const data = reactive({\n motion: usePreferredReducedMotion()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredReducedTransparency = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredReducedTransparency\",\n setup(props, { slots }) {\n const data = reactive({\n transparency: usePreferredReducedTransparency()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst vResizeObserver = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n useResizeObserver(el, binding.value);\n else\n useResizeObserver(el, ...binding.value);\n }\n};\n\nfunction useCssVar(prop, target, options = {}) {\n const { window = defaultWindow, initialValue, observe = false } = options;\n const variable = shallowRef(initialValue);\n const elRef = computed(() => {\n var _a;\n return unrefElement(target) || ((_a = window == null ? void 0 : window.document) == null ? void 0 : _a.documentElement);\n });\n function updateCssVar() {\n var _a;\n const key = toValue(prop);\n const el = toValue(elRef);\n if (el && window && key) {\n const value = (_a = window.getComputedStyle(el).getPropertyValue(key)) == null ? void 0 : _a.trim();\n variable.value = value || variable.value || initialValue;\n }\n }\n if (observe) {\n useMutationObserver(elRef, updateCssVar, {\n attributeFilter: [\"style\", \"class\"],\n window\n });\n }\n watch(\n [elRef, () => toValue(prop)],\n (_, old) => {\n if (old[0] && old[1])\n old[0].style.removeProperty(old[1]);\n updateCssVar();\n },\n { immediate: true }\n );\n watch(\n [variable, elRef],\n ([val, el]) => {\n const raw_prop = toValue(prop);\n if ((el == null ? void 0 : el.style) && raw_prop) {\n if (val == null)\n el.style.removeProperty(raw_prop);\n else\n el.style.setProperty(raw_prop, val);\n }\n },\n { immediate: true }\n );\n return variable;\n}\n\nconst topVarName = \"--vueuse-safe-area-top\";\nconst rightVarName = \"--vueuse-safe-area-right\";\nconst bottomVarName = \"--vueuse-safe-area-bottom\";\nconst leftVarName = \"--vueuse-safe-area-left\";\nfunction useScreenSafeArea() {\n const top = shallowRef(\"\");\n const right = shallowRef(\"\");\n const bottom = shallowRef(\"\");\n const left = shallowRef(\"\");\n if (isClient) {\n const topCssVar = useCssVar(topVarName);\n const rightCssVar = useCssVar(rightVarName);\n const bottomCssVar = useCssVar(bottomVarName);\n const leftCssVar = useCssVar(leftVarName);\n topCssVar.value = \"env(safe-area-inset-top, 0px)\";\n rightCssVar.value = \"env(safe-area-inset-right, 0px)\";\n bottomCssVar.value = \"env(safe-area-inset-bottom, 0px)\";\n leftCssVar.value = \"env(safe-area-inset-left, 0px)\";\n tryOnMounted(update);\n useEventListener(\"resize\", useDebounceFn(update), { passive: true });\n }\n function update() {\n top.value = getValue(topVarName);\n right.value = getValue(rightVarName);\n bottom.value = getValue(bottomVarName);\n left.value = getValue(leftVarName);\n }\n return {\n top,\n right,\n bottom,\n left,\n update\n };\n}\nfunction getValue(position) {\n return getComputedStyle(document.documentElement).getPropertyValue(position);\n}\n\nconst UseScreenSafeArea = /* @__PURE__ */ defineComponent({\n name: \"UseScreenSafeArea\",\n props: {\n top: Boolean,\n right: Boolean,\n bottom: Boolean,\n left: Boolean\n },\n setup(props, { slots }) {\n const {\n top,\n right,\n bottom,\n left\n } = useScreenSafeArea();\n return () => {\n if (slots.default) {\n return h(\"div\", {\n style: {\n paddingTop: props.top ? top.value : \"\",\n paddingRight: props.right ? right.value : \"\",\n paddingBottom: props.bottom ? bottom.value : \"\",\n paddingLeft: props.left ? left.value : \"\",\n boxSizing: \"border-box\",\n maxHeight: \"100vh\",\n maxWidth: \"100vw\",\n overflow: \"auto\"\n }\n }, slots.default());\n }\n };\n }\n});\n\nconst vScroll = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\") {\n const handler = binding.value;\n const state = useScroll(el, {\n onScroll() {\n handler(state);\n },\n onStop() {\n handler(state);\n }\n });\n } else {\n const [handler, options] = binding.value;\n const state = useScroll(el, {\n ...options,\n onScroll(e) {\n var _a;\n (_a = options.onScroll) == null ? void 0 : _a.call(options, e);\n handler(state);\n },\n onStop(e) {\n var _a;\n (_a = options.onStop) == null ? void 0 : _a.call(options, e);\n handler(state);\n }\n });\n }\n }\n};\n\nfunction checkOverflowScroll(ele) {\n const style = window.getComputedStyle(ele);\n if (style.overflowX === \"scroll\" || style.overflowY === \"scroll\" || style.overflowX === \"auto\" && ele.clientWidth < ele.scrollWidth || style.overflowY === \"auto\" && ele.clientHeight < ele.scrollHeight) {\n return true;\n } else {\n const parent = ele.parentNode;\n if (!parent || parent.tagName === \"BODY\")\n return false;\n return checkOverflowScroll(parent);\n }\n}\nfunction preventDefault(rawEvent) {\n const e = rawEvent || window.event;\n const _target = e.target;\n if (checkOverflowScroll(_target))\n return false;\n if (e.touches.length > 1)\n return true;\n if (e.preventDefault)\n e.preventDefault();\n return false;\n}\nconst elInitialOverflow = /* @__PURE__ */ new WeakMap();\nfunction useScrollLock(element, initialState = false) {\n const isLocked = shallowRef(initialState);\n let stopTouchMoveListener = null;\n let initialOverflow = \"\";\n watch(toRef(element), (el) => {\n const target = resolveElement(toValue(el));\n if (target) {\n const ele = target;\n if (!elInitialOverflow.get(ele))\n elInitialOverflow.set(ele, ele.style.overflow);\n if (ele.style.overflow !== \"hidden\")\n initialOverflow = ele.style.overflow;\n if (ele.style.overflow === \"hidden\")\n return isLocked.value = true;\n if (isLocked.value)\n return ele.style.overflow = \"hidden\";\n }\n }, {\n immediate: true\n });\n const lock = () => {\n const el = resolveElement(toValue(element));\n if (!el || isLocked.value)\n return;\n if (isIOS) {\n stopTouchMoveListener = useEventListener(\n el,\n \"touchmove\",\n (e) => {\n preventDefault(e);\n },\n { passive: false }\n );\n }\n el.style.overflow = \"hidden\";\n isLocked.value = true;\n };\n const unlock = () => {\n const el = resolveElement(toValue(element));\n if (!el || !isLocked.value)\n return;\n if (isIOS)\n stopTouchMoveListener == null ? void 0 : stopTouchMoveListener();\n el.style.overflow = initialOverflow;\n elInitialOverflow.delete(el);\n isLocked.value = false;\n };\n tryOnScopeDispose(unlock);\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else unlock();\n }\n });\n}\n\nfunction onScrollLock() {\n let isMounted = false;\n const state = shallowRef(false);\n return (el, binding) => {\n state.value = binding.value;\n if (isMounted)\n return;\n isMounted = true;\n const isLocked = useScrollLock(el, binding.value);\n watch(state, (v) => isLocked.value = v);\n };\n}\nconst vScrollLock = onScrollLock();\n\nconst UseTimeAgo = /* @__PURE__ */ defineComponent({\n name: \"UseTimeAgo\",\n props: [\"time\", \"updateInterval\", \"max\", \"fullDateFormatter\", \"messages\", \"showSecond\"],\n setup(props, { slots }) {\n const data = reactive(useTimeAgo(() => props.time, { ...props, controls: true }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseTimestamp = /* @__PURE__ */ defineComponent({\n name: \"UseTimestamp\",\n props: [\"immediate\", \"interval\", \"offset\"],\n setup(props, { slots }) {\n const data = reactive(useTimestamp({ ...props, controls: true }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseVirtualList = /* @__PURE__ */ defineComponent({\n name: \"UseVirtualList\",\n props: [\n \"list\",\n \"options\",\n \"height\"\n ],\n setup(props, { slots, expose }) {\n const { list: listRef } = toRefs(props);\n const { list, containerProps, wrapperProps, scrollTo } = useVirtualList(listRef, props.options);\n expose({ scrollTo });\n if (containerProps.style && typeof containerProps.style === \"object\" && !Array.isArray(containerProps.style))\n containerProps.style.height = props.height || \"300px\";\n return () => h(\"div\", { ...containerProps }, [\n h(\"div\", { ...wrapperProps.value }, list.value.map((item) => h(\"div\", { style: { overflow: \"hidden\", height: item.height } }, slots.default ? slots.default(item) : \"Please set content!\")))\n ]);\n }\n});\n\nconst UseWindowFocus = /* @__PURE__ */ defineComponent({\n name: \"UseWindowFocus\",\n setup(props, { slots }) {\n const data = reactive({\n focused: useWindowFocus()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseWindowSize = /* @__PURE__ */ defineComponent({\n name: \"UseWindowSize\",\n props: [\"initialWidth\", \"initialHeight\"],\n setup(props, { slots }) {\n const data = reactive(useWindowSize(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nexport { OnClickOutside, OnLongPress, UseActiveElement, UseBattery, UseBrowserLocation, UseClipboard, UseColorMode, UseDark, UseDeviceMotion, UseDeviceOrientation, UseDevicePixelRatio, UseDevicesList, UseDocumentVisibility, UseDraggable, UseElementBounding, UseElementSize, UseElementVisibility, UseEyeDropper, UseFullscreen, UseGeolocation, UseIdle, UseImage, UseMouse, UseMouseInElement, UseMousePressed, UseNetwork, UseNow, UseObjectUrl, UseOffsetPagination, UseOnline, UsePageLeave, UsePointer, UsePointerLock, UsePreferredColorScheme, UsePreferredContrast, UsePreferredDark, UsePreferredLanguages, UsePreferredReducedMotion, UsePreferredReducedTransparency, UseScreenSafeArea, UseTimeAgo, UseTimestamp, UseVirtualList, UseWindowFocus, UseWindowSize, vOnClickOutside as VOnClickOutside, vOnLongPress as VOnLongPress, vElementBounding, vElementHover, vElementSize, vElementVisibility, vInfiniteScroll, vIntersectionObserver, vMouseInElement, vOnClickOutside, vOnKeyStroke, vOnLongPress, vResizeObserver, vScroll, vScrollLock };\n","import { l as logger } from \"../../chunks/logger-D3RVzcfQ.mjs\";\nfunction registerContactsMenuAction(action) {\n window._nc_contacts_menu_hooks ??= {};\n if (window._nc_contacts_menu_hooks[action.id]) {\n logger.error(`ContactsMenu action for id ${action.id} has already been registered`, {\n action\n });\n return;\n }\n window._nc_contacts_menu_hooks[action.id] = action;\n}\nfunction getEnabledContactsMenuActions(entry) {\n if (!window._nc_contacts_menu_hooks) {\n return [];\n }\n return Object.values(window._nc_contacts_menu_hooks).filter((action) => action.enabled(entry));\n}\nexport {\n getEnabledContactsMenuActions,\n registerContactsMenuAction\n};\n//# sourceMappingURL=index.mjs.map\n","'use strict';\n\nObject.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });\n\nvar buffer = {};\n\nvar base64Js = {};\n\nbase64Js.byteLength = byteLength;\nbase64Js.toByteArray = toByteArray;\nbase64Js.fromByteArray = fromByteArray;\n\nvar lookup = [];\nvar revLookup = [];\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array;\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i];\n revLookup[code.charCodeAt(i)] = i;\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62;\nrevLookup['_'.charCodeAt(0)] = 63;\n\nfunction getLens (b64) {\n var len = b64.length;\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=');\n if (validLen === -1) validLen = len;\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4);\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64);\n var validLen = lens[0];\n var placeHoldersLen = lens[1];\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp;\n var lens = getLens(b64);\n var validLen = lens[0];\n var placeHoldersLen = lens[1];\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen));\n\n var curByte = 0;\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen;\n\n var i;\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)];\n arr[curByte++] = (tmp >> 16) & 0xFF;\n arr[curByte++] = (tmp >> 8) & 0xFF;\n arr[curByte++] = tmp & 0xFF;\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4);\n arr[curByte++] = tmp & 0xFF;\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2);\n arr[curByte++] = (tmp >> 8) & 0xFF;\n arr[curByte++] = tmp & 0xFF;\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp;\n var output = [];\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF);\n output.push(tripletToBase64(tmp));\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp;\n var len = uint8.length;\n var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes\n var parts = [];\n var maxChunkLength = 16383; // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)));\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1];\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n );\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1];\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n );\n }\n\n return parts.join('')\n}\n\nvar ieee754 = {};\n\n/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\n\nieee754.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\nieee754.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 * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n\n(function (exports) {\n\n\tconst base64 = base64Js;\n\tconst ieee754$1 = ieee754;\n\tconst customInspectSymbol =\n\t (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n\t ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n\t : null;\n\n\texports.Buffer = Buffer;\n\texports.SlowBuffer = SlowBuffer;\n\texports.INSPECT_MAX_BYTES = 50;\n\n\tconst K_MAX_LENGTH = 0x7fffffff;\n\texports.kMaxLength = K_MAX_LENGTH;\n\tconst { Uint8Array: GlobalUint8Array, ArrayBuffer: GlobalArrayBuffer, SharedArrayBuffer: GlobalSharedArrayBuffer } = globalThis;\n\n\t/**\n\t * If `Buffer.TYPED_ARRAY_SUPPORT`:\n\t * === true Use Uint8Array implementation (fastest)\n\t * === false Print warning and recommend using `buffer` v4.x which has an Object\n\t * implementation (most compatible, even IE6)\n\t *\n\t * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n\t * Opera 11.6+, iOS 4.2+.\n\t *\n\t * We report that the browser does not support typed arrays if the are not subclassable\n\t * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n\t * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n\t * for __proto__ and has a buggy typed array implementation.\n\t */\n\tBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport();\n\n\tif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n\t typeof console.error === 'function') {\n\t console.error(\n\t 'This browser lacks typed array (Uint8Array) support which is required by ' +\n\t '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n\t );\n\t}\n\n\tfunction typedArraySupport () {\n\t // Can typed array instances can be augmented?\n\t try {\n\t const arr = new GlobalUint8Array(1);\n\t const proto = { foo: function () { return 42 } };\n\t Object.setPrototypeOf(proto, GlobalUint8Array.prototype);\n\t Object.setPrototypeOf(arr, proto);\n\t return arr.foo() === 42\n\t } catch (e) {\n\t return false\n\t }\n\t}\n\n\tObject.defineProperty(Buffer.prototype, 'parent', {\n\t enumerable: true,\n\t get: function () {\n\t if (!Buffer.isBuffer(this)) return undefined\n\t return this.buffer\n\t }\n\t});\n\n\tObject.defineProperty(Buffer.prototype, 'offset', {\n\t enumerable: true,\n\t get: function () {\n\t if (!Buffer.isBuffer(this)) return undefined\n\t return this.byteOffset\n\t }\n\t});\n\n\tfunction createBuffer (length) {\n\t if (length > K_MAX_LENGTH) {\n\t throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n\t }\n\t // Return an augmented `Uint8Array` instance\n\t const buf = new GlobalUint8Array(length);\n\t Object.setPrototypeOf(buf, Buffer.prototype);\n\t return buf\n\t}\n\n\t/**\n\t * The Buffer constructor returns instances of `Uint8Array` that have their\n\t * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n\t * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n\t * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n\t * returns a single octet.\n\t *\n\t * The `Uint8Array` prototype remains unmodified.\n\t */\n\n\tfunction Buffer (arg, encodingOrOffset, length) {\n\t // Common case.\n\t if (typeof arg === 'number') {\n\t if (typeof encodingOrOffset === 'string') {\n\t throw new TypeError(\n\t 'The \"string\" argument must be of type string. Received type number'\n\t )\n\t }\n\t return allocUnsafe(arg)\n\t }\n\t return from(arg, encodingOrOffset, length)\n\t}\n\n\tBuffer.poolSize = 8192; // not used by this implementation\n\n\tfunction from (value, encodingOrOffset, length) {\n\t if (typeof value === 'string') {\n\t return fromString(value, encodingOrOffset)\n\t }\n\n\t if (GlobalArrayBuffer.isView(value)) {\n\t return fromArrayView(value)\n\t }\n\n\t if (value == null) {\n\t throw new TypeError(\n\t 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n\t 'or Array-like Object. Received type ' + (typeof value)\n\t )\n\t }\n\n\t if (isInstance(value, GlobalArrayBuffer) ||\n\t (value && isInstance(value.buffer, GlobalArrayBuffer))) {\n\t return fromArrayBuffer(value, encodingOrOffset, length)\n\t }\n\n\t if (typeof GlobalSharedArrayBuffer !== 'undefined' &&\n\t (isInstance(value, GlobalSharedArrayBuffer) ||\n\t (value && isInstance(value.buffer, GlobalSharedArrayBuffer)))) {\n\t return fromArrayBuffer(value, encodingOrOffset, length)\n\t }\n\n\t if (typeof value === 'number') {\n\t throw new TypeError(\n\t 'The \"value\" argument must not be of type number. Received type number'\n\t )\n\t }\n\n\t const valueOf = value.valueOf && value.valueOf();\n\t if (valueOf != null && valueOf !== value) {\n\t return Buffer.from(valueOf, encodingOrOffset, length)\n\t }\n\n\t const b = fromObject(value);\n\t if (b) return b\n\n\t if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n\t typeof value[Symbol.toPrimitive] === 'function') {\n\t return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length)\n\t }\n\n\t throw new TypeError(\n\t 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n\t 'or Array-like Object. Received type ' + (typeof value)\n\t )\n\t}\n\n\t/**\n\t * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n\t * if value is a number.\n\t * Buffer.from(str[, encoding])\n\t * Buffer.from(array)\n\t * Buffer.from(buffer)\n\t * Buffer.from(arrayBuffer[, byteOffset[, length]])\n\t **/\n\tBuffer.from = function (value, encodingOrOffset, length) {\n\t return from(value, encodingOrOffset, length)\n\t};\n\n\t// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n\t// https://github.com/feross/buffer/pull/148\n\tObject.setPrototypeOf(Buffer.prototype, GlobalUint8Array.prototype);\n\tObject.setPrototypeOf(Buffer, GlobalUint8Array);\n\n\tfunction assertSize (size) {\n\t if (typeof size !== 'number') {\n\t throw new TypeError('\"size\" argument must be of type number')\n\t } else if (size < 0) {\n\t throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n\t }\n\t}\n\n\tfunction alloc (size, fill, encoding) {\n\t assertSize(size);\n\t if (size <= 0) {\n\t return createBuffer(size)\n\t }\n\t if (fill !== undefined) {\n\t // Only pay attention to encoding if it's a string. This\n\t // prevents accidentally sending in a number that would\n\t // be interpreted as a start offset.\n\t return typeof encoding === 'string'\n\t ? createBuffer(size).fill(fill, encoding)\n\t : createBuffer(size).fill(fill)\n\t }\n\t return createBuffer(size)\n\t}\n\n\t/**\n\t * Creates a new filled Buffer instance.\n\t * alloc(size[, fill[, encoding]])\n\t **/\n\tBuffer.alloc = function (size, fill, encoding) {\n\t return alloc(size, fill, encoding)\n\t};\n\n\tfunction allocUnsafe (size) {\n\t assertSize(size);\n\t return createBuffer(size < 0 ? 0 : checked(size) | 0)\n\t}\n\n\t/**\n\t * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n\t * */\n\tBuffer.allocUnsafe = function (size) {\n\t return allocUnsafe(size)\n\t};\n\t/**\n\t * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n\t */\n\tBuffer.allocUnsafeSlow = function (size) {\n\t return allocUnsafe(size)\n\t};\n\n\tfunction fromString (string, encoding) {\n\t if (typeof encoding !== 'string' || encoding === '') {\n\t encoding = 'utf8';\n\t }\n\n\t if (!Buffer.isEncoding(encoding)) {\n\t throw new TypeError('Unknown encoding: ' + encoding)\n\t }\n\n\t const length = byteLength(string, encoding) | 0;\n\t let buf = createBuffer(length);\n\n\t const actual = buf.write(string, encoding);\n\n\t if (actual !== length) {\n\t // Writing a hex string, for example, that contains invalid characters will\n\t // cause everything after the first invalid character to be ignored. (e.g.\n\t // 'abxxcd' will be treated as 'ab')\n\t buf = buf.slice(0, actual);\n\t }\n\n\t return buf\n\t}\n\n\tfunction fromArrayLike (array) {\n\t const length = array.length < 0 ? 0 : checked(array.length) | 0;\n\t const buf = createBuffer(length);\n\t for (let i = 0; i < length; i += 1) {\n\t buf[i] = array[i] & 255;\n\t }\n\t return buf\n\t}\n\n\tfunction fromArrayView (arrayView) {\n\t if (isInstance(arrayView, GlobalUint8Array)) {\n\t const copy = new GlobalUint8Array(arrayView);\n\t return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n\t }\n\t return fromArrayLike(arrayView)\n\t}\n\n\tfunction fromArrayBuffer (array, byteOffset, length) {\n\t if (byteOffset < 0 || array.byteLength < byteOffset) {\n\t throw new RangeError('\"offset\" is outside of buffer bounds')\n\t }\n\n\t if (array.byteLength < byteOffset + (length || 0)) {\n\t throw new RangeError('\"length\" is outside of buffer bounds')\n\t }\n\n\t let buf;\n\t if (byteOffset === undefined && length === undefined) {\n\t buf = new GlobalUint8Array(array);\n\t } else if (length === undefined) {\n\t buf = new GlobalUint8Array(array, byteOffset);\n\t } else {\n\t buf = new GlobalUint8Array(array, byteOffset, length);\n\t }\n\n\t // Return an augmented `Uint8Array` instance\n\t Object.setPrototypeOf(buf, Buffer.prototype);\n\n\t return buf\n\t}\n\n\tfunction fromObject (obj) {\n\t if (Buffer.isBuffer(obj)) {\n\t const len = checked(obj.length) | 0;\n\t const buf = createBuffer(len);\n\n\t if (buf.length === 0) {\n\t return buf\n\t }\n\n\t obj.copy(buf, 0, 0, len);\n\t return buf\n\t }\n\n\t if (obj.length !== undefined) {\n\t if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n\t return createBuffer(0)\n\t }\n\t return fromArrayLike(obj)\n\t }\n\n\t if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n\t return fromArrayLike(obj.data)\n\t }\n\t}\n\n\tfunction checked (length) {\n\t // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n\t // length is NaN (which is otherwise coerced to zero.)\n\t if (length >= K_MAX_LENGTH) {\n\t throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n\t 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n\t }\n\t return length | 0\n\t}\n\n\tfunction SlowBuffer (length) {\n\t if (+length != length) { // eslint-disable-line eqeqeq\n\t length = 0;\n\t }\n\t return Buffer.alloc(+length)\n\t}\n\n\tBuffer.isBuffer = function isBuffer (b) {\n\t return b != null && b._isBuffer === true &&\n\t b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n\t};\n\n\tBuffer.compare = function compare (a, b) {\n\t if (isInstance(a, GlobalUint8Array)) a = Buffer.from(a, a.offset, a.byteLength);\n\t if (isInstance(b, GlobalUint8Array)) b = Buffer.from(b, b.offset, b.byteLength);\n\t if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n\t throw new TypeError(\n\t 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n\t )\n\t }\n\n\t if (a === b) return 0\n\n\t let x = a.length;\n\t let y = b.length;\n\n\t for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n\t if (a[i] !== b[i]) {\n\t x = a[i];\n\t y = b[i];\n\t break\n\t }\n\t }\n\n\t if (x < y) return -1\n\t if (y < x) return 1\n\t return 0\n\t};\n\n\tBuffer.isEncoding = function isEncoding (encoding) {\n\t switch (String(encoding).toLowerCase()) {\n\t case 'hex':\n\t case 'utf8':\n\t case 'utf-8':\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t case 'base64':\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return true\n\t default:\n\t return false\n\t }\n\t};\n\n\tBuffer.concat = function concat (list, length) {\n\t if (!Array.isArray(list)) {\n\t throw new TypeError('\"list\" argument must be an Array of Buffers')\n\t }\n\n\t if (list.length === 0) {\n\t return Buffer.alloc(0)\n\t }\n\n\t let i;\n\t if (length === undefined) {\n\t length = 0;\n\t for (i = 0; i < list.length; ++i) {\n\t length += list[i].length;\n\t }\n\t }\n\n\t const buffer = Buffer.allocUnsafe(length);\n\t let pos = 0;\n\t for (i = 0; i < list.length; ++i) {\n\t let buf = list[i];\n\t if (isInstance(buf, GlobalUint8Array)) {\n\t if (pos + buf.length > buffer.length) {\n\t if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf);\n\t buf.copy(buffer, pos);\n\t } else {\n\t GlobalUint8Array.prototype.set.call(\n\t buffer,\n\t buf,\n\t pos\n\t );\n\t }\n\t } else if (!Buffer.isBuffer(buf)) {\n\t throw new TypeError('\"list\" argument must be an Array of Buffers')\n\t } else {\n\t buf.copy(buffer, pos);\n\t }\n\t pos += buf.length;\n\t }\n\t return buffer\n\t};\n\n\tfunction byteLength (string, encoding) {\n\t if (Buffer.isBuffer(string)) {\n\t return string.length\n\t }\n\t if (GlobalArrayBuffer.isView(string) || isInstance(string, GlobalArrayBuffer)) {\n\t return string.byteLength\n\t }\n\t if (typeof string !== 'string') {\n\t throw new TypeError(\n\t 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n\t 'Received type ' + typeof string\n\t )\n\t }\n\n\t const len = string.length;\n\t const mustMatch = (arguments.length > 2 && arguments[2] === true);\n\t if (!mustMatch && len === 0) return 0\n\n\t // Use a for loop to avoid recursion\n\t let loweredCase = false;\n\t for (;;) {\n\t switch (encoding) {\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t return len\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8ToBytes(string).length\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return len * 2\n\t case 'hex':\n\t return len >>> 1\n\t case 'base64':\n\t return base64ToBytes(string).length\n\t default:\n\t if (loweredCase) {\n\t return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n\t }\n\t encoding = ('' + encoding).toLowerCase();\n\t loweredCase = true;\n\t }\n\t }\n\t}\n\tBuffer.byteLength = byteLength;\n\n\tfunction slowToString (encoding, start, end) {\n\t let loweredCase = false;\n\n\t // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n\t // property of a typed array.\n\n\t // This behaves neither like String nor Uint8Array in that we set start/end\n\t // to their upper/lower bounds if the value passed is out of range.\n\t // undefined is handled specially as per ECMA-262 6th Edition,\n\t // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n\t if (start === undefined || start < 0) {\n\t start = 0;\n\t }\n\t // Return early if start > this.length. Done here to prevent potential uint32\n\t // coercion fail below.\n\t if (start > this.length) {\n\t return ''\n\t }\n\n\t if (end === undefined || end > this.length) {\n\t end = this.length;\n\t }\n\n\t if (end <= 0) {\n\t return ''\n\t }\n\n\t // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n\t end >>>= 0;\n\t start >>>= 0;\n\n\t if (end <= start) {\n\t return ''\n\t }\n\n\t if (!encoding) encoding = 'utf8';\n\n\t while (true) {\n\t switch (encoding) {\n\t case 'hex':\n\t return hexSlice(this, start, end)\n\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8Slice(this, start, end)\n\n\t case 'ascii':\n\t return asciiSlice(this, start, end)\n\n\t case 'latin1':\n\t case 'binary':\n\t return latin1Slice(this, start, end)\n\n\t case 'base64':\n\t return base64Slice(this, start, end)\n\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return utf16leSlice(this, start, end)\n\n\t default:\n\t if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n\t encoding = (encoding + '').toLowerCase();\n\t loweredCase = true;\n\t }\n\t }\n\t}\n\n\t// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n\t// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n\t// reliably in a browserify context because there could be multiple different\n\t// copies of the 'buffer' package in use. This method works even for Buffer\n\t// instances that were created from another copy of the `buffer` package.\n\t// See: https://github.com/feross/buffer/issues/154\n\tBuffer.prototype._isBuffer = true;\n\n\tfunction swap (b, n, m) {\n\t const i = b[n];\n\t b[n] = b[m];\n\t b[m] = i;\n\t}\n\n\tBuffer.prototype.swap16 = function swap16 () {\n\t const len = this.length;\n\t if (len % 2 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 16-bits')\n\t }\n\t for (let i = 0; i < len; i += 2) {\n\t swap(this, i, i + 1);\n\t }\n\t return this\n\t};\n\n\tBuffer.prototype.swap32 = function swap32 () {\n\t const len = this.length;\n\t if (len % 4 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 32-bits')\n\t }\n\t for (let i = 0; i < len; i += 4) {\n\t swap(this, i, i + 3);\n\t swap(this, i + 1, i + 2);\n\t }\n\t return this\n\t};\n\n\tBuffer.prototype.swap64 = function swap64 () {\n\t const len = this.length;\n\t if (len % 8 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 64-bits')\n\t }\n\t for (let i = 0; i < len; i += 8) {\n\t swap(this, i, i + 7);\n\t swap(this, i + 1, i + 6);\n\t swap(this, i + 2, i + 5);\n\t swap(this, i + 3, i + 4);\n\t }\n\t return this\n\t};\n\n\tBuffer.prototype.toString = function toString () {\n\t const length = this.length;\n\t if (length === 0) return ''\n\t if (arguments.length === 0) return utf8Slice(this, 0, length)\n\t return slowToString.apply(this, arguments)\n\t};\n\n\tBuffer.prototype.toLocaleString = Buffer.prototype.toString;\n\n\tBuffer.prototype.equals = function equals (b) {\n\t if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n\t if (this === b) return true\n\t return Buffer.compare(this, b) === 0\n\t};\n\n\tBuffer.prototype.inspect = function inspect () {\n\t let str = '';\n\t const max = exports.INSPECT_MAX_BYTES;\n\t str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim();\n\t if (this.length > max) str += ' ... ';\n\t return ''\n\t};\n\tif (customInspectSymbol) {\n\t Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect;\n\t}\n\n\tBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n\t if (isInstance(target, GlobalUint8Array)) {\n\t target = Buffer.from(target, target.offset, target.byteLength);\n\t }\n\t if (!Buffer.isBuffer(target)) {\n\t throw new TypeError(\n\t 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n\t 'Received type ' + (typeof target)\n\t )\n\t }\n\n\t if (start === undefined) {\n\t start = 0;\n\t }\n\t if (end === undefined) {\n\t end = target ? target.length : 0;\n\t }\n\t if (thisStart === undefined) {\n\t thisStart = 0;\n\t }\n\t if (thisEnd === undefined) {\n\t thisEnd = this.length;\n\t }\n\n\t if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n\t throw new RangeError('out of range index')\n\t }\n\n\t if (thisStart >= thisEnd && start >= end) {\n\t return 0\n\t }\n\t if (thisStart >= thisEnd) {\n\t return -1\n\t }\n\t if (start >= end) {\n\t return 1\n\t }\n\n\t start >>>= 0;\n\t end >>>= 0;\n\t thisStart >>>= 0;\n\t thisEnd >>>= 0;\n\n\t if (this === target) return 0\n\n\t let x = thisEnd - thisStart;\n\t let y = end - start;\n\t const len = Math.min(x, y);\n\n\t const thisCopy = this.slice(thisStart, thisEnd);\n\t const targetCopy = target.slice(start, end);\n\n\t for (let i = 0; i < len; ++i) {\n\t if (thisCopy[i] !== targetCopy[i]) {\n\t x = thisCopy[i];\n\t y = targetCopy[i];\n\t break\n\t }\n\t }\n\n\t if (x < y) return -1\n\t if (y < x) return 1\n\t return 0\n\t};\n\n\t// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n\t// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n\t//\n\t// Arguments:\n\t// - buffer - a Buffer to search\n\t// - val - a string, Buffer, or number\n\t// - byteOffset - an index into `buffer`; will be clamped to an int32\n\t// - encoding - an optional encoding, relevant is val is a string\n\t// - dir - true for indexOf, false for lastIndexOf\n\tfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n\t // Empty buffer means no match\n\t if (buffer.length === 0) return -1\n\n\t // Normalize byteOffset\n\t if (typeof byteOffset === 'string') {\n\t encoding = byteOffset;\n\t byteOffset = 0;\n\t } else if (byteOffset > 0x7fffffff) {\n\t byteOffset = 0x7fffffff;\n\t } else if (byteOffset < -0x80000000) {\n\t byteOffset = -0x80000000;\n\t }\n\t byteOffset = +byteOffset; // Coerce to Number.\n\t if (numberIsNaN(byteOffset)) {\n\t // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n\t byteOffset = dir ? 0 : (buffer.length - 1);\n\t }\n\n\t // Normalize byteOffset: negative offsets start from the end of the buffer\n\t if (byteOffset < 0) byteOffset = buffer.length + byteOffset;\n\t if (byteOffset >= buffer.length) {\n\t if (dir) return -1\n\t else byteOffset = buffer.length - 1;\n\t } else if (byteOffset < 0) {\n\t if (dir) byteOffset = 0;\n\t else return -1\n\t }\n\n\t // Normalize val\n\t if (typeof val === 'string') {\n\t val = Buffer.from(val, encoding);\n\t }\n\n\t // Finally, search either indexOf (if dir is true) or lastIndexOf\n\t if (Buffer.isBuffer(val)) {\n\t // Special case: looking for empty string/buffer always fails\n\t if (val.length === 0) {\n\t return -1\n\t }\n\t return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n\t } else if (typeof val === 'number') {\n\t val = val & 0xFF; // Search for a byte value [0-255]\n\t if (typeof GlobalUint8Array.prototype.indexOf === 'function') {\n\t if (dir) {\n\t return GlobalUint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n\t } else {\n\t return GlobalUint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n\t }\n\t }\n\t return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n\t }\n\n\t throw new TypeError('val must be string, number or Buffer')\n\t}\n\n\tfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n\t let indexSize = 1;\n\t let arrLength = arr.length;\n\t let valLength = val.length;\n\n\t if (encoding !== undefined) {\n\t encoding = String(encoding).toLowerCase();\n\t if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n\t encoding === 'utf16le' || encoding === 'utf-16le') {\n\t if (arr.length < 2 || val.length < 2) {\n\t return -1\n\t }\n\t indexSize = 2;\n\t arrLength /= 2;\n\t valLength /= 2;\n\t byteOffset /= 2;\n\t }\n\t }\n\n\t function read (buf, i) {\n\t if (indexSize === 1) {\n\t return buf[i]\n\t } else {\n\t return buf.readUInt16BE(i * indexSize)\n\t }\n\t }\n\n\t let i;\n\t if (dir) {\n\t let foundIndex = -1;\n\t for (i = byteOffset; i < arrLength; i++) {\n\t if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n\t if (foundIndex === -1) foundIndex = i;\n\t if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n\t } else {\n\t if (foundIndex !== -1) i -= i - foundIndex;\n\t foundIndex = -1;\n\t }\n\t }\n\t } else {\n\t if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength;\n\t for (i = byteOffset; i >= 0; i--) {\n\t let found = true;\n\t for (let j = 0; j < valLength; j++) {\n\t if (read(arr, i + j) !== read(val, j)) {\n\t found = false;\n\t break\n\t }\n\t }\n\t if (found) return i\n\t }\n\t }\n\n\t return -1\n\t}\n\n\tBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n\t return this.indexOf(val, byteOffset, encoding) !== -1\n\t};\n\n\tBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n\t return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n\t};\n\n\tBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n\t return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n\t};\n\n\tfunction hexWrite (buf, string, offset, length) {\n\t offset = Number(offset) || 0;\n\t const remaining = buf.length - offset;\n\t if (!length) {\n\t length = remaining;\n\t } else {\n\t length = Number(length);\n\t if (length > remaining) {\n\t length = remaining;\n\t }\n\t }\n\n\t const strLen = string.length;\n\n\t if (length > strLen / 2) {\n\t length = strLen / 2;\n\t }\n\t let i;\n\t for (i = 0; i < length; ++i) {\n\t const parsed = parseInt(string.substr(i * 2, 2), 16);\n\t if (numberIsNaN(parsed)) return i\n\t buf[offset + i] = parsed;\n\t }\n\t return i\n\t}\n\n\tfunction utf8Write (buf, string, offset, length) {\n\t return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n\t}\n\n\tfunction asciiWrite (buf, string, offset, length) {\n\t return blitBuffer(asciiToBytes(string), buf, offset, length)\n\t}\n\n\tfunction base64Write (buf, string, offset, length) {\n\t return blitBuffer(base64ToBytes(string), buf, offset, length)\n\t}\n\n\tfunction ucs2Write (buf, string, offset, length) {\n\t return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n\t}\n\n\tBuffer.prototype.write = function write (string, offset, length, encoding) {\n\t // Buffer#write(string)\n\t if (offset === undefined) {\n\t encoding = 'utf8';\n\t length = this.length;\n\t offset = 0;\n\t // Buffer#write(string, encoding)\n\t } else if (length === undefined && typeof offset === 'string') {\n\t encoding = offset;\n\t length = this.length;\n\t offset = 0;\n\t // Buffer#write(string, offset[, length][, encoding])\n\t } else if (isFinite(offset)) {\n\t offset = offset >>> 0;\n\t if (isFinite(length)) {\n\t length = length >>> 0;\n\t if (encoding === undefined) encoding = 'utf8';\n\t } else {\n\t encoding = length;\n\t length = undefined;\n\t }\n\t } else {\n\t throw new Error(\n\t 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n\t )\n\t }\n\n\t const remaining = this.length - offset;\n\t if (length === undefined || length > remaining) length = remaining;\n\n\t if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n\t throw new RangeError('Attempt to write outside buffer bounds')\n\t }\n\n\t if (!encoding) encoding = 'utf8';\n\n\t let loweredCase = false;\n\t for (;;) {\n\t switch (encoding) {\n\t case 'hex':\n\t return hexWrite(this, string, offset, length)\n\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8Write(this, string, offset, length)\n\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t return asciiWrite(this, string, offset, length)\n\n\t case 'base64':\n\t // Warning: maxLength not taken into account in base64Write\n\t return base64Write(this, string, offset, length)\n\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return ucs2Write(this, string, offset, length)\n\n\t default:\n\t if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n\t encoding = ('' + encoding).toLowerCase();\n\t loweredCase = true;\n\t }\n\t }\n\t};\n\n\tBuffer.prototype.toJSON = function toJSON () {\n\t return {\n\t type: 'Buffer',\n\t data: Array.prototype.slice.call(this._arr || this, 0)\n\t }\n\t};\n\n\tfunction base64Slice (buf, start, end) {\n\t if (start === 0 && end === buf.length) {\n\t return base64.fromByteArray(buf)\n\t } else {\n\t return base64.fromByteArray(buf.slice(start, end))\n\t }\n\t}\n\n\tfunction utf8Slice (buf, start, end) {\n\t end = Math.min(buf.length, end);\n\t const res = [];\n\n\t let i = start;\n\t while (i < end) {\n\t const firstByte = buf[i];\n\t let codePoint = null;\n\t let bytesPerSequence = (firstByte > 0xEF)\n\t ? 4\n\t : (firstByte > 0xDF)\n\t ? 3\n\t : (firstByte > 0xBF)\n\t ? 2\n\t : 1;\n\n\t if (i + bytesPerSequence <= end) {\n\t let secondByte, thirdByte, fourthByte, tempCodePoint;\n\n\t switch (bytesPerSequence) {\n\t case 1:\n\t if (firstByte < 0x80) {\n\t codePoint = firstByte;\n\t }\n\t break\n\t case 2:\n\t secondByte = buf[i + 1];\n\t if ((secondByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F);\n\t if (tempCodePoint > 0x7F) {\n\t codePoint = tempCodePoint;\n\t }\n\t }\n\t break\n\t case 3:\n\t secondByte = buf[i + 1];\n\t thirdByte = buf[i + 2];\n\t if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F);\n\t if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n\t codePoint = tempCodePoint;\n\t }\n\t }\n\t break\n\t case 4:\n\t secondByte = buf[i + 1];\n\t thirdByte = buf[i + 2];\n\t fourthByte = buf[i + 3];\n\t if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F);\n\t if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n\t codePoint = tempCodePoint;\n\t }\n\t }\n\t }\n\t }\n\n\t if (codePoint === null) {\n\t // we did not generate a valid codePoint so insert a\n\t // replacement char (U+FFFD) and advance only 1 byte\n\t codePoint = 0xFFFD;\n\t bytesPerSequence = 1;\n\t } else if (codePoint > 0xFFFF) {\n\t // encode to utf16 (surrogate pair dance)\n\t codePoint -= 0x10000;\n\t res.push(codePoint >>> 10 & 0x3FF | 0xD800);\n\t codePoint = 0xDC00 | codePoint & 0x3FF;\n\t }\n\n\t res.push(codePoint);\n\t i += bytesPerSequence;\n\t }\n\n\t return decodeCodePointsArray(res)\n\t}\n\n\t// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n\t// the lowest limit is Chrome, with 0x10000 args.\n\t// We go 1 magnitude less, for safety\n\tconst MAX_ARGUMENTS_LENGTH = 0x1000;\n\n\tfunction decodeCodePointsArray (codePoints) {\n\t const len = codePoints.length;\n\t if (len <= MAX_ARGUMENTS_LENGTH) {\n\t return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n\t }\n\n\t // Decode in chunks to avoid \"call stack size exceeded\".\n\t let res = '';\n\t let i = 0;\n\t while (i < len) {\n\t res += String.fromCharCode.apply(\n\t String,\n\t codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n\t );\n\t }\n\t return res\n\t}\n\n\tfunction asciiSlice (buf, start, end) {\n\t let ret = '';\n\t end = Math.min(buf.length, end);\n\n\t for (let i = start; i < end; ++i) {\n\t ret += String.fromCharCode(buf[i] & 0x7F);\n\t }\n\t return ret\n\t}\n\n\tfunction latin1Slice (buf, start, end) {\n\t let ret = '';\n\t end = Math.min(buf.length, end);\n\n\t for (let i = start; i < end; ++i) {\n\t ret += String.fromCharCode(buf[i]);\n\t }\n\t return ret\n\t}\n\n\tfunction hexSlice (buf, start, end) {\n\t const len = buf.length;\n\n\t if (!start || start < 0) start = 0;\n\t if (!end || end < 0 || end > len) end = len;\n\n\t let out = '';\n\t for (let i = start; i < end; ++i) {\n\t out += hexSliceLookupTable[buf[i]];\n\t }\n\t return out\n\t}\n\n\tfunction utf16leSlice (buf, start, end) {\n\t const bytes = buf.slice(start, end);\n\t let res = '';\n\t // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n\t for (let i = 0; i < bytes.length - 1; i += 2) {\n\t res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256));\n\t }\n\t return res\n\t}\n\n\tBuffer.prototype.slice = function slice (start, end) {\n\t const len = this.length;\n\t start = ~~start;\n\t end = end === undefined ? len : ~~end;\n\n\t if (start < 0) {\n\t start += len;\n\t if (start < 0) start = 0;\n\t } else if (start > len) {\n\t start = len;\n\t }\n\n\t if (end < 0) {\n\t end += len;\n\t if (end < 0) end = 0;\n\t } else if (end > len) {\n\t end = len;\n\t }\n\n\t if (end < start) end = start;\n\n\t const newBuf = this.subarray(start, end);\n\t // Return an augmented `Uint8Array` instance\n\t Object.setPrototypeOf(newBuf, Buffer.prototype);\n\n\t return newBuf\n\t};\n\n\t/*\n\t * Need to make sure that buffer isn't trying to write out of bounds.\n\t */\n\tfunction checkOffset (offset, ext, length) {\n\t if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n\t if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n\t}\n\n\tBuffer.prototype.readUintLE =\n\tBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) checkOffset(offset, byteLength, this.length);\n\n\t let val = this[offset];\n\t let mul = 1;\n\t let i = 0;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t val += this[offset + i] * mul;\n\t }\n\n\t return val\n\t};\n\n\tBuffer.prototype.readUintBE =\n\tBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) {\n\t checkOffset(offset, byteLength, this.length);\n\t }\n\n\t let val = this[offset + --byteLength];\n\t let mul = 1;\n\t while (byteLength > 0 && (mul *= 0x100)) {\n\t val += this[offset + --byteLength] * mul;\n\t }\n\n\t return val\n\t};\n\n\tBuffer.prototype.readUint8 =\n\tBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 1, this.length);\n\t return this[offset]\n\t};\n\n\tBuffer.prototype.readUint16LE =\n\tBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t return this[offset] | (this[offset + 1] << 8)\n\t};\n\n\tBuffer.prototype.readUint16BE =\n\tBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t return (this[offset] << 8) | this[offset + 1]\n\t};\n\n\tBuffer.prototype.readUint32LE =\n\tBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return ((this[offset]) |\n\t (this[offset + 1] << 8) |\n\t (this[offset + 2] << 16)) +\n\t (this[offset + 3] * 0x1000000)\n\t};\n\n\tBuffer.prototype.readUint32BE =\n\tBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return (this[offset] * 0x1000000) +\n\t ((this[offset + 1] << 16) |\n\t (this[offset + 2] << 8) |\n\t this[offset + 3])\n\t};\n\n\tBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const lo = first +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 24;\n\n\t const hi = this[++offset] +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset] * 2 ** 16 +\n\t last * 2 ** 24;\n\n\t return BigInt(lo) + (BigInt(hi) << BigInt(32))\n\t});\n\n\tBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const hi = first * 2 ** 24 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset];\n\n\t const lo = this[++offset] * 2 ** 24 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t last;\n\n\t return (BigInt(hi) << BigInt(32)) + BigInt(lo)\n\t});\n\n\tBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) checkOffset(offset, byteLength, this.length);\n\n\t let val = this[offset];\n\t let mul = 1;\n\t let i = 0;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t val += this[offset + i] * mul;\n\t }\n\t mul *= 0x80;\n\n\t if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n\n\t return val\n\t};\n\n\tBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) checkOffset(offset, byteLength, this.length);\n\n\t let i = byteLength;\n\t let mul = 1;\n\t let val = this[offset + --i];\n\t while (i > 0 && (mul *= 0x100)) {\n\t val += this[offset + --i] * mul;\n\t }\n\t mul *= 0x80;\n\n\t if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n\n\t return val\n\t};\n\n\tBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 1, this.length);\n\t if (!(this[offset] & 0x80)) return (this[offset])\n\t return ((0xff - this[offset] + 1) * -1)\n\t};\n\n\tBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t const val = this[offset] | (this[offset + 1] << 8);\n\t return (val & 0x8000) ? val | 0xFFFF0000 : val\n\t};\n\n\tBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t const val = this[offset + 1] | (this[offset] << 8);\n\t return (val & 0x8000) ? val | 0xFFFF0000 : val\n\t};\n\n\tBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return (this[offset]) |\n\t (this[offset + 1] << 8) |\n\t (this[offset + 2] << 16) |\n\t (this[offset + 3] << 24)\n\t};\n\n\tBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return (this[offset] << 24) |\n\t (this[offset + 1] << 16) |\n\t (this[offset + 2] << 8) |\n\t (this[offset + 3])\n\t};\n\n\tBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const val = this[offset + 4] +\n\t this[offset + 5] * 2 ** 8 +\n\t this[offset + 6] * 2 ** 16 +\n\t (last << 24); // Overflow\n\n\t return (BigInt(val) << BigInt(32)) +\n\t BigInt(first +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 24)\n\t});\n\n\tBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const val = (first << 24) + // Overflow\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset];\n\n\t return (BigInt(val) << BigInt(32)) +\n\t BigInt(this[++offset] * 2 ** 24 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t last)\n\t});\n\n\tBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\t return ieee754$1.read(this, offset, true, 23, 4)\n\t};\n\n\tBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\t return ieee754$1.read(this, offset, false, 23, 4)\n\t};\n\n\tBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 8, this.length);\n\t return ieee754$1.read(this, offset, true, 52, 8)\n\t};\n\n\tBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 8, this.length);\n\t return ieee754$1.read(this, offset, false, 52, 8)\n\t};\n\n\tfunction checkInt (buf, value, offset, ext, max, min) {\n\t if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n\t if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n\t if (offset + ext > buf.length) throw new RangeError('Index out of range')\n\t}\n\n\tBuffer.prototype.writeUintLE =\n\tBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) {\n\t const maxBytes = Math.pow(2, 8 * byteLength) - 1;\n\t checkInt(this, value, offset, byteLength, maxBytes, 0);\n\t }\n\n\t let mul = 1;\n\t let i = 0;\n\t this[offset] = value & 0xFF;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t this[offset + i] = (value / mul) & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeUintBE =\n\tBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) {\n\t const maxBytes = Math.pow(2, 8 * byteLength) - 1;\n\t checkInt(this, value, offset, byteLength, maxBytes, 0);\n\t }\n\n\t let i = byteLength - 1;\n\t let mul = 1;\n\t this[offset + i] = value & 0xFF;\n\t while (--i >= 0 && (mul *= 0x100)) {\n\t this[offset + i] = (value / mul) & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeUint8 =\n\tBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0);\n\t this[offset] = (value & 0xff);\n\t return offset + 1\n\t};\n\n\tBuffer.prototype.writeUint16LE =\n\tBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n\t this[offset] = (value & 0xff);\n\t this[offset + 1] = (value >>> 8);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeUint16BE =\n\tBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n\t this[offset] = (value >>> 8);\n\t this[offset + 1] = (value & 0xff);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeUint32LE =\n\tBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n\t this[offset + 3] = (value >>> 24);\n\t this[offset + 2] = (value >>> 16);\n\t this[offset + 1] = (value >>> 8);\n\t this[offset] = (value & 0xff);\n\t return offset + 4\n\t};\n\n\tBuffer.prototype.writeUint32BE =\n\tBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n\t this[offset] = (value >>> 24);\n\t this[offset + 1] = (value >>> 16);\n\t this[offset + 2] = (value >>> 8);\n\t this[offset + 3] = (value & 0xff);\n\t return offset + 4\n\t};\n\n\tfunction wrtBigUInt64LE (buf, value, offset, min, max) {\n\t checkIntBI(value, min, max, buf, offset, 7);\n\n\t let lo = Number(value & BigInt(0xffffffff));\n\t buf[offset++] = lo;\n\t lo = lo >> 8;\n\t buf[offset++] = lo;\n\t lo = lo >> 8;\n\t buf[offset++] = lo;\n\t lo = lo >> 8;\n\t buf[offset++] = lo;\n\t let hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n\t buf[offset++] = hi;\n\t hi = hi >> 8;\n\t buf[offset++] = hi;\n\t hi = hi >> 8;\n\t buf[offset++] = hi;\n\t hi = hi >> 8;\n\t buf[offset++] = hi;\n\t return offset\n\t}\n\n\tfunction wrtBigUInt64BE (buf, value, offset, min, max) {\n\t checkIntBI(value, min, max, buf, offset, 7);\n\n\t let lo = Number(value & BigInt(0xffffffff));\n\t buf[offset + 7] = lo;\n\t lo = lo >> 8;\n\t buf[offset + 6] = lo;\n\t lo = lo >> 8;\n\t buf[offset + 5] = lo;\n\t lo = lo >> 8;\n\t buf[offset + 4] = lo;\n\t let hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n\t buf[offset + 3] = hi;\n\t hi = hi >> 8;\n\t buf[offset + 2] = hi;\n\t hi = hi >> 8;\n\t buf[offset + 1] = hi;\n\t hi = hi >> 8;\n\t buf[offset] = hi;\n\t return offset + 8\n\t}\n\n\tBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE (value, offset = 0) {\n\t return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n\t});\n\n\tBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE (value, offset = 0) {\n\t return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n\t});\n\n\tBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t const limit = Math.pow(2, (8 * byteLength) - 1);\n\n\t checkInt(this, value, offset, byteLength, limit - 1, -limit);\n\t }\n\n\t let i = 0;\n\t let mul = 1;\n\t let sub = 0;\n\t this[offset] = value & 0xFF;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n\t sub = 1;\n\t }\n\t this[offset + i] = ((value / mul) >> 0) - sub & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t const limit = Math.pow(2, (8 * byteLength) - 1);\n\n\t checkInt(this, value, offset, byteLength, limit - 1, -limit);\n\t }\n\n\t let i = byteLength - 1;\n\t let mul = 1;\n\t let sub = 0;\n\t this[offset + i] = value & 0xFF;\n\t while (--i >= 0 && (mul *= 0x100)) {\n\t if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n\t sub = 1;\n\t }\n\t this[offset + i] = ((value / mul) >> 0) - sub & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80);\n\t if (value < 0) value = 0xff + value + 1;\n\t this[offset] = (value & 0xff);\n\t return offset + 1\n\t};\n\n\tBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n\t this[offset] = (value & 0xff);\n\t this[offset + 1] = (value >>> 8);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n\t this[offset] = (value >>> 8);\n\t this[offset + 1] = (value & 0xff);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n\t this[offset] = (value & 0xff);\n\t this[offset + 1] = (value >>> 8);\n\t this[offset + 2] = (value >>> 16);\n\t this[offset + 3] = (value >>> 24);\n\t return offset + 4\n\t};\n\n\tBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n\t if (value < 0) value = 0xffffffff + value + 1;\n\t this[offset] = (value >>> 24);\n\t this[offset + 1] = (value >>> 16);\n\t this[offset + 2] = (value >>> 8);\n\t this[offset + 3] = (value & 0xff);\n\t return offset + 4\n\t};\n\n\tBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE (value, offset = 0) {\n\t return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n\t});\n\n\tBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE (value, offset = 0) {\n\t return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n\t});\n\n\tfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n\t if (offset + ext > buf.length) throw new RangeError('Index out of range')\n\t if (offset < 0) throw new RangeError('Index out of range')\n\t}\n\n\tfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t checkIEEE754(buf, value, offset, 4);\n\t }\n\t ieee754$1.write(buf, value, offset, littleEndian, 23, 4);\n\t return offset + 4\n\t}\n\n\tBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n\t return writeFloat(this, value, offset, true, noAssert)\n\t};\n\n\tBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n\t return writeFloat(this, value, offset, false, noAssert)\n\t};\n\n\tfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t checkIEEE754(buf, value, offset, 8);\n\t }\n\t ieee754$1.write(buf, value, offset, littleEndian, 52, 8);\n\t return offset + 8\n\t}\n\n\tBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n\t return writeDouble(this, value, offset, true, noAssert)\n\t};\n\n\tBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n\t return writeDouble(this, value, offset, false, noAssert)\n\t};\n\n\t// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\n\tBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n\t if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n\t if (!start) start = 0;\n\t if (!end && end !== 0) end = this.length;\n\t if (targetStart >= target.length) targetStart = target.length;\n\t if (!targetStart) targetStart = 0;\n\t if (end > 0 && end < start) end = start;\n\n\t // Copy 0 bytes; we're done\n\t if (end === start) return 0\n\t if (target.length === 0 || this.length === 0) return 0\n\n\t // Fatal error conditions\n\t if (targetStart < 0) {\n\t throw new RangeError('targetStart out of bounds')\n\t }\n\t if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n\t if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n\t // Are we oob?\n\t if (end > this.length) end = this.length;\n\t if (target.length - targetStart < end - start) {\n\t end = target.length - targetStart + start;\n\t }\n\n\t const len = end - start;\n\n\t if (this === target && typeof GlobalUint8Array.prototype.copyWithin === 'function') {\n\t // Use built-in when available, missing from IE11\n\t this.copyWithin(targetStart, start, end);\n\t } else {\n\t GlobalUint8Array.prototype.set.call(\n\t target,\n\t this.subarray(start, end),\n\t targetStart\n\t );\n\t }\n\n\t return len\n\t};\n\n\t// Usage:\n\t// buffer.fill(number[, offset[, end]])\n\t// buffer.fill(buffer[, offset[, end]])\n\t// buffer.fill(string[, offset[, end]][, encoding])\n\tBuffer.prototype.fill = function fill (val, start, end, encoding) {\n\t // Handle string cases:\n\t if (typeof val === 'string') {\n\t if (typeof start === 'string') {\n\t encoding = start;\n\t start = 0;\n\t end = this.length;\n\t } else if (typeof end === 'string') {\n\t encoding = end;\n\t end = this.length;\n\t }\n\t if (encoding !== undefined && typeof encoding !== 'string') {\n\t throw new TypeError('encoding must be a string')\n\t }\n\t if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n\t throw new TypeError('Unknown encoding: ' + encoding)\n\t }\n\t if (val.length === 1) {\n\t const code = val.charCodeAt(0);\n\t if ((encoding === 'utf8' && code < 128) ||\n\t encoding === 'latin1') {\n\t // Fast path: If `val` fits into a single byte, use that numeric value.\n\t val = code;\n\t }\n\t }\n\t } else if (typeof val === 'number') {\n\t val = val & 255;\n\t } else if (typeof val === 'boolean') {\n\t val = Number(val);\n\t }\n\n\t // Invalid ranges are not set to a default, so can range check early.\n\t if (start < 0 || this.length < start || this.length < end) {\n\t throw new RangeError('Out of range index')\n\t }\n\n\t if (end <= start) {\n\t return this\n\t }\n\n\t start = start >>> 0;\n\t end = end === undefined ? this.length : end >>> 0;\n\n\t if (!val) val = 0;\n\n\t let i;\n\t if (typeof val === 'number') {\n\t for (i = start; i < end; ++i) {\n\t this[i] = val;\n\t }\n\t } else {\n\t const bytes = Buffer.isBuffer(val)\n\t ? val\n\t : Buffer.from(val, encoding);\n\t const len = bytes.length;\n\t if (len === 0) {\n\t throw new TypeError('The value \"' + val +\n\t '\" is invalid for argument \"value\"')\n\t }\n\t for (i = 0; i < end - start; ++i) {\n\t this[i + start] = bytes[i % len];\n\t }\n\t }\n\n\t return this\n\t};\n\n\t// CUSTOM ERRORS\n\t// =============\n\n\t// Simplified versions from Node, changed for Buffer-only usage\n\tconst errors = {};\n\tfunction E (sym, getMessage, Base) {\n\t errors[sym] = class NodeError extends Base {\n\t constructor () {\n\t super();\n\n\t Object.defineProperty(this, 'message', {\n\t value: getMessage.apply(this, arguments),\n\t writable: true,\n\t configurable: true\n\t });\n\n\t // Add the error code to the name to include it in the stack trace.\n\t this.name = `${this.name} [${sym}]`;\n\t // Access the stack to generate the error message including the error code\n\t // from the name.\n\t this.stack; // eslint-disable-line no-unused-expressions\n\t // Reset the name to the actual name.\n\t delete this.name;\n\t }\n\n\t get code () {\n\t return sym\n\t }\n\n\t set code (value) {\n\t Object.defineProperty(this, 'code', {\n\t configurable: true,\n\t enumerable: true,\n\t value,\n\t writable: true\n\t });\n\t }\n\n\t toString () {\n\t return `${this.name} [${sym}]: ${this.message}`\n\t }\n\t };\n\t}\n\n\tE('ERR_BUFFER_OUT_OF_BOUNDS',\n\t function (name) {\n\t if (name) {\n\t return `${name} is outside of buffer bounds`\n\t }\n\n\t return 'Attempt to access memory outside buffer bounds'\n\t }, RangeError);\n\tE('ERR_INVALID_ARG_TYPE',\n\t function (name, actual) {\n\t return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`\n\t }, TypeError);\n\tE('ERR_OUT_OF_RANGE',\n\t function (str, range, input) {\n\t let msg = `The value of \"${str}\" is out of range.`;\n\t let received = input;\n\t if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n\t received = addNumericalSeparator(String(input));\n\t } else if (typeof input === 'bigint') {\n\t received = String(input);\n\t if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n\t received = addNumericalSeparator(received);\n\t }\n\t received += 'n';\n\t }\n\t msg += ` It must be ${range}. Received ${received}`;\n\t return msg\n\t }, RangeError);\n\n\tfunction addNumericalSeparator (val) {\n\t let res = '';\n\t let i = val.length;\n\t const start = val[0] === '-' ? 1 : 0;\n\t for (; i >= start + 4; i -= 3) {\n\t res = `_${val.slice(i - 3, i)}${res}`;\n\t }\n\t return `${val.slice(0, i)}${res}`\n\t}\n\n\t// CHECK FUNCTIONS\n\t// ===============\n\n\tfunction checkBounds (buf, offset, byteLength) {\n\t validateNumber(offset, 'offset');\n\t if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n\t boundsError(offset, buf.length - (byteLength + 1));\n\t }\n\t}\n\n\tfunction checkIntBI (value, min, max, buf, offset, byteLength) {\n\t if (value > max || value < min) {\n\t const n = typeof min === 'bigint' ? 'n' : '';\n\t let range;\n\t if (byteLength > 3) {\n\t if (min === 0 || min === BigInt(0)) {\n\t range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`;\n\t } else {\n\t range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` +\n\t `${(byteLength + 1) * 8 - 1}${n}`;\n\t }\n\t } else {\n\t range = `>= ${min}${n} and <= ${max}${n}`;\n\t }\n\t throw new errors.ERR_OUT_OF_RANGE('value', range, value)\n\t }\n\t checkBounds(buf, offset, byteLength);\n\t}\n\n\tfunction validateNumber (value, name) {\n\t if (typeof value !== 'number') {\n\t throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value)\n\t }\n\t}\n\n\tfunction boundsError (value, length, type) {\n\t if (Math.floor(value) !== value) {\n\t validateNumber(value, type);\n\t throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value)\n\t }\n\n\t if (length < 0) {\n\t throw new errors.ERR_BUFFER_OUT_OF_BOUNDS()\n\t }\n\n\t throw new errors.ERR_OUT_OF_RANGE(type || 'offset',\n\t `>= ${type ? 1 : 0} and <= ${length}`,\n\t value)\n\t}\n\n\t// HELPER FUNCTIONS\n\t// ================\n\n\tconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g;\n\n\tfunction base64clean (str) {\n\t // Node takes equal signs as end of the Base64 encoding\n\t str = str.split('=')[0];\n\t // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n\t str = str.trim().replace(INVALID_BASE64_RE, '');\n\t // Node converts strings with length < 2 to ''\n\t if (str.length < 2) return ''\n\t // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n\t while (str.length % 4 !== 0) {\n\t str = str + '=';\n\t }\n\t return str\n\t}\n\n\tfunction utf8ToBytes (string, units) {\n\t units = units || Infinity;\n\t let codePoint;\n\t const length = string.length;\n\t let leadSurrogate = null;\n\t const bytes = [];\n\n\t for (let i = 0; i < length; ++i) {\n\t codePoint = string.charCodeAt(i);\n\n\t // is surrogate component\n\t if (codePoint > 0xD7FF && codePoint < 0xE000) {\n\t // last char was a lead\n\t if (!leadSurrogate) {\n\t // no lead yet\n\t if (codePoint > 0xDBFF) {\n\t // unexpected trail\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t continue\n\t } else if (i + 1 === length) {\n\t // unpaired lead\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t continue\n\t }\n\n\t // valid lead\n\t leadSurrogate = codePoint;\n\n\t continue\n\t }\n\n\t // 2 leads in a row\n\t if (codePoint < 0xDC00) {\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t leadSurrogate = codePoint;\n\t continue\n\t }\n\n\t // valid surrogate pair\n\t codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000;\n\t } else if (leadSurrogate) {\n\t // valid bmp char, but last char was a lead\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t }\n\n\t leadSurrogate = null;\n\n\t // encode utf8\n\t if (codePoint < 0x80) {\n\t if ((units -= 1) < 0) break\n\t bytes.push(codePoint);\n\t } else if (codePoint < 0x800) {\n\t if ((units -= 2) < 0) break\n\t bytes.push(\n\t codePoint >> 0x6 | 0xC0,\n\t codePoint & 0x3F | 0x80\n\t );\n\t } else if (codePoint < 0x10000) {\n\t if ((units -= 3) < 0) break\n\t bytes.push(\n\t codePoint >> 0xC | 0xE0,\n\t codePoint >> 0x6 & 0x3F | 0x80,\n\t codePoint & 0x3F | 0x80\n\t );\n\t } else if (codePoint < 0x110000) {\n\t if ((units -= 4) < 0) break\n\t bytes.push(\n\t codePoint >> 0x12 | 0xF0,\n\t codePoint >> 0xC & 0x3F | 0x80,\n\t codePoint >> 0x6 & 0x3F | 0x80,\n\t codePoint & 0x3F | 0x80\n\t );\n\t } else {\n\t throw new Error('Invalid code point')\n\t }\n\t }\n\n\t return bytes\n\t}\n\n\tfunction asciiToBytes (str) {\n\t const byteArray = [];\n\t for (let i = 0; i < str.length; ++i) {\n\t // Node's code seems to be doing this and not & 0x7F..\n\t byteArray.push(str.charCodeAt(i) & 0xFF);\n\t }\n\t return byteArray\n\t}\n\n\tfunction utf16leToBytes (str, units) {\n\t let c, hi, lo;\n\t const byteArray = [];\n\t for (let i = 0; i < str.length; ++i) {\n\t if ((units -= 2) < 0) break\n\n\t c = str.charCodeAt(i);\n\t hi = c >> 8;\n\t lo = c % 256;\n\t byteArray.push(lo);\n\t byteArray.push(hi);\n\t }\n\n\t return byteArray\n\t}\n\n\tfunction base64ToBytes (str) {\n\t return base64.toByteArray(base64clean(str))\n\t}\n\n\tfunction blitBuffer (src, dst, offset, length) {\n\t let i;\n\t for (i = 0; i < length; ++i) {\n\t if ((i + offset >= dst.length) || (i >= src.length)) break\n\t dst[i + offset] = src[i];\n\t }\n\t return i\n\t}\n\n\t// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n\t// the `instanceof` check but they should be treated as of that type.\n\t// See: https://github.com/feross/buffer/issues/166\n\tfunction isInstance (obj, type) {\n\t return obj instanceof type ||\n\t (obj != null && obj.constructor != null && obj.constructor.name != null &&\n\t obj.constructor.name === type.name)\n\t}\n\tfunction numberIsNaN (obj) {\n\t // For IE11 support\n\t return obj !== obj // eslint-disable-line no-self-compare\n\t}\n\n\t// Create lookup table for `toString('hex')`\n\t// See: https://github.com/feross/buffer/issues/219\n\tconst hexSliceLookupTable = (function () {\n\t const alphabet = '0123456789abcdef';\n\t const table = new Array(256);\n\t for (let i = 0; i < 16; ++i) {\n\t const i16 = i * 16;\n\t for (let j = 0; j < 16; ++j) {\n\t table[i16 + j] = alphabet[i] + alphabet[j];\n\t }\n\t }\n\t return table\n\t})();\n\n\t// Return not function with Error if BigInt not supported\n\tfunction defineBigIntMethod (fn) {\n\t return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn\n\t}\n\n\tfunction BufferBigIntNotDefined () {\n\t throw new Error('BigInt not supported')\n\t} \n} (buffer));\n\nconst Buffer = buffer.Buffer;\n\nexports.Blob = buffer.Blob;\nexports.BlobOptions = buffer.BlobOptions;\nexports.Buffer = buffer.Buffer;\nexports.File = buffer.File;\nexports.FileOptions = buffer.FileOptions;\nexports.INSPECT_MAX_BYTES = buffer.INSPECT_MAX_BYTES;\nexports.SlowBuffer = buffer.SlowBuffer;\nexports.TranscodeEncoding = buffer.TranscodeEncoding;\nexports.atob = buffer.atob;\nexports.btoa = buffer.btoa;\nexports.constants = buffer.constants;\nexports.default = Buffer;\nexports.isAscii = buffer.isAscii;\nexports.isUtf8 = buffer.isUtf8;\nexports.kMaxLength = buffer.kMaxLength;\nexports.kStringMaxLength = buffer.kStringMaxLength;\nexports.resolveObjectURL = buffer.resolveObjectURL;\nexports.transcode = buffer.transcode;\n//# sourceMappingURL=index.cjs.map\n","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict'\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nvar MAX_BYTES = 65536\n\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nvar MAX_UINT32 = 4294967295\n\nfunction oldBrowser () {\n throw new Error('Secure random number generation is not supported by this browser.\\nUse Chrome, Firefox or Internet Explorer 11')\n}\n\nvar Buffer = require('safe-buffer').Buffer\nvar crypto = global.crypto || global.msCrypto\n\nif (crypto && crypto.getRandomValues) {\n module.exports = randomBytes\n} else {\n module.exports = oldBrowser\n}\n\nfunction randomBytes (size, cb) {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n\n var bytes = Buffer.allocUnsafe(size)\n\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (var generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n\n if (typeof cb === 'function') {\n return process.nextTick(function () {\n cb(null, bytes)\n })\n }\n\n return bytes\n}\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","module.exports = require('events').EventEmitter;\n","'use strict';\n\n/** @type {import('./shams')} */\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\t/** @type {{ [k in symbol]?: unknown }} */\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (var _ in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\t// eslint-disable-next-line no-extra-parens\n\t\tvar descriptor = /** @type {PropertyDescriptor} */ (Object.getOwnPropertyDescriptor(obj, sym));\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Object;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Error;\n","'use strict';\n\n/** @type {import('./eval')} */\nmodule.exports = EvalError;\n","'use strict';\n\n/** @type {import('./range')} */\nmodule.exports = RangeError;\n","'use strict';\n\n/** @type {import('./ref')} */\nmodule.exports = ReferenceError;\n","'use strict';\n\n/** @type {import('./syntax')} */\nmodule.exports = SyntaxError;\n","'use strict';\n\n/** @type {import('./type')} */\nmodule.exports = TypeError;\n","'use strict';\n\n/** @type {import('./uri')} */\nmodule.exports = URIError;\n","'use strict';\n\n/** @type {import('./abs')} */\nmodule.exports = Math.abs;\n","'use strict';\n\n/** @type {import('./floor')} */\nmodule.exports = Math.floor;\n","'use strict';\n\n/** @type {import('./max')} */\nmodule.exports = Math.max;\n","'use strict';\n\n/** @type {import('./min')} */\nmodule.exports = Math.min;\n","'use strict';\n\n/** @type {import('./pow')} */\nmodule.exports = Math.pow;\n","'use strict';\n\n/** @type {import('./round')} */\nmodule.exports = Math.round;\n","'use strict';\n\n/** @type {import('./isNaN')} */\nmodule.exports = Number.isNaN || function isNaN(a) {\n\treturn a !== a;\n};\n","'use strict';\n\nvar $isNaN = require('./isNaN');\n\n/** @type {import('./sign')} */\nmodule.exports = function sign(number) {\n\tif ($isNaN(number) || number === 0) {\n\t\treturn number;\n\t}\n\treturn number < 0 ? -1 : +1;\n};\n","'use strict';\n\n/** @type {import('./gOPD')} */\nmodule.exports = Object.getOwnPropertyDescriptor;\n","'use strict';\n\n/** @type {import('.')} */\nvar $gOPD = require('./gOPD');\n\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict';\n\n/** @type {import('.')} */\nvar $defineProperty = Object.defineProperty || false;\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = false;\n\t}\n}\n\nmodule.exports = $defineProperty;\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\n/** @type {import('./Reflect.getPrototypeOf')} */\nmodule.exports = (typeof Reflect !== 'undefined' && Reflect.getPrototypeOf) || null;\n","'use strict';\n\nvar $Object = require('es-object-atoms');\n\n/** @type {import('./Object.getPrototypeOf')} */\nmodule.exports = $Object.getPrototypeOf || null;\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar toStr = Object.prototype.toString;\nvar max = Math.max;\nvar funcType = '[object Function]';\n\nvar concatty = function concatty(a, b) {\n var arr = [];\n\n for (var i = 0; i < a.length; i += 1) {\n arr[i] = a[i];\n }\n for (var j = 0; j < b.length; j += 1) {\n arr[j + a.length] = b[j];\n }\n\n return arr;\n};\n\nvar slicy = function slicy(arrLike, offset) {\n var arr = [];\n for (var i = offset || 0, j = 0; i < arrLike.length; i += 1, j += 1) {\n arr[j] = arrLike[i];\n }\n return arr;\n};\n\nvar joiny = function (arr, joiner) {\n var str = '';\n for (var i = 0; i < arr.length; i += 1) {\n str += arr[i];\n if (i + 1 < arr.length) {\n str += joiner;\n }\n }\n return str;\n};\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.apply(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slicy(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n concatty(args, arguments)\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n }\n return target.apply(\n that,\n concatty(args, arguments)\n );\n\n };\n\n var boundLength = max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs[i] = '$' + i;\n }\n\n bound = Function('binder', 'return function (' + joiny(boundArgs, ',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","'use strict';\n\n/** @type {import('./functionCall')} */\nmodule.exports = Function.prototype.call;\n","'use strict';\n\n/** @type {import('./functionApply')} */\nmodule.exports = Function.prototype.apply;\n","'use strict';\n\n/** @type {import('./reflectApply')} */\nmodule.exports = typeof Reflect !== 'undefined' && Reflect && Reflect.apply;\n","'use strict';\n\nvar bind = require('function-bind');\n\nvar $apply = require('./functionApply');\nvar $call = require('./functionCall');\nvar $reflectApply = require('./reflectApply');\n\n/** @type {import('./actualApply')} */\nmodule.exports = $reflectApply || bind.call($call, $apply);\n","'use strict';\n\nvar bind = require('function-bind');\nvar $TypeError = require('es-errors/type');\n\nvar $call = require('./functionCall');\nvar $actualApply = require('./actualApply');\n\n/** @type {(args: [Function, thisArg?: unknown, ...args: unknown[]]) => Function} TODO FIXME, find a way to use import('.') */\nmodule.exports = function callBindBasic(args) {\n\tif (args.length < 1 || typeof args[0] !== 'function') {\n\t\tthrow new $TypeError('a function is required');\n\t}\n\treturn $actualApply(bind, $call, args);\n};\n","'use strict';\n\nvar callBind = require('call-bind-apply-helpers');\nvar gOPD = require('gopd');\n\nvar hasProtoAccessor;\ntry {\n\t// eslint-disable-next-line no-extra-parens, no-proto\n\thasProtoAccessor = /** @type {{ __proto__?: typeof Array.prototype }} */ ([]).__proto__ === Array.prototype;\n} catch (e) {\n\tif (!e || typeof e !== 'object' || !('code' in e) || e.code !== 'ERR_PROTO_ACCESS') {\n\t\tthrow e;\n\t}\n}\n\n// eslint-disable-next-line no-extra-parens\nvar desc = !!hasProtoAccessor && gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));\n\nvar $Object = Object;\nvar $getPrototypeOf = $Object.getPrototypeOf;\n\n/** @type {import('./get')} */\nmodule.exports = desc && typeof desc.get === 'function'\n\t? callBind([desc.get])\n\t: typeof $getPrototypeOf === 'function'\n\t\t? /** @type {import('./get')} */ function getDunder(value) {\n\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\treturn $getPrototypeOf(value == null ? value : $Object(value));\n\t\t}\n\t\t: false;\n","'use strict';\n\nvar reflectGetProto = require('./Reflect.getPrototypeOf');\nvar originalGetProto = require('./Object.getPrototypeOf');\n\nvar getDunderProto = require('dunder-proto/get');\n\n/** @type {import('.')} */\nmodule.exports = reflectGetProto\n\t? function getProto(O) {\n\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\treturn reflectGetProto(O);\n\t}\n\t: originalGetProto\n\t\t? function getProto(O) {\n\t\t\tif (!O || (typeof O !== 'object' && typeof O !== 'function')) {\n\t\t\t\tthrow new TypeError('getProto: not an object');\n\t\t\t}\n\t\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\t\treturn originalGetProto(O);\n\t\t}\n\t\t: getDunderProto\n\t\t\t? function getProto(O) {\n\t\t\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\t\t\treturn getDunderProto(O);\n\t\t\t}\n\t\t\t: null;\n","'use strict';\n\nvar call = Function.prototype.call;\nvar $hasOwn = Object.prototype.hasOwnProperty;\nvar bind = require('function-bind');\n\n/** @type {import('.')} */\nmodule.exports = bind.call(call, $hasOwn);\n","'use strict';\n\nvar undefined;\n\nvar $Object = require('es-object-atoms');\n\nvar $Error = require('es-errors');\nvar $EvalError = require('es-errors/eval');\nvar $RangeError = require('es-errors/range');\nvar $ReferenceError = require('es-errors/ref');\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\nvar $URIError = require('es-errors/uri');\n\nvar abs = require('math-intrinsics/abs');\nvar floor = require('math-intrinsics/floor');\nvar max = require('math-intrinsics/max');\nvar min = require('math-intrinsics/min');\nvar pow = require('math-intrinsics/pow');\nvar round = require('math-intrinsics/round');\nvar sign = require('math-intrinsics/sign');\n\nvar $Function = Function;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = require('gopd');\nvar $defineProperty = require('es-define-property');\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\n\nvar getProto = require('get-proto');\nvar $ObjectGPO = require('get-proto/Object.getPrototypeOf');\nvar $ReflectGPO = require('get-proto/Reflect.getPrototypeOf');\n\nvar $apply = require('call-bind-apply-helpers/functionApply');\nvar $call = require('call-bind-apply-helpers/functionCall');\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' || !getProto ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t__proto__: null,\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols && getProto ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%BigInt64Array%': typeof BigInt64Array === 'undefined' ? undefined : BigInt64Array,\n\t'%BigUint64Array%': typeof BigUint64Array === 'undefined' ? undefined : BigUint64Array,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': $Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': $EvalError,\n\t'%Float16Array%': typeof Float16Array === 'undefined' ? undefined : Float16Array,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols && getProto ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': $Object,\n\t'%Object.getOwnPropertyDescriptor%': $gOPD,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': $RangeError,\n\t'%ReferenceError%': $ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols && getProto ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': $URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet,\n\n\t'%Function.prototype.call%': $call,\n\t'%Function.prototype.apply%': $apply,\n\t'%Object.defineProperty%': $defineProperty,\n\t'%Object.getPrototypeOf%': $ObjectGPO,\n\t'%Math.abs%': abs,\n\t'%Math.floor%': floor,\n\t'%Math.max%': max,\n\t'%Math.min%': min,\n\t'%Math.pow%': pow,\n\t'%Math.round%': round,\n\t'%Math.sign%': sign,\n\t'%Reflect.getPrototypeOf%': $ReflectGPO\n};\n\nif (getProto) {\n\ttry {\n\t\tnull.error; // eslint-disable-line no-unused-expressions\n\t} catch (e) {\n\t\t// https://github.com/tc39/proposal-shadowrealm/pull/384#issuecomment-1364264229\n\t\tvar errorProto = getProto(getProto(e));\n\t\tINTRINSICS['%Error.prototype%'] = errorProto;\n\t}\n}\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen && getProto) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t__proto__: null,\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('hasown');\nvar $concat = bind.call($call, Array.prototype.concat);\nvar $spliceApply = bind.call($apply, Array.prototype.splice);\nvar $replace = bind.call($call, String.prototype.replace);\nvar $strSlice = bind.call($call, String.prototype.slice);\nvar $exec = bind.call($call, RegExp.prototype.exec);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tif ($exec(/^%?[^%]*%?$/, name) === null) {\n\t\tthrow new $SyntaxError('`%` may not be present anywhere but at the beginning and end of the intrinsic name');\n\t}\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBindBasic = require('call-bind-apply-helpers');\n\n/** @type {(thisArg: string, searchString: string, position?: number) => number} */\nvar $indexOf = callBindBasic([GetIntrinsic('%String.prototype.indexOf%')]);\n\n/** @type {import('.')} */\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\t/* eslint no-extra-parens: 0 */\n\n\tvar intrinsic = /** @type {(this: unknown, ...args: unknown[]) => unknown} */ (GetIntrinsic(name, !!allowMissing));\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBindBasic(/** @type {const} */ ([intrinsic]));\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bound');\n\nvar $toString = callBound('Object.prototype.toString');\n\n/** @type {import('.')} */\nvar isStandardArguments = function isArguments(value) {\n\tif (\n\t\thasToStringTag\n\t\t&& value\n\t\t&& typeof value === 'object'\n\t\t&& Symbol.toStringTag in value\n\t) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\n/** @type {import('.')} */\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null\n\t\t&& typeof value === 'object'\n\t\t&& 'length' in value\n\t\t&& typeof value.length === 'number'\n\t\t&& value.length >= 0\n\t\t&& $toString(value) !== '[object Array]'\n\t\t&& 'callee' in value\n\t\t&& $toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\n// @ts-expect-error TODO make this not error\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\n/** @type {import('.')} */\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n","'use strict';\n\nvar callBound = require('call-bound');\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar hasOwn = require('hasown');\nvar gOPD = require('gopd');\n\n/** @type {import('.')} */\nvar fn;\n\nif (hasToStringTag) {\n\t/** @type {(receiver: ThisParameterType, ...args: Parameters) => ReturnType} */\n\tvar $exec = callBound('RegExp.prototype.exec');\n\t/** @type {object} */\n\tvar isRegexMarker = {};\n\n\tvar throwRegexMarker = function () {\n\t\tthrow isRegexMarker;\n\t};\n\t/** @type {{ toString(): never, valueOf(): never, [Symbol.toPrimitive]?(): never }} */\n\tvar badStringifier = {\n\t\ttoString: throwRegexMarker,\n\t\tvalueOf: throwRegexMarker\n\t};\n\n\tif (typeof Symbol.toPrimitive === 'symbol') {\n\t\tbadStringifier[Symbol.toPrimitive] = throwRegexMarker;\n\t}\n\n\t/** @type {import('.')} */\n\t// @ts-expect-error TS can't figure out that the $exec call always throws\n\t// eslint-disable-next-line consistent-return\n\tfn = function isRegex(value) {\n\t\tif (!value || typeof value !== 'object') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// eslint-disable-next-line no-extra-parens\n\t\tvar descriptor = /** @type {NonNullable} */ (gOPD)(/** @type {{ lastIndex?: unknown }} */ (value), 'lastIndex');\n\t\tvar hasLastIndexDataProperty = descriptor && hasOwn(descriptor, 'value');\n\t\tif (!hasLastIndexDataProperty) {\n\t\t\treturn false;\n\t\t}\n\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-extra-parens\n\t\t\t$exec(value, /** @type {string} */ (/** @type {unknown} */ (badStringifier)));\n\t\t} catch (e) {\n\t\t\treturn e === isRegexMarker;\n\t\t}\n\t};\n} else {\n\t/** @type {(receiver: ThisParameterType, ...args: Parameters) => ReturnType} */\n\tvar $toString = callBound('Object.prototype.toString');\n\t/** @const @type {'[object RegExp]'} */\n\tvar regexClass = '[object RegExp]';\n\n\t/** @type {import('.')} */\n\tfn = function isRegex(value) {\n\t\t// In older browsers, typeof regex incorrectly returns 'function'\n\t\tif (!value || (typeof value !== 'object' && typeof value !== 'function')) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn $toString(value) === regexClass;\n\t};\n}\n\nmodule.exports = fn;\n","'use strict';\n\nvar callBound = require('call-bound');\nvar isRegex = require('is-regex');\n\nvar $exec = callBound('RegExp.prototype.exec');\nvar $TypeError = require('es-errors/type');\n\n/** @type {import('.')} */\nmodule.exports = function regexTester(regex) {\n\tif (!isRegex(regex)) {\n\t\tthrow new $TypeError('`regex` must be a RegExp');\n\t}\n\treturn function test(s) {\n\t\treturn $exec(regex, s) !== null;\n\t};\n};\n","'use strict';\n\nvar callBound = require('call-bound');\nvar safeRegexTest = require('safe-regex-test');\nvar isFnRegex = safeRegexTest(/^\\s*(?:function)?\\*/);\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = require('get-proto');\n\nvar toStr = callBound('Object.prototype.toString');\nvar fnToStr = callBound('Function.prototype.toString');\n\nvar getGeneratorFunc = function () { // eslint-disable-line consistent-return\n\tif (!hasToStringTag) {\n\t\treturn false;\n\t}\n\ttry {\n\t\treturn Function('return function*() {}')();\n\t} catch (e) {\n\t}\n};\n/** @type {undefined | false | null | GeneratorFunctionConstructor} */\nvar GeneratorFunction;\n\n/** @type {import('.')} */\nmodule.exports = function isGeneratorFunction(fn) {\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\tif (isFnRegex(fnToStr(fn))) {\n\t\treturn true;\n\t}\n\tif (!hasToStringTag) {\n\t\tvar str = toStr(fn);\n\t\treturn str === '[object GeneratorFunction]';\n\t}\n\tif (!getProto) {\n\t\treturn false;\n\t}\n\tif (typeof GeneratorFunction === 'undefined') {\n\t\tvar generatorFunc = getGeneratorFunc();\n\t\tGeneratorFunction = generatorFunc\n\t\t\t// eslint-disable-next-line no-extra-parens\n\t\t\t? /** @type {GeneratorFunctionConstructor} */ (getProto(generatorFunc))\n\t\t\t: false;\n\t}\n\treturn getProto(fn) === GeneratorFunction;\n};\n","'use strict';\n\nvar fnToStr = Function.prototype.toString;\nvar reflectApply = typeof Reflect === 'object' && Reflect !== null && Reflect.apply;\nvar badArrayLike;\nvar isCallableMarker;\nif (typeof reflectApply === 'function' && typeof Object.defineProperty === 'function') {\n\ttry {\n\t\tbadArrayLike = Object.defineProperty({}, 'length', {\n\t\t\tget: function () {\n\t\t\t\tthrow isCallableMarker;\n\t\t\t}\n\t\t});\n\t\tisCallableMarker = {};\n\t\t// eslint-disable-next-line no-throw-literal\n\t\treflectApply(function () { throw 42; }, null, badArrayLike);\n\t} catch (_) {\n\t\tif (_ !== isCallableMarker) {\n\t\t\treflectApply = null;\n\t\t}\n\t}\n} else {\n\treflectApply = null;\n}\n\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n\ttry {\n\t\tvar fnStr = fnToStr.call(value);\n\t\treturn constructorRegex.test(fnStr);\n\t} catch (e) {\n\t\treturn false; // not a function\n\t}\n};\n\nvar tryFunctionObject = function tryFunctionToStr(value) {\n\ttry {\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tfnToStr.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\nvar toStr = Object.prototype.toString;\nvar objectClass = '[object Object]';\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar ddaClass = '[object HTMLAllCollection]'; // IE 11\nvar ddaClass2 = '[object HTML document.all class]';\nvar ddaClass3 = '[object HTMLCollection]'; // IE 9-10\nvar hasToStringTag = typeof Symbol === 'function' && !!Symbol.toStringTag; // better: use `has-tostringtag`\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar isDDA = function isDocumentDotAll() { return false; };\nif (typeof document === 'object') {\n\t// Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n\tvar all = document.all;\n\tif (toStr.call(all) === toStr.call(document.all)) {\n\t\tisDDA = function isDocumentDotAll(value) {\n\t\t\t/* globals document: false */\n\t\t\t// in IE 6-8, typeof document.all is \"object\" and it's truthy\n\t\t\tif ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n\t\t\t\ttry {\n\t\t\t\t\tvar str = toStr.call(value);\n\t\t\t\t\treturn (\n\t\t\t\t\t\tstr === ddaClass\n\t\t\t\t\t\t|| str === ddaClass2\n\t\t\t\t\t\t|| str === ddaClass3 // opera 12.16\n\t\t\t\t\t\t|| str === objectClass // IE 6-8\n\t\t\t\t\t) && value('') == null; // eslint-disable-line eqeqeq\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\t}\n}\n\nmodule.exports = reflectApply\n\t? function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\ttry {\n\t\t\treflectApply(value, null, badArrayLike);\n\t\t} catch (e) {\n\t\t\tif (e !== isCallableMarker) { return false; }\n\t\t}\n\t\treturn !isES6ClassFn(value) && tryFunctionObject(value);\n\t}\n\t: function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\tif (hasToStringTag) { return tryFunctionObject(value); }\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tvar strClass = toStr.call(value);\n\t\tif (strClass !== fnClass && strClass !== genClass && !(/^\\[object HTML/).test(strClass)) { return false; }\n\t\treturn tryFunctionObject(value);\n\t};\n","'use strict';\n\nvar isCallable = require('is-callable');\n\nvar toStr = Object.prototype.toString;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\n/** @type {(arr: A, iterator: (this: This | void, value: A[number], index: number, arr: A) => void, receiver: This | undefined) => void} */\nvar forEachArray = function forEachArray(array, iterator, receiver) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (hasOwnProperty.call(array, i)) {\n if (receiver == null) {\n iterator(array[i], i, array);\n } else {\n iterator.call(receiver, array[i], i, array);\n }\n }\n }\n};\n\n/** @type {(string: S, iterator: (this: This | void, value: S[number], index: number, string: S) => void, receiver: This | undefined) => void} */\nvar forEachString = function forEachString(string, iterator, receiver) {\n for (var i = 0, len = string.length; i < len; i++) {\n // no such thing as a sparse string.\n if (receiver == null) {\n iterator(string.charAt(i), i, string);\n } else {\n iterator.call(receiver, string.charAt(i), i, string);\n }\n }\n};\n\n/** @type {(obj: O, iterator: (this: This | void, value: O[keyof O], index: keyof O, obj: O) => void, receiver: This | undefined) => void} */\nvar forEachObject = function forEachObject(object, iterator, receiver) {\n for (var k in object) {\n if (hasOwnProperty.call(object, k)) {\n if (receiver == null) {\n iterator(object[k], k, object);\n } else {\n iterator.call(receiver, object[k], k, object);\n }\n }\n }\n};\n\n/** @type {(x: unknown) => x is readonly unknown[]} */\nfunction isArray(x) {\n return toStr.call(x) === '[object Array]';\n}\n\n/** @type {import('.')._internal} */\nmodule.exports = function forEach(list, iterator, thisArg) {\n if (!isCallable(iterator)) {\n throw new TypeError('iterator must be a function');\n }\n\n var receiver;\n if (arguments.length >= 3) {\n receiver = thisArg;\n }\n\n if (isArray(list)) {\n forEachArray(list, iterator, receiver);\n } else if (typeof list === 'string') {\n forEachString(list, iterator, receiver);\n } else {\n forEachObject(list, iterator, receiver);\n }\n};\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = [\n\t'Float16Array',\n\t'Float32Array',\n\t'Float64Array',\n\t'Int8Array',\n\t'Int16Array',\n\t'Int32Array',\n\t'Uint8Array',\n\t'Uint8ClampedArray',\n\t'Uint16Array',\n\t'Uint32Array',\n\t'BigInt64Array',\n\t'BigUint64Array'\n];\n","'use strict';\n\nvar possibleNames = require('possible-typed-array-names');\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\n/** @type {import('.')} */\nmodule.exports = function availableTypedArrays() {\n\tvar /** @type {ReturnType} */ out = [];\n\tfor (var i = 0; i < possibleNames.length; i++) {\n\t\tif (typeof g[possibleNames[i]] === 'function') {\n\t\t\t// @ts-expect-error\n\t\t\tout[out.length] = possibleNames[i];\n\t\t}\n\t}\n\treturn out;\n};\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\n\nvar gopd = require('gopd');\n\n/** @type {import('.')} */\nmodule.exports = function defineDataProperty(\n\tobj,\n\tproperty,\n\tvalue\n) {\n\tif (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) {\n\t\tthrow new $TypeError('`obj` must be an object or a function`');\n\t}\n\tif (typeof property !== 'string' && typeof property !== 'symbol') {\n\t\tthrow new $TypeError('`property` must be a string or a symbol`');\n\t}\n\tif (arguments.length > 3 && typeof arguments[3] !== 'boolean' && arguments[3] !== null) {\n\t\tthrow new $TypeError('`nonEnumerable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 4 && typeof arguments[4] !== 'boolean' && arguments[4] !== null) {\n\t\tthrow new $TypeError('`nonWritable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 5 && typeof arguments[5] !== 'boolean' && arguments[5] !== null) {\n\t\tthrow new $TypeError('`nonConfigurable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 6 && typeof arguments[6] !== 'boolean') {\n\t\tthrow new $TypeError('`loose`, if provided, must be a boolean');\n\t}\n\n\tvar nonEnumerable = arguments.length > 3 ? arguments[3] : null;\n\tvar nonWritable = arguments.length > 4 ? arguments[4] : null;\n\tvar nonConfigurable = arguments.length > 5 ? arguments[5] : null;\n\tvar loose = arguments.length > 6 ? arguments[6] : false;\n\n\t/* @type {false | TypedPropertyDescriptor} */\n\tvar desc = !!gopd && gopd(obj, property);\n\n\tif ($defineProperty) {\n\t\t$defineProperty(obj, property, {\n\t\t\tconfigurable: nonConfigurable === null && desc ? desc.configurable : !nonConfigurable,\n\t\t\tenumerable: nonEnumerable === null && desc ? desc.enumerable : !nonEnumerable,\n\t\t\tvalue: value,\n\t\t\twritable: nonWritable === null && desc ? desc.writable : !nonWritable\n\t\t});\n\t} else if (loose || (!nonEnumerable && !nonWritable && !nonConfigurable)) {\n\t\t// must fall back to [[Set]], and was not explicitly asked to make non-enumerable, non-writable, or non-configurable\n\t\tobj[property] = value; // eslint-disable-line no-param-reassign\n\t} else {\n\t\tthrow new $SyntaxError('This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.');\n\t}\n};\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar hasPropertyDescriptors = function hasPropertyDescriptors() {\n\treturn !!$defineProperty;\n};\n\nhasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() {\n\t// node v0.6 has a bug where array lengths can be Set but not Defined\n\tif (!$defineProperty) {\n\t\treturn null;\n\t}\n\ttry {\n\t\treturn $defineProperty([], 'length', { value: 1 }).length !== 1;\n\t} catch (e) {\n\t\t// In Firefox 4-22, defining length on an array throws an exception.\n\t\treturn true;\n\t}\n};\n\nmodule.exports = hasPropertyDescriptors;\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\n\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tif (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n\t\tthrow new $TypeError('`length` must be a positive 32-bit integer');\n\t}\n\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\n\tvar functionLengthIsConfigurable = true;\n\tvar functionLengthIsWritable = true;\n\tif ('length' in fn && gOPD) {\n\t\tvar desc = gOPD(fn, 'length');\n\t\tif (desc && !desc.configurable) {\n\t\t\tfunctionLengthIsConfigurable = false;\n\t\t}\n\t\tif (desc && !desc.writable) {\n\t\t\tfunctionLengthIsWritable = false;\n\t\t}\n\t}\n\n\tif (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length);\n\t\t}\n\t}\n\treturn fn;\n};\n","'use strict';\n\nvar bind = require('function-bind');\nvar $apply = require('./functionApply');\nvar actualApply = require('./actualApply');\n\n/** @type {import('./applyBind')} */\nmodule.exports = function applyBind() {\n\treturn actualApply(bind, $apply, arguments);\n};\n","'use strict';\n\nvar setFunctionLength = require('set-function-length');\n\nvar $defineProperty = require('es-define-property');\n\nvar callBindBasic = require('call-bind-apply-helpers');\nvar applyBind = require('call-bind-apply-helpers/applyBind');\n\nmodule.exports = function callBind(originalFunction) {\n\tvar func = callBindBasic(arguments);\n\tvar adjustedLength = originalFunction.length - (arguments.length - 1);\n\treturn setFunctionLength(\n\t\tfunc,\n\t\t1 + (adjustedLength > 0 ? adjustedLength : 0),\n\t\ttrue\n\t);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","'use strict';\n\nvar forEach = require('for-each');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBind = require('call-bind');\nvar callBound = require('call-bound');\nvar gOPD = require('gopd');\nvar getProto = require('get-proto');\n\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $slice = callBound('String.prototype.slice');\n\n/** @type {(array: readonly T[], value: unknown) => number} */\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n\tfor (var i = 0; i < array.length; i += 1) {\n\t\tif (array[i] === value) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n};\n\n/** @typedef {import('./types').Getter} Getter */\n/** @type {import('./types').Cache} */\nvar cache = { __proto__: null };\nif (hasToStringTag && gOPD && getProto) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tif (Symbol.toStringTag in arr && getProto) {\n\t\t\tvar proto = getProto(arr);\n\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\tif (!descriptor && proto) {\n\t\t\t\tvar superProto = getProto(proto);\n\t\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t}\n\t\t\t// @ts-expect-error TODO: fix\n\t\t\tcache['$' + typedArray] = callBind(descriptor.get);\n\t\t}\n\t});\n} else {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tvar fn = arr.slice || arr.set;\n\t\tif (fn) {\n\t\t\tcache[\n\t\t\t\t/** @type {`$${import('.').TypedArrayName}`} */ ('$' + typedArray)\n\t\t\t] = /** @type {import('./types').BoundSlice | import('./types').BoundSet} */ (\n\t\t\t\t// @ts-expect-error TODO FIXME\n\t\t\t\tcallBind(fn)\n\t\t\t);\n\t\t}\n\t});\n}\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t/** @type {Record<`\\$${import('.').TypedArrayName}`, Getter>} */ (cache),\n\t\t/** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */\n\t\tfunction (getter, typedArray) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t\t// @ts-expect-error a throw is fine here\n\t\t\t\t\tif ('$' + getter(value) === typedArray) {\n\t\t\t\t\t\tfound = /** @type {import('.').TypedArrayName} */ ($slice(typedArray, 1));\n\t\t\t\t\t}\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar trySlices = function tryAllSlices(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t/** @type {Record<`\\$${import('.').TypedArrayName}`, Getter>} */(cache),\n\t\t/** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */ function (getter, name) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t\t// @ts-expect-error a throw is fine here\n\t\t\t\t\tgetter(value);\n\t\t\t\t\tfound = /** @type {import('.').TypedArrayName} */ ($slice(name, 1));\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {import('.')} */\nmodule.exports = function whichTypedArray(value) {\n\tif (!value || typeof value !== 'object') { return false; }\n\tif (!hasToStringTag) {\n\t\t/** @type {string} */\n\t\tvar tag = $slice($toString(value), 8, -1);\n\t\tif ($indexOf(typedArrays, tag) > -1) {\n\t\t\treturn tag;\n\t\t}\n\t\tif (tag !== 'Object') {\n\t\t\treturn false;\n\t\t}\n\t\t// node < 0.6 hits here on real Typed Arrays\n\t\treturn trySlices(value);\n\t}\n\tif (!gOPD) { return null; } // unknown engine\n\treturn tryTypedArrays(value);\n};\n","'use strict';\n\nvar whichTypedArray = require('which-typed-array');\n\n/** @type {import('.')} */\nmodule.exports = function isTypedArray(value) {\n\treturn !!whichTypedArray(value);\n};\n","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\n\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\n\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\n\nvar ObjectToString = uncurryThis(Object.prototype.toString);\n\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\n\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\n\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\n\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch(e) {\n return false;\n }\n}\n\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n\treturn (\n\t\t(\n\t\t\ttypeof Promise !== 'undefined' &&\n\t\t\tinput instanceof Promise\n\t\t) ||\n\t\t(\n\t\t\tinput !== null &&\n\t\t\ttypeof input === 'object' &&\n\t\t\ttypeof input.then === 'function' &&\n\t\t\ttypeof input.catch === 'function'\n\t\t)\n\t);\n}\nexports.isPromise = isPromise;\n\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n\n return (\n isTypedArray(value) ||\n isDataView(value)\n );\n}\nexports.isArrayBufferView = isArrayBufferView;\n\n\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\n\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\n\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\n\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\n\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\n\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\n\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\n\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\n\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\n\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\n\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\n\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = (\n typeof Map !== 'undefined' &&\n isMapToString(new Map())\n);\n\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n\n return isMapToString.working\n ? isMapToString(value)\n : value instanceof Map;\n}\nexports.isMap = isMap;\n\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = (\n typeof Set !== 'undefined' &&\n isSetToString(new Set())\n);\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n\n return isSetToString.working\n ? isSetToString(value)\n : value instanceof Set;\n}\nexports.isSet = isSet;\n\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = (\n typeof WeakMap !== 'undefined' &&\n isWeakMapToString(new WeakMap())\n);\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n\n return isWeakMapToString.working\n ? isWeakMapToString(value)\n : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\n\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = (\n typeof WeakSet !== 'undefined' &&\n isWeakSetToString(new WeakSet())\n);\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\n\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n isArrayBufferToString(new ArrayBuffer())\n);\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n\n return isArrayBufferToString.working\n ? isArrayBufferToString(value)\n : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n typeof DataView !== 'undefined' &&\n isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))\n);\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n\n return isDataViewToString.working\n ? isDataViewToString(value)\n : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n\n return isSharedArrayBufferToString.working\n ? isSharedArrayBufferToString(value)\n : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\n\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\n\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\n\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\n\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\n\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\n\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\n\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\n\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\n\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\n\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\n\nfunction isBoxedPrimitive(value) {\n return (\n isNumberObject(value) ||\n isStringObject(value) ||\n isBooleanObject(value) ||\n isBigIntObject(value) ||\n isSymbolObject(value)\n );\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\n\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (\n isArrayBuffer(value) ||\n isSharedArrayBuffer(value)\n );\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function(method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function() {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnvRegex = /^$/;\n\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&')\n .replace(/\\*/g, '.*')\n .replace(/,/g, '$|^')\n .toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function(set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').slice(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.slice(1, -1);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\n\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb.bind(null, null, ret)) },\n function(rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\nvar _require2 = require('util'),\n inspect = _require2.inspect;\nvar custom = inspect && inspect.custom || 'inspect';\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\nmodule.exports = /*#__PURE__*/function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) ret += s + p.data;\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n }\n\n // Consumes a specified amount of characters from the buffered data.\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread(_objectSpread({}, options), {}, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n return BufferList;\n}();","'use strict';\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n return this;\n}\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n return Math.floor(hwm);\n }\n\n // Default value\n return state.objectMode ? 16 : 16 * 1024;\n}\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nrequire('inherits')(Writable, Stream);\nfunction nop() {}\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'finish' (and potentially 'end')\n this.autoDestroy = !!options.autoDestroy;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex);\n\n // legacy.\n this.writable = true;\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END();\n // TODO: defer error events consistently everywhere, not just the cb\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n return true;\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n return ret;\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n if (entry === null) state.lastBufferedRequest = null;\n }\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\nWritable.prototype._writev = null;\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n errorOrDestroy(stream, err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n return need;\n}\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n};\n/**/\n\nmodule.exports = Duplex;\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\nrequire('inherits')(Duplex, Readable);\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n process.nextTick(onEndNT, this);\n}\nfunction onEndNT(self) {\n self.end();\n}\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\n/**/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n callback.apply(this, args);\n };\n}\nfunction noop() {}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n var writableEnded = stream._writableState && stream._writableState.finished;\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n var onclose = function onclose() {\n var err;\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\nmodule.exports = eos;","'use strict';\n\nvar _Object$setPrototypeO;\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar finished = require('./end-of-stream');\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n if (resolve !== null) {\n var data = iter[kStream].read();\n // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n next: function next() {\n var _this = this;\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n if (error !== null) {\n return Promise.reject(error);\n }\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n }\n\n // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n var lastPromise = this[kLastPromise];\n var promise;\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n promise = new Promise(this[kHandlePromise]);\n }\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject];\n // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n iterator[kError] = err;\n return;\n }\n var resolve = iterator[kLastResolve];\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\nmodule.exports = createReadableStreamAsyncIterator;","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nmodule.exports = Readable;\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\nvar debugUtil = require('util');\nvar debug;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/buffer_list');\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;\n\n// Lazy loaded to improve the startup performance.\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\nrequire('inherits')(Readable, Stream);\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'end' (and potentially 'finish')\n this.autoDestroy = !!options.autoDestroy;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options);\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex);\n\n // legacy\n this.readable = true;\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n Stream.call(this);\n}\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n return er;\n}\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder;\n // If setEncoding(null), decoder.encoding equals utf8\n this._readableState.encoding = this._readableState.decoder.encoding;\n\n // Iterate over current buffer to convert already stored Buffers:\n var p = this._readableState.buffer.head;\n var content = '';\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n this._readableState.buffer.clear();\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n};\n\n// Don't raise the hwm > 1GB\nvar MAX_HWM = 0x40000000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n }\n\n // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n return dest;\n};\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0;\n\n // Try start flowing on next tick if stream isn't explicitly paused\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true;\n\n // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n state.paused = false;\n return this;\n};\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n if (!state.reading) {\n stream.read(0);\n }\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n this._readableState.paused = true;\n return this;\n};\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null);\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n return this;\n};\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n return createReadableStreamAsyncIterator(this);\n };\n}\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n});\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length);\n\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n return from(Readable, iterable, opts);\n };\n}\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\nvar Duplex = require('./_stream_duplex');\nrequire('inherits')(Transform, Duplex);\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null)\n // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\nfunction prefinish() {\n var _this = this;\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null)\n // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\nvar Transform = require('./_stream_transform');\nrequire('inherits')(PassThrough, Transform);\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar eos;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true;\n\n // request.destroy just do .end - .abort is what we want\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\nfunction call(fn) {\n fn();\n}\nfunction pipe(from, to) {\n return from.pipe(to);\n}\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\nmodule.exports = pipeline;","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/lib/_stream_readable.js');\nStream.Writable = require('readable-stream/lib/_stream_writable.js');\nStream.Duplex = require('readable-stream/lib/_stream_duplex.js');\nStream.Transform = require('readable-stream/lib/_stream_transform.js');\nStream.PassThrough = require('readable-stream/lib/_stream_passthrough.js');\nStream.finished = require('readable-stream/lib/internal/streams/end-of-stream.js')\nStream.pipeline = require('readable-stream/lib/internal/streams/pipeline.js')\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n","'use strict'\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('stream').Transform\nvar inherits = require('inherits')\n\nfunction HashBase (blockSize) {\n Transform.call(this)\n\n this._block = Buffer.allocUnsafe(blockSize)\n this._blockSize = blockSize\n this._blockOffset = 0\n this._length = [0, 0, 0, 0]\n\n this._finalized = false\n}\n\ninherits(HashBase, Transform)\n\nHashBase.prototype._transform = function (chunk, encoding, callback) {\n var error = null\n try {\n this.update(chunk, encoding)\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nHashBase.prototype._flush = function (callback) {\n var error = null\n try {\n this.push(this.digest())\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nvar useUint8Array = typeof Uint8Array !== 'undefined'\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined' &&\n typeof Uint8Array !== 'undefined' &&\n ArrayBuffer.isView &&\n (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT)\n\nfunction toBuffer (data, encoding) {\n // No need to do anything for exact instance\n // This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n if (data instanceof Buffer) return data\n\n // Convert strings to Buffer\n if (typeof data === 'string') return Buffer.from(data, encoding)\n\n /*\n * Wrap any TypedArray instances and DataViews\n * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n */\n if (useArrayBuffer && ArrayBuffer.isView(data)) {\n if (data.byteLength === 0) return Buffer.alloc(0) // Bug in Node.js <6.3.1, which treats this as out-of-bounds\n var res = Buffer.from(data.buffer, data.byteOffset, data.byteLength)\n // Recheck result size, as offset/length doesn't work on Node.js <5.10\n // We just go to Uint8Array case if this fails\n if (res.byteLength === data.byteLength) return res\n }\n\n /*\n * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n * Doesn't make sense with other TypedArray instances\n */\n if (useUint8Array && data instanceof Uint8Array) return Buffer.from(data)\n\n /*\n * Old Buffer polyfill on an engine that doesn't have TypedArray support\n * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n * Convert to our current Buffer implementation\n */\n if (\n Buffer.isBuffer(data) &&\n data.constructor &&\n typeof data.constructor.isBuffer === 'function' &&\n data.constructor.isBuffer(data)\n ) {\n return Buffer.from(data)\n }\n\n throw new TypeError('The \"data\" argument must be of type string or an instance of Buffer, TypedArray, or DataView.')\n}\n\nHashBase.prototype.update = function (data, encoding) {\n if (this._finalized) throw new Error('Digest already called')\n\n data = toBuffer(data, encoding) // asserts correct input type\n\n // consume data\n var block = this._block\n var offset = 0\n while (this._blockOffset + data.length - offset >= this._blockSize) {\n for (var i = this._blockOffset; i < this._blockSize;) block[i++] = data[offset++]\n this._update()\n this._blockOffset = 0\n }\n while (offset < data.length) block[this._blockOffset++] = data[offset++]\n\n // update length\n for (var j = 0, carry = data.length * 8; carry > 0; ++j) {\n this._length[j] += carry\n carry = (this._length[j] / 0x0100000000) | 0\n if (carry > 0) this._length[j] -= 0x0100000000 * carry\n }\n\n return this\n}\n\nHashBase.prototype._update = function () {\n throw new Error('_update is not implemented')\n}\n\nHashBase.prototype.digest = function (encoding) {\n if (this._finalized) throw new Error('Digest already called')\n this._finalized = true\n\n var digest = this._digest()\n if (encoding !== undefined) digest = digest.toString(encoding)\n\n // reset state\n this._block.fill(0)\n this._blockOffset = 0\n for (var i = 0; i < 4; ++i) this._length[i] = 0\n\n return digest\n}\n\nHashBase.prototype._digest = function () {\n throw new Error('_digest is not implemented')\n}\n\nmodule.exports = HashBase\n","'use strict'\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\nvar Buffer = require('safe-buffer').Buffer\n\nvar ARRAY16 = new Array(16)\n\nfunction MD5 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n}\n\ninherits(MD5, HashBase)\n\nMD5.prototype._update = function () {\n var M = ARRAY16\n for (var i = 0; i < 16; ++i) M[i] = this._block.readInt32LE(i * 4)\n\n var a = this._a\n var b = this._b\n var c = this._c\n var d = this._d\n\n a = fnF(a, b, c, d, M[0], 0xd76aa478, 7)\n d = fnF(d, a, b, c, M[1], 0xe8c7b756, 12)\n c = fnF(c, d, a, b, M[2], 0x242070db, 17)\n b = fnF(b, c, d, a, M[3], 0xc1bdceee, 22)\n a = fnF(a, b, c, d, M[4], 0xf57c0faf, 7)\n d = fnF(d, a, b, c, M[5], 0x4787c62a, 12)\n c = fnF(c, d, a, b, M[6], 0xa8304613, 17)\n b = fnF(b, c, d, a, M[7], 0xfd469501, 22)\n a = fnF(a, b, c, d, M[8], 0x698098d8, 7)\n d = fnF(d, a, b, c, M[9], 0x8b44f7af, 12)\n c = fnF(c, d, a, b, M[10], 0xffff5bb1, 17)\n b = fnF(b, c, d, a, M[11], 0x895cd7be, 22)\n a = fnF(a, b, c, d, M[12], 0x6b901122, 7)\n d = fnF(d, a, b, c, M[13], 0xfd987193, 12)\n c = fnF(c, d, a, b, M[14], 0xa679438e, 17)\n b = fnF(b, c, d, a, M[15], 0x49b40821, 22)\n\n a = fnG(a, b, c, d, M[1], 0xf61e2562, 5)\n d = fnG(d, a, b, c, M[6], 0xc040b340, 9)\n c = fnG(c, d, a, b, M[11], 0x265e5a51, 14)\n b = fnG(b, c, d, a, M[0], 0xe9b6c7aa, 20)\n a = fnG(a, b, c, d, M[5], 0xd62f105d, 5)\n d = fnG(d, a, b, c, M[10], 0x02441453, 9)\n c = fnG(c, d, a, b, M[15], 0xd8a1e681, 14)\n b = fnG(b, c, d, a, M[4], 0xe7d3fbc8, 20)\n a = fnG(a, b, c, d, M[9], 0x21e1cde6, 5)\n d = fnG(d, a, b, c, M[14], 0xc33707d6, 9)\n c = fnG(c, d, a, b, M[3], 0xf4d50d87, 14)\n b = fnG(b, c, d, a, M[8], 0x455a14ed, 20)\n a = fnG(a, b, c, d, M[13], 0xa9e3e905, 5)\n d = fnG(d, a, b, c, M[2], 0xfcefa3f8, 9)\n c = fnG(c, d, a, b, M[7], 0x676f02d9, 14)\n b = fnG(b, c, d, a, M[12], 0x8d2a4c8a, 20)\n\n a = fnH(a, b, c, d, M[5], 0xfffa3942, 4)\n d = fnH(d, a, b, c, M[8], 0x8771f681, 11)\n c = fnH(c, d, a, b, M[11], 0x6d9d6122, 16)\n b = fnH(b, c, d, a, M[14], 0xfde5380c, 23)\n a = fnH(a, b, c, d, M[1], 0xa4beea44, 4)\n d = fnH(d, a, b, c, M[4], 0x4bdecfa9, 11)\n c = fnH(c, d, a, b, M[7], 0xf6bb4b60, 16)\n b = fnH(b, c, d, a, M[10], 0xbebfbc70, 23)\n a = fnH(a, b, c, d, M[13], 0x289b7ec6, 4)\n d = fnH(d, a, b, c, M[0], 0xeaa127fa, 11)\n c = fnH(c, d, a, b, M[3], 0xd4ef3085, 16)\n b = fnH(b, c, d, a, M[6], 0x04881d05, 23)\n a = fnH(a, b, c, d, M[9], 0xd9d4d039, 4)\n d = fnH(d, a, b, c, M[12], 0xe6db99e5, 11)\n c = fnH(c, d, a, b, M[15], 0x1fa27cf8, 16)\n b = fnH(b, c, d, a, M[2], 0xc4ac5665, 23)\n\n a = fnI(a, b, c, d, M[0], 0xf4292244, 6)\n d = fnI(d, a, b, c, M[7], 0x432aff97, 10)\n c = fnI(c, d, a, b, M[14], 0xab9423a7, 15)\n b = fnI(b, c, d, a, M[5], 0xfc93a039, 21)\n a = fnI(a, b, c, d, M[12], 0x655b59c3, 6)\n d = fnI(d, a, b, c, M[3], 0x8f0ccc92, 10)\n c = fnI(c, d, a, b, M[10], 0xffeff47d, 15)\n b = fnI(b, c, d, a, M[1], 0x85845dd1, 21)\n a = fnI(a, b, c, d, M[8], 0x6fa87e4f, 6)\n d = fnI(d, a, b, c, M[15], 0xfe2ce6e0, 10)\n c = fnI(c, d, a, b, M[6], 0xa3014314, 15)\n b = fnI(b, c, d, a, M[13], 0x4e0811a1, 21)\n a = fnI(a, b, c, d, M[4], 0xf7537e82, 6)\n d = fnI(d, a, b, c, M[11], 0xbd3af235, 10)\n c = fnI(c, d, a, b, M[2], 0x2ad7d2bb, 15)\n b = fnI(b, c, d, a, M[9], 0xeb86d391, 21)\n\n this._a = (this._a + a) | 0\n this._b = (this._b + b) | 0\n this._c = (this._c + c) | 0\n this._d = (this._d + d) | 0\n}\n\nMD5.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = Buffer.allocUnsafe(16)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fnF (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnG (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnH (a, b, c, d, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnI (a, b, c, d, m, k, s) {\n return (rotl((a + ((c ^ (b | (~d)))) + m + k) | 0, s) + b) | 0\n}\n\nmodule.exports = MD5\n","'use strict'\nvar Buffer = require('buffer').Buffer\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\n\nvar ARRAY16 = new Array(16)\n\nvar zl = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n]\n\nvar zr = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n]\n\nvar sl = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n]\n\nvar sr = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n]\n\nvar hl = [0x00000000, 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xa953fd4e]\nvar hr = [0x50a28be6, 0x5c4dd124, 0x6d703ef3, 0x7a6d76e9, 0x00000000]\n\nfunction RIPEMD160 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n this._e = 0xc3d2e1f0\n}\n\ninherits(RIPEMD160, HashBase)\n\nRIPEMD160.prototype._update = function () {\n var words = ARRAY16\n for (var j = 0; j < 16; ++j) words[j] = this._block.readInt32LE(j * 4)\n\n var al = this._a | 0\n var bl = this._b | 0\n var cl = this._c | 0\n var dl = this._d | 0\n var el = this._e | 0\n\n var ar = this._a | 0\n var br = this._b | 0\n var cr = this._c | 0\n var dr = this._d | 0\n var er = this._e | 0\n\n // computation\n for (var i = 0; i < 80; i += 1) {\n var tl\n var tr\n if (i < 16) {\n tl = fn1(al, bl, cl, dl, el, words[zl[i]], hl[0], sl[i])\n tr = fn5(ar, br, cr, dr, er, words[zr[i]], hr[0], sr[i])\n } else if (i < 32) {\n tl = fn2(al, bl, cl, dl, el, words[zl[i]], hl[1], sl[i])\n tr = fn4(ar, br, cr, dr, er, words[zr[i]], hr[1], sr[i])\n } else if (i < 48) {\n tl = fn3(al, bl, cl, dl, el, words[zl[i]], hl[2], sl[i])\n tr = fn3(ar, br, cr, dr, er, words[zr[i]], hr[2], sr[i])\n } else if (i < 64) {\n tl = fn4(al, bl, cl, dl, el, words[zl[i]], hl[3], sl[i])\n tr = fn2(ar, br, cr, dr, er, words[zr[i]], hr[3], sr[i])\n } else { // if (i<80) {\n tl = fn5(al, bl, cl, dl, el, words[zl[i]], hl[4], sl[i])\n tr = fn1(ar, br, cr, dr, er, words[zr[i]], hr[4], sr[i])\n }\n\n al = el\n el = dl\n dl = rotl(cl, 10)\n cl = bl\n bl = tl\n\n ar = er\n er = dr\n dr = rotl(cr, 10)\n cr = br\n br = tr\n }\n\n // update state\n var t = (this._b + cl + dr) | 0\n this._b = (this._c + dl + er) | 0\n this._c = (this._d + el + ar) | 0\n this._d = (this._e + al + br) | 0\n this._e = (this._a + bl + cr) | 0\n this._a = t\n}\n\nRIPEMD160.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = Buffer.alloc ? Buffer.alloc(20) : new Buffer(20)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n buffer.writeInt32LE(this._e, 16)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fn1 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn2 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn3 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b | (~c)) ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn4 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn5 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ (c | (~d))) + m + k) | 0, s) + e) | 0\n}\n\nmodule.exports = RIPEMD160\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","'use strict';\n\nvar $TypeError = require('es-errors/type');\n\nvar callBound = require('call-bound');\n\n/** @type {undefined | ((thisArg: import('.').TypedArray) => Buffer)} */\nvar $typedArrayBuffer = callBound('TypedArray.prototype.buffer', true);\n\nvar isTypedArray = require('is-typed-array');\n\n/** @type {import('.')} */\n// node <= 0.10, < 0.11.4 has a nonconfigurable own property instead of a prototype getter\nmodule.exports = $typedArrayBuffer || function typedArrayBuffer(x) {\n\tif (!isTypedArray(x)) {\n\t\tthrow new $TypeError('Not a Typed Array');\n\t}\n\treturn x.buffer;\n};\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar isArray = require('isarray');\nvar typedArrayBuffer = require('typed-array-buffer');\n\nvar isView = ArrayBuffer.isView || function isView(obj) {\n\ttry {\n\t\ttypedArrayBuffer(obj);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\n\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined'\n\t&& typeof Uint8Array !== 'undefined';\nvar useFromArrayBuffer = useArrayBuffer && (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT);\n\nmodule.exports = function toBuffer(data, encoding) {\n\t/*\n\t * No need to do anything for exact instance\n\t * This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n\t */\n\tif (data instanceof Buffer) {\n\t\treturn data;\n\t}\n\n\tif (typeof data === 'string') {\n\t\treturn Buffer.from(data, encoding);\n\t}\n\n\t/*\n\t * Wrap any TypedArray instances and DataViews\n\t * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n\t */\n\tif (useArrayBuffer && isView(data)) {\n\t\t// Bug in Node.js <6.3.1, which treats this as out-of-bounds\n\t\tif (data.byteLength === 0) {\n\t\t\treturn Buffer.alloc(0);\n\t\t}\n\n\t\t// When Buffer is based on Uint8Array, we can just construct it from ArrayBuffer\n\t\tif (useFromArrayBuffer) {\n\t\t\tvar res = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n\t\t\t/*\n\t\t\t * Recheck result size, as offset/length doesn't work on Node.js <5.10\n\t\t\t * We just go to Uint8Array case if this fails\n\t\t\t */\n\t\t\tif (res.byteLength === data.byteLength) {\n\t\t\t\treturn res;\n\t\t\t}\n\t\t}\n\n\t\t// Convert to Uint8Array bytes and then to Buffer\n\t\tvar uint8 = data instanceof Uint8Array ? data : new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n\t\tvar result = Buffer.from(uint8);\n\n\t\t/*\n\t\t * Let's recheck that conversion succeeded\n\t\t * We have .length but not .byteLength when useFromArrayBuffer is false\n\t\t */\n\t\tif (result.length === data.byteLength) {\n\t\t\treturn result;\n\t\t}\n\t}\n\n\t/*\n\t * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n\t * Doesn't make sense with other TypedArray instances\n\t */\n\tif (useUint8Array && data instanceof Uint8Array) {\n\t\treturn Buffer.from(data);\n\t}\n\n\tvar isArr = isArray(data);\n\tif (isArr) {\n\t\tfor (var i = 0; i < data.length; i += 1) {\n\t\t\tvar x = data[i];\n\t\t\tif (\n\t\t\t\ttypeof x !== 'number'\n\t\t\t\t|| x < 0\n\t\t\t\t|| x > 255\n\t\t\t\t|| ~~x !== x // NaN and integer check\n\t\t\t) {\n\t\t\t\tthrow new RangeError('Array items must be numbers in the range 0-255.');\n\t\t\t}\n\t\t}\n\t}\n\n\t/*\n\t * Old Buffer polyfill on an engine that doesn't have TypedArray support\n\t * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n\t * Convert to our current Buffer implementation\n\t */\n\tif (\n\t\tisArr || (\n\t\t\tBuffer.isBuffer(data)\n\t\t\t\t&& data.constructor\n\t\t\t\t&& typeof data.constructor.isBuffer === 'function'\n\t\t\t\t&& data.constructor.isBuffer(data)\n\t\t)\n\t) {\n\t\treturn Buffer.from(data);\n\t}\n\n\tthrow new TypeError('The \"data\" argument must be a string, an Array, a Buffer, a Uint8Array, or a DataView.');\n};\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar toBuffer = require('to-buffer');\n\n// prototype class for hash functions\nfunction Hash(blockSize, finalSize) {\n\tthis._block = Buffer.alloc(blockSize);\n\tthis._finalSize = finalSize;\n\tthis._blockSize = blockSize;\n\tthis._len = 0;\n}\n\nHash.prototype.update = function (data, enc) {\n\t/* eslint no-param-reassign: 0 */\n\tdata = toBuffer(data, enc || 'utf8');\n\n\tvar block = this._block;\n\tvar blockSize = this._blockSize;\n\tvar length = data.length;\n\tvar accum = this._len;\n\n\tfor (var offset = 0; offset < length;) {\n\t\tvar assigned = accum % blockSize;\n\t\tvar remainder = Math.min(length - offset, blockSize - assigned);\n\n\t\tfor (var i = 0; i < remainder; i++) {\n\t\t\tblock[assigned + i] = data[offset + i];\n\t\t}\n\n\t\taccum += remainder;\n\t\toffset += remainder;\n\n\t\tif ((accum % blockSize) === 0) {\n\t\t\tthis._update(block);\n\t\t}\n\t}\n\n\tthis._len += length;\n\treturn this;\n};\n\nHash.prototype.digest = function (enc) {\n\tvar rem = this._len % this._blockSize;\n\n\tthis._block[rem] = 0x80;\n\n\t/*\n\t * zero (rem + 1) trailing bits, where (rem + 1) is the smallest\n\t * non-negative solution to the equation (length + 1 + (rem + 1)) === finalSize mod blockSize\n\t */\n\tthis._block.fill(0, rem + 1);\n\n\tif (rem >= this._finalSize) {\n\t\tthis._update(this._block);\n\t\tthis._block.fill(0);\n\t}\n\n\tvar bits = this._len * 8;\n\n\t// uint32\n\tif (bits <= 0xffffffff) {\n\t\tthis._block.writeUInt32BE(bits, this._blockSize - 4);\n\n\t\t// uint64\n\t} else {\n\t\tvar lowBits = (bits & 0xffffffff) >>> 0;\n\t\tvar highBits = (bits - lowBits) / 0x100000000;\n\n\t\tthis._block.writeUInt32BE(highBits, this._blockSize - 8);\n\t\tthis._block.writeUInt32BE(lowBits, this._blockSize - 4);\n\t}\n\n\tthis._update(this._block);\n\tvar hash = this._hash();\n\n\treturn enc ? hash.toString(enc) : hash;\n};\n\nHash.prototype._update = function () {\n\tthrow new Error('_update must be implemented by subclass');\n};\n\nmodule.exports = Hash;\n","'use strict';\n\n/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-0, as defined\n * in FIPS PUB 180-1\n * This source code is derived from sha1.js of the same repository.\n * The difference between SHA-0 and SHA-1 is just a bitwise rotate left\n * operation was added.\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0\n];\n\nvar W = new Array(80);\n\nfunction Sha() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha, Hash);\n\nSha.prototype.init = function () {\n\tthis._a = 0x67452301;\n\tthis._b = 0xefcdab89;\n\tthis._c = 0x98badcfe;\n\tthis._d = 0x10325476;\n\tthis._e = 0xc3d2e1f0;\n\n\treturn this;\n};\n\nfunction rotl5(num) {\n\treturn (num << 5) | (num >>> 27);\n}\n\nfunction rotl30(num) {\n\treturn (num << 30) | (num >>> 2);\n}\n\nfunction ft(s, b, c, d) {\n\tif (s === 0) {\n\t\treturn (b & c) | (~b & d);\n\t}\n\tif (s === 2) {\n\t\treturn (b & c) | (b & d) | (c & d);\n\t}\n\treturn b ^ c ^ d;\n}\n\nSha.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar a = this._a | 0;\n\tvar b = this._b | 0;\n\tvar c = this._c | 0;\n\tvar d = this._d | 0;\n\tvar e = this._e | 0;\n\n\tfor (var i = 0; i < 16; ++i) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t}\n\tfor (; i < 80; ++i) {\n\t\tw[i] = w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16];\n\t}\n\n\tfor (var j = 0; j < 80; ++j) {\n\t\tvar s = ~~(j / 20);\n\t\tvar t = (rotl5(a) + ft(s, b, c, d) + e + w[j] + K[s]) | 0;\n\n\t\te = d;\n\t\td = c;\n\t\tc = rotl30(b);\n\t\tb = a;\n\t\ta = t;\n\t}\n\n\tthis._a = (a + this._a) | 0;\n\tthis._b = (b + this._b) | 0;\n\tthis._c = (c + this._c) | 0;\n\tthis._d = (d + this._d) | 0;\n\tthis._e = (e + this._e) | 0;\n};\n\nSha.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(20);\n\n\tH.writeInt32BE(this._a | 0, 0);\n\tH.writeInt32BE(this._b | 0, 4);\n\tH.writeInt32BE(this._c | 0, 8);\n\tH.writeInt32BE(this._d | 0, 12);\n\tH.writeInt32BE(this._e | 0, 16);\n\n\treturn H;\n};\n\nmodule.exports = Sha;\n","'use strict';\n\n/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined\n * in FIPS PUB 180-1\n * Version 2.1a Copyright Paul Johnston 2000 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0\n];\n\nvar W = new Array(80);\n\nfunction Sha1() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha1, Hash);\n\nSha1.prototype.init = function () {\n\tthis._a = 0x67452301;\n\tthis._b = 0xefcdab89;\n\tthis._c = 0x98badcfe;\n\tthis._d = 0x10325476;\n\tthis._e = 0xc3d2e1f0;\n\n\treturn this;\n};\n\nfunction rotl1(num) {\n\treturn (num << 1) | (num >>> 31);\n}\n\nfunction rotl5(num) {\n\treturn (num << 5) | (num >>> 27);\n}\n\nfunction rotl30(num) {\n\treturn (num << 30) | (num >>> 2);\n}\n\nfunction ft(s, b, c, d) {\n\tif (s === 0) {\n\t\treturn (b & c) | (~b & d);\n\t}\n\tif (s === 2) {\n\t\treturn (b & c) | (b & d) | (c & d);\n\t}\n\treturn b ^ c ^ d;\n}\n\nSha1.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar a = this._a | 0;\n\tvar b = this._b | 0;\n\tvar c = this._c | 0;\n\tvar d = this._d | 0;\n\tvar e = this._e | 0;\n\n\tfor (var i = 0; i < 16; ++i) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t}\n\tfor (; i < 80; ++i) {\n\t\tw[i] = rotl1(w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n\t}\n\n\tfor (var j = 0; j < 80; ++j) {\n\t\tvar s = ~~(j / 20);\n\t\tvar t = (rotl5(a) + ft(s, b, c, d) + e + w[j] + K[s]) | 0;\n\n\t\te = d;\n\t\td = c;\n\t\tc = rotl30(b);\n\t\tb = a;\n\t\ta = t;\n\t}\n\n\tthis._a = (a + this._a) | 0;\n\tthis._b = (b + this._b) | 0;\n\tthis._c = (c + this._c) | 0;\n\tthis._d = (d + this._d) | 0;\n\tthis._e = (e + this._e) | 0;\n};\n\nSha1.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(20);\n\n\tH.writeInt32BE(this._a | 0, 0);\n\tH.writeInt32BE(this._b | 0, 4);\n\tH.writeInt32BE(this._c | 0, 8);\n\tH.writeInt32BE(this._d | 0, 12);\n\tH.writeInt32BE(this._e | 0, 16);\n\n\treturn H;\n};\n\nmodule.exports = Sha1;\n","'use strict';\n\n/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x428A2F98,\n\t0x71374491,\n\t0xB5C0FBCF,\n\t0xE9B5DBA5,\n\t0x3956C25B,\n\t0x59F111F1,\n\t0x923F82A4,\n\t0xAB1C5ED5,\n\t0xD807AA98,\n\t0x12835B01,\n\t0x243185BE,\n\t0x550C7DC3,\n\t0x72BE5D74,\n\t0x80DEB1FE,\n\t0x9BDC06A7,\n\t0xC19BF174,\n\t0xE49B69C1,\n\t0xEFBE4786,\n\t0x0FC19DC6,\n\t0x240CA1CC,\n\t0x2DE92C6F,\n\t0x4A7484AA,\n\t0x5CB0A9DC,\n\t0x76F988DA,\n\t0x983E5152,\n\t0xA831C66D,\n\t0xB00327C8,\n\t0xBF597FC7,\n\t0xC6E00BF3,\n\t0xD5A79147,\n\t0x06CA6351,\n\t0x14292967,\n\t0x27B70A85,\n\t0x2E1B2138,\n\t0x4D2C6DFC,\n\t0x53380D13,\n\t0x650A7354,\n\t0x766A0ABB,\n\t0x81C2C92E,\n\t0x92722C85,\n\t0xA2BFE8A1,\n\t0xA81A664B,\n\t0xC24B8B70,\n\t0xC76C51A3,\n\t0xD192E819,\n\t0xD6990624,\n\t0xF40E3585,\n\t0x106AA070,\n\t0x19A4C116,\n\t0x1E376C08,\n\t0x2748774C,\n\t0x34B0BCB5,\n\t0x391C0CB3,\n\t0x4ED8AA4A,\n\t0x5B9CCA4F,\n\t0x682E6FF3,\n\t0x748F82EE,\n\t0x78A5636F,\n\t0x84C87814,\n\t0x8CC70208,\n\t0x90BEFFFA,\n\t0xA4506CEB,\n\t0xBEF9A3F7,\n\t0xC67178F2\n];\n\nvar W = new Array(64);\n\nfunction Sha256() {\n\tthis.init();\n\n\tthis._w = W; // new Array(64)\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha256, Hash);\n\nSha256.prototype.init = function () {\n\tthis._a = 0x6a09e667;\n\tthis._b = 0xbb67ae85;\n\tthis._c = 0x3c6ef372;\n\tthis._d = 0xa54ff53a;\n\tthis._e = 0x510e527f;\n\tthis._f = 0x9b05688c;\n\tthis._g = 0x1f83d9ab;\n\tthis._h = 0x5be0cd19;\n\n\treturn this;\n};\n\nfunction ch(x, y, z) {\n\treturn z ^ (x & (y ^ z));\n}\n\nfunction maj(x, y, z) {\n\treturn (x & y) | (z & (x | y));\n}\n\nfunction sigma0(x) {\n\treturn ((x >>> 2) | (x << 30)) ^ ((x >>> 13) | (x << 19)) ^ ((x >>> 22) | (x << 10));\n}\n\nfunction sigma1(x) {\n\treturn ((x >>> 6) | (x << 26)) ^ ((x >>> 11) | (x << 21)) ^ ((x >>> 25) | (x << 7));\n}\n\nfunction gamma0(x) {\n\treturn ((x >>> 7) | (x << 25)) ^ ((x >>> 18) | (x << 14)) ^ (x >>> 3);\n}\n\nfunction gamma1(x) {\n\treturn ((x >>> 17) | (x << 15)) ^ ((x >>> 19) | (x << 13)) ^ (x >>> 10);\n}\n\nSha256.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar a = this._a | 0;\n\tvar b = this._b | 0;\n\tvar c = this._c | 0;\n\tvar d = this._d | 0;\n\tvar e = this._e | 0;\n\tvar f = this._f | 0;\n\tvar g = this._g | 0;\n\tvar h = this._h | 0;\n\n\tfor (var i = 0; i < 16; ++i) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t}\n\tfor (; i < 64; ++i) {\n\t\tw[i] = (gamma1(w[i - 2]) + w[i - 7] + gamma0(w[i - 15]) + w[i - 16]) | 0;\n\t}\n\n\tfor (var j = 0; j < 64; ++j) {\n\t\tvar T1 = (h + sigma1(e) + ch(e, f, g) + K[j] + w[j]) | 0;\n\t\tvar T2 = (sigma0(a) + maj(a, b, c)) | 0;\n\n\t\th = g;\n\t\tg = f;\n\t\tf = e;\n\t\te = (d + T1) | 0;\n\t\td = c;\n\t\tc = b;\n\t\tb = a;\n\t\ta = (T1 + T2) | 0;\n\t}\n\n\tthis._a = (a + this._a) | 0;\n\tthis._b = (b + this._b) | 0;\n\tthis._c = (c + this._c) | 0;\n\tthis._d = (d + this._d) | 0;\n\tthis._e = (e + this._e) | 0;\n\tthis._f = (f + this._f) | 0;\n\tthis._g = (g + this._g) | 0;\n\tthis._h = (h + this._h) | 0;\n};\n\nSha256.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(32);\n\n\tH.writeInt32BE(this._a, 0);\n\tH.writeInt32BE(this._b, 4);\n\tH.writeInt32BE(this._c, 8);\n\tH.writeInt32BE(this._d, 12);\n\tH.writeInt32BE(this._e, 16);\n\tH.writeInt32BE(this._f, 20);\n\tH.writeInt32BE(this._g, 24);\n\tH.writeInt32BE(this._h, 28);\n\n\treturn H;\n};\n\nmodule.exports = Sha256;\n","'use strict';\n\n/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits');\nvar Sha256 = require('./sha256');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar W = new Array(64);\n\nfunction Sha224() {\n\tthis.init();\n\n\tthis._w = W; // new Array(64)\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha224, Sha256);\n\nSha224.prototype.init = function () {\n\tthis._a = 0xc1059ed8;\n\tthis._b = 0x367cd507;\n\tthis._c = 0x3070dd17;\n\tthis._d = 0xf70e5939;\n\tthis._e = 0xffc00b31;\n\tthis._f = 0x68581511;\n\tthis._g = 0x64f98fa7;\n\tthis._h = 0xbefa4fa4;\n\n\treturn this;\n};\n\nSha224.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(28);\n\n\tH.writeInt32BE(this._a, 0);\n\tH.writeInt32BE(this._b, 4);\n\tH.writeInt32BE(this._c, 8);\n\tH.writeInt32BE(this._d, 12);\n\tH.writeInt32BE(this._e, 16);\n\tH.writeInt32BE(this._f, 20);\n\tH.writeInt32BE(this._g, 24);\n\n\treturn H;\n};\n\nmodule.exports = Sha224;\n","'use strict';\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x428a2f98,\n\t0xd728ae22,\n\t0x71374491,\n\t0x23ef65cd,\n\t0xb5c0fbcf,\n\t0xec4d3b2f,\n\t0xe9b5dba5,\n\t0x8189dbbc,\n\t0x3956c25b,\n\t0xf348b538,\n\t0x59f111f1,\n\t0xb605d019,\n\t0x923f82a4,\n\t0xaf194f9b,\n\t0xab1c5ed5,\n\t0xda6d8118,\n\t0xd807aa98,\n\t0xa3030242,\n\t0x12835b01,\n\t0x45706fbe,\n\t0x243185be,\n\t0x4ee4b28c,\n\t0x550c7dc3,\n\t0xd5ffb4e2,\n\t0x72be5d74,\n\t0xf27b896f,\n\t0x80deb1fe,\n\t0x3b1696b1,\n\t0x9bdc06a7,\n\t0x25c71235,\n\t0xc19bf174,\n\t0xcf692694,\n\t0xe49b69c1,\n\t0x9ef14ad2,\n\t0xefbe4786,\n\t0x384f25e3,\n\t0x0fc19dc6,\n\t0x8b8cd5b5,\n\t0x240ca1cc,\n\t0x77ac9c65,\n\t0x2de92c6f,\n\t0x592b0275,\n\t0x4a7484aa,\n\t0x6ea6e483,\n\t0x5cb0a9dc,\n\t0xbd41fbd4,\n\t0x76f988da,\n\t0x831153b5,\n\t0x983e5152,\n\t0xee66dfab,\n\t0xa831c66d,\n\t0x2db43210,\n\t0xb00327c8,\n\t0x98fb213f,\n\t0xbf597fc7,\n\t0xbeef0ee4,\n\t0xc6e00bf3,\n\t0x3da88fc2,\n\t0xd5a79147,\n\t0x930aa725,\n\t0x06ca6351,\n\t0xe003826f,\n\t0x14292967,\n\t0x0a0e6e70,\n\t0x27b70a85,\n\t0x46d22ffc,\n\t0x2e1b2138,\n\t0x5c26c926,\n\t0x4d2c6dfc,\n\t0x5ac42aed,\n\t0x53380d13,\n\t0x9d95b3df,\n\t0x650a7354,\n\t0x8baf63de,\n\t0x766a0abb,\n\t0x3c77b2a8,\n\t0x81c2c92e,\n\t0x47edaee6,\n\t0x92722c85,\n\t0x1482353b,\n\t0xa2bfe8a1,\n\t0x4cf10364,\n\t0xa81a664b,\n\t0xbc423001,\n\t0xc24b8b70,\n\t0xd0f89791,\n\t0xc76c51a3,\n\t0x0654be30,\n\t0xd192e819,\n\t0xd6ef5218,\n\t0xd6990624,\n\t0x5565a910,\n\t0xf40e3585,\n\t0x5771202a,\n\t0x106aa070,\n\t0x32bbd1b8,\n\t0x19a4c116,\n\t0xb8d2d0c8,\n\t0x1e376c08,\n\t0x5141ab53,\n\t0x2748774c,\n\t0xdf8eeb99,\n\t0x34b0bcb5,\n\t0xe19b48a8,\n\t0x391c0cb3,\n\t0xc5c95a63,\n\t0x4ed8aa4a,\n\t0xe3418acb,\n\t0x5b9cca4f,\n\t0x7763e373,\n\t0x682e6ff3,\n\t0xd6b2b8a3,\n\t0x748f82ee,\n\t0x5defb2fc,\n\t0x78a5636f,\n\t0x43172f60,\n\t0x84c87814,\n\t0xa1f0ab72,\n\t0x8cc70208,\n\t0x1a6439ec,\n\t0x90befffa,\n\t0x23631e28,\n\t0xa4506ceb,\n\t0xde82bde9,\n\t0xbef9a3f7,\n\t0xb2c67915,\n\t0xc67178f2,\n\t0xe372532b,\n\t0xca273ece,\n\t0xea26619c,\n\t0xd186b8c7,\n\t0x21c0c207,\n\t0xeada7dd6,\n\t0xcde0eb1e,\n\t0xf57d4f7f,\n\t0xee6ed178,\n\t0x06f067aa,\n\t0x72176fba,\n\t0x0a637dc5,\n\t0xa2c898a6,\n\t0x113f9804,\n\t0xbef90dae,\n\t0x1b710b35,\n\t0x131c471b,\n\t0x28db77f5,\n\t0x23047d84,\n\t0x32caab7b,\n\t0x40c72493,\n\t0x3c9ebe0a,\n\t0x15c9bebc,\n\t0x431d67c4,\n\t0x9c100d4c,\n\t0x4cc5d4be,\n\t0xcb3e42b6,\n\t0x597f299c,\n\t0xfc657e2a,\n\t0x5fcb6fab,\n\t0x3ad6faec,\n\t0x6c44198c,\n\t0x4a475817\n];\n\nvar W = new Array(160);\n\nfunction Sha512() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 128, 112);\n}\n\ninherits(Sha512, Hash);\n\nSha512.prototype.init = function () {\n\tthis._ah = 0x6a09e667;\n\tthis._bh = 0xbb67ae85;\n\tthis._ch = 0x3c6ef372;\n\tthis._dh = 0xa54ff53a;\n\tthis._eh = 0x510e527f;\n\tthis._fh = 0x9b05688c;\n\tthis._gh = 0x1f83d9ab;\n\tthis._hh = 0x5be0cd19;\n\n\tthis._al = 0xf3bcc908;\n\tthis._bl = 0x84caa73b;\n\tthis._cl = 0xfe94f82b;\n\tthis._dl = 0x5f1d36f1;\n\tthis._el = 0xade682d1;\n\tthis._fl = 0x2b3e6c1f;\n\tthis._gl = 0xfb41bd6b;\n\tthis._hl = 0x137e2179;\n\n\treturn this;\n};\n\nfunction Ch(x, y, z) {\n\treturn z ^ (x & (y ^ z));\n}\n\nfunction maj(x, y, z) {\n\treturn (x & y) | (z & (x | y));\n}\n\nfunction sigma0(x, xl) {\n\treturn ((x >>> 28) | (xl << 4)) ^ ((xl >>> 2) | (x << 30)) ^ ((xl >>> 7) | (x << 25));\n}\n\nfunction sigma1(x, xl) {\n\treturn ((x >>> 14) | (xl << 18)) ^ ((x >>> 18) | (xl << 14)) ^ ((xl >>> 9) | (x << 23));\n}\n\nfunction Gamma0(x, xl) {\n\treturn ((x >>> 1) | (xl << 31)) ^ ((x >>> 8) | (xl << 24)) ^ (x >>> 7);\n}\n\nfunction Gamma0l(x, xl) {\n\treturn ((x >>> 1) | (xl << 31)) ^ ((x >>> 8) | (xl << 24)) ^ ((x >>> 7) | (xl << 25));\n}\n\nfunction Gamma1(x, xl) {\n\treturn ((x >>> 19) | (xl << 13)) ^ ((xl >>> 29) | (x << 3)) ^ (x >>> 6);\n}\n\nfunction Gamma1l(x, xl) {\n\treturn ((x >>> 19) | (xl << 13)) ^ ((xl >>> 29) | (x << 3)) ^ ((x >>> 6) | (xl << 26));\n}\n\nfunction getCarry(a, b) {\n\treturn (a >>> 0) < (b >>> 0) ? 1 : 0;\n}\n\nSha512.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar ah = this._ah | 0;\n\tvar bh = this._bh | 0;\n\tvar ch = this._ch | 0;\n\tvar dh = this._dh | 0;\n\tvar eh = this._eh | 0;\n\tvar fh = this._fh | 0;\n\tvar gh = this._gh | 0;\n\tvar hh = this._hh | 0;\n\n\tvar al = this._al | 0;\n\tvar bl = this._bl | 0;\n\tvar cl = this._cl | 0;\n\tvar dl = this._dl | 0;\n\tvar el = this._el | 0;\n\tvar fl = this._fl | 0;\n\tvar gl = this._gl | 0;\n\tvar hl = this._hl | 0;\n\n\tfor (var i = 0; i < 32; i += 2) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t\tw[i + 1] = M.readInt32BE((i * 4) + 4);\n\t}\n\tfor (; i < 160; i += 2) {\n\t\tvar xh = w[i - (15 * 2)];\n\t\tvar xl = w[i - (15 * 2) + 1];\n\t\tvar gamma0 = Gamma0(xh, xl);\n\t\tvar gamma0l = Gamma0l(xl, xh);\n\n\t\txh = w[i - (2 * 2)];\n\t\txl = w[i - (2 * 2) + 1];\n\t\tvar gamma1 = Gamma1(xh, xl);\n\t\tvar gamma1l = Gamma1l(xl, xh);\n\n\t\t// w[i] = gamma0 + w[i - 7] + gamma1 + w[i - 16]\n\t\tvar Wi7h = w[i - (7 * 2)];\n\t\tvar Wi7l = w[i - (7 * 2) + 1];\n\n\t\tvar Wi16h = w[i - (16 * 2)];\n\t\tvar Wi16l = w[i - (16 * 2) + 1];\n\n\t\tvar Wil = (gamma0l + Wi7l) | 0;\n\t\tvar Wih = (gamma0 + Wi7h + getCarry(Wil, gamma0l)) | 0;\n\t\tWil = (Wil + gamma1l) | 0;\n\t\tWih = (Wih + gamma1 + getCarry(Wil, gamma1l)) | 0;\n\t\tWil = (Wil + Wi16l) | 0;\n\t\tWih = (Wih + Wi16h + getCarry(Wil, Wi16l)) | 0;\n\n\t\tw[i] = Wih;\n\t\tw[i + 1] = Wil;\n\t}\n\n\tfor (var j = 0; j < 160; j += 2) {\n\t\tWih = w[j];\n\t\tWil = w[j + 1];\n\n\t\tvar majh = maj(ah, bh, ch);\n\t\tvar majl = maj(al, bl, cl);\n\n\t\tvar sigma0h = sigma0(ah, al);\n\t\tvar sigma0l = sigma0(al, ah);\n\t\tvar sigma1h = sigma1(eh, el);\n\t\tvar sigma1l = sigma1(el, eh);\n\n\t\t// t1 = h + sigma1 + ch + K[j] + w[j]\n\t\tvar Kih = K[j];\n\t\tvar Kil = K[j + 1];\n\n\t\tvar chh = Ch(eh, fh, gh);\n\t\tvar chl = Ch(el, fl, gl);\n\n\t\tvar t1l = (hl + sigma1l) | 0;\n\t\tvar t1h = (hh + sigma1h + getCarry(t1l, hl)) | 0;\n\t\tt1l = (t1l + chl) | 0;\n\t\tt1h = (t1h + chh + getCarry(t1l, chl)) | 0;\n\t\tt1l = (t1l + Kil) | 0;\n\t\tt1h = (t1h + Kih + getCarry(t1l, Kil)) | 0;\n\t\tt1l = (t1l + Wil) | 0;\n\t\tt1h = (t1h + Wih + getCarry(t1l, Wil)) | 0;\n\n\t\t// t2 = sigma0 + maj\n\t\tvar t2l = (sigma0l + majl) | 0;\n\t\tvar t2h = (sigma0h + majh + getCarry(t2l, sigma0l)) | 0;\n\n\t\thh = gh;\n\t\thl = gl;\n\t\tgh = fh;\n\t\tgl = fl;\n\t\tfh = eh;\n\t\tfl = el;\n\t\tel = (dl + t1l) | 0;\n\t\teh = (dh + t1h + getCarry(el, dl)) | 0;\n\t\tdh = ch;\n\t\tdl = cl;\n\t\tch = bh;\n\t\tcl = bl;\n\t\tbh = ah;\n\t\tbl = al;\n\t\tal = (t1l + t2l) | 0;\n\t\tah = (t1h + t2h + getCarry(al, t1l)) | 0;\n\t}\n\n\tthis._al = (this._al + al) | 0;\n\tthis._bl = (this._bl + bl) | 0;\n\tthis._cl = (this._cl + cl) | 0;\n\tthis._dl = (this._dl + dl) | 0;\n\tthis._el = (this._el + el) | 0;\n\tthis._fl = (this._fl + fl) | 0;\n\tthis._gl = (this._gl + gl) | 0;\n\tthis._hl = (this._hl + hl) | 0;\n\n\tthis._ah = (this._ah + ah + getCarry(this._al, al)) | 0;\n\tthis._bh = (this._bh + bh + getCarry(this._bl, bl)) | 0;\n\tthis._ch = (this._ch + ch + getCarry(this._cl, cl)) | 0;\n\tthis._dh = (this._dh + dh + getCarry(this._dl, dl)) | 0;\n\tthis._eh = (this._eh + eh + getCarry(this._el, el)) | 0;\n\tthis._fh = (this._fh + fh + getCarry(this._fl, fl)) | 0;\n\tthis._gh = (this._gh + gh + getCarry(this._gl, gl)) | 0;\n\tthis._hh = (this._hh + hh + getCarry(this._hl, hl)) | 0;\n};\n\nSha512.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(64);\n\n\tfunction writeInt64BE(h, l, offset) {\n\t\tH.writeInt32BE(h, offset);\n\t\tH.writeInt32BE(l, offset + 4);\n\t}\n\n\twriteInt64BE(this._ah, this._al, 0);\n\twriteInt64BE(this._bh, this._bl, 8);\n\twriteInt64BE(this._ch, this._cl, 16);\n\twriteInt64BE(this._dh, this._dl, 24);\n\twriteInt64BE(this._eh, this._el, 32);\n\twriteInt64BE(this._fh, this._fl, 40);\n\twriteInt64BE(this._gh, this._gl, 48);\n\twriteInt64BE(this._hh, this._hl, 56);\n\n\treturn H;\n};\n\nmodule.exports = Sha512;\n","'use strict';\n\nvar inherits = require('inherits');\nvar SHA512 = require('./sha512');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar W = new Array(160);\n\nfunction Sha384() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 128, 112);\n}\n\ninherits(Sha384, SHA512);\n\nSha384.prototype.init = function () {\n\tthis._ah = 0xcbbb9d5d;\n\tthis._bh = 0x629a292a;\n\tthis._ch = 0x9159015a;\n\tthis._dh = 0x152fecd8;\n\tthis._eh = 0x67332667;\n\tthis._fh = 0x8eb44a87;\n\tthis._gh = 0xdb0c2e0d;\n\tthis._hh = 0x47b5481d;\n\n\tthis._al = 0xc1059ed8;\n\tthis._bl = 0x367cd507;\n\tthis._cl = 0x3070dd17;\n\tthis._dl = 0xf70e5939;\n\tthis._el = 0xffc00b31;\n\tthis._fl = 0x68581511;\n\tthis._gl = 0x64f98fa7;\n\tthis._hl = 0xbefa4fa4;\n\n\treturn this;\n};\n\nSha384.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(48);\n\n\tfunction writeInt64BE(h, l, offset) {\n\t\tH.writeInt32BE(h, offset);\n\t\tH.writeInt32BE(l, offset + 4);\n\t}\n\n\twriteInt64BE(this._ah, this._al, 0);\n\twriteInt64BE(this._bh, this._bl, 8);\n\twriteInt64BE(this._ch, this._cl, 16);\n\twriteInt64BE(this._dh, this._dl, 24);\n\twriteInt64BE(this._eh, this._el, 32);\n\twriteInt64BE(this._fh, this._fl, 40);\n\n\treturn H;\n};\n\nmodule.exports = Sha384;\n","'use strict';\n\nmodule.exports = function SHA(algorithm) {\n\tvar alg = algorithm.toLowerCase();\n\n\tvar Algorithm = module.exports[alg];\n\tif (!Algorithm) {\n\t\tthrow new Error(alg + ' is not supported (we accept pull requests)');\n\t}\n\n\treturn new Algorithm();\n};\n\nmodule.exports.sha = require('./sha');\nmodule.exports.sha1 = require('./sha1');\nmodule.exports.sha224 = require('./sha224');\nmodule.exports.sha256 = require('./sha256');\nmodule.exports.sha384 = require('./sha384');\nmodule.exports.sha512 = require('./sha512');\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar Transform = require('stream').Transform;\nvar StringDecoder = require('string_decoder').StringDecoder;\nvar inherits = require('inherits');\n\nfunction CipherBase(hashMode) {\n\tTransform.call(this);\n\tthis.hashMode = typeof hashMode === 'string';\n\tif (this.hashMode) {\n\t\tthis[hashMode] = this._finalOrDigest;\n\t} else {\n\t\tthis['final'] = this._finalOrDigest;\n\t}\n\tif (this._final) {\n\t\tthis.__final = this._final;\n\t\tthis._final = null;\n\t}\n\tthis._decoder = null;\n\tthis._encoding = null;\n}\ninherits(CipherBase, Transform);\n\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined'\n\t&& typeof Uint8Array !== 'undefined'\n\t&& ArrayBuffer.isView\n\t&& (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT);\n\nfunction toBuffer(data, encoding) {\n\t/*\n\t * No need to do anything for exact instance\n\t * This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n\t */\n\tif (data instanceof Buffer) {\n\t\treturn data;\n\t}\n\n\t// Convert strings to Buffer\n\tif (typeof data === 'string') {\n\t\treturn Buffer.from(data, encoding);\n\t}\n\n\t/*\n\t * Wrap any TypedArray instances and DataViews\n\t * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n\t */\n\tif (useArrayBuffer && ArrayBuffer.isView(data)) {\n\t\t// Bug in Node.js <6.3.1, which treats this as out-of-bounds\n\t\tif (data.byteLength === 0) {\n\t\t\treturn Buffer.alloc(0);\n\t\t}\n\n\t\tvar res = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n\t\t/*\n\t\t * Recheck result size, as offset/length doesn't work on Node.js <5.10\n\t\t * We just go to Uint8Array case if this fails\n\t\t */\n\t\tif (res.byteLength === data.byteLength) {\n\t\t\treturn res;\n\t\t}\n\t}\n\n\t/*\n\t * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n\t * Doesn't make sense with other TypedArray instances\n\t */\n\tif (useUint8Array && data instanceof Uint8Array) {\n\t\treturn Buffer.from(data);\n\t}\n\n\t/*\n\t * Old Buffer polyfill on an engine that doesn't have TypedArray support\n\t * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n\t * Convert to our current Buffer implementation\n\t */\n\tif (\n\t\tBuffer.isBuffer(data)\n\t\t\t&& data.constructor\n\t\t\t&& typeof data.constructor.isBuffer === 'function'\n\t\t\t&& data.constructor.isBuffer(data)\n\t) {\n\t\treturn Buffer.from(data);\n\t}\n\n\tthrow new TypeError('The \"data\" argument must be of type string or an instance of Buffer, TypedArray, or DataView.');\n}\n\nCipherBase.prototype.update = function (data, inputEnc, outputEnc) {\n\tvar bufferData = toBuffer(data, inputEnc); // asserts correct input type\n\tvar outData = this._update(bufferData);\n\tif (this.hashMode) {\n\t\treturn this;\n\t}\n\n\tif (outputEnc) {\n\t\toutData = this._toString(outData, outputEnc);\n\t}\n\n\treturn outData;\n};\n\nCipherBase.prototype.setAutoPadding = function () {};\nCipherBase.prototype.getAuthTag = function () {\n\tthrow new Error('trying to get auth tag in unsupported state');\n};\n\nCipherBase.prototype.setAuthTag = function () {\n\tthrow new Error('trying to set auth tag in unsupported state');\n};\n\nCipherBase.prototype.setAAD = function () {\n\tthrow new Error('trying to set aad in unsupported state');\n};\n\nCipherBase.prototype._transform = function (data, _, next) {\n\tvar err;\n\ttry {\n\t\tif (this.hashMode) {\n\t\t\tthis._update(data);\n\t\t} else {\n\t\t\tthis.push(this._update(data));\n\t\t}\n\t} catch (e) {\n\t\terr = e;\n\t} finally {\n\t\tnext(err);\n\t}\n};\nCipherBase.prototype._flush = function (done) {\n\tvar err;\n\ttry {\n\t\tthis.push(this.__final());\n\t} catch (e) {\n\t\terr = e;\n\t}\n\n\tdone(err);\n};\nCipherBase.prototype._finalOrDigest = function (outputEnc) {\n\tvar outData = this.__final() || Buffer.alloc(0);\n\tif (outputEnc) {\n\t\toutData = this._toString(outData, outputEnc, true);\n\t}\n\treturn outData;\n};\n\nCipherBase.prototype._toString = function (value, enc, fin) {\n\tif (!this._decoder) {\n\t\tthis._decoder = new StringDecoder(enc);\n\t\tthis._encoding = enc;\n\t}\n\n\tif (this._encoding !== enc) {\n\t\tthrow new Error('can’t switch encodings');\n\t}\n\n\tvar out = this._decoder.write(value);\n\tif (fin) {\n\t\tout += this._decoder.end();\n\t}\n\n\treturn out;\n};\n\nmodule.exports = CipherBase;\n","'use strict'\nvar inherits = require('inherits')\nvar MD5 = require('md5.js')\nvar RIPEMD160 = require('ripemd160')\nvar sha = require('sha.js')\nvar Base = require('cipher-base')\n\nfunction Hash (hash) {\n Base.call(this, 'digest')\n\n this._hash = hash\n}\n\ninherits(Hash, Base)\n\nHash.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHash.prototype._final = function () {\n return this._hash.digest()\n}\n\nmodule.exports = function createHash (alg) {\n alg = alg.toLowerCase()\n if (alg === 'md5') return new MD5()\n if (alg === 'rmd160' || alg === 'ripemd160') return new RIPEMD160()\n\n return new Hash(sha(alg))\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar Base = require('cipher-base')\n\nvar ZEROS = Buffer.alloc(128)\nvar blocksize = 64\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n this._alg = alg\n this._key = key\n\n if (key.length > blocksize) {\n key = alg(key)\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n\n this._hash = [ipad]\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.push(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._alg(Buffer.concat(this._hash))\n return this._alg(Buffer.concat([this._opad, h]))\n}\nmodule.exports = Hmac\n","var MD5 = require('md5.js')\n\nmodule.exports = function (buffer) {\n return new MD5().update(buffer).digest()\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Legacy = require('./legacy')\nvar Base = require('cipher-base')\nvar Buffer = require('safe-buffer').Buffer\nvar md5 = require('create-hash/md5')\nvar RIPEMD160 = require('ripemd160')\n\nvar sha = require('sha.js')\n\nvar ZEROS = Buffer.alloc(128)\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64\n\n this._alg = alg\n this._key = key\n if (key.length > blocksize) {\n var hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n key = hash.update(key).digest()\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n this._hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n this._hash.update(ipad)\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._hash.digest()\n var hash = this._alg === 'rmd160' ? new RIPEMD160() : sha(this._alg)\n return hash.update(this._opad).update(h).digest()\n}\n\nmodule.exports = function createHmac (alg, key) {\n alg = alg.toLowerCase()\n if (alg === 'rmd160' || alg === 'ripemd160') {\n return new Hmac('rmd160', key)\n }\n if (alg === 'md5') {\n return new Legacy(md5, key)\n }\n return new Hmac(alg, key)\n}\n","'use strict';\n\nmodule.exports = require('./browser/algorithms.json');\n","'use strict';\n\nvar MAX_ALLOC = Math.pow(2, 30) - 1; // default in iojs\n\nmodule.exports = function (iterations, keylen) {\n\tif (typeof iterations !== 'number') {\n\t\tthrow new TypeError('Iterations not a number');\n\t}\n\n\tif (iterations < 0) {\n\t\tthrow new TypeError('Bad iterations');\n\t}\n\n\tif (typeof keylen !== 'number') {\n\t\tthrow new TypeError('Key length not a number');\n\t}\n\n\tif (keylen < 0 || keylen > MAX_ALLOC || keylen !== keylen) { /* eslint no-self-compare: 0 */\n\t\tthrow new TypeError('Bad key length');\n\t}\n};\n","'use strict';\n\nvar defaultEncoding;\n/* istanbul ignore next */\nif (global.process && global.process.browser) {\n\tdefaultEncoding = 'utf-8';\n} else if (global.process && global.process.version) {\n\tvar pVersionMajor = parseInt(process.version.split('.')[0].slice(1), 10);\n\n\tdefaultEncoding = pVersionMajor >= 6 ? 'utf-8' : 'binary';\n} else {\n\tdefaultEncoding = 'utf-8';\n}\nmodule.exports = defaultEncoding;\n","'use strict'\nvar intSize = 4\nvar zeroBuffer = new Buffer(intSize)\nzeroBuffer.fill(0)\n\nvar charSize = 8\nvar hashSize = 16\n\nfunction toArray (buf) {\n if ((buf.length % intSize) !== 0) {\n var len = buf.length + (intSize - (buf.length % intSize))\n buf = Buffer.concat([buf, zeroBuffer], len)\n }\n\n var arr = new Array(buf.length >>> 2)\n for (var i = 0, j = 0; i < buf.length; i += intSize, j++) {\n arr[j] = buf.readInt32LE(i)\n }\n\n return arr\n}\n\nmodule.exports = function hash (buf, fn) {\n var arr = fn(toArray(buf), buf.length * charSize)\n buf = new Buffer(hashSize)\n for (var i = 0; i < arr.length; i++) {\n buf.writeInt32LE(arr[i], i << 2, true)\n }\n return buf\n}\n","'use strict'\n/*\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\n\nvar makeHash = require('./make-hash')\n\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length\n */\nfunction core_md5 (x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << ((len) % 32)\n x[(((len + 64) >>> 9) << 4) + 14] = len\n\n var a = 1732584193\n var b = -271733879\n var c = -1732584194\n var d = 271733878\n\n for (var i = 0; i < x.length; i += 16) {\n var olda = a\n var oldb = b\n var oldc = c\n var oldd = d\n\n a = md5_ff(a, b, c, d, x[i + 0], 7, -680876936)\n d = md5_ff(d, a, b, c, x[i + 1], 12, -389564586)\n c = md5_ff(c, d, a, b, x[i + 2], 17, 606105819)\n b = md5_ff(b, c, d, a, x[i + 3], 22, -1044525330)\n a = md5_ff(a, b, c, d, x[i + 4], 7, -176418897)\n d = md5_ff(d, a, b, c, x[i + 5], 12, 1200080426)\n c = md5_ff(c, d, a, b, x[i + 6], 17, -1473231341)\n b = md5_ff(b, c, d, a, x[i + 7], 22, -45705983)\n a = md5_ff(a, b, c, d, x[i + 8], 7, 1770035416)\n d = md5_ff(d, a, b, c, x[i + 9], 12, -1958414417)\n c = md5_ff(c, d, a, b, x[i + 10], 17, -42063)\n b = md5_ff(b, c, d, a, x[i + 11], 22, -1990404162)\n a = md5_ff(a, b, c, d, x[i + 12], 7, 1804603682)\n d = md5_ff(d, a, b, c, x[i + 13], 12, -40341101)\n c = md5_ff(c, d, a, b, x[i + 14], 17, -1502002290)\n b = md5_ff(b, c, d, a, x[i + 15], 22, 1236535329)\n\n a = md5_gg(a, b, c, d, x[i + 1], 5, -165796510)\n d = md5_gg(d, a, b, c, x[i + 6], 9, -1069501632)\n c = md5_gg(c, d, a, b, x[i + 11], 14, 643717713)\n b = md5_gg(b, c, d, a, x[i + 0], 20, -373897302)\n a = md5_gg(a, b, c, d, x[i + 5], 5, -701558691)\n d = md5_gg(d, a, b, c, x[i + 10], 9, 38016083)\n c = md5_gg(c, d, a, b, x[i + 15], 14, -660478335)\n b = md5_gg(b, c, d, a, x[i + 4], 20, -405537848)\n a = md5_gg(a, b, c, d, x[i + 9], 5, 568446438)\n d = md5_gg(d, a, b, c, x[i + 14], 9, -1019803690)\n c = md5_gg(c, d, a, b, x[i + 3], 14, -187363961)\n b = md5_gg(b, c, d, a, x[i + 8], 20, 1163531501)\n a = md5_gg(a, b, c, d, x[i + 13], 5, -1444681467)\n d = md5_gg(d, a, b, c, x[i + 2], 9, -51403784)\n c = md5_gg(c, d, a, b, x[i + 7], 14, 1735328473)\n b = md5_gg(b, c, d, a, x[i + 12], 20, -1926607734)\n\n a = md5_hh(a, b, c, d, x[i + 5], 4, -378558)\n d = md5_hh(d, a, b, c, x[i + 8], 11, -2022574463)\n c = md5_hh(c, d, a, b, x[i + 11], 16, 1839030562)\n b = md5_hh(b, c, d, a, x[i + 14], 23, -35309556)\n a = md5_hh(a, b, c, d, x[i + 1], 4, -1530992060)\n d = md5_hh(d, a, b, c, x[i + 4], 11, 1272893353)\n c = md5_hh(c, d, a, b, x[i + 7], 16, -155497632)\n b = md5_hh(b, c, d, a, x[i + 10], 23, -1094730640)\n a = md5_hh(a, b, c, d, x[i + 13], 4, 681279174)\n d = md5_hh(d, a, b, c, x[i + 0], 11, -358537222)\n c = md5_hh(c, d, a, b, x[i + 3], 16, -722521979)\n b = md5_hh(b, c, d, a, x[i + 6], 23, 76029189)\n a = md5_hh(a, b, c, d, x[i + 9], 4, -640364487)\n d = md5_hh(d, a, b, c, x[i + 12], 11, -421815835)\n c = md5_hh(c, d, a, b, x[i + 15], 16, 530742520)\n b = md5_hh(b, c, d, a, x[i + 2], 23, -995338651)\n\n a = md5_ii(a, b, c, d, x[i + 0], 6, -198630844)\n d = md5_ii(d, a, b, c, x[i + 7], 10, 1126891415)\n c = md5_ii(c, d, a, b, x[i + 14], 15, -1416354905)\n b = md5_ii(b, c, d, a, x[i + 5], 21, -57434055)\n a = md5_ii(a, b, c, d, x[i + 12], 6, 1700485571)\n d = md5_ii(d, a, b, c, x[i + 3], 10, -1894986606)\n c = md5_ii(c, d, a, b, x[i + 10], 15, -1051523)\n b = md5_ii(b, c, d, a, x[i + 1], 21, -2054922799)\n a = md5_ii(a, b, c, d, x[i + 8], 6, 1873313359)\n d = md5_ii(d, a, b, c, x[i + 15], 10, -30611744)\n c = md5_ii(c, d, a, b, x[i + 6], 15, -1560198380)\n b = md5_ii(b, c, d, a, x[i + 13], 21, 1309151649)\n a = md5_ii(a, b, c, d, x[i + 4], 6, -145523070)\n d = md5_ii(d, a, b, c, x[i + 11], 10, -1120210379)\n c = md5_ii(c, d, a, b, x[i + 2], 15, 718787259)\n b = md5_ii(b, c, d, a, x[i + 9], 21, -343485551)\n\n a = safe_add(a, olda)\n b = safe_add(b, oldb)\n c = safe_add(c, oldc)\n d = safe_add(d, oldd)\n }\n\n return [a, b, c, d]\n}\n\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\nfunction md5_cmn (q, a, b, x, s, t) {\n return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s), b)\n}\n\nfunction md5_ff (a, b, c, d, x, s, t) {\n return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t)\n}\n\nfunction md5_gg (a, b, c, d, x, s, t) {\n return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t)\n}\n\nfunction md5_hh (a, b, c, d, x, s, t) {\n return md5_cmn(b ^ c ^ d, a, b, x, s, t)\n}\n\nfunction md5_ii (a, b, c, d, x, s, t) {\n return md5_cmn(c ^ (b | (~d)), a, b, x, s, t)\n}\n\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\nfunction safe_add (x, y) {\n var lsw = (x & 0xFFFF) + (y & 0xFFFF)\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16)\n return (msw << 16) | (lsw & 0xFFFF)\n}\n\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\nfunction bit_rol (num, cnt) {\n return (num << cnt) | (num >>> (32 - cnt))\n}\n\nmodule.exports = function md5 (buf) {\n return makeHash(buf, core_md5)\n}\n","'use strict'\nvar Transform = require('stream').Transform\nvar inherits = require('inherits')\n\nfunction HashBase (blockSize) {\n Transform.call(this)\n\n this._block = new Buffer(blockSize)\n this._blockSize = blockSize\n this._blockOffset = 0\n this._length = [0, 0, 0, 0]\n\n this._finalized = false\n}\n\ninherits(HashBase, Transform)\n\nHashBase.prototype._transform = function (chunk, encoding, callback) {\n var error = null\n try {\n if (encoding !== 'buffer') chunk = new Buffer(chunk, encoding)\n this.update(chunk)\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nHashBase.prototype._flush = function (callback) {\n var error = null\n try {\n this.push(this._digest())\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nHashBase.prototype.update = function (data, encoding) {\n if (!Buffer.isBuffer(data) && typeof data !== 'string') throw new TypeError('Data must be a string or a buffer')\n if (this._finalized) throw new Error('Digest already called')\n if (!Buffer.isBuffer(data)) data = new Buffer(data, encoding || 'binary')\n\n // consume data\n var block = this._block\n var offset = 0\n while (this._blockOffset + data.length - offset >= this._blockSize) {\n for (var i = this._blockOffset; i < this._blockSize;) block[i++] = data[offset++]\n this._update()\n this._blockOffset = 0\n }\n while (offset < data.length) block[this._blockOffset++] = data[offset++]\n\n // update length\n for (var j = 0, carry = data.length * 8; carry > 0; ++j) {\n this._length[j] += carry\n carry = (this._length[j] / 0x0100000000) | 0\n if (carry > 0) this._length[j] -= 0x0100000000 * carry\n }\n\n return this\n}\n\nHashBase.prototype._update = function (data) {\n throw new Error('_update is not implemented')\n}\n\nHashBase.prototype.digest = function (encoding) {\n if (this._finalized) throw new Error('Digest already called')\n this._finalized = true\n\n var digest = this._digest()\n if (encoding !== undefined) digest = digest.toString(encoding)\n return digest\n}\n\nHashBase.prototype._digest = function () {\n throw new Error('_digest is not implemented')\n}\n\nmodule.exports = HashBase\n","'use strict'\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\n\nfunction RIPEMD160 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n this._e = 0xc3d2e1f0\n}\n\ninherits(RIPEMD160, HashBase)\n\nRIPEMD160.prototype._update = function () {\n var m = new Array(16)\n for (var i = 0; i < 16; ++i) m[i] = this._block.readInt32LE(i * 4)\n\n var al = this._a\n var bl = this._b\n var cl = this._c\n var dl = this._d\n var el = this._e\n\n // Mj = 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15\n // K = 0x00000000\n // Sj = 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8\n al = fn1(al, bl, cl, dl, el, m[0], 0x00000000, 11); cl = rotl(cl, 10)\n el = fn1(el, al, bl, cl, dl, m[1], 0x00000000, 14); bl = rotl(bl, 10)\n dl = fn1(dl, el, al, bl, cl, m[2], 0x00000000, 15); al = rotl(al, 10)\n cl = fn1(cl, dl, el, al, bl, m[3], 0x00000000, 12); el = rotl(el, 10)\n bl = fn1(bl, cl, dl, el, al, m[4], 0x00000000, 5); dl = rotl(dl, 10)\n al = fn1(al, bl, cl, dl, el, m[5], 0x00000000, 8); cl = rotl(cl, 10)\n el = fn1(el, al, bl, cl, dl, m[6], 0x00000000, 7); bl = rotl(bl, 10)\n dl = fn1(dl, el, al, bl, cl, m[7], 0x00000000, 9); al = rotl(al, 10)\n cl = fn1(cl, dl, el, al, bl, m[8], 0x00000000, 11); el = rotl(el, 10)\n bl = fn1(bl, cl, dl, el, al, m[9], 0x00000000, 13); dl = rotl(dl, 10)\n al = fn1(al, bl, cl, dl, el, m[10], 0x00000000, 14); cl = rotl(cl, 10)\n el = fn1(el, al, bl, cl, dl, m[11], 0x00000000, 15); bl = rotl(bl, 10)\n dl = fn1(dl, el, al, bl, cl, m[12], 0x00000000, 6); al = rotl(al, 10)\n cl = fn1(cl, dl, el, al, bl, m[13], 0x00000000, 7); el = rotl(el, 10)\n bl = fn1(bl, cl, dl, el, al, m[14], 0x00000000, 9); dl = rotl(dl, 10)\n al = fn1(al, bl, cl, dl, el, m[15], 0x00000000, 8); cl = rotl(cl, 10)\n\n // Mj = 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8\n // K = 0x5a827999\n // Sj = 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12\n el = fn2(el, al, bl, cl, dl, m[7], 0x5a827999, 7); bl = rotl(bl, 10)\n dl = fn2(dl, el, al, bl, cl, m[4], 0x5a827999, 6); al = rotl(al, 10)\n cl = fn2(cl, dl, el, al, bl, m[13], 0x5a827999, 8); el = rotl(el, 10)\n bl = fn2(bl, cl, dl, el, al, m[1], 0x5a827999, 13); dl = rotl(dl, 10)\n al = fn2(al, bl, cl, dl, el, m[10], 0x5a827999, 11); cl = rotl(cl, 10)\n el = fn2(el, al, bl, cl, dl, m[6], 0x5a827999, 9); bl = rotl(bl, 10)\n dl = fn2(dl, el, al, bl, cl, m[15], 0x5a827999, 7); al = rotl(al, 10)\n cl = fn2(cl, dl, el, al, bl, m[3], 0x5a827999, 15); el = rotl(el, 10)\n bl = fn2(bl, cl, dl, el, al, m[12], 0x5a827999, 7); dl = rotl(dl, 10)\n al = fn2(al, bl, cl, dl, el, m[0], 0x5a827999, 12); cl = rotl(cl, 10)\n el = fn2(el, al, bl, cl, dl, m[9], 0x5a827999, 15); bl = rotl(bl, 10)\n dl = fn2(dl, el, al, bl, cl, m[5], 0x5a827999, 9); al = rotl(al, 10)\n cl = fn2(cl, dl, el, al, bl, m[2], 0x5a827999, 11); el = rotl(el, 10)\n bl = fn2(bl, cl, dl, el, al, m[14], 0x5a827999, 7); dl = rotl(dl, 10)\n al = fn2(al, bl, cl, dl, el, m[11], 0x5a827999, 13); cl = rotl(cl, 10)\n el = fn2(el, al, bl, cl, dl, m[8], 0x5a827999, 12); bl = rotl(bl, 10)\n\n // Mj = 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12\n // K = 0x6ed9eba1\n // Sj = 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5\n dl = fn3(dl, el, al, bl, cl, m[3], 0x6ed9eba1, 11); al = rotl(al, 10)\n cl = fn3(cl, dl, el, al, bl, m[10], 0x6ed9eba1, 13); el = rotl(el, 10)\n bl = fn3(bl, cl, dl, el, al, m[14], 0x6ed9eba1, 6); dl = rotl(dl, 10)\n al = fn3(al, bl, cl, dl, el, m[4], 0x6ed9eba1, 7); cl = rotl(cl, 10)\n el = fn3(el, al, bl, cl, dl, m[9], 0x6ed9eba1, 14); bl = rotl(bl, 10)\n dl = fn3(dl, el, al, bl, cl, m[15], 0x6ed9eba1, 9); al = rotl(al, 10)\n cl = fn3(cl, dl, el, al, bl, m[8], 0x6ed9eba1, 13); el = rotl(el, 10)\n bl = fn3(bl, cl, dl, el, al, m[1], 0x6ed9eba1, 15); dl = rotl(dl, 10)\n al = fn3(al, bl, cl, dl, el, m[2], 0x6ed9eba1, 14); cl = rotl(cl, 10)\n el = fn3(el, al, bl, cl, dl, m[7], 0x6ed9eba1, 8); bl = rotl(bl, 10)\n dl = fn3(dl, el, al, bl, cl, m[0], 0x6ed9eba1, 13); al = rotl(al, 10)\n cl = fn3(cl, dl, el, al, bl, m[6], 0x6ed9eba1, 6); el = rotl(el, 10)\n bl = fn3(bl, cl, dl, el, al, m[13], 0x6ed9eba1, 5); dl = rotl(dl, 10)\n al = fn3(al, bl, cl, dl, el, m[11], 0x6ed9eba1, 12); cl = rotl(cl, 10)\n el = fn3(el, al, bl, cl, dl, m[5], 0x6ed9eba1, 7); bl = rotl(bl, 10)\n dl = fn3(dl, el, al, bl, cl, m[12], 0x6ed9eba1, 5); al = rotl(al, 10)\n\n // Mj = 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2\n // K = 0x8f1bbcdc\n // Sj = 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12\n cl = fn4(cl, dl, el, al, bl, m[1], 0x8f1bbcdc, 11); el = rotl(el, 10)\n bl = fn4(bl, cl, dl, el, al, m[9], 0x8f1bbcdc, 12); dl = rotl(dl, 10)\n al = fn4(al, bl, cl, dl, el, m[11], 0x8f1bbcdc, 14); cl = rotl(cl, 10)\n el = fn4(el, al, bl, cl, dl, m[10], 0x8f1bbcdc, 15); bl = rotl(bl, 10)\n dl = fn4(dl, el, al, bl, cl, m[0], 0x8f1bbcdc, 14); al = rotl(al, 10)\n cl = fn4(cl, dl, el, al, bl, m[8], 0x8f1bbcdc, 15); el = rotl(el, 10)\n bl = fn4(bl, cl, dl, el, al, m[12], 0x8f1bbcdc, 9); dl = rotl(dl, 10)\n al = fn4(al, bl, cl, dl, el, m[4], 0x8f1bbcdc, 8); cl = rotl(cl, 10)\n el = fn4(el, al, bl, cl, dl, m[13], 0x8f1bbcdc, 9); bl = rotl(bl, 10)\n dl = fn4(dl, el, al, bl, cl, m[3], 0x8f1bbcdc, 14); al = rotl(al, 10)\n cl = fn4(cl, dl, el, al, bl, m[7], 0x8f1bbcdc, 5); el = rotl(el, 10)\n bl = fn4(bl, cl, dl, el, al, m[15], 0x8f1bbcdc, 6); dl = rotl(dl, 10)\n al = fn4(al, bl, cl, dl, el, m[14], 0x8f1bbcdc, 8); cl = rotl(cl, 10)\n el = fn4(el, al, bl, cl, dl, m[5], 0x8f1bbcdc, 6); bl = rotl(bl, 10)\n dl = fn4(dl, el, al, bl, cl, m[6], 0x8f1bbcdc, 5); al = rotl(al, 10)\n cl = fn4(cl, dl, el, al, bl, m[2], 0x8f1bbcdc, 12); el = rotl(el, 10)\n\n // Mj = 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n // K = 0xa953fd4e\n // Sj = 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n bl = fn5(bl, cl, dl, el, al, m[4], 0xa953fd4e, 9); dl = rotl(dl, 10)\n al = fn5(al, bl, cl, dl, el, m[0], 0xa953fd4e, 15); cl = rotl(cl, 10)\n el = fn5(el, al, bl, cl, dl, m[5], 0xa953fd4e, 5); bl = rotl(bl, 10)\n dl = fn5(dl, el, al, bl, cl, m[9], 0xa953fd4e, 11); al = rotl(al, 10)\n cl = fn5(cl, dl, el, al, bl, m[7], 0xa953fd4e, 6); el = rotl(el, 10)\n bl = fn5(bl, cl, dl, el, al, m[12], 0xa953fd4e, 8); dl = rotl(dl, 10)\n al = fn5(al, bl, cl, dl, el, m[2], 0xa953fd4e, 13); cl = rotl(cl, 10)\n el = fn5(el, al, bl, cl, dl, m[10], 0xa953fd4e, 12); bl = rotl(bl, 10)\n dl = fn5(dl, el, al, bl, cl, m[14], 0xa953fd4e, 5); al = rotl(al, 10)\n cl = fn5(cl, dl, el, al, bl, m[1], 0xa953fd4e, 12); el = rotl(el, 10)\n bl = fn5(bl, cl, dl, el, al, m[3], 0xa953fd4e, 13); dl = rotl(dl, 10)\n al = fn5(al, bl, cl, dl, el, m[8], 0xa953fd4e, 14); cl = rotl(cl, 10)\n el = fn5(el, al, bl, cl, dl, m[11], 0xa953fd4e, 11); bl = rotl(bl, 10)\n dl = fn5(dl, el, al, bl, cl, m[6], 0xa953fd4e, 8); al = rotl(al, 10)\n cl = fn5(cl, dl, el, al, bl, m[15], 0xa953fd4e, 5); el = rotl(el, 10)\n bl = fn5(bl, cl, dl, el, al, m[13], 0xa953fd4e, 6); dl = rotl(dl, 10)\n\n var ar = this._a\n var br = this._b\n var cr = this._c\n var dr = this._d\n var er = this._e\n\n // M'j = 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12\n // K' = 0x50a28be6\n // S'j = 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6\n ar = fn5(ar, br, cr, dr, er, m[5], 0x50a28be6, 8); cr = rotl(cr, 10)\n er = fn5(er, ar, br, cr, dr, m[14], 0x50a28be6, 9); br = rotl(br, 10)\n dr = fn5(dr, er, ar, br, cr, m[7], 0x50a28be6, 9); ar = rotl(ar, 10)\n cr = fn5(cr, dr, er, ar, br, m[0], 0x50a28be6, 11); er = rotl(er, 10)\n br = fn5(br, cr, dr, er, ar, m[9], 0x50a28be6, 13); dr = rotl(dr, 10)\n ar = fn5(ar, br, cr, dr, er, m[2], 0x50a28be6, 15); cr = rotl(cr, 10)\n er = fn5(er, ar, br, cr, dr, m[11], 0x50a28be6, 15); br = rotl(br, 10)\n dr = fn5(dr, er, ar, br, cr, m[4], 0x50a28be6, 5); ar = rotl(ar, 10)\n cr = fn5(cr, dr, er, ar, br, m[13], 0x50a28be6, 7); er = rotl(er, 10)\n br = fn5(br, cr, dr, er, ar, m[6], 0x50a28be6, 7); dr = rotl(dr, 10)\n ar = fn5(ar, br, cr, dr, er, m[15], 0x50a28be6, 8); cr = rotl(cr, 10)\n er = fn5(er, ar, br, cr, dr, m[8], 0x50a28be6, 11); br = rotl(br, 10)\n dr = fn5(dr, er, ar, br, cr, m[1], 0x50a28be6, 14); ar = rotl(ar, 10)\n cr = fn5(cr, dr, er, ar, br, m[10], 0x50a28be6, 14); er = rotl(er, 10)\n br = fn5(br, cr, dr, er, ar, m[3], 0x50a28be6, 12); dr = rotl(dr, 10)\n ar = fn5(ar, br, cr, dr, er, m[12], 0x50a28be6, 6); cr = rotl(cr, 10)\n\n // M'j = 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2\n // K' = 0x5c4dd124\n // S'j = 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11\n er = fn4(er, ar, br, cr, dr, m[6], 0x5c4dd124, 9); br = rotl(br, 10)\n dr = fn4(dr, er, ar, br, cr, m[11], 0x5c4dd124, 13); ar = rotl(ar, 10)\n cr = fn4(cr, dr, er, ar, br, m[3], 0x5c4dd124, 15); er = rotl(er, 10)\n br = fn4(br, cr, dr, er, ar, m[7], 0x5c4dd124, 7); dr = rotl(dr, 10)\n ar = fn4(ar, br, cr, dr, er, m[0], 0x5c4dd124, 12); cr = rotl(cr, 10)\n er = fn4(er, ar, br, cr, dr, m[13], 0x5c4dd124, 8); br = rotl(br, 10)\n dr = fn4(dr, er, ar, br, cr, m[5], 0x5c4dd124, 9); ar = rotl(ar, 10)\n cr = fn4(cr, dr, er, ar, br, m[10], 0x5c4dd124, 11); er = rotl(er, 10)\n br = fn4(br, cr, dr, er, ar, m[14], 0x5c4dd124, 7); dr = rotl(dr, 10)\n ar = fn4(ar, br, cr, dr, er, m[15], 0x5c4dd124, 7); cr = rotl(cr, 10)\n er = fn4(er, ar, br, cr, dr, m[8], 0x5c4dd124, 12); br = rotl(br, 10)\n dr = fn4(dr, er, ar, br, cr, m[12], 0x5c4dd124, 7); ar = rotl(ar, 10)\n cr = fn4(cr, dr, er, ar, br, m[4], 0x5c4dd124, 6); er = rotl(er, 10)\n br = fn4(br, cr, dr, er, ar, m[9], 0x5c4dd124, 15); dr = rotl(dr, 10)\n ar = fn4(ar, br, cr, dr, er, m[1], 0x5c4dd124, 13); cr = rotl(cr, 10)\n er = fn4(er, ar, br, cr, dr, m[2], 0x5c4dd124, 11); br = rotl(br, 10)\n\n // M'j = 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13\n // K' = 0x6d703ef3\n // S'j = 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5\n dr = fn3(dr, er, ar, br, cr, m[15], 0x6d703ef3, 9); ar = rotl(ar, 10)\n cr = fn3(cr, dr, er, ar, br, m[5], 0x6d703ef3, 7); er = rotl(er, 10)\n br = fn3(br, cr, dr, er, ar, m[1], 0x6d703ef3, 15); dr = rotl(dr, 10)\n ar = fn3(ar, br, cr, dr, er, m[3], 0x6d703ef3, 11); cr = rotl(cr, 10)\n er = fn3(er, ar, br, cr, dr, m[7], 0x6d703ef3, 8); br = rotl(br, 10)\n dr = fn3(dr, er, ar, br, cr, m[14], 0x6d703ef3, 6); ar = rotl(ar, 10)\n cr = fn3(cr, dr, er, ar, br, m[6], 0x6d703ef3, 6); er = rotl(er, 10)\n br = fn3(br, cr, dr, er, ar, m[9], 0x6d703ef3, 14); dr = rotl(dr, 10)\n ar = fn3(ar, br, cr, dr, er, m[11], 0x6d703ef3, 12); cr = rotl(cr, 10)\n er = fn3(er, ar, br, cr, dr, m[8], 0x6d703ef3, 13); br = rotl(br, 10)\n dr = fn3(dr, er, ar, br, cr, m[12], 0x6d703ef3, 5); ar = rotl(ar, 10)\n cr = fn3(cr, dr, er, ar, br, m[2], 0x6d703ef3, 14); er = rotl(er, 10)\n br = fn3(br, cr, dr, er, ar, m[10], 0x6d703ef3, 13); dr = rotl(dr, 10)\n ar = fn3(ar, br, cr, dr, er, m[0], 0x6d703ef3, 13); cr = rotl(cr, 10)\n er = fn3(er, ar, br, cr, dr, m[4], 0x6d703ef3, 7); br = rotl(br, 10)\n dr = fn3(dr, er, ar, br, cr, m[13], 0x6d703ef3, 5); ar = rotl(ar, 10)\n\n // M'j = 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14\n // K' = 0x7a6d76e9\n // S'j = 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8\n cr = fn2(cr, dr, er, ar, br, m[8], 0x7a6d76e9, 15); er = rotl(er, 10)\n br = fn2(br, cr, dr, er, ar, m[6], 0x7a6d76e9, 5); dr = rotl(dr, 10)\n ar = fn2(ar, br, cr, dr, er, m[4], 0x7a6d76e9, 8); cr = rotl(cr, 10)\n er = fn2(er, ar, br, cr, dr, m[1], 0x7a6d76e9, 11); br = rotl(br, 10)\n dr = fn2(dr, er, ar, br, cr, m[3], 0x7a6d76e9, 14); ar = rotl(ar, 10)\n cr = fn2(cr, dr, er, ar, br, m[11], 0x7a6d76e9, 14); er = rotl(er, 10)\n br = fn2(br, cr, dr, er, ar, m[15], 0x7a6d76e9, 6); dr = rotl(dr, 10)\n ar = fn2(ar, br, cr, dr, er, m[0], 0x7a6d76e9, 14); cr = rotl(cr, 10)\n er = fn2(er, ar, br, cr, dr, m[5], 0x7a6d76e9, 6); br = rotl(br, 10)\n dr = fn2(dr, er, ar, br, cr, m[12], 0x7a6d76e9, 9); ar = rotl(ar, 10)\n cr = fn2(cr, dr, er, ar, br, m[2], 0x7a6d76e9, 12); er = rotl(er, 10)\n br = fn2(br, cr, dr, er, ar, m[13], 0x7a6d76e9, 9); dr = rotl(dr, 10)\n ar = fn2(ar, br, cr, dr, er, m[9], 0x7a6d76e9, 12); cr = rotl(cr, 10)\n er = fn2(er, ar, br, cr, dr, m[7], 0x7a6d76e9, 5); br = rotl(br, 10)\n dr = fn2(dr, er, ar, br, cr, m[10], 0x7a6d76e9, 15); ar = rotl(ar, 10)\n cr = fn2(cr, dr, er, ar, br, m[14], 0x7a6d76e9, 8); er = rotl(er, 10)\n\n // M'j = 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n // K' = 0x00000000\n // S'j = 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n br = fn1(br, cr, dr, er, ar, m[12], 0x00000000, 8); dr = rotl(dr, 10)\n ar = fn1(ar, br, cr, dr, er, m[15], 0x00000000, 5); cr = rotl(cr, 10)\n er = fn1(er, ar, br, cr, dr, m[10], 0x00000000, 12); br = rotl(br, 10)\n dr = fn1(dr, er, ar, br, cr, m[4], 0x00000000, 9); ar = rotl(ar, 10)\n cr = fn1(cr, dr, er, ar, br, m[1], 0x00000000, 12); er = rotl(er, 10)\n br = fn1(br, cr, dr, er, ar, m[5], 0x00000000, 5); dr = rotl(dr, 10)\n ar = fn1(ar, br, cr, dr, er, m[8], 0x00000000, 14); cr = rotl(cr, 10)\n er = fn1(er, ar, br, cr, dr, m[7], 0x00000000, 6); br = rotl(br, 10)\n dr = fn1(dr, er, ar, br, cr, m[6], 0x00000000, 8); ar = rotl(ar, 10)\n cr = fn1(cr, dr, er, ar, br, m[2], 0x00000000, 13); er = rotl(er, 10)\n br = fn1(br, cr, dr, er, ar, m[13], 0x00000000, 6); dr = rotl(dr, 10)\n ar = fn1(ar, br, cr, dr, er, m[14], 0x00000000, 5); cr = rotl(cr, 10)\n er = fn1(er, ar, br, cr, dr, m[0], 0x00000000, 15); br = rotl(br, 10)\n dr = fn1(dr, er, ar, br, cr, m[3], 0x00000000, 13); ar = rotl(ar, 10)\n cr = fn1(cr, dr, er, ar, br, m[9], 0x00000000, 11); er = rotl(er, 10)\n br = fn1(br, cr, dr, er, ar, m[11], 0x00000000, 11); dr = rotl(dr, 10)\n\n // change state\n var t = (this._b + cl + dr) | 0\n this._b = (this._c + dl + er) | 0\n this._c = (this._d + el + ar) | 0\n this._d = (this._e + al + br) | 0\n this._e = (this._a + bl + cr) | 0\n this._a = t\n}\n\nRIPEMD160.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = new Buffer(20)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n buffer.writeInt32LE(this._e, 16)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fn1 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn2 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn3 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b | (~c)) ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn4 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn5 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ (c | (~d))) + m + k) | 0, s) + e) | 0\n}\n\nmodule.exports = RIPEMD160\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar toBuffer = require('to-buffer');\n\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = useUint8Array && typeof ArrayBuffer !== 'undefined';\nvar isView = useArrayBuffer && ArrayBuffer.isView;\n\nmodule.exports = function (thing, encoding, name) {\n\tif (\n\t\ttypeof thing === 'string'\n\t\t|| Buffer.isBuffer(thing)\n\t\t|| (useUint8Array && thing instanceof Uint8Array)\n\t\t|| (isView && isView(thing))\n\t) {\n\t\treturn toBuffer(thing, encoding);\n\t}\n\tthrow new TypeError(name + ' must be a string, a Buffer, a Uint8Array, or a DataView');\n};\n","'use strict';\n\nvar md5 = require('create-hash/md5');\nvar RIPEMD160 = require('ripemd160');\nvar sha = require('sha.js');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar checkParameters = require('./precondition');\nvar defaultEncoding = require('./default-encoding');\nvar toBuffer = require('./to-buffer');\n\nvar ZEROS = Buffer.alloc(128);\nvar sizes = {\n\t__proto__: null,\n\tmd5: 16,\n\tsha1: 20,\n\tsha224: 28,\n\tsha256: 32,\n\tsha384: 48,\n\tsha512: 64,\n\t'sha512-256': 32,\n\tripemd160: 20,\n\trmd160: 20\n};\n\nvar mapping = {\n\t__proto__: null,\n\t'sha-1': 'sha1',\n\t'sha-224': 'sha224',\n\t'sha-256': 'sha256',\n\t'sha-384': 'sha384',\n\t'sha-512': 'sha512',\n\t'ripemd-160': 'ripemd160'\n};\n\nfunction rmd160Func(data) {\n\treturn new RIPEMD160().update(data).digest();\n}\n\nfunction getDigest(alg) {\n\tfunction shaFunc(data) {\n\t\treturn sha(alg).update(data).digest();\n\t}\n\n\tif (alg === 'rmd160' || alg === 'ripemd160') {\n\t\treturn rmd160Func;\n\t}\n\tif (alg === 'md5') {\n\t\treturn md5;\n\t}\n\treturn shaFunc;\n}\n\nfunction Hmac(alg, key, saltLen) {\n\tvar hash = getDigest(alg);\n\tvar blocksize = alg === 'sha512' || alg === 'sha384' ? 128 : 64;\n\n\tif (key.length > blocksize) {\n\t\tkey = hash(key);\n\t} else if (key.length < blocksize) {\n\t\tkey = Buffer.concat([key, ZEROS], blocksize);\n\t}\n\n\tvar ipad = Buffer.allocUnsafe(blocksize + sizes[alg]);\n\tvar opad = Buffer.allocUnsafe(blocksize + sizes[alg]);\n\tfor (var i = 0; i < blocksize; i++) {\n\t\tipad[i] = key[i] ^ 0x36;\n\t\topad[i] = key[i] ^ 0x5C;\n\t}\n\n\tvar ipad1 = Buffer.allocUnsafe(blocksize + saltLen + 4);\n\tipad.copy(ipad1, 0, 0, blocksize);\n\tthis.ipad1 = ipad1;\n\tthis.ipad2 = ipad;\n\tthis.opad = opad;\n\tthis.alg = alg;\n\tthis.blocksize = blocksize;\n\tthis.hash = hash;\n\tthis.size = sizes[alg];\n}\n\nHmac.prototype.run = function (data, ipad) {\n\tdata.copy(ipad, this.blocksize);\n\tvar h = this.hash(ipad);\n\th.copy(this.opad, this.blocksize);\n\treturn this.hash(this.opad);\n};\n\nfunction pbkdf2(password, salt, iterations, keylen, digest) {\n\tcheckParameters(iterations, keylen);\n\tpassword = toBuffer(password, defaultEncoding, 'Password');\n\tsalt = toBuffer(salt, defaultEncoding, 'Salt');\n\n\tvar lowerDigest = (digest || 'sha1').toLowerCase();\n\tvar mappedDigest = mapping[lowerDigest] || lowerDigest;\n\tvar size = sizes[mappedDigest];\n\tif (typeof size !== 'number' || !size) {\n\t\tthrow new TypeError('Digest algorithm not supported: ' + digest);\n\t}\n\n\tvar hmac = new Hmac(mappedDigest, password, salt.length);\n\n\tvar DK = Buffer.allocUnsafe(keylen);\n\tvar block1 = Buffer.allocUnsafe(salt.length + 4);\n\tsalt.copy(block1, 0, 0, salt.length);\n\n\tvar destPos = 0;\n\tvar hLen = size;\n\tvar l = Math.ceil(keylen / hLen);\n\n\tfor (var i = 1; i <= l; i++) {\n\t\tblock1.writeUInt32BE(i, salt.length);\n\n\t\tvar T = hmac.run(block1, hmac.ipad1);\n\t\tvar U = T;\n\n\t\tfor (var j = 1; j < iterations; j++) {\n\t\t\tU = hmac.run(U, hmac.ipad2);\n\t\t\tfor (var k = 0; k < hLen; k++) {\n\t\t\t\tT[k] ^= U[k];\n\t\t\t}\n\t\t}\n\n\t\tT.copy(DK, destPos);\n\t\tdestPos += hLen;\n\t}\n\n\treturn DK;\n}\n\nmodule.exports = pbkdf2;\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\n\nvar checkParameters = require('./precondition');\nvar defaultEncoding = require('./default-encoding');\nvar sync = require('./sync');\nvar toBuffer = require('./to-buffer');\n\nvar ZERO_BUF;\nvar subtle = global.crypto && global.crypto.subtle;\nvar toBrowser = {\n\tsha: 'SHA-1',\n\t'sha-1': 'SHA-1',\n\tsha1: 'SHA-1',\n\tsha256: 'SHA-256',\n\t'sha-256': 'SHA-256',\n\tsha384: 'SHA-384',\n\t'sha-384': 'SHA-384',\n\t'sha-512': 'SHA-512',\n\tsha512: 'SHA-512'\n};\nvar checks = [];\nvar nextTick;\nfunction getNextTick() {\n\tif (nextTick) {\n\t\treturn nextTick;\n\t}\n\tif (global.process && global.process.nextTick) {\n\t\tnextTick = global.process.nextTick;\n\t} else if (global.queueMicrotask) {\n\t\tnextTick = global.queueMicrotask;\n\t} else if (global.setImmediate) {\n\t\tnextTick = global.setImmediate;\n\t} else {\n\t\tnextTick = global.setTimeout;\n\t}\n\treturn nextTick;\n}\nfunction browserPbkdf2(password, salt, iterations, length, algo) {\n\treturn subtle.importKey('raw', password, { name: 'PBKDF2' }, false, ['deriveBits']).then(function (key) {\n\t\treturn subtle.deriveBits({\n\t\t\tname: 'PBKDF2',\n\t\t\tsalt: salt,\n\t\t\titerations: iterations,\n\t\t\thash: {\n\t\t\t\tname: algo\n\t\t\t}\n\t\t}, key, length << 3);\n\t}).then(function (res) {\n\t\treturn Buffer.from(res);\n\t});\n}\nfunction checkNative(algo) {\n\tif (global.process && !global.process.browser) {\n\t\treturn Promise.resolve(false);\n\t}\n\tif (!subtle || !subtle.importKey || !subtle.deriveBits) {\n\t\treturn Promise.resolve(false);\n\t}\n\tif (checks[algo] !== undefined) {\n\t\treturn checks[algo];\n\t}\n\tZERO_BUF = ZERO_BUF || Buffer.alloc(8);\n\tvar prom = browserPbkdf2(ZERO_BUF, ZERO_BUF, 10, 128, algo)\n\t\t.then(\n\t\t\tfunction () { return true; },\n\t\t\tfunction () { return false; }\n\t\t);\n\tchecks[algo] = prom;\n\treturn prom;\n}\n\nfunction resolvePromise(promise, callback) {\n\tpromise.then(function (out) {\n\t\tgetNextTick()(function () {\n\t\t\tcallback(null, out);\n\t\t});\n\t}, function (e) {\n\t\tgetNextTick()(function () {\n\t\t\tcallback(e);\n\t\t});\n\t});\n}\nmodule.exports = function (password, salt, iterations, keylen, digest, callback) {\n\tif (typeof digest === 'function') {\n\t\tcallback = digest;\n\t\tdigest = undefined;\n\t}\n\n\tdigest = digest || 'sha1';\n\tvar algo = toBrowser[digest.toLowerCase()];\n\n\tif (!algo || typeof global.Promise !== 'function') {\n\t\tgetNextTick()(function () {\n\t\t\tvar out;\n\t\t\ttry {\n\t\t\t\tout = sync(password, salt, iterations, keylen, digest);\n\t\t\t} catch (e) {\n\t\t\t\tcallback(e);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tcallback(null, out);\n\t\t});\n\t\treturn;\n\t}\n\n\tcheckParameters(iterations, keylen);\n\tpassword = toBuffer(password, defaultEncoding, 'Password');\n\tsalt = toBuffer(salt, defaultEncoding, 'Salt');\n\tif (typeof callback !== 'function') {\n\t\tthrow new Error('No callback provided to pbkdf2');\n\t}\n\n\tresolvePromise(checkNative(algo).then(function (resp) {\n\t\tif (resp) {\n\t\t\treturn browserPbkdf2(password, salt, iterations, keylen, algo);\n\t\t}\n\n\t\treturn sync(password, salt, iterations, keylen, digest);\n\t}), callback);\n};\n","'use strict';\n\nexports.pbkdf2 = require('./lib/async');\nexports.pbkdf2Sync = require('./lib/sync');\n","'use strict';\n\nexports.readUInt32BE = function readUInt32BE(bytes, off) {\n var res = (bytes[0 + off] << 24) |\n (bytes[1 + off] << 16) |\n (bytes[2 + off] << 8) |\n bytes[3 + off];\n return res >>> 0;\n};\n\nexports.writeUInt32BE = function writeUInt32BE(bytes, value, off) {\n bytes[0 + off] = value >>> 24;\n bytes[1 + off] = (value >>> 16) & 0xff;\n bytes[2 + off] = (value >>> 8) & 0xff;\n bytes[3 + off] = value & 0xff;\n};\n\nexports.ip = function ip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n }\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.rip = function rip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 0; i < 4; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n for (var i = 4; i < 8; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.pc1 = function pc1(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n // 7, 15, 23, 31, 39, 47, 55, 63\n // 6, 14, 22, 30, 39, 47, 55, 63\n // 5, 13, 21, 29, 39, 47, 55, 63\n // 4, 12, 20, 28\n for (var i = 7; i >= 5; i--) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n\n // 1, 9, 17, 25, 33, 41, 49, 57\n // 2, 10, 18, 26, 34, 42, 50, 58\n // 3, 11, 19, 27, 35, 43, 51, 59\n // 36, 44, 52, 60\n for (var i = 1; i <= 3; i++) {\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.r28shl = function r28shl(num, shift) {\n return ((num << shift) & 0xfffffff) | (num >>> (28 - shift));\n};\n\nvar pc2table = [\n // inL => outL\n 14, 11, 17, 4, 27, 23, 25, 0,\n 13, 22, 7, 18, 5, 9, 16, 24,\n 2, 20, 12, 21, 1, 8, 15, 26,\n\n // inR => outR\n 15, 4, 25, 19, 9, 1, 26, 16,\n 5, 11, 23, 8, 12, 7, 17, 0,\n 22, 3, 10, 14, 6, 20, 27, 24\n];\n\nexports.pc2 = function pc2(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n var len = pc2table.length >>> 1;\n for (var i = 0; i < len; i++) {\n outL <<= 1;\n outL |= (inL >>> pc2table[i]) & 0x1;\n }\n for (var i = len; i < pc2table.length; i++) {\n outR <<= 1;\n outR |= (inR >>> pc2table[i]) & 0x1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.expand = function expand(r, out, off) {\n var outL = 0;\n var outR = 0;\n\n outL = ((r & 1) << 5) | (r >>> 27);\n for (var i = 23; i >= 15; i -= 4) {\n outL <<= 6;\n outL |= (r >>> i) & 0x3f;\n }\n for (var i = 11; i >= 3; i -= 4) {\n outR |= (r >>> i) & 0x3f;\n outR <<= 6;\n }\n outR |= ((r & 0x1f) << 1) | (r >>> 31);\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nvar sTable = [\n 14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1,\n 3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8,\n 4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7,\n 15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13,\n\n 15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14,\n 9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5,\n 0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2,\n 5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9,\n\n 10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10,\n 1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1,\n 13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7,\n 11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12,\n\n 7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3,\n 1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9,\n 10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8,\n 15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14,\n\n 2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1,\n 8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6,\n 4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13,\n 15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3,\n\n 12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5,\n 0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8,\n 9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10,\n 7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13,\n\n 4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10,\n 3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6,\n 1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7,\n 10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12,\n\n 13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4,\n 10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2,\n 7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13,\n 0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11\n];\n\nexports.substitute = function substitute(inL, inR) {\n var out = 0;\n for (var i = 0; i < 4; i++) {\n var b = (inL >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n for (var i = 0; i < 4; i++) {\n var b = (inR >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[4 * 0x40 + i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n return out >>> 0;\n};\n\nvar permuteTable = [\n 16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22,\n 30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7\n];\n\nexports.permute = function permute(num) {\n var out = 0;\n for (var i = 0; i < permuteTable.length; i++) {\n out <<= 1;\n out |= (num >>> permuteTable[i]) & 0x1;\n }\n return out >>> 0;\n};\n\nexports.padSplit = function padSplit(num, size, group) {\n var str = num.toString(2);\n while (str.length < size)\n str = '0' + str;\n\n var out = [];\n for (var i = 0; i < size; i += group)\n out.push(str.slice(i, i + group));\n return out.join(' ');\n};\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\n\nfunction Cipher(options) {\n this.options = options;\n\n this.type = this.options.type;\n this.blockSize = 8;\n this._init();\n\n this.buffer = new Array(this.blockSize);\n this.bufferOff = 0;\n this.padding = options.padding !== false\n}\nmodule.exports = Cipher;\n\nCipher.prototype._init = function _init() {\n // Might be overrided\n};\n\nCipher.prototype.update = function update(data) {\n if (data.length === 0)\n return [];\n\n if (this.type === 'decrypt')\n return this._updateDecrypt(data);\n else\n return this._updateEncrypt(data);\n};\n\nCipher.prototype._buffer = function _buffer(data, off) {\n // Append data to buffer\n var min = Math.min(this.buffer.length - this.bufferOff, data.length - off);\n for (var i = 0; i < min; i++)\n this.buffer[this.bufferOff + i] = data[off + i];\n this.bufferOff += min;\n\n // Shift next\n return min;\n};\n\nCipher.prototype._flushBuffer = function _flushBuffer(out, off) {\n this._update(this.buffer, 0, out, off);\n this.bufferOff = 0;\n return this.blockSize;\n};\n\nCipher.prototype._updateEncrypt = function _updateEncrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = ((this.bufferOff + data.length) / this.blockSize) | 0;\n var out = new Array(count * this.blockSize);\n\n if (this.bufferOff !== 0) {\n inputOff += this._buffer(data, inputOff);\n\n if (this.bufferOff === this.buffer.length)\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Write blocks\n var max = data.length - ((data.length - inputOff) % this.blockSize);\n for (; inputOff < max; inputOff += this.blockSize) {\n this._update(data, inputOff, out, outputOff);\n outputOff += this.blockSize;\n }\n\n // Queue rest\n for (; inputOff < data.length; inputOff++, this.bufferOff++)\n this.buffer[this.bufferOff] = data[inputOff];\n\n return out;\n};\n\nCipher.prototype._updateDecrypt = function _updateDecrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = Math.ceil((this.bufferOff + data.length) / this.blockSize) - 1;\n var out = new Array(count * this.blockSize);\n\n // TODO(indutny): optimize it, this is far from optimal\n for (; count > 0; count--) {\n inputOff += this._buffer(data, inputOff);\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Buffer rest of the input\n inputOff += this._buffer(data, inputOff);\n\n return out;\n};\n\nCipher.prototype.final = function final(buffer) {\n var first;\n if (buffer)\n first = this.update(buffer);\n\n var last;\n if (this.type === 'encrypt')\n last = this._finalEncrypt();\n else\n last = this._finalDecrypt();\n\n if (first)\n return first.concat(last);\n else\n return last;\n};\n\nCipher.prototype._pad = function _pad(buffer, off) {\n if (off === 0)\n return false;\n\n while (off < buffer.length)\n buffer[off++] = 0;\n\n return true;\n};\n\nCipher.prototype._finalEncrypt = function _finalEncrypt() {\n if (!this._pad(this.buffer, this.bufferOff))\n return [];\n\n var out = new Array(this.blockSize);\n this._update(this.buffer, 0, out, 0);\n return out;\n};\n\nCipher.prototype._unpad = function _unpad(buffer) {\n return buffer;\n};\n\nCipher.prototype._finalDecrypt = function _finalDecrypt() {\n assert.equal(this.bufferOff, this.blockSize, 'Not enough data to decrypt');\n var out = new Array(this.blockSize);\n this._flushBuffer(out, 0);\n\n return this._unpad(out);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar utils = require('./utils');\nvar Cipher = require('./cipher');\n\nfunction DESState() {\n this.tmp = new Array(2);\n this.keys = null;\n}\n\nfunction DES(options) {\n Cipher.call(this, options);\n\n var state = new DESState();\n this._desState = state;\n\n this.deriveKeys(state, options.key);\n}\ninherits(DES, Cipher);\nmodule.exports = DES;\n\nDES.create = function create(options) {\n return new DES(options);\n};\n\nvar shiftTable = [\n 1, 1, 2, 2, 2, 2, 2, 2,\n 1, 2, 2, 2, 2, 2, 2, 1\n];\n\nDES.prototype.deriveKeys = function deriveKeys(state, key) {\n state.keys = new Array(16 * 2);\n\n assert.equal(key.length, this.blockSize, 'Invalid key length');\n\n var kL = utils.readUInt32BE(key, 0);\n var kR = utils.readUInt32BE(key, 4);\n\n utils.pc1(kL, kR, state.tmp, 0);\n kL = state.tmp[0];\n kR = state.tmp[1];\n for (var i = 0; i < state.keys.length; i += 2) {\n var shift = shiftTable[i >>> 1];\n kL = utils.r28shl(kL, shift);\n kR = utils.r28shl(kR, shift);\n utils.pc2(kL, kR, state.keys, i);\n }\n};\n\nDES.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._desState;\n\n var l = utils.readUInt32BE(inp, inOff);\n var r = utils.readUInt32BE(inp, inOff + 4);\n\n // Initial Permutation\n utils.ip(l, r, state.tmp, 0);\n l = state.tmp[0];\n r = state.tmp[1];\n\n if (this.type === 'encrypt')\n this._encrypt(state, l, r, state.tmp, 0);\n else\n this._decrypt(state, l, r, state.tmp, 0);\n\n l = state.tmp[0];\n r = state.tmp[1];\n\n utils.writeUInt32BE(out, l, outOff);\n utils.writeUInt32BE(out, r, outOff + 4);\n};\n\nDES.prototype._pad = function _pad(buffer, off) {\n if (this.padding === false) {\n return false;\n }\n\n var value = buffer.length - off;\n for (var i = off; i < buffer.length; i++)\n buffer[i] = value;\n\n return true;\n};\n\nDES.prototype._unpad = function _unpad(buffer) {\n if (this.padding === false) {\n return buffer;\n }\n\n var pad = buffer[buffer.length - 1];\n for (var i = buffer.length - pad; i < buffer.length; i++)\n assert.equal(buffer[i], pad);\n\n return buffer.slice(0, buffer.length - pad);\n};\n\nDES.prototype._encrypt = function _encrypt(state, lStart, rStart, out, off) {\n var l = lStart;\n var r = rStart;\n\n // Apply f() x16 times\n for (var i = 0; i < state.keys.length; i += 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(r, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = r;\n r = (l ^ f) >>> 0;\n l = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(r, l, out, off);\n};\n\nDES.prototype._decrypt = function _decrypt(state, lStart, rStart, out, off) {\n var l = rStart;\n var r = lStart;\n\n // Apply f() x16 times\n for (var i = state.keys.length - 2; i >= 0; i -= 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(l, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = l;\n l = (r ^ f) >>> 0;\n r = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(l, r, out, off);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar proto = {};\n\nfunction CBCState(iv) {\n assert.equal(iv.length, 8, 'Invalid IV length');\n\n this.iv = new Array(8);\n for (var i = 0; i < this.iv.length; i++)\n this.iv[i] = iv[i];\n}\n\nfunction instantiate(Base) {\n function CBC(options) {\n Base.call(this, options);\n this._cbcInit();\n }\n inherits(CBC, Base);\n\n var keys = Object.keys(proto);\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n CBC.prototype[key] = proto[key];\n }\n\n CBC.create = function create(options) {\n return new CBC(options);\n };\n\n return CBC;\n}\n\nexports.instantiate = instantiate;\n\nproto._cbcInit = function _cbcInit() {\n var state = new CBCState(this.options.iv);\n this._cbcState = state;\n};\n\nproto._update = function _update(inp, inOff, out, outOff) {\n var state = this._cbcState;\n var superProto = this.constructor.super_.prototype;\n\n var iv = state.iv;\n if (this.type === 'encrypt') {\n for (var i = 0; i < this.blockSize; i++)\n iv[i] ^= inp[inOff + i];\n\n superProto._update.call(this, iv, 0, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = out[outOff + i];\n } else {\n superProto._update.call(this, inp, inOff, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n out[outOff + i] ^= iv[i];\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = inp[inOff + i];\n }\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar Cipher = require('./cipher');\nvar DES = require('./des');\n\nfunction EDEState(type, key) {\n assert.equal(key.length, 24, 'Invalid key length');\n\n var k1 = key.slice(0, 8);\n var k2 = key.slice(8, 16);\n var k3 = key.slice(16, 24);\n\n if (type === 'encrypt') {\n this.ciphers = [\n DES.create({ type: 'encrypt', key: k1 }),\n DES.create({ type: 'decrypt', key: k2 }),\n DES.create({ type: 'encrypt', key: k3 })\n ];\n } else {\n this.ciphers = [\n DES.create({ type: 'decrypt', key: k3 }),\n DES.create({ type: 'encrypt', key: k2 }),\n DES.create({ type: 'decrypt', key: k1 })\n ];\n }\n}\n\nfunction EDE(options) {\n Cipher.call(this, options);\n\n var state = new EDEState(this.type, this.options.key);\n this._edeState = state;\n}\ninherits(EDE, Cipher);\n\nmodule.exports = EDE;\n\nEDE.create = function create(options) {\n return new EDE(options);\n};\n\nEDE.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._edeState;\n\n state.ciphers[0]._update(inp, inOff, out, outOff);\n state.ciphers[1]._update(out, outOff, out, outOff);\n state.ciphers[2]._update(out, outOff, out, outOff);\n};\n\nEDE.prototype._pad = DES.prototype._pad;\nEDE.prototype._unpad = DES.prototype._unpad;\n","'use strict';\n\nexports.utils = require('./des/utils');\nexports.Cipher = require('./des/cipher');\nexports.DES = require('./des/des');\nexports.CBC = require('./des/cbc');\nexports.EDE = require('./des/ede');\n","var CipherBase = require('cipher-base')\nvar des = require('des.js')\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar modes = {\n 'des-ede3-cbc': des.CBC.instantiate(des.EDE),\n 'des-ede3': des.EDE,\n 'des-ede-cbc': des.CBC.instantiate(des.EDE),\n 'des-ede': des.EDE,\n 'des-cbc': des.CBC.instantiate(des.DES),\n 'des-ecb': des.DES\n}\nmodes.des = modes['des-cbc']\nmodes.des3 = modes['des-ede3-cbc']\nmodule.exports = DES\ninherits(DES, CipherBase)\nfunction DES (opts) {\n CipherBase.call(this)\n var modeName = opts.mode.toLowerCase()\n var mode = modes[modeName]\n var type\n if (opts.decrypt) {\n type = 'decrypt'\n } else {\n type = 'encrypt'\n }\n var key = opts.key\n if (!Buffer.isBuffer(key)) {\n key = Buffer.from(key)\n }\n if (modeName === 'des-ede' || modeName === 'des-ede-cbc') {\n key = Buffer.concat([key, key.slice(0, 8)])\n }\n var iv = opts.iv\n if (!Buffer.isBuffer(iv)) {\n iv = Buffer.from(iv)\n }\n this._des = mode.create({\n key: key,\n iv: iv,\n type: type\n })\n}\nDES.prototype._update = function (data) {\n return Buffer.from(this._des.update(data))\n}\nDES.prototype._final = function () {\n return Buffer.from(this._des.final())\n}\n","exports.encrypt = function (self, block) {\n return self._cipher.encryptBlock(block)\n}\n\nexports.decrypt = function (self, block) {\n return self._cipher.decryptBlock(block)\n}\n","module.exports = function xor (a, b) {\n var length = Math.min(a.length, b.length)\n var buffer = new Buffer(length)\n\n for (var i = 0; i < length; ++i) {\n buffer[i] = a[i] ^ b[i]\n }\n\n return buffer\n}\n","var xor = require('buffer-xor')\n\nexports.encrypt = function (self, block) {\n var data = xor(block, self._prev)\n\n self._prev = self._cipher.encryptBlock(data)\n return self._prev\n}\n\nexports.decrypt = function (self, block) {\n var pad = self._prev\n\n self._prev = block\n var out = self._cipher.decryptBlock(block)\n\n return xor(out, pad)\n}\n","var Buffer = require('safe-buffer').Buffer\nvar xor = require('buffer-xor')\n\nfunction encryptStart (self, data, decrypt) {\n var len = data.length\n var out = xor(data, self._cache)\n self._cache = self._cache.slice(len)\n self._prev = Buffer.concat([self._prev, decrypt ? data : out])\n return out\n}\n\nexports.encrypt = function (self, data, decrypt) {\n var out = Buffer.allocUnsafe(0)\n var len\n\n while (data.length) {\n if (self._cache.length === 0) {\n self._cache = self._cipher.encryptBlock(self._prev)\n self._prev = Buffer.allocUnsafe(0)\n }\n\n if (self._cache.length <= data.length) {\n len = self._cache.length\n out = Buffer.concat([out, encryptStart(self, data.slice(0, len), decrypt)])\n data = data.slice(len)\n } else {\n out = Buffer.concat([out, encryptStart(self, data, decrypt)])\n break\n }\n }\n\n return out\n}\n","var Buffer = require('safe-buffer').Buffer\n\nfunction encryptByte (self, byteParam, decrypt) {\n var pad = self._cipher.encryptBlock(self._prev)\n var out = pad[0] ^ byteParam\n\n self._prev = Buffer.concat([\n self._prev.slice(1),\n Buffer.from([decrypt ? byteParam : out])\n ])\n\n return out\n}\n\nexports.encrypt = function (self, chunk, decrypt) {\n var len = chunk.length\n var out = Buffer.allocUnsafe(len)\n var i = -1\n\n while (++i < len) {\n out[i] = encryptByte(self, chunk[i], decrypt)\n }\n\n return out\n}\n","var Buffer = require('safe-buffer').Buffer\n\nfunction encryptByte (self, byteParam, decrypt) {\n var pad\n var i = -1\n var len = 8\n var out = 0\n var bit, value\n while (++i < len) {\n pad = self._cipher.encryptBlock(self._prev)\n bit = (byteParam & (1 << (7 - i))) ? 0x80 : 0\n value = pad[0] ^ bit\n out += ((value & 0x80) >> (i % 8))\n self._prev = shiftIn(self._prev, decrypt ? bit : value)\n }\n return out\n}\n\nfunction shiftIn (buffer, value) {\n var len = buffer.length\n var i = -1\n var out = Buffer.allocUnsafe(buffer.length)\n buffer = Buffer.concat([buffer, Buffer.from([value])])\n\n while (++i < len) {\n out[i] = buffer[i] << 1 | buffer[i + 1] >> (7)\n }\n\n return out\n}\n\nexports.encrypt = function (self, chunk, decrypt) {\n var len = chunk.length\n var out = Buffer.allocUnsafe(len)\n var i = -1\n\n while (++i < len) {\n out[i] = encryptByte(self, chunk[i], decrypt)\n }\n\n return out\n}\n","var xor = require('buffer-xor')\n\nfunction getBlock (self) {\n self._prev = self._cipher.encryptBlock(self._prev)\n return self._prev\n}\n\nexports.encrypt = function (self, chunk) {\n while (self._cache.length < chunk.length) {\n self._cache = Buffer.concat([self._cache, getBlock(self)])\n }\n\n var pad = self._cache.slice(0, chunk.length)\n self._cache = self._cache.slice(chunk.length)\n return xor(chunk, pad)\n}\n","function incr32 (iv) {\n var len = iv.length\n var item\n while (len--) {\n item = iv.readUInt8(len)\n if (item === 255) {\n iv.writeUInt8(0, len)\n } else {\n item++\n iv.writeUInt8(item, len)\n break\n }\n }\n}\nmodule.exports = incr32\n","var xor = require('buffer-xor')\nvar Buffer = require('safe-buffer').Buffer\nvar incr32 = require('../incr32')\n\nfunction getBlock (self) {\n var out = self._cipher.encryptBlockRaw(self._prev)\n incr32(self._prev)\n return out\n}\n\nvar blockSize = 16\nexports.encrypt = function (self, chunk) {\n var chunkNum = Math.ceil(chunk.length / blockSize)\n var start = self._cache.length\n self._cache = Buffer.concat([\n self._cache,\n Buffer.allocUnsafe(chunkNum * blockSize)\n ])\n for (var i = 0; i < chunkNum; i++) {\n var out = getBlock(self)\n var offset = start + i * blockSize\n self._cache.writeUInt32BE(out[0], offset + 0)\n self._cache.writeUInt32BE(out[1], offset + 4)\n self._cache.writeUInt32BE(out[2], offset + 8)\n self._cache.writeUInt32BE(out[3], offset + 12)\n }\n var pad = self._cache.slice(0, chunk.length)\n self._cache = self._cache.slice(chunk.length)\n return xor(chunk, pad)\n}\n","var modeModules = {\n ECB: require('./ecb'),\n CBC: require('./cbc'),\n CFB: require('./cfb'),\n CFB8: require('./cfb8'),\n CFB1: require('./cfb1'),\n OFB: require('./ofb'),\n CTR: require('./ctr'),\n GCM: require('./ctr')\n}\n\nvar modes = require('./list.json')\n\nfor (var key in modes) {\n modes[key].module = modeModules[modes[key].mode]\n}\n\nmodule.exports = modes\n","// based on the aes implimentation in triple sec\n// https://github.com/keybase/triplesec\n// which is in turn based on the one from crypto-js\n// https://code.google.com/p/crypto-js/\n\nvar Buffer = require('safe-buffer').Buffer\n\nfunction asUInt32Array (buf) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n\n var len = (buf.length / 4) | 0\n var out = new Array(len)\n\n for (var i = 0; i < len; i++) {\n out[i] = buf.readUInt32BE(i * 4)\n }\n\n return out\n}\n\nfunction scrubVec (v) {\n for (var i = 0; i < v.length; v++) {\n v[i] = 0\n }\n}\n\nfunction cryptBlock (M, keySchedule, SUB_MIX, SBOX, nRounds) {\n var SUB_MIX0 = SUB_MIX[0]\n var SUB_MIX1 = SUB_MIX[1]\n var SUB_MIX2 = SUB_MIX[2]\n var SUB_MIX3 = SUB_MIX[3]\n\n var s0 = M[0] ^ keySchedule[0]\n var s1 = M[1] ^ keySchedule[1]\n var s2 = M[2] ^ keySchedule[2]\n var s3 = M[3] ^ keySchedule[3]\n var t0, t1, t2, t3\n var ksRow = 4\n\n for (var round = 1; round < nRounds; round++) {\n t0 = SUB_MIX0[s0 >>> 24] ^ SUB_MIX1[(s1 >>> 16) & 0xff] ^ SUB_MIX2[(s2 >>> 8) & 0xff] ^ SUB_MIX3[s3 & 0xff] ^ keySchedule[ksRow++]\n t1 = SUB_MIX0[s1 >>> 24] ^ SUB_MIX1[(s2 >>> 16) & 0xff] ^ SUB_MIX2[(s3 >>> 8) & 0xff] ^ SUB_MIX3[s0 & 0xff] ^ keySchedule[ksRow++]\n t2 = SUB_MIX0[s2 >>> 24] ^ SUB_MIX1[(s3 >>> 16) & 0xff] ^ SUB_MIX2[(s0 >>> 8) & 0xff] ^ SUB_MIX3[s1 & 0xff] ^ keySchedule[ksRow++]\n t3 = SUB_MIX0[s3 >>> 24] ^ SUB_MIX1[(s0 >>> 16) & 0xff] ^ SUB_MIX2[(s1 >>> 8) & 0xff] ^ SUB_MIX3[s2 & 0xff] ^ keySchedule[ksRow++]\n s0 = t0\n s1 = t1\n s2 = t2\n s3 = t3\n }\n\n t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++]\n t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++]\n t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++]\n t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++]\n t0 = t0 >>> 0\n t1 = t1 >>> 0\n t2 = t2 >>> 0\n t3 = t3 >>> 0\n\n return [t0, t1, t2, t3]\n}\n\n// AES constants\nvar RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36]\nvar G = (function () {\n // Compute double table\n var d = new Array(256)\n for (var j = 0; j < 256; j++) {\n if (j < 128) {\n d[j] = j << 1\n } else {\n d[j] = (j << 1) ^ 0x11b\n }\n }\n\n var SBOX = []\n var INV_SBOX = []\n var SUB_MIX = [[], [], [], []]\n var INV_SUB_MIX = [[], [], [], []]\n\n // Walk GF(2^8)\n var x = 0\n var xi = 0\n for (var i = 0; i < 256; ++i) {\n // Compute sbox\n var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4)\n sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63\n SBOX[x] = sx\n INV_SBOX[sx] = x\n\n // Compute multiplication\n var x2 = d[x]\n var x4 = d[x2]\n var x8 = d[x4]\n\n // Compute sub bytes, mix columns tables\n var t = (d[sx] * 0x101) ^ (sx * 0x1010100)\n SUB_MIX[0][x] = (t << 24) | (t >>> 8)\n SUB_MIX[1][x] = (t << 16) | (t >>> 16)\n SUB_MIX[2][x] = (t << 8) | (t >>> 24)\n SUB_MIX[3][x] = t\n\n // Compute inv sub bytes, inv mix columns tables\n t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100)\n INV_SUB_MIX[0][sx] = (t << 24) | (t >>> 8)\n INV_SUB_MIX[1][sx] = (t << 16) | (t >>> 16)\n INV_SUB_MIX[2][sx] = (t << 8) | (t >>> 24)\n INV_SUB_MIX[3][sx] = t\n\n if (x === 0) {\n x = xi = 1\n } else {\n x = x2 ^ d[d[d[x8 ^ x2]]]\n xi ^= d[d[xi]]\n }\n }\n\n return {\n SBOX: SBOX,\n INV_SBOX: INV_SBOX,\n SUB_MIX: SUB_MIX,\n INV_SUB_MIX: INV_SUB_MIX\n }\n})()\n\nfunction AES (key) {\n this._key = asUInt32Array(key)\n this._reset()\n}\n\nAES.blockSize = 4 * 4\nAES.keySize = 256 / 8\nAES.prototype.blockSize = AES.blockSize\nAES.prototype.keySize = AES.keySize\nAES.prototype._reset = function () {\n var keyWords = this._key\n var keySize = keyWords.length\n var nRounds = keySize + 6\n var ksRows = (nRounds + 1) * 4\n\n var keySchedule = []\n for (var k = 0; k < keySize; k++) {\n keySchedule[k] = keyWords[k]\n }\n\n for (k = keySize; k < ksRows; k++) {\n var t = keySchedule[k - 1]\n\n if (k % keySize === 0) {\n t = (t << 8) | (t >>> 24)\n t =\n (G.SBOX[t >>> 24] << 24) |\n (G.SBOX[(t >>> 16) & 0xff] << 16) |\n (G.SBOX[(t >>> 8) & 0xff] << 8) |\n (G.SBOX[t & 0xff])\n\n t ^= RCON[(k / keySize) | 0] << 24\n } else if (keySize > 6 && k % keySize === 4) {\n t =\n (G.SBOX[t >>> 24] << 24) |\n (G.SBOX[(t >>> 16) & 0xff] << 16) |\n (G.SBOX[(t >>> 8) & 0xff] << 8) |\n (G.SBOX[t & 0xff])\n }\n\n keySchedule[k] = keySchedule[k - keySize] ^ t\n }\n\n var invKeySchedule = []\n for (var ik = 0; ik < ksRows; ik++) {\n var ksR = ksRows - ik\n var tt = keySchedule[ksR - (ik % 4 ? 0 : 4)]\n\n if (ik < 4 || ksR <= 4) {\n invKeySchedule[ik] = tt\n } else {\n invKeySchedule[ik] =\n G.INV_SUB_MIX[0][G.SBOX[tt >>> 24]] ^\n G.INV_SUB_MIX[1][G.SBOX[(tt >>> 16) & 0xff]] ^\n G.INV_SUB_MIX[2][G.SBOX[(tt >>> 8) & 0xff]] ^\n G.INV_SUB_MIX[3][G.SBOX[tt & 0xff]]\n }\n }\n\n this._nRounds = nRounds\n this._keySchedule = keySchedule\n this._invKeySchedule = invKeySchedule\n}\n\nAES.prototype.encryptBlockRaw = function (M) {\n M = asUInt32Array(M)\n return cryptBlock(M, this._keySchedule, G.SUB_MIX, G.SBOX, this._nRounds)\n}\n\nAES.prototype.encryptBlock = function (M) {\n var out = this.encryptBlockRaw(M)\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0], 0)\n buf.writeUInt32BE(out[1], 4)\n buf.writeUInt32BE(out[2], 8)\n buf.writeUInt32BE(out[3], 12)\n return buf\n}\n\nAES.prototype.decryptBlock = function (M) {\n M = asUInt32Array(M)\n\n // swap\n var m1 = M[1]\n M[1] = M[3]\n M[3] = m1\n\n var out = cryptBlock(M, this._invKeySchedule, G.INV_SUB_MIX, G.INV_SBOX, this._nRounds)\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0], 0)\n buf.writeUInt32BE(out[3], 4)\n buf.writeUInt32BE(out[2], 8)\n buf.writeUInt32BE(out[1], 12)\n return buf\n}\n\nAES.prototype.scrub = function () {\n scrubVec(this._keySchedule)\n scrubVec(this._invKeySchedule)\n scrubVec(this._key)\n}\n\nmodule.exports.AES = AES\n","var Buffer = require('safe-buffer').Buffer\nvar ZEROES = Buffer.alloc(16, 0)\n\nfunction toArray (buf) {\n return [\n buf.readUInt32BE(0),\n buf.readUInt32BE(4),\n buf.readUInt32BE(8),\n buf.readUInt32BE(12)\n ]\n}\n\nfunction fromArray (out) {\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0] >>> 0, 0)\n buf.writeUInt32BE(out[1] >>> 0, 4)\n buf.writeUInt32BE(out[2] >>> 0, 8)\n buf.writeUInt32BE(out[3] >>> 0, 12)\n return buf\n}\n\nfunction GHASH (key) {\n this.h = key\n this.state = Buffer.alloc(16, 0)\n this.cache = Buffer.allocUnsafe(0)\n}\n\n// from http://bitwiseshiftleft.github.io/sjcl/doc/symbols/src/core_gcm.js.html\n// by Juho Vähä-Herttua\nGHASH.prototype.ghash = function (block) {\n var i = -1\n while (++i < block.length) {\n this.state[i] ^= block[i]\n }\n this._multiply()\n}\n\nGHASH.prototype._multiply = function () {\n var Vi = toArray(this.h)\n var Zi = [0, 0, 0, 0]\n var j, xi, lsbVi\n var i = -1\n while (++i < 128) {\n xi = (this.state[~~(i / 8)] & (1 << (7 - (i % 8)))) !== 0\n if (xi) {\n // Z_i+1 = Z_i ^ V_i\n Zi[0] ^= Vi[0]\n Zi[1] ^= Vi[1]\n Zi[2] ^= Vi[2]\n Zi[3] ^= Vi[3]\n }\n\n // Store the value of LSB(V_i)\n lsbVi = (Vi[3] & 1) !== 0\n\n // V_i+1 = V_i >> 1\n for (j = 3; j > 0; j--) {\n Vi[j] = (Vi[j] >>> 1) | ((Vi[j - 1] & 1) << 31)\n }\n Vi[0] = Vi[0] >>> 1\n\n // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R\n if (lsbVi) {\n Vi[0] = Vi[0] ^ (0xe1 << 24)\n }\n }\n this.state = fromArray(Zi)\n}\n\nGHASH.prototype.update = function (buf) {\n this.cache = Buffer.concat([this.cache, buf])\n var chunk\n while (this.cache.length >= 16) {\n chunk = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n this.ghash(chunk)\n }\n}\n\nGHASH.prototype.final = function (abl, bl) {\n if (this.cache.length) {\n this.ghash(Buffer.concat([this.cache, ZEROES], 16))\n }\n\n this.ghash(fromArray([0, abl, 0, bl]))\n return this.state\n}\n\nmodule.exports = GHASH\n","var aes = require('./aes')\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\nvar GHASH = require('./ghash')\nvar xor = require('buffer-xor')\nvar incr32 = require('./incr32')\n\nfunction xorTest (a, b) {\n var out = 0\n if (a.length !== b.length) out++\n\n var len = Math.min(a.length, b.length)\n for (var i = 0; i < len; ++i) {\n out += (a[i] ^ b[i])\n }\n\n return out\n}\n\nfunction calcIv (self, iv, ck) {\n if (iv.length === 12) {\n self._finID = Buffer.concat([iv, Buffer.from([0, 0, 0, 1])])\n return Buffer.concat([iv, Buffer.from([0, 0, 0, 2])])\n }\n var ghash = new GHASH(ck)\n var len = iv.length\n var toPad = len % 16\n ghash.update(iv)\n if (toPad) {\n toPad = 16 - toPad\n ghash.update(Buffer.alloc(toPad, 0))\n }\n ghash.update(Buffer.alloc(8, 0))\n var ivBits = len * 8\n var tail = Buffer.alloc(8)\n tail.writeUIntBE(ivBits, 0, 8)\n ghash.update(tail)\n self._finID = ghash.state\n var out = Buffer.from(self._finID)\n incr32(out)\n return out\n}\nfunction StreamCipher (mode, key, iv, decrypt) {\n Transform.call(this)\n\n var h = Buffer.alloc(4, 0)\n\n this._cipher = new aes.AES(key)\n var ck = this._cipher.encryptBlock(h)\n this._ghash = new GHASH(ck)\n iv = calcIv(this, iv, ck)\n\n this._prev = Buffer.from(iv)\n this._cache = Buffer.allocUnsafe(0)\n this._secCache = Buffer.allocUnsafe(0)\n this._decrypt = decrypt\n this._alen = 0\n this._len = 0\n this._mode = mode\n\n this._authTag = null\n this._called = false\n}\n\ninherits(StreamCipher, Transform)\n\nStreamCipher.prototype._update = function (chunk) {\n if (!this._called && this._alen) {\n var rump = 16 - (this._alen % 16)\n if (rump < 16) {\n rump = Buffer.alloc(rump, 0)\n this._ghash.update(rump)\n }\n }\n\n this._called = true\n var out = this._mode.encrypt(this, chunk)\n if (this._decrypt) {\n this._ghash.update(chunk)\n } else {\n this._ghash.update(out)\n }\n this._len += chunk.length\n return out\n}\n\nStreamCipher.prototype._final = function () {\n if (this._decrypt && !this._authTag) throw new Error('Unsupported state or unable to authenticate data')\n\n var tag = xor(this._ghash.final(this._alen * 8, this._len * 8), this._cipher.encryptBlock(this._finID))\n if (this._decrypt && xorTest(tag, this._authTag)) throw new Error('Unsupported state or unable to authenticate data')\n\n this._authTag = tag\n this._cipher.scrub()\n}\n\nStreamCipher.prototype.getAuthTag = function getAuthTag () {\n if (this._decrypt || !Buffer.isBuffer(this._authTag)) throw new Error('Attempting to get auth tag in unsupported state')\n\n return this._authTag\n}\n\nStreamCipher.prototype.setAuthTag = function setAuthTag (tag) {\n if (!this._decrypt) throw new Error('Attempting to set auth tag in unsupported state')\n\n this._authTag = tag\n}\n\nStreamCipher.prototype.setAAD = function setAAD (buf) {\n if (this._called) throw new Error('Attempting to set AAD in unsupported state')\n\n this._ghash.update(buf)\n this._alen += buf.length\n}\n\nmodule.exports = StreamCipher\n","var aes = require('./aes')\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\n\nfunction StreamCipher (mode, key, iv, decrypt) {\n Transform.call(this)\n\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._cache = Buffer.allocUnsafe(0)\n this._secCache = Buffer.allocUnsafe(0)\n this._decrypt = decrypt\n this._mode = mode\n}\n\ninherits(StreamCipher, Transform)\n\nStreamCipher.prototype._update = function (chunk) {\n return this._mode.encrypt(this, chunk, this._decrypt)\n}\n\nStreamCipher.prototype._final = function () {\n this._cipher.scrub()\n}\n\nmodule.exports = StreamCipher\n","var Buffer = require('safe-buffer').Buffer\nvar MD5 = require('md5.js')\n\n/* eslint-disable camelcase */\nfunction EVP_BytesToKey (password, salt, keyBits, ivLen) {\n if (!Buffer.isBuffer(password)) password = Buffer.from(password, 'binary')\n if (salt) {\n if (!Buffer.isBuffer(salt)) salt = Buffer.from(salt, 'binary')\n if (salt.length !== 8) throw new RangeError('salt should be Buffer with 8 byte length')\n }\n\n var keyLen = keyBits / 8\n var key = Buffer.alloc(keyLen)\n var iv = Buffer.alloc(ivLen || 0)\n var tmp = Buffer.alloc(0)\n\n while (keyLen > 0 || ivLen > 0) {\n var hash = new MD5()\n hash.update(tmp)\n hash.update(password)\n if (salt) hash.update(salt)\n tmp = hash.digest()\n\n var used = 0\n\n if (keyLen > 0) {\n var keyStart = key.length - keyLen\n used = Math.min(keyLen, tmp.length)\n tmp.copy(key, keyStart, 0, used)\n keyLen -= used\n }\n\n if (used < tmp.length && ivLen > 0) {\n var ivStart = iv.length - ivLen\n var length = Math.min(ivLen, tmp.length - used)\n tmp.copy(iv, ivStart, used, used + length)\n ivLen -= length\n }\n }\n\n tmp.fill(0)\n return { key: key, iv: iv }\n}\n\nmodule.exports = EVP_BytesToKey\n","var MODES = require('./modes')\nvar AuthCipher = require('./authCipher')\nvar Buffer = require('safe-buffer').Buffer\nvar StreamCipher = require('./streamCipher')\nvar Transform = require('cipher-base')\nvar aes = require('./aes')\nvar ebtk = require('evp_bytestokey')\nvar inherits = require('inherits')\n\nfunction Cipher (mode, key, iv) {\n Transform.call(this)\n\n this._cache = new Splitter()\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._mode = mode\n this._autopadding = true\n}\n\ninherits(Cipher, Transform)\n\nCipher.prototype._update = function (data) {\n this._cache.add(data)\n var chunk\n var thing\n var out = []\n\n while ((chunk = this._cache.get())) {\n thing = this._mode.encrypt(this, chunk)\n out.push(thing)\n }\n\n return Buffer.concat(out)\n}\n\nvar PADDING = Buffer.alloc(16, 0x10)\n\nCipher.prototype._final = function () {\n var chunk = this._cache.flush()\n if (this._autopadding) {\n chunk = this._mode.encrypt(this, chunk)\n this._cipher.scrub()\n return chunk\n }\n\n if (!chunk.equals(PADDING)) {\n this._cipher.scrub()\n throw new Error('data not multiple of block length')\n }\n}\n\nCipher.prototype.setAutoPadding = function (setTo) {\n this._autopadding = !!setTo\n return this\n}\n\nfunction Splitter () {\n this.cache = Buffer.allocUnsafe(0)\n}\n\nSplitter.prototype.add = function (data) {\n this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function () {\n if (this.cache.length > 15) {\n var out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n return null\n}\n\nSplitter.prototype.flush = function () {\n var len = 16 - this.cache.length\n var padBuff = Buffer.allocUnsafe(len)\n\n var i = -1\n while (++i < len) {\n padBuff.writeUInt8(len, i)\n }\n\n return Buffer.concat([this.cache, padBuff])\n}\n\nfunction createCipheriv (suite, password, iv) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n if (typeof password === 'string') password = Buffer.from(password)\n if (password.length !== config.key / 8) throw new TypeError('invalid key length ' + password.length)\n\n if (typeof iv === 'string') iv = Buffer.from(iv)\n if (config.mode !== 'GCM' && iv.length !== config.iv) throw new TypeError('invalid iv length ' + iv.length)\n\n if (config.type === 'stream') {\n return new StreamCipher(config.module, password, iv)\n } else if (config.type === 'auth') {\n return new AuthCipher(config.module, password, iv)\n }\n\n return new Cipher(config.module, password, iv)\n}\n\nfunction createCipher (suite, password) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n var keys = ebtk(password, false, config.key, config.iv)\n return createCipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createCipheriv = createCipheriv\nexports.createCipher = createCipher\n","var AuthCipher = require('./authCipher')\nvar Buffer = require('safe-buffer').Buffer\nvar MODES = require('./modes')\nvar StreamCipher = require('./streamCipher')\nvar Transform = require('cipher-base')\nvar aes = require('./aes')\nvar ebtk = require('evp_bytestokey')\nvar inherits = require('inherits')\n\nfunction Decipher (mode, key, iv) {\n Transform.call(this)\n\n this._cache = new Splitter()\n this._last = void 0\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._mode = mode\n this._autopadding = true\n}\n\ninherits(Decipher, Transform)\n\nDecipher.prototype._update = function (data) {\n this._cache.add(data)\n var chunk\n var thing\n var out = []\n while ((chunk = this._cache.get(this._autopadding))) {\n thing = this._mode.decrypt(this, chunk)\n out.push(thing)\n }\n return Buffer.concat(out)\n}\n\nDecipher.prototype._final = function () {\n var chunk = this._cache.flush()\n if (this._autopadding) {\n return unpad(this._mode.decrypt(this, chunk))\n } else if (chunk) {\n throw new Error('data not multiple of block length')\n }\n}\n\nDecipher.prototype.setAutoPadding = function (setTo) {\n this._autopadding = !!setTo\n return this\n}\n\nfunction Splitter () {\n this.cache = Buffer.allocUnsafe(0)\n}\n\nSplitter.prototype.add = function (data) {\n this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function (autoPadding) {\n var out\n if (autoPadding) {\n if (this.cache.length > 16) {\n out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n } else {\n if (this.cache.length >= 16) {\n out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n }\n\n return null\n}\n\nSplitter.prototype.flush = function () {\n if (this.cache.length) return this.cache\n}\n\nfunction unpad (last) {\n var padded = last[15]\n if (padded < 1 || padded > 16) {\n throw new Error('unable to decrypt data')\n }\n var i = -1\n while (++i < padded) {\n if (last[(i + (16 - padded))] !== padded) {\n throw new Error('unable to decrypt data')\n }\n }\n if (padded === 16) return\n\n return last.slice(0, 16 - padded)\n}\n\nfunction createDecipheriv (suite, password, iv) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n if (typeof iv === 'string') iv = Buffer.from(iv)\n if (config.mode !== 'GCM' && iv.length !== config.iv) throw new TypeError('invalid iv length ' + iv.length)\n\n if (typeof password === 'string') password = Buffer.from(password)\n if (password.length !== config.key / 8) throw new TypeError('invalid key length ' + password.length)\n\n if (config.type === 'stream') {\n return new StreamCipher(config.module, password, iv, true)\n } else if (config.type === 'auth') {\n return new AuthCipher(config.module, password, iv, true)\n }\n\n return new Decipher(config.module, password, iv)\n}\n\nfunction createDecipher (suite, password) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n var keys = ebtk(password, false, config.key, config.iv)\n return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createDecipher = createDecipher\nexports.createDecipheriv = createDecipheriv\n","var ciphers = require('./encrypter')\nvar deciphers = require('./decrypter')\nvar modes = require('./modes/list.json')\n\nfunction getCiphers () {\n return Object.keys(modes)\n}\n\nexports.createCipher = exports.Cipher = ciphers.createCipher\nexports.createCipheriv = exports.Cipheriv = ciphers.createCipheriv\nexports.createDecipher = exports.Decipher = deciphers.createDecipher\nexports.createDecipheriv = exports.Decipheriv = deciphers.createDecipheriv\nexports.listCiphers = exports.getCiphers = getCiphers\n","exports['des-ecb'] = {\n key: 8,\n iv: 0\n}\nexports['des-cbc'] = exports.des = {\n key: 8,\n iv: 8\n}\nexports['des-ede3-cbc'] = exports.des3 = {\n key: 24,\n iv: 8\n}\nexports['des-ede3'] = {\n key: 24,\n iv: 0\n}\nexports['des-ede-cbc'] = {\n key: 16,\n iv: 8\n}\nexports['des-ede'] = {\n key: 16,\n iv: 0\n}\n","var DES = require('browserify-des')\nvar aes = require('browserify-aes/browser')\nvar aesModes = require('browserify-aes/modes')\nvar desModes = require('browserify-des/modes')\nvar ebtk = require('evp_bytestokey')\n\nfunction createCipher (suite, password) {\n suite = suite.toLowerCase()\n\n var keyLen, ivLen\n if (aesModes[suite]) {\n keyLen = aesModes[suite].key\n ivLen = aesModes[suite].iv\n } else if (desModes[suite]) {\n keyLen = desModes[suite].key * 8\n ivLen = desModes[suite].iv\n } else {\n throw new TypeError('invalid suite type')\n }\n\n var keys = ebtk(password, false, keyLen, ivLen)\n return createCipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createDecipher (suite, password) {\n suite = suite.toLowerCase()\n\n var keyLen, ivLen\n if (aesModes[suite]) {\n keyLen = aesModes[suite].key\n ivLen = aesModes[suite].iv\n } else if (desModes[suite]) {\n keyLen = desModes[suite].key * 8\n ivLen = desModes[suite].iv\n } else {\n throw new TypeError('invalid suite type')\n }\n\n var keys = ebtk(password, false, keyLen, ivLen)\n return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createCipheriv (suite, key, iv) {\n suite = suite.toLowerCase()\n if (aesModes[suite]) return aes.createCipheriv(suite, key, iv)\n if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite })\n\n throw new TypeError('invalid suite type')\n}\n\nfunction createDecipheriv (suite, key, iv) {\n suite = suite.toLowerCase()\n if (aesModes[suite]) return aes.createDecipheriv(suite, key, iv)\n if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite, decrypt: true })\n\n throw new TypeError('invalid suite type')\n}\n\nfunction getCiphers () {\n return Object.keys(desModes).concat(aes.getCiphers())\n}\n\nexports.createCipher = exports.Cipher = createCipher\nexports.createCipheriv = exports.Cipheriv = createCipheriv\nexports.createDecipher = exports.Decipher = createDecipher\nexports.createDecipheriv = exports.Decipheriv = createDecipheriv\nexports.listCiphers = exports.getCiphers = getCiphers\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var r;\n\nmodule.exports = function rand(len) {\n if (!r)\n r = new Rand(null);\n\n return r.generate(len);\n};\n\nfunction Rand(rand) {\n this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n if (this.rand.getBytes)\n return this.rand.getBytes(n);\n\n var res = new Uint8Array(n);\n for (var i = 0; i < res.length; i++)\n res[i] = this.rand.getByte();\n return res;\n};\n\nif (typeof self === 'object') {\n if (self.crypto && self.crypto.getRandomValues) {\n // Modern browsers\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.crypto.getRandomValues(arr);\n return arr;\n };\n } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n // IE\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.msCrypto.getRandomValues(arr);\n return arr;\n };\n\n // Safari's WebWorkers do not have `crypto`\n } else if (typeof window === 'object') {\n // Old junk\n Rand.prototype._rand = function() {\n throw new Error('Not implemented yet');\n };\n }\n} else {\n // Node.js or Web worker with no crypto support\n try {\n var crypto = require('crypto');\n if (typeof crypto.randomBytes !== 'function')\n throw new Error('Not supported');\n\n Rand.prototype._rand = function _rand(n) {\n return crypto.randomBytes(n);\n };\n } catch (e) {\n }\n}\n","var bn = require('bn.js');\nvar brorand = require('brorand');\n\nfunction MillerRabin(rand) {\n this.rand = rand || new brorand.Rand();\n}\nmodule.exports = MillerRabin;\n\nMillerRabin.create = function create(rand) {\n return new MillerRabin(rand);\n};\n\nMillerRabin.prototype._randbelow = function _randbelow(n) {\n var len = n.bitLength();\n var min_bytes = Math.ceil(len / 8);\n\n // Generage random bytes until a number less than n is found.\n // This ensures that 0..n-1 have an equal probability of being selected.\n do\n var a = new bn(this.rand.generate(min_bytes));\n while (a.cmp(n) >= 0);\n\n return a;\n};\n\nMillerRabin.prototype._randrange = function _randrange(start, stop) {\n // Generate a random number greater than or equal to start and less than stop.\n var size = stop.sub(start);\n return start.add(this._randbelow(size));\n};\n\nMillerRabin.prototype.test = function test(n, k, cb) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n var prime = true;\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n if (cb)\n cb(a);\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return false;\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s)\n return false;\n }\n\n return prime;\n};\n\nMillerRabin.prototype.getDivisor = function getDivisor(n, k) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n\n var g = n.gcd(a);\n if (g.cmpn(1) !== 0)\n return g;\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return x.fromRed().subn(1).gcd(n);\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s) {\n x = x.redSqr();\n return x.fromRed().subn(1).gcd(n);\n }\n }\n\n return false;\n};\n","var randomBytes = require('randombytes');\nmodule.exports = findPrime;\nfindPrime.simpleSieve = simpleSieve;\nfindPrime.fermatTest = fermatTest;\nvar BN = require('bn.js');\nvar TWENTYFOUR = new BN(24);\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar ONE = new BN(1);\nvar TWO = new BN(2);\nvar FIVE = new BN(5);\nvar SIXTEEN = new BN(16);\nvar EIGHT = new BN(8);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar ELEVEN = new BN(11);\nvar FOUR = new BN(4);\nvar TWELVE = new BN(12);\nvar primes = null;\n\nfunction _getPrimes() {\n if (primes !== null)\n return primes;\n\n var limit = 0x100000;\n var res = [];\n res[0] = 2;\n for (var i = 1, k = 3; k < limit; k += 2) {\n var sqrt = Math.ceil(Math.sqrt(k));\n for (var j = 0; j < i && res[j] <= sqrt; j++)\n if (k % res[j] === 0)\n break;\n\n if (i !== j && res[j] <= sqrt)\n continue;\n\n res[i++] = k;\n }\n primes = res;\n return res;\n}\n\nfunction simpleSieve(p) {\n var primes = _getPrimes();\n\n for (var i = 0; i < primes.length; i++)\n if (p.modn(primes[i]) === 0) {\n if (p.cmpn(primes[i]) === 0) {\n return true;\n } else {\n return false;\n }\n }\n\n return true;\n}\n\nfunction fermatTest(p) {\n var red = BN.mont(p);\n return TWO.toRed(red).redPow(p.subn(1)).fromRed().cmpn(1) === 0;\n}\n\nfunction findPrime(bits, gen) {\n if (bits < 16) {\n // this is what openssl does\n if (gen === 2 || gen === 5) {\n return new BN([0x8c, 0x7b]);\n } else {\n return new BN([0x8c, 0x27]);\n }\n }\n gen = new BN(gen);\n\n var num, n2;\n\n while (true) {\n num = new BN(randomBytes(Math.ceil(bits / 8)));\n while (num.bitLength() > bits) {\n num.ishrn(1);\n }\n if (num.isEven()) {\n num.iadd(ONE);\n }\n if (!num.testn(1)) {\n num.iadd(TWO);\n }\n if (!gen.cmp(TWO)) {\n while (num.mod(TWENTYFOUR).cmp(ELEVEN)) {\n num.iadd(FOUR);\n }\n } else if (!gen.cmp(FIVE)) {\n while (num.mod(TEN).cmp(THREE)) {\n num.iadd(FOUR);\n }\n }\n n2 = num.shrn(1);\n if (simpleSieve(n2) && simpleSieve(num) &&\n fermatTest(n2) && fermatTest(num) &&\n millerRabin.test(n2) && millerRabin.test(num)) {\n return num;\n }\n }\n\n}\n","var BN = require('bn.js');\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar TWENTYFOUR = new BN(24);\nvar ELEVEN = new BN(11);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar primes = require('./generatePrime');\nvar randomBytes = require('randombytes');\nmodule.exports = DH;\n\nfunction setPublicKey(pub, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc);\n }\n this._pub = new BN(pub);\n return this;\n}\n\nfunction setPrivateKey(priv, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc);\n }\n this._priv = new BN(priv);\n return this;\n}\n\nvar primeCache = {};\nfunction checkPrime(prime, generator) {\n var gen = generator.toString('hex');\n var hex = [gen, prime.toString(16)].join('_');\n if (hex in primeCache) {\n return primeCache[hex];\n }\n var error = 0;\n\n if (prime.isEven() ||\n !primes.simpleSieve ||\n !primes.fermatTest(prime) ||\n !millerRabin.test(prime)) {\n //not a prime so +1\n error += 1;\n\n if (gen === '02' || gen === '05') {\n // we'd be able to check the generator\n // it would fail so +8\n error += 8;\n } else {\n //we wouldn't be able to test the generator\n // so +4\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n }\n if (!millerRabin.test(prime.shrn(1))) {\n //not a safe prime\n error += 2;\n }\n var rem;\n switch (gen) {\n case '02':\n if (prime.mod(TWENTYFOUR).cmp(ELEVEN)) {\n // unsuidable generator\n error += 8;\n }\n break;\n case '05':\n rem = prime.mod(TEN);\n if (rem.cmp(THREE) && rem.cmp(SEVEN)) {\n // prime mod 10 needs to equal 3 or 7\n error += 8;\n }\n break;\n default:\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n}\n\nfunction DH(prime, generator, malleable) {\n this.setGenerator(generator);\n this.__prime = new BN(prime);\n this._prime = BN.mont(this.__prime);\n this._primeLen = prime.length;\n this._pub = undefined;\n this._priv = undefined;\n this._primeCode = undefined;\n if (malleable) {\n this.setPublicKey = setPublicKey;\n this.setPrivateKey = setPrivateKey;\n } else {\n this._primeCode = 8;\n }\n}\nObject.defineProperty(DH.prototype, 'verifyError', {\n enumerable: true,\n get: function () {\n if (typeof this._primeCode !== 'number') {\n this._primeCode = checkPrime(this.__prime, this.__gen);\n }\n return this._primeCode;\n }\n});\nDH.prototype.generateKeys = function () {\n if (!this._priv) {\n this._priv = new BN(randomBytes(this._primeLen));\n }\n this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed();\n return this.getPublicKey();\n};\n\nDH.prototype.computeSecret = function (other) {\n other = new BN(other);\n other = other.toRed(this._prime);\n var secret = other.redPow(this._priv).fromRed();\n var out = new Buffer(secret.toArray());\n var prime = this.getPrime();\n if (out.length < prime.length) {\n var front = new Buffer(prime.length - out.length);\n front.fill(0);\n out = Buffer.concat([front, out]);\n }\n return out;\n};\n\nDH.prototype.getPublicKey = function getPublicKey(enc) {\n return formatReturnValue(this._pub, enc);\n};\n\nDH.prototype.getPrivateKey = function getPrivateKey(enc) {\n return formatReturnValue(this._priv, enc);\n};\n\nDH.prototype.getPrime = function (enc) {\n return formatReturnValue(this.__prime, enc);\n};\n\nDH.prototype.getGenerator = function (enc) {\n return formatReturnValue(this._gen, enc);\n};\n\nDH.prototype.setGenerator = function (gen, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(gen)) {\n gen = new Buffer(gen, enc);\n }\n this.__gen = gen;\n this._gen = new BN(gen);\n return this;\n};\n\nfunction formatReturnValue(bn, enc) {\n var buf = new Buffer(bn.toArray());\n if (!enc) {\n return buf;\n } else {\n return buf.toString(enc);\n }\n}\n","var generatePrime = require('./lib/generatePrime')\nvar primes = require('./lib/primes.json')\n\nvar DH = require('./lib/dh')\n\nfunction getDiffieHellman (mod) {\n var prime = new Buffer(primes[mod].prime, 'hex')\n var gen = new Buffer(primes[mod].gen, 'hex')\n\n return new DH(prime, gen)\n}\n\nvar ENCODINGS = {\n 'binary': true, 'hex': true, 'base64': true\n}\n\nfunction createDiffieHellman (prime, enc, generator, genc) {\n if (Buffer.isBuffer(enc) || ENCODINGS[enc] === undefined) {\n return createDiffieHellman(prime, 'binary', enc, generator)\n }\n\n enc = enc || 'binary'\n genc = genc || 'binary'\n generator = generator || new Buffer([2])\n\n if (!Buffer.isBuffer(generator)) {\n generator = new Buffer(generator, genc)\n }\n\n if (typeof prime === 'number') {\n return new DH(generatePrime(prime, generator), generator, true)\n }\n\n if (!Buffer.isBuffer(prime)) {\n prime = new Buffer(prime, enc)\n }\n\n return new DH(prime, generator, true)\n}\n\nexports.DiffieHellmanGroup = exports.createDiffieHellmanGroup = exports.getDiffieHellman = getDiffieHellman\nexports.createDiffieHellman = exports.DiffieHellman = createDiffieHellman\n","'use strict';\n\nif (typeof process === 'undefined' ||\n !process.version ||\n process.version.indexOf('v0.') === 0 ||\n process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n module.exports = { nextTick: nextTick };\n} else {\n module.exports = process\n}\n\nfunction nextTick(fn, arg1, arg2, arg3) {\n if (typeof fn !== 'function') {\n throw new TypeError('\"callback\" argument must be a function');\n }\n var len = arguments.length;\n var args, i;\n switch (len) {\n case 0:\n case 1:\n return process.nextTick(fn);\n case 2:\n return process.nextTick(function afterTickOne() {\n fn.call(null, arg1);\n });\n case 3:\n return process.nextTick(function afterTickTwo() {\n fn.call(null, arg1, arg2);\n });\n case 4:\n return process.nextTick(function afterTickThree() {\n fn.call(null, arg1, arg2, arg3);\n });\n default:\n args = new Array(len - 1);\n i = 0;\n while (i < args.length) {\n args[i++] = arguments[i];\n }\n return process.nextTick(function afterTick() {\n fn.apply(null, args);\n });\n }\n}\n\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","module.exports = require('events').EventEmitter;\n","/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\n\nfunction isArray(arg) {\n if (Array.isArray) {\n return Array.isArray(arg);\n }\n return objectToString(arg) === '[object Array]';\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n return (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('buffer').Buffer.isBuffer;\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n","'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Buffer = require('safe-buffer').Buffer;\nvar util = require('util');\n\nfunction copyBuffer(src, target, offset) {\n src.copy(target, offset);\n}\n\nmodule.exports = function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n\n BufferList.prototype.push = function push(v) {\n var entry = { data: v, next: null };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n };\n\n BufferList.prototype.unshift = function unshift(v) {\n var entry = { data: v, next: this.head };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n };\n\n BufferList.prototype.shift = function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n };\n\n BufferList.prototype.clear = function clear() {\n this.head = this.tail = null;\n this.length = 0;\n };\n\n BufferList.prototype.join = function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) {\n ret += s + p.data;\n }return ret;\n };\n\n BufferList.prototype.concat = function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n };\n\n return BufferList;\n}();\n\nif (util && util.inspect && util.inspect.custom) {\n module.exports.prototype[util.inspect.custom] = function () {\n var obj = util.inspect({ length: this.length });\n return this.constructor.name + ' ' + obj;\n };\n}","'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n pna.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n pna.nextTick(emitErrorNT, this, err);\n }\n }\n\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n pna.nextTick(emitErrorNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n pna.nextTick(emitErrorNT, _this, err);\n }\n } else if (cb) {\n cb(err);\n }\n });\n\n return this;\n}\n\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\n\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\n\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : pna.nextTick;\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nutil.inherits(Writable, Stream);\n\nfunction nop() {}\n\nfunction WritableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n var isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n var hwm = options.highWaterMark;\n var writableHwm = options.writableHighWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\n if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (writableHwm || writableHwm === 0)) this.highWaterMark = writableHwm;else this.highWaterMark = defaultHwm;\n\n // cast to ints.\n this.highWaterMark = Math.floor(this.highWaterMark);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function () {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function (object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function (object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n if (!realHasInstance.call(Writable, this) && !(this instanceof Duplex)) {\n return new Writable(options);\n }\n\n this._writableState = new WritableState(options, this);\n\n // legacy.\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n\n if (typeof options.writev === 'function') this._writev = options.writev;\n\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n\n if (typeof options.final === 'function') this._final = options.final;\n }\n\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n this.emit('error', new Error('Cannot pipe, not readable'));\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new Error('write after end');\n // TODO: defer error events consistently everywhere, not just the cb\n stream.emit('error', er);\n pna.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var valid = true;\n var er = false;\n\n if (chunk === null) {\n er = new TypeError('May not write null values to stream');\n } else if (typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n if (er) {\n stream.emit('error', er);\n pna.nextTick(cb, er);\n valid = false;\n }\n return valid;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\n if (typeof cb !== 'function') cb = nop;\n\n if (state.ended) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n\n return ret;\n};\n\nWritable.prototype.cork = function () {\n var state = this._writableState;\n\n state.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\n\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n\n state.length += len;\n\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n pna.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n pna.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n\n onwriteStateUpdate(state);\n\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state);\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n /**/\n asyncWrite(afterWrite, stream, state, finished, cb);\n /**/\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new Error('_write() is not implemented'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n};\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n stream.emit('error', err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function') {\n state.pendingcb++;\n state.finalCalled = true;\n pna.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n }\n }\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) pna.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\n\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\n\nObject.defineProperty(Writable.prototype, 'destroyed', {\n get: function () {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\n\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n this.end();\n cb(err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) {\n keys.push(key);\n }return keys;\n};\n/**/\n\nmodule.exports = Duplex;\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\n{\n // avoid scope creep, the keys array can then be collected\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n\n Readable.call(this, options);\n Writable.call(this, options);\n\n if (options && options.readable === false) this.readable = false;\n\n if (options && options.writable === false) this.writable = false;\n\n this.allowHalfOpen = true;\n if (options && options.allowHalfOpen === false) this.allowHalfOpen = false;\n\n this.once('end', onend);\n}\n\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._writableState.highWaterMark;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // if we allow half-open state, or if the writable side ended,\n // then we're ok.\n if (this.allowHalfOpen || this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n pna.nextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n get: function () {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});\n\nDuplex.prototype._destroy = function (err, cb) {\n this.push(null);\n this.end();\n\n pna.nextTick(cb, err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\nmodule.exports = Readable;\n\n/**/\nvar isArray = require('isarray');\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function (emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar debugUtil = require('util');\nvar debug = void 0;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function () {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/BufferList');\nvar destroyImpl = require('./internal/streams/destroy');\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\n\nfunction ReadableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n var isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n var hwm = options.highWaterMark;\n var readableHwm = options.readableHighWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\n if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (readableHwm || readableHwm === 0)) this.highWaterMark = readableHwm;else this.highWaterMark = defaultHwm;\n\n // cast to ints.\n this.highWaterMark = Math.floor(this.highWaterMark);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n if (!(this instanceof Readable)) return new Readable(options);\n\n this._readableState = new ReadableState(options, this);\n\n // legacy\n this.readable = true;\n\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n\n Stream.call(this);\n}\n\nObject.defineProperty(Readable.prototype, 'destroyed', {\n get: function () {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\n\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n this.push(null);\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\n\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n stream.emit('error', er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (addToFront) {\n if (state.endEmitted) stream.emit('error', new Error('stream.unshift() after end event'));else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n stream.emit('error', new Error('stream.push() after EOF'));\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n }\n }\n\n return needMoreData(state);\n}\n\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n stream.emit('data', chunk);\n stream.read(0);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\n\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n return er;\n}\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes. This is to work around cases where hwm=0,\n// such as the repl. Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n}\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this._readableState.decoder = new StringDecoder(enc);\n this._readableState.encoding = enc;\n return this;\n};\n\n// Don't raise the hwm > 8MB\nvar MAX_HWM = 0x800000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = true;\n n = 0;\n } else {\n state.length -= n;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n\n return ret;\n};\n\nfunction onEofChunk(stream, state) {\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n\n // emit 'readable' now to make sure it gets picked up.\n emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n if (state.sync) pna.nextTick(emitReadable_, stream);else emitReadable_(stream);\n }\n}\n\nfunction emitReadable_(stream) {\n debug('emit readable');\n stream.emit('readable');\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n pna.nextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n var len = state.length;\n while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;else len = state.length;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n this.emit('error', new Error('_read() is not implemented'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) pna.nextTick(endFn);else src.once('end', endFn);\n\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n // If the user pushes more data while we're writing to dest then we'll end up\n // in ondata again. However, we only want to increase awaitDrain once because\n // dest will only emit one 'drain' event for the multiple writes.\n // => Introduce a guard on increasing awaitDrain.\n var increasedAwaitDrain = false;\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n increasedAwaitDrain = false;\n var ret = dest.write(chunk);\n if (false === ret && !increasedAwaitDrain) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n increasedAwaitDrain = true;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function () {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = { hasUnpiped: false };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this, { hasUnpiped: false });\n }return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\n dest.emit('unpipe', this, unpipeInfo);\n\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n\n if (ev === 'data') {\n // Start flowing on next tick if stream isn't explicitly paused\n if (this._readableState.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n var state = this._readableState;\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.emittedReadable = false;\n if (!state.reading) {\n pna.nextTick(nReadingNextTick, this);\n } else if (state.length) {\n emitReadable(this);\n }\n }\n }\n\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n state.flowing = true;\n resume(this, state);\n }\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n pna.nextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n if (!state.reading) {\n debug('resume read 0');\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n state.awaitDrain = 0;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (false !== this._readableState.flowing) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null) {}\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n\n var state = this._readableState;\n var paused = false;\n\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n\n _this.push(null);\n });\n\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function (method) {\n return function () {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return this;\n};\n\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._readableState.highWaterMark;\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = fromListPartial(n, state.buffer, state.decoder);\n }\n\n return ret;\n}\n\n// Extracts only enough buffered data to satisfy the amount requested.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromListPartial(n, list, hasStrings) {\n var ret;\n if (n < list.head.data.length) {\n // slice is the same for buffers and strings\n ret = list.head.data.slice(0, n);\n list.head.data = list.head.data.slice(n);\n } else if (n === list.head.data.length) {\n // first chunk is a perfect match\n ret = list.shift();\n } else {\n // result spans more than one buffer\n ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list);\n }\n return ret;\n}\n\n// Copies a specified amount of characters from the list of buffered data\n// chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBufferString(n, list) {\n var p = list.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\n// Copies a specified amount of bytes from the list of buffered data chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBuffer(n, list) {\n var ret = Buffer.allocUnsafe(n);\n var p = list.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n\n // If we get here before consuming all the bytes, then that is a\n // bug in node. Should never happen.\n if (state.length > 0) throw new Error('\"endReadable()\" called on non-empty stream');\n\n if (!state.endEmitted) {\n state.ended = true;\n pna.nextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n }\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(Transform, Duplex);\n\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n\n var cb = ts.writecb;\n\n if (!cb) {\n return this.emit('error', new Error('write callback called multiple times'));\n }\n\n ts.writechunk = null;\n ts.writecb = null;\n\n if (data != null) // single equals check for both `null` and `undefined`\n this.push(data);\n\n cb(er);\n\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n\n Duplex.call(this, options);\n\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\n\nfunction prefinish() {\n var _this = this;\n\n if (typeof this._flush === 'function') {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n throw new Error('_transform() is not implemented');\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nTransform.prototype._destroy = function (err, cb) {\n var _this2 = this;\n\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n _this2.emit('close');\n });\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n\n if (data != null) // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new Error('Calling transform done when ws.length != 0');\n\n if (stream._transformState.transforming) throw new Error('Calling transform done when still transforming');\n\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this._strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // '0' - '9'\n if (c >= 48 && c <= 57) {\n return c - 48;\n // 'A' - 'F'\n } else if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n } else {\n assert(false, 'Invalid character in ' + string);\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this._strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var b = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n b = c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n b = c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n b = c;\n }\n assert(c >= 0 && b < mul, 'Invalid character');\n r += b;\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this._strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n function move (dest, src) {\n dest.words = src.words;\n dest.length = src.length;\n dest.negative = src.negative;\n dest.red = src.red;\n }\n\n BN.prototype._move = function _move (dest) {\n move(dest, this);\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype._strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n // Check Symbol.for because not everywhere where Symbol defined\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol#Browser_compatibility\n if (typeof Symbol !== 'undefined' && typeof Symbol.for === 'function') {\n try {\n BN.prototype[Symbol.for('nodejs.util.inspect.custom')] = inspect;\n } catch (e) {\n BN.prototype.inspect = inspect;\n }\n } else {\n BN.prototype.inspect = inspect;\n }\n\n function inspect () {\n return (this.red ? '';\n }\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modrn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16, 2);\n };\n\n if (Buffer) {\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n return this.toArrayLike(Buffer, endian, length);\n };\n }\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n var allocate = function allocate (ArrayType, size) {\n if (ArrayType.allocUnsafe) {\n return ArrayType.allocUnsafe(size);\n }\n return new ArrayType(size);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n this._strip();\n\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n var res = allocate(ArrayType, reqLength);\n var postfix = endian === 'le' ? 'LE' : 'BE';\n this['_toArrayLike' + postfix](res, byteLength);\n return res;\n };\n\n BN.prototype._toArrayLikeLE = function _toArrayLikeLE (res, byteLength) {\n var position = 0;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position++] = word & 0xff;\n if (position < res.length) {\n res[position++] = (word >> 8) & 0xff;\n }\n if (position < res.length) {\n res[position++] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position < res.length) {\n res[position++] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position < res.length) {\n res[position++] = carry;\n\n while (position < res.length) {\n res[position++] = 0;\n }\n }\n };\n\n BN.prototype._toArrayLikeBE = function _toArrayLikeBE (res, byteLength) {\n var position = res.length - 1;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position--] = word & 0xff;\n if (position >= 0) {\n res[position--] = (word >> 8) & 0xff;\n }\n if (position >= 0) {\n res[position--] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position >= 0) {\n res[position--] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position >= 0) {\n res[position--] = carry;\n\n while (position >= 0) {\n res[position--] = 0;\n }\n }\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] >>> wbit) & 0x01;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this._strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this._strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this._strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this._strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this._strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this._strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n function jumboMulTo (self, num, out) {\n // Temporary disable, see https://github.com/indutny/bn.js/issues/211\n // var fftm = new FFTM();\n // return fftm.mulp(self, num, out);\n return bigMulTo(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out._strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this._strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) <= num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this._strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this._strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this._strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q._strip();\n }\n a._strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || (r2 === 1 && cmp === 0)) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modrn = function modrn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return isNegNum ? -acc : acc;\n };\n\n // WARNING: DEPRECATED\n BN.prototype.modn = function modn (num) {\n return this.modrn(num);\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n this._strip();\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this._strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is a BN v4 instance\n r.strip();\n } else {\n // r is a BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n\n move(a, a.umod(this.m)._forceRed(this));\n return a;\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","'use strict';\n\nvar BN = require('bn.js');\nvar randomBytes = require('randombytes');\nvar Buffer = require('safe-buffer').Buffer;\n\nfunction getr(priv) {\n\tvar len = priv.modulus.byteLength();\n\tvar r;\n\tdo {\n\t\tr = new BN(randomBytes(len));\n\t} while (r.cmp(priv.modulus) >= 0 || !r.umod(priv.prime1) || !r.umod(priv.prime2));\n\treturn r;\n}\n\nfunction blind(priv) {\n\tvar r = getr(priv);\n\tvar blinder = r.toRed(BN.mont(priv.modulus)).redPow(new BN(priv.publicExponent)).fromRed();\n\treturn { blinder: blinder, unblinder: r.invm(priv.modulus) };\n}\n\nfunction crt(msg, priv) {\n\tvar blinds = blind(priv);\n\tvar len = priv.modulus.byteLength();\n\tvar blinded = new BN(msg).mul(blinds.blinder).umod(priv.modulus);\n\tvar c1 = blinded.toRed(BN.mont(priv.prime1));\n\tvar c2 = blinded.toRed(BN.mont(priv.prime2));\n\tvar qinv = priv.coefficient;\n\tvar p = priv.prime1;\n\tvar q = priv.prime2;\n\tvar m1 = c1.redPow(priv.exponent1).fromRed();\n\tvar m2 = c2.redPow(priv.exponent2).fromRed();\n\tvar h = m1.isub(m2).imul(qinv).umod(p).imul(q);\n\treturn m2.iadd(h).imul(blinds.unblinder).umod(priv.modulus).toArrayLike(Buffer, 'be', len);\n}\ncrt.getr = getr;\n\nmodule.exports = crt;\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n","'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\nvar minAssert = require('minimalistic-assert');\nvar minUtils = require('minimalistic-crypto-utils');\n\nutils.assert = minAssert;\nutils.toArray = minUtils.toArray;\nutils.zero2 = minUtils.zero2;\nutils.toHex = minUtils.toHex;\nutils.encode = minUtils.encode;\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w, bits) {\n var naf = new Array(Math.max(num.bitLength(), bits) + 1);\n var i;\n for (i = 0; i < naf.length; i += 1) {\n naf[i] = 0;\n }\n\n var ws = 1 << (w + 1);\n var k = num.clone();\n\n for (i = 0; i < naf.length; i++) {\n var z;\n var mod = k.andln(ws - 1);\n if (k.isOdd()) {\n if (mod > (ws >> 1) - 1)\n z = (ws >> 1) - mod;\n else\n z = mod;\n k.isubn(z);\n } else {\n z = 0;\n }\n\n naf[i] = z;\n k.iushrn(1);\n }\n\n return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n var jsf = [\n [],\n [],\n ];\n\n k1 = k1.clone();\n k2 = k2.clone();\n var d1 = 0;\n var d2 = 0;\n var m8;\n while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n // First phase\n var m14 = (k1.andln(3) + d1) & 3;\n var m24 = (k2.andln(3) + d2) & 3;\n if (m14 === 3)\n m14 = -1;\n if (m24 === 3)\n m24 = -1;\n var u1;\n if ((m14 & 1) === 0) {\n u1 = 0;\n } else {\n m8 = (k1.andln(7) + d1) & 7;\n if ((m8 === 3 || m8 === 5) && m24 === 2)\n u1 = -m14;\n else\n u1 = m14;\n }\n jsf[0].push(u1);\n\n var u2;\n if ((m24 & 1) === 0) {\n u2 = 0;\n } else {\n m8 = (k2.andln(7) + d2) & 7;\n if ((m8 === 3 || m8 === 5) && m14 === 2)\n u2 = -m24;\n else\n u2 = m24;\n }\n jsf[1].push(u2);\n\n // Second phase\n if (2 * d1 === u1 + 1)\n d1 = 1 - d1;\n if (2 * d2 === u2 + 1)\n d2 = 1 - d2;\n k1.iushrn(1);\n k2.iushrn(1);\n }\n\n return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, name, computer) {\n var key = '_' + name;\n obj.prototype[name] = function cachedProperty() {\n return this[key] !== undefined ? this[key] :\n this[key] = computer.call(this);\n };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n this.type = type;\n this.p = new BN(conf.p, 16);\n\n // Use Montgomery, when there is no fast reduction for the prime\n this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n // Useful for many curves\n this.zero = new BN(0).toRed(this.red);\n this.one = new BN(1).toRed(this.red);\n this.two = new BN(2).toRed(this.red);\n\n // Curve configuration, optional\n this.n = conf.n && new BN(conf.n, 16);\n this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n // Temporary arrays\n this._wnafT1 = new Array(4);\n this._wnafT2 = new Array(4);\n this._wnafT3 = new Array(4);\n this._wnafT4 = new Array(4);\n\n this._bitLength = this.n ? this.n.bitLength() : 0;\n\n // Generalized Greg Maxwell's trick\n var adjustCount = this.n && this.p.div(this.n);\n if (!adjustCount || adjustCount.cmpn(100) > 0) {\n this.redN = null;\n } else {\n this._maxwellTrick = true;\n this.redN = this.n.toRed(this.red);\n }\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n assert(p.precomputed);\n var doubles = p._getDoubles();\n\n var naf = getNAF(k, 1, this._bitLength);\n var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n I /= 3;\n\n // Translate into more windowed form\n var repr = [];\n var j;\n var nafW;\n for (j = 0; j < naf.length; j += doubles.step) {\n nafW = 0;\n for (var l = j + doubles.step - 1; l >= j; l--)\n nafW = (nafW << 1) + naf[l];\n repr.push(nafW);\n }\n\n var a = this.jpoint(null, null, null);\n var b = this.jpoint(null, null, null);\n for (var i = I; i > 0; i--) {\n for (j = 0; j < repr.length; j++) {\n nafW = repr[j];\n if (nafW === i)\n b = b.mixedAdd(doubles.points[j]);\n else if (nafW === -i)\n b = b.mixedAdd(doubles.points[j].neg());\n }\n a = a.add(b);\n }\n return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n var w = 4;\n\n // Precompute window\n var nafPoints = p._getNAFPoints(w);\n w = nafPoints.wnd;\n var wnd = nafPoints.points;\n\n // Get NAF form\n var naf = getNAF(k, w, this._bitLength);\n\n // Add `this`*(N+1) for every w-NAF index\n var acc = this.jpoint(null, null, null);\n for (var i = naf.length - 1; i >= 0; i--) {\n // Count zeroes\n for (var l = 0; i >= 0 && naf[i] === 0; i--)\n l++;\n if (i >= 0)\n l++;\n acc = acc.dblp(l);\n\n if (i < 0)\n break;\n var z = naf[i];\n assert(z !== 0);\n if (p.type === 'affine') {\n // J +- P\n if (z > 0)\n acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n else\n acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n } else {\n // J +- J\n if (z > 0)\n acc = acc.add(wnd[(z - 1) >> 1]);\n else\n acc = acc.add(wnd[(-z - 1) >> 1].neg());\n }\n }\n return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n points,\n coeffs,\n len,\n jacobianResult) {\n var wndWidth = this._wnafT1;\n var wnd = this._wnafT2;\n var naf = this._wnafT3;\n\n // Fill all arrays\n var max = 0;\n var i;\n var j;\n var p;\n for (i = 0; i < len; i++) {\n p = points[i];\n var nafPoints = p._getNAFPoints(defW);\n wndWidth[i] = nafPoints.wnd;\n wnd[i] = nafPoints.points;\n }\n\n // Comb small window NAFs\n for (i = len - 1; i >= 1; i -= 2) {\n var a = i - 1;\n var b = i;\n if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength);\n naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength);\n max = Math.max(naf[a].length, max);\n max = Math.max(naf[b].length, max);\n continue;\n }\n\n var comb = [\n points[a], /* 1 */\n null, /* 3 */\n null, /* 5 */\n points[b], /* 7 */\n ];\n\n // Try to avoid Projective points, if possible\n if (points[a].y.cmp(points[b].y) === 0) {\n comb[1] = points[a].add(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].add(points[b].neg());\n } else {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n }\n\n var index = [\n -3, /* -1 -1 */\n -1, /* -1 0 */\n -5, /* -1 1 */\n -7, /* 0 -1 */\n 0, /* 0 0 */\n 7, /* 0 1 */\n 5, /* 1 -1 */\n 1, /* 1 0 */\n 3, /* 1 1 */\n ];\n\n var jsf = getJSF(coeffs[a], coeffs[b]);\n max = Math.max(jsf[0].length, max);\n naf[a] = new Array(max);\n naf[b] = new Array(max);\n for (j = 0; j < max; j++) {\n var ja = jsf[0][j] | 0;\n var jb = jsf[1][j] | 0;\n\n naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n naf[b][j] = 0;\n wnd[a] = comb;\n }\n }\n\n var acc = this.jpoint(null, null, null);\n var tmp = this._wnafT4;\n for (i = max; i >= 0; i--) {\n var k = 0;\n\n while (i >= 0) {\n var zero = true;\n for (j = 0; j < len; j++) {\n tmp[j] = naf[j][i] | 0;\n if (tmp[j] !== 0)\n zero = false;\n }\n if (!zero)\n break;\n k++;\n i--;\n }\n if (i >= 0)\n k++;\n acc = acc.dblp(k);\n if (i < 0)\n break;\n\n for (j = 0; j < len; j++) {\n var z = tmp[j];\n p;\n if (z === 0)\n continue;\n else if (z > 0)\n p = wnd[j][(z - 1) >> 1];\n else if (z < 0)\n p = wnd[j][(-z - 1) >> 1].neg();\n\n if (p.type === 'affine')\n acc = acc.mixedAdd(p);\n else\n acc = acc.add(p);\n }\n }\n // Zeroify references\n for (i = 0; i < len; i++)\n wnd[i] = null;\n\n if (jacobianResult)\n return acc;\n else\n return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n this.curve = curve;\n this.type = type;\n this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n bytes = utils.toArray(bytes, enc);\n\n var len = this.p.byteLength();\n\n // uncompressed, hybrid-odd, hybrid-even\n if ((bytes[0] === 0x04 || bytes[0] === 0x06 || bytes[0] === 0x07) &&\n bytes.length - 1 === 2 * len) {\n if (bytes[0] === 0x06)\n assert(bytes[bytes.length - 1] % 2 === 0);\n else if (bytes[0] === 0x07)\n assert(bytes[bytes.length - 1] % 2 === 1);\n\n var res = this.point(bytes.slice(1, 1 + len),\n bytes.slice(1 + len, 1 + 2 * len));\n\n return res;\n } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n bytes.length - 1 === len) {\n return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n }\n throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n var len = this.curve.p.byteLength();\n var x = this.getX().toArray('be', len);\n\n if (compact)\n return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n return [ 0x04 ].concat(x, this.getY().toArray('be', len));\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n if (this.precomputed)\n return this;\n\n var precomputed = {\n doubles: null,\n naf: null,\n beta: null,\n };\n precomputed.naf = this._getNAFPoints(8);\n precomputed.doubles = this._getDoubles(4, power);\n precomputed.beta = this._getBeta();\n this.precomputed = precomputed;\n\n return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n if (!this.precomputed)\n return false;\n\n var doubles = this.precomputed.doubles;\n if (!doubles)\n return false;\n\n return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n if (this.precomputed && this.precomputed.doubles)\n return this.precomputed.doubles;\n\n var doubles = [ this ];\n var acc = this;\n for (var i = 0; i < power; i += step) {\n for (var j = 0; j < step; j++)\n acc = acc.dbl();\n doubles.push(acc);\n }\n return {\n step: step,\n points: doubles,\n };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n if (this.precomputed && this.precomputed.naf)\n return this.precomputed.naf;\n\n var res = [ this ];\n var max = (1 << wnd) - 1;\n var dbl = max === 1 ? null : this.dbl();\n for (var i = 1; i < max; i++)\n res[i] = res[i - 1].add(dbl);\n return {\n wnd: wnd,\n points: res,\n };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n var r = this;\n for (var i = 0; i < k; i++)\n r = r.dbl();\n return r;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction ShortCurve(conf) {\n Base.call(this, 'short', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.tinv = this.two.redInvm();\n\n this.zeroA = this.a.fromRed().cmpn(0) === 0;\n this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n // If the curve is endomorphic, precalculate beta and lambda\n this.endo = this._getEndomorphism(conf);\n this._endoWnafT1 = new Array(4);\n this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n // No efficient endomorphism\n if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n return;\n\n // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n var beta;\n var lambda;\n if (conf.beta) {\n beta = new BN(conf.beta, 16).toRed(this.red);\n } else {\n var betas = this._getEndoRoots(this.p);\n // Choose the smallest beta\n beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n beta = beta.toRed(this.red);\n }\n if (conf.lambda) {\n lambda = new BN(conf.lambda, 16);\n } else {\n // Choose the lambda that is matching selected beta\n var lambdas = this._getEndoRoots(this.n);\n if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n lambda = lambdas[0];\n } else {\n lambda = lambdas[1];\n assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n }\n }\n\n // Get basis vectors, used for balanced length-two representation\n var basis;\n if (conf.basis) {\n basis = conf.basis.map(function(vec) {\n return {\n a: new BN(vec.a, 16),\n b: new BN(vec.b, 16),\n };\n });\n } else {\n basis = this._getEndoBasis(lambda);\n }\n\n return {\n beta: beta,\n lambda: lambda,\n basis: basis,\n };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n // Find roots of for x^2 + x + 1 in F\n // Root = (-1 +- Sqrt(-3)) / 2\n //\n var red = num === this.p ? this.red : BN.mont(num);\n var tinv = new BN(2).toRed(red).redInvm();\n var ntinv = tinv.redNeg();\n\n var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n var l1 = ntinv.redAdd(s).fromRed();\n var l2 = ntinv.redSub(s).fromRed();\n return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n // aprxSqrt >= sqrt(this.n)\n var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n // 3.74\n // Run EGCD, until r(L + 1) < aprxSqrt\n var u = lambda;\n var v = this.n.clone();\n var x1 = new BN(1);\n var y1 = new BN(0);\n var x2 = new BN(0);\n var y2 = new BN(1);\n\n // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n var a0;\n var b0;\n // First vector\n var a1;\n var b1;\n // Second vector\n var a2;\n var b2;\n\n var prevR;\n var i = 0;\n var r;\n var x;\n while (u.cmpn(0) !== 0) {\n var q = v.div(u);\n r = v.sub(q.mul(u));\n x = x2.sub(q.mul(x1));\n var y = y2.sub(q.mul(y1));\n\n if (!a1 && r.cmp(aprxSqrt) < 0) {\n a0 = prevR.neg();\n b0 = x1;\n a1 = r.neg();\n b1 = x;\n } else if (a1 && ++i === 2) {\n break;\n }\n prevR = r;\n\n v = u;\n u = r;\n x2 = x1;\n x1 = x;\n y2 = y1;\n y1 = y;\n }\n a2 = r.neg();\n b2 = x;\n\n var len1 = a1.sqr().add(b1.sqr());\n var len2 = a2.sqr().add(b2.sqr());\n if (len2.cmp(len1) >= 0) {\n a2 = a0;\n b2 = b0;\n }\n\n // Normalize signs\n if (a1.negative) {\n a1 = a1.neg();\n b1 = b1.neg();\n }\n if (a2.negative) {\n a2 = a2.neg();\n b2 = b2.neg();\n }\n\n return [\n { a: a1, b: b1 },\n { a: a2, b: b2 },\n ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n var basis = this.endo.basis;\n var v1 = basis[0];\n var v2 = basis[1];\n\n var c1 = v2.b.mul(k).divRound(this.n);\n var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n var p1 = c1.mul(v1.a);\n var p2 = c2.mul(v2.a);\n var q1 = c1.mul(v1.b);\n var q2 = c2.mul(v2.b);\n\n // Calculate answer\n var k1 = k.sub(p1).sub(p2);\n var k2 = q1.add(q2).neg();\n return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n // XXX Is there any way to tell if the number is odd without converting it\n // to non-red form?\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n if (point.inf)\n return true;\n\n var x = point.x;\n var y = point.y;\n\n var ax = this.a.redMul(x);\n var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n function _endoWnafMulAdd(points, coeffs, jacobianResult) {\n var npoints = this._endoWnafT1;\n var ncoeffs = this._endoWnafT2;\n for (var i = 0; i < points.length; i++) {\n var split = this._endoSplit(coeffs[i]);\n var p = points[i];\n var beta = p._getBeta();\n\n if (split.k1.negative) {\n split.k1.ineg();\n p = p.neg(true);\n }\n if (split.k2.negative) {\n split.k2.ineg();\n beta = beta.neg(true);\n }\n\n npoints[i * 2] = p;\n npoints[i * 2 + 1] = beta;\n ncoeffs[i * 2] = split.k1;\n ncoeffs[i * 2 + 1] = split.k2;\n }\n var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult);\n\n // Clean-up references to points and coefficients\n for (var j = 0; j < i * 2; j++) {\n npoints[j] = null;\n ncoeffs[j] = null;\n }\n return res;\n };\n\nfunction Point(curve, x, y, isRed) {\n Base.BasePoint.call(this, curve, 'affine');\n if (x === null && y === null) {\n this.x = null;\n this.y = null;\n this.inf = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n // Force redgomery representation when loading from JSON\n if (isRed) {\n this.x.forceRed(this.curve.red);\n this.y.forceRed(this.curve.red);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n this.inf = false;\n }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n if (!this.curve.endo)\n return;\n\n var pre = this.precomputed;\n if (pre && pre.beta)\n return pre.beta;\n\n var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n if (pre) {\n var curve = this.curve;\n var endoMul = function(p) {\n return curve.point(p.x.redMul(curve.endo.beta), p.y);\n };\n pre.beta = beta;\n beta.precomputed = {\n beta: null,\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(endoMul),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(endoMul),\n },\n };\n }\n return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n if (!this.precomputed)\n return [ this.x, this.y ];\n\n return [ this.x, this.y, this.precomputed && {\n doubles: this.precomputed.doubles && {\n step: this.precomputed.doubles.step,\n points: this.precomputed.doubles.points.slice(1),\n },\n naf: this.precomputed.naf && {\n wnd: this.precomputed.naf.wnd,\n points: this.precomputed.naf.points.slice(1),\n },\n } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n if (typeof obj === 'string')\n obj = JSON.parse(obj);\n var res = curve.point(obj[0], obj[1], red);\n if (!obj[2])\n return res;\n\n function obj2point(obj) {\n return curve.point(obj[0], obj[1], red);\n }\n\n var pre = obj[2];\n res.precomputed = {\n beta: null,\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: [ res ].concat(pre.doubles.points.map(obj2point)),\n },\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: [ res ].concat(pre.naf.points.map(obj2point)),\n },\n };\n return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.inf)\n return p;\n\n // P + O = P\n if (p.inf)\n return this;\n\n // P + P = 2P\n if (this.eq(p))\n return this.dbl();\n\n // P + (-P) = O\n if (this.neg().eq(p))\n return this.curve.point(null, null);\n\n // P + Q = O\n if (this.x.cmp(p.x) === 0)\n return this.curve.point(null, null);\n\n var c = this.y.redSub(p.y);\n if (c.cmpn(0) !== 0)\n c = c.redMul(this.x.redSub(p.x).redInvm());\n var nx = c.redSqr().redISub(this.x).redISub(p.x);\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.inf)\n return this;\n\n // 2P = O\n var ys1 = this.y.redAdd(this.y);\n if (ys1.cmpn(0) === 0)\n return this.curve.point(null, null);\n\n var a = this.curve.a;\n\n var x2 = this.x.redSqr();\n var dyinv = ys1.redInvm();\n var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n k = new BN(k, 16);\n if (this.isInfinity())\n return this;\n else if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else if (this.curve.endo)\n return this.curve._endoWnafMulAdd([ this ], [ k ]);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs, true);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2, true);\n};\n\nPoint.prototype.eq = function eq(p) {\n return this === p ||\n this.inf === p.inf &&\n (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n if (this.inf)\n return this;\n\n var res = this.curve.point(this.x, this.y.redNeg());\n if (_precompute && this.precomputed) {\n var pre = this.precomputed;\n var negate = function(p) {\n return p.neg();\n };\n res.precomputed = {\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(negate),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(negate),\n },\n };\n }\n return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n if (this.inf)\n return this.curve.jpoint(null, null, null);\n\n var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n Base.BasePoint.call(this, curve, 'jacobian');\n if (x === null && y === null && z === null) {\n this.x = this.curve.one;\n this.y = this.curve.one;\n this.z = new BN(0);\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = new BN(z, 16);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n\n this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n if (this.isInfinity())\n return this.curve.point(null, null);\n\n var zinv = this.z.redInvm();\n var zinv2 = zinv.redSqr();\n var ax = this.x.redMul(zinv2);\n var ay = this.y.redMul(zinv2).redMul(zinv);\n\n return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.isInfinity())\n return p;\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 12M + 4S + 7A\n var pz2 = p.z.redSqr();\n var z2 = this.z.redSqr();\n var u1 = this.x.redMul(pz2);\n var u2 = p.x.redMul(z2);\n var s1 = this.y.redMul(pz2.redMul(p.z));\n var s2 = p.y.redMul(z2.redMul(this.z));\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(p.z).redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n // O + P = P\n if (this.isInfinity())\n return p.toJ();\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 8M + 3S + 7A\n var z2 = this.z.redSqr();\n var u1 = this.x;\n var u2 = p.x.redMul(z2);\n var s1 = this.y;\n var s2 = p.y.redMul(z2).redMul(this.z);\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n if (pow === 0)\n return this;\n if (this.isInfinity())\n return this;\n if (!pow)\n return this.dbl();\n\n var i;\n if (this.curve.zeroA || this.curve.threeA) {\n var r = this;\n for (i = 0; i < pow; i++)\n r = r.dbl();\n return r;\n }\n\n // 1M + 2S + 1A + N * (4S + 5M + 8A)\n // N = 1 => 6M + 6S + 9A\n var a = this.curve.a;\n var tinv = this.curve.tinv;\n\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n // Reuse results\n var jyd = jy.redAdd(jy);\n for (i = 0; i < pow; i++) {\n var jx2 = jx.redSqr();\n var jyd2 = jyd.redSqr();\n var jyd4 = jyd2.redSqr();\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var t1 = jx.redMul(jyd2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n var dny = c.redMul(t2);\n dny = dny.redIAdd(dny).redISub(jyd4);\n var nz = jyd.redMul(jz);\n if (i + 1 < pow)\n jz4 = jz4.redMul(jyd4);\n\n jx = nx;\n jz = nz;\n jyd = dny;\n }\n\n return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n if (this.curve.zeroA)\n return this._zeroDbl();\n else if (this.curve.threeA)\n return this._threeDbl();\n else\n return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 14A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // T = M ^ 2 - 2*S\n var t = m.redSqr().redISub(s).redISub(s);\n\n // 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2*Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-dbl-2009-l\n // 2M + 5S + 13A\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = B^2\n var c = b.redSqr();\n // D = 2 * ((X1 + B)^2 - A - C)\n var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n d = d.redIAdd(d);\n // E = 3 * A\n var e = a.redAdd(a).redIAdd(a);\n // F = E^2\n var f = e.redSqr();\n\n // 8 * C\n var c8 = c.redIAdd(c);\n c8 = c8.redIAdd(c8);\n c8 = c8.redIAdd(c8);\n\n // X3 = F - 2 * D\n nx = f.redISub(d).redISub(d);\n // Y3 = E * (D - X3) - 8 * C\n ny = e.redMul(d.redISub(nx)).redISub(c8);\n // Z3 = 2 * Y1 * Z1\n nz = this.y.redMul(this.z);\n nz = nz.redIAdd(nz);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 15A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a\n var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n // T = M^2 - 2 * S\n var t = m.redSqr().redISub(s).redISub(s);\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2 * Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n // 3M + 5S\n\n // delta = Z1^2\n var delta = this.z.redSqr();\n // gamma = Y1^2\n var gamma = this.y.redSqr();\n // beta = X1 * gamma\n var beta = this.x.redMul(gamma);\n // alpha = 3 * (X1 - delta) * (X1 + delta)\n var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n alpha = alpha.redAdd(alpha).redIAdd(alpha);\n // X3 = alpha^2 - 8 * beta\n var beta4 = beta.redIAdd(beta);\n beta4 = beta4.redIAdd(beta4);\n var beta8 = beta4.redAdd(beta4);\n nx = alpha.redSqr().redISub(beta8);\n // Z3 = (Y1 + Z1)^2 - gamma - delta\n nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n var ggamma8 = gamma.redSqr();\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n var a = this.curve.a;\n\n // 4M + 6S + 10A\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n var jx2 = jx.redSqr();\n var jy2 = jy.redSqr();\n\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var jxd4 = jx.redAdd(jx);\n jxd4 = jxd4.redIAdd(jxd4);\n var t1 = jxd4.redMul(jy2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n\n var jyd8 = jy2.redSqr();\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n var ny = c.redMul(t2).redISub(jyd8);\n var nz = jy.redAdd(jy).redMul(jz);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n if (!this.curve.zeroA)\n return this.dbl().add(this);\n\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n // 5M + 10S + ...\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // ZZ = Z1^2\n var zz = this.z.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // M = 3 * XX + a * ZZ2; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // MM = M^2\n var mm = m.redSqr();\n // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n e = e.redIAdd(e);\n e = e.redAdd(e).redIAdd(e);\n e = e.redISub(mm);\n // EE = E^2\n var ee = e.redSqr();\n // T = 16*YYYY\n var t = yyyy.redIAdd(yyyy);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n // U = (M + E)^2 - MM - EE - T\n var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n // X3 = 4 * (X1 * EE - 4 * YY * U)\n var yyu4 = yy.redMul(u);\n yyu4 = yyu4.redIAdd(yyu4);\n yyu4 = yyu4.redIAdd(yyu4);\n var nx = this.x.redMul(ee).redISub(yyu4);\n nx = nx.redIAdd(nx);\n nx = nx.redIAdd(nx);\n // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n // Z3 = (Z1 + E)^2 - ZZ - EE\n var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n k = new BN(k, kbase);\n\n return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n if (p.type === 'affine')\n return this.eq(p.toJ());\n\n if (this === p)\n return true;\n\n // x1 * z2^2 == x2 * z1^2\n var z2 = this.z.redSqr();\n var pz2 = p.z.redSqr();\n if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n return false;\n\n // y1 * z2^3 == y2 * z1^3\n var z3 = z2.redMul(this.z);\n var pz3 = pz2.redMul(p.z);\n return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.eqXToP = function eqXToP(x) {\n var zs = this.z.redSqr();\n var rx = x.toRed(this.curve.red).redMul(zs);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(zs);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\nJPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar utils = require('../utils');\n\nfunction MontCurve(conf) {\n Base.call(this, 'mont', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.i4 = new BN(4).toRed(this.red).redInvm();\n this.two = new BN(2).toRed(this.red);\n this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n var x = point.normalize().x;\n var x2 = x.redSqr();\n var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n var y = rhs.redSqrt();\n\n return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && z === null) {\n this.x = this.curve.one;\n this.z = this.curve.zero;\n } else {\n this.x = new BN(x, 16);\n this.z = new BN(z, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n // 2M + 2S + 4A\n\n // A = X1 + Z1\n var a = this.x.redAdd(this.z);\n // AA = A^2\n var aa = a.redSqr();\n // B = X1 - Z1\n var b = this.x.redSub(this.z);\n // BB = B^2\n var bb = b.redSqr();\n // C = AA - BB\n var c = aa.redSub(bb);\n // X3 = AA * BB\n var nx = aa.redMul(bb);\n // Z3 = C * (BB + A24 * C)\n var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n // 4M + 2S + 6A\n\n // A = X2 + Z2\n var a = this.x.redAdd(this.z);\n // B = X2 - Z2\n var b = this.x.redSub(this.z);\n // C = X3 + Z3\n var c = p.x.redAdd(p.z);\n // D = X3 - Z3\n var d = p.x.redSub(p.z);\n // DA = D * A\n var da = d.redMul(a);\n // CB = C * B\n var cb = c.redMul(b);\n // X5 = Z1 * (DA + CB)^2\n var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n // Z5 = X1 * (DA - CB)^2\n var nz = diff.x.redMul(da.redISub(cb).redSqr());\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n var t = k.clone();\n var a = this; // (N / 2) * Q + Q\n var b = this.curve.point(null, null); // (N / 2) * Q\n var c = this; // Q\n\n for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n bits.push(t.andln(1));\n\n for (var i = bits.length - 1; i >= 0; i--) {\n if (bits[i] === 0) {\n // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n a = a.diffAdd(b, c);\n // N * Q = 2 * ((N / 2) * Q + Q))\n b = b.dbl();\n } else {\n // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n b = a.diffAdd(b, c);\n // N * Q + Q = 2 * ((N / 2) * Q + Q)\n a = a.dbl();\n }\n }\n return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.jumlAdd = function jumlAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n this.x = this.x.redMul(this.z.redInvm());\n this.z = this.curve.one;\n return this;\n};\n\nPoint.prototype.getX = function getX() {\n // Normalize coordinates\n this.normalize();\n\n return this.x.fromRed();\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction EdwardsCurve(conf) {\n // NOTE: Important as we are creating point in Base.call()\n this.twisted = (conf.a | 0) !== 1;\n this.mOneA = this.twisted && (conf.a | 0) === -1;\n this.extended = this.mOneA;\n\n Base.call(this, 'edwards', conf);\n\n this.a = new BN(conf.a, 16).umod(this.red.m);\n this.a = this.a.toRed(this.red);\n this.c = new BN(conf.c, 16).toRed(this.red);\n this.c2 = this.c.redSqr();\n this.d = new BN(conf.d, 16).toRed(this.red);\n this.dd = this.d.redAdd(this.d);\n\n assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n if (this.mOneA)\n return num.redNeg();\n else\n return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n if (this.oneC)\n return num;\n else\n return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var x2 = x.redSqr();\n var rhs = this.c2.redSub(this.a.redMul(x2));\n var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n var y2 = rhs.redMul(lhs.redInvm());\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n y = new BN(y, 16);\n if (!y.red)\n y = y.toRed(this.red);\n\n // x^2 = (y^2 - c^2) / (c^2 d y^2 - a)\n var y2 = y.redSqr();\n var lhs = y2.redSub(this.c2);\n var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a);\n var x2 = lhs.redMul(rhs.redInvm());\n\n if (x2.cmp(this.zero) === 0) {\n if (odd)\n throw new Error('invalid point');\n else\n return this.point(this.zero, y);\n }\n\n var x = x2.redSqrt();\n if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n if (x.fromRed().isOdd() !== odd)\n x = x.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n if (point.isInfinity())\n return true;\n\n // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n point.normalize();\n\n var x2 = point.x.redSqr();\n var y2 = point.y.redSqr();\n var lhs = x2.redMul(this.a).redAdd(y2);\n var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && y === null && z === null) {\n this.x = this.curve.zero;\n this.y = this.curve.one;\n this.z = this.curve.one;\n this.t = this.curve.zero;\n this.zOne = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = z ? new BN(z, 16) : this.curve.one;\n this.t = t && new BN(t, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n if (this.t && !this.t.red)\n this.t = this.t.toRed(this.curve.red);\n this.zOne = this.z === this.curve.one;\n\n // Use extended coordinates\n if (this.curve.extended && !this.t) {\n this.t = this.x.redMul(this.y);\n if (!this.zOne)\n this.t = this.t.redMul(this.z.redInvm());\n }\n }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.x.cmpn(0) === 0 &&\n (this.y.cmp(this.z) === 0 ||\n (this.zOne && this.y.cmp(this.curve.c) === 0));\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #doubling-dbl-2008-hwcd\n // 4M + 4S\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = 2 * Z1^2\n var c = this.z.redSqr();\n c = c.redIAdd(c);\n // D = a * A\n var d = this.curve._mulA(a);\n // E = (X1 + Y1)^2 - A - B\n var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n // G = D + B\n var g = d.redAdd(b);\n // F = G - C\n var f = g.redSub(c);\n // H = D - B\n var h = d.redSub(b);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #doubling-dbl-2008-bbjlp\n // #doubling-dbl-2007-bl\n // and others\n // Generally 3M + 4S or 2M + 4S\n\n // B = (X1 + Y1)^2\n var b = this.x.redAdd(this.y).redSqr();\n // C = X1^2\n var c = this.x.redSqr();\n // D = Y1^2\n var d = this.y.redSqr();\n\n var nx;\n var ny;\n var nz;\n var e;\n var h;\n var j;\n if (this.curve.twisted) {\n // E = a * C\n e = this.curve._mulA(c);\n // F = E + D\n var f = e.redAdd(d);\n if (this.zOne) {\n // X3 = (B - C - D) * (F - 2)\n nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F^2 - 2 * F\n nz = f.redSqr().redSub(f).redSub(f);\n } else {\n // H = Z1^2\n h = this.z.redSqr();\n // J = F - 2 * H\n j = f.redSub(h).redISub(h);\n // X3 = (B-C-D)*J\n nx = b.redSub(c).redISub(d).redMul(j);\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F * J\n nz = f.redMul(j);\n }\n } else {\n // E = C + D\n e = c.redAdd(d);\n // H = (c * Z1)^2\n h = this.curve._mulC(this.z).redSqr();\n // J = E - 2 * H\n j = e.redSub(h).redSub(h);\n // X3 = c * (B - E) * J\n nx = this.curve._mulC(b.redISub(e)).redMul(j);\n // Y3 = c * E * (C - D)\n ny = this.curve._mulC(e).redMul(c.redISub(d));\n // Z3 = E * J\n nz = e.redMul(j);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n // Double in extended coordinates\n if (this.curve.extended)\n return this._extDbl();\n else\n return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #addition-add-2008-hwcd-3\n // 8M\n\n // A = (Y1 - X1) * (Y2 - X2)\n var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n // B = (Y1 + X1) * (Y2 + X2)\n var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n // C = T1 * k * T2\n var c = this.t.redMul(this.curve.dd).redMul(p.t);\n // D = Z1 * 2 * Z2\n var d = this.z.redMul(p.z.redAdd(p.z));\n // E = B - A\n var e = b.redSub(a);\n // F = D - C\n var f = d.redSub(c);\n // G = D + C\n var g = d.redAdd(c);\n // H = B + A\n var h = b.redAdd(a);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #addition-add-2008-bbjlp\n // #addition-add-2007-bl\n // 10M + 1S\n\n // A = Z1 * Z2\n var a = this.z.redMul(p.z);\n // B = A^2\n var b = a.redSqr();\n // C = X1 * X2\n var c = this.x.redMul(p.x);\n // D = Y1 * Y2\n var d = this.y.redMul(p.y);\n // E = d * C * D\n var e = this.curve.d.redMul(c).redMul(d);\n // F = B - E\n var f = b.redSub(e);\n // G = B + E\n var g = b.redAdd(e);\n // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n var nx = a.redMul(f).redMul(tmp);\n var ny;\n var nz;\n if (this.curve.twisted) {\n // Y3 = A * G * (D - a * C)\n ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n // Z3 = F * G\n nz = f.redMul(g);\n } else {\n // Y3 = A * G * (D - C)\n ny = a.redMul(g).redMul(d.redSub(c));\n // Z3 = c * F * G\n nz = this.curve._mulC(f).redMul(g);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n if (this.isInfinity())\n return p;\n if (p.isInfinity())\n return this;\n\n if (this.curve.extended)\n return this._extAdd(p);\n else\n return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, false);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, true);\n};\n\nPoint.prototype.normalize = function normalize() {\n if (this.zOne)\n return this;\n\n // Normalize coordinates\n var zi = this.z.redInvm();\n this.x = this.x.redMul(zi);\n this.y = this.y.redMul(zi);\n if (this.t)\n this.t = this.t.redMul(zi);\n this.z = this.curve.one;\n this.zOne = true;\n return this;\n};\n\nPoint.prototype.neg = function neg() {\n return this.curve.point(this.x.redNeg(),\n this.y,\n this.z,\n this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n this.normalize();\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n this.normalize();\n return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n return this === other ||\n this.getX().cmp(other.getX()) === 0 &&\n this.getY().cmp(other.getY()) === 0;\n};\n\nPoint.prototype.eqXToP = function eqXToP(x) {\n var rx = x.toRed(this.curve.red).redMul(this.z);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(this.z);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n","'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n return false;\n }\n if (i < 0 || i + 1 >= msg.length) {\n return false;\n }\n return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg === 'string') {\n if (!enc) {\n // Inspired by stringToUtf8ByteArray() in closure-library by Google\n // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n // Apache License 2.0\n // https://github.com/google/closure-library/blob/master/LICENSE\n var p = 0;\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n if (c < 128) {\n res[p++] = c;\n } else if (c < 2048) {\n res[p++] = (c >> 6) | 192;\n res[p++] = (c & 63) | 128;\n } else if (isSurrogatePair(msg, i)) {\n c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n res[p++] = (c >> 18) | 240;\n res[p++] = ((c >> 12) & 63) | 128;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n } else {\n res[p++] = (c >> 12) | 224;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n }\n }\n } else if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n }\n } else {\n for (i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n }\n return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n var res = (w >>> 24) |\n ((w >>> 8) & 0xff00) |\n ((w << 8) & 0xff0000) |\n ((w & 0xff) << 24);\n return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n var res = '';\n for (var i = 0; i < msg.length; i++) {\n var w = msg[i];\n if (endian === 'little')\n w = htonl(w);\n res += zero8(w.toString(16));\n }\n return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n if (word.length === 7)\n return '0' + word;\n else if (word.length === 6)\n return '00' + word;\n else if (word.length === 5)\n return '000' + word;\n else if (word.length === 4)\n return '0000' + word;\n else if (word.length === 3)\n return '00000' + word;\n else if (word.length === 2)\n return '000000' + word;\n else if (word.length === 1)\n return '0000000' + word;\n else\n return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n var len = end - start;\n assert(len % 4 === 0);\n var res = new Array(len / 4);\n for (var i = 0, k = start; i < res.length; i++, k += 4) {\n var w;\n if (endian === 'big')\n w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n else\n w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n res[i] = w >>> 0;\n }\n return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n var res = new Array(msg.length * 4);\n for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n var m = msg[i];\n if (endian === 'big') {\n res[k] = m >>> 24;\n res[k + 1] = (m >>> 16) & 0xff;\n res[k + 2] = (m >>> 8) & 0xff;\n res[k + 3] = m & 0xff;\n } else {\n res[k + 3] = m >>> 24;\n res[k + 2] = (m >>> 16) & 0xff;\n res[k + 1] = (m >>> 8) & 0xff;\n res[k] = m & 0xff;\n }\n }\n return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n var bh = buf[pos];\n var bl = buf[pos + 1];\n\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n buf[pos] = hi >>> 0;\n buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n var lo = al + bl;\n return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n\n var hi = ah + bh + ch + dh + carry;\n return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n var lo = al + bl + cl + dl;\n return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n lo = (lo + el) >>> 0;\n carry += lo < el ? 1 : 0;\n\n var hi = ah + bh + ch + dh + eh + carry;\n return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var lo = al + bl + cl + dl + el;\n\n return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n var r = (al << (32 - num)) | (ah >>> num);\n return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n this.pending = null;\n this.pendingTotal = 0;\n this.blockSize = this.constructor.blockSize;\n this.outSize = this.constructor.outSize;\n this.hmacStrength = this.constructor.hmacStrength;\n this.padLength = this.constructor.padLength / 8;\n this.endian = 'big';\n\n this._delta8 = this.blockSize / 8;\n this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n // Convert message to array, pad it, and join into 32bit blocks\n msg = utils.toArray(msg, enc);\n if (!this.pending)\n this.pending = msg;\n else\n this.pending = this.pending.concat(msg);\n this.pendingTotal += msg.length;\n\n // Enough data, try updating\n if (this.pending.length >= this._delta8) {\n msg = this.pending;\n\n // Process pending data in blocks\n var r = msg.length % this._delta8;\n this.pending = msg.slice(msg.length - r, msg.length);\n if (this.pending.length === 0)\n this.pending = null;\n\n msg = utils.join32(msg, 0, msg.length - r, this.endian);\n for (var i = 0; i < msg.length; i += this._delta32)\n this._update(msg, i, i + this._delta32);\n }\n\n return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n this.update(this._pad());\n assert(this.pending === null);\n\n return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n var len = this.pendingTotal;\n var bytes = this._delta8;\n var k = bytes - ((len + this.padLength) % bytes);\n var res = new Array(k + this.padLength);\n res[0] = 0x80;\n for (var i = 1; i < k; i++)\n res[i] = 0;\n\n // Append length\n len <<= 3;\n if (this.endian === 'big') {\n for (var t = 8; t < this.padLength; t++)\n res[i++] = 0;\n\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = len & 0xff;\n } else {\n res[i++] = len & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n\n for (t = 8; t < this.padLength; t++)\n res[i++] = 0;\n }\n\n return res;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n if (s === 0)\n return ch32(x, y, z);\n if (s === 1 || s === 3)\n return p32(x, y, z);\n if (s === 2)\n return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n 0x5A827999, 0x6ED9EBA1,\n 0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n if (!(this instanceof SHA1))\n return new SHA1();\n\n BlockHash.call(this);\n this.h = [\n 0x67452301, 0xefcdab89, 0x98badcfe,\n 0x10325476, 0xc3d2e1f0 ];\n this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n\n for(; i < W.length; i++)\n W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n\n for (i = 0; i < W.length; i++) {\n var s = ~~(i / 20);\n var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n e = d;\n d = c;\n c = rotl32(b, 30);\n b = a;\n a = t;\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n if (!(this instanceof SHA256))\n return new SHA256();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n ];\n this.k = sha256_K;\n this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i++)\n W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n var f = this.h[5];\n var g = this.h[6];\n var h = this.h[7];\n\n assert(this.k.length === W.length);\n for (i = 0; i < W.length; i++) {\n var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n var T2 = sum32(s0_256(a), maj32(a, b, c));\n h = g;\n g = f;\n f = e;\n e = sum32(d, T1);\n d = c;\n c = b;\n b = a;\n a = sum32(T1, T2);\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n this.h[5] = sum32(this.h[5], f);\n this.h[6] = sum32(this.h[6], g);\n this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n if (!(this instanceof SHA224))\n return new SHA224();\n\n SHA256.call(this);\n this.h = [\n 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n // Just truncate output\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 7), 'big');\n else\n return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n if (!(this instanceof SHA512))\n return new SHA512();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xf3bcc908,\n 0xbb67ae85, 0x84caa73b,\n 0x3c6ef372, 0xfe94f82b,\n 0xa54ff53a, 0x5f1d36f1,\n 0x510e527f, 0xade682d1,\n 0x9b05688c, 0x2b3e6c1f,\n 0x1f83d9ab, 0xfb41bd6b,\n 0x5be0cd19, 0x137e2179 ];\n this.k = sha512_K;\n this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n var W = this.W;\n\n // 32 x 32bit words\n for (var i = 0; i < 32; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i += 2) {\n var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2\n var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n var c1_hi = W[i - 14]; // i - 7\n var c1_lo = W[i - 13];\n var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15\n var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n var c3_hi = W[i - 32]; // i - 16\n var c3_lo = W[i - 31];\n\n W[i] = sum64_4_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n W[i + 1] = sum64_4_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n this._prepareBlock(msg, start);\n\n var W = this.W;\n\n var ah = this.h[0];\n var al = this.h[1];\n var bh = this.h[2];\n var bl = this.h[3];\n var ch = this.h[4];\n var cl = this.h[5];\n var dh = this.h[6];\n var dl = this.h[7];\n var eh = this.h[8];\n var el = this.h[9];\n var fh = this.h[10];\n var fl = this.h[11];\n var gh = this.h[12];\n var gl = this.h[13];\n var hh = this.h[14];\n var hl = this.h[15];\n\n assert(this.k.length === W.length);\n for (var i = 0; i < W.length; i += 2) {\n var c0_hi = hh;\n var c0_lo = hl;\n var c1_hi = s1_512_hi(eh, el);\n var c1_lo = s1_512_lo(eh, el);\n var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n var c3_hi = this.k[i];\n var c3_lo = this.k[i + 1];\n var c4_hi = W[i];\n var c4_lo = W[i + 1];\n\n var T1_hi = sum64_5_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n var T1_lo = sum64_5_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n\n c0_hi = s0_512_hi(ah, al);\n c0_lo = s0_512_lo(ah, al);\n c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n hh = gh;\n hl = gl;\n\n gh = fh;\n gl = fl;\n\n fh = eh;\n fl = el;\n\n eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n dh = ch;\n dl = cl;\n\n ch = bh;\n cl = bl;\n\n bh = ah;\n bl = al;\n\n ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n }\n\n sum64(this.h, 0, ah, al);\n sum64(this.h, 2, bh, bl);\n sum64(this.h, 4, ch, cl);\n sum64(this.h, 6, dh, dl);\n sum64(this.h, 8, eh, el);\n sum64(this.h, 10, fh, fl);\n sum64(this.h, 12, gh, gl);\n sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ ((~xh) & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ ((~xl) & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 28);\n var c1_hi = rotr64_hi(xl, xh, 2); // 34\n var c2_hi = rotr64_hi(xl, xh, 7); // 39\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 28);\n var c1_lo = rotr64_lo(xl, xh, 2); // 34\n var c2_lo = rotr64_lo(xl, xh, 7); // 39\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 14);\n var c1_hi = rotr64_hi(xh, xl, 18);\n var c2_hi = rotr64_hi(xl, xh, 9); // 41\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 14);\n var c1_lo = rotr64_lo(xh, xl, 18);\n var c2_lo = rotr64_lo(xl, xh, 9); // 41\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 1);\n var c1_hi = rotr64_hi(xh, xl, 8);\n var c2_hi = shr64_hi(xh, xl, 7);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 1);\n var c1_lo = rotr64_lo(xh, xl, 8);\n var c2_lo = shr64_lo(xh, xl, 7);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 19);\n var c1_hi = rotr64_hi(xl, xh, 29); // 61\n var c2_hi = shr64_hi(xh, xl, 6);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 19);\n var c1_lo = rotr64_lo(xl, xh, 29); // 61\n var c2_lo = shr64_lo(xh, xl, 6);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n","'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n if (!(this instanceof SHA384))\n return new SHA384();\n\n SHA512.call(this);\n this.h = [\n 0xcbbb9d5d, 0xc1059ed8,\n 0x629a292a, 0x367cd507,\n 0x9159015a, 0x3070dd17,\n 0x152fecd8, 0xf70e5939,\n 0x67332667, 0xffc00b31,\n 0x8eb44a87, 0x68581511,\n 0xdb0c2e0d, 0x64f98fa7,\n 0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 12), 'big');\n else\n return utils.split32(this.h.slice(0, 12), 'big');\n};\n","'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n","'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n if (!(this instanceof RIPEMD160))\n return new RIPEMD160();\n\n BlockHash.call(this);\n\n this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n var A = this.h[0];\n var B = this.h[1];\n var C = this.h[2];\n var D = this.h[3];\n var E = this.h[4];\n var Ah = A;\n var Bh = B;\n var Ch = C;\n var Dh = D;\n var Eh = E;\n for (var j = 0; j < 80; j++) {\n var T = sum32(\n rotl32(\n sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n s[j]),\n E);\n A = E;\n E = D;\n D = rotl32(C, 10);\n C = B;\n B = T;\n T = sum32(\n rotl32(\n sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n sh[j]),\n Eh);\n Ah = Eh;\n Eh = Dh;\n Dh = rotl32(Ch, 10);\n Ch = Bh;\n Bh = T;\n }\n T = sum32_3(this.h[1], C, Dh);\n this.h[1] = sum32_3(this.h[2], D, Eh);\n this.h[2] = sum32_3(this.h[3], E, Ah);\n this.h[3] = sum32_3(this.h[4], A, Bh);\n this.h[4] = sum32_3(this.h[0], B, Ch);\n this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'little');\n else\n return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n if (j <= 15)\n return x ^ y ^ z;\n else if (j <= 31)\n return (x & y) | ((~x) & z);\n else if (j <= 47)\n return (x | (~y)) ^ z;\n else if (j <= 63)\n return (x & z) | (y & (~z));\n else\n return x ^ (y | (~z));\n}\n\nfunction K(j) {\n if (j <= 15)\n return 0x00000000;\n else if (j <= 31)\n return 0x5a827999;\n else if (j <= 47)\n return 0x6ed9eba1;\n else if (j <= 63)\n return 0x8f1bbcdc;\n else\n return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n if (j <= 15)\n return 0x50a28be6;\n else if (j <= 31)\n return 0x5c4dd124;\n else if (j <= 47)\n return 0x6d703ef3;\n else if (j <= 63)\n return 0x7a6d76e9;\n else\n return 0x00000000;\n}\n\nvar r = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n if (!(this instanceof Hmac))\n return new Hmac(hash, key, enc);\n this.Hash = hash;\n this.blockSize = hash.blockSize / 8;\n this.outSize = hash.outSize / 8;\n this.inner = null;\n this.outer = null;\n\n this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n // Shorten key, if needed\n if (key.length > this.blockSize)\n key = new this.Hash().update(key).digest();\n assert(key.length <= this.blockSize);\n\n // Add padding to key\n for (var i = key.length; i < this.blockSize; i++)\n key.push(0);\n\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x36;\n this.inner = new this.Hash().update(key);\n\n // 0x36 ^ 0x5c = 0x6a\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x6a;\n this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n this.inner.update(msg, enc);\n return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n this.outer.update(this.inner.digest());\n return this.outer.digest(enc);\n};\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","module.exports = {\n doubles: {\n step: 4,\n points: [\n [\n 'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n 'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821',\n ],\n [\n '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf',\n ],\n [\n '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n 'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695',\n ],\n [\n '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9',\n ],\n [\n '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36',\n ],\n [\n '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f',\n ],\n [\n 'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999',\n ],\n [\n '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n 'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09',\n ],\n [\n 'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d',\n ],\n [\n 'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n 'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088',\n ],\n [\n 'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d',\n ],\n [\n '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8',\n ],\n [\n '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a',\n ],\n [\n '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453',\n ],\n [\n '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160',\n ],\n [\n '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0',\n ],\n [\n '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6',\n ],\n [\n '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589',\n ],\n [\n '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n 'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17',\n ],\n [\n 'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda',\n ],\n [\n 'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd',\n ],\n [\n '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2',\n ],\n [\n '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6',\n ],\n [\n 'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f',\n ],\n [\n '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n 'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01',\n ],\n [\n 'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3',\n ],\n [\n 'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n 'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f',\n ],\n [\n 'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7',\n ],\n [\n 'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n 'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78',\n ],\n [\n 'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1',\n ],\n [\n '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n 'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150',\n ],\n [\n '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82',\n ],\n [\n 'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc',\n ],\n [\n '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n 'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b',\n ],\n [\n 'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51',\n ],\n [\n 'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45',\n ],\n [\n 'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n 'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120',\n ],\n [\n '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84',\n ],\n [\n '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d',\n ],\n [\n '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n 'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d',\n ],\n [\n '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8',\n ],\n [\n 'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8',\n ],\n [\n '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac',\n ],\n [\n '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n 'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f',\n ],\n [\n '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962',\n ],\n [\n 'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907',\n ],\n [\n '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n 'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec',\n ],\n [\n 'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n 'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d',\n ],\n [\n 'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414',\n ],\n [\n '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n 'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd',\n ],\n [\n '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n 'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0',\n ],\n [\n 'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811',\n ],\n [\n 'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1',\n ],\n [\n 'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c',\n ],\n [\n '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n 'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73',\n ],\n [\n '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd',\n ],\n [\n 'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n 'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405',\n ],\n [\n '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n 'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589',\n ],\n [\n '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e',\n ],\n [\n '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27',\n ],\n [\n 'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n 'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1',\n ],\n [\n '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482',\n ],\n [\n '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945',\n ],\n [\n 'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573',\n ],\n [\n 'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n 'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82',\n ],\n ],\n },\n naf: {\n wnd: 7,\n points: [\n [\n 'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672',\n ],\n [\n '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n 'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6',\n ],\n [\n '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da',\n ],\n [\n 'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n 'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37',\n ],\n [\n '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n 'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b',\n ],\n [\n 'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n 'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81',\n ],\n [\n 'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58',\n ],\n [\n 'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77',\n ],\n [\n '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a',\n ],\n [\n '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c',\n ],\n [\n '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67',\n ],\n [\n '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402',\n ],\n [\n 'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n 'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55',\n ],\n [\n 'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482',\n ],\n [\n '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n 'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82',\n ],\n [\n '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n 'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396',\n ],\n [\n '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49',\n ],\n [\n '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf',\n ],\n [\n '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a',\n ],\n [\n '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n 'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7',\n ],\n [\n 'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n 'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933',\n ],\n [\n '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a',\n ],\n [\n '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6',\n ],\n [\n 'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n 'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37',\n ],\n [\n '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e',\n ],\n [\n 'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n 'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6',\n ],\n [\n 'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n 'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476',\n ],\n [\n '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40',\n ],\n [\n '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61',\n ],\n [\n '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683',\n ],\n [\n 'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5',\n ],\n [\n '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b',\n ],\n [\n 'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417',\n ],\n [\n '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n 'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868',\n ],\n [\n '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n 'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a',\n ],\n [\n 'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n 'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6',\n ],\n [\n '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996',\n ],\n [\n '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n 'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e',\n ],\n [\n 'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n 'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d',\n ],\n [\n '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2',\n ],\n [\n '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n 'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e',\n ],\n [\n '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437',\n ],\n [\n '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n 'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311',\n ],\n [\n 'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4',\n ],\n [\n '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575',\n ],\n [\n '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n 'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d',\n ],\n [\n '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n 'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d',\n ],\n [\n 'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n 'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629',\n ],\n [\n 'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n 'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06',\n ],\n [\n '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374',\n ],\n [\n '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee',\n ],\n [\n 'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1',\n ],\n [\n 'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n 'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b',\n ],\n [\n '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661',\n ],\n [\n '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6',\n ],\n [\n 'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e',\n ],\n [\n '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d',\n ],\n [\n 'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n 'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc',\n ],\n [\n '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n 'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4',\n ],\n [\n '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c',\n ],\n [\n 'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b',\n ],\n [\n 'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913',\n ],\n [\n '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154',\n ],\n [\n '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865',\n ],\n [\n '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n 'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc',\n ],\n [\n '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n 'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224',\n ],\n [\n '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e',\n ],\n [\n '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6',\n ],\n [\n '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511',\n ],\n [\n '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n 'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b',\n ],\n [\n 'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n 'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2',\n ],\n [\n '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n 'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c',\n ],\n [\n 'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3',\n ],\n [\n 'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d',\n ],\n [\n 'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700',\n ],\n [\n 'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4',\n ],\n [\n '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n 'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196',\n ],\n [\n '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4',\n ],\n [\n '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n 'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257',\n ],\n [\n 'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n 'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13',\n ],\n [\n 'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096',\n ],\n [\n 'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n 'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38',\n ],\n [\n 'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f',\n ],\n [\n '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448',\n ],\n [\n 'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a',\n ],\n [\n 'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4',\n ],\n [\n '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437',\n ],\n [\n '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n 'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7',\n ],\n [\n 'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d',\n ],\n [\n 'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a',\n ],\n [\n 'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54',\n ],\n [\n '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77',\n ],\n [\n 'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n 'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517',\n ],\n [\n '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n 'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10',\n ],\n [\n 'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n 'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125',\n ],\n [\n 'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e',\n ],\n [\n '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n 'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1',\n ],\n [\n 'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2',\n ],\n [\n 'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423',\n ],\n [\n 'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8',\n ],\n [\n '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n 'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758',\n ],\n [\n '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n 'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375',\n ],\n [\n 'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d',\n ],\n [\n '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n 'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec',\n ],\n [\n '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0',\n ],\n [\n '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n 'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c',\n ],\n [\n 'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n 'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4',\n ],\n [\n '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n 'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f',\n ],\n [\n '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649',\n ],\n [\n '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n 'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826',\n ],\n [\n '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5',\n ],\n [\n 'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n 'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87',\n ],\n [\n '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b',\n ],\n [\n 'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc',\n ],\n [\n '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c',\n ],\n [\n 'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n 'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f',\n ],\n [\n 'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a',\n ],\n [\n 'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n 'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46',\n ],\n [\n '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n 'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f',\n ],\n [\n '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03',\n ],\n [\n '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n 'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08',\n ],\n [\n '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8',\n ],\n [\n '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373',\n ],\n [\n '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n 'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3',\n ],\n [\n '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8',\n ],\n [\n '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1',\n ],\n [\n '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9',\n ],\n ],\n },\n};\n","'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar curve = require('./curve');\nvar utils = require('./utils');\n\nvar assert = utils.assert;\n\nfunction PresetCurve(options) {\n if (options.type === 'short')\n this.curve = new curve.short(options);\n else if (options.type === 'edwards')\n this.curve = new curve.edwards(options);\n else\n this.curve = new curve.mont(options);\n this.g = this.curve.g;\n this.n = this.curve.n;\n this.hash = options.hash;\n\n assert(this.g.validate(), 'Invalid curve');\n assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n get: function() {\n var curve = new PresetCurve(options);\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n value: curve,\n });\n return curve;\n },\n });\n}\n\ndefineCurve('p192', {\n type: 'short',\n prime: 'p192',\n p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n hash: hash.sha256,\n gRed: false,\n g: [\n '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811',\n ],\n});\n\ndefineCurve('p224', {\n type: 'short',\n prime: 'p224',\n p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n hash: hash.sha256,\n gRed: false,\n g: [\n 'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n 'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34',\n ],\n});\n\ndefineCurve('p256', {\n type: 'short',\n prime: null,\n p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n hash: hash.sha256,\n gRed: false,\n g: [\n '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5',\n ],\n});\n\ndefineCurve('p384', {\n type: 'short',\n prime: null,\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 ffffffff',\n a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 fffffffc',\n b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n 'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n hash: hash.sha384,\n gRed: false,\n g: [\n 'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n '5502f25d bf55296c 3a545e38 72760ab7',\n '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f',\n ],\n});\n\ndefineCurve('p521', {\n type: 'short',\n prime: null,\n p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff',\n a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff fffffffc',\n b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n 'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n hash: hash.sha512,\n gRed: false,\n g: [\n '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n 'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n '3fad0761 353c7086 a272c240 88be9476 9fd16650',\n ],\n});\n\ndefineCurve('curve25519', {\n type: 'mont',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '76d06',\n b: '1',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '9',\n ],\n});\n\ndefineCurve('ed25519', {\n type: 'edwards',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '-1',\n c: '1',\n // -121665 * (121666^(-1)) (mod P)\n d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n // 4/5\n '6666666666666666666666666666666666666666666666666666666666666658',\n ],\n});\n\nvar pre;\ntry {\n pre = require('./precomputed/secp256k1');\n} catch (e) {\n pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n type: 'short',\n prime: 'k256',\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n a: '0',\n b: '7',\n n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n h: '1',\n hash: hash.sha256,\n\n // Precomputed endomorphism\n beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n basis: [\n {\n a: '3086d221a7d46bcde86c90e49284eb15',\n b: '-e4437ed6010e88286f547fa90abfe4c3',\n },\n {\n a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n b: '3086d221a7d46bcde86c90e49284eb15',\n },\n ],\n\n gRed: false,\n g: [\n '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n pre,\n ],\n});\n","'use strict';\n\nvar hash = require('hash.js');\nvar utils = require('minimalistic-crypto-utils');\nvar assert = require('minimalistic-assert');\n\nfunction HmacDRBG(options) {\n if (!(this instanceof HmacDRBG))\n return new HmacDRBG(options);\n this.hash = options.hash;\n this.predResist = !!options.predResist;\n\n this.outLen = this.hash.outSize;\n this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n this._reseed = null;\n this.reseedInterval = null;\n this.K = null;\n this.V = null;\n\n var entropy = utils.toArray(options.entropy, options.entropyEnc || 'hex');\n var nonce = utils.toArray(options.nonce, options.nonceEnc || 'hex');\n var pers = utils.toArray(options.pers, options.persEnc || 'hex');\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n var seed = entropy.concat(nonce).concat(pers);\n\n this.K = new Array(this.outLen / 8);\n this.V = new Array(this.outLen / 8);\n for (var i = 0; i < this.V.length; i++) {\n this.K[i] = 0x00;\n this.V[i] = 0x01;\n }\n\n this._update(seed);\n this._reseed = 1;\n this.reseedInterval = 0x1000000000000; // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n var kmac = this._hmac()\n .update(this.V)\n .update([ 0x00 ]);\n if (seed)\n kmac = kmac.update(seed);\n this.K = kmac.digest();\n this.V = this._hmac().update(this.V).digest();\n if (!seed)\n return;\n\n this.K = this._hmac()\n .update(this.V)\n .update([ 0x01 ])\n .update(seed)\n .digest();\n this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n // Optional entropy enc\n if (typeof entropyEnc !== 'string') {\n addEnc = add;\n add = entropyEnc;\n entropyEnc = null;\n }\n\n entropy = utils.toArray(entropy, entropyEnc);\n add = utils.toArray(add, addEnc);\n\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n this._update(entropy.concat(add || []));\n this._reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n if (this._reseed > this.reseedInterval)\n throw new Error('Reseed is required');\n\n // Optional encoding\n if (typeof enc !== 'string') {\n addEnc = add;\n add = enc;\n enc = null;\n }\n\n // Optional additional data\n if (add) {\n add = utils.toArray(add, addEnc || 'hex');\n this._update(add);\n }\n\n var temp = [];\n while (temp.length < len) {\n this.V = this._hmac().update(this.V).digest();\n temp = temp.concat(this.V);\n }\n\n var res = temp.slice(0, len);\n this._update(add);\n this._reseed++;\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction KeyPair(ec, options) {\n this.ec = ec;\n this.priv = null;\n this.pub = null;\n\n // KeyPair(ec, { priv: ..., pub: ... })\n if (options.priv)\n this._importPrivate(options.priv, options.privEnc);\n if (options.pub)\n this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n if (pub instanceof KeyPair)\n return pub;\n\n return new KeyPair(ec, {\n pub: pub,\n pubEnc: enc,\n });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n if (priv instanceof KeyPair)\n return priv;\n\n return new KeyPair(ec, {\n priv: priv,\n privEnc: enc,\n });\n};\n\nKeyPair.prototype.validate = function validate() {\n var pub = this.getPublic();\n\n if (pub.isInfinity())\n return { result: false, reason: 'Invalid public key' };\n if (!pub.validate())\n return { result: false, reason: 'Public key is not a point' };\n if (!pub.mul(this.ec.curve.n).isInfinity())\n return { result: false, reason: 'Public key * N != O' };\n\n return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n // compact is optional argument\n if (typeof compact === 'string') {\n enc = compact;\n compact = null;\n }\n\n if (!this.pub)\n this.pub = this.ec.g.mul(this.priv);\n\n if (!enc)\n return this.pub;\n\n return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n if (enc === 'hex')\n return this.priv.toString(16, 2);\n else\n return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n this.priv = new BN(key, enc || 16);\n\n // Ensure that the priv won't be bigger than n, otherwise we may fail\n // in fixed multiplication method\n this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n if (key.x || key.y) {\n // Montgomery points only have an `x` coordinate.\n // Weierstrass/Edwards points on the other hand have both `x` and\n // `y` coordinates.\n if (this.ec.curve.type === 'mont') {\n assert(key.x, 'Need x coordinate');\n } else if (this.ec.curve.type === 'short' ||\n this.ec.curve.type === 'edwards') {\n assert(key.x && key.y, 'Need both x and y coordinate');\n }\n this.pub = this.ec.curve.point(key.x, key.y);\n return;\n }\n this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n if(!pub.validate()) {\n assert(pub.validate(), 'public point not validated');\n }\n return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature, options) {\n return this.ec.verify(msg, signature, this, undefined, options);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n return '';\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n if (options instanceof Signature)\n return options;\n\n if (this._importDER(options, enc))\n return;\n\n assert(options.r && options.s, 'Signature without r or s');\n this.r = new BN(options.r, 16);\n this.s = new BN(options.s, 16);\n if (options.recoveryParam === undefined)\n this.recoveryParam = null;\n else\n this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n this.place = 0;\n}\n\nfunction getLength(buf, p) {\n var initial = buf[p.place++];\n if (!(initial & 0x80)) {\n return initial;\n }\n var octetLen = initial & 0xf;\n\n // Indefinite length or overflow\n if (octetLen === 0 || octetLen > 4) {\n return false;\n }\n\n if(buf[p.place] === 0x00) {\n return false;\n }\n\n var val = 0;\n for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n val <<= 8;\n val |= buf[off];\n val >>>= 0;\n }\n\n // Leading zeroes\n if (val <= 0x7f) {\n return false;\n }\n\n p.place = off;\n return val;\n}\n\nfunction rmPadding(buf) {\n var i = 0;\n var len = buf.length - 1;\n while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n i++;\n }\n if (i === 0) {\n return buf;\n }\n return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n data = utils.toArray(data, enc);\n var p = new Position();\n if (data[p.place++] !== 0x30) {\n return false;\n }\n var len = getLength(data, p);\n if (len === false) {\n return false;\n }\n if ((len + p.place) !== data.length) {\n return false;\n }\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var rlen = getLength(data, p);\n if (rlen === false) {\n return false;\n }\n if ((data[p.place] & 128) !== 0) {\n return false;\n }\n var r = data.slice(p.place, rlen + p.place);\n p.place += rlen;\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var slen = getLength(data, p);\n if (slen === false) {\n return false;\n }\n if (data.length !== slen + p.place) {\n return false;\n }\n if ((data[p.place] & 128) !== 0) {\n return false;\n }\n var s = data.slice(p.place, slen + p.place);\n if (r[0] === 0) {\n if (r[1] & 0x80) {\n r = r.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n if (s[0] === 0) {\n if (s[1] & 0x80) {\n s = s.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n\n this.r = new BN(r);\n this.s = new BN(s);\n this.recoveryParam = null;\n\n return true;\n};\n\nfunction constructLength(arr, len) {\n if (len < 0x80) {\n arr.push(len);\n return;\n }\n var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n arr.push(octets | 0x80);\n while (--octets) {\n arr.push((len >>> (octets << 3)) & 0xff);\n }\n arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n var r = this.r.toArray();\n var s = this.s.toArray();\n\n // Pad values\n if (r[0] & 0x80)\n r = [ 0 ].concat(r);\n // Pad values\n if (s[0] & 0x80)\n s = [ 0 ].concat(s);\n\n r = rmPadding(r);\n s = rmPadding(s);\n\n while (!s[0] && !(s[1] & 0x80)) {\n s = s.slice(1);\n }\n var arr = [ 0x02 ];\n constructLength(arr, r.length);\n arr = arr.concat(r);\n arr.push(0x02);\n constructLength(arr, s.length);\n var backHalf = arr.concat(s);\n var res = [ 0x30 ];\n constructLength(res, backHalf.length);\n res = res.concat(backHalf);\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar HmacDRBG = require('hmac-drbg');\nvar utils = require('../utils');\nvar curves = require('../curves');\nvar rand = require('brorand');\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n if (!(this instanceof EC))\n return new EC(options);\n\n // Shortcut `elliptic.ec(curve-name)`\n if (typeof options === 'string') {\n assert(Object.prototype.hasOwnProperty.call(curves, options),\n 'Unknown curve ' + options);\n\n options = curves[options];\n }\n\n // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n if (options instanceof curves.PresetCurve)\n options = { curve: options };\n\n this.curve = options.curve.curve;\n this.n = this.curve.n;\n this.nh = this.n.ushrn(1);\n this.g = this.curve.g;\n\n // Point on curve\n this.g = options.curve.g;\n this.g.precompute(options.curve.n.bitLength() + 1);\n\n // Hash for function for DRBG\n this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n if (!options)\n options = {};\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n entropy: options.entropy || rand(this.hash.hmacStrength),\n entropyEnc: options.entropy && options.entropyEnc || 'utf8',\n nonce: this.n.toArray(),\n });\n\n var bytes = this.n.byteLength();\n var ns2 = this.n.sub(new BN(2));\n for (;;) {\n var priv = new BN(drbg.generate(bytes));\n if (priv.cmp(ns2) > 0)\n continue;\n\n priv.iaddn(1);\n return this.keyFromPrivate(priv);\n }\n};\n\nEC.prototype._truncateToN = function _truncateToN(msg, truncOnly, bitLength) {\n var byteLength;\n if (BN.isBN(msg) || typeof msg === 'number') {\n msg = new BN(msg, 16);\n byteLength = msg.byteLength();\n } else if (typeof msg === 'object') {\n // BN assumes an array-like input and asserts length\n byteLength = msg.length;\n msg = new BN(msg, 16);\n } else {\n // BN converts the value to string\n var str = msg.toString();\n // HEX encoding\n byteLength = (str.length + 1) >>> 1;\n msg = new BN(str, 16);\n }\n // Allow overriding\n if (typeof bitLength !== 'number') {\n bitLength = byteLength * 8;\n }\n var delta = bitLength - this.n.bitLength();\n if (delta > 0)\n msg = msg.ushrn(delta);\n if (!truncOnly && msg.cmp(this.n) >= 0)\n return msg.sub(this.n);\n else\n return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n if (typeof enc === 'object') {\n options = enc;\n enc = null;\n }\n if (!options)\n options = {};\n\n if (typeof msg !== 'string' && typeof msg !== 'number' && !BN.isBN(msg)) {\n assert(typeof msg === 'object' && msg && typeof msg.length === 'number',\n 'Expected message to be an array-like, a hex string, or a BN instance');\n assert((msg.length >>> 0) === msg.length); // non-negative 32-bit integer\n for (var i = 0; i < msg.length; i++) assert((msg[i] & 255) === msg[i]);\n }\n\n key = this.keyFromPrivate(key, enc);\n msg = this._truncateToN(msg, false, options.msgBitLength);\n\n // Would fail further checks, but let's make the error message clear\n assert(!msg.isNeg(), 'Can not sign a negative message');\n\n // Zero-extend key to provide enough entropy\n var bytes = this.n.byteLength();\n var bkey = key.getPrivate().toArray('be', bytes);\n\n // Zero-extend nonce to have the same byte size as N\n var nonce = msg.toArray('be', bytes);\n\n // Recheck nonce to be bijective to msg\n assert((new BN(nonce)).eq(msg), 'Can not sign message');\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n entropy: bkey,\n nonce: nonce,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n });\n\n // Number of bytes to generate\n var ns1 = this.n.sub(new BN(1));\n\n for (var iter = 0; ; iter++) {\n var k = options.k ?\n options.k(iter) :\n new BN(drbg.generate(this.n.byteLength()));\n k = this._truncateToN(k, true);\n if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n continue;\n\n var kp = this.g.mul(k);\n if (kp.isInfinity())\n continue;\n\n var kpX = kp.getX();\n var r = kpX.umod(this.n);\n if (r.cmpn(0) === 0)\n continue;\n\n var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n s = s.umod(this.n);\n if (s.cmpn(0) === 0)\n continue;\n\n var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n (kpX.cmp(r) !== 0 ? 2 : 0);\n\n // Use complement of `s`, if it is > `n / 2`\n if (options.canonical && s.cmp(this.nh) > 0) {\n s = this.n.sub(s);\n recoveryParam ^= 1;\n }\n\n return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc, options) {\n if (!options)\n options = {};\n\n msg = this._truncateToN(msg, false, options.msgBitLength);\n key = this.keyFromPublic(key, enc);\n signature = new Signature(signature, 'hex');\n\n // Perform primitive values validation\n var r = signature.r;\n var s = signature.s;\n if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n return false;\n if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n return false;\n\n // Validate signature\n var sinv = s.invm(this.n);\n var u1 = sinv.mul(msg).umod(this.n);\n var u2 = sinv.mul(r).umod(this.n);\n var p;\n\n if (!this.curve._maxwellTrick) {\n p = this.g.mulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n return p.getX().umod(this.n).cmp(r) === 0;\n }\n\n // NOTE: Greg Maxwell's trick, inspired by:\n // https://git.io/vad3K\n\n p = this.g.jmulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n // Compare `p.x` of Jacobian point with `r`,\n // this will do `p.x == r * p.z^2` instead of multiplying `p.x` by the\n // inverse of `p.z^2`\n return p.eqXToP(r);\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n assert((3 & j) === j, 'The recovery param is more than two bits');\n signature = new Signature(signature, enc);\n\n var n = this.n;\n var e = new BN(msg);\n var r = signature.r;\n var s = signature.s;\n\n // A set LSB signifies that the y-coordinate is odd\n var isYOdd = j & 1;\n var isSecondKey = j >> 1;\n if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n throw new Error('Unable to find sencond key candinate');\n\n // 1.1. Let x = r + jn.\n if (isSecondKey)\n r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n else\n r = this.curve.pointFromX(r, isYOdd);\n\n var rInv = signature.r.invm(n);\n var s1 = n.sub(e).mul(rInv).umod(n);\n var s2 = s.mul(rInv).umod(n);\n\n // 1.6.1 Compute Q = r^-1 (sR - eG)\n // Q = r^-1 (sR + -eG)\n return this.g.mulAdd(s1, r, s2);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n signature = new Signature(signature, enc);\n if (signature.recoveryParam !== null)\n return signature.recoveryParam;\n\n for (var i = 0; i < 4; i++) {\n var Qprime;\n try {\n Qprime = this.recoverPubKey(e, signature, i);\n } catch (e) {\n continue;\n }\n\n if (Qprime.eq(Q))\n return i;\n }\n throw new Error('Unable to find valid recovery factor');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n this.eddsa = eddsa;\n this._secret = parseBytes(params.secret);\n if (eddsa.isPoint(params.pub))\n this._pub = params.pub;\n else\n this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n if (pub instanceof KeyPair)\n return pub;\n return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n if (secret instanceof KeyPair)\n return secret;\n return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n return this._secret;\n};\n\ncachedProperty(KeyPair, 'pubBytes', function pubBytes() {\n return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, 'pub', function pub() {\n if (this._pubBytes)\n return this.eddsa.decodePoint(this._pubBytes);\n return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, 'privBytes', function privBytes() {\n var eddsa = this.eddsa;\n var hash = this.hash();\n var lastIx = eddsa.encodingLength - 1;\n\n var a = hash.slice(0, eddsa.encodingLength);\n a[0] &= 248;\n a[lastIx] &= 127;\n a[lastIx] |= 64;\n\n return a;\n});\n\ncachedProperty(KeyPair, 'priv', function priv() {\n return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, 'hash', function hash() {\n return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, 'messagePrefix', function messagePrefix() {\n return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n assert(this._secret, 'KeyPair can only verify');\n return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n assert(this._secret, 'KeyPair is public only');\n return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array|Object} sig -\n* @param {Array|Point} [sig.R] - R point as Point or bytes\n* @param {Array|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array} [sig.Rencoded] - R point encoded\n* @param {Array} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n this.eddsa = eddsa;\n\n if (typeof sig !== 'object')\n sig = parseBytes(sig);\n\n if (Array.isArray(sig)) {\n assert(sig.length === eddsa.encodingLength * 2, 'Signature has invalid size');\n sig = {\n R: sig.slice(0, eddsa.encodingLength),\n S: sig.slice(eddsa.encodingLength),\n };\n }\n\n assert(sig.R && sig.S, 'Signature without R or S');\n\n if (eddsa.isPoint(sig.R))\n this._R = sig.R;\n if (sig.S instanceof BN)\n this._S = sig.S;\n\n this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, 'S', function S() {\n return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, 'R', function R() {\n return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, 'Rencoded', function Rencoded() {\n return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, 'Sencoded', function Sencoded() {\n return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n","'use strict';\n\nvar hash = require('hash.js');\nvar curves = require('../curves');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n if (!(this instanceof EDDSA))\n return new EDDSA(curve);\n\n curve = curves[curve].curve;\n this.curve = curve;\n this.g = curve.g;\n this.g.precompute(curve.n.bitLength() + 1);\n\n this.pointClass = curve.point().constructor;\n this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n message = parseBytes(message);\n var key = this.keyFromSecret(secret);\n var r = this.hashInt(key.messagePrefix(), message);\n var R = this.g.mul(r);\n var Rencoded = this.encodePoint(R);\n var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n .mul(key.priv());\n var S = r.add(s_).umod(this.curve.n);\n return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n message = parseBytes(message);\n sig = this.makeSignature(sig);\n if (sig.S().gte(sig.eddsa.curve.n) || sig.S().isNeg()) {\n return false;\n }\n var key = this.keyFromPublic(pub);\n var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n var SG = this.g.mul(sig.S());\n var RplusAh = sig.R().add(key.pub().mul(h));\n return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n var hash = this.hash();\n for (var i = 0; i < arguments.length; i++)\n hash.update(arguments[i]);\n return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n if (sig instanceof Signature)\n return sig;\n return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n var enc = point.getY().toArray('le', this.encodingLength);\n enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n bytes = utils.parseBytes(bytes);\n\n var lastIx = bytes.length - 1;\n var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n var y = utils.intFromLE(normed);\n return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n return val instanceof this.pointClass;\n};\n","'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var indexOf = function (xs, item) {\n if (xs.indexOf) return xs.indexOf(item);\n else for (var i = 0; i < xs.length; i++) {\n if (xs[i] === item) return i;\n }\n return -1;\n};\nvar Object_keys = function (obj) {\n if (Object.keys) return Object.keys(obj)\n else {\n var res = [];\n for (var key in obj) res.push(key)\n return res;\n }\n};\n\nvar forEach = function (xs, fn) {\n if (xs.forEach) return xs.forEach(fn)\n else for (var i = 0; i < xs.length; i++) {\n fn(xs[i], i, xs);\n }\n};\n\nvar defineProp = (function() {\n try {\n Object.defineProperty({}, '_', {});\n return function(obj, name, value) {\n Object.defineProperty(obj, name, {\n writable: true,\n enumerable: false,\n configurable: true,\n value: value\n })\n };\n } catch(e) {\n return function(obj, name, value) {\n obj[name] = value;\n };\n }\n}());\n\nvar globals = ['Array', 'Boolean', 'Date', 'Error', 'EvalError', 'Function',\n'Infinity', 'JSON', 'Math', 'NaN', 'Number', 'Object', 'RangeError',\n'ReferenceError', 'RegExp', 'String', 'SyntaxError', 'TypeError', 'URIError',\n'decodeURI', 'decodeURIComponent', 'encodeURI', 'encodeURIComponent', 'escape',\n'eval', 'isFinite', 'isNaN', 'parseFloat', 'parseInt', 'undefined', 'unescape'];\n\nfunction Context() {}\nContext.prototype = {};\n\nvar Script = exports.Script = function NodeScript (code) {\n if (!(this instanceof Script)) return new Script(code);\n this.code = code;\n};\n\nScript.prototype.runInContext = function (context) {\n if (!(context instanceof Context)) {\n throw new TypeError(\"needs a 'context' argument.\");\n }\n \n var iframe = document.createElement('iframe');\n if (!iframe.style) iframe.style = {};\n iframe.style.display = 'none';\n \n document.body.appendChild(iframe);\n \n var win = iframe.contentWindow;\n var wEval = win.eval, wExecScript = win.execScript;\n\n if (!wEval && wExecScript) {\n // win.eval() magically appears when this is called in IE:\n wExecScript.call(win, 'null');\n wEval = win.eval;\n }\n \n forEach(Object_keys(context), function (key) {\n win[key] = context[key];\n });\n forEach(globals, function (key) {\n if (context[key]) {\n win[key] = context[key];\n }\n });\n \n var winKeys = Object_keys(win);\n\n var res = wEval.call(win, this.code);\n \n forEach(Object_keys(win), function (key) {\n // Avoid copying circular objects like `top` and `window` by only\n // updating existing context properties or new properties in the `win`\n // that was only introduced after the eval.\n if (key in context || indexOf(winKeys, key) === -1) {\n context[key] = win[key];\n }\n });\n\n forEach(globals, function (key) {\n if (!(key in context)) {\n defineProp(context, key, win[key]);\n }\n });\n \n document.body.removeChild(iframe);\n \n return res;\n};\n\nScript.prototype.runInThisContext = function () {\n return eval(this.code); // maybe...\n};\n\nScript.prototype.runInNewContext = function (context) {\n var ctx = Script.createContext(context);\n var res = this.runInContext(ctx);\n\n if (context) {\n forEach(Object_keys(ctx), function (key) {\n context[key] = ctx[key];\n });\n }\n\n return res;\n};\n\nforEach(Object_keys(Script.prototype), function (name) {\n exports[name] = Script[name] = function (code) {\n var s = Script(code);\n return s[name].apply(s, [].slice.call(arguments, 1));\n };\n});\n\nexports.isContext = function (context) {\n return context instanceof Context;\n};\n\nexports.createScript = function (code) {\n return exports.Script(code);\n};\n\nexports.createContext = Script.createContext = function (context) {\n var copy = new Context();\n if(typeof context === 'object') {\n forEach(Object_keys(context), function (key) {\n copy[key] = context[key];\n });\n }\n return copy;\n};\n","var asn1 = require('../asn1');\nvar inherits = require('inherits');\n\nvar api = exports;\n\napi.define = function define(name, body) {\n return new Entity(name, body);\n};\n\nfunction Entity(name, body) {\n this.name = name;\n this.body = body;\n\n this.decoders = {};\n this.encoders = {};\n};\n\nEntity.prototype._createNamed = function createNamed(base) {\n var named;\n try {\n named = require('vm').runInThisContext(\n '(function ' + this.name + '(entity) {\\n' +\n ' this._initNamed(entity);\\n' +\n '})'\n );\n } catch (e) {\n named = function (entity) {\n this._initNamed(entity);\n };\n }\n inherits(named, base);\n named.prototype._initNamed = function initnamed(entity) {\n base.call(this, entity);\n };\n\n return new named(this);\n};\n\nEntity.prototype._getDecoder = function _getDecoder(enc) {\n enc = enc || 'der';\n // Lazily create decoder\n if (!this.decoders.hasOwnProperty(enc))\n this.decoders[enc] = this._createNamed(asn1.decoders[enc]);\n return this.decoders[enc];\n};\n\nEntity.prototype.decode = function decode(data, enc, options) {\n return this._getDecoder(enc).decode(data, options);\n};\n\nEntity.prototype._getEncoder = function _getEncoder(enc) {\n enc = enc || 'der';\n // Lazily create encoder\n if (!this.encoders.hasOwnProperty(enc))\n this.encoders[enc] = this._createNamed(asn1.encoders[enc]);\n return this.encoders[enc];\n};\n\nEntity.prototype.encode = function encode(data, enc, /* internal */ reporter) {\n return this._getEncoder(enc).encode(data, reporter);\n};\n","var inherits = require('inherits');\n\nfunction Reporter(options) {\n this._reporterState = {\n obj: null,\n path: [],\n options: options || {},\n errors: []\n };\n}\nexports.Reporter = Reporter;\n\nReporter.prototype.isError = function isError(obj) {\n return obj instanceof ReporterError;\n};\n\nReporter.prototype.save = function save() {\n var state = this._reporterState;\n\n return { obj: state.obj, pathLen: state.path.length };\n};\n\nReporter.prototype.restore = function restore(data) {\n var state = this._reporterState;\n\n state.obj = data.obj;\n state.path = state.path.slice(0, data.pathLen);\n};\n\nReporter.prototype.enterKey = function enterKey(key) {\n return this._reporterState.path.push(key);\n};\n\nReporter.prototype.exitKey = function exitKey(index) {\n var state = this._reporterState;\n\n state.path = state.path.slice(0, index - 1);\n};\n\nReporter.prototype.leaveKey = function leaveKey(index, key, value) {\n var state = this._reporterState;\n\n this.exitKey(index);\n if (state.obj !== null)\n state.obj[key] = value;\n};\n\nReporter.prototype.path = function path() {\n return this._reporterState.path.join('/');\n};\n\nReporter.prototype.enterObject = function enterObject() {\n var state = this._reporterState;\n\n var prev = state.obj;\n state.obj = {};\n return prev;\n};\n\nReporter.prototype.leaveObject = function leaveObject(prev) {\n var state = this._reporterState;\n\n var now = state.obj;\n state.obj = prev;\n return now;\n};\n\nReporter.prototype.error = function error(msg) {\n var err;\n var state = this._reporterState;\n\n var inherited = msg instanceof ReporterError;\n if (inherited) {\n err = msg;\n } else {\n err = new ReporterError(state.path.map(function(elem) {\n return '[' + JSON.stringify(elem) + ']';\n }).join(''), msg.message || msg, msg.stack);\n }\n\n if (!state.options.partial)\n throw err;\n\n if (!inherited)\n state.errors.push(err);\n\n return err;\n};\n\nReporter.prototype.wrapResult = function wrapResult(result) {\n var state = this._reporterState;\n if (!state.options.partial)\n return result;\n\n return {\n result: this.isError(result) ? null : result,\n errors: state.errors\n };\n};\n\nfunction ReporterError(path, msg) {\n this.path = path;\n this.rethrow(msg);\n};\ninherits(ReporterError, Error);\n\nReporterError.prototype.rethrow = function rethrow(msg) {\n this.message = msg + ' at: ' + (this.path || '(shallow)');\n if (Error.captureStackTrace)\n Error.captureStackTrace(this, ReporterError);\n\n if (!this.stack) {\n try {\n // IE only adds stack when thrown\n throw new Error(this.message);\n } catch (e) {\n this.stack = e.stack;\n }\n }\n return this;\n};\n","var inherits = require('inherits');\nvar Reporter = require('../base').Reporter;\nvar Buffer = require('buffer').Buffer;\n\nfunction DecoderBuffer(base, options) {\n Reporter.call(this, options);\n if (!Buffer.isBuffer(base)) {\n this.error('Input not Buffer');\n return;\n }\n\n this.base = base;\n this.offset = 0;\n this.length = base.length;\n}\ninherits(DecoderBuffer, Reporter);\nexports.DecoderBuffer = DecoderBuffer;\n\nDecoderBuffer.prototype.save = function save() {\n return { offset: this.offset, reporter: Reporter.prototype.save.call(this) };\n};\n\nDecoderBuffer.prototype.restore = function restore(save) {\n // Return skipped data\n var res = new DecoderBuffer(this.base);\n res.offset = save.offset;\n res.length = this.offset;\n\n this.offset = save.offset;\n Reporter.prototype.restore.call(this, save.reporter);\n\n return res;\n};\n\nDecoderBuffer.prototype.isEmpty = function isEmpty() {\n return this.offset === this.length;\n};\n\nDecoderBuffer.prototype.readUInt8 = function readUInt8(fail) {\n if (this.offset + 1 <= this.length)\n return this.base.readUInt8(this.offset++, true);\n else\n return this.error(fail || 'DecoderBuffer overrun');\n}\n\nDecoderBuffer.prototype.skip = function skip(bytes, fail) {\n if (!(this.offset + bytes <= this.length))\n return this.error(fail || 'DecoderBuffer overrun');\n\n var res = new DecoderBuffer(this.base);\n\n // Share reporter state\n res._reporterState = this._reporterState;\n\n res.offset = this.offset;\n res.length = this.offset + bytes;\n this.offset += bytes;\n return res;\n}\n\nDecoderBuffer.prototype.raw = function raw(save) {\n return this.base.slice(save ? save.offset : this.offset, this.length);\n}\n\nfunction EncoderBuffer(value, reporter) {\n if (Array.isArray(value)) {\n this.length = 0;\n this.value = value.map(function(item) {\n if (!(item instanceof EncoderBuffer))\n item = new EncoderBuffer(item, reporter);\n this.length += item.length;\n return item;\n }, this);\n } else if (typeof value === 'number') {\n if (!(0 <= value && value <= 0xff))\n return reporter.error('non-byte EncoderBuffer value');\n this.value = value;\n this.length = 1;\n } else if (typeof value === 'string') {\n this.value = value;\n this.length = Buffer.byteLength(value);\n } else if (Buffer.isBuffer(value)) {\n this.value = value;\n this.length = value.length;\n } else {\n return reporter.error('Unsupported type: ' + typeof value);\n }\n}\nexports.EncoderBuffer = EncoderBuffer;\n\nEncoderBuffer.prototype.join = function join(out, offset) {\n if (!out)\n out = new Buffer(this.length);\n if (!offset)\n offset = 0;\n\n if (this.length === 0)\n return out;\n\n if (Array.isArray(this.value)) {\n this.value.forEach(function(item) {\n item.join(out, offset);\n offset += item.length;\n });\n } else {\n if (typeof this.value === 'number')\n out[offset] = this.value;\n else if (typeof this.value === 'string')\n out.write(this.value, offset);\n else if (Buffer.isBuffer(this.value))\n this.value.copy(out, offset);\n offset += this.length;\n }\n\n return out;\n};\n","var Reporter = require('../base').Reporter;\nvar EncoderBuffer = require('../base').EncoderBuffer;\nvar DecoderBuffer = require('../base').DecoderBuffer;\nvar assert = require('minimalistic-assert');\n\n// Supported tags\nvar tags = [\n 'seq', 'seqof', 'set', 'setof', 'objid', 'bool',\n 'gentime', 'utctime', 'null_', 'enum', 'int', 'objDesc',\n 'bitstr', 'bmpstr', 'charstr', 'genstr', 'graphstr', 'ia5str', 'iso646str',\n 'numstr', 'octstr', 'printstr', 't61str', 'unistr', 'utf8str', 'videostr'\n];\n\n// Public methods list\nvar methods = [\n 'key', 'obj', 'use', 'optional', 'explicit', 'implicit', 'def', 'choice',\n 'any', 'contains'\n].concat(tags);\n\n// Overrided methods list\nvar overrided = [\n '_peekTag', '_decodeTag', '_use',\n '_decodeStr', '_decodeObjid', '_decodeTime',\n '_decodeNull', '_decodeInt', '_decodeBool', '_decodeList',\n\n '_encodeComposite', '_encodeStr', '_encodeObjid', '_encodeTime',\n '_encodeNull', '_encodeInt', '_encodeBool'\n];\n\nfunction Node(enc, parent) {\n var state = {};\n this._baseState = state;\n\n state.enc = enc;\n\n state.parent = parent || null;\n state.children = null;\n\n // State\n state.tag = null;\n state.args = null;\n state.reverseArgs = null;\n state.choice = null;\n state.optional = false;\n state.any = false;\n state.obj = false;\n state.use = null;\n state.useDecoder = null;\n state.key = null;\n state['default'] = null;\n state.explicit = null;\n state.implicit = null;\n state.contains = null;\n\n // Should create new instance on each method\n if (!state.parent) {\n state.children = [];\n this._wrap();\n }\n}\nmodule.exports = Node;\n\nvar stateProps = [\n 'enc', 'parent', 'children', 'tag', 'args', 'reverseArgs', 'choice',\n 'optional', 'any', 'obj', 'use', 'alteredUse', 'key', 'default', 'explicit',\n 'implicit', 'contains'\n];\n\nNode.prototype.clone = function clone() {\n var state = this._baseState;\n var cstate = {};\n stateProps.forEach(function(prop) {\n cstate[prop] = state[prop];\n });\n var res = new this.constructor(cstate.parent);\n res._baseState = cstate;\n return res;\n};\n\nNode.prototype._wrap = function wrap() {\n var state = this._baseState;\n methods.forEach(function(method) {\n this[method] = function _wrappedMethod() {\n var clone = new this.constructor(this);\n state.children.push(clone);\n return clone[method].apply(clone, arguments);\n };\n }, this);\n};\n\nNode.prototype._init = function init(body) {\n var state = this._baseState;\n\n assert(state.parent === null);\n body.call(this);\n\n // Filter children\n state.children = state.children.filter(function(child) {\n return child._baseState.parent === this;\n }, this);\n assert.equal(state.children.length, 1, 'Root node can have only one child');\n};\n\nNode.prototype._useArgs = function useArgs(args) {\n var state = this._baseState;\n\n // Filter children and args\n var children = args.filter(function(arg) {\n return arg instanceof this.constructor;\n }, this);\n args = args.filter(function(arg) {\n return !(arg instanceof this.constructor);\n }, this);\n\n if (children.length !== 0) {\n assert(state.children === null);\n state.children = children;\n\n // Replace parent to maintain backward link\n children.forEach(function(child) {\n child._baseState.parent = this;\n }, this);\n }\n if (args.length !== 0) {\n assert(state.args === null);\n state.args = args;\n state.reverseArgs = args.map(function(arg) {\n if (typeof arg !== 'object' || arg.constructor !== Object)\n return arg;\n\n var res = {};\n Object.keys(arg).forEach(function(key) {\n if (key == (key | 0))\n key |= 0;\n var value = arg[key];\n res[value] = key;\n });\n return res;\n });\n }\n};\n\n//\n// Overrided methods\n//\n\noverrided.forEach(function(method) {\n Node.prototype[method] = function _overrided() {\n var state = this._baseState;\n throw new Error(method + ' not implemented for encoding: ' + state.enc);\n };\n});\n\n//\n// Public methods\n//\n\ntags.forEach(function(tag) {\n Node.prototype[tag] = function _tagMethod() {\n var state = this._baseState;\n var args = Array.prototype.slice.call(arguments);\n\n assert(state.tag === null);\n state.tag = tag;\n\n this._useArgs(args);\n\n return this;\n };\n});\n\nNode.prototype.use = function use(item) {\n assert(item);\n var state = this._baseState;\n\n assert(state.use === null);\n state.use = item;\n\n return this;\n};\n\nNode.prototype.optional = function optional() {\n var state = this._baseState;\n\n state.optional = true;\n\n return this;\n};\n\nNode.prototype.def = function def(val) {\n var state = this._baseState;\n\n assert(state['default'] === null);\n state['default'] = val;\n state.optional = true;\n\n return this;\n};\n\nNode.prototype.explicit = function explicit(num) {\n var state = this._baseState;\n\n assert(state.explicit === null && state.implicit === null);\n state.explicit = num;\n\n return this;\n};\n\nNode.prototype.implicit = function implicit(num) {\n var state = this._baseState;\n\n assert(state.explicit === null && state.implicit === null);\n state.implicit = num;\n\n return this;\n};\n\nNode.prototype.obj = function obj() {\n var state = this._baseState;\n var args = Array.prototype.slice.call(arguments);\n\n state.obj = true;\n\n if (args.length !== 0)\n this._useArgs(args);\n\n return this;\n};\n\nNode.prototype.key = function key(newKey) {\n var state = this._baseState;\n\n assert(state.key === null);\n state.key = newKey;\n\n return this;\n};\n\nNode.prototype.any = function any() {\n var state = this._baseState;\n\n state.any = true;\n\n return this;\n};\n\nNode.prototype.choice = function choice(obj) {\n var state = this._baseState;\n\n assert(state.choice === null);\n state.choice = obj;\n this._useArgs(Object.keys(obj).map(function(key) {\n return obj[key];\n }));\n\n return this;\n};\n\nNode.prototype.contains = function contains(item) {\n var state = this._baseState;\n\n assert(state.use === null);\n state.contains = item;\n\n return this;\n};\n\n//\n// Decoding\n//\n\nNode.prototype._decode = function decode(input, options) {\n var state = this._baseState;\n\n // Decode root node\n if (state.parent === null)\n return input.wrapResult(state.children[0]._decode(input, options));\n\n var result = state['default'];\n var present = true;\n\n var prevKey = null;\n if (state.key !== null)\n prevKey = input.enterKey(state.key);\n\n // Check if tag is there\n if (state.optional) {\n var tag = null;\n if (state.explicit !== null)\n tag = state.explicit;\n else if (state.implicit !== null)\n tag = state.implicit;\n else if (state.tag !== null)\n tag = state.tag;\n\n if (tag === null && !state.any) {\n // Trial and Error\n var save = input.save();\n try {\n if (state.choice === null)\n this._decodeGeneric(state.tag, input, options);\n else\n this._decodeChoice(input, options);\n present = true;\n } catch (e) {\n present = false;\n }\n input.restore(save);\n } else {\n present = this._peekTag(input, tag, state.any);\n\n if (input.isError(present))\n return present;\n }\n }\n\n // Push object on stack\n var prevObj;\n if (state.obj && present)\n prevObj = input.enterObject();\n\n if (present) {\n // Unwrap explicit values\n if (state.explicit !== null) {\n var explicit = this._decodeTag(input, state.explicit);\n if (input.isError(explicit))\n return explicit;\n input = explicit;\n }\n\n var start = input.offset;\n\n // Unwrap implicit and normal values\n if (state.use === null && state.choice === null) {\n if (state.any)\n var save = input.save();\n var body = this._decodeTag(\n input,\n state.implicit !== null ? state.implicit : state.tag,\n state.any\n );\n if (input.isError(body))\n return body;\n\n if (state.any)\n result = input.raw(save);\n else\n input = body;\n }\n\n if (options && options.track && state.tag !== null)\n options.track(input.path(), start, input.length, 'tagged');\n\n if (options && options.track && state.tag !== null)\n options.track(input.path(), input.offset, input.length, 'content');\n\n // Select proper method for tag\n if (state.any)\n result = result;\n else if (state.choice === null)\n result = this._decodeGeneric(state.tag, input, options);\n else\n result = this._decodeChoice(input, options);\n\n if (input.isError(result))\n return result;\n\n // Decode children\n if (!state.any && state.choice === null && state.children !== null) {\n state.children.forEach(function decodeChildren(child) {\n // NOTE: We are ignoring errors here, to let parser continue with other\n // parts of encoded data\n child._decode(input, options);\n });\n }\n\n // Decode contained/encoded by schema, only in bit or octet strings\n if (state.contains && (state.tag === 'octstr' || state.tag === 'bitstr')) {\n var data = new DecoderBuffer(result);\n result = this._getUse(state.contains, input._reporterState.obj)\n ._decode(data, options);\n }\n }\n\n // Pop object\n if (state.obj && present)\n result = input.leaveObject(prevObj);\n\n // Set key\n if (state.key !== null && (result !== null || present === true))\n input.leaveKey(prevKey, state.key, result);\n else if (prevKey !== null)\n input.exitKey(prevKey);\n\n return result;\n};\n\nNode.prototype._decodeGeneric = function decodeGeneric(tag, input, options) {\n var state = this._baseState;\n\n if (tag === 'seq' || tag === 'set')\n return null;\n if (tag === 'seqof' || tag === 'setof')\n return this._decodeList(input, tag, state.args[0], options);\n else if (/str$/.test(tag))\n return this._decodeStr(input, tag, options);\n else if (tag === 'objid' && state.args)\n return this._decodeObjid(input, state.args[0], state.args[1], options);\n else if (tag === 'objid')\n return this._decodeObjid(input, null, null, options);\n else if (tag === 'gentime' || tag === 'utctime')\n return this._decodeTime(input, tag, options);\n else if (tag === 'null_')\n return this._decodeNull(input, options);\n else if (tag === 'bool')\n return this._decodeBool(input, options);\n else if (tag === 'objDesc')\n return this._decodeStr(input, tag, options);\n else if (tag === 'int' || tag === 'enum')\n return this._decodeInt(input, state.args && state.args[0], options);\n\n if (state.use !== null) {\n return this._getUse(state.use, input._reporterState.obj)\n ._decode(input, options);\n } else {\n return input.error('unknown tag: ' + tag);\n }\n};\n\nNode.prototype._getUse = function _getUse(entity, obj) {\n\n var state = this._baseState;\n // Create altered use decoder if implicit is set\n state.useDecoder = this._use(entity, obj);\n assert(state.useDecoder._baseState.parent === null);\n state.useDecoder = state.useDecoder._baseState.children[0];\n if (state.implicit !== state.useDecoder._baseState.implicit) {\n state.useDecoder = state.useDecoder.clone();\n state.useDecoder._baseState.implicit = state.implicit;\n }\n return state.useDecoder;\n};\n\nNode.prototype._decodeChoice = function decodeChoice(input, options) {\n var state = this._baseState;\n var result = null;\n var match = false;\n\n Object.keys(state.choice).some(function(key) {\n var save = input.save();\n var node = state.choice[key];\n try {\n var value = node._decode(input, options);\n if (input.isError(value))\n return false;\n\n result = { type: key, value: value };\n match = true;\n } catch (e) {\n input.restore(save);\n return false;\n }\n return true;\n }, this);\n\n if (!match)\n return input.error('Choice not matched');\n\n return result;\n};\n\n//\n// Encoding\n//\n\nNode.prototype._createEncoderBuffer = function createEncoderBuffer(data) {\n return new EncoderBuffer(data, this.reporter);\n};\n\nNode.prototype._encode = function encode(data, reporter, parent) {\n var state = this._baseState;\n if (state['default'] !== null && state['default'] === data)\n return;\n\n var result = this._encodeValue(data, reporter, parent);\n if (result === undefined)\n return;\n\n if (this._skipDefault(result, reporter, parent))\n return;\n\n return result;\n};\n\nNode.prototype._encodeValue = function encode(data, reporter, parent) {\n var state = this._baseState;\n\n // Decode root node\n if (state.parent === null)\n return state.children[0]._encode(data, reporter || new Reporter());\n\n var result = null;\n\n // Set reporter to share it with a child class\n this.reporter = reporter;\n\n // Check if data is there\n if (state.optional && data === undefined) {\n if (state['default'] !== null)\n data = state['default']\n else\n return;\n }\n\n // Encode children first\n var content = null;\n var primitive = false;\n if (state.any) {\n // Anything that was given is translated to buffer\n result = this._createEncoderBuffer(data);\n } else if (state.choice) {\n result = this._encodeChoice(data, reporter);\n } else if (state.contains) {\n content = this._getUse(state.contains, parent)._encode(data, reporter);\n primitive = true;\n } else if (state.children) {\n content = state.children.map(function(child) {\n if (child._baseState.tag === 'null_')\n return child._encode(null, reporter, data);\n\n if (child._baseState.key === null)\n return reporter.error('Child should have a key');\n var prevKey = reporter.enterKey(child._baseState.key);\n\n if (typeof data !== 'object')\n return reporter.error('Child expected, but input is not object');\n\n var res = child._encode(data[child._baseState.key], reporter, data);\n reporter.leaveKey(prevKey);\n\n return res;\n }, this).filter(function(child) {\n return child;\n });\n content = this._createEncoderBuffer(content);\n } else {\n if (state.tag === 'seqof' || state.tag === 'setof') {\n // TODO(indutny): this should be thrown on DSL level\n if (!(state.args && state.args.length === 1))\n return reporter.error('Too many args for : ' + state.tag);\n\n if (!Array.isArray(data))\n return reporter.error('seqof/setof, but data is not Array');\n\n var child = this.clone();\n child._baseState.implicit = null;\n content = this._createEncoderBuffer(data.map(function(item) {\n var state = this._baseState;\n\n return this._getUse(state.args[0], data)._encode(item, reporter);\n }, child));\n } else if (state.use !== null) {\n result = this._getUse(state.use, parent)._encode(data, reporter);\n } else {\n content = this._encodePrimitive(state.tag, data);\n primitive = true;\n }\n }\n\n // Encode data itself\n var result;\n if (!state.any && state.choice === null) {\n var tag = state.implicit !== null ? state.implicit : state.tag;\n var cls = state.implicit === null ? 'universal' : 'context';\n\n if (tag === null) {\n if (state.use === null)\n reporter.error('Tag could be omitted only for .use()');\n } else {\n if (state.use === null)\n result = this._encodeComposite(tag, primitive, cls, content);\n }\n }\n\n // Wrap in explicit\n if (state.explicit !== null)\n result = this._encodeComposite(state.explicit, false, 'context', result);\n\n return result;\n};\n\nNode.prototype._encodeChoice = function encodeChoice(data, reporter) {\n var state = this._baseState;\n\n var node = state.choice[data.type];\n if (!node) {\n assert(\n false,\n data.type + ' not found in ' +\n JSON.stringify(Object.keys(state.choice)));\n }\n return node._encode(data.value, reporter);\n};\n\nNode.prototype._encodePrimitive = function encodePrimitive(tag, data) {\n var state = this._baseState;\n\n if (/str$/.test(tag))\n return this._encodeStr(data, tag);\n else if (tag === 'objid' && state.args)\n return this._encodeObjid(data, state.reverseArgs[0], state.args[1]);\n else if (tag === 'objid')\n return this._encodeObjid(data, null, null);\n else if (tag === 'gentime' || tag === 'utctime')\n return this._encodeTime(data, tag);\n else if (tag === 'null_')\n return this._encodeNull();\n else if (tag === 'int' || tag === 'enum')\n return this._encodeInt(data, state.args && state.reverseArgs[0]);\n else if (tag === 'bool')\n return this._encodeBool(data);\n else if (tag === 'objDesc')\n return this._encodeStr(data, tag);\n else\n throw new Error('Unsupported tag: ' + tag);\n};\n\nNode.prototype._isNumstr = function isNumstr(str) {\n return /^[0-9 ]*$/.test(str);\n};\n\nNode.prototype._isPrintstr = function isPrintstr(str) {\n return /^[A-Za-z0-9 '\\(\\)\\+,\\-\\.\\/:=\\?]*$/.test(str);\n};\n","var base = exports;\n\nbase.Reporter = require('./reporter').Reporter;\nbase.DecoderBuffer = require('./buffer').DecoderBuffer;\nbase.EncoderBuffer = require('./buffer').EncoderBuffer;\nbase.Node = require('./node');\n","var constants = require('../constants');\n\nexports.tagClass = {\n 0: 'universal',\n 1: 'application',\n 2: 'context',\n 3: 'private'\n};\nexports.tagClassByName = constants._reverse(exports.tagClass);\n\nexports.tag = {\n 0x00: 'end',\n 0x01: 'bool',\n 0x02: 'int',\n 0x03: 'bitstr',\n 0x04: 'octstr',\n 0x05: 'null_',\n 0x06: 'objid',\n 0x07: 'objDesc',\n 0x08: 'external',\n 0x09: 'real',\n 0x0a: 'enum',\n 0x0b: 'embed',\n 0x0c: 'utf8str',\n 0x0d: 'relativeOid',\n 0x10: 'seq',\n 0x11: 'set',\n 0x12: 'numstr',\n 0x13: 'printstr',\n 0x14: 't61str',\n 0x15: 'videostr',\n 0x16: 'ia5str',\n 0x17: 'utctime',\n 0x18: 'gentime',\n 0x19: 'graphstr',\n 0x1a: 'iso646str',\n 0x1b: 'genstr',\n 0x1c: 'unistr',\n 0x1d: 'charstr',\n 0x1e: 'bmpstr'\n};\nexports.tagByName = constants._reverse(exports.tag);\n","var constants = exports;\n\n// Helper\nconstants._reverse = function reverse(map) {\n var res = {};\n\n Object.keys(map).forEach(function(key) {\n // Convert key to integer if it is stringified\n if ((key | 0) == key)\n key = key | 0;\n\n var value = map[key];\n res[value] = key;\n });\n\n return res;\n};\n\nconstants.der = require('./der');\n","var inherits = require('inherits');\n\nvar asn1 = require('../../asn1');\nvar base = asn1.base;\nvar bignum = asn1.bignum;\n\n// Import DER constants\nvar der = asn1.constants.der;\n\nfunction DERDecoder(entity) {\n this.enc = 'der';\n this.name = entity.name;\n this.entity = entity;\n\n // Construct base tree\n this.tree = new DERNode();\n this.tree._init(entity.body);\n};\nmodule.exports = DERDecoder;\n\nDERDecoder.prototype.decode = function decode(data, options) {\n if (!(data instanceof base.DecoderBuffer))\n data = new base.DecoderBuffer(data, options);\n\n return this.tree._decode(data, options);\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n base.Node.call(this, 'der', parent);\n}\ninherits(DERNode, base.Node);\n\nDERNode.prototype._peekTag = function peekTag(buffer, tag, any) {\n if (buffer.isEmpty())\n return false;\n\n var state = buffer.save();\n var decodedTag = derDecodeTag(buffer, 'Failed to peek tag: \"' + tag + '\"');\n if (buffer.isError(decodedTag))\n return decodedTag;\n\n buffer.restore(state);\n\n return decodedTag.tag === tag || decodedTag.tagStr === tag ||\n (decodedTag.tagStr + 'of') === tag || any;\n};\n\nDERNode.prototype._decodeTag = function decodeTag(buffer, tag, any) {\n var decodedTag = derDecodeTag(buffer,\n 'Failed to decode tag of \"' + tag + '\"');\n if (buffer.isError(decodedTag))\n return decodedTag;\n\n var len = derDecodeLen(buffer,\n decodedTag.primitive,\n 'Failed to get length of \"' + tag + '\"');\n\n // Failure\n if (buffer.isError(len))\n return len;\n\n if (!any &&\n decodedTag.tag !== tag &&\n decodedTag.tagStr !== tag &&\n decodedTag.tagStr + 'of' !== tag) {\n return buffer.error('Failed to match tag: \"' + tag + '\"');\n }\n\n if (decodedTag.primitive || len !== null)\n return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n\n // Indefinite length... find END tag\n var state = buffer.save();\n var res = this._skipUntilEnd(\n buffer,\n 'Failed to skip indefinite length body: \"' + this.tag + '\"');\n if (buffer.isError(res))\n return res;\n\n len = buffer.offset - state.offset;\n buffer.restore(state);\n return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n};\n\nDERNode.prototype._skipUntilEnd = function skipUntilEnd(buffer, fail) {\n while (true) {\n var tag = derDecodeTag(buffer, fail);\n if (buffer.isError(tag))\n return tag;\n var len = derDecodeLen(buffer, tag.primitive, fail);\n if (buffer.isError(len))\n return len;\n\n var res;\n if (tag.primitive || len !== null)\n res = buffer.skip(len)\n else\n res = this._skipUntilEnd(buffer, fail);\n\n // Failure\n if (buffer.isError(res))\n return res;\n\n if (tag.tagStr === 'end')\n break;\n }\n};\n\nDERNode.prototype._decodeList = function decodeList(buffer, tag, decoder,\n options) {\n var result = [];\n while (!buffer.isEmpty()) {\n var possibleEnd = this._peekTag(buffer, 'end');\n if (buffer.isError(possibleEnd))\n return possibleEnd;\n\n var res = decoder.decode(buffer, 'der', options);\n if (buffer.isError(res) && possibleEnd)\n break;\n result.push(res);\n }\n return result;\n};\n\nDERNode.prototype._decodeStr = function decodeStr(buffer, tag) {\n if (tag === 'bitstr') {\n var unused = buffer.readUInt8();\n if (buffer.isError(unused))\n return unused;\n return { unused: unused, data: buffer.raw() };\n } else if (tag === 'bmpstr') {\n var raw = buffer.raw();\n if (raw.length % 2 === 1)\n return buffer.error('Decoding of string type: bmpstr length mismatch');\n\n var str = '';\n for (var i = 0; i < raw.length / 2; i++) {\n str += String.fromCharCode(raw.readUInt16BE(i * 2));\n }\n return str;\n } else if (tag === 'numstr') {\n var numstr = buffer.raw().toString('ascii');\n if (!this._isNumstr(numstr)) {\n return buffer.error('Decoding of string type: ' +\n 'numstr unsupported characters');\n }\n return numstr;\n } else if (tag === 'octstr') {\n return buffer.raw();\n } else if (tag === 'objDesc') {\n return buffer.raw();\n } else if (tag === 'printstr') {\n var printstr = buffer.raw().toString('ascii');\n if (!this._isPrintstr(printstr)) {\n return buffer.error('Decoding of string type: ' +\n 'printstr unsupported characters');\n }\n return printstr;\n } else if (/str$/.test(tag)) {\n return buffer.raw().toString();\n } else {\n return buffer.error('Decoding of string type: ' + tag + ' unsupported');\n }\n};\n\nDERNode.prototype._decodeObjid = function decodeObjid(buffer, values, relative) {\n var result;\n var identifiers = [];\n var ident = 0;\n while (!buffer.isEmpty()) {\n var subident = buffer.readUInt8();\n ident <<= 7;\n ident |= subident & 0x7f;\n if ((subident & 0x80) === 0) {\n identifiers.push(ident);\n ident = 0;\n }\n }\n if (subident & 0x80)\n identifiers.push(ident);\n\n var first = (identifiers[0] / 40) | 0;\n var second = identifiers[0] % 40;\n\n if (relative)\n result = identifiers;\n else\n result = [first, second].concat(identifiers.slice(1));\n\n if (values) {\n var tmp = values[result.join(' ')];\n if (tmp === undefined)\n tmp = values[result.join('.')];\n if (tmp !== undefined)\n result = tmp;\n }\n\n return result;\n};\n\nDERNode.prototype._decodeTime = function decodeTime(buffer, tag) {\n var str = buffer.raw().toString();\n if (tag === 'gentime') {\n var year = str.slice(0, 4) | 0;\n var mon = str.slice(4, 6) | 0;\n var day = str.slice(6, 8) | 0;\n var hour = str.slice(8, 10) | 0;\n var min = str.slice(10, 12) | 0;\n var sec = str.slice(12, 14) | 0;\n } else if (tag === 'utctime') {\n var year = str.slice(0, 2) | 0;\n var mon = str.slice(2, 4) | 0;\n var day = str.slice(4, 6) | 0;\n var hour = str.slice(6, 8) | 0;\n var min = str.slice(8, 10) | 0;\n var sec = str.slice(10, 12) | 0;\n if (year < 70)\n year = 2000 + year;\n else\n year = 1900 + year;\n } else {\n return buffer.error('Decoding ' + tag + ' time is not supported yet');\n }\n\n return Date.UTC(year, mon - 1, day, hour, min, sec, 0);\n};\n\nDERNode.prototype._decodeNull = function decodeNull(buffer) {\n return null;\n};\n\nDERNode.prototype._decodeBool = function decodeBool(buffer) {\n var res = buffer.readUInt8();\n if (buffer.isError(res))\n return res;\n else\n return res !== 0;\n};\n\nDERNode.prototype._decodeInt = function decodeInt(buffer, values) {\n // Bigint, return as it is (assume big endian)\n var raw = buffer.raw();\n var res = new bignum(raw);\n\n if (values)\n res = values[res.toString(10)] || res;\n\n return res;\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n if (typeof entity === 'function')\n entity = entity(obj);\n return entity._getDecoder('der').tree;\n};\n\n// Utility methods\n\nfunction derDecodeTag(buf, fail) {\n var tag = buf.readUInt8(fail);\n if (buf.isError(tag))\n return tag;\n\n var cls = der.tagClass[tag >> 6];\n var primitive = (tag & 0x20) === 0;\n\n // Multi-octet tag - load\n if ((tag & 0x1f) === 0x1f) {\n var oct = tag;\n tag = 0;\n while ((oct & 0x80) === 0x80) {\n oct = buf.readUInt8(fail);\n if (buf.isError(oct))\n return oct;\n\n tag <<= 7;\n tag |= oct & 0x7f;\n }\n } else {\n tag &= 0x1f;\n }\n var tagStr = der.tag[tag];\n\n return {\n cls: cls,\n primitive: primitive,\n tag: tag,\n tagStr: tagStr\n };\n}\n\nfunction derDecodeLen(buf, primitive, fail) {\n var len = buf.readUInt8(fail);\n if (buf.isError(len))\n return len;\n\n // Indefinite form\n if (!primitive && len === 0x80)\n return null;\n\n // Definite form\n if ((len & 0x80) === 0) {\n // Short form\n return len;\n }\n\n // Long form\n var num = len & 0x7f;\n if (num > 4)\n return buf.error('length octect is too long');\n\n len = 0;\n for (var i = 0; i < num; i++) {\n len <<= 8;\n var j = buf.readUInt8(fail);\n if (buf.isError(j))\n return j;\n len |= j;\n }\n\n return len;\n}\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar DERDecoder = require('./der');\n\nfunction PEMDecoder(entity) {\n DERDecoder.call(this, entity);\n this.enc = 'pem';\n};\ninherits(PEMDecoder, DERDecoder);\nmodule.exports = PEMDecoder;\n\nPEMDecoder.prototype.decode = function decode(data, options) {\n var lines = data.toString().split(/[\\r\\n]+/g);\n\n var label = options.label.toUpperCase();\n\n var re = /^-----(BEGIN|END) ([^-]+)-----$/;\n var start = -1;\n var end = -1;\n for (var i = 0; i < lines.length; i++) {\n var match = lines[i].match(re);\n if (match === null)\n continue;\n\n if (match[2] !== label)\n continue;\n\n if (start === -1) {\n if (match[1] !== 'BEGIN')\n break;\n start = i;\n } else {\n if (match[1] !== 'END')\n break;\n end = i;\n break;\n }\n }\n if (start === -1 || end === -1)\n throw new Error('PEM section not found for: ' + label);\n\n var base64 = lines.slice(start + 1, end).join('');\n // Remove excessive symbols\n base64.replace(/[^a-z0-9\\+\\/=]+/gi, '');\n\n var input = new Buffer(base64, 'base64');\n return DERDecoder.prototype.decode.call(this, input, options);\n};\n","var decoders = exports;\n\ndecoders.der = require('./der');\ndecoders.pem = require('./pem');\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar asn1 = require('../../asn1');\nvar base = asn1.base;\n\n// Import DER constants\nvar der = asn1.constants.der;\n\nfunction DEREncoder(entity) {\n this.enc = 'der';\n this.name = entity.name;\n this.entity = entity;\n\n // Construct base tree\n this.tree = new DERNode();\n this.tree._init(entity.body);\n};\nmodule.exports = DEREncoder;\n\nDEREncoder.prototype.encode = function encode(data, reporter) {\n return this.tree._encode(data, reporter).join();\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n base.Node.call(this, 'der', parent);\n}\ninherits(DERNode, base.Node);\n\nDERNode.prototype._encodeComposite = function encodeComposite(tag,\n primitive,\n cls,\n content) {\n var encodedTag = encodeTag(tag, primitive, cls, this.reporter);\n\n // Short form\n if (content.length < 0x80) {\n var header = new Buffer(2);\n header[0] = encodedTag;\n header[1] = content.length;\n return this._createEncoderBuffer([ header, content ]);\n }\n\n // Long form\n // Count octets required to store length\n var lenOctets = 1;\n for (var i = content.length; i >= 0x100; i >>= 8)\n lenOctets++;\n\n var header = new Buffer(1 + 1 + lenOctets);\n header[0] = encodedTag;\n header[1] = 0x80 | lenOctets;\n\n for (var i = 1 + lenOctets, j = content.length; j > 0; i--, j >>= 8)\n header[i] = j & 0xff;\n\n return this._createEncoderBuffer([ header, content ]);\n};\n\nDERNode.prototype._encodeStr = function encodeStr(str, tag) {\n if (tag === 'bitstr') {\n return this._createEncoderBuffer([ str.unused | 0, str.data ]);\n } else if (tag === 'bmpstr') {\n var buf = new Buffer(str.length * 2);\n for (var i = 0; i < str.length; i++) {\n buf.writeUInt16BE(str.charCodeAt(i), i * 2);\n }\n return this._createEncoderBuffer(buf);\n } else if (tag === 'numstr') {\n if (!this._isNumstr(str)) {\n return this.reporter.error('Encoding of string type: numstr supports ' +\n 'only digits and space');\n }\n return this._createEncoderBuffer(str);\n } else if (tag === 'printstr') {\n if (!this._isPrintstr(str)) {\n return this.reporter.error('Encoding of string type: printstr supports ' +\n 'only latin upper and lower case letters, ' +\n 'digits, space, apostrophe, left and rigth ' +\n 'parenthesis, plus sign, comma, hyphen, ' +\n 'dot, slash, colon, equal sign, ' +\n 'question mark');\n }\n return this._createEncoderBuffer(str);\n } else if (/str$/.test(tag)) {\n return this._createEncoderBuffer(str);\n } else if (tag === 'objDesc') {\n return this._createEncoderBuffer(str);\n } else {\n return this.reporter.error('Encoding of string type: ' + tag +\n ' unsupported');\n }\n};\n\nDERNode.prototype._encodeObjid = function encodeObjid(id, values, relative) {\n if (typeof id === 'string') {\n if (!values)\n return this.reporter.error('string objid given, but no values map found');\n if (!values.hasOwnProperty(id))\n return this.reporter.error('objid not found in values map');\n id = values[id].split(/[\\s\\.]+/g);\n for (var i = 0; i < id.length; i++)\n id[i] |= 0;\n } else if (Array.isArray(id)) {\n id = id.slice();\n for (var i = 0; i < id.length; i++)\n id[i] |= 0;\n }\n\n if (!Array.isArray(id)) {\n return this.reporter.error('objid() should be either array or string, ' +\n 'got: ' + JSON.stringify(id));\n }\n\n if (!relative) {\n if (id[1] >= 40)\n return this.reporter.error('Second objid identifier OOB');\n id.splice(0, 2, id[0] * 40 + id[1]);\n }\n\n // Count number of octets\n var size = 0;\n for (var i = 0; i < id.length; i++) {\n var ident = id[i];\n for (size++; ident >= 0x80; ident >>= 7)\n size++;\n }\n\n var objid = new Buffer(size);\n var offset = objid.length - 1;\n for (var i = id.length - 1; i >= 0; i--) {\n var ident = id[i];\n objid[offset--] = ident & 0x7f;\n while ((ident >>= 7) > 0)\n objid[offset--] = 0x80 | (ident & 0x7f);\n }\n\n return this._createEncoderBuffer(objid);\n};\n\nfunction two(num) {\n if (num < 10)\n return '0' + num;\n else\n return num;\n}\n\nDERNode.prototype._encodeTime = function encodeTime(time, tag) {\n var str;\n var date = new Date(time);\n\n if (tag === 'gentime') {\n str = [\n two(date.getFullYear()),\n two(date.getUTCMonth() + 1),\n two(date.getUTCDate()),\n two(date.getUTCHours()),\n two(date.getUTCMinutes()),\n two(date.getUTCSeconds()),\n 'Z'\n ].join('');\n } else if (tag === 'utctime') {\n str = [\n two(date.getFullYear() % 100),\n two(date.getUTCMonth() + 1),\n two(date.getUTCDate()),\n two(date.getUTCHours()),\n two(date.getUTCMinutes()),\n two(date.getUTCSeconds()),\n 'Z'\n ].join('');\n } else {\n this.reporter.error('Encoding ' + tag + ' time is not supported yet');\n }\n\n return this._encodeStr(str, 'octstr');\n};\n\nDERNode.prototype._encodeNull = function encodeNull() {\n return this._createEncoderBuffer('');\n};\n\nDERNode.prototype._encodeInt = function encodeInt(num, values) {\n if (typeof num === 'string') {\n if (!values)\n return this.reporter.error('String int or enum given, but no values map');\n if (!values.hasOwnProperty(num)) {\n return this.reporter.error('Values map doesn\\'t contain: ' +\n JSON.stringify(num));\n }\n num = values[num];\n }\n\n // Bignum, assume big endian\n if (typeof num !== 'number' && !Buffer.isBuffer(num)) {\n var numArray = num.toArray();\n if (!num.sign && numArray[0] & 0x80) {\n numArray.unshift(0);\n }\n num = new Buffer(numArray);\n }\n\n if (Buffer.isBuffer(num)) {\n var size = num.length;\n if (num.length === 0)\n size++;\n\n var out = new Buffer(size);\n num.copy(out);\n if (num.length === 0)\n out[0] = 0\n return this._createEncoderBuffer(out);\n }\n\n if (num < 0x80)\n return this._createEncoderBuffer(num);\n\n if (num < 0x100)\n return this._createEncoderBuffer([0, num]);\n\n var size = 1;\n for (var i = num; i >= 0x100; i >>= 8)\n size++;\n\n var out = new Array(size);\n for (var i = out.length - 1; i >= 0; i--) {\n out[i] = num & 0xff;\n num >>= 8;\n }\n if(out[0] & 0x80) {\n out.unshift(0);\n }\n\n return this._createEncoderBuffer(new Buffer(out));\n};\n\nDERNode.prototype._encodeBool = function encodeBool(value) {\n return this._createEncoderBuffer(value ? 0xff : 0);\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n if (typeof entity === 'function')\n entity = entity(obj);\n return entity._getEncoder('der').tree;\n};\n\nDERNode.prototype._skipDefault = function skipDefault(dataBuffer, reporter, parent) {\n var state = this._baseState;\n var i;\n if (state['default'] === null)\n return false;\n\n var data = dataBuffer.join();\n if (state.defaultBuffer === undefined)\n state.defaultBuffer = this._encodeValue(state['default'], reporter, parent).join();\n\n if (data.length !== state.defaultBuffer.length)\n return false;\n\n for (i=0; i < data.length; i++)\n if (data[i] !== state.defaultBuffer[i])\n return false;\n\n return true;\n};\n\n// Utility methods\n\nfunction encodeTag(tag, primitive, cls, reporter) {\n var res;\n\n if (tag === 'seqof')\n tag = 'seq';\n else if (tag === 'setof')\n tag = 'set';\n\n if (der.tagByName.hasOwnProperty(tag))\n res = der.tagByName[tag];\n else if (typeof tag === 'number' && (tag | 0) === tag)\n res = tag;\n else\n return reporter.error('Unknown tag: ' + tag);\n\n if (res >= 0x1f)\n return reporter.error('Multi-octet tag encoding unsupported');\n\n if (!primitive)\n res |= 0x20;\n\n res |= (der.tagClassByName[cls || 'universal'] << 6);\n\n return res;\n}\n","var inherits = require('inherits');\n\nvar DEREncoder = require('./der');\n\nfunction PEMEncoder(entity) {\n DEREncoder.call(this, entity);\n this.enc = 'pem';\n};\ninherits(PEMEncoder, DEREncoder);\nmodule.exports = PEMEncoder;\n\nPEMEncoder.prototype.encode = function encode(data, options) {\n var buf = DEREncoder.prototype.encode.call(this, data);\n\n var p = buf.toString('base64');\n var out = [ '-----BEGIN ' + options.label + '-----' ];\n for (var i = 0; i < p.length; i += 64)\n out.push(p.slice(i, i + 64));\n out.push('-----END ' + options.label + '-----');\n return out.join('\\n');\n};\n","var encoders = exports;\n\nencoders.der = require('./der');\nencoders.pem = require('./pem');\n","var asn1 = exports;\n\nasn1.bignum = require('bn.js');\n\nasn1.define = require('./asn1/api').define;\nasn1.base = require('./asn1/base');\nasn1.constants = require('./asn1/constants');\nasn1.decoders = require('./asn1/decoders');\nasn1.encoders = require('./asn1/encoders');\n","// from https://github.com/Rantanen/node-dtls/blob/25a7dc861bda38cfeac93a723500eea4f0ac2e86/Certificate.js\n// thanks to @Rantanen\n\n'use strict';\n\nvar asn = require('asn1.js');\n\nvar Time = asn.define('Time', function () {\n\tthis.choice({\n\t\tutcTime: this.utctime(),\n\t\tgeneralTime: this.gentime()\n\t});\n});\n\nvar AttributeTypeValue = asn.define('AttributeTypeValue', function () {\n\tthis.seq().obj(\n\t\tthis.key('type').objid(),\n\t\tthis.key('value').any()\n\t);\n});\n\nvar AlgorithmIdentifier = asn.define('AlgorithmIdentifier', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').objid(),\n\t\tthis.key('parameters').optional(),\n\t\tthis.key('curve').objid().optional()\n\t);\n});\n\nvar SubjectPublicKeyInfo = asn.define('SubjectPublicKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('subjectPublicKey').bitstr()\n\t);\n});\n\nvar RelativeDistinguishedName = asn.define('RelativeDistinguishedName', function () {\n\tthis.setof(AttributeTypeValue);\n});\n\nvar RDNSequence = asn.define('RDNSequence', function () {\n\tthis.seqof(RelativeDistinguishedName);\n});\n\nvar Name = asn.define('Name', function () {\n\tthis.choice({\n\t\trdnSequence: this.use(RDNSequence)\n\t});\n});\n\nvar Validity = asn.define('Validity', function () {\n\tthis.seq().obj(\n\t\tthis.key('notBefore').use(Time),\n\t\tthis.key('notAfter').use(Time)\n\t);\n});\n\nvar Extension = asn.define('Extension', function () {\n\tthis.seq().obj(\n\t\tthis.key('extnID').objid(),\n\t\tthis.key('critical').bool().def(false),\n\t\tthis.key('extnValue').octstr()\n\t);\n});\n\nvar TBSCertificate = asn.define('TBSCertificate', function () {\n\tthis.seq().obj(\n\t\tthis.key('version').explicit(0)['int']().optional(),\n\t\tthis.key('serialNumber')['int'](),\n\t\tthis.key('signature').use(AlgorithmIdentifier),\n\t\tthis.key('issuer').use(Name),\n\t\tthis.key('validity').use(Validity),\n\t\tthis.key('subject').use(Name),\n\t\tthis.key('subjectPublicKeyInfo').use(SubjectPublicKeyInfo),\n\t\tthis.key('issuerUniqueID').implicit(1).bitstr().optional(),\n\t\tthis.key('subjectUniqueID').implicit(2).bitstr().optional(),\n\t\tthis.key('extensions').explicit(3).seqof(Extension).optional()\n\t);\n});\n\nvar X509Certificate = asn.define('X509Certificate', function () {\n\tthis.seq().obj(\n\t\tthis.key('tbsCertificate').use(TBSCertificate),\n\t\tthis.key('signatureAlgorithm').use(AlgorithmIdentifier),\n\t\tthis.key('signatureValue').bitstr()\n\t);\n});\n\nmodule.exports = X509Certificate;\n","// from https://github.com/indutny/self-signed/blob/gh-pages/lib/asn1.js\n// Fedor, you are amazing.\n\n'use strict';\n\nvar asn1 = require('asn1.js');\n\nexports.certificate = require('./certificate');\n\nvar RSAPrivateKey = asn1.define('RSAPrivateKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('modulus')['int'](),\n\t\tthis.key('publicExponent')['int'](),\n\t\tthis.key('privateExponent')['int'](),\n\t\tthis.key('prime1')['int'](),\n\t\tthis.key('prime2')['int'](),\n\t\tthis.key('exponent1')['int'](),\n\t\tthis.key('exponent2')['int'](),\n\t\tthis.key('coefficient')['int']()\n\t);\n});\nexports.RSAPrivateKey = RSAPrivateKey;\n\nvar RSAPublicKey = asn1.define('RSAPublicKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('modulus')['int'](),\n\t\tthis.key('publicExponent')['int']()\n\t);\n});\nexports.RSAPublicKey = RSAPublicKey;\n\nvar AlgorithmIdentifier = asn1.define('AlgorithmIdentifier', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').objid(),\n\t\tthis.key('none').null_().optional(),\n\t\tthis.key('curve').objid().optional(),\n\t\tthis.key('params').seq().obj(\n\t\t\tthis.key('p')['int'](),\n\t\t\tthis.key('q')['int'](),\n\t\t\tthis.key('g')['int']()\n\t\t).optional()\n\t);\n});\n\nvar PublicKey = asn1.define('SubjectPublicKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('subjectPublicKey').bitstr()\n\t);\n});\nexports.PublicKey = PublicKey;\n\nvar PrivateKeyInfo = asn1.define('PrivateKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('subjectPrivateKey').octstr()\n\t);\n});\nexports.PrivateKey = PrivateKeyInfo;\nvar EncryptedPrivateKeyInfo = asn1.define('EncryptedPrivateKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').seq().obj(\n\t\t\tthis.key('id').objid(),\n\t\t\tthis.key('decrypt').seq().obj(\n\t\t\t\tthis.key('kde').seq().obj(\n\t\t\t\t\tthis.key('id').objid(),\n\t\t\t\t\tthis.key('kdeparams').seq().obj(\n\t\t\t\t\t\tthis.key('salt').octstr(),\n\t\t\t\t\t\tthis.key('iters')['int']()\n\t\t\t\t\t)\n\t\t\t\t),\n\t\t\t\tthis.key('cipher').seq().obj(\n\t\t\t\t\tthis.key('algo').objid(),\n\t\t\t\t\tthis.key('iv').octstr()\n\t\t\t\t)\n\t\t\t)\n\t\t),\n\t\tthis.key('subjectPrivateKey').octstr()\n\t);\n});\n\nexports.EncryptedPrivateKey = EncryptedPrivateKeyInfo;\n\nvar DSAPrivateKey = asn1.define('DSAPrivateKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('p')['int'](),\n\t\tthis.key('q')['int'](),\n\t\tthis.key('g')['int'](),\n\t\tthis.key('pub_key')['int'](),\n\t\tthis.key('priv_key')['int']()\n\t);\n});\nexports.DSAPrivateKey = DSAPrivateKey;\n\nexports.DSAparam = asn1.define('DSAparam', function () {\n\tthis['int']();\n});\n\nvar ECParameters = asn1.define('ECParameters', function () {\n\tthis.choice({\n\t\tnamedCurve: this.objid()\n\t});\n});\n\nvar ECPrivateKey = asn1.define('ECPrivateKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('privateKey').octstr(),\n\t\tthis.key('parameters').optional().explicit(0).use(ECParameters),\n\t\tthis.key('publicKey').optional().explicit(1).bitstr()\n\t);\n});\nexports.ECPrivateKey = ECPrivateKey;\n\nexports.signature = asn1.define('signature', function () {\n\tthis.seq().obj(\n\t\tthis.key('r')['int'](),\n\t\tthis.key('s')['int']()\n\t);\n});\n","'use strict';\n\n// adapted from https://github.com/apatil/pemstrip\nvar findProc = /Proc-Type: 4,ENCRYPTED[\\n\\r]+DEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)[\\n\\r]+([0-9A-z\\n\\r+/=]+)[\\n\\r]+/m;\nvar startRegex = /^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----/m;\nvar fullRegex = /^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----([0-9A-z\\n\\r+/=]+)-----END \\1-----$/m;\nvar evp = require('evp_bytestokey');\nvar ciphers = require('browserify-aes');\nvar Buffer = require('safe-buffer').Buffer;\nmodule.exports = function (okey, password) {\n\tvar key = okey.toString();\n\tvar match = key.match(findProc);\n\tvar decrypted;\n\tif (!match) {\n\t\tvar match2 = key.match(fullRegex);\n\t\tdecrypted = Buffer.from(match2[2].replace(/[\\r\\n]/g, ''), 'base64');\n\t} else {\n\t\tvar suite = 'aes' + match[1];\n\t\tvar iv = Buffer.from(match[2], 'hex');\n\t\tvar cipherText = Buffer.from(match[3].replace(/[\\r\\n]/g, ''), 'base64');\n\t\tvar cipherKey = evp(password, iv.slice(0, 8), parseInt(match[1], 10)).key;\n\t\tvar out = [];\n\t\tvar cipher = ciphers.createDecipheriv(suite, cipherKey, iv);\n\t\tout.push(cipher.update(cipherText));\n\t\tout.push(cipher['final']());\n\t\tdecrypted = Buffer.concat(out);\n\t}\n\tvar tag = key.match(startRegex)[1];\n\treturn {\n\t\ttag: tag,\n\t\tdata: decrypted\n\t};\n};\n","'use strict';\n\nvar asn1 = require('./asn1');\nvar aesid = require('./aesid.json');\nvar fixProc = require('./fixProc');\nvar ciphers = require('browserify-aes');\nvar compat = require('pbkdf2');\nvar Buffer = require('safe-buffer').Buffer;\n\nfunction decrypt(data, password) {\n\tvar salt = data.algorithm.decrypt.kde.kdeparams.salt;\n\tvar iters = parseInt(data.algorithm.decrypt.kde.kdeparams.iters.toString(), 10);\n\tvar algo = aesid[data.algorithm.decrypt.cipher.algo.join('.')];\n\tvar iv = data.algorithm.decrypt.cipher.iv;\n\tvar cipherText = data.subjectPrivateKey;\n\tvar keylen = parseInt(algo.split('-')[1], 10) / 8;\n\tvar key = compat.pbkdf2Sync(password, salt, iters, keylen, 'sha1');\n\tvar cipher = ciphers.createDecipheriv(algo, key, iv);\n\tvar out = [];\n\tout.push(cipher.update(cipherText));\n\tout.push(cipher['final']());\n\treturn Buffer.concat(out);\n}\n\nfunction parseKeys(buffer) {\n\tvar password;\n\tif (typeof buffer === 'object' && !Buffer.isBuffer(buffer)) {\n\t\tpassword = buffer.passphrase;\n\t\tbuffer = buffer.key;\n\t}\n\tif (typeof buffer === 'string') {\n\t\tbuffer = Buffer.from(buffer);\n\t}\n\n\tvar stripped = fixProc(buffer, password);\n\n\tvar type = stripped.tag;\n\tvar data = stripped.data;\n\tvar subtype, ndata;\n\tswitch (type) {\n\t\tcase 'CERTIFICATE':\n\t\t\tndata = asn1.certificate.decode(data, 'der').tbsCertificate.subjectPublicKeyInfo;\n\t\t\t// falls through\n\t\tcase 'PUBLIC KEY':\n\t\t\tif (!ndata) {\n\t\t\t\tndata = asn1.PublicKey.decode(data, 'der');\n\t\t\t}\n\t\t\tsubtype = ndata.algorithm.algorithm.join('.');\n\t\t\tswitch (subtype) {\n\t\t\t\tcase '1.2.840.113549.1.1.1':\n\t\t\t\t\treturn asn1.RSAPublicKey.decode(ndata.subjectPublicKey.data, 'der');\n\t\t\t\tcase '1.2.840.10045.2.1':\n\t\t\t\t\tndata.subjectPrivateKey = ndata.subjectPublicKey;\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttype: 'ec',\n\t\t\t\t\t\tdata: ndata\n\t\t\t\t\t};\n\t\t\t\tcase '1.2.840.10040.4.1':\n\t\t\t\t\tndata.algorithm.params.pub_key = asn1.DSAparam.decode(ndata.subjectPublicKey.data, 'der');\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttype: 'dsa',\n\t\t\t\t\t\tdata: ndata.algorithm.params\n\t\t\t\t\t};\n\t\t\t\tdefault: throw new Error('unknown key id ' + subtype);\n\t\t\t}\n\t\t\t// throw new Error('unknown key type ' + type)\n\t\tcase 'ENCRYPTED PRIVATE KEY':\n\t\t\tdata = asn1.EncryptedPrivateKey.decode(data, 'der');\n\t\t\tdata = decrypt(data, password);\n\t\t\t// falls through\n\t\tcase 'PRIVATE KEY':\n\t\t\tndata = asn1.PrivateKey.decode(data, 'der');\n\t\t\tsubtype = ndata.algorithm.algorithm.join('.');\n\t\t\tswitch (subtype) {\n\t\t\t\tcase '1.2.840.113549.1.1.1':\n\t\t\t\t\treturn asn1.RSAPrivateKey.decode(ndata.subjectPrivateKey, 'der');\n\t\t\t\tcase '1.2.840.10045.2.1':\n\t\t\t\t\treturn {\n\t\t\t\t\t\tcurve: ndata.algorithm.curve,\n\t\t\t\t\t\tprivateKey: asn1.ECPrivateKey.decode(ndata.subjectPrivateKey, 'der').privateKey\n\t\t\t\t\t};\n\t\t\t\tcase '1.2.840.10040.4.1':\n\t\t\t\t\tndata.algorithm.params.priv_key = asn1.DSAparam.decode(ndata.subjectPrivateKey, 'der');\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttype: 'dsa',\n\t\t\t\t\t\tparams: ndata.algorithm.params\n\t\t\t\t\t};\n\t\t\t\tdefault: throw new Error('unknown key id ' + subtype);\n\t\t\t}\n\t\t\t// throw new Error('unknown key type ' + type)\n\t\tcase 'RSA PUBLIC KEY':\n\t\t\treturn asn1.RSAPublicKey.decode(data, 'der');\n\t\tcase 'RSA PRIVATE KEY':\n\t\t\treturn asn1.RSAPrivateKey.decode(data, 'der');\n\t\tcase 'DSA PRIVATE KEY':\n\t\t\treturn {\n\t\t\t\ttype: 'dsa',\n\t\t\t\tparams: asn1.DSAPrivateKey.decode(data, 'der')\n\t\t\t};\n\t\tcase 'EC PRIVATE KEY':\n\t\t\tdata = asn1.ECPrivateKey.decode(data, 'der');\n\t\t\treturn {\n\t\t\t\tcurve: data.parameters.value,\n\t\t\t\tprivateKey: data.privateKey\n\t\t\t};\n\t\tdefault: throw new Error('unknown key type ' + type);\n\t}\n}\nparseKeys.signature = asn1.signature;\n\nmodule.exports = parseKeys;\n","'use strict';\n\n// much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js\nvar Buffer = require('safe-buffer').Buffer;\nvar createHmac = require('create-hmac');\nvar crt = require('browserify-rsa');\nvar EC = require('elliptic').ec;\nvar BN = require('bn.js');\nvar parseKeys = require('parse-asn1');\nvar curves = require('./curves.json');\n\nvar RSA_PKCS1_PADDING = 1;\n\nfunction sign(hash, key, hashType, signType, tag) {\n var priv = parseKeys(key);\n if (priv.curve) {\n // rsa keys can be interpreted as ecdsa ones in openssl\n if (signType !== 'ecdsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong private key type'); }\n return ecSign(hash, priv);\n } else if (priv.type === 'dsa') {\n if (signType !== 'dsa') { throw new Error('wrong private key type'); }\n return dsaSign(hash, priv, hashType);\n }\n if (signType !== 'rsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong private key type'); }\n if (key.padding !== undefined && key.padding !== RSA_PKCS1_PADDING) { throw new Error('illegal or unsupported padding mode'); }\n\n hash = Buffer.concat([tag, hash]);\n var len = priv.modulus.byteLength();\n var pad = [0, 1];\n while (hash.length + pad.length + 1 < len) { pad.push(0xff); }\n pad.push(0x00);\n var i = -1;\n while (++i < hash.length) { pad.push(hash[i]); }\n\n var out = crt(pad, priv);\n return out;\n}\n\nfunction ecSign(hash, priv) {\n var curveId = curves[priv.curve.join('.')];\n if (!curveId) { throw new Error('unknown curve ' + priv.curve.join('.')); }\n\n var curve = new EC(curveId);\n var key = curve.keyFromPrivate(priv.privateKey);\n var out = key.sign(hash);\n\n return Buffer.from(out.toDER());\n}\n\nfunction dsaSign(hash, priv, algo) {\n var x = priv.params.priv_key;\n var p = priv.params.p;\n var q = priv.params.q;\n var g = priv.params.g;\n var r = new BN(0);\n var k;\n var H = bits2int(hash, q).mod(q);\n var s = false;\n var kv = getKey(x, q, hash, algo);\n while (s === false) {\n k = makeKey(q, kv, algo);\n r = makeR(g, k, p, q);\n s = k.invm(q).imul(H.add(x.mul(r))).mod(q);\n if (s.cmpn(0) === 0) {\n s = false;\n r = new BN(0);\n }\n }\n return toDER(r, s);\n}\n\nfunction toDER(r, s) {\n r = r.toArray();\n s = s.toArray();\n\n // Pad values\n if (r[0] & 0x80) { r = [0].concat(r); }\n if (s[0] & 0x80) { s = [0].concat(s); }\n\n var total = r.length + s.length + 4;\n var res = [\n 0x30, total, 0x02, r.length\n ];\n res = res.concat(r, [0x02, s.length], s);\n return Buffer.from(res);\n}\n\nfunction getKey(x, q, hash, algo) {\n x = Buffer.from(x.toArray());\n if (x.length < q.byteLength()) {\n var zeros = Buffer.alloc(q.byteLength() - x.length);\n x = Buffer.concat([zeros, x]);\n }\n var hlen = hash.length;\n var hbits = bits2octets(hash, q);\n var v = Buffer.alloc(hlen);\n v.fill(1);\n var k = Buffer.alloc(hlen);\n k = createHmac(algo, k).update(v).update(Buffer.from([0])).update(x).update(hbits).digest();\n v = createHmac(algo, k).update(v).digest();\n k = createHmac(algo, k).update(v).update(Buffer.from([1])).update(x).update(hbits).digest();\n v = createHmac(algo, k).update(v).digest();\n return { k: k, v: v };\n}\n\nfunction bits2int(obits, q) {\n var bits = new BN(obits);\n var shift = (obits.length << 3) - q.bitLength();\n if (shift > 0) { bits.ishrn(shift); }\n return bits;\n}\n\nfunction bits2octets(bits, q) {\n bits = bits2int(bits, q);\n bits = bits.mod(q);\n var out = Buffer.from(bits.toArray());\n if (out.length < q.byteLength()) {\n var zeros = Buffer.alloc(q.byteLength() - out.length);\n out = Buffer.concat([zeros, out]);\n }\n return out;\n}\n\nfunction makeKey(q, kv, algo) {\n var t;\n var k;\n\n do {\n t = Buffer.alloc(0);\n\n while (t.length * 8 < q.bitLength()) {\n kv.v = createHmac(algo, kv.k).update(kv.v).digest();\n t = Buffer.concat([t, kv.v]);\n }\n\n k = bits2int(t, q);\n kv.k = createHmac(algo, kv.k).update(kv.v).update(Buffer.from([0])).digest();\n kv.v = createHmac(algo, kv.k).update(kv.v).digest();\n } while (k.cmp(q) !== -1);\n\n return k;\n}\n\nfunction makeR(g, k, p, q) {\n return g.toRed(BN.mont(p)).redPow(k).fromRed().mod(q);\n}\n\nmodule.exports = sign;\nmodule.exports.getKey = getKey;\nmodule.exports.makeKey = makeKey;\n","'use strict';\n\n// much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js\nvar Buffer = require('safe-buffer').Buffer;\nvar BN = require('bn.js');\nvar EC = require('elliptic').ec;\nvar parseKeys = require('parse-asn1');\nvar curves = require('./curves.json');\n\nfunction verify(sig, hash, key, signType, tag) {\n var pub = parseKeys(key);\n if (pub.type === 'ec') {\n // rsa keys can be interpreted as ecdsa ones in openssl\n if (signType !== 'ecdsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong public key type'); }\n return ecVerify(sig, hash, pub);\n } else if (pub.type === 'dsa') {\n if (signType !== 'dsa') { throw new Error('wrong public key type'); }\n return dsaVerify(sig, hash, pub);\n }\n if (signType !== 'rsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong public key type'); }\n\n hash = Buffer.concat([tag, hash]);\n var len = pub.modulus.byteLength();\n var pad = [1];\n var padNum = 0;\n while (hash.length + pad.length + 2 < len) {\n pad.push(0xff);\n padNum += 1;\n }\n pad.push(0x00);\n var i = -1;\n while (++i < hash.length) {\n pad.push(hash[i]);\n }\n pad = Buffer.from(pad);\n var red = BN.mont(pub.modulus);\n sig = new BN(sig).toRed(red);\n\n sig = sig.redPow(new BN(pub.publicExponent));\n sig = Buffer.from(sig.fromRed().toArray());\n var out = padNum < 8 ? 1 : 0;\n len = Math.min(sig.length, pad.length);\n if (sig.length !== pad.length) { out = 1; }\n\n i = -1;\n while (++i < len) { out |= sig[i] ^ pad[i]; }\n return out === 0;\n}\n\nfunction ecVerify(sig, hash, pub) {\n var curveId = curves[pub.data.algorithm.curve.join('.')];\n if (!curveId) { throw new Error('unknown curve ' + pub.data.algorithm.curve.join('.')); }\n\n var curve = new EC(curveId);\n var pubkey = pub.data.subjectPrivateKey.data;\n\n return curve.verify(hash, sig, pubkey);\n}\n\nfunction dsaVerify(sig, hash, pub) {\n var p = pub.data.p;\n var q = pub.data.q;\n var g = pub.data.g;\n var y = pub.data.pub_key;\n var unpacked = parseKeys.signature.decode(sig, 'der');\n var s = unpacked.s;\n var r = unpacked.r;\n checkValue(s, q);\n checkValue(r, q);\n var montp = BN.mont(p);\n var w = s.invm(q);\n var v = g.toRed(montp)\n .redPow(new BN(hash).mul(w).mod(q))\n .fromRed()\n .mul(y.toRed(montp).redPow(r.mul(w).mod(q)).fromRed())\n .mod(p)\n .mod(q);\n return v.cmp(r) === 0;\n}\n\nfunction checkValue(b, q) {\n if (b.cmpn(0) <= 0) { throw new Error('invalid sig'); }\n if (b.cmp(q) >= 0) { throw new Error('invalid sig'); }\n}\n\nmodule.exports = verify;\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar createHash = require('create-hash');\nvar stream = require('readable-stream');\nvar inherits = require('inherits');\nvar sign = require('./sign');\nvar verify = require('./verify');\n\nvar algorithms = require('./algorithms.json');\nObject.keys(algorithms).forEach(function (key) {\n algorithms[key].id = Buffer.from(algorithms[key].id, 'hex');\n algorithms[key.toLowerCase()] = algorithms[key];\n});\n\nfunction Sign(algorithm) {\n stream.Writable.call(this);\n\n var data = algorithms[algorithm];\n if (!data) { throw new Error('Unknown message digest'); }\n\n this._hashType = data.hash;\n this._hash = createHash(data.hash);\n this._tag = data.id;\n this._signType = data.sign;\n}\ninherits(Sign, stream.Writable);\n\nSign.prototype._write = function _write(data, _, done) {\n this._hash.update(data);\n done();\n};\n\nSign.prototype.update = function update(data, enc) {\n this._hash.update(typeof data === 'string' ? Buffer.from(data, enc) : data);\n\n return this;\n};\n\nSign.prototype.sign = function signMethod(key, enc) {\n this.end();\n var hash = this._hash.digest();\n var sig = sign(hash, key, this._hashType, this._signType, this._tag);\n\n return enc ? sig.toString(enc) : sig;\n};\n\nfunction Verify(algorithm) {\n stream.Writable.call(this);\n\n var data = algorithms[algorithm];\n if (!data) { throw new Error('Unknown message digest'); }\n\n this._hash = createHash(data.hash);\n this._tag = data.id;\n this._signType = data.sign;\n}\ninherits(Verify, stream.Writable);\n\nVerify.prototype._write = function _write(data, _, done) {\n this._hash.update(data);\n done();\n};\n\nVerify.prototype.update = function update(data, enc) {\n this._hash.update(typeof data === 'string' ? Buffer.from(data, enc) : data);\n\n return this;\n};\n\nVerify.prototype.verify = function verifyMethod(key, sig, enc) {\n var sigBuffer = typeof sig === 'string' ? Buffer.from(sig, enc) : sig;\n\n this.end();\n var hash = this._hash.digest();\n return verify(sigBuffer, hash, key, this._signType, this._tag);\n};\n\nfunction createSign(algorithm) {\n return new Sign(algorithm);\n}\n\nfunction createVerify(algorithm) {\n return new Verify(algorithm);\n}\n\nmodule.exports = {\n Sign: createSign,\n Verify: createVerify,\n createSign: createSign,\n createVerify: createVerify\n};\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var elliptic = require('elliptic')\nvar BN = require('bn.js')\n\nmodule.exports = function createECDH (curve) {\n return new ECDH(curve)\n}\n\nvar aliases = {\n secp256k1: {\n name: 'secp256k1',\n byteLength: 32\n },\n secp224r1: {\n name: 'p224',\n byteLength: 28\n },\n prime256v1: {\n name: 'p256',\n byteLength: 32\n },\n prime192v1: {\n name: 'p192',\n byteLength: 24\n },\n ed25519: {\n name: 'ed25519',\n byteLength: 32\n },\n secp384r1: {\n name: 'p384',\n byteLength: 48\n },\n secp521r1: {\n name: 'p521',\n byteLength: 66\n }\n}\n\naliases.p224 = aliases.secp224r1\naliases.p256 = aliases.secp256r1 = aliases.prime256v1\naliases.p192 = aliases.secp192r1 = aliases.prime192v1\naliases.p384 = aliases.secp384r1\naliases.p521 = aliases.secp521r1\n\nfunction ECDH (curve) {\n this.curveType = aliases[curve]\n if (!this.curveType) {\n this.curveType = {\n name: curve\n }\n }\n this.curve = new elliptic.ec(this.curveType.name) // eslint-disable-line new-cap\n this.keys = void 0\n}\n\nECDH.prototype.generateKeys = function (enc, format) {\n this.keys = this.curve.genKeyPair()\n return this.getPublicKey(enc, format)\n}\n\nECDH.prototype.computeSecret = function (other, inenc, enc) {\n inenc = inenc || 'utf8'\n if (!Buffer.isBuffer(other)) {\n other = new Buffer(other, inenc)\n }\n var otherPub = this.curve.keyFromPublic(other).getPublic()\n var out = otherPub.mul(this.keys.getPrivate()).getX()\n return formatReturnValue(out, enc, this.curveType.byteLength)\n}\n\nECDH.prototype.getPublicKey = function (enc, format) {\n var key = this.keys.getPublic(format === 'compressed', true)\n if (format === 'hybrid') {\n if (key[key.length - 1] % 2) {\n key[0] = 7\n } else {\n key[0] = 6\n }\n }\n return formatReturnValue(key, enc)\n}\n\nECDH.prototype.getPrivateKey = function (enc) {\n return formatReturnValue(this.keys.getPrivate(), enc)\n}\n\nECDH.prototype.setPublicKey = function (pub, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc)\n }\n this.keys._importPublic(pub)\n return this\n}\n\nECDH.prototype.setPrivateKey = function (priv, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc)\n }\n\n var _priv = new BN(priv)\n _priv = _priv.toString(16)\n this.keys = this.curve.genKeyPair()\n this.keys._importPrivate(_priv)\n return this\n}\n\nfunction formatReturnValue (bn, enc, len) {\n if (!Array.isArray(bn)) {\n bn = bn.toArray()\n }\n var buf = new Buffer(bn)\n if (len && buf.length < len) {\n var zeros = new Buffer(len - buf.length)\n zeros.fill(0)\n buf = Buffer.concat([zeros, buf])\n }\n if (!enc) {\n return buf\n } else {\n return buf.toString(enc)\n }\n}\n","var createHash = require('create-hash')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function (seed, len) {\n var t = Buffer.alloc(0)\n var i = 0\n var c\n while (t.length < len) {\n c = i2ops(i++)\n t = Buffer.concat([t, createHash('sha1').update(seed).update(c).digest()])\n }\n return t.slice(0, len)\n}\n\nfunction i2ops (c) {\n var out = Buffer.allocUnsafe(4)\n out.writeUInt32BE(c, 0)\n return out\n}\n","module.exports = function xor (a, b) {\n var len = a.length\n var i = -1\n while (++i < len) {\n a[i] ^= b[i]\n }\n return a\n}\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var BN = require('bn.js')\nvar Buffer = require('safe-buffer').Buffer\n\nfunction withPublic (paddedMsg, key) {\n return Buffer.from(paddedMsg\n .toRed(BN.mont(key.modulus))\n .redPow(new BN(key.publicExponent))\n .fromRed()\n .toArray())\n}\n\nmodule.exports = withPublic\n","var parseKeys = require('parse-asn1')\nvar randomBytes = require('randombytes')\nvar createHash = require('create-hash')\nvar mgf = require('./mgf')\nvar xor = require('./xor')\nvar BN = require('bn.js')\nvar withPublic = require('./withPublic')\nvar crt = require('browserify-rsa')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function publicEncrypt (publicKey, msg, reverse) {\n var padding\n if (publicKey.padding) {\n padding = publicKey.padding\n } else if (reverse) {\n padding = 1\n } else {\n padding = 4\n }\n var key = parseKeys(publicKey)\n var paddedMsg\n if (padding === 4) {\n paddedMsg = oaep(key, msg)\n } else if (padding === 1) {\n paddedMsg = pkcs1(key, msg, reverse)\n } else if (padding === 3) {\n paddedMsg = new BN(msg)\n if (paddedMsg.cmp(key.modulus) >= 0) {\n throw new Error('data too long for modulus')\n }\n } else {\n throw new Error('unknown padding')\n }\n if (reverse) {\n return crt(paddedMsg, key)\n } else {\n return withPublic(paddedMsg, key)\n }\n}\n\nfunction oaep (key, msg) {\n var k = key.modulus.byteLength()\n var mLen = msg.length\n var iHash = createHash('sha1').update(Buffer.alloc(0)).digest()\n var hLen = iHash.length\n var hLen2 = 2 * hLen\n if (mLen > k - hLen2 - 2) {\n throw new Error('message too long')\n }\n var ps = Buffer.alloc(k - mLen - hLen2 - 2)\n var dblen = k - hLen - 1\n var seed = randomBytes(hLen)\n var maskedDb = xor(Buffer.concat([iHash, ps, Buffer.alloc(1, 1), msg], dblen), mgf(seed, dblen))\n var maskedSeed = xor(seed, mgf(maskedDb, hLen))\n return new BN(Buffer.concat([Buffer.alloc(1), maskedSeed, maskedDb], k))\n}\nfunction pkcs1 (key, msg, reverse) {\n var mLen = msg.length\n var k = key.modulus.byteLength()\n if (mLen > k - 11) {\n throw new Error('message too long')\n }\n var ps\n if (reverse) {\n ps = Buffer.alloc(k - mLen - 3, 0xff)\n } else {\n ps = nonZero(k - mLen - 3)\n }\n return new BN(Buffer.concat([Buffer.from([0, reverse ? 1 : 2]), ps, Buffer.alloc(1), msg], k))\n}\nfunction nonZero (len) {\n var out = Buffer.allocUnsafe(len)\n var i = 0\n var cache = randomBytes(len * 2)\n var cur = 0\n var num\n while (i < len) {\n if (cur === cache.length) {\n cache = randomBytes(len * 2)\n cur = 0\n }\n num = cache[cur++]\n if (num) {\n out[i++] = num\n }\n }\n return out\n}\n","var parseKeys = require('parse-asn1')\nvar mgf = require('./mgf')\nvar xor = require('./xor')\nvar BN = require('bn.js')\nvar crt = require('browserify-rsa')\nvar createHash = require('create-hash')\nvar withPublic = require('./withPublic')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function privateDecrypt (privateKey, enc, reverse) {\n var padding\n if (privateKey.padding) {\n padding = privateKey.padding\n } else if (reverse) {\n padding = 1\n } else {\n padding = 4\n }\n\n var key = parseKeys(privateKey)\n var k = key.modulus.byteLength()\n if (enc.length > k || new BN(enc).cmp(key.modulus) >= 0) {\n throw new Error('decryption error')\n }\n var msg\n if (reverse) {\n msg = withPublic(new BN(enc), key)\n } else {\n msg = crt(enc, key)\n }\n var zBuffer = Buffer.alloc(k - msg.length)\n msg = Buffer.concat([zBuffer, msg], k)\n if (padding === 4) {\n return oaep(key, msg)\n } else if (padding === 1) {\n return pkcs1(key, msg, reverse)\n } else if (padding === 3) {\n return msg\n } else {\n throw new Error('unknown padding')\n }\n}\n\nfunction oaep (key, msg) {\n var k = key.modulus.byteLength()\n var iHash = createHash('sha1').update(Buffer.alloc(0)).digest()\n var hLen = iHash.length\n if (msg[0] !== 0) {\n throw new Error('decryption error')\n }\n var maskedSeed = msg.slice(1, hLen + 1)\n var maskedDb = msg.slice(hLen + 1)\n var seed = xor(maskedSeed, mgf(maskedDb, hLen))\n var db = xor(maskedDb, mgf(seed, k - hLen - 1))\n if (compare(iHash, db.slice(0, hLen))) {\n throw new Error('decryption error')\n }\n var i = hLen\n while (db[i] === 0) {\n i++\n }\n if (db[i++] !== 1) {\n throw new Error('decryption error')\n }\n return db.slice(i)\n}\n\nfunction pkcs1 (key, msg, reverse) {\n var p1 = msg.slice(0, 2)\n var i = 2\n var status = 0\n while (msg[i++] !== 0) {\n if (i >= msg.length) {\n status++\n break\n }\n }\n var ps = msg.slice(2, i - 1)\n\n if ((p1.toString('hex') !== '0002' && !reverse) || (p1.toString('hex') !== '0001' && reverse)) {\n status++\n }\n if (ps.length < 8) {\n status++\n }\n if (status) {\n throw new Error('decryption error')\n }\n return msg.slice(i)\n}\nfunction compare (a, b) {\n a = Buffer.from(a)\n b = Buffer.from(b)\n var dif = 0\n var len = a.length\n if (a.length !== b.length) {\n dif++\n len = Math.min(a.length, b.length)\n }\n var i = -1\n while (++i < len) {\n dif += (a[i] ^ b[i])\n }\n return dif\n}\n","exports.publicEncrypt = require('./publicEncrypt')\nexports.privateDecrypt = require('./privateDecrypt')\n\nexports.privateEncrypt = function privateEncrypt (key, buf) {\n return exports.publicEncrypt(key, buf, true)\n}\n\nexports.publicDecrypt = function publicDecrypt (key, buf) {\n return exports.privateDecrypt(key, buf, true)\n}\n","'use strict'\n\nfunction oldBrowser () {\n throw new Error('secure random number generation not supported by this browser\\nuse chrome, FireFox or Internet Explorer 11')\n}\nvar safeBuffer = require('safe-buffer')\nvar randombytes = require('randombytes')\nvar Buffer = safeBuffer.Buffer\nvar kBufferMaxLength = safeBuffer.kMaxLength\nvar crypto = global.crypto || global.msCrypto\nvar kMaxUint32 = Math.pow(2, 32) - 1\nfunction assertOffset (offset, length) {\n if (typeof offset !== 'number' || offset !== offset) { // eslint-disable-line no-self-compare\n throw new TypeError('offset must be a number')\n }\n\n if (offset > kMaxUint32 || offset < 0) {\n throw new TypeError('offset must be a uint32')\n }\n\n if (offset > kBufferMaxLength || offset > length) {\n throw new RangeError('offset out of range')\n }\n}\n\nfunction assertSize (size, offset, length) {\n if (typeof size !== 'number' || size !== size) { // eslint-disable-line no-self-compare\n throw new TypeError('size must be a number')\n }\n\n if (size > kMaxUint32 || size < 0) {\n throw new TypeError('size must be a uint32')\n }\n\n if (size + offset > length || size > kBufferMaxLength) {\n throw new RangeError('buffer too small')\n }\n}\nif ((crypto && crypto.getRandomValues) || !process.browser) {\n exports.randomFill = randomFill\n exports.randomFillSync = randomFillSync\n} else {\n exports.randomFill = oldBrowser\n exports.randomFillSync = oldBrowser\n}\nfunction randomFill (buf, offset, size, cb) {\n if (!Buffer.isBuffer(buf) && !(buf instanceof global.Uint8Array)) {\n throw new TypeError('\"buf\" argument must be a Buffer or Uint8Array')\n }\n\n if (typeof offset === 'function') {\n cb = offset\n offset = 0\n size = buf.length\n } else if (typeof size === 'function') {\n cb = size\n size = buf.length - offset\n } else if (typeof cb !== 'function') {\n throw new TypeError('\"cb\" argument must be a function')\n }\n assertOffset(offset, buf.length)\n assertSize(size, offset, buf.length)\n return actualFill(buf, offset, size, cb)\n}\n\nfunction actualFill (buf, offset, size, cb) {\n if (process.browser) {\n var ourBuf = buf.buffer\n var uint = new Uint8Array(ourBuf, offset, size)\n crypto.getRandomValues(uint)\n if (cb) {\n process.nextTick(function () {\n cb(null, buf)\n })\n return\n }\n return buf\n }\n if (cb) {\n randombytes(size, function (err, bytes) {\n if (err) {\n return cb(err)\n }\n bytes.copy(buf, offset)\n cb(null, buf)\n })\n return\n }\n var bytes = randombytes(size)\n bytes.copy(buf, offset)\n return buf\n}\nfunction randomFillSync (buf, offset, size) {\n if (typeof offset === 'undefined') {\n offset = 0\n }\n if (!Buffer.isBuffer(buf) && !(buf instanceof global.Uint8Array)) {\n throw new TypeError('\"buf\" argument must be a Buffer or Uint8Array')\n }\n\n assertOffset(offset, buf.length)\n\n if (size === undefined) size = buf.length - offset\n\n assertSize(size, offset, buf.length)\n\n return actualFill(buf, offset, size)\n}\n","'use strict';\n\n// eslint-disable-next-line no-multi-assign\nexports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes');\n\n// eslint-disable-next-line no-multi-assign\nexports.createHash = exports.Hash = require('create-hash');\n\n// eslint-disable-next-line no-multi-assign\nexports.createHmac = exports.Hmac = require('create-hmac');\n\nvar algos = require('browserify-sign/algos');\nvar algoKeys = Object.keys(algos);\nvar hashes = [\n\t'sha1',\n\t'sha224',\n\t'sha256',\n\t'sha384',\n\t'sha512',\n\t'md5',\n\t'rmd160'\n].concat(algoKeys);\n\nexports.getHashes = function () {\n\treturn hashes;\n};\n\nvar p = require('pbkdf2');\nexports.pbkdf2 = p.pbkdf2;\nexports.pbkdf2Sync = p.pbkdf2Sync;\n\nvar aes = require('browserify-cipher');\n\nexports.Cipher = aes.Cipher;\nexports.createCipher = aes.createCipher;\nexports.Cipheriv = aes.Cipheriv;\nexports.createCipheriv = aes.createCipheriv;\nexports.Decipher = aes.Decipher;\nexports.createDecipher = aes.createDecipher;\nexports.Decipheriv = aes.Decipheriv;\nexports.createDecipheriv = aes.createDecipheriv;\nexports.getCiphers = aes.getCiphers;\nexports.listCiphers = aes.listCiphers;\n\nvar dh = require('diffie-hellman');\n\nexports.DiffieHellmanGroup = dh.DiffieHellmanGroup;\nexports.createDiffieHellmanGroup = dh.createDiffieHellmanGroup;\nexports.getDiffieHellman = dh.getDiffieHellman;\nexports.createDiffieHellman = dh.createDiffieHellman;\nexports.DiffieHellman = dh.DiffieHellman;\n\nvar sign = require('browserify-sign');\n\nexports.createSign = sign.createSign;\nexports.Sign = sign.Sign;\nexports.createVerify = sign.createVerify;\nexports.Verify = sign.Verify;\n\nexports.createECDH = require('create-ecdh');\n\nvar publicEncrypt = require('public-encrypt');\n\nexports.publicEncrypt = publicEncrypt.publicEncrypt;\nexports.privateEncrypt = publicEncrypt.privateEncrypt;\nexports.publicDecrypt = publicEncrypt.publicDecrypt;\nexports.privateDecrypt = publicEncrypt.privateDecrypt;\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\n// [\n// 'createCredentials'\n// ].forEach(function (name) {\n// exports[name] = function () {\n// throw new Error('sorry, ' + name + ' is not implemented yet\\nwe accept pull requests\\nhttps://github.com/browserify/crypto-browserify');\n// };\n// });\n\nvar rf = require('randomfill');\n\nexports.randomFill = rf.randomFill;\nexports.randomFillSync = rf.randomFillSync;\n\nexports.createCredentials = function () {\n\tthrow new Error('sorry, createCredentials is not implemented yet\\nwe accept pull requests\\nhttps://github.com/browserify/crypto-browserify');\n};\n\nexports.constants = {\n\tDH_CHECK_P_NOT_SAFE_PRIME: 2,\n\tDH_CHECK_P_NOT_PRIME: 1,\n\tDH_UNABLE_TO_CHECK_GENERATOR: 4,\n\tDH_NOT_SUITABLE_GENERATOR: 8,\n\tNPN_ENABLED: 1,\n\tALPN_ENABLED: 1,\n\tRSA_PKCS1_PADDING: 1,\n\tRSA_SSLV23_PADDING: 2,\n\tRSA_NO_PADDING: 3,\n\tRSA_PKCS1_OAEP_PADDING: 4,\n\tRSA_X931_PADDING: 5,\n\tRSA_PKCS1_PSS_PADDING: 6,\n\tPOINT_CONVERSION_COMPRESSED: 2,\n\tPOINT_CONVERSION_UNCOMPRESSED: 4,\n\tPOINT_CONVERSION_HYBRID: 6\n};\n","import { r as register, t as t3, a as t } from \"./_l10n-CeXHJQB0.mjs\";\nregister(t3);\nclass Color {\n /**\n * @param r - The red value\n * @param g - The green value\n * @param b - The blue value\n * @param name - The name of the color\n */\n constructor(r, g, b, name) {\n this.r = r;\n this.g = g;\n this.b = b;\n this.name = name;\n this.r = Math.min(r, 255);\n this.g = Math.min(g, 255);\n this.b = Math.min(b, 255);\n this.name = name;\n }\n /**\n * The hexadecimal color string.\n */\n get color() {\n const toHex = (int) => `00${int.toString(16)}`.slice(-2);\n return `#${toHex(this.r)}${toHex(this.g)}${toHex(this.b)}`;\n }\n}\nfunction calculateStepIncrement(steps, color1, color2) {\n return {\n r: (color2.r - color1.r) / steps,\n g: (color2.g - color1.g) / steps,\n b: (color2.b - color1.b) / steps\n };\n}\nfunction mixPalette(steps, color1, color2) {\n const palette = [];\n palette.push(color1);\n const increment = calculateStepIncrement(steps, color1, color2);\n for (let i = 1; i < steps; i++) {\n const r = Math.floor(color1.r + increment.r * i);\n const g = Math.floor(color1.g + increment.g * i);\n const b = Math.floor(color1.b + increment.b * i);\n palette.push(new Color(r, g, b));\n }\n return palette;\n}\nconst defaultPalette = [\n /* eslint-disable @stylistic/function-call-argument-newline -- Allow to put translators comments */\n new Color(\n 182,\n 70,\n 157,\n t(\"Purple\")\n ),\n new Color(\n 191,\n 103,\n 139,\n t(\"Rosy brown\")\n // TRANSLATORS: A color name for RGB(191, 103, 139)\n ),\n new Color(\n 201,\n 136,\n 121,\n t(\"Feldspar\")\n // TRANSLATORS: A color name for RGB(201, 136, 121)\n ),\n new Color(\n 211,\n 169,\n 103,\n t(\"Whiskey\")\n // TRANSLATORS: A color name for RGB(211, 169, 103)\n ),\n new Color(\n 221,\n 203,\n 85,\n t(\"Gold\")\n ),\n new Color(\n 165,\n 184,\n 114,\n t(\"Olivine\")\n // TRANSLATORS: A color name for RGB(165, 184, 114)\n ),\n new Color(\n 110,\n 166,\n 143,\n t(\"Acapulco\")\n // TRANSLATORS: A color name for RGB(110, 166, 143)\n ),\n new Color(\n 55,\n 148,\n 172,\n t(\"Boston Blue\")\n // TRANSLATORS: A color name for RGB(55, 148, 172)\n ),\n new Color(\n 0,\n 130,\n 201,\n t(\"Nextcloud blue\")\n ),\n new Color(\n 45,\n 115,\n 190,\n t(\"Mariner\")\n // TRANSLATORS: A color name for RGB(45, 115, 190)\n ),\n new Color(\n 91,\n 100,\n 179,\n t(\"Blue Violet\")\n // TRANSLATORS: A color name for RGB(91, 100, 179)\n ),\n new Color(\n 136,\n 85,\n 168,\n t(\"Deluge\")\n // TRANSLATORS: A color name for RGB(136, 85, 168)\n )\n /* eslint-enable @stylistic/function-call-argument-newline */\n];\nfunction generatePalette(steps) {\n const red = new Color(182, 70, 157, t(\"Purple\"));\n const yellow = new Color(221, 203, 85, t(\"Gold\"));\n const blue = new Color(0, 130, 201, t(\"Nextcloud blue\"));\n const palette1 = mixPalette(steps, red, yellow);\n const palette2 = mixPalette(steps, yellow, blue);\n const palette3 = mixPalette(steps, blue, red);\n return palette1.concat(palette2).concat(palette3);\n}\nexport {\n Color as C,\n defaultPalette as d,\n generatePalette as g\n};\n//# sourceMappingURL=colors-BZi52VLk.mjs.map\n","import { createHash } from \"crypto-browserify\";\nimport { g as generatePalette } from \"../../chunks/colors-BZi52VLk.mjs\";\nfunction hashCode(str) {\n let hash = str;\n if (str.match(/^([0-9a-f]{4}-?){8}$/) === null) {\n hash = createHash(\"md5\").update(str).digest(\"hex\");\n }\n hash = hash.replace(/[^0-9a-f]/g, \"\");\n let finalInt = 0;\n for (let i = 0; i < hash.length; i++) {\n finalInt += parseInt(hash.charAt(i), 16);\n }\n return finalInt;\n}\nfunction usernameToColor(username) {\n const steps = 6;\n const finalPalette = generatePalette(steps);\n const hash = hashCode(username.toLocaleLowerCase());\n return finalPalette[hash % finalPalette.length];\n}\nexport {\n usernameToColor\n};\n//# sourceMappingURL=index.mjs.map\n","'use strict';\n\n(function (global) {\n\n // minimal symbol polyfill for IE11 and others\n if (typeof Symbol !== 'function') {\n var Symbol = function(name) {\n return name;\n }\n\n Symbol.nonNative = true;\n }\n\n const STATE_PLAINTEXT = Symbol('plaintext');\n const STATE_HTML = Symbol('html');\n const STATE_COMMENT = Symbol('comment');\n\n const ALLOWED_TAGS_REGEX = /<(\\w*)>/g;\n const NORMALIZE_TAG_REGEX = /<\\/?([^\\s\\/>]+)/;\n\n function striptags(html, allowable_tags, tag_replacement) {\n html = html || '';\n allowable_tags = allowable_tags || [];\n tag_replacement = tag_replacement || '';\n\n let context = init_context(allowable_tags, tag_replacement);\n\n return striptags_internal(html, context);\n }\n\n function init_striptags_stream(allowable_tags, tag_replacement) {\n allowable_tags = allowable_tags || [];\n tag_replacement = tag_replacement || '';\n\n let context = init_context(allowable_tags, tag_replacement);\n\n return function striptags_stream(html) {\n return striptags_internal(html || '', context);\n };\n }\n\n striptags.init_streaming_mode = init_striptags_stream;\n\n function init_context(allowable_tags, tag_replacement) {\n allowable_tags = parse_allowable_tags(allowable_tags);\n\n return {\n allowable_tags : allowable_tags,\n tag_replacement: tag_replacement,\n\n state : STATE_PLAINTEXT,\n tag_buffer : '',\n depth : 0,\n in_quote_char : ''\n };\n }\n\n function striptags_internal(html, context) {\n if (typeof html != \"string\") {\n throw new TypeError(\"'html' parameter must be a string\");\n }\n\n let allowable_tags = context.allowable_tags;\n let tag_replacement = context.tag_replacement;\n\n let state = context.state;\n let tag_buffer = context.tag_buffer;\n let depth = context.depth;\n let in_quote_char = context.in_quote_char;\n let output = '';\n\n for (let idx = 0, length = html.length; idx < length; idx++) {\n let char = html[idx];\n\n if (state === STATE_PLAINTEXT) {\n switch (char) {\n case '<':\n state = STATE_HTML;\n tag_buffer += char;\n break;\n\n default:\n output += char;\n break;\n }\n }\n\n else if (state === STATE_HTML) {\n switch (char) {\n case '<':\n // ignore '<' if inside a quote\n if (in_quote_char) {\n break;\n }\n\n // we're seeing a nested '<'\n depth++;\n break;\n\n case '>':\n // ignore '>' if inside a quote\n if (in_quote_char) {\n break;\n }\n\n // something like this is happening: '<<>>'\n if (depth) {\n depth--;\n\n break;\n }\n\n // this is closing the tag in tag_buffer\n in_quote_char = '';\n state = STATE_PLAINTEXT;\n tag_buffer += '>';\n\n if (allowable_tags.has(normalize_tag(tag_buffer))) {\n output += tag_buffer;\n } else {\n output += tag_replacement;\n }\n\n tag_buffer = '';\n break;\n\n case '\"':\n case '\\'':\n // catch both single and double quotes\n\n if (char === in_quote_char) {\n in_quote_char = '';\n } else {\n in_quote_char = in_quote_char || char;\n }\n\n tag_buffer += char;\n break;\n\n case '-':\n if (tag_buffer === '':\n if (tag_buffer.slice(-2) == '--') {\n // close the comment\n state = STATE_PLAINTEXT;\n }\n\n tag_buffer = '';\n break;\n\n default:\n tag_buffer += char;\n break;\n }\n }\n }\n\n // save the context for future iterations\n context.state = state;\n context.tag_buffer = tag_buffer;\n context.depth = depth;\n context.in_quote_char = in_quote_char;\n\n return output;\n }\n\n function parse_allowable_tags(allowable_tags) {\n let tag_set = new Set();\n\n if (typeof allowable_tags === 'string') {\n let match;\n\n while ((match = ALLOWED_TAGS_REGEX.exec(allowable_tags))) {\n tag_set.add(match[1]);\n }\n }\n\n else if (!Symbol.nonNative &&\n typeof allowable_tags[Symbol.iterator] === 'function') {\n\n tag_set = new Set(allowable_tags);\n }\n\n else if (typeof allowable_tags.forEach === 'function') {\n // IE11 compatible\n allowable_tags.forEach(tag_set.add, tag_set);\n }\n\n return tag_set;\n }\n\n function normalize_tag(tag_buffer) {\n let match = NORMALIZE_TAG_REGEX.exec(tag_buffer);\n\n return match ? match[1].toLowerCase() : null;\n }\n\n if (typeof define === 'function' && define.amd) {\n // AMD\n define(function module_factory() { return striptags; });\n }\n\n else if (typeof module === 'object' && module.exports) {\n // Node\n module.exports = striptags;\n }\n\n else {\n // Browser\n global.striptags = striptags;\n }\n}(this));\n","import '../assets/NcMentionBubble-ptHUq68a.css';\nimport { generateUrl } from \"@nextcloud/router\";\nimport { checkIfDarkTheme } from \"../functions/isDarkTheme/index.mjs\";\nfunction getAvatarUrl(user, options) {\n const size = (options?.size || 64) <= 64 ? 64 : 512;\n const guestUrl = options?.isGuest ? \"/guest\" : \"\";\n const themeUrl = options?.isDarkTheme ?? checkIfDarkTheme(document.body) ? \"/dark\" : \"\";\n return generateUrl(`/avatar${guestUrl}/{user}/{size}${themeUrl}`, {\n user,\n size\n });\n}\nexport {\n getAvatarUrl as g\n};\n//# sourceMappingURL=NcMentionBubble.vue_vue_type_style_index_0_scoped_45238efd_lang-D6LzDiYf.mjs.map\n","import '../assets/NcUserStatusIcon-D8HqS9GC.css';\nimport { defineComponent, mergeModels, useModel, computed, watch, createElementBlock, createCommentVNode, openBlock, normalizeClass } from \"vue\";\nimport axios from \"@nextcloud/axios\";\nimport { getCapabilities } from \"@nextcloud/capabilities\";\nimport { generateOcsUrl } from \"@nextcloud/router\";\nimport { r as register, B as t11, a as t } from \"./_l10n-CeXHJQB0.mjs\";\nimport { l as logger } from \"./logger-D3RVzcfQ.mjs\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst awaySvg = '\\n\\n\t\\n\\n';\nconst busySvg = '\\n\\n\t\\n\\n';\nconst dndSvg = '\\n\\n\t\\n\\n';\nconst invisibleSvg = '\\n\\n\t\\n\\n';\nconst onlineSvg = '\\n\\n\t\\n\\n';\nregister();\nregister(t11);\nfunction getUserStatusText(status) {\n switch (status) {\n case \"away\":\n return t(\"away\");\n // TRANSLATORS: User status if the user is currently away from keyboard\n case \"busy\":\n return t(\"busy\");\n case \"dnd\":\n return t(\"do not disturb\");\n case \"online\":\n return t(\"online\");\n case \"invisible\":\n return t(\"invisible\");\n case \"offline\":\n return t(\"offline\");\n default:\n return status;\n }\n}\nconst _hoisted_1 = [\"aria-hidden\", \"aria-label\", \"innerHTML\"];\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcUserStatusIcon\",\n props: /* @__PURE__ */ mergeModels({\n user: { default: void 0 },\n ariaHidden: { type: [Boolean, String], default: false }\n }, {\n \"status\": {},\n \"statusModifiers\": {}\n }),\n emits: [\"update:status\"],\n setup(__props) {\n const status = useModel(__props, \"status\");\n const props = __props;\n const isInvisible = computed(() => status.value && [\"invisible\", \"offline\"].includes(status.value));\n const ariaLabel = computed(() => status.value && (!props.ariaHidden || props.ariaHidden === \"false\") ? t(\"User status: {status}\", { status: getUserStatusText(status.value) }) : void 0);\n watch(() => props.user, async (user) => {\n if (!status.value && user && getCapabilities()?.user_status?.enabled) {\n try {\n const { data } = await axios.get(generateOcsUrl(\"/apps/user_status/api/v1/statuses/{user}\", { user }));\n status.value = data.ocs?.data?.status;\n } catch (error) {\n logger.debug(\"Error while fetching user status\", { error });\n }\n }\n }, { immediate: true });\n const matchSvg = {\n online: onlineSvg,\n away: awaySvg,\n busy: busySvg,\n dnd: dndSvg,\n invisible: invisibleSvg,\n offline: invisibleSvg\n };\n const activeSvg = computed(() => status.value && matchSvg[status.value]);\n return (_ctx, _cache) => {\n return status.value ? (openBlock(), createElementBlock(\"span\", {\n key: 0,\n class: normalizeClass([\"user-status-icon\", {\n \"user-status-icon--invisible\": isInvisible.value\n }]),\n \"aria-hidden\": !ariaLabel.value || void 0,\n \"aria-label\": ariaLabel.value,\n role: \"img\",\n innerHTML: activeSvg.value\n }, null, 10, _hoisted_1)) : createCommentVNode(\"\", true);\n };\n }\n});\nconst NcUserStatusIcon = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-009e879d\"]]);\nexport {\n NcUserStatusIcon as N,\n getUserStatusText as g\n};\n//# sourceMappingURL=NcUserStatusIcon-DiX6zPGT.mjs.map\n","const ActionGlobalMixin = {\n beforeUpdate() {\n this.text = this.getText();\n },\n data() {\n return {\n // $slots are not reactive.\n // We need to update the content manually\n text: this.getText()\n };\n },\n computed: {\n isLongText() {\n return this.text && this.text.trim().length > 20;\n }\n },\n methods: {\n getText() {\n return this.$slots.default?.()[0].children?.trim?.() || \"\";\n }\n }\n};\nexport {\n ActionGlobalMixin as A\n};\n//# sourceMappingURL=actionGlobal-BZFdtdJL.mjs.map\n","import { warn } from \"vue\";\nimport { N as NC_ACTIONS_CLOSE_MENU } from \"./useNcActions-CiGWxAJE.mjs\";\nimport { A as ActionGlobalMixin } from \"./actionGlobal-BZFdtdJL.mjs\";\nconst ActionTextMixin = {\n mixins: [ActionGlobalMixin],\n props: {\n /**\n * Icon to show with the action, can be either a CSS class or an URL\n */\n icon: {\n type: String,\n default: \"\"\n },\n /**\n * The main text content of the entry.\n */\n name: {\n type: String,\n default: \"\"\n },\n /**\n * The title attribute of the element.\n */\n title: {\n type: String,\n default: \"\"\n },\n /**\n * Whether we close the Actions menu after the click\n */\n closeAfterClick: {\n type: Boolean,\n default: false\n },\n /**\n * Aria label for the button. Not needed if the button has text.\n */\n ariaLabel: {\n type: String,\n default: null\n }\n },\n inject: {\n closeMenu: {\n from: NC_ACTIONS_CLOSE_MENU\n }\n },\n emits: [\n \"click\"\n ],\n created() {\n if (\"ariaHidden\" in this.$attrs) {\n warn(\"[NcAction*]: Do not set the ariaHidden attribute as the root element will inherit the incorrect aria-hidden.\");\n }\n },\n computed: {\n /**\n * Check if icon prop is an URL\n *\n * @return {boolean} Whether the icon prop is an URL\n */\n isIconUrl() {\n try {\n return !!new URL(this.icon, this.icon.startsWith(\"/\") ? window.location.origin : void 0);\n } catch {\n return false;\n }\n }\n },\n methods: {\n onClick(event) {\n this.$emit(\"click\", event);\n if (this.closeAfterClick) {\n this.closeMenu(false);\n }\n }\n }\n};\nexport {\n ActionTextMixin as A\n};\n//# sourceMappingURL=actionText-DYzDdbVe.mjs.map\n","import '../assets/NcActionButton-D7bnKlOt.css';\nimport { c as mdiChevronRight, d as mdiCheck } from \"./mdi-D_GPbmUY.mjs\";\nimport { N as NcIconSvgWrapper } from \"./NcIconSvgWrapper-5AA93z-F.mjs\";\nimport { A as ActionTextMixin } from \"./actionText-DYzDdbVe.mjs\";\nimport { a as NC_ACTIONS_IS_SEMANTIC_MENU } from \"./useNcActions-CiGWxAJE.mjs\";\nimport { resolveComponent, createElementBlock, openBlock, normalizeClass, createElementVNode, mergeProps, renderSlot, createBlock, createCommentVNode, normalizeStyle, toDisplayString } from \"vue\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst _sfc_main = {\n name: \"NcActionButton\",\n components: {\n NcIconSvgWrapper\n },\n mixins: [ActionTextMixin],\n inject: {\n isInSemanticMenu: {\n from: NC_ACTIONS_IS_SEMANTIC_MENU,\n default: false\n }\n },\n props: {\n /**\n * disabled state of the action button\n */\n disabled: {\n type: Boolean,\n default: false\n },\n /**\n * If this is a menu, a chevron icon will\n * be added at the end of the line\n */\n isMenu: {\n type: Boolean,\n default: false\n },\n /**\n * The button's behavior, by default the button acts like a normal button with optional toggle button behavior if `modelValue` is `true` or `false`.\n * But you can also set to checkbox button behavior with tri-state or radio button like behavior.\n * This extends the native HTML button type attribute.\n */\n type: {\n type: String,\n default: \"button\",\n validator: (behavior) => [\"button\", \"checkbox\", \"radio\", \"reset\", \"submit\"].includes(behavior)\n },\n /**\n * The buttons state if `type` is 'checkbox' or 'radio' (meaning if it is pressed / selected).\n * For checkbox and toggle button behavior - boolean value.\n * For radio button behavior - could be a boolean checked or a string with the value of the button.\n * Note: Unlike native radio buttons, NcActionButton are not grouped by name, so you need to connect them by bind correct modelValue.\n *\n * **This is not availabe for `type='submit'` or `type='reset'`**\n *\n * If using `type='checkbox'` a `model-value` of `true` means checked, `false` means unchecked and `null` means indeterminate (tri-state)\n * For `type='radio'` `null` is equal to `false`\n */\n modelValue: {\n type: [Boolean, String],\n default: null\n },\n /**\n * The value used for the `modelValue` when this component is used with radio behavior\n * Similar to the `value` attribute of ``\n */\n value: {\n type: String,\n default: null\n },\n /**\n * Small underlying text content of the entry\n */\n description: {\n type: String,\n default: \"\"\n }\n },\n emits: [\"update:modelValue\"],\n setup() {\n return {\n mdiCheck,\n mdiChevronRight\n };\n },\n computed: {\n /**\n * determines if the action is focusable\n *\n * @return {boolean} is the action focusable ?\n */\n isFocusable() {\n return !this.disabled;\n },\n /**\n * The current \"checked\" or \"pressed\" state for the model behavior\n */\n isChecked() {\n if (this.type === \"radio\" && typeof this.modelValue !== \"boolean\") {\n return this.modelValue === this.value;\n }\n return this.modelValue;\n },\n /**\n * The native HTML type to set on the button\n */\n nativeType() {\n if (this.type === \"submit\" || this.type === \"reset\") {\n return this.type;\n }\n return \"button\";\n },\n /**\n * HTML attributes to bind to the
` and ``. Use `scope` on ``\n background: null, // ``. Use CSS `background-image` instead\n bgColor: null, // `` and table elements. Use CSS `background-color` instead\n border: number, // ``. Use CSS `border-width` instead,\n borderColor: null, // `
`. Use CSS `border-color` instead,\n bottomMargin: number, // ``\n cellPadding: null, // `
`\n cellSpacing: null, // `
`\n char: null, // Several table elements. When `align=char`, sets the character to align on\n charOff: null, // Several table elements. When `char`, offsets the alignment\n classId: null, // ``\n clear: null, // `
`. Use CSS `clear` instead\n code: null, // ``\n codeBase: null, // ``\n codeType: null, // ``\n color: null, // `` and `
`. Use CSS instead\n compact: boolean, // Lists. Use CSS to reduce space between items instead\n declare: boolean, // ``\n event: null, // `\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationRawTagOpen(code) {\n if (code === 47) {\n effects.consume(code);\n buffer = '';\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In raw continuation, after ` | \n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function continuationRawEndTag(code) {\n if (code === 62) {\n const name = buffer.toLowerCase();\n if (htmlRawNames.includes(name)) {\n effects.consume(code);\n return continuationClose;\n }\n return continuation(code);\n }\n if (asciiAlpha(code) && buffer.length < 8) {\n // Always the case.\n effects.consume(code);\n buffer += String.fromCharCode(code);\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In cdata continuation, after `]`, expecting `]>`.\n *\n * ```markdown\n * > | &<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationCdataInside(code) {\n if (code === 93) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In declaration or instruction continuation, at `>`.\n *\n * ```markdown\n * > | \n * ^\n * > | \n * ^\n * > | \n * ^\n * > | \n * ^\n * > | &<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationDeclarationInside(code) {\n if (code === 62) {\n effects.consume(code);\n return continuationClose;\n }\n\n // More dashes.\n if (code === 45 && marker === 2) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In closed continuation: everything we get until the eol/eof is part of it.\n *\n * ```markdown\n * > | \n * ^\n * ```\n *\n * @type {State}\n */\n function continuationClose(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"htmlFlowData\");\n return continuationAfter(code);\n }\n effects.consume(code);\n return continuationClose;\n }\n\n /**\n * Done.\n *\n * ```markdown\n * > | \n * ^\n * ```\n *\n * @type {State}\n */\n function continuationAfter(code) {\n effects.exit(\"htmlFlow\");\n // // Feel free to interrupt.\n // tokenizer.interrupt = false\n // // No longer concrete.\n // tokenizer.concrete = false\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeNonLazyContinuationStart(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * At eol, before continuation.\n *\n * ```markdown\n * > | * ```js\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * A continuation.\n *\n * ```markdown\n * | * ```js\n * > | b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n return self.parser.lazy[self.now().line] ? nok(code) : ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlankLineBefore(effects, ok, nok) {\n return start;\n\n /**\n * Before eol, expecting blank line.\n *\n * ```markdown\n * > |
\n * ^\n * |\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return effects.attempt(blankLine, ok, nok);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiAlphanumeric, asciiAlpha, markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const htmlText = {\n name: 'htmlText',\n tokenize: tokenizeHtmlText\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHtmlText(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable | undefined} */\n let marker;\n /** @type {number} */\n let index;\n /** @type {State} */\n let returnState;\n return start;\n\n /**\n * Start of HTML (text).\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"htmlText\");\n effects.enter(\"htmlTextData\");\n effects.consume(code);\n return open;\n }\n\n /**\n * After `<`, at tag name or other stuff.\n *\n * ```markdown\n * > | a c\n * ^\n * > | a c\n * ^\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 33) {\n effects.consume(code);\n return declarationOpen;\n }\n if (code === 47) {\n effects.consume(code);\n return tagCloseStart;\n }\n if (code === 63) {\n effects.consume(code);\n return instruction;\n }\n\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagOpen;\n }\n return nok(code);\n }\n\n /**\n * After ` | a c\n * ^\n * > | a c\n * ^\n * > | a &<]]> c\n * ^\n * ```\n *\n * @type {State}\n */\n function declarationOpen(code) {\n if (code === 45) {\n effects.consume(code);\n return commentOpenInside;\n }\n if (code === 91) {\n effects.consume(code);\n index = 0;\n return cdataOpenInside;\n }\n if (asciiAlpha(code)) {\n effects.consume(code);\n return declaration;\n }\n return nok(code);\n }\n\n /**\n * In a comment, after ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentOpenInside(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return nok(code);\n }\n\n /**\n * In comment.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function comment(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 45) {\n effects.consume(code);\n return commentClose;\n }\n if (markdownLineEnding(code)) {\n returnState = comment;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return comment;\n }\n\n /**\n * In comment, after `-`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentClose(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return comment(code);\n }\n\n /**\n * In comment, after `--`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentEnd(code) {\n return code === 62 ? end(code) : code === 45 ? commentClose(code) : comment(code);\n }\n\n /**\n * After ` | a &<]]> b\n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function cdataOpenInside(code) {\n const value = \"CDATA[\";\n if (code === value.charCodeAt(index++)) {\n effects.consume(code);\n return index === value.length ? cdata : cdataOpenInside;\n }\n return nok(code);\n }\n\n /**\n * In CDATA.\n *\n * ```markdown\n * > | a &<]]> b\n * ^^^\n * ```\n *\n * @type {State}\n */\n function cdata(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataClose;\n }\n if (markdownLineEnding(code)) {\n returnState = cdata;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return cdata;\n }\n\n /**\n * In CDATA, after `]`, at another `]`.\n *\n * ```markdown\n * > | a &<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataClose(code) {\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In CDATA, after `]]`, at `>`.\n *\n * ```markdown\n * > | a &<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataEnd(code) {\n if (code === 62) {\n return end(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In declaration.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function declaration(code) {\n if (code === null || code === 62) {\n return end(code);\n }\n if (markdownLineEnding(code)) {\n returnState = declaration;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return declaration;\n }\n\n /**\n * In instruction.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function instruction(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 63) {\n effects.consume(code);\n return instructionClose;\n }\n if (markdownLineEnding(code)) {\n returnState = instruction;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return instruction;\n }\n\n /**\n * In instruction, after `?`, at `>`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function instructionClose(code) {\n return code === 62 ? end(code) : instruction(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseStart(code) {\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagClose;\n }\n return nok(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagClose(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagClose;\n }\n return tagCloseBetween(code);\n }\n\n /**\n * In closing tag, after tag name.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseBetween(code) {\n if (markdownLineEnding(code)) {\n returnState = tagCloseBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagCloseBetween;\n }\n return end(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpen(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpen;\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In opening tag, after tag name.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenBetween(code) {\n if (code === 47) {\n effects.consume(code);\n return end;\n }\n\n // ASCII alphabetical and `:` and `_`.\n if (code === 58 || code === 95 || asciiAlpha(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenBetween;\n }\n return end(code);\n }\n\n /**\n * In attribute name.\n *\n * ```markdown\n * > | a d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeName(code) {\n // ASCII alphabetical and `-`, `.`, `:`, and `_`.\n if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n return tagOpenAttributeNameAfter(code);\n }\n\n /**\n * After attribute name, before initializer, the end of the tag, or\n * whitespace.\n *\n * ```markdown\n * > | a d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeNameAfter(code) {\n if (code === 61) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeNameAfter;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeNameAfter;\n }\n return tagOpenBetween(code);\n }\n\n /**\n * Before unquoted, double quoted, or single quoted attribute value, allowing\n * whitespace.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueBefore(code) {\n if (code === null || code === 60 || code === 61 || code === 62 || code === 96) {\n return nok(code);\n }\n if (code === 34 || code === 39) {\n effects.consume(code);\n marker = code;\n return tagOpenAttributeValueQuoted;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueBefore;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * In double or single quoted attribute value.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuoted(code) {\n if (code === marker) {\n effects.consume(code);\n marker = undefined;\n return tagOpenAttributeValueQuotedAfter;\n }\n if (code === null) {\n return nok(code);\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueQuoted;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueQuoted;\n }\n\n /**\n * In unquoted attribute value.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueUnquoted(code) {\n if (code === null || code === 34 || code === 39 || code === 60 || code === 61 || code === 96) {\n return nok(code);\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * After double or single quoted attribute value, before whitespace or the end\n * of the tag.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuotedAfter(code) {\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In certain circumstances of a tag where only an `>` is allowed.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function end(code) {\n if (code === 62) {\n effects.consume(code);\n effects.exit(\"htmlTextData\");\n effects.exit(\"htmlText\");\n return ok;\n }\n return nok(code);\n }\n\n /**\n * At eol.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * > | a \n * ```\n *\n * @type {State}\n */\n function lineEndingBefore(code) {\n effects.exit(\"htmlTextData\");\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return lineEndingAfter;\n }\n\n /**\n * After eol, at optional whitespace.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a \n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfter(code) {\n // Always populated by defaults.\n\n return markdownSpace(code) ? factorySpace(effects, lineEndingAfterPrefix, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code) : lineEndingAfterPrefix(code);\n }\n\n /**\n * After eol, after optional whitespace.\n *\n * > 👉 **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a \n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfterPrefix(code) {\n effects.enter(\"htmlTextData\");\n return returnState(code);\n }\n}","/**\n * @import {\n * Construct,\n * Event,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factoryDestination } from 'micromark-factory-destination';\nimport { factoryLabel } from 'micromark-factory-label';\nimport { factoryTitle } from 'micromark-factory-title';\nimport { factoryWhitespace } from 'micromark-factory-whitespace';\nimport { markdownLineEndingOrSpace } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/** @type {Construct} */\nexport const labelEnd = {\n name: 'labelEnd',\n resolveAll: resolveAllLabelEnd,\n resolveTo: resolveToLabelEnd,\n tokenize: tokenizeLabelEnd\n};\n\n/** @type {Construct} */\nconst resourceConstruct = {\n tokenize: tokenizeResource\n};\n/** @type {Construct} */\nconst referenceFullConstruct = {\n tokenize: tokenizeReferenceFull\n};\n/** @type {Construct} */\nconst referenceCollapsedConstruct = {\n tokenize: tokenizeReferenceCollapsed\n};\n\n/** @type {Resolver} */\nfunction resolveAllLabelEnd(events) {\n let index = -1;\n /** @type {Array} */\n const newEvents = [];\n while (++index < events.length) {\n const token = events[index][1];\n newEvents.push(events[index]);\n if (token.type === \"labelImage\" || token.type === \"labelLink\" || token.type === \"labelEnd\") {\n // Remove the marker.\n const offset = token.type === \"labelImage\" ? 4 : 2;\n token.type = \"data\";\n index += offset;\n }\n }\n\n // If the events are equal, we don't have to copy newEvents to events\n if (events.length !== newEvents.length) {\n splice(events, 0, events.length, newEvents);\n }\n return events;\n}\n\n/** @type {Resolver} */\nfunction resolveToLabelEnd(events, context) {\n let index = events.length;\n let offset = 0;\n /** @type {Token} */\n let token;\n /** @type {number | undefined} */\n let open;\n /** @type {number | undefined} */\n let close;\n /** @type {Array} */\n let media;\n\n // Find an opening.\n while (index--) {\n token = events[index][1];\n if (open) {\n // If we see another link, or inactive link label, we’ve been here before.\n if (token.type === \"link\" || token.type === \"labelLink\" && token._inactive) {\n break;\n }\n\n // Mark other link openings as inactive, as we can’t have links in\n // links.\n if (events[index][0] === 'enter' && token.type === \"labelLink\") {\n token._inactive = true;\n }\n } else if (close) {\n if (events[index][0] === 'enter' && (token.type === \"labelImage\" || token.type === \"labelLink\") && !token._balanced) {\n open = index;\n if (token.type !== \"labelLink\") {\n offset = 2;\n break;\n }\n }\n } else if (token.type === \"labelEnd\") {\n close = index;\n }\n }\n const group = {\n type: events[open][1].type === \"labelLink\" ? \"link\" : \"image\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n const label = {\n type: \"label\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[close][1].end\n }\n };\n const text = {\n type: \"labelText\",\n start: {\n ...events[open + offset + 2][1].end\n },\n end: {\n ...events[close - 2][1].start\n }\n };\n media = [['enter', group, context], ['enter', label, context]];\n\n // Opening marker.\n media = push(media, events.slice(open + 1, open + offset + 3));\n\n // Text open.\n media = push(media, [['enter', text, context]]);\n\n // Always populated by defaults.\n\n // Between.\n media = push(media, resolveAll(context.parser.constructs.insideSpan.null, events.slice(open + offset + 4, close - 3), context));\n\n // Text close, marker close, label close.\n media = push(media, [['exit', text, context], events[close - 2], events[close - 1], ['exit', label, context]]);\n\n // Reference, resource, or so.\n media = push(media, events.slice(close + 1));\n\n // Media close.\n media = push(media, [['exit', group, context]]);\n splice(events, open, events.length, media);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelEnd(effects, ok, nok) {\n const self = this;\n let index = self.events.length;\n /** @type {Token} */\n let labelStart;\n /** @type {boolean} */\n let defined;\n\n // Find an opening.\n while (index--) {\n if ((self.events[index][1].type === \"labelImage\" || self.events[index][1].type === \"labelLink\") && !self.events[index][1]._balanced) {\n labelStart = self.events[index][1];\n break;\n }\n }\n return start;\n\n /**\n * Start of label end.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // If there is not an okay opening.\n if (!labelStart) {\n return nok(code);\n }\n\n // If the corresponding label (link) start is marked as inactive,\n // it means we’d be wrapping a link, like this:\n //\n // ```markdown\n // > | a [b [c](d) e](f) g.\n // ^\n // ```\n //\n // We can’t have that, so it’s just balanced brackets.\n if (labelStart._inactive) {\n return labelEndNok(code);\n }\n defined = self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n })));\n effects.enter(\"labelEnd\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelEnd\");\n return after;\n }\n\n /**\n * After `]`.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // Note: `markdown-rs` also parses GFM footnotes here, which for us is in\n // an extension.\n\n // Resource (`[asd](fgh)`)?\n if (code === 40) {\n return effects.attempt(resourceConstruct, labelEndOk, defined ? labelEndOk : labelEndNok)(code);\n }\n\n // Full (`[asd][fgh]`) or collapsed (`[asd][]`) reference?\n if (code === 91) {\n return effects.attempt(referenceFullConstruct, labelEndOk, defined ? referenceNotFull : labelEndNok)(code);\n }\n\n // Shortcut (`[asd]`) reference?\n return defined ? labelEndOk(code) : labelEndNok(code);\n }\n\n /**\n * After `]`, at `[`, but not at a full reference.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceNotFull(code) {\n return effects.attempt(referenceCollapsedConstruct, labelEndOk, labelEndNok)(code);\n }\n\n /**\n * Done, we found something.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndOk(code) {\n // Note: `markdown-rs` does a bunch of stuff here.\n return ok(code);\n }\n\n /**\n * Done, it’s nothing.\n *\n * There was an okay opening, but we didn’t match anything.\n *\n * ```markdown\n * > | [a](b c\n * ^\n * > | [a][b c\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndNok(code) {\n labelStart._balanced = true;\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeResource(effects, ok, nok) {\n return resourceStart;\n\n /**\n * At a resource.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceStart(code) {\n effects.enter(\"resource\");\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n return resourceBefore;\n }\n\n /**\n * In resource, after `(`, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBefore(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceOpen)(code) : resourceOpen(code);\n }\n\n /**\n * In resource, after optional whitespace, at `)` or a destination.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceOpen(code) {\n if (code === 41) {\n return resourceEnd(code);\n }\n return factoryDestination(effects, resourceDestinationAfter, resourceDestinationMissing, \"resourceDestination\", \"resourceDestinationLiteral\", \"resourceDestinationLiteralMarker\", \"resourceDestinationRaw\", \"resourceDestinationString\", 32)(code);\n }\n\n /**\n * In resource, after destination, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceBetween)(code) : resourceEnd(code);\n }\n\n /**\n * At invalid destination.\n *\n * ```markdown\n * > | [a](<<) b\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationMissing(code) {\n return nok(code);\n }\n\n /**\n * In resource, after destination and whitespace, at `(` or title.\n *\n * ```markdown\n * > | [a](b ) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBetween(code) {\n if (code === 34 || code === 39 || code === 40) {\n return factoryTitle(effects, resourceTitleAfter, nok, \"resourceTitle\", \"resourceTitleMarker\", \"resourceTitleString\")(code);\n }\n return resourceEnd(code);\n }\n\n /**\n * In resource, after title, at optional whitespace.\n *\n * ```markdown\n * > | [a](b \"c\") d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceTitleAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceEnd)(code) : resourceEnd(code);\n }\n\n /**\n * In resource, at `)`.\n *\n * ```markdown\n * > | [a](b) d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceEnd(code) {\n if (code === 41) {\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n effects.exit(\"resource\");\n return ok;\n }\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceFull(effects, ok, nok) {\n const self = this;\n return referenceFull;\n\n /**\n * In a reference (full), at the `[`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFull(code) {\n return factoryLabel.call(self, effects, referenceFullAfter, referenceFullMissing, \"reference\", \"referenceMarker\", \"referenceString\")(code);\n }\n\n /**\n * In a reference (full), after `]`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullAfter(code) {\n return self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize(self.events[self.events.length - 1][1]).slice(1, -1))) ? ok(code) : nok(code);\n }\n\n /**\n * In reference (full) that was missing.\n *\n * ```markdown\n * > | [a][b d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullMissing(code) {\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceCollapsed(effects, ok, nok) {\n return referenceCollapsedStart;\n\n /**\n * In reference (collapsed), at `[`.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedStart(code) {\n // We only attempt a collapsed label if there’s a `[`.\n\n effects.enter(\"reference\");\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n return referenceCollapsedOpen;\n }\n\n /**\n * In reference (collapsed), at `]`.\n *\n * > 👉 **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedOpen(code) {\n if (code === 93) {\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n effects.exit(\"reference\");\n return ok;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartImage = {\n name: 'labelStartImage',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartImage\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartImage(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (image) start.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelImage\");\n effects.enter(\"labelImageMarker\");\n effects.consume(code);\n effects.exit(\"labelImageMarker\");\n return open;\n }\n\n /**\n * After `!`, at `[`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 91) {\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelImage\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * After `![`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * This is needed in because, when GFM footnotes are enabled, images never\n * form when started with a `^`.\n * Instead, links form:\n *\n * ```markdown\n * ![^a](b)\n *\n * ![^a][b]\n *\n * [b]: c\n * ```\n *\n * ```html\n *

!^a

\n *

!^a

\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // To do: use a new field to do this, this is still needed for\n // `micromark-extension-gfm-footnote`, but the `label-start-link`\n // behavior isn’t.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartLink = {\n name: 'labelStartLink',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartLink\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartLink(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (link) start.\n *\n * ```markdown\n * > | a [b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelLink\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelLink\");\n return after;\n }\n\n /** @type {State} */\n function after(code) {\n // To do: this isn’t needed in `micromark-extension-gfm-footnote`,\n // remove.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const lineEnding = {\n name: 'lineEnding',\n tokenize: tokenizeLineEnding\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLineEnding(effects, ok) {\n return start;\n\n /** @type {State} */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, ok, \"linePrefix\");\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const thematicBreak = {\n name: 'thematicBreak',\n tokenize: tokenizeThematicBreak\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeThematicBreak(effects, ok, nok) {\n let size = 0;\n /** @type {NonNullable} */\n let marker;\n return start;\n\n /**\n * Start of thematic break.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"thematicBreak\");\n // To do: parse indent like `markdown-rs`.\n return before(code);\n }\n\n /**\n * After optional whitespace, at marker.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n marker = code;\n return atBreak(code);\n }\n\n /**\n * After something, before something else.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function atBreak(code) {\n if (code === marker) {\n effects.enter(\"thematicBreakSequence\");\n return sequence(code);\n }\n if (size >= 3 && (code === null || markdownLineEnding(code))) {\n effects.exit(\"thematicBreak\");\n return ok(code);\n }\n return nok(code);\n }\n\n /**\n * In sequence.\n *\n * ```markdown\n * > | ***\n * ^\n * ```\n *\n * @type {State}\n */\n function sequence(code) {\n if (code === marker) {\n effects.consume(code);\n size++;\n return sequence;\n }\n effects.exit(\"thematicBreakSequence\");\n return markdownSpace(code) ? factorySpace(effects, atBreak, \"whitespace\")(code) : atBreak(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Exiter,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiDigit, markdownSpace } from 'micromark-util-character';\nimport { blankLine } from './blank-line.js';\nimport { thematicBreak } from './thematic-break.js';\n\n/** @type {Construct} */\nexport const list = {\n continuation: {\n tokenize: tokenizeListContinuation\n },\n exit: tokenizeListEnd,\n name: 'list',\n tokenize: tokenizeListStart\n};\n\n/** @type {Construct} */\nconst listItemPrefixWhitespaceConstruct = {\n partial: true,\n tokenize: tokenizeListItemPrefixWhitespace\n};\n\n/** @type {Construct} */\nconst indentConstruct = {\n partial: true,\n tokenize: tokenizeIndent\n};\n\n// To do: `markdown-rs` parses list items on their own and later stitches them\n// together.\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListStart(effects, ok, nok) {\n const self = this;\n const tail = self.events[self.events.length - 1];\n let initialSize = tail && tail[1].type === \"linePrefix\" ? tail[2].sliceSerialize(tail[1], true).length : 0;\n let size = 0;\n return start;\n\n /** @type {State} */\n function start(code) {\n const kind = self.containerState.type || (code === 42 || code === 43 || code === 45 ? \"listUnordered\" : \"listOrdered\");\n if (kind === \"listUnordered\" ? !self.containerState.marker || code === self.containerState.marker : asciiDigit(code)) {\n if (!self.containerState.type) {\n self.containerState.type = kind;\n effects.enter(kind, {\n _container: true\n });\n }\n if (kind === \"listUnordered\") {\n effects.enter(\"listItemPrefix\");\n return code === 42 || code === 45 ? effects.check(thematicBreak, nok, atMarker)(code) : atMarker(code);\n }\n if (!self.interrupt || code === 49) {\n effects.enter(\"listItemPrefix\");\n effects.enter(\"listItemValue\");\n return inside(code);\n }\n }\n return nok(code);\n }\n\n /** @type {State} */\n function inside(code) {\n if (asciiDigit(code) && ++size < 10) {\n effects.consume(code);\n return inside;\n }\n if ((!self.interrupt || size < 2) && (self.containerState.marker ? code === self.containerState.marker : code === 41 || code === 46)) {\n effects.exit(\"listItemValue\");\n return atMarker(code);\n }\n return nok(code);\n }\n\n /**\n * @type {State}\n **/\n function atMarker(code) {\n effects.enter(\"listItemMarker\");\n effects.consume(code);\n effects.exit(\"listItemMarker\");\n self.containerState.marker = self.containerState.marker || code;\n return effects.check(blankLine,\n // Can’t be empty when interrupting.\n self.interrupt ? nok : onBlank, effects.attempt(listItemPrefixWhitespaceConstruct, endOfPrefix, otherPrefix));\n }\n\n /** @type {State} */\n function onBlank(code) {\n self.containerState.initialBlankLine = true;\n initialSize++;\n return endOfPrefix(code);\n }\n\n /** @type {State} */\n function otherPrefix(code) {\n if (markdownSpace(code)) {\n effects.enter(\"listItemPrefixWhitespace\");\n effects.consume(code);\n effects.exit(\"listItemPrefixWhitespace\");\n return endOfPrefix;\n }\n return nok(code);\n }\n\n /** @type {State} */\n function endOfPrefix(code) {\n self.containerState.size = initialSize + self.sliceSerialize(effects.exit(\"listItemPrefix\"), true).length;\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListContinuation(effects, ok, nok) {\n const self = this;\n self.containerState._closeFlow = undefined;\n return effects.check(blankLine, onBlank, notBlank);\n\n /** @type {State} */\n function onBlank(code) {\n self.containerState.furtherBlankLines = self.containerState.furtherBlankLines || self.containerState.initialBlankLine;\n\n // We have a blank line.\n // Still, try to consume at most the items size.\n return factorySpace(effects, ok, \"listItemIndent\", self.containerState.size + 1)(code);\n }\n\n /** @type {State} */\n function notBlank(code) {\n if (self.containerState.furtherBlankLines || !markdownSpace(code)) {\n self.containerState.furtherBlankLines = undefined;\n self.containerState.initialBlankLine = undefined;\n return notInCurrentItem(code);\n }\n self.containerState.furtherBlankLines = undefined;\n self.containerState.initialBlankLine = undefined;\n return effects.attempt(indentConstruct, ok, notInCurrentItem)(code);\n }\n\n /** @type {State} */\n function notInCurrentItem(code) {\n // While we do continue, we signal that the flow should be closed.\n self.containerState._closeFlow = true;\n // As we’re closing flow, we’re no longer interrupting.\n self.interrupt = undefined;\n // Always populated by defaults.\n\n return factorySpace(effects, effects.attempt(list, ok, nok), \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeIndent(effects, ok, nok) {\n const self = this;\n return factorySpace(effects, afterPrefix, \"listItemIndent\", self.containerState.size + 1);\n\n /** @type {State} */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"listItemIndent\" && tail[2].sliceSerialize(tail[1], true).length === self.containerState.size ? ok(code) : nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Exiter}\n */\nfunction tokenizeListEnd(effects) {\n effects.exit(this.containerState.type);\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeListItemPrefixWhitespace(effects, ok, nok) {\n const self = this;\n\n // Always populated by defaults.\n\n return factorySpace(effects, afterPrefix, \"listItemPrefixWhitespace\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4 + 1);\n\n /** @type {State} */\n function afterPrefix(code) {\n const tail = self.events[self.events.length - 1];\n return !markdownSpace(code) && tail && tail[1].type === \"listItemPrefixWhitespace\" ? ok(code) : nok(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const setextUnderline = {\n name: 'setextUnderline',\n resolveTo: resolveToSetextUnderline,\n tokenize: tokenizeSetextUnderline\n};\n\n/** @type {Resolver} */\nfunction resolveToSetextUnderline(events, context) {\n // To do: resolve like `markdown-rs`.\n let index = events.length;\n /** @type {number | undefined} */\n let content;\n /** @type {number | undefined} */\n let text;\n /** @type {number | undefined} */\n let definition;\n\n // Find the opening of the content.\n // It’ll always exist: we don’t tokenize if it isn’t there.\n while (index--) {\n if (events[index][0] === 'enter') {\n if (events[index][1].type === \"content\") {\n content = index;\n break;\n }\n if (events[index][1].type === \"paragraph\") {\n text = index;\n }\n }\n // Exit\n else {\n if (events[index][1].type === \"content\") {\n // Remove the content end (if needed we’ll add it later)\n events.splice(index, 1);\n }\n if (!definition && events[index][1].type === \"definition\") {\n definition = index;\n }\n }\n }\n const heading = {\n type: \"setextHeading\",\n start: {\n ...events[content][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n\n // Change the paragraph to setext heading text.\n events[text][1].type = \"setextHeadingText\";\n\n // If we have definitions in the content, we’ll keep on having content,\n // but we need move it.\n if (definition) {\n events.splice(text, 0, ['enter', heading, context]);\n events.splice(definition + 1, 0, ['exit', events[content][1], context]);\n events[content][1].end = {\n ...events[definition][1].end\n };\n } else {\n events[content][1] = heading;\n }\n\n // Add the heading exit at the end.\n events.push(['exit', heading, context]);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeSetextUnderline(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable} */\n let marker;\n return start;\n\n /**\n * At start of heading (setext) underline.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n let index = self.events.length;\n /** @type {boolean | undefined} */\n let paragraph;\n // Find an opening.\n while (index--) {\n // Skip enter/exit of line ending, line prefix, and content.\n // We can now either have a definition or a paragraph.\n if (self.events[index][1].type !== \"lineEnding\" && self.events[index][1].type !== \"linePrefix\" && self.events[index][1].type !== \"content\") {\n paragraph = self.events[index][1].type === \"paragraph\";\n break;\n }\n }\n\n // To do: handle lazy/pierce like `markdown-rs`.\n // To do: parse indent like `markdown-rs`.\n if (!self.parser.lazy[self.now().line] && (self.interrupt || paragraph)) {\n effects.enter(\"setextHeadingLine\");\n marker = code;\n return before(code);\n }\n return nok(code);\n }\n\n /**\n * After optional whitespace, at `-` or `=`.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function before(code) {\n effects.enter(\"setextHeadingLineSequence\");\n return inside(code);\n }\n\n /**\n * In sequence.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n if (code === marker) {\n effects.consume(code);\n return inside;\n }\n effects.exit(\"setextHeadingLineSequence\");\n return markdownSpace(code) ? factorySpace(effects, after, \"lineSuffix\")(code) : after(code);\n }\n\n /**\n * After sequence, after optional whitespace.\n *\n * ```markdown\n * | aa\n * > | ==\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"setextHeadingLine\");\n return ok(code);\n }\n return nok(code);\n }\n}","/**\n * @import {\n * InitialConstruct,\n * Initializer,\n * State,\n * TokenizeContext\n * } from 'micromark-util-types'\n */\n\nimport { blankLine, content } from 'micromark-core-commonmark';\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {InitialConstruct} */\nexport const flow = {\n tokenize: initializeFlow\n};\n\n/**\n * @this {TokenizeContext}\n * Self.\n * @type {Initializer}\n * Initializer.\n */\nfunction initializeFlow(effects) {\n const self = this;\n const initial = effects.attempt(\n // Try to parse a blank line.\n blankLine, atBlankEnding,\n // Try to parse initial flow (essentially, only code).\n effects.attempt(this.parser.constructs.flowInitial, afterConstruct, factorySpace(effects, effects.attempt(this.parser.constructs.flow, afterConstruct, effects.attempt(content, afterConstruct)), \"linePrefix\")));\n return initial;\n\n /** @type {State} */\n function atBlankEnding(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEndingBlank\");\n effects.consume(code);\n effects.exit(\"lineEndingBlank\");\n self.currentConstruct = undefined;\n return initial;\n }\n\n /** @type {State} */\n function afterConstruct(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n self.currentConstruct = undefined;\n return initial;\n }\n}","/**\n * @import {\n * Code,\n * InitialConstruct,\n * Initializer,\n * Resolver,\n * State,\n * TokenizeContext\n * } from 'micromark-util-types'\n */\n\nexport const resolver = {\n resolveAll: createResolver()\n};\nexport const string = initializeFactory('string');\nexport const text = initializeFactory('text');\n\n/**\n * @param {'string' | 'text'} field\n * Field.\n * @returns {InitialConstruct}\n * Construct.\n */\nfunction initializeFactory(field) {\n return {\n resolveAll: createResolver(field === 'text' ? resolveAllLineSuffixes : undefined),\n tokenize: initializeText\n };\n\n /**\n * @this {TokenizeContext}\n * Context.\n * @type {Initializer}\n */\n function initializeText(effects) {\n const self = this;\n const constructs = this.parser.constructs[field];\n const text = effects.attempt(constructs, start, notText);\n return start;\n\n /** @type {State} */\n function start(code) {\n return atBreak(code) ? text(code) : notText(code);\n }\n\n /** @type {State} */\n function notText(code) {\n if (code === null) {\n effects.consume(code);\n return;\n }\n effects.enter(\"data\");\n effects.consume(code);\n return data;\n }\n\n /** @type {State} */\n function data(code) {\n if (atBreak(code)) {\n effects.exit(\"data\");\n return text(code);\n }\n\n // Data.\n effects.consume(code);\n return data;\n }\n\n /**\n * @param {Code} code\n * Code.\n * @returns {boolean}\n * Whether the code is a break.\n */\n function atBreak(code) {\n if (code === null) {\n return true;\n }\n const list = constructs[code];\n let index = -1;\n if (list) {\n // Always populated by defaults.\n\n while (++index < list.length) {\n const item = list[index];\n if (!item.previous || item.previous.call(self, self.previous)) {\n return true;\n }\n }\n }\n return false;\n }\n }\n}\n\n/**\n * @param {Resolver | undefined} [extraResolver]\n * Resolver.\n * @returns {Resolver}\n * Resolver.\n */\nfunction createResolver(extraResolver) {\n return resolveAllText;\n\n /** @type {Resolver} */\n function resolveAllText(events, context) {\n let index = -1;\n /** @type {number | undefined} */\n let enter;\n\n // A rather boring computation (to merge adjacent `data` events) which\n // improves mm performance by 29%.\n while (++index <= events.length) {\n if (enter === undefined) {\n if (events[index] && events[index][1].type === \"data\") {\n enter = index;\n index++;\n }\n } else if (!events[index] || events[index][1].type !== \"data\") {\n // Don’t do anything if there is one data token.\n if (index !== enter + 2) {\n events[enter][1].end = events[index - 1][1].end;\n events.splice(enter + 2, index - enter - 2);\n index = enter + 2;\n }\n enter = undefined;\n }\n }\n return extraResolver ? extraResolver(events, context) : events;\n }\n}\n\n/**\n * A rather ugly set of instructions which again looks at chunks in the input\n * stream.\n * The reason to do this here is that it is *much* faster to parse in reverse.\n * And that we can’t hook into `null` to split the line suffix before an EOF.\n * To do: figure out if we can make this into a clean utility, or even in core.\n * As it will be useful for GFMs literal autolink extension (and maybe even\n * tables?)\n *\n * @type {Resolver}\n */\nfunction resolveAllLineSuffixes(events, context) {\n let eventIndex = 0; // Skip first.\n\n while (++eventIndex <= events.length) {\n if ((eventIndex === events.length || events[eventIndex][1].type === \"lineEnding\") && events[eventIndex - 1][1].type === \"data\") {\n const data = events[eventIndex - 1][1];\n const chunks = context.sliceStream(data);\n let index = chunks.length;\n let bufferIndex = -1;\n let size = 0;\n /** @type {boolean | undefined} */\n let tabs;\n while (index--) {\n const chunk = chunks[index];\n if (typeof chunk === 'string') {\n bufferIndex = chunk.length;\n while (chunk.charCodeAt(bufferIndex - 1) === 32) {\n size++;\n bufferIndex--;\n }\n if (bufferIndex) break;\n bufferIndex = -1;\n }\n // Number\n else if (chunk === -2) {\n tabs = true;\n size++;\n } else if (chunk === -1) {\n // Empty\n } else {\n // Replacement character, exit.\n index++;\n break;\n }\n }\n\n // Allow final trailing whitespace.\n if (context._contentTypeTextTrailing && eventIndex === events.length) {\n size = 0;\n }\n if (size) {\n const token = {\n type: eventIndex === events.length || tabs || size < 2 ? \"lineSuffix\" : \"hardBreakTrailing\",\n start: {\n _bufferIndex: index ? bufferIndex : data.start._bufferIndex + bufferIndex,\n _index: data.start._index + index,\n line: data.end.line,\n column: data.end.column - size,\n offset: data.end.offset - size\n },\n end: {\n ...data.end\n }\n };\n data.end = {\n ...token.start\n };\n if (data.start.offset === data.end.offset) {\n Object.assign(data, token);\n } else {\n events.splice(eventIndex, 0, ['enter', token, context], ['exit', token, context]);\n eventIndex += 2;\n }\n }\n eventIndex++;\n }\n }\n return events;\n}","/**\n * @import {Extension} from 'micromark-util-types'\n */\n\nimport { attention, autolink, blockQuote, characterEscape, characterReference, codeFenced, codeIndented, codeText, definition, hardBreakEscape, headingAtx, htmlFlow, htmlText, labelEnd, labelStartImage, labelStartLink, lineEnding, list, setextUnderline, thematicBreak } from 'micromark-core-commonmark';\nimport { resolver as resolveText } from './initialize/text.js';\n\n/** @satisfies {Extension['document']} */\nexport const document = {\n [42]: list,\n [43]: list,\n [45]: list,\n [48]: list,\n [49]: list,\n [50]: list,\n [51]: list,\n [52]: list,\n [53]: list,\n [54]: list,\n [55]: list,\n [56]: list,\n [57]: list,\n [62]: blockQuote\n};\n\n/** @satisfies {Extension['contentInitial']} */\nexport const contentInitial = {\n [91]: definition\n};\n\n/** @satisfies {Extension['flowInitial']} */\nexport const flowInitial = {\n [-2]: codeIndented,\n [-1]: codeIndented,\n [32]: codeIndented\n};\n\n/** @satisfies {Extension['flow']} */\nexport const flow = {\n [35]: headingAtx,\n [42]: thematicBreak,\n [45]: [setextUnderline, thematicBreak],\n [60]: htmlFlow,\n [61]: setextUnderline,\n [95]: thematicBreak,\n [96]: codeFenced,\n [126]: codeFenced\n};\n\n/** @satisfies {Extension['string']} */\nexport const string = {\n [38]: characterReference,\n [92]: characterEscape\n};\n\n/** @satisfies {Extension['text']} */\nexport const text = {\n [-5]: lineEnding,\n [-4]: lineEnding,\n [-3]: lineEnding,\n [33]: labelStartImage,\n [38]: characterReference,\n [42]: attention,\n [60]: [autolink, htmlText],\n [91]: labelStartLink,\n [92]: [hardBreakEscape, characterEscape],\n [93]: labelEnd,\n [95]: attention,\n [96]: codeText\n};\n\n/** @satisfies {Extension['insideSpan']} */\nexport const insideSpan = {\n null: [attention, resolveText]\n};\n\n/** @satisfies {Extension['attentionMarkers']} */\nexport const attentionMarkers = {\n null: [42, 95]\n};\n\n/** @satisfies {Extension['disable']} */\nexport const disable = {\n null: []\n};","/**\n * @import {\n * Chunk,\n * Code,\n * ConstructRecord,\n * Construct,\n * Effects,\n * InitialConstruct,\n * ParseContext,\n * Point,\n * State,\n * TokenizeContext,\n * Token\n * } from 'micromark-util-types'\n */\n\n/**\n * @callback Restore\n * Restore the state.\n * @returns {undefined}\n * Nothing.\n *\n * @typedef Info\n * Info.\n * @property {Restore} restore\n * Restore.\n * @property {number} from\n * From.\n *\n * @callback ReturnHandle\n * Handle a successful run.\n * @param {Construct} construct\n * Construct.\n * @param {Info} info\n * Info.\n * @returns {undefined}\n * Nothing.\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/**\n * Create a tokenizer.\n * Tokenizers deal with one type of data (e.g., containers, flow, text).\n * The parser is the object dealing with it all.\n * `initialize` works like other constructs, except that only its `tokenize`\n * function is used, in which case it doesn’t receive an `ok` or `nok`.\n * `from` can be given to set the point before the first character, although\n * when further lines are indented, they must be set with `defineSkip`.\n *\n * @param {ParseContext} parser\n * Parser.\n * @param {InitialConstruct} initialize\n * Construct.\n * @param {Omit | undefined} [from]\n * Point (optional).\n * @returns {TokenizeContext}\n * Context.\n */\nexport function createTokenizer(parser, initialize, from) {\n /** @type {Point} */\n let point = {\n _bufferIndex: -1,\n _index: 0,\n line: from && from.line || 1,\n column: from && from.column || 1,\n offset: from && from.offset || 0\n };\n /** @type {Record} */\n const columnStart = {};\n /** @type {Array} */\n const resolveAllConstructs = [];\n /** @type {Array} */\n let chunks = [];\n /** @type {Array} */\n let stack = [];\n /** @type {boolean | undefined} */\n let consumed = true;\n\n /**\n * Tools used for tokenizing.\n *\n * @type {Effects}\n */\n const effects = {\n attempt: constructFactory(onsuccessfulconstruct),\n check: constructFactory(onsuccessfulcheck),\n consume,\n enter,\n exit,\n interrupt: constructFactory(onsuccessfulcheck, {\n interrupt: true\n })\n };\n\n /**\n * State and tools for resolving and serializing.\n *\n * @type {TokenizeContext}\n */\n const context = {\n code: null,\n containerState: {},\n defineSkip,\n events: [],\n now,\n parser,\n previous: null,\n sliceSerialize,\n sliceStream,\n write\n };\n\n /**\n * The state function.\n *\n * @type {State | undefined}\n */\n let state = initialize.tokenize.call(context, effects);\n\n /**\n * Track which character we expect to be consumed, to catch bugs.\n *\n * @type {Code}\n */\n let expectedCode;\n if (initialize.resolveAll) {\n resolveAllConstructs.push(initialize);\n }\n return context;\n\n /** @type {TokenizeContext['write']} */\n function write(slice) {\n chunks = push(chunks, slice);\n main();\n\n // Exit if we’re not done, resolve might change stuff.\n if (chunks[chunks.length - 1] !== null) {\n return [];\n }\n addResult(initialize, 0);\n\n // Otherwise, resolve, and exit.\n context.events = resolveAll(resolveAllConstructs, context.events, context);\n return context.events;\n }\n\n //\n // Tools.\n //\n\n /** @type {TokenizeContext['sliceSerialize']} */\n function sliceSerialize(token, expandTabs) {\n return serializeChunks(sliceStream(token), expandTabs);\n }\n\n /** @type {TokenizeContext['sliceStream']} */\n function sliceStream(token) {\n return sliceChunks(chunks, token);\n }\n\n /** @type {TokenizeContext['now']} */\n function now() {\n // This is a hot path, so we clone manually instead of `Object.assign({}, point)`\n const {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n } = point;\n return {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n };\n }\n\n /** @type {TokenizeContext['defineSkip']} */\n function defineSkip(value) {\n columnStart[value.line] = value.column;\n accountForPotentialSkip();\n }\n\n //\n // State management.\n //\n\n /**\n * Main loop (note that `_index` and `_bufferIndex` in `point` are modified by\n * `consume`).\n * Here is where we walk through the chunks, which either include strings of\n * several characters, or numerical character codes.\n * The reason to do this in a loop instead of a call is so the stack can\n * drain.\n *\n * @returns {undefined}\n * Nothing.\n */\n function main() {\n /** @type {number} */\n let chunkIndex;\n while (point._index < chunks.length) {\n const chunk = chunks[point._index];\n\n // If we’re in a buffer chunk, loop through it.\n if (typeof chunk === 'string') {\n chunkIndex = point._index;\n if (point._bufferIndex < 0) {\n point._bufferIndex = 0;\n }\n while (point._index === chunkIndex && point._bufferIndex < chunk.length) {\n go(chunk.charCodeAt(point._bufferIndex));\n }\n } else {\n go(chunk);\n }\n }\n }\n\n /**\n * Deal with one code.\n *\n * @param {Code} code\n * Code.\n * @returns {undefined}\n * Nothing.\n */\n function go(code) {\n consumed = undefined;\n expectedCode = code;\n state = state(code);\n }\n\n /** @type {Effects['consume']} */\n function consume(code) {\n if (markdownLineEnding(code)) {\n point.line++;\n point.column = 1;\n point.offset += code === -3 ? 2 : 1;\n accountForPotentialSkip();\n } else if (code !== -1) {\n point.column++;\n point.offset++;\n }\n\n // Not in a string chunk.\n if (point._bufferIndex < 0) {\n point._index++;\n } else {\n point._bufferIndex++;\n\n // At end of string chunk.\n if (point._bufferIndex ===\n // Points w/ non-negative `_bufferIndex` reference\n // strings.\n /** @type {string} */\n chunks[point._index].length) {\n point._bufferIndex = -1;\n point._index++;\n }\n }\n\n // Expose the previous character.\n context.previous = code;\n\n // Mark as consumed.\n consumed = true;\n }\n\n /** @type {Effects['enter']} */\n function enter(type, fields) {\n /** @type {Token} */\n // @ts-expect-error Patch instead of assign required fields to help GC.\n const token = fields || {};\n token.type = type;\n token.start = now();\n context.events.push(['enter', token, context]);\n stack.push(token);\n return token;\n }\n\n /** @type {Effects['exit']} */\n function exit(type) {\n const token = stack.pop();\n token.end = now();\n context.events.push(['exit', token, context]);\n return token;\n }\n\n /**\n * Use results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulconstruct(construct, info) {\n addResult(construct, info.from);\n }\n\n /**\n * Discard results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulcheck(_, info) {\n info.restore();\n }\n\n /**\n * Factory to attempt/check/interrupt.\n *\n * @param {ReturnHandle} onreturn\n * Callback.\n * @param {{interrupt?: boolean | undefined} | undefined} [fields]\n * Fields.\n */\n function constructFactory(onreturn, fields) {\n return hook;\n\n /**\n * Handle either an object mapping codes to constructs, a list of\n * constructs, or a single construct.\n *\n * @param {Array | ConstructRecord | Construct} constructs\n * Constructs.\n * @param {State} returnState\n * State.\n * @param {State | undefined} [bogusState]\n * State.\n * @returns {State}\n * State.\n */\n function hook(constructs, returnState, bogusState) {\n /** @type {ReadonlyArray} */\n let listOfConstructs;\n /** @type {number} */\n let constructIndex;\n /** @type {Construct} */\n let currentConstruct;\n /** @type {Info} */\n let info;\n return Array.isArray(constructs) ? /* c8 ignore next 1 */\n handleListOfConstructs(constructs) : 'tokenize' in constructs ?\n // Looks like a construct.\n handleListOfConstructs([(/** @type {Construct} */constructs)]) : handleMapOfConstructs(constructs);\n\n /**\n * Handle a list of construct.\n *\n * @param {ConstructRecord} map\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleMapOfConstructs(map) {\n return start;\n\n /** @type {State} */\n function start(code) {\n const left = code !== null && map[code];\n const all = code !== null && map.null;\n const list = [\n // To do: add more extension tests.\n /* c8 ignore next 2 */\n ...(Array.isArray(left) ? left : left ? [left] : []), ...(Array.isArray(all) ? all : all ? [all] : [])];\n return handleListOfConstructs(list)(code);\n }\n }\n\n /**\n * Handle a list of construct.\n *\n * @param {ReadonlyArray} list\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleListOfConstructs(list) {\n listOfConstructs = list;\n constructIndex = 0;\n if (list.length === 0) {\n return bogusState;\n }\n return handleConstruct(list[constructIndex]);\n }\n\n /**\n * Handle a single construct.\n *\n * @param {Construct} construct\n * Construct.\n * @returns {State}\n * State.\n */\n function handleConstruct(construct) {\n return start;\n\n /** @type {State} */\n function start(code) {\n // To do: not needed to store if there is no bogus state, probably?\n // Currently doesn’t work because `inspect` in document does a check\n // w/o a bogus, which doesn’t make sense. But it does seem to help perf\n // by not storing.\n info = store();\n currentConstruct = construct;\n if (!construct.partial) {\n context.currentConstruct = construct;\n }\n\n // Always populated by defaults.\n\n if (construct.name && context.parser.constructs.disable.null.includes(construct.name)) {\n return nok(code);\n }\n return construct.tokenize.call(\n // If we do have fields, create an object w/ `context` as its\n // prototype.\n // This allows a “live binding”, which is needed for `interrupt`.\n fields ? Object.assign(Object.create(context), fields) : context, effects, ok, nok)(code);\n }\n }\n\n /** @type {State} */\n function ok(code) {\n consumed = true;\n onreturn(currentConstruct, info);\n return returnState;\n }\n\n /** @type {State} */\n function nok(code) {\n consumed = true;\n info.restore();\n if (++constructIndex < listOfConstructs.length) {\n return handleConstruct(listOfConstructs[constructIndex]);\n }\n return bogusState;\n }\n }\n }\n\n /**\n * @param {Construct} construct\n * Construct.\n * @param {number} from\n * From.\n * @returns {undefined}\n * Nothing.\n */\n function addResult(construct, from) {\n if (construct.resolveAll && !resolveAllConstructs.includes(construct)) {\n resolveAllConstructs.push(construct);\n }\n if (construct.resolve) {\n splice(context.events, from, context.events.length - from, construct.resolve(context.events.slice(from), context));\n }\n if (construct.resolveTo) {\n context.events = construct.resolveTo(context.events, context);\n }\n }\n\n /**\n * Store state.\n *\n * @returns {Info}\n * Info.\n */\n function store() {\n const startPoint = now();\n const startPrevious = context.previous;\n const startCurrentConstruct = context.currentConstruct;\n const startEventsIndex = context.events.length;\n const startStack = Array.from(stack);\n return {\n from: startEventsIndex,\n restore\n };\n\n /**\n * Restore state.\n *\n * @returns {undefined}\n * Nothing.\n */\n function restore() {\n point = startPoint;\n context.previous = startPrevious;\n context.currentConstruct = startCurrentConstruct;\n context.events.length = startEventsIndex;\n stack = startStack;\n accountForPotentialSkip();\n }\n }\n\n /**\n * Move the current point a bit forward in the line when it’s on a column\n * skip.\n *\n * @returns {undefined}\n * Nothing.\n */\n function accountForPotentialSkip() {\n if (point.line in columnStart && point.column < 2) {\n point.column = columnStart[point.line];\n point.offset += columnStart[point.line] - 1;\n }\n }\n}\n\n/**\n * Get the chunks from a slice of chunks in the range of a token.\n *\n * @param {ReadonlyArray} chunks\n * Chunks.\n * @param {Pick} token\n * Token.\n * @returns {Array}\n * Chunks.\n */\nfunction sliceChunks(chunks, token) {\n const startIndex = token.start._index;\n const startBufferIndex = token.start._bufferIndex;\n const endIndex = token.end._index;\n const endBufferIndex = token.end._bufferIndex;\n /** @type {Array} */\n let view;\n if (startIndex === endIndex) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view = [chunks[startIndex].slice(startBufferIndex, endBufferIndex)];\n } else {\n view = chunks.slice(startIndex, endIndex);\n if (startBufferIndex > -1) {\n const head = view[0];\n if (typeof head === 'string') {\n view[0] = head.slice(startBufferIndex);\n /* c8 ignore next 4 -- used to be used, no longer */\n } else {\n view.shift();\n }\n }\n if (endBufferIndex > 0) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view.push(chunks[endIndex].slice(0, endBufferIndex));\n }\n }\n return view;\n}\n\n/**\n * Get the string value of a slice of chunks.\n *\n * @param {ReadonlyArray} chunks\n * Chunks.\n * @param {boolean | undefined} [expandTabs=false]\n * Whether to expand tabs (default: `false`).\n * @returns {string}\n * Result.\n */\nfunction serializeChunks(chunks, expandTabs) {\n let index = -1;\n /** @type {Array} */\n const result = [];\n /** @type {boolean | undefined} */\n let atTab;\n while (++index < chunks.length) {\n const chunk = chunks[index];\n /** @type {string} */\n let value;\n if (typeof chunk === 'string') {\n value = chunk;\n } else switch (chunk) {\n case -5:\n {\n value = \"\\r\";\n break;\n }\n case -4:\n {\n value = \"\\n\";\n break;\n }\n case -3:\n {\n value = \"\\r\" + \"\\n\";\n break;\n }\n case -2:\n {\n value = expandTabs ? \" \" : \"\\t\";\n break;\n }\n case -1:\n {\n if (!expandTabs && atTab) continue;\n value = \" \";\n break;\n }\n default:\n {\n // Currently only replacement character.\n value = String.fromCharCode(chunk);\n }\n }\n atTab = chunk === -2;\n result.push(value);\n }\n return result.join('');\n}","/**\n * @import {\n * Create,\n * FullNormalizedExtension,\n * InitialConstruct,\n * ParseContext,\n * ParseOptions\n * } from 'micromark-util-types'\n */\n\nimport { combineExtensions } from 'micromark-util-combine-extensions';\nimport { content } from './initialize/content.js';\nimport { document } from './initialize/document.js';\nimport { flow } from './initialize/flow.js';\nimport { string, text } from './initialize/text.js';\nimport * as defaultConstructs from './constructs.js';\nimport { createTokenizer } from './create-tokenizer.js';\n\n/**\n * @param {ParseOptions | null | undefined} [options]\n * Configuration (optional).\n * @returns {ParseContext}\n * Parser.\n */\nexport function parse(options) {\n const settings = options || {};\n const constructs = /** @type {FullNormalizedExtension} */\n combineExtensions([defaultConstructs, ...(settings.extensions || [])]);\n\n /** @type {ParseContext} */\n const parser = {\n constructs,\n content: create(content),\n defined: [],\n document: create(document),\n flow: create(flow),\n lazy: {},\n string: create(string),\n text: create(text)\n };\n return parser;\n\n /**\n * @param {InitialConstruct} initial\n * Construct to start with.\n * @returns {Create}\n * Create a tokenizer.\n */\n function create(initial) {\n return creator;\n /** @type {Create} */\n function creator(from) {\n return createTokenizer(parser, initial, from);\n }\n }\n}","/**\n * @import {Event} from 'micromark-util-types'\n */\n\nimport { subtokenize } from 'micromark-util-subtokenize';\n\n/**\n * @param {Array} events\n * Events.\n * @returns {Array}\n * Events.\n */\nexport function postprocess(events) {\n while (!subtokenize(events)) {\n // Empty\n }\n return events;\n}","/**\n * @import {Chunk, Code, Encoding, Value} from 'micromark-util-types'\n */\n\n/**\n * @callback Preprocessor\n * Preprocess a value.\n * @param {Value} value\n * Value.\n * @param {Encoding | null | undefined} [encoding]\n * Encoding when `value` is a typed array (optional).\n * @param {boolean | null | undefined} [end=false]\n * Whether this is the last chunk (default: `false`).\n * @returns {Array}\n * Chunks.\n */\n\nconst search = /[\\0\\t\\n\\r]/g;\n\n/**\n * @returns {Preprocessor}\n * Preprocess a value.\n */\nexport function preprocess() {\n let column = 1;\n let buffer = '';\n /** @type {boolean | undefined} */\n let start = true;\n /** @type {boolean | undefined} */\n let atCarriageReturn;\n return preprocessor;\n\n /** @type {Preprocessor} */\n // eslint-disable-next-line complexity\n function preprocessor(value, encoding, end) {\n /** @type {Array} */\n const chunks = [];\n /** @type {RegExpMatchArray | null} */\n let match;\n /** @type {number} */\n let next;\n /** @type {number} */\n let startPosition;\n /** @type {number} */\n let endPosition;\n /** @type {Code} */\n let code;\n value = buffer + (typeof value === 'string' ? value.toString() : new TextDecoder(encoding || undefined).decode(value));\n startPosition = 0;\n buffer = '';\n if (start) {\n // To do: `markdown-rs` actually parses BOMs (byte order mark).\n if (value.charCodeAt(0) === 65279) {\n startPosition++;\n }\n start = undefined;\n }\n while (startPosition < value.length) {\n search.lastIndex = startPosition;\n match = search.exec(value);\n endPosition = match && match.index !== undefined ? match.index : value.length;\n code = value.charCodeAt(endPosition);\n if (!match) {\n buffer = value.slice(startPosition);\n break;\n }\n if (code === 10 && startPosition === endPosition && atCarriageReturn) {\n chunks.push(-3);\n atCarriageReturn = undefined;\n } else {\n if (atCarriageReturn) {\n chunks.push(-5);\n atCarriageReturn = undefined;\n }\n if (startPosition < endPosition) {\n chunks.push(value.slice(startPosition, endPosition));\n column += endPosition - startPosition;\n }\n switch (code) {\n case 0:\n {\n chunks.push(65533);\n column++;\n break;\n }\n case 9:\n {\n next = Math.ceil(column / 4) * 4;\n chunks.push(-2);\n while (column++ < next) chunks.push(-1);\n break;\n }\n case 10:\n {\n chunks.push(-4);\n column = 1;\n break;\n }\n default:\n {\n atCarriageReturn = true;\n column = 1;\n }\n }\n }\n startPosition = endPosition + 1;\n }\n if (end) {\n if (atCarriageReturn) chunks.push(-5);\n if (buffer) chunks.push(buffer);\n chunks.push(null);\n }\n return chunks;\n }\n}","import { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nconst characterEscapeOrReference = /\\\\([!-/:-@[-`{-~])|&(#(?:\\d{1,7}|x[\\da-f]{1,6})|[\\da-z]{1,31});/gi;\n\n/**\n * Decode markdown strings (which occur in places such as fenced code info\n * strings, destinations, labels, and titles).\n *\n * The “string” content type allows character escapes and -references.\n * This decodes those.\n *\n * @param {string} value\n * Value to decode.\n * @returns {string}\n * Decoded value.\n */\nexport function decodeString(value) {\n return value.replace(characterEscapeOrReference, decode);\n}\n\n/**\n * @param {string} $0\n * Match.\n * @param {string} $1\n * Character escape.\n * @param {string} $2\n * Character reference.\n * @returns {string}\n * Decoded value\n */\nfunction decode($0, $1, $2) {\n if ($1) {\n // Escape.\n return $1;\n }\n\n // Reference.\n const head = $2.charCodeAt(0);\n if (head === 35) {\n const head = $2.charCodeAt(1);\n const hex = head === 120 || head === 88;\n return decodeNumericCharacterReference($2.slice(hex ? 2 : 1), hex ? 16 : 10);\n }\n return decodeNamedCharacterReference($2) || $0;\n}","/**\n * @import {\n * Break,\n * Blockquote,\n * Code,\n * Definition,\n * Emphasis,\n * Heading,\n * Html,\n * Image,\n * InlineCode,\n * Link,\n * ListItem,\n * List,\n * Nodes,\n * Paragraph,\n * PhrasingContent,\n * ReferenceType,\n * Root,\n * Strong,\n * Text,\n * ThematicBreak\n * } from 'mdast'\n * @import {\n * Encoding,\n * Event,\n * Token,\n * Value\n * } from 'micromark-util-types'\n * @import {Point} from 'unist'\n * @import {\n * CompileContext,\n * CompileData,\n * Config,\n * Extension,\n * Handle,\n * OnEnterError,\n * Options\n * } from './types.js'\n */\n\nimport { toString } from 'mdast-util-to-string';\nimport { parse, postprocess, preprocess } from 'micromark';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nimport { decodeString } from 'micromark-util-decode-string';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { stringifyPosition } from 'unist-util-stringify-position';\nconst own = {}.hasOwnProperty;\n\n/**\n * Turn markdown into a syntax tree.\n *\n * @overload\n * @param {Value} value\n * @param {Encoding | null | undefined} [encoding]\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @overload\n * @param {Value} value\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @param {Value} value\n * Markdown to parse.\n * @param {Encoding | Options | null | undefined} [encoding]\n * Character encoding for when `value` is `Buffer`.\n * @param {Options | null | undefined} [options]\n * Configuration.\n * @returns {Root}\n * mdast tree.\n */\nexport function fromMarkdown(value, encoding, options) {\n if (typeof encoding !== 'string') {\n options = encoding;\n encoding = undefined;\n }\n return compiler(options)(postprocess(parse(options).document().write(preprocess()(value, encoding, true))));\n}\n\n/**\n * Note this compiler only understand complete buffering, not streaming.\n *\n * @param {Options | null | undefined} [options]\n */\nfunction compiler(options) {\n /** @type {Config} */\n const config = {\n transforms: [],\n canContainEols: ['emphasis', 'fragment', 'heading', 'paragraph', 'strong'],\n enter: {\n autolink: opener(link),\n autolinkProtocol: onenterdata,\n autolinkEmail: onenterdata,\n atxHeading: opener(heading),\n blockQuote: opener(blockQuote),\n characterEscape: onenterdata,\n characterReference: onenterdata,\n codeFenced: opener(codeFlow),\n codeFencedFenceInfo: buffer,\n codeFencedFenceMeta: buffer,\n codeIndented: opener(codeFlow, buffer),\n codeText: opener(codeText, buffer),\n codeTextData: onenterdata,\n data: onenterdata,\n codeFlowValue: onenterdata,\n definition: opener(definition),\n definitionDestinationString: buffer,\n definitionLabelString: buffer,\n definitionTitleString: buffer,\n emphasis: opener(emphasis),\n hardBreakEscape: opener(hardBreak),\n hardBreakTrailing: opener(hardBreak),\n htmlFlow: opener(html, buffer),\n htmlFlowData: onenterdata,\n htmlText: opener(html, buffer),\n htmlTextData: onenterdata,\n image: opener(image),\n label: buffer,\n link: opener(link),\n listItem: opener(listItem),\n listItemValue: onenterlistitemvalue,\n listOrdered: opener(list, onenterlistordered),\n listUnordered: opener(list),\n paragraph: opener(paragraph),\n reference: onenterreference,\n referenceString: buffer,\n resourceDestinationString: buffer,\n resourceTitleString: buffer,\n setextHeading: opener(heading),\n strong: opener(strong),\n thematicBreak: opener(thematicBreak)\n },\n exit: {\n atxHeading: closer(),\n atxHeadingSequence: onexitatxheadingsequence,\n autolink: closer(),\n autolinkEmail: onexitautolinkemail,\n autolinkProtocol: onexitautolinkprotocol,\n blockQuote: closer(),\n characterEscapeValue: onexitdata,\n characterReferenceMarkerHexadecimal: onexitcharacterreferencemarker,\n characterReferenceMarkerNumeric: onexitcharacterreferencemarker,\n characterReferenceValue: onexitcharacterreferencevalue,\n characterReference: onexitcharacterreference,\n codeFenced: closer(onexitcodefenced),\n codeFencedFence: onexitcodefencedfence,\n codeFencedFenceInfo: onexitcodefencedfenceinfo,\n codeFencedFenceMeta: onexitcodefencedfencemeta,\n codeFlowValue: onexitdata,\n codeIndented: closer(onexitcodeindented),\n codeText: closer(onexitcodetext),\n codeTextData: onexitdata,\n data: onexitdata,\n definition: closer(),\n definitionDestinationString: onexitdefinitiondestinationstring,\n definitionLabelString: onexitdefinitionlabelstring,\n definitionTitleString: onexitdefinitiontitlestring,\n emphasis: closer(),\n hardBreakEscape: closer(onexithardbreak),\n hardBreakTrailing: closer(onexithardbreak),\n htmlFlow: closer(onexithtmlflow),\n htmlFlowData: onexitdata,\n htmlText: closer(onexithtmltext),\n htmlTextData: onexitdata,\n image: closer(onexitimage),\n label: onexitlabel,\n labelText: onexitlabeltext,\n lineEnding: onexitlineending,\n link: closer(onexitlink),\n listItem: closer(),\n listOrdered: closer(),\n listUnordered: closer(),\n paragraph: closer(),\n referenceString: onexitreferencestring,\n resourceDestinationString: onexitresourcedestinationstring,\n resourceTitleString: onexitresourcetitlestring,\n resource: onexitresource,\n setextHeading: closer(onexitsetextheading),\n setextHeadingLineSequence: onexitsetextheadinglinesequence,\n setextHeadingText: onexitsetextheadingtext,\n strong: closer(),\n thematicBreak: closer()\n }\n };\n configure(config, (options || {}).mdastExtensions || []);\n\n /** @type {CompileData} */\n const data = {};\n return compile;\n\n /**\n * Turn micromark events into an mdast tree.\n *\n * @param {Array} events\n * Events.\n * @returns {Root}\n * mdast tree.\n */\n function compile(events) {\n /** @type {Root} */\n let tree = {\n type: 'root',\n children: []\n };\n /** @type {Omit} */\n const context = {\n stack: [tree],\n tokenStack: [],\n config,\n enter,\n exit,\n buffer,\n resume,\n data\n };\n /** @type {Array} */\n const listStack = [];\n let index = -1;\n while (++index < events.length) {\n // We preprocess lists to add `listItem` tokens, and to infer whether\n // items the list itself are spread out.\n if (events[index][1].type === \"listOrdered\" || events[index][1].type === \"listUnordered\") {\n if (events[index][0] === 'enter') {\n listStack.push(index);\n } else {\n const tail = listStack.pop();\n index = prepareList(events, tail, index);\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n const handler = config[events[index][0]];\n if (own.call(handler, events[index][1].type)) {\n handler[events[index][1].type].call(Object.assign({\n sliceSerialize: events[index][2].sliceSerialize\n }, context), events[index][1]);\n }\n }\n\n // Handle tokens still being open.\n if (context.tokenStack.length > 0) {\n const tail = context.tokenStack[context.tokenStack.length - 1];\n const handler = tail[1] || defaultOnError;\n handler.call(context, undefined, tail[0]);\n }\n\n // Figure out `root` position.\n tree.position = {\n start: point(events.length > 0 ? events[0][1].start : {\n line: 1,\n column: 1,\n offset: 0\n }),\n end: point(events.length > 0 ? events[events.length - 2][1].end : {\n line: 1,\n column: 1,\n offset: 0\n })\n };\n\n // Call transforms.\n index = -1;\n while (++index < config.transforms.length) {\n tree = config.transforms[index](tree) || tree;\n }\n return tree;\n }\n\n /**\n * @param {Array} events\n * @param {number} start\n * @param {number} length\n * @returns {number}\n */\n function prepareList(events, start, length) {\n let index = start - 1;\n let containerBalance = -1;\n let listSpread = false;\n /** @type {Token | undefined} */\n let listItem;\n /** @type {number | undefined} */\n let lineIndex;\n /** @type {number | undefined} */\n let firstBlankLineIndex;\n /** @type {boolean | undefined} */\n let atMarker;\n while (++index <= length) {\n const event = events[index];\n switch (event[1].type) {\n case \"listUnordered\":\n case \"listOrdered\":\n case \"blockQuote\":\n {\n if (event[0] === 'enter') {\n containerBalance++;\n } else {\n containerBalance--;\n }\n atMarker = undefined;\n break;\n }\n case \"lineEndingBlank\":\n {\n if (event[0] === 'enter') {\n if (listItem && !atMarker && !containerBalance && !firstBlankLineIndex) {\n firstBlankLineIndex = index;\n }\n atMarker = undefined;\n }\n break;\n }\n case \"linePrefix\":\n case \"listItemValue\":\n case \"listItemMarker\":\n case \"listItemPrefix\":\n case \"listItemPrefixWhitespace\":\n {\n // Empty.\n\n break;\n }\n default:\n {\n atMarker = undefined;\n }\n }\n if (!containerBalance && event[0] === 'enter' && event[1].type === \"listItemPrefix\" || containerBalance === -1 && event[0] === 'exit' && (event[1].type === \"listUnordered\" || event[1].type === \"listOrdered\")) {\n if (listItem) {\n let tailIndex = index;\n lineIndex = undefined;\n while (tailIndex--) {\n const tailEvent = events[tailIndex];\n if (tailEvent[1].type === \"lineEnding\" || tailEvent[1].type === \"lineEndingBlank\") {\n if (tailEvent[0] === 'exit') continue;\n if (lineIndex) {\n events[lineIndex][1].type = \"lineEndingBlank\";\n listSpread = true;\n }\n tailEvent[1].type = \"lineEnding\";\n lineIndex = tailIndex;\n } else if (tailEvent[1].type === \"linePrefix\" || tailEvent[1].type === \"blockQuotePrefix\" || tailEvent[1].type === \"blockQuotePrefixWhitespace\" || tailEvent[1].type === \"blockQuoteMarker\" || tailEvent[1].type === \"listItemIndent\") {\n // Empty\n } else {\n break;\n }\n }\n if (firstBlankLineIndex && (!lineIndex || firstBlankLineIndex < lineIndex)) {\n listItem._spread = true;\n }\n\n // Fix position.\n listItem.end = Object.assign({}, lineIndex ? events[lineIndex][1].start : event[1].end);\n events.splice(lineIndex || index, 0, ['exit', listItem, event[2]]);\n index++;\n length++;\n }\n\n // Create a new list item.\n if (event[1].type === \"listItemPrefix\") {\n /** @type {Token} */\n const item = {\n type: 'listItem',\n _spread: false,\n start: Object.assign({}, event[1].start),\n // @ts-expect-error: we’ll add `end` in a second.\n end: undefined\n };\n listItem = item;\n events.splice(index, 0, ['enter', item, event[2]]);\n index++;\n length++;\n firstBlankLineIndex = undefined;\n atMarker = true;\n }\n }\n }\n events[start][1]._spread = listSpread;\n return length;\n }\n\n /**\n * Create an opener handle.\n *\n * @param {(token: Token) => Nodes} create\n * Create a node.\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function opener(create, and) {\n return open;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function open(token) {\n enter.call(this, create(token), token);\n if (and) and.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['buffer']}\n */\n function buffer() {\n this.stack.push({\n type: 'fragment',\n children: []\n });\n }\n\n /**\n * @type {CompileContext['enter']}\n */\n function enter(node, token, errorHandler) {\n const parent = this.stack[this.stack.length - 1];\n /** @type {Array} */\n const siblings = parent.children;\n siblings.push(node);\n this.stack.push(node);\n this.tokenStack.push([token, errorHandler || undefined]);\n node.position = {\n start: point(token.start),\n // @ts-expect-error: `end` will be patched later.\n end: undefined\n };\n }\n\n /**\n * Create a closer handle.\n *\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function closer(and) {\n return close;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function close(token) {\n if (and) and.call(this, token);\n exit.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['exit']}\n */\n function exit(token, onExitError) {\n const node = this.stack.pop();\n const open = this.tokenStack.pop();\n if (!open) {\n throw new Error('Cannot close `' + token.type + '` (' + stringifyPosition({\n start: token.start,\n end: token.end\n }) + '): it’s not open');\n } else if (open[0].type !== token.type) {\n if (onExitError) {\n onExitError.call(this, token, open[0]);\n } else {\n const handler = open[1] || defaultOnError;\n handler.call(this, token, open[0]);\n }\n }\n node.position.end = point(token.end);\n }\n\n /**\n * @type {CompileContext['resume']}\n */\n function resume() {\n return toString(this.stack.pop());\n }\n\n //\n // Handlers.\n //\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistordered() {\n this.data.expectingFirstListItemValue = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistitemvalue(token) {\n if (this.data.expectingFirstListItemValue) {\n const ancestor = this.stack[this.stack.length - 2];\n ancestor.start = Number.parseInt(this.sliceSerialize(token), 10);\n this.data.expectingFirstListItemValue = undefined;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfenceinfo() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.lang = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfencemeta() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.meta = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfence() {\n // Exit if this is the closing fence.\n if (this.data.flowCodeInside) return;\n this.buffer();\n this.data.flowCodeInside = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefenced() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, '');\n this.data.flowCodeInside = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodeindented() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/(\\r?\\n|\\r)$/g, '');\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitionlabelstring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.label = label;\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiontitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiondestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitatxheadingsequence(token) {\n const node = this.stack[this.stack.length - 1];\n if (!node.depth) {\n const depth = this.sliceSerialize(token).length;\n node.depth = depth;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadingtext() {\n this.data.setextHeadingSlurpLineEnding = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadinglinesequence(token) {\n const node = this.stack[this.stack.length - 1];\n node.depth = this.sliceSerialize(token).codePointAt(0) === 61 ? 1 : 2;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheading() {\n this.data.setextHeadingSlurpLineEnding = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterdata(token) {\n const node = this.stack[this.stack.length - 1];\n /** @type {Array} */\n const siblings = node.children;\n let tail = siblings[siblings.length - 1];\n if (!tail || tail.type !== 'text') {\n // Add a new text node.\n tail = text();\n tail.position = {\n start: point(token.start),\n // @ts-expect-error: we’ll add `end` later.\n end: undefined\n };\n siblings.push(tail);\n }\n this.stack.push(tail);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitdata(token) {\n const tail = this.stack.pop();\n tail.value += this.sliceSerialize(token);\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlineending(token) {\n const context = this.stack[this.stack.length - 1];\n // If we’re at a hard break, include the line ending in there.\n if (this.data.atHardBreak) {\n const tail = context.children[context.children.length - 1];\n tail.position.end = point(token.end);\n this.data.atHardBreak = undefined;\n return;\n }\n if (!this.data.setextHeadingSlurpLineEnding && config.canContainEols.includes(context.type)) {\n onenterdata.call(this, token);\n onexitdata.call(this, token);\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithardbreak() {\n this.data.atHardBreak = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmlflow() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmltext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcodetext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlink() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitimage() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabeltext(token) {\n const string = this.sliceSerialize(token);\n const ancestor = this.stack[this.stack.length - 2];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n ancestor.label = decodeString(string);\n // @ts-expect-error: same as above.\n ancestor.identifier = normalizeIdentifier(string).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabel() {\n const fragment = this.stack[this.stack.length - 1];\n const value = this.resume();\n const node = this.stack[this.stack.length - 1];\n // Assume a reference.\n this.data.inReference = true;\n if (node.type === 'link') {\n /** @type {Array} */\n const children = fragment.children;\n node.children = children;\n } else {\n node.alt = value;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcedestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcetitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresource() {\n this.data.inReference = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterreference() {\n this.data.referenceType = 'collapsed';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitreferencestring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n node.label = label;\n // @ts-expect-error: same as above.\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n this.data.referenceType = 'full';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcharacterreferencemarker(token) {\n this.data.characterReferenceType = token.type;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreferencevalue(token) {\n const data = this.sliceSerialize(token);\n const type = this.data.characterReferenceType;\n /** @type {string} */\n let value;\n if (type) {\n value = decodeNumericCharacterReference(data, type === \"characterReferenceMarkerNumeric\" ? 10 : 16);\n this.data.characterReferenceType = undefined;\n } else {\n const result = decodeNamedCharacterReference(data);\n value = result;\n }\n const tail = this.stack[this.stack.length - 1];\n tail.value += value;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreference(token) {\n const tail = this.stack.pop();\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkprotocol(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = this.sliceSerialize(token);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkemail(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = 'mailto:' + this.sliceSerialize(token);\n }\n\n //\n // Creaters.\n //\n\n /** @returns {Blockquote} */\n function blockQuote() {\n return {\n type: 'blockquote',\n children: []\n };\n }\n\n /** @returns {Code} */\n function codeFlow() {\n return {\n type: 'code',\n lang: null,\n meta: null,\n value: ''\n };\n }\n\n /** @returns {InlineCode} */\n function codeText() {\n return {\n type: 'inlineCode',\n value: ''\n };\n }\n\n /** @returns {Definition} */\n function definition() {\n return {\n type: 'definition',\n identifier: '',\n label: null,\n title: null,\n url: ''\n };\n }\n\n /** @returns {Emphasis} */\n function emphasis() {\n return {\n type: 'emphasis',\n children: []\n };\n }\n\n /** @returns {Heading} */\n function heading() {\n return {\n type: 'heading',\n // @ts-expect-error `depth` will be set later.\n depth: 0,\n children: []\n };\n }\n\n /** @returns {Break} */\n function hardBreak() {\n return {\n type: 'break'\n };\n }\n\n /** @returns {Html} */\n function html() {\n return {\n type: 'html',\n value: ''\n };\n }\n\n /** @returns {Image} */\n function image() {\n return {\n type: 'image',\n title: null,\n url: '',\n alt: null\n };\n }\n\n /** @returns {Link} */\n function link() {\n return {\n type: 'link',\n title: null,\n url: '',\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {List}\n */\n function list(token) {\n return {\n type: 'list',\n ordered: token.type === 'listOrdered',\n start: null,\n spread: token._spread,\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {ListItem}\n */\n function listItem(token) {\n return {\n type: 'listItem',\n spread: token._spread,\n checked: null,\n children: []\n };\n }\n\n /** @returns {Paragraph} */\n function paragraph() {\n return {\n type: 'paragraph',\n children: []\n };\n }\n\n /** @returns {Strong} */\n function strong() {\n return {\n type: 'strong',\n children: []\n };\n }\n\n /** @returns {Text} */\n function text() {\n return {\n type: 'text',\n value: ''\n };\n }\n\n /** @returns {ThematicBreak} */\n function thematicBreak() {\n return {\n type: 'thematicBreak'\n };\n }\n}\n\n/**\n * Copy a point-like value.\n *\n * @param {Point} d\n * Point-like value.\n * @returns {Point}\n * unist point.\n */\nfunction point(d) {\n return {\n line: d.line,\n column: d.column,\n offset: d.offset\n };\n}\n\n/**\n * @param {Config} combined\n * @param {Array | Extension>} extensions\n * @returns {undefined}\n */\nfunction configure(combined, extensions) {\n let index = -1;\n while (++index < extensions.length) {\n const value = extensions[index];\n if (Array.isArray(value)) {\n configure(combined, value);\n } else {\n extension(combined, value);\n }\n }\n}\n\n/**\n * @param {Config} combined\n * @param {Extension} extension\n * @returns {undefined}\n */\nfunction extension(combined, extension) {\n /** @type {keyof Extension} */\n let key;\n for (key in extension) {\n if (own.call(extension, key)) {\n switch (key) {\n case 'canContainEols':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'transforms':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'enter':\n case 'exit':\n {\n const right = extension[key];\n if (right) {\n Object.assign(combined[key], right);\n }\n break;\n }\n // No default\n }\n }\n }\n}\n\n/** @type {OnEnterError} */\nfunction defaultOnError(left, right) {\n if (left) {\n throw new Error('Cannot close `' + left.type + '` (' + stringifyPosition({\n start: left.start,\n end: left.end\n }) + '): a different token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is open');\n } else {\n throw new Error('Cannot close document, a token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is still open');\n }\n}","/**\n * @typedef {import('mdast').Root} Root\n * @typedef {import('mdast-util-from-markdown').Options} FromMarkdownOptions\n * @typedef {import('unified').Parser} Parser\n * @typedef {import('unified').Processor} Processor\n */\n\n/**\n * @typedef {Omit} Options\n */\n\nimport {fromMarkdown} from 'mdast-util-from-markdown'\n\n/**\n * Aadd support for parsing from markdown.\n *\n * @param {Readonly | null | undefined} [options]\n * Configuration (optional).\n * @returns {undefined}\n * Nothing.\n */\nexport default function remarkParse(options) {\n /** @type {Processor} */\n // @ts-expect-error: TS in JSDoc generates wrong types if `this` is typed regularly.\n const self = this\n\n self.parser = parser\n\n /**\n * @type {Parser}\n */\n function parser(doc) {\n return fromMarkdown(doc, {\n ...self.data('settings'),\n ...options,\n // Note: these options are not in the readme.\n // The goal is for them to be set by plugins on `data` instead of being\n // passed by users.\n extensions: self.data('micromarkExtensions') || [],\n mdastExtensions: self.data('fromMarkdownExtensions') || []\n })\n }\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Blockquote} Blockquote\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `blockquote` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Blockquote} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function blockquote(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'blockquote',\n properties: {},\n children: state.wrap(state.all(node), true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Text} Text\n * @typedef {import('mdast').Break} Break\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `break` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Break} node\n * mdast node.\n * @returns {Array}\n * hast element content.\n */\nexport function hardBreak(state, node) {\n /** @type {Element} */\n const result = {type: 'element', tagName: 'br', properties: {}, children: []}\n state.patch(node, result)\n return [state.applyData(node, result), {type: 'text', value: '\\n'}]\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Code} Code\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `code` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Code} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function code(state, node) {\n const value = node.value ? node.value + '\\n' : ''\n /** @type {Properties} */\n const properties = {}\n\n if (node.lang) {\n properties.className = ['language-' + node.lang]\n }\n\n // Create ``.\n /** @type {Element} */\n let result = {\n type: 'element',\n tagName: 'code',\n properties,\n children: [{type: 'text', value}]\n }\n\n if (node.meta) {\n result.data = {meta: node.meta}\n }\n\n state.patch(node, result)\n result = state.applyData(node, result)\n\n // Create `
`.\n  result = {type: 'element', tagName: 'pre', properties: {}, children: [result]}\n  state.patch(node, result)\n  return result\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Delete} Delete\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `delete` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Delete} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function strikethrough(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'del',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Emphasis} Emphasis\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `emphasis` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Emphasis} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function emphasis(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'em',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').FootnoteReference} FootnoteReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `footnoteReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {FootnoteReference} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function footnoteReference(state, node) {\n  const clobberPrefix =\n    typeof state.options.clobberPrefix === 'string'\n      ? state.options.clobberPrefix\n      : 'user-content-'\n  const id = String(node.identifier).toUpperCase()\n  const safeId = normalizeUri(id.toLowerCase())\n  const index = state.footnoteOrder.indexOf(id)\n  /** @type {number} */\n  let counter\n\n  let reuseCounter = state.footnoteCounts.get(id)\n\n  if (reuseCounter === undefined) {\n    reuseCounter = 0\n    state.footnoteOrder.push(id)\n    counter = state.footnoteOrder.length\n  } else {\n    counter = index + 1\n  }\n\n  reuseCounter += 1\n  state.footnoteCounts.set(id, reuseCounter)\n\n  /** @type {Element} */\n  const link = {\n    type: 'element',\n    tagName: 'a',\n    properties: {\n      href: '#' + clobberPrefix + 'fn-' + safeId,\n      id:\n        clobberPrefix +\n        'fnref-' +\n        safeId +\n        (reuseCounter > 1 ? '-' + reuseCounter : ''),\n      dataFootnoteRef: true,\n      ariaDescribedBy: ['footnote-label']\n    },\n    children: [{type: 'text', value: String(counter)}]\n  }\n  state.patch(node, link)\n\n  /** @type {Element} */\n  const sup = {\n    type: 'element',\n    tagName: 'sup',\n    properties: {},\n    children: [link]\n  }\n  state.patch(node, sup)\n  return state.applyData(node, sup)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Heading} Heading\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `heading` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Heading} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function heading(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'h' + node.depth,\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Html} Html\n * @typedef {import('../state.js').State} State\n * @typedef {import('../../index.js').Raw} Raw\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `html` node into hast (`raw` node in dangerous mode, otherwise\n * nothing).\n *\n * @param {State} state\n *   Info passed around.\n * @param {Html} node\n *   mdast node.\n * @returns {Element | Raw | undefined}\n *   hast node.\n */\nexport function html(state, node) {\n  if (state.options.allowDangerousHtml) {\n    /** @type {Raw} */\n    const result = {type: 'raw', value: node.value}\n    state.patch(node, result)\n    return state.applyData(node, result)\n  }\n\n  return undefined\n}\n","/**\n * @typedef {import('hast').ElementContent} ElementContent\n *\n * @typedef {import('mdast').Nodes} Nodes\n * @typedef {import('mdast').Reference} Reference\n *\n * @typedef {import('./state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Return the content of a reference without definition as plain text.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Extract} node\n *   Reference node (image, link).\n * @returns {Array}\n *   hast content.\n */\nexport function revert(state, node) {\n  const subtype = node.referenceType\n  let suffix = ']'\n\n  if (subtype === 'collapsed') {\n    suffix += '[]'\n  } else if (subtype === 'full') {\n    suffix += '[' + (node.label || node.identifier) + ']'\n  }\n\n  if (node.type === 'imageReference') {\n    return [{type: 'text', value: '![' + node.alt + suffix}]\n  }\n\n  const contents = state.all(node)\n  const head = contents[0]\n\n  if (head && head.type === 'text') {\n    head.value = '[' + head.value\n  } else {\n    contents.unshift({type: 'text', value: '['})\n  }\n\n  const tail = contents[contents.length - 1]\n\n  if (tail && tail.type === 'text') {\n    tail.value += suffix\n  } else {\n    contents.push({type: 'text', value: suffix})\n  }\n\n  return contents\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').ImageReference} ImageReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `imageReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ImageReference} node\n *   mdast node.\n * @returns {Array | ElementContent}\n *   hast node.\n */\nexport function imageReference(state, node) {\n  const id = String(node.identifier).toUpperCase()\n  const definition = state.definitionById.get(id)\n\n  if (!definition) {\n    return revert(state, node)\n  }\n\n  /** @type {Properties} */\n  const properties = {src: normalizeUri(definition.url || ''), alt: node.alt}\n\n  if (definition.title !== null && definition.title !== undefined) {\n    properties.title = definition.title\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'img', properties, children: []}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Image} Image\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `image` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Image} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function image(state, node) {\n  /** @type {Properties} */\n  const properties = {src: normalizeUri(node.url)}\n\n  if (node.alt !== null && node.alt !== undefined) {\n    properties.alt = node.alt\n  }\n\n  if (node.title !== null && node.title !== undefined) {\n    properties.title = node.title\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'img', properties, children: []}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Text} Text\n * @typedef {import('mdast').InlineCode} InlineCode\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `inlineCode` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {InlineCode} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function inlineCode(state, node) {\n  /** @type {Text} */\n  const text = {type: 'text', value: node.value.replace(/\\r?\\n|\\r/g, ' ')}\n  state.patch(node, text)\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'code',\n    properties: {},\n    children: [text]\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').LinkReference} LinkReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `linkReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {LinkReference} node\n *   mdast node.\n * @returns {Array | ElementContent}\n *   hast node.\n */\nexport function linkReference(state, node) {\n  const id = String(node.identifier).toUpperCase()\n  const definition = state.definitionById.get(id)\n\n  if (!definition) {\n    return revert(state, node)\n  }\n\n  /** @type {Properties} */\n  const properties = {href: normalizeUri(definition.url || '')}\n\n  if (definition.title !== null && definition.title !== undefined) {\n    properties.title = definition.title\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'a',\n    properties,\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Link} Link\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `link` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Link} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function link(state, node) {\n  /** @type {Properties} */\n  const properties = {href: normalizeUri(node.url)}\n\n  if (node.title !== null && node.title !== undefined) {\n    properties.title = node.title\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'a',\n    properties,\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').ListItem} ListItem\n * @typedef {import('mdast').Parents} Parents\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `listItem` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ListItem} node\n *   mdast node.\n * @param {Parents | undefined} parent\n *   Parent of `node`.\n * @returns {Element}\n *   hast node.\n */\nexport function listItem(state, node, parent) {\n  const results = state.all(node)\n  const loose = parent ? listLoose(parent) : listItemLoose(node)\n  /** @type {Properties} */\n  const properties = {}\n  /** @type {Array} */\n  const children = []\n\n  if (typeof node.checked === 'boolean') {\n    const head = results[0]\n    /** @type {Element} */\n    let paragraph\n\n    if (head && head.type === 'element' && head.tagName === 'p') {\n      paragraph = head\n    } else {\n      paragraph = {type: 'element', tagName: 'p', properties: {}, children: []}\n      results.unshift(paragraph)\n    }\n\n    if (paragraph.children.length > 0) {\n      paragraph.children.unshift({type: 'text', value: ' '})\n    }\n\n    paragraph.children.unshift({\n      type: 'element',\n      tagName: 'input',\n      properties: {type: 'checkbox', checked: node.checked, disabled: true},\n      children: []\n    })\n\n    // According to github-markdown-css, this class hides bullet.\n    // See: .\n    properties.className = ['task-list-item']\n  }\n\n  let index = -1\n\n  while (++index < results.length) {\n    const child = results[index]\n\n    // Add eols before nodes, except if this is a loose, first paragraph.\n    if (\n      loose ||\n      index !== 0 ||\n      child.type !== 'element' ||\n      child.tagName !== 'p'\n    ) {\n      children.push({type: 'text', value: '\\n'})\n    }\n\n    if (child.type === 'element' && child.tagName === 'p' && !loose) {\n      children.push(...child.children)\n    } else {\n      children.push(child)\n    }\n  }\n\n  const tail = results[results.length - 1]\n\n  // Add a final eol.\n  if (tail && (loose || tail.type !== 'element' || tail.tagName !== 'p')) {\n    children.push({type: 'text', value: '\\n'})\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'li', properties, children}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n\n/**\n * @param {Parents} node\n * @return {Boolean}\n */\nfunction listLoose(node) {\n  let loose = false\n  if (node.type === 'list') {\n    loose = node.spread || false\n    const children = node.children\n    let index = -1\n\n    while (!loose && ++index < children.length) {\n      loose = listItemLoose(children[index])\n    }\n  }\n\n  return loose\n}\n\n/**\n * @param {ListItem} node\n * @return {Boolean}\n */\nfunction listItemLoose(node) {\n  const spread = node.spread\n\n  return spread === null || spread === undefined\n    ? node.children.length > 1\n    : spread\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').List} List\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `list` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {List} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function list(state, node) {\n  /** @type {Properties} */\n  const properties = {}\n  const results = state.all(node)\n  let index = -1\n\n  if (typeof node.start === 'number' && node.start !== 1) {\n    properties.start = node.start\n  }\n\n  // Like GitHub, add a class for custom styling.\n  while (++index < results.length) {\n    const child = results[index]\n\n    if (\n      child.type === 'element' &&\n      child.tagName === 'li' &&\n      child.properties &&\n      Array.isArray(child.properties.className) &&\n      child.properties.className.includes('task-list-item')\n    ) {\n      properties.className = ['contains-task-list']\n      break\n    }\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: node.ordered ? 'ol' : 'ul',\n    properties,\n    children: state.wrap(results, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Paragraph} Paragraph\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `paragraph` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Paragraph} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function paragraph(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'p',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Parents} HastParents\n * @typedef {import('hast').Root} HastRoot\n * @typedef {import('mdast').Root} MdastRoot\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `root` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {MdastRoot} node\n *   mdast node.\n * @returns {HastParents}\n *   hast node.\n */\nexport function root(state, node) {\n  /** @type {HastRoot} */\n  const result = {type: 'root', children: state.wrap(state.all(node))}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Strong} Strong\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `strong` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Strong} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function strong(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'strong',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Table} Table\n * @typedef {import('../state.js').State} State\n */\n\nimport {pointEnd, pointStart} from 'unist-util-position'\n\n/**\n * Turn an mdast `table` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Table} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function table(state, node) {\n  const rows = state.all(node)\n  const firstRow = rows.shift()\n  /** @type {Array} */\n  const tableContent = []\n\n  if (firstRow) {\n    /** @type {Element} */\n    const head = {\n      type: 'element',\n      tagName: 'thead',\n      properties: {},\n      children: state.wrap([firstRow], true)\n    }\n    state.patch(node.children[0], head)\n    tableContent.push(head)\n  }\n\n  if (rows.length > 0) {\n    /** @type {Element} */\n    const body = {\n      type: 'element',\n      tagName: 'tbody',\n      properties: {},\n      children: state.wrap(rows, true)\n    }\n\n    const start = pointStart(node.children[1])\n    const end = pointEnd(node.children[node.children.length - 1])\n    if (start && end) body.position = {start, end}\n    tableContent.push(body)\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'table',\n    properties: {},\n    children: state.wrap(tableContent, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Parents} Parents\n * @typedef {import('mdast').TableRow} TableRow\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `tableRow` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {TableRow} node\n *   mdast node.\n * @param {Parents | undefined} parent\n *   Parent of `node`.\n * @returns {Element}\n *   hast node.\n */\nexport function tableRow(state, node, parent) {\n  const siblings = parent ? parent.children : undefined\n  // Generate a body row when without parent.\n  const rowIndex = siblings ? siblings.indexOf(node) : 1\n  const tagName = rowIndex === 0 ? 'th' : 'td'\n  // To do: option to use `style`?\n  const align = parent && parent.type === 'table' ? parent.align : undefined\n  const length = align ? align.length : node.children.length\n  let cellIndex = -1\n  /** @type {Array} */\n  const cells = []\n\n  while (++cellIndex < length) {\n    // Note: can also be undefined.\n    const cell = node.children[cellIndex]\n    /** @type {Properties} */\n    const properties = {}\n    const alignValue = align ? align[cellIndex] : undefined\n\n    if (alignValue) {\n      properties.align = alignValue\n    }\n\n    /** @type {Element} */\n    let result = {type: 'element', tagName, properties, children: []}\n\n    if (cell) {\n      result.children = state.all(cell)\n      state.patch(cell, result)\n      result = state.applyData(cell, result)\n    }\n\n    cells.push(result)\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'tr',\n    properties: {},\n    children: state.wrap(cells, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').TableCell} TableCell\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `tableCell` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {TableCell} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function tableCell(state, node) {\n  // Note: this function is normally not called: see `table-row` for how rows\n  // and their cells are compiled.\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'td', // Assume body cell.\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","const tab = 9 /* `\\t` */\nconst space = 32 /* ` ` */\n\n/**\n * Remove initial and final spaces and tabs at the line breaks in `value`.\n * Does not trim initial and final spaces and tabs of the value itself.\n *\n * @param {string} value\n *   Value to trim.\n * @returns {string}\n *   Trimmed value.\n */\nexport function trimLines(value) {\n  const source = String(value)\n  const search = /\\r?\\n|\\r/g\n  let match = search.exec(source)\n  let last = 0\n  /** @type {Array} */\n  const lines = []\n\n  while (match) {\n    lines.push(\n      trimLine(source.slice(last, match.index), last > 0, true),\n      match[0]\n    )\n\n    last = match.index + match[0].length\n    match = search.exec(source)\n  }\n\n  lines.push(trimLine(source.slice(last), last > 0, false))\n\n  return lines.join('')\n}\n\n/**\n * @param {string} value\n *   Line to trim.\n * @param {boolean} start\n *   Whether to trim the start of the line.\n * @param {boolean} end\n *   Whether to trim the end of the line.\n * @returns {string}\n *   Trimmed line.\n */\nfunction trimLine(value, start, end) {\n  let startIndex = 0\n  let endIndex = value.length\n\n  if (start) {\n    let code = value.codePointAt(startIndex)\n\n    while (code === tab || code === space) {\n      startIndex++\n      code = value.codePointAt(startIndex)\n    }\n  }\n\n  if (end) {\n    let code = value.codePointAt(endIndex - 1)\n\n    while (code === tab || code === space) {\n      endIndex--\n      code = value.codePointAt(endIndex - 1)\n    }\n  }\n\n  return endIndex > startIndex ? value.slice(startIndex, endIndex) : ''\n}\n","/**\n * @typedef {import('hast').Element} HastElement\n * @typedef {import('hast').Text} HastText\n * @typedef {import('mdast').Text} MdastText\n * @typedef {import('../state.js').State} State\n */\n\nimport {trimLines} from 'trim-lines'\n\n/**\n * Turn an mdast `text` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {MdastText} node\n *   mdast node.\n * @returns {HastElement | HastText}\n *   hast node.\n */\nexport function text(state, node) {\n  /** @type {HastText} */\n  const result = {type: 'text', value: trimLines(String(node.value))}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').ThematicBreak} ThematicBreak\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `thematicBreak` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ThematicBreak} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function thematicBreak(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'hr',\n    properties: {},\n    children: []\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","import {blockquote} from './blockquote.js'\nimport {hardBreak} from './break.js'\nimport {code} from './code.js'\nimport {strikethrough} from './delete.js'\nimport {emphasis} from './emphasis.js'\nimport {footnoteReference} from './footnote-reference.js'\nimport {heading} from './heading.js'\nimport {html} from './html.js'\nimport {imageReference} from './image-reference.js'\nimport {image} from './image.js'\nimport {inlineCode} from './inline-code.js'\nimport {linkReference} from './link-reference.js'\nimport {link} from './link.js'\nimport {listItem} from './list-item.js'\nimport {list} from './list.js'\nimport {paragraph} from './paragraph.js'\nimport {root} from './root.js'\nimport {strong} from './strong.js'\nimport {table} from './table.js'\nimport {tableRow} from './table-row.js'\nimport {tableCell} from './table-cell.js'\nimport {text} from './text.js'\nimport {thematicBreak} from './thematic-break.js'\n\n/**\n * Default handlers for nodes.\n *\n * @satisfies {import('../state.js').Handlers}\n */\nexport const handlers = {\n  blockquote,\n  break: hardBreak,\n  code,\n  delete: strikethrough,\n  emphasis,\n  footnoteReference,\n  heading,\n  html,\n  imageReference,\n  image,\n  inlineCode,\n  linkReference,\n  link,\n  listItem,\n  list,\n  paragraph,\n  // @ts-expect-error: root is different, but hard to type.\n  root,\n  strong,\n  table,\n  tableCell,\n  tableRow,\n  text,\n  thematicBreak,\n  toml: ignore,\n  yaml: ignore,\n  definition: ignore,\n  footnoteDefinition: ignore\n}\n\n// Return nothing for nodes that are ignored.\nfunction ignore() {\n  return undefined\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n *\n * @typedef {import('./state.js').State} State\n */\n\n/**\n * @callback FootnoteBackContentTemplate\n *   Generate content for the backreference dynamically.\n *\n *   For the following markdown:\n *\n *   ```markdown\n *   Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n *   [^remark]: things about remark\n *   [^micromark]: things about micromark\n *   ```\n *\n *   This function will be called with:\n *\n *   *  `0` and `0` for the backreference from `things about micromark` to\n *      `alpha`, as it is the first used definition, and the first call to it\n *   *  `0` and `1` for the backreference from `things about micromark` to\n *      `bravo`, as it is the first used definition, and the second call to it\n *   *  `1` and `0` for the backreference from `things about remark` to\n *      `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {Array | ElementContent | string}\n *   Content for the backreference when linking back from definitions to their\n *   reference.\n *\n * @callback FootnoteBackLabelTemplate\n *   Generate a back label dynamically.\n *\n *   For the following markdown:\n *\n *   ```markdown\n *   Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n *   [^remark]: things about remark\n *   [^micromark]: things about micromark\n *   ```\n *\n *   This function will be called with:\n *\n *   *  `0` and `0` for the backreference from `things about micromark` to\n *      `alpha`, as it is the first used definition, and the first call to it\n *   *  `0` and `1` for the backreference from `things about micromark` to\n *      `bravo`, as it is the first used definition, and the second call to it\n *   *  `1` and `0` for the backreference from `things about remark` to\n *      `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {string}\n *   Back label to use when linking back from definitions to their reference.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Generate the default content that GitHub uses on backreferences.\n *\n * @param {number} _\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {Array}\n *   Content.\n */\nexport function defaultFootnoteBackContent(_, rereferenceIndex) {\n  /** @type {Array} */\n  const result = [{type: 'text', value: '↩'}]\n\n  if (rereferenceIndex > 1) {\n    result.push({\n      type: 'element',\n      tagName: 'sup',\n      properties: {},\n      children: [{type: 'text', value: String(rereferenceIndex)}]\n    })\n  }\n\n  return result\n}\n\n/**\n * Generate the default label that GitHub uses on backreferences.\n *\n * @param {number} referenceIndex\n *   Index of the definition in the order that they are first referenced,\n *   0-indexed.\n * @param {number} rereferenceIndex\n *   Index of calls to the same definition, 0-indexed.\n * @returns {string}\n *   Label.\n */\nexport function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n  return (\n    'Back to reference ' +\n    (referenceIndex + 1) +\n    (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n  )\n}\n\n/**\n * Generate a hast footer for called footnote definitions.\n *\n * @param {State} state\n *   Info passed around.\n * @returns {Element | undefined}\n *   `section` element or `undefined`.\n */\n// eslint-disable-next-line complexity\nexport function footer(state) {\n  const clobberPrefix =\n    typeof state.options.clobberPrefix === 'string'\n      ? state.options.clobberPrefix\n      : 'user-content-'\n  const footnoteBackContent =\n    state.options.footnoteBackContent || defaultFootnoteBackContent\n  const footnoteBackLabel =\n    state.options.footnoteBackLabel || defaultFootnoteBackLabel\n  const footnoteLabel = state.options.footnoteLabel || 'Footnotes'\n  const footnoteLabelTagName = state.options.footnoteLabelTagName || 'h2'\n  const footnoteLabelProperties = state.options.footnoteLabelProperties || {\n    className: ['sr-only']\n  }\n  /** @type {Array} */\n  const listItems = []\n  let referenceIndex = -1\n\n  while (++referenceIndex < state.footnoteOrder.length) {\n    const definition = state.footnoteById.get(\n      state.footnoteOrder[referenceIndex]\n    )\n\n    if (!definition) {\n      continue\n    }\n\n    const content = state.all(definition)\n    const id = String(definition.identifier).toUpperCase()\n    const safeId = normalizeUri(id.toLowerCase())\n    let rereferenceIndex = 0\n    /** @type {Array} */\n    const backReferences = []\n    const counts = state.footnoteCounts.get(id)\n\n    // eslint-disable-next-line no-unmodified-loop-condition\n    while (counts !== undefined && ++rereferenceIndex <= counts) {\n      if (backReferences.length > 0) {\n        backReferences.push({type: 'text', value: ' '})\n      }\n\n      let children =\n        typeof footnoteBackContent === 'string'\n          ? footnoteBackContent\n          : footnoteBackContent(referenceIndex, rereferenceIndex)\n\n      if (typeof children === 'string') {\n        children = {type: 'text', value: children}\n      }\n\n      backReferences.push({\n        type: 'element',\n        tagName: 'a',\n        properties: {\n          href:\n            '#' +\n            clobberPrefix +\n            'fnref-' +\n            safeId +\n            (rereferenceIndex > 1 ? '-' + rereferenceIndex : ''),\n          dataFootnoteBackref: '',\n          ariaLabel:\n            typeof footnoteBackLabel === 'string'\n              ? footnoteBackLabel\n              : footnoteBackLabel(referenceIndex, rereferenceIndex),\n          className: ['data-footnote-backref']\n        },\n        children: Array.isArray(children) ? children : [children]\n      })\n    }\n\n    const tail = content[content.length - 1]\n\n    if (tail && tail.type === 'element' && tail.tagName === 'p') {\n      const tailTail = tail.children[tail.children.length - 1]\n      if (tailTail && tailTail.type === 'text') {\n        tailTail.value += ' '\n      } else {\n        tail.children.push({type: 'text', value: ' '})\n      }\n\n      tail.children.push(...backReferences)\n    } else {\n      content.push(...backReferences)\n    }\n\n    /** @type {Element} */\n    const listItem = {\n      type: 'element',\n      tagName: 'li',\n      properties: {id: clobberPrefix + 'fn-' + safeId},\n      children: state.wrap(content, true)\n    }\n\n    state.patch(definition, listItem)\n\n    listItems.push(listItem)\n  }\n\n  if (listItems.length === 0) {\n    return\n  }\n\n  return {\n    type: 'element',\n    tagName: 'section',\n    properties: {dataFootnotes: true, className: ['footnotes']},\n    children: [\n      {\n        type: 'element',\n        tagName: footnoteLabelTagName,\n        properties: {\n          ...structuredClone(footnoteLabelProperties),\n          id: 'footnote-label'\n        },\n        children: [{type: 'text', value: footnoteLabel}]\n      },\n      {type: 'text', value: '\\n'},\n      {\n        type: 'element',\n        tagName: 'ol',\n        properties: {},\n        children: state.wrap(listItems, true)\n      },\n      {type: 'text', value: '\\n'}\n    ]\n  }\n}\n","/**\n * @typedef {import('hast').Element} HastElement\n * @typedef {import('hast').ElementContent} HastElementContent\n * @typedef {import('hast').Nodes} HastNodes\n * @typedef {import('hast').Properties} HastProperties\n * @typedef {import('hast').RootContent} HastRootContent\n * @typedef {import('hast').Text} HastText\n *\n * @typedef {import('mdast').Definition} MdastDefinition\n * @typedef {import('mdast').FootnoteDefinition} MdastFootnoteDefinition\n * @typedef {import('mdast').Nodes} MdastNodes\n * @typedef {import('mdast').Parents} MdastParents\n *\n * @typedef {import('vfile').VFile} VFile\n *\n * @typedef {import('./footer.js').FootnoteBackContentTemplate} FootnoteBackContentTemplate\n * @typedef {import('./footer.js').FootnoteBackLabelTemplate} FootnoteBackLabelTemplate\n */\n\n/**\n * @callback Handler\n *   Handle a node.\n * @param {State} state\n *   Info passed around.\n * @param {any} node\n *   mdast node to handle.\n * @param {MdastParents | undefined} parent\n *   Parent of `node`.\n * @returns {Array | HastElementContent | undefined}\n *   hast node.\n *\n * @typedef {Partial>} Handlers\n *   Handle nodes.\n *\n * @typedef Options\n *   Configuration (optional).\n * @property {boolean | null | undefined} [allowDangerousHtml=false]\n *   Whether to persist raw HTML in markdown in the hast tree (default:\n *   `false`).\n * @property {string | null | undefined} [clobberPrefix='user-content-']\n *   Prefix to use before the `id` property on footnotes to prevent them from\n *   *clobbering* (default: `'user-content-'`).\n *\n *   Pass `''` for trusted markdown and when you are careful with\n *   polyfilling.\n *   You could pass a different prefix.\n *\n *   DOM clobbering is this:\n *\n *   ```html\n *   

\n * \n * ```\n *\n * The above example shows that elements are made available by browsers, by\n * their ID, on the `window` object.\n * This is a security risk because you might be expecting some other variable\n * at that place.\n * It can also break polyfills.\n * Using a prefix solves these problems.\n * @property {VFile | null | undefined} [file]\n * Corresponding virtual file representing the input document (optional).\n * @property {FootnoteBackContentTemplate | string | null | undefined} [footnoteBackContent]\n * Content of the backreference back to references (default: `defaultFootnoteBackContent`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackContent(_, rereferenceIndex) {\n * const result = [{type: 'text', value: '↩'}]\n *\n * if (rereferenceIndex > 1) {\n * result.push({\n * type: 'element',\n * tagName: 'sup',\n * properties: {},\n * children: [{type: 'text', value: String(rereferenceIndex)}]\n * })\n * }\n *\n * return result\n * }\n * ```\n *\n * This content is used in the `a` element of each backreference (the `↩`\n * links).\n * @property {FootnoteBackLabelTemplate | string | null | undefined} [footnoteBackLabel]\n * Label to describe the backreference back to references (default:\n * `defaultFootnoteBackLabel`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n * return (\n * 'Back to reference ' +\n * (referenceIndex + 1) +\n * (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n * )\n * }\n * ```\n *\n * Change it when the markdown is not in English.\n *\n * This label is used in the `ariaLabel` property on each backreference\n * (the `↩` links).\n * It affects users of assistive technology.\n * @property {string | null | undefined} [footnoteLabel='Footnotes']\n * Textual label to use for the footnotes section (default: `'Footnotes'`).\n *\n * Change it when the markdown is not in English.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {HastProperties | null | undefined} [footnoteLabelProperties={className: ['sr-only']}]\n * Properties to use on the footnote label (default: `{className:\n * ['sr-only']}`).\n *\n * Change it to show the label and add other properties.\n *\n * This label is typically hidden visually (assuming an `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass an empty string.\n * You can also add different properties.\n *\n * > **Note**: `id: 'footnote-label'` is always added, because footnote\n * > calls use it with `aria-describedby` to provide an accessible label.\n * @property {string | null | undefined} [footnoteLabelTagName='h2']\n * HTML tag name to use for the footnote label element (default: `'h2'`).\n *\n * Change it to match your document structure.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {Handlers | null | undefined} [handlers]\n * Extra handlers for nodes (optional).\n * @property {Array | null | undefined} [passThrough]\n * List of custom mdast node types to pass through (keep) in hast (note that\n * the node itself is passed, but eventual children are transformed)\n * (optional).\n * @property {Handler | null | undefined} [unknownHandler]\n * Handler for all unknown nodes (optional).\n *\n * @typedef State\n * Info passed around.\n * @property {(node: MdastNodes) => Array} all\n * Transform the children of an mdast parent to hast.\n * @property {(from: MdastNodes, to: Type) => HastElement | Type} applyData\n * Honor the `data` of `from`, and generate an element instead of `node`.\n * @property {Map} definitionById\n * Definitions by their identifier.\n * @property {Map} footnoteById\n * Footnote definitions by their identifier.\n * @property {Map} footnoteCounts\n * Counts for how often the same footnote was called.\n * @property {Array} footnoteOrder\n * Identifiers of order when footnote calls first appear in tree order.\n * @property {Handlers} handlers\n * Applied handlers.\n * @property {(node: MdastNodes, parent: MdastParents | undefined) => Array | HastElementContent | undefined} one\n * Transform an mdast node to hast.\n * @property {Options} options\n * Configuration.\n * @property {(from: MdastNodes, node: HastNodes) => undefined} patch\n * Copy a node’s positional info.\n * @property {(nodes: Array, loose?: boolean | undefined) => Array} wrap\n * Wrap `nodes` with line endings between each node, adds initial/final line endings when `loose`.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {visit} from 'unist-util-visit'\nimport {position} from 'unist-util-position'\nimport {handlers as defaultHandlers} from './handlers/index.js'\n\nconst own = {}.hasOwnProperty\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Create `state` from an mdast tree.\n *\n * @param {MdastNodes} tree\n * mdast node to transform.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {State}\n * `state` function.\n */\nexport function createState(tree, options) {\n const settings = options || emptyOptions\n /** @type {Map} */\n const definitionById = new Map()\n /** @type {Map} */\n const footnoteById = new Map()\n /** @type {Map} */\n const footnoteCounts = new Map()\n /** @type {Handlers} */\n // @ts-expect-error: the root handler returns a root.\n // Hard to type.\n const handlers = {...defaultHandlers, ...settings.handlers}\n\n /** @type {State} */\n const state = {\n all,\n applyData,\n definitionById,\n footnoteById,\n footnoteCounts,\n footnoteOrder: [],\n handlers,\n one,\n options: settings,\n patch,\n wrap\n }\n\n visit(tree, function (node) {\n if (node.type === 'definition' || node.type === 'footnoteDefinition') {\n const map = node.type === 'definition' ? definitionById : footnoteById\n const id = String(node.identifier).toUpperCase()\n\n // Mimick CM behavior of link definitions.\n // See: .\n if (!map.has(id)) {\n // @ts-expect-error: node type matches map.\n map.set(id, node)\n }\n }\n })\n\n return state\n\n /**\n * Transform an mdast node into a hast node.\n *\n * @param {MdastNodes} node\n * mdast node.\n * @param {MdastParents | undefined} [parent]\n * Parent of `node`.\n * @returns {Array | HastElementContent | undefined}\n * Resulting hast node.\n */\n function one(node, parent) {\n const type = node.type\n const handle = state.handlers[type]\n\n if (own.call(state.handlers, type) && handle) {\n return handle(state, node, parent)\n }\n\n if (state.options.passThrough && state.options.passThrough.includes(type)) {\n if ('children' in node) {\n const {children, ...shallow} = node\n const result = structuredClone(shallow)\n // @ts-expect-error: TS doesn’t understand…\n result.children = state.all(node)\n // @ts-expect-error: TS doesn’t understand…\n return result\n }\n\n // @ts-expect-error: it’s custom.\n return structuredClone(node)\n }\n\n const unknown = state.options.unknownHandler || defaultUnknownHandler\n\n return unknown(state, node, parent)\n }\n\n /**\n * Transform the children of an mdast node into hast nodes.\n *\n * @param {MdastNodes} parent\n * mdast node to compile\n * @returns {Array}\n * Resulting hast nodes.\n */\n function all(parent) {\n /** @type {Array} */\n const values = []\n\n if ('children' in parent) {\n const nodes = parent.children\n let index = -1\n while (++index < nodes.length) {\n const result = state.one(nodes[index], parent)\n\n // To do: see if we van clean this? Can we merge texts?\n if (result) {\n if (index && nodes[index - 1].type === 'break') {\n if (!Array.isArray(result) && result.type === 'text') {\n result.value = trimMarkdownSpaceStart(result.value)\n }\n\n if (!Array.isArray(result) && result.type === 'element') {\n const head = result.children[0]\n\n if (head && head.type === 'text') {\n head.value = trimMarkdownSpaceStart(head.value)\n }\n }\n }\n\n if (Array.isArray(result)) {\n values.push(...result)\n } else {\n values.push(result)\n }\n }\n }\n }\n\n return values\n }\n}\n\n/**\n * Copy a node’s positional info.\n *\n * @param {MdastNodes} from\n * mdast node to copy from.\n * @param {HastNodes} to\n * hast node to copy into.\n * @returns {undefined}\n * Nothing.\n */\nfunction patch(from, to) {\n if (from.position) to.position = position(from)\n}\n\n/**\n * Honor the `data` of `from` and maybe generate an element instead of `to`.\n *\n * @template {HastNodes} Type\n * Node type.\n * @param {MdastNodes} from\n * mdast node to use data from.\n * @param {Type} to\n * hast node to change.\n * @returns {HastElement | Type}\n * Nothing.\n */\nfunction applyData(from, to) {\n /** @type {HastElement | Type} */\n let result = to\n\n // Handle `data.hName`, `data.hProperties, `data.hChildren`.\n if (from && from.data) {\n const hName = from.data.hName\n const hChildren = from.data.hChildren\n const hProperties = from.data.hProperties\n\n if (typeof hName === 'string') {\n // Transforming the node resulted in an element with a different name\n // than wanted:\n if (result.type === 'element') {\n result.tagName = hName\n }\n // Transforming the node resulted in a non-element, which happens for\n // raw, text, and root nodes (unless custom handlers are passed).\n // The intent of `hName` is to create an element, but likely also to keep\n // the content around (otherwise: pass `hChildren`).\n else {\n /** @type {Array} */\n // @ts-expect-error: assume no doctypes in `root`.\n const children = 'children' in result ? result.children : [result]\n result = {type: 'element', tagName: hName, properties: {}, children}\n }\n }\n\n if (result.type === 'element' && hProperties) {\n Object.assign(result.properties, structuredClone(hProperties))\n }\n\n if (\n 'children' in result &&\n result.children &&\n hChildren !== null &&\n hChildren !== undefined\n ) {\n result.children = hChildren\n }\n }\n\n return result\n}\n\n/**\n * Transform an unknown node.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdastNodes} node\n * Unknown mdast node.\n * @returns {HastElement | HastText}\n * Resulting hast node.\n */\nfunction defaultUnknownHandler(state, node) {\n const data = node.data || {}\n /** @type {HastElement | HastText} */\n const result =\n 'value' in node &&\n !(own.call(data, 'hProperties') || own.call(data, 'hChildren'))\n ? {type: 'text', value: node.value}\n : {\n type: 'element',\n tagName: 'div',\n properties: {},\n children: state.all(node)\n }\n\n state.patch(node, result)\n return state.applyData(node, result)\n}\n\n/**\n * Wrap `nodes` with line endings between each node.\n *\n * @template {HastRootContent} Type\n * Node type.\n * @param {Array} nodes\n * List of nodes to wrap.\n * @param {boolean | undefined} [loose=false]\n * Whether to add line endings at start and end (default: `false`).\n * @returns {Array}\n * Wrapped nodes.\n */\nexport function wrap(nodes, loose) {\n /** @type {Array} */\n const result = []\n let index = -1\n\n if (loose) {\n result.push({type: 'text', value: '\\n'})\n }\n\n while (++index < nodes.length) {\n if (index) result.push({type: 'text', value: '\\n'})\n result.push(nodes[index])\n }\n\n if (loose && nodes.length > 0) {\n result.push({type: 'text', value: '\\n'})\n }\n\n return result\n}\n\n/**\n * Trim spaces and tabs at the start of `value`.\n *\n * @param {string} value\n * Value to trim.\n * @returns {string}\n * Result.\n */\nfunction trimMarkdownSpaceStart(value) {\n let index = 0\n let code = value.charCodeAt(index)\n\n while (code === 9 || code === 32) {\n index++\n code = value.charCodeAt(index)\n }\n\n return value.slice(index)\n}\n","/**\n * @typedef {import('hast').Nodes} HastNodes\n * @typedef {import('mdast').Nodes} MdastNodes\n * @typedef {import('./state.js').Options} Options\n */\n\nimport {ok as assert} from 'devlop'\nimport {footer} from './footer.js'\nimport {createState} from './state.js'\n\n/**\n * Transform mdast to hast.\n *\n * ##### Notes\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most utilities ignore `raw` nodes but two notable ones don’t:\n *\n * * `hast-util-to-html` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful\n * if you completely trust authors\n * * `hast-util-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc).\n * This is a heavy task as it needs a full HTML parser, but it is the only\n * way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark, which we follow by default.\n * They are supported by GitHub, so footnotes can be enabled in markdown with\n * `mdast-util-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes, which is hidden for sighted users but shown to\n * assistive technology.\n * When your page is not in English, you must define translated values.\n *\n * Back references use ARIA attributes, but the section label itself uses a\n * heading that is hidden with an `sr-only` class.\n * To show it to sighted users, define different attributes in\n * `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem, as it links footnote calls to footnote\n * definitions on the page through `id` attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n *

\n * \n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * Example: headings (DOM clobbering) in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value` (and doesn’t have `data.hName`,\n * `data.hProperties`, or `data.hChildren`, see later), create a hast `text`\n * node\n * * otherwise, create a `
` element (which could be changed with\n * `data.hName`), with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @param {MdastNodes} tree\n * mdast tree.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {HastNodes}\n * hast tree.\n */\nexport function toHast(tree, options) {\n const state = createState(tree, options)\n const node = state.one(tree, undefined)\n const foot = footer(state)\n /** @type {HastNodes} */\n const result = Array.isArray(node)\n ? {type: 'root', children: node}\n : node || {type: 'root', children: []}\n\n if (foot) {\n // If there’s a footer, there were definitions, meaning block\n // content.\n // So `result` is a parent node.\n assert('children' in result)\n result.children.push({type: 'text', value: '\\n'}, foot)\n }\n\n return result\n}\n","/**\n * @import {Root as HastRoot} from 'hast'\n * @import {Root as MdastRoot} from 'mdast'\n * @import {Options as ToHastOptions} from 'mdast-util-to-hast'\n * @import {Processor} from 'unified'\n * @import {VFile} from 'vfile'\n */\n\n/**\n * @typedef {Omit} Options\n *\n * @callback TransformBridge\n * Bridge-mode.\n *\n * Runs the destination with the new hast tree.\n * Discards result.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {Promise}\n * Nothing.\n *\n * @callback TransformMutate\n * Mutate-mode.\n *\n * Further transformers run on the hast tree.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {HastRoot}\n * Tree (hast).\n */\n\nimport {toHast} from 'mdast-util-to-hast'\n\n/**\n * Turn markdown into HTML.\n *\n * ##### Notes\n *\n * ###### Signature\n *\n * * if a processor is given,\n * runs the (rehype) plugins used on it with a hast tree,\n * then discards the result (*bridge mode*)\n * * otherwise,\n * returns a hast tree,\n * the plugins used after `remarkRehype` are rehype plugins (*mutate mode*)\n *\n * > 👉 **Note**:\n * > It’s highly unlikely that you want to pass a `processor`.\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most plugins ignore `raw` nodes but two notable ones don’t:\n *\n * * `rehype-stringify` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful if\n * you completely trust authors\n * * `rehype-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc);\n * this is a heavy task as it needs a full HTML parser,\n * but it is the only way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark,\n * which we follow by default.\n * They are supported by GitHub,\n * so footnotes can be enabled in markdown with `remark-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes,\n * which is hidden for sighted users but shown to assistive technology.\n * When your page is not in English,\n * you must define translated values.\n *\n * Back references use ARIA attributes,\n * but the section label itself uses a heading that is hidden with an\n * `sr-only` class.\n * To show it to sighted users,\n * define different attributes in `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem,\n * as it links footnote calls to footnote definitions on the page through `id`\n * attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n *

\n * \n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * *Example: headings (DOM clobbering)* in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value`\n * (and doesn’t have `data.hName`, `data.hProperties`, or `data.hChildren`,\n * see later),\n * create a hast `text` node\n * * otherwise,\n * create a `
` element (which could be changed with `data.hName`),\n * with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @overload\n * @param {Processor} processor\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformBridge}\n *\n * @overload\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformMutate}\n *\n * @overload\n * @param {Readonly | Processor | null | undefined} [destination]\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformBridge | TransformMutate}\n *\n * @param {Readonly | Processor | null | undefined} [destination]\n * Processor or configuration (optional).\n * @param {Readonly | null | undefined} [options]\n * When a processor was given,\n * configuration (optional).\n * @returns {TransformBridge | TransformMutate}\n * Transform.\n */\nexport default function remarkRehype(destination, options) {\n if (destination && 'run' in destination) {\n /**\n * @type {TransformBridge}\n */\n return async function (tree, file) {\n // Cast because root in -> root out.\n const hastTree = /** @type {HastRoot} */ (\n toHast(tree, {file, ...options})\n )\n await destination.run(hastTree, file)\n }\n }\n\n /**\n * @type {TransformMutate}\n */\n return function (tree, file) {\n // Cast because root in -> root out.\n // To do: in the future, disallow ` || options` fallback.\n // With `unified-engine`, `destination` can be `undefined` but\n // `options` will be the file set.\n // We should not pass that as `options`.\n return /** @type {HastRoot} */ (\n toHast(tree, {file, ...(destination || options)})\n )\n }\n}\n","/**\n * @typedef {import('mdast').Nodes} Nodes\n */\n\nimport {visit} from 'unist-util-visit'\n\n/**\n * Remove empty paragraphs in `tree`.\n *\n * @param {Nodes} tree\n * Tree to change.\n * @returns {undefined}\n * Nothing.\n */\nexport function squeezeParagraphs(tree) {\n visit(tree, function (node, index, parent) {\n if (\n index !== undefined &&\n parent &&\n node.type === 'paragraph' &&\n node.children.every(function (child) {\n return child.type === 'text' && /^\\s*$/.test(child.value)\n })\n ) {\n parent.children.splice(index, 1)\n return index\n }\n })\n}\n","/**\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: MIT\n */\n\n/**\n * @typedef {import('mdast').PhrasingContent} PhrasingContent\n * @typedef {import('mdast').Root} Root\n */\n\nimport {squeezeParagraphs} from 'mdast-squeeze-paragraphs'\nimport {visit} from 'unist-util-visit'\n\n/**\n * Only keep links with the given protocols.\n *\n * @param {object} options Options\n * @param {string[]} options.except - Protocols to exclude. Defauls to `['http', 'https']`.\n * @returns\n * Transform.\n */\nexport default function remarkUnlinkProtocols(\n options = {except: ['http', 'https']}\n) {\n /**\n * Transform.\n *\n * @param {Root} tree\n * Tree.\n * @returns {undefined}\n * Nothing.\n */\n return function (tree) {\n /** @type {Map} */\n const definitions = new Map()\n\n // Find definitions to look up linkReferences.\n visit(tree, 'definition', function (node, index, parent) {\n definitions.set(node.identifier, node.url)\n if (parent && typeof index === 'number') {\n const url = node.url\n if (\n url &&\n url.includes(':') &&\n !options.except.some((proto) => url.startsWith(`${proto}:`))\n ) {\n parent.children.splice(index, 1)\n return index\n }\n }\n })\n\n visit(tree, function (node, index, parent) {\n if (\n parent &&\n typeof index === 'number' &&\n (node.type === 'link' || node.type === 'linkReference')\n ) {\n const url =\n node.type === 'link' ? node.url : definitions.get(node.identifier)\n if (\n url &&\n url.includes(':') &&\n !options.except.some((proto) => url.startsWith(`${proto}:`))\n ) {\n parent.children.splice(index, 1, ...node.children)\n return index\n }\n }\n })\n\n squeezeParagraphs(tree)\n }\n}\n","/**\n * Throw a given error.\n *\n * @param {Error|null|undefined} [error]\n * Maybe error.\n * @returns {asserts error is null|undefined}\n */\nexport function bail(error) {\n if (error) {\n throw error\n }\n}\n","'use strict';\n\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar toStr = Object.prototype.toString;\nvar defineProperty = Object.defineProperty;\nvar gOPD = Object.getOwnPropertyDescriptor;\n\nvar isArray = function isArray(arr) {\n\tif (typeof Array.isArray === 'function') {\n\t\treturn Array.isArray(arr);\n\t}\n\n\treturn toStr.call(arr) === '[object Array]';\n};\n\nvar isPlainObject = function isPlainObject(obj) {\n\tif (!obj || toStr.call(obj) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tvar hasOwnConstructor = hasOwn.call(obj, 'constructor');\n\tvar hasIsPrototypeOf = obj.constructor && obj.constructor.prototype && hasOwn.call(obj.constructor.prototype, 'isPrototypeOf');\n\t// Not own constructor property must be Object\n\tif (obj.constructor && !hasOwnConstructor && !hasIsPrototypeOf) {\n\t\treturn false;\n\t}\n\n\t// Own properties are enumerated firstly, so to speed up,\n\t// if last one is own, then all properties are own.\n\tvar key;\n\tfor (key in obj) { /**/ }\n\n\treturn typeof key === 'undefined' || hasOwn.call(obj, key);\n};\n\n// If name is '__proto__', and Object.defineProperty is available, define __proto__ as an own property on target\nvar setProperty = function setProperty(target, options) {\n\tif (defineProperty && options.name === '__proto__') {\n\t\tdefineProperty(target, options.name, {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: true,\n\t\t\tvalue: options.newValue,\n\t\t\twritable: true\n\t\t});\n\t} else {\n\t\ttarget[options.name] = options.newValue;\n\t}\n};\n\n// Return undefined instead of __proto__ if '__proto__' is not an own property\nvar getProperty = function getProperty(obj, name) {\n\tif (name === '__proto__') {\n\t\tif (!hasOwn.call(obj, name)) {\n\t\t\treturn void 0;\n\t\t} else if (gOPD) {\n\t\t\t// In early versions of node, obj['__proto__'] is buggy when obj has\n\t\t\t// __proto__ as an own property. Object.getOwnPropertyDescriptor() works.\n\t\t\treturn gOPD(obj, name).value;\n\t\t}\n\t}\n\n\treturn obj[name];\n};\n\nmodule.exports = function extend() {\n\tvar options, name, src, copy, copyIsArray, clone;\n\tvar target = arguments[0];\n\tvar i = 1;\n\tvar length = arguments.length;\n\tvar deep = false;\n\n\t// Handle a deep copy situation\n\tif (typeof target === 'boolean') {\n\t\tdeep = target;\n\t\ttarget = arguments[1] || {};\n\t\t// skip the boolean and the target\n\t\ti = 2;\n\t}\n\tif (target == null || (typeof target !== 'object' && typeof target !== 'function')) {\n\t\ttarget = {};\n\t}\n\n\tfor (; i < length; ++i) {\n\t\toptions = arguments[i];\n\t\t// Only deal with non-null/undefined values\n\t\tif (options != null) {\n\t\t\t// Extend the base object\n\t\t\tfor (name in options) {\n\t\t\t\tsrc = getProperty(target, name);\n\t\t\t\tcopy = getProperty(options, name);\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif (target !== copy) {\n\t\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\t\tif (deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {\n\t\t\t\t\t\tif (copyIsArray) {\n\t\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\t\tclone = src && isArray(src) ? src : [];\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tclone = src && isPlainObject(src) ? src : {};\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\t\tsetProperty(target, { name: name, newValue: extend(deep, clone, copy) });\n\n\t\t\t\t\t// Don't bring in undefined values\n\t\t\t\t\t} else if (typeof copy !== 'undefined') {\n\t\t\t\t\t\tsetProperty(target, { name: name, newValue: copy });\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n","export default function isPlainObject(value) {\n\tif (typeof value !== 'object' || value === null) {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in value) && !(Symbol.iterator in value);\n}\n","// To do: remove `void`s\n// To do: remove `null` from output of our APIs, allow it as user APIs.\n\n/**\n * @typedef {(error?: Error | null | undefined, ...output: Array) => void} Callback\n * Callback.\n *\n * @typedef {(...input: Array) => any} Middleware\n * Ware.\n *\n * @typedef Pipeline\n * Pipeline.\n * @property {Run} run\n * Run the pipeline.\n * @property {Use} use\n * Add middleware.\n *\n * @typedef {(...input: Array) => void} Run\n * Call all middleware.\n *\n * Calls `done` on completion with either an error or the output of the\n * last middleware.\n *\n * > 👉 **Note**: as the length of input defines whether async functions get a\n * > `next` function,\n * > it’s recommended to keep `input` at one value normally.\n\n *\n * @typedef {(fn: Middleware) => Pipeline} Use\n * Add middleware.\n */\n\n/**\n * Create new middleware.\n *\n * @returns {Pipeline}\n * Pipeline.\n */\nexport function trough() {\n /** @type {Array} */\n const fns = []\n /** @type {Pipeline} */\n const pipeline = {run, use}\n\n return pipeline\n\n /** @type {Run} */\n function run(...values) {\n let middlewareIndex = -1\n /** @type {Callback} */\n const callback = values.pop()\n\n if (typeof callback !== 'function') {\n throw new TypeError('Expected function as last argument, not ' + callback)\n }\n\n next(null, ...values)\n\n /**\n * Run the next `fn`, or we’re done.\n *\n * @param {Error | null | undefined} error\n * @param {Array} output\n */\n function next(error, ...output) {\n const fn = fns[++middlewareIndex]\n let index = -1\n\n if (error) {\n callback(error)\n return\n }\n\n // Copy non-nullish input into values.\n while (++index < values.length) {\n if (output[index] === null || output[index] === undefined) {\n output[index] = values[index]\n }\n }\n\n // Save the newly created `output` for the next call.\n values = output\n\n // Next or done.\n if (fn) {\n wrap(fn, next)(...output)\n } else {\n callback(null, ...output)\n }\n }\n }\n\n /** @type {Use} */\n function use(middelware) {\n if (typeof middelware !== 'function') {\n throw new TypeError(\n 'Expected `middelware` to be a function, not ' + middelware\n )\n }\n\n fns.push(middelware)\n return pipeline\n }\n}\n\n/**\n * Wrap `middleware` into a uniform interface.\n *\n * You can pass all input to the resulting function.\n * `callback` is then called with the output of `middleware`.\n *\n * If `middleware` accepts more arguments than the later given in input,\n * an extra `done` function is passed to it after that input,\n * which must be called by `middleware`.\n *\n * The first value in `input` is the main input value.\n * All other input values are the rest input values.\n * The values given to `callback` are the input values,\n * merged with every non-nullish output value.\n *\n * * if `middleware` throws an error,\n * returns a promise that is rejected,\n * or calls the given `done` function with an error,\n * `callback` is called with that error\n * * if `middleware` returns a value or returns a promise that is resolved,\n * that value is the main output value\n * * if `middleware` calls `done`,\n * all non-nullish values except for the first one (the error) overwrite the\n * output values\n *\n * @param {Middleware} middleware\n * Function to wrap.\n * @param {Callback} callback\n * Callback called with the output of `middleware`.\n * @returns {Run}\n * Wrapped middleware.\n */\nexport function wrap(middleware, callback) {\n /** @type {boolean} */\n let called\n\n return wrapped\n\n /**\n * Call `middleware`.\n * @this {any}\n * @param {Array} parameters\n * @returns {void}\n */\n function wrapped(...parameters) {\n const fnExpectsCallback = middleware.length > parameters.length\n /** @type {any} */\n let result\n\n if (fnExpectsCallback) {\n parameters.push(done)\n }\n\n try {\n result = middleware.apply(this, parameters)\n } catch (error) {\n const exception = /** @type {Error} */ (error)\n\n // Well, this is quite the pickle.\n // `middleware` received a callback and called it synchronously, but that\n // threw an error.\n // The only thing left to do is to throw the thing instead.\n if (fnExpectsCallback && called) {\n throw exception\n }\n\n return done(exception)\n }\n\n if (!fnExpectsCallback) {\n if (result && result.then && typeof result.then === 'function') {\n result.then(then, done)\n } else if (result instanceof Error) {\n done(result)\n } else {\n then(result)\n }\n }\n }\n\n /**\n * Call `callback`, only once.\n *\n * @type {Callback}\n */\n function done(error, ...output) {\n if (!called) {\n called = true\n callback(error, ...output)\n }\n }\n\n /**\n * Call `done` with one value.\n *\n * @param {any} [value]\n */\n function then(value) {\n done(null, value)\n }\n}\n","// A derivative work based on:\n// .\n// Which is licensed:\n//\n// MIT License\n//\n// Copyright (c) 2013 James Halliday\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of\n// this software and associated documentation files (the \"Software\"), to deal in\n// the Software without restriction, including without limitation the rights to\n// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\n// the Software, and to permit persons to whom the Software is furnished to do so,\n// subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\n// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\n// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\n// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\n// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A derivative work based on:\n//\n// Parts of that are extracted from Node’s internal `path` module:\n// .\n// Which is licensed:\n//\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nexport const minpath = {basename, dirname, extname, join, sep: '/'}\n\n/* eslint-disable max-depth, complexity */\n\n/**\n * Get the basename from a path.\n *\n * @param {string} path\n * File path.\n * @param {string | null | undefined} [extname]\n * Extension to strip.\n * @returns {string}\n * Stem or basename.\n */\nfunction basename(path, extname) {\n if (extname !== undefined && typeof extname !== 'string') {\n throw new TypeError('\"ext\" argument must be a string')\n }\n\n assertPath(path)\n let start = 0\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let seenNonSlash\n\n if (\n extname === undefined ||\n extname.length === 0 ||\n extname.length > path.length\n ) {\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // path component.\n seenNonSlash = true\n end = index + 1\n }\n }\n\n return end < 0 ? '' : path.slice(start, end)\n }\n\n if (extname === path) {\n return ''\n }\n\n let firstNonSlashEnd = -1\n let extnameIndex = extname.length - 1\n\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else {\n if (firstNonSlashEnd < 0) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching.\n seenNonSlash = true\n firstNonSlashEnd = index + 1\n }\n\n if (extnameIndex > -1) {\n // Try to match the explicit extension.\n if (path.codePointAt(index) === extname.codePointAt(extnameIndex--)) {\n if (extnameIndex < 0) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = index\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extnameIndex = -1\n end = firstNonSlashEnd\n }\n }\n }\n }\n\n if (start === end) {\n end = firstNonSlashEnd\n } else if (end < 0) {\n end = path.length\n }\n\n return path.slice(start, end)\n}\n\n/**\n * Get the dirname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\nfunction dirname(path) {\n assertPath(path)\n\n if (path.length === 0) {\n return '.'\n }\n\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n // Prefix `--` is important to not run on `0`.\n while (--index) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n if (unmatchedSlash) {\n end = index\n break\n }\n } else if (!unmatchedSlash) {\n // We saw the first non-path separator\n unmatchedSlash = true\n }\n }\n\n return end < 0\n ? path.codePointAt(0) === 47 /* `/` */\n ? '/'\n : '.'\n : end === 1 && path.codePointAt(0) === 47 /* `/` */\n ? '//'\n : path.slice(0, end)\n}\n\n/**\n * Get an extname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * Extname.\n */\nfunction extname(path) {\n assertPath(path)\n\n let index = path.length\n\n let end = -1\n let startPart = 0\n let startDot = -1\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find.\n let preDotState = 0\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n while (index--) {\n const code = path.codePointAt(index)\n\n if (code === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (unmatchedSlash) {\n startPart = index + 1\n break\n }\n\n continue\n }\n\n if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // extension.\n unmatchedSlash = true\n end = index + 1\n }\n\n if (code === 46 /* `.` */) {\n // If this is our first dot, mark it as the start of our extension.\n if (startDot < 0) {\n startDot = index\n } else if (preDotState !== 1) {\n preDotState = 1\n }\n } else if (startDot > -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension.\n preDotState = -1\n }\n }\n\n if (\n startDot < 0 ||\n end < 0 ||\n // We saw a non-dot character immediately before the dot.\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly `..`.\n (preDotState === 1 && startDot === end - 1 && startDot === startPart + 1)\n ) {\n return ''\n }\n\n return path.slice(startDot, end)\n}\n\n/**\n * Join segments from a path.\n *\n * @param {Array} segments\n * Path segments.\n * @returns {string}\n * File path.\n */\nfunction join(...segments) {\n let index = -1\n /** @type {string | undefined} */\n let joined\n\n while (++index < segments.length) {\n assertPath(segments[index])\n\n if (segments[index]) {\n joined =\n joined === undefined ? segments[index] : joined + '/' + segments[index]\n }\n }\n\n return joined === undefined ? '.' : normalize(joined)\n}\n\n/**\n * Normalize a basic file path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\n// Note: `normalize` is not exposed as `path.normalize`, so some code is\n// manually removed from it.\nfunction normalize(path) {\n assertPath(path)\n\n const absolute = path.codePointAt(0) === 47 /* `/` */\n\n // Normalize the path according to POSIX rules.\n let value = normalizeString(path, !absolute)\n\n if (value.length === 0 && !absolute) {\n value = '.'\n }\n\n if (value.length > 0 && path.codePointAt(path.length - 1) === 47 /* / */) {\n value += '/'\n }\n\n return absolute ? '/' + value : value\n}\n\n/**\n * Resolve `.` and `..` elements in a path with directory names.\n *\n * @param {string} path\n * File path.\n * @param {boolean} allowAboveRoot\n * Whether `..` can move above root.\n * @returns {string}\n * File path.\n */\nfunction normalizeString(path, allowAboveRoot) {\n let result = ''\n let lastSegmentLength = 0\n let lastSlash = -1\n let dots = 0\n let index = -1\n /** @type {number | undefined} */\n let code\n /** @type {number} */\n let lastSlashIndex\n\n while (++index <= path.length) {\n if (index < path.length) {\n code = path.codePointAt(index)\n } else if (code === 47 /* `/` */) {\n break\n } else {\n code = 47 /* `/` */\n }\n\n if (code === 47 /* `/` */) {\n if (lastSlash === index - 1 || dots === 1) {\n // Empty.\n } else if (lastSlash !== index - 1 && dots === 2) {\n if (\n result.length < 2 ||\n lastSegmentLength !== 2 ||\n result.codePointAt(result.length - 1) !== 46 /* `.` */ ||\n result.codePointAt(result.length - 2) !== 46 /* `.` */\n ) {\n if (result.length > 2) {\n lastSlashIndex = result.lastIndexOf('/')\n\n if (lastSlashIndex !== result.length - 1) {\n if (lastSlashIndex < 0) {\n result = ''\n lastSegmentLength = 0\n } else {\n result = result.slice(0, lastSlashIndex)\n lastSegmentLength = result.length - 1 - result.lastIndexOf('/')\n }\n\n lastSlash = index\n dots = 0\n continue\n }\n } else if (result.length > 0) {\n result = ''\n lastSegmentLength = 0\n lastSlash = index\n dots = 0\n continue\n }\n }\n\n if (allowAboveRoot) {\n result = result.length > 0 ? result + '/..' : '..'\n lastSegmentLength = 2\n }\n } else {\n if (result.length > 0) {\n result += '/' + path.slice(lastSlash + 1, index)\n } else {\n result = path.slice(lastSlash + 1, index)\n }\n\n lastSegmentLength = index - lastSlash - 1\n }\n\n lastSlash = index\n dots = 0\n } else if (code === 46 /* `.` */ && dots > -1) {\n dots++\n } else {\n dots = -1\n }\n }\n\n return result\n}\n\n/**\n * Make sure `path` is a string.\n *\n * @param {string} path\n * File path.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError(\n 'Path must be a string. Received ' + JSON.stringify(path)\n )\n }\n}\n\n/* eslint-enable max-depth, complexity */\n","// Somewhat based on:\n// .\n// But I don’t think one tiny line of code can be copyrighted. 😅\nexport const minproc = {cwd}\n\nfunction cwd() {\n return '/'\n}\n","/**\n * Checks if a value has the shape of a WHATWG URL object.\n *\n * Using a symbol or instanceof would not be able to recognize URL objects\n * coming from other implementations (e.g. in Electron), so instead we are\n * checking some well known properties for a lack of a better test.\n *\n * We use `href` and `protocol` as they are the only properties that are\n * easy to retrieve and calculate due to the lazy nature of the getters.\n *\n * We check for auth attribute to distinguish legacy url instance with\n * WHATWG URL instance.\n *\n * @param {unknown} fileUrlOrPath\n * File path or URL.\n * @returns {fileUrlOrPath is URL}\n * Whether it’s a URL.\n */\n// From: \nexport function isUrl(fileUrlOrPath) {\n return Boolean(\n fileUrlOrPath !== null &&\n typeof fileUrlOrPath === 'object' &&\n 'href' in fileUrlOrPath &&\n fileUrlOrPath.href &&\n 'protocol' in fileUrlOrPath &&\n fileUrlOrPath.protocol &&\n // @ts-expect-error: indexing is fine.\n fileUrlOrPath.auth === undefined\n )\n}\n","import {isUrl} from './minurl.shared.js'\n\nexport {isUrl} from './minurl.shared.js'\n\n// See: \n\n/**\n * @param {URL | string} path\n * File URL.\n * @returns {string}\n * File URL.\n */\nexport function urlToPath(path) {\n if (typeof path === 'string') {\n path = new URL(path)\n } else if (!isUrl(path)) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'The \"path\" argument must be of type string or an instance of URL. Received `' +\n path +\n '`'\n )\n error.code = 'ERR_INVALID_ARG_TYPE'\n throw error\n }\n\n if (path.protocol !== 'file:') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError('The URL must be of scheme file')\n error.code = 'ERR_INVALID_URL_SCHEME'\n throw error\n }\n\n return getPathFromURLPosix(path)\n}\n\n/**\n * Get a path from a POSIX URL.\n *\n * @param {URL} url\n * URL.\n * @returns {string}\n * File path.\n */\nfunction getPathFromURLPosix(url) {\n if (url.hostname !== '') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL host must be \"localhost\" or empty on darwin'\n )\n error.code = 'ERR_INVALID_FILE_URL_HOST'\n throw error\n }\n\n const pathname = url.pathname\n let index = -1\n\n while (++index < pathname.length) {\n if (\n pathname.codePointAt(index) === 37 /* `%` */ &&\n pathname.codePointAt(index + 1) === 50 /* `2` */\n ) {\n const third = pathname.codePointAt(index + 2)\n if (third === 70 /* `F` */ || third === 102 /* `f` */) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL path must not include encoded / characters'\n )\n error.code = 'ERR_INVALID_FILE_URL_PATH'\n throw error\n }\n }\n }\n\n return decodeURIComponent(pathname)\n}\n","/**\n * @import {Node, Point, Position} from 'unist'\n * @import {Options as MessageOptions} from 'vfile-message'\n * @import {Compatible, Data, Map, Options, Value} from 'vfile'\n */\n\n/**\n * @typedef {object & {type: string, position?: Position | undefined}} NodeLike\n */\n\nimport {VFileMessage} from 'vfile-message'\nimport {minpath} from '#minpath'\nimport {minproc} from '#minproc'\nimport {urlToPath, isUrl} from '#minurl'\n\n/**\n * Order of setting (least specific to most), we need this because otherwise\n * `{stem: 'a', path: '~/b.js'}` would throw, as a path is needed before a\n * stem can be set.\n */\nconst order = /** @type {const} */ ([\n 'history',\n 'path',\n 'basename',\n 'stem',\n 'extname',\n 'dirname'\n])\n\nexport class VFile {\n /**\n * Create a new virtual file.\n *\n * `options` is treated as:\n *\n * * `string` or `Uint8Array` — `{value: options}`\n * * `URL` — `{path: options}`\n * * `VFile` — shallow copies its data over to the new file\n * * `object` — all fields are shallow copied over to the new file\n *\n * Path related fields are set in the following order (least specific to\n * most specific): `history`, `path`, `basename`, `stem`, `extname`,\n * `dirname`.\n *\n * You cannot set `dirname` or `extname` without setting either `history`,\n * `path`, `basename`, or `stem` too.\n *\n * @param {Compatible | null | undefined} [value]\n * File value.\n * @returns\n * New instance.\n */\n constructor(value) {\n /** @type {Options | VFile} */\n let options\n\n if (!value) {\n options = {}\n } else if (isUrl(value)) {\n options = {path: value}\n } else if (typeof value === 'string' || isUint8Array(value)) {\n options = {value}\n } else {\n options = value\n }\n\n /* eslint-disable no-unused-expressions */\n\n /**\n * Base of `path` (default: `process.cwd()` or `'/'` in browsers).\n *\n * @type {string}\n */\n // Prevent calling `cwd` (which could be expensive) if it’s not needed;\n // the empty string will be overridden in the next block.\n this.cwd = 'cwd' in options ? '' : minproc.cwd()\n\n /**\n * Place to store custom info (default: `{}`).\n *\n * It’s OK to store custom data directly on the file but moving it to\n * `data` is recommended.\n *\n * @type {Data}\n */\n this.data = {}\n\n /**\n * List of file paths the file moved between.\n *\n * The first is the original path and the last is the current path.\n *\n * @type {Array}\n */\n this.history = []\n\n /**\n * List of messages associated with the file.\n *\n * @type {Array}\n */\n this.messages = []\n\n /**\n * Raw value.\n *\n * @type {Value}\n */\n this.value\n\n // The below are non-standard, they are “well-known”.\n // As in, used in several tools.\n /**\n * Source map.\n *\n * This type is equivalent to the `RawSourceMap` type from the `source-map`\n * module.\n *\n * @type {Map | null | undefined}\n */\n this.map\n\n /**\n * Custom, non-string, compiled, representation.\n *\n * This is used by unified to store non-string results.\n * One example is when turning markdown into React nodes.\n *\n * @type {unknown}\n */\n this.result\n\n /**\n * Whether a file was saved to disk.\n *\n * This is used by vfile reporters.\n *\n * @type {boolean}\n */\n this.stored\n /* eslint-enable no-unused-expressions */\n\n // Set path related properties in the correct order.\n let index = -1\n\n while (++index < order.length) {\n const field = order[index]\n\n // Note: we specifically use `in` instead of `hasOwnProperty` to accept\n // `vfile`s too.\n if (\n field in options &&\n options[field] !== undefined &&\n options[field] !== null\n ) {\n // @ts-expect-error: TS doesn’t understand basic reality.\n this[field] = field === 'history' ? [...options[field]] : options[field]\n }\n }\n\n /** @type {string} */\n let field\n\n // Set non-path related properties.\n for (field in options) {\n // @ts-expect-error: fine to set other things.\n if (!order.includes(field)) {\n // @ts-expect-error: fine to set other things.\n this[field] = options[field]\n }\n }\n }\n\n /**\n * Get the basename (including extname) (example: `'index.min.js'`).\n *\n * @returns {string | undefined}\n * Basename.\n */\n get basename() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path)\n : undefined\n }\n\n /**\n * Set basename (including extname) (`'index.min.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} basename\n * Basename.\n * @returns {undefined}\n * Nothing.\n */\n set basename(basename) {\n assertNonEmpty(basename, 'basename')\n assertPart(basename, 'basename')\n this.path = minpath.join(this.dirname || '', basename)\n }\n\n /**\n * Get the parent path (example: `'~'`).\n *\n * @returns {string | undefined}\n * Dirname.\n */\n get dirname() {\n return typeof this.path === 'string'\n ? minpath.dirname(this.path)\n : undefined\n }\n\n /**\n * Set the parent path (example: `'~'`).\n *\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} dirname\n * Dirname.\n * @returns {undefined}\n * Nothing.\n */\n set dirname(dirname) {\n assertPath(this.basename, 'dirname')\n this.path = minpath.join(dirname || '', this.basename)\n }\n\n /**\n * Get the extname (including dot) (example: `'.js'`).\n *\n * @returns {string | undefined}\n * Extname.\n */\n get extname() {\n return typeof this.path === 'string'\n ? minpath.extname(this.path)\n : undefined\n }\n\n /**\n * Set the extname (including dot) (example: `'.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} extname\n * Extname.\n * @returns {undefined}\n * Nothing.\n */\n set extname(extname) {\n assertPart(extname, 'extname')\n assertPath(this.dirname, 'extname')\n\n if (extname) {\n if (extname.codePointAt(0) !== 46 /* `.` */) {\n throw new Error('`extname` must start with `.`')\n }\n\n if (extname.includes('.', 1)) {\n throw new Error('`extname` cannot contain multiple dots')\n }\n }\n\n this.path = minpath.join(this.dirname, this.stem + (extname || ''))\n }\n\n /**\n * Get the full path (example: `'~/index.min.js'`).\n *\n * @returns {string}\n * Path.\n */\n get path() {\n return this.history[this.history.length - 1]\n }\n\n /**\n * Set the full path (example: `'~/index.min.js'`).\n *\n * Cannot be nullified.\n * You can set a file URL (a `URL` object with a `file:` protocol) which will\n * be turned into a path with `url.fileURLToPath`.\n *\n * @param {URL | string} path\n * Path.\n * @returns {undefined}\n * Nothing.\n */\n set path(path) {\n if (isUrl(path)) {\n path = urlToPath(path)\n }\n\n assertNonEmpty(path, 'path')\n\n if (this.path !== path) {\n this.history.push(path)\n }\n }\n\n /**\n * Get the stem (basename w/o extname) (example: `'index.min'`).\n *\n * @returns {string | undefined}\n * Stem.\n */\n get stem() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path, this.extname)\n : undefined\n }\n\n /**\n * Set the stem (basename w/o extname) (example: `'index.min'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} stem\n * Stem.\n * @returns {undefined}\n * Nothing.\n */\n set stem(stem) {\n assertNonEmpty(stem, 'stem')\n assertPart(stem, 'stem')\n this.path = minpath.join(this.dirname || '', stem + (this.extname || ''))\n }\n\n // Normal prototypal methods.\n /**\n * Create a fatal message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `true` (error; file not usable)\n * and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {never}\n * Never.\n * @throws {VFileMessage}\n * Message.\n */\n fail(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = true\n\n throw message\n }\n\n /**\n * Create an info message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `undefined` (info; change\n * likely not needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n info(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = undefined\n\n return message\n }\n\n /**\n * Create a message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `false` (warning; change may be\n * needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > 🪦 **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n message(causeOrReason, optionsOrParentOrPlace, origin) {\n const message = new VFileMessage(\n // @ts-expect-error: the overloads are fine.\n causeOrReason,\n optionsOrParentOrPlace,\n origin\n )\n\n if (this.path) {\n message.name = this.path + ':' + message.name\n message.file = this.path\n }\n\n message.fatal = false\n\n this.messages.push(message)\n\n return message\n }\n\n /**\n * Serialize the file.\n *\n * > **Note**: which encodings are supported depends on the engine.\n * > For info on Node.js, see:\n * > .\n *\n * @param {string | null | undefined} [encoding='utf8']\n * Character encoding to understand `value` as when it’s a `Uint8Array`\n * (default: `'utf-8'`).\n * @returns {string}\n * Serialized file.\n */\n toString(encoding) {\n if (this.value === undefined) {\n return ''\n }\n\n if (typeof this.value === 'string') {\n return this.value\n }\n\n const decoder = new TextDecoder(encoding || undefined)\n return decoder.decode(this.value)\n }\n}\n\n/**\n * Assert that `part` is not a path (as in, does not contain `path.sep`).\n *\n * @param {string | null | undefined} part\n * File path part.\n * @param {string} name\n * Part name.\n * @returns {undefined}\n * Nothing.\n */\nfunction assertPart(part, name) {\n if (part && part.includes(minpath.sep)) {\n throw new Error(\n '`' + name + '` cannot be a path: did not expect `' + minpath.sep + '`'\n )\n }\n}\n\n/**\n * Assert that `part` is not empty.\n *\n * @param {string | undefined} part\n * Thing.\n * @param {string} name\n * Part name.\n * @returns {asserts part is string}\n * Nothing.\n */\nfunction assertNonEmpty(part, name) {\n if (!part) {\n throw new Error('`' + name + '` cannot be empty')\n }\n}\n\n/**\n * Assert `path` exists.\n *\n * @param {string | undefined} path\n * Path.\n * @param {string} name\n * Dependency name.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path, name) {\n if (!path) {\n throw new Error('Setting `' + name + '` requires `path` to be set too')\n }\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","export const CallableInstance =\n /**\n * @type {new , Result>(property: string | symbol) => (...parameters: Parameters) => Result}\n */\n (\n /** @type {unknown} */\n (\n /**\n * @this {Function}\n * @param {string | symbol} property\n * @returns {(...parameters: Array) => unknown}\n */\n function (property) {\n const self = this\n const constr = self.constructor\n const proto = /** @type {Record} */ (\n // Prototypes do exist.\n // type-coverage:ignore-next-line\n constr.prototype\n )\n const value = proto[property]\n /** @type {(...parameters: Array) => unknown} */\n const apply = function () {\n return value.apply(apply, arguments)\n }\n\n Object.setPrototypeOf(apply, proto)\n\n // Not needed for us in `unified`: we only call this on the `copy`\n // function,\n // and we don't need to add its fields (`length`, `name`)\n // over.\n // See also: GH-246.\n // const names = Object.getOwnPropertyNames(value)\n //\n // for (const p of names) {\n // const descriptor = Object.getOwnPropertyDescriptor(value, p)\n // if (descriptor) Object.defineProperty(apply, p, descriptor)\n // }\n\n return apply\n }\n )\n )\n","/**\n * @typedef {import('trough').Pipeline} Pipeline\n *\n * @typedef {import('unist').Node} Node\n *\n * @typedef {import('vfile').Compatible} Compatible\n * @typedef {import('vfile').Value} Value\n *\n * @typedef {import('../index.js').CompileResultMap} CompileResultMap\n * @typedef {import('../index.js').Data} Data\n * @typedef {import('../index.js').Settings} Settings\n */\n\n/**\n * @typedef {CompileResultMap[keyof CompileResultMap]} CompileResults\n * Acceptable results from compilers.\n *\n * To register custom results, add them to\n * {@linkcode CompileResultMap}.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the compiler receives (default: `Node`).\n * @template {CompileResults} [Result=CompileResults]\n * The thing that the compiler yields (default: `CompileResults`).\n * @callback Compiler\n * A **compiler** handles the compiling of a syntax tree to something else\n * (in most cases, text) (TypeScript type).\n *\n * It is used in the stringify phase and called with a {@linkcode Node}\n * and {@linkcode VFile} representation of the document to compile.\n * It should return the textual representation of the given tree (typically\n * `string`).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n * @param {Tree} tree\n * Tree to compile.\n * @param {VFile} file\n * File associated with `tree`.\n * @returns {Result}\n * New content: compiled text (`string` or `Uint8Array`, for `file.value`) or\n * something else (for `file.result`).\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the parser yields (default: `Node`)\n * @callback Parser\n * A **parser** handles the parsing of text to a syntax tree.\n *\n * It is used in the parse phase and is called with a `string` and\n * {@linkcode VFile} of the document to parse.\n * It must return the syntax tree representation of the given file\n * ({@linkcode Node}).\n * @param {string} document\n * Document to parse.\n * @param {VFile} file\n * File associated with `document`.\n * @returns {Tree}\n * Node representing the given file.\n */\n\n/**\n * @typedef {(\n * Plugin, any, any> |\n * PluginTuple, any, any> |\n * Preset\n * )} Pluggable\n * Union of the different ways to add plugins and settings.\n */\n\n/**\n * @typedef {Array} PluggableList\n * List of plugins and presets.\n */\n\n// Note: we can’t use `callback` yet as it messes up `this`:\n// .\n/**\n * @template {Array} [PluginParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=Node]\n * Value that is expected as input (default: `Node`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=Input]\n * Value that is yielded as output (default: `Input`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * (this: Processor, ...parameters: PluginParameters) =>\n * Input extends string ? // Parser.\n * Output extends Node | undefined ? undefined | void : never :\n * Output extends CompileResults ? // Compiler.\n * Input extends Node | undefined ? undefined | void : never :\n * Transformer<\n * Input extends Node ? Input : Node,\n * Output extends Node ? Output : Node\n * > | undefined | void\n * )} Plugin\n * Single plugin.\n *\n * Plugins configure the processors they are applied on in the following\n * ways:\n *\n * * they change the processor, such as the parser, the compiler, or by\n * configuring data\n * * they specify how to handle trees and files\n *\n * In practice, they are functions that can receive options and configure the\n * processor (`this`).\n *\n * > **Note**: plugins are called when the processor is *frozen*, not when\n * > they are applied.\n */\n\n/**\n * Tuple of a plugin and its configuration.\n *\n * The first item is a plugin, the rest are its parameters.\n *\n * @template {Array} [TupleParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=undefined]\n * Value that is expected as input (optional).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=undefined] (optional).\n * Value that is yielded as output.\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * [\n * plugin: Plugin,\n * ...parameters: TupleParameters\n * ]\n * )} PluginTuple\n */\n\n/**\n * @typedef Preset\n * Sharable configuration.\n *\n * They can contain plugins and settings.\n * @property {PluggableList | undefined} [plugins]\n * List of plugins and presets (optional).\n * @property {Settings | undefined} [settings]\n * Shared settings for parsers and compilers (optional).\n */\n\n/**\n * @template {VFile} [File=VFile]\n * The file that the callback receives (default: `VFile`).\n * @callback ProcessCallback\n * Callback called when the process is done.\n *\n * Called with either an error or a result.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {File | undefined} [file]\n * Processed file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The tree that the callback receives (default: `Node`).\n * @callback RunCallback\n * Callback called when transformers are done.\n *\n * Called with either an error or results.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {Tree | undefined} [tree]\n * Transformed tree (optional).\n * @param {VFile | undefined} [file]\n * File (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Output=Node]\n * Node type that the transformer yields (default: `Node`).\n * @callback TransformCallback\n * Callback passed to transforms.\n *\n * If the signature of a `transformer` accepts a third argument, the\n * transformer may perform asynchronous operations, and must call it.\n * @param {Error | undefined} [error]\n * Fatal error to stop the process (optional).\n * @param {Output | undefined} [tree]\n * New, changed, tree (optional).\n * @param {VFile | undefined} [file]\n * New, changed, file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Input=Node]\n * Node type that the transformer expects (default: `Node`).\n * @template {Node} [Output=Input]\n * Node type that the transformer yields (default: `Input`).\n * @callback Transformer\n * Transformers handle syntax trees and files.\n *\n * They are functions that are called each time a syntax tree and file are\n * passed through the run phase.\n * When an error occurs in them (either because it’s thrown, returned,\n * rejected, or passed to `next`), the process stops.\n *\n * The run phase is handled by [`trough`][trough], see its documentation for\n * the exact semantics of these functions.\n *\n * > **Note**: you should likely ignore `next`: don’t accept it.\n * > it supports callback-style async work.\n * > But promises are likely easier to reason about.\n *\n * [trough]: https://github.com/wooorm/trough#function-fninput-next\n * @param {Input} tree\n * Tree to handle.\n * @param {VFile} file\n * File to handle.\n * @param {TransformCallback} next\n * Callback.\n * @returns {(\n * Promise |\n * Promise | // For some reason this is needed separately.\n * Output |\n * Error |\n * undefined |\n * void\n * )}\n * If you accept `next`, nothing.\n * Otherwise:\n *\n * * `Error` — fatal error to stop the process\n * * `Promise` or `undefined` — the next transformer keeps using\n * same tree\n * * `Promise` or `Node` — new, changed, tree\n */\n\n/**\n * @template {Node | undefined} ParseTree\n * Output of `parse`.\n * @template {Node | undefined} HeadTree\n * Input for `run`.\n * @template {Node | undefined} TailTree\n * Output for `run`.\n * @template {Node | undefined} CompileTree\n * Input of `stringify`.\n * @template {CompileResults | undefined} CompileResult\n * Output of `stringify`.\n * @template {Node | string | undefined} Input\n * Input of plugin.\n * @template Output\n * Output of plugin (optional).\n * @typedef {(\n * Input extends string\n * ? Output extends Node | undefined\n * ? // Parser.\n * Processor<\n * Output extends undefined ? ParseTree : Output,\n * HeadTree,\n * TailTree,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor\n * : Output extends CompileResults\n * ? Input extends Node | undefined\n * ? // Compiler.\n * Processor<\n * ParseTree,\n * HeadTree,\n * TailTree,\n * Input extends undefined ? CompileTree : Input,\n * Output extends undefined ? CompileResult : Output\n * >\n * : // Unknown.\n * Processor\n * : Input extends Node | undefined\n * ? Output extends Node | undefined\n * ? // Transform.\n * Processor<\n * ParseTree,\n * HeadTree extends undefined ? Input : HeadTree,\n * Output extends undefined ? TailTree : Output,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor\n * : // Unknown.\n * Processor\n * )} UsePlugin\n * Create a processor based on the input/output of a {@link Plugin plugin}.\n */\n\n/**\n * @template {CompileResults | undefined} Result\n * Node type that the transformer yields.\n * @typedef {(\n * Result extends Value | undefined ?\n * VFile :\n * VFile & {result: Result}\n * )} VFileWithOutput\n * Type to generate a {@linkcode VFile} corresponding to a compiler result.\n *\n * If a result that is not acceptable on a `VFile` is used, that will\n * be stored on the `result` field of {@linkcode VFile}.\n */\n\nimport {bail} from 'bail'\nimport extend from 'extend'\nimport {ok as assert} from 'devlop'\nimport isPlainObj from 'is-plain-obj'\nimport {trough} from 'trough'\nimport {VFile} from 'vfile'\nimport {CallableInstance} from './callable-instance.js'\n\n// To do: next major: drop `Compiler`, `Parser`: prefer lowercase.\n\n// To do: we could start yielding `never` in TS when a parser is missing and\n// `parse` is called.\n// Currently, we allow directly setting `processor.parser`, which is untyped.\n\nconst own = {}.hasOwnProperty\n\n/**\n * @template {Node | undefined} [ParseTree=undefined]\n * Output of `parse` (optional).\n * @template {Node | undefined} [HeadTree=undefined]\n * Input for `run` (optional).\n * @template {Node | undefined} [TailTree=undefined]\n * Output for `run` (optional).\n * @template {Node | undefined} [CompileTree=undefined]\n * Input of `stringify` (optional).\n * @template {CompileResults | undefined} [CompileResult=undefined]\n * Output of `stringify` (optional).\n * @extends {CallableInstance<[], Processor>}\n */\nexport class Processor extends CallableInstance {\n /**\n * Create a processor.\n */\n constructor() {\n // If `Processor()` is called (w/o new), `copy` is called instead.\n super('copy')\n\n /**\n * Compiler to use (deprecated).\n *\n * @deprecated\n * Use `compiler` instead.\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.Compiler = undefined\n\n /**\n * Parser to use (deprecated).\n *\n * @deprecated\n * Use `parser` instead.\n * @type {(\n * Parser |\n * undefined\n * )}\n */\n this.Parser = undefined\n\n // Note: the following fields are considered private.\n // However, they are needed for tests, and TSC generates an untyped\n // `private freezeIndex` field for, which trips `type-coverage` up.\n // Instead, we use `@deprecated` to visualize that they shouldn’t be used.\n /**\n * Internal list of configured plugins.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Array>>}\n */\n this.attachers = []\n\n /**\n * Compiler to use.\n *\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.compiler = undefined\n\n /**\n * Internal state to track where we are while freezing.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {number}\n */\n this.freezeIndex = -1\n\n /**\n * Internal state to track whether we’re frozen.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {boolean | undefined}\n */\n this.frozen = undefined\n\n /**\n * Internal state.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Data}\n */\n this.namespace = {}\n\n /**\n * Parser to use.\n *\n * @type {(\n * Parser |\n * undefined\n * )}\n */\n this.parser = undefined\n\n /**\n * Internal list of configured transformers.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Pipeline}\n */\n this.transformers = trough()\n }\n\n /**\n * Copy a processor.\n *\n * @deprecated\n * This is a private internal method and should not be used.\n * @returns {Processor}\n * New *unfrozen* processor ({@linkcode Processor}) that is\n * configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\n copy() {\n // Cast as the type parameters will be the same after attaching.\n const destination =\n /** @type {Processor} */ (\n new Processor()\n )\n let index = -1\n\n while (++index < this.attachers.length) {\n const attacher = this.attachers[index]\n destination.use(...attacher)\n }\n\n destination.data(extend(true, {}, this.namespace))\n\n return destination\n }\n\n /**\n * Configure the processor with info available to all plugins.\n * Information is stored in an object.\n *\n * Typically, options can be given to a specific plugin, but sometimes it\n * makes sense to have information shared with several plugins.\n * For example, a list of HTML elements that are self-closing, which is\n * needed during all phases.\n *\n * > **Note**: setting information cannot occur on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * > **Note**: to register custom data in TypeScript, augment the\n * > {@linkcode Data} interface.\n *\n * @example\n * This example show how to get and set info:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * const processor = unified().data('alpha', 'bravo')\n *\n * processor.data('alpha') // => 'bravo'\n *\n * processor.data() // => {alpha: 'bravo'}\n *\n * processor.data({charlie: 'delta'})\n *\n * processor.data() // => {charlie: 'delta'}\n * ```\n *\n * @template {keyof Data} Key\n *\n * @overload\n * @returns {Data}\n *\n * @overload\n * @param {Data} dataset\n * @returns {Processor}\n *\n * @overload\n * @param {Key} key\n * @returns {Data[Key]}\n *\n * @overload\n * @param {Key} key\n * @param {Data[Key]} value\n * @returns {Processor}\n *\n * @param {Data | Key} [key]\n * Key to get or set, or entire dataset to set, or nothing to get the\n * entire dataset (optional).\n * @param {Data[Key]} [value]\n * Value to set (optional).\n * @returns {unknown}\n * The current processor when setting, the value at `key` when getting, or\n * the entire dataset when getting without key.\n */\n data(key, value) {\n if (typeof key === 'string') {\n // Set `key`.\n if (arguments.length === 2) {\n assertUnfrozen('data', this.frozen)\n this.namespace[key] = value\n return this\n }\n\n // Get `key`.\n return (own.call(this.namespace, key) && this.namespace[key]) || undefined\n }\n\n // Set space.\n if (key) {\n assertUnfrozen('data', this.frozen)\n this.namespace = key\n return this\n }\n\n // Get space.\n return this.namespace\n }\n\n /**\n * Freeze a processor.\n *\n * Frozen processors are meant to be extended and not to be configured\n * directly.\n *\n * When a processor is frozen it cannot be unfrozen.\n * New processors working the same way can be created by calling the\n * processor.\n *\n * It’s possible to freeze processors explicitly by calling `.freeze()`.\n * Processors freeze automatically when `.parse()`, `.run()`, `.runSync()`,\n * `.stringify()`, `.process()`, or `.processSync()` are called.\n *\n * @returns {Processor}\n * The current processor.\n */\n freeze() {\n if (this.frozen) {\n return this\n }\n\n // Cast so that we can type plugins easier.\n // Plugins are supposed to be usable on different processors, not just on\n // this exact processor.\n const self = /** @type {Processor} */ (/** @type {unknown} */ (this))\n\n while (++this.freezeIndex < this.attachers.length) {\n const [attacher, ...options] = this.attachers[this.freezeIndex]\n\n if (options[0] === false) {\n continue\n }\n\n if (options[0] === true) {\n options[0] = undefined\n }\n\n const transformer = attacher.call(self, ...options)\n\n if (typeof transformer === 'function') {\n this.transformers.use(transformer)\n }\n }\n\n this.frozen = true\n this.freezeIndex = Number.POSITIVE_INFINITY\n\n return this\n }\n\n /**\n * Parse text to a syntax tree.\n *\n * > **Note**: `parse` freezes the processor if not already *frozen*.\n *\n * > **Note**: `parse` performs the parse phase, not the run phase or other\n * > phases.\n *\n * @param {Compatible | undefined} [file]\n * file to parse (optional); typically `string` or `VFile`; any value\n * accepted as `x` in `new VFile(x)`.\n * @returns {ParseTree extends undefined ? Node : ParseTree}\n * Syntax tree representing `file`.\n */\n parse(file) {\n this.freeze()\n const realFile = vfile(file)\n const parser = this.parser || this.Parser\n assertParser('parse', parser)\n return parser(String(realFile), realFile)\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * > **Note**: `process` freezes the processor if not already *frozen*.\n *\n * > **Note**: `process` performs the parse, run, and stringify phases.\n *\n * @overload\n * @param {Compatible | undefined} file\n * @param {ProcessCallback>} done\n * @returns {undefined}\n *\n * @overload\n * @param {Compatible | undefined} [file]\n * @returns {Promise>}\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`]; any value accepted as\n * `x` in `new VFile(x)`.\n * @param {ProcessCallback> | undefined} [done]\n * Callback (optional).\n * @returns {Promise | undefined}\n * Nothing if `done` is given.\n * Otherwise a promise, rejected with a fatal error or resolved with the\n * processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n process(file, done) {\n const self = this\n\n this.freeze()\n assertParser('process', this.parser || this.Parser)\n assertCompiler('process', this.compiler || this.Compiler)\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {((file: VFileWithOutput) => undefined | void) | undefined} resolve\n * @param {(error: Error | undefined) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n const realFile = vfile(file)\n // Assume `ParseTree` (the result of the parser) matches `HeadTree` (the\n // input of the first transform).\n const parseTree =\n /** @type {HeadTree extends undefined ? Node : HeadTree} */ (\n /** @type {unknown} */ (self.parse(realFile))\n )\n\n self.run(parseTree, realFile, function (error, tree, file) {\n if (error || !tree || !file) {\n return realDone(error)\n }\n\n // Assume `TailTree` (the output of the last transform) matches\n // `CompileTree` (the input of the compiler).\n const compileTree =\n /** @type {CompileTree extends undefined ? Node : CompileTree} */ (\n /** @type {unknown} */ (tree)\n )\n\n const compileResult = self.stringify(compileTree, file)\n\n if (looksLikeAValue(compileResult)) {\n file.value = compileResult\n } else {\n file.result = compileResult\n }\n\n realDone(error, /** @type {VFileWithOutput} */ (file))\n })\n\n /**\n * @param {Error | undefined} error\n * @param {VFileWithOutput | undefined} [file]\n * @returns {undefined}\n */\n function realDone(error, file) {\n if (error || !file) {\n reject(error)\n } else if (resolve) {\n resolve(file)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, file)\n }\n }\n }\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `processSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `processSync` performs the parse, run, and stringify phases.\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`; any value accepted as\n * `x` in `new VFile(x)`.\n * @returns {VFileWithOutput}\n * The processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n processSync(file) {\n /** @type {boolean} */\n let complete = false\n /** @type {VFileWithOutput | undefined} */\n let result\n\n this.freeze()\n assertParser('processSync', this.parser || this.Parser)\n assertCompiler('processSync', this.compiler || this.Compiler)\n\n this.process(file, realDone)\n assertDone('processSync', 'process', complete)\n assert(result, 'we either bailed on an error or have a tree')\n\n return result\n\n /**\n * @type {ProcessCallback>}\n */\n function realDone(error, file) {\n complete = true\n bail(error)\n result = file\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * > **Note**: `run` freezes the processor if not already *frozen*.\n *\n * > **Note**: `run` performs the run phase, not other phases.\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {RunCallback} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} file\n * @param {RunCallback} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} [file]\n * @returns {Promise}\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {(\n * RunCallback |\n * Compatible\n * )} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @param {RunCallback} [done]\n * Callback (optional).\n * @returns {Promise | undefined}\n * Nothing if `done` is given.\n * Otherwise, a promise rejected with a fatal error or resolved with the\n * transformed tree.\n */\n run(tree, file, done) {\n assertNode(tree)\n this.freeze()\n\n const transformers = this.transformers\n\n if (!done && typeof file === 'function') {\n done = file\n file = undefined\n }\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {(\n * ((tree: TailTree extends undefined ? Node : TailTree) => undefined | void) |\n * undefined\n * )} resolve\n * @param {(error: Error) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n assert(\n typeof file !== 'function',\n '`file` can’t be a `done` anymore, we checked'\n )\n const realFile = vfile(file)\n transformers.run(tree, realFile, realDone)\n\n /**\n * @param {Error | undefined} error\n * @param {Node} outputTree\n * @param {VFile} file\n * @returns {undefined}\n */\n function realDone(error, outputTree, file) {\n const resultingTree =\n /** @type {TailTree extends undefined ? Node : TailTree} */ (\n outputTree || tree\n )\n\n if (error) {\n reject(error)\n } else if (resolve) {\n resolve(resultingTree)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, resultingTree, file)\n }\n }\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `runSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `runSync` performs the run phase, not other phases.\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {TailTree extends undefined ? Node : TailTree}\n * Transformed tree.\n */\n runSync(tree, file) {\n /** @type {boolean} */\n let complete = false\n /** @type {(TailTree extends undefined ? Node : TailTree) | undefined} */\n let result\n\n this.run(tree, file, realDone)\n\n assertDone('runSync', 'run', complete)\n assert(result, 'we either bailed on an error or have a tree')\n return result\n\n /**\n * @type {RunCallback}\n */\n function realDone(error, tree) {\n bail(error)\n result = tree\n complete = true\n }\n }\n\n /**\n * Compile a syntax tree.\n *\n * > **Note**: `stringify` freezes the processor if not already *frozen*.\n *\n * > **Note**: `stringify` performs the stringify phase, not the run phase\n * > or other phases.\n *\n * @param {CompileTree extends undefined ? Node : CompileTree} tree\n * Tree to compile.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {CompileResult extends undefined ? Value : CompileResult}\n * Textual representation of the tree (see note).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n stringify(tree, file) {\n this.freeze()\n const realFile = vfile(file)\n const compiler = this.compiler || this.Compiler\n assertCompiler('stringify', compiler)\n assertNode(tree)\n\n return compiler(tree, realFile)\n }\n\n /**\n * Configure the processor to use a plugin, a list of usable values, or a\n * preset.\n *\n * If the processor is already using a plugin, the previous plugin\n * configuration is changed based on the options that are passed in.\n * In other words, the plugin is not added a second time.\n *\n * > **Note**: `use` cannot be called on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * @example\n * There are many ways to pass plugins to `.use()`.\n * This example gives an overview:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * unified()\n * // Plugin with options:\n * .use(pluginA, {x: true, y: true})\n * // Passing the same plugin again merges configuration (to `{x: true, y: false, z: true}`):\n * .use(pluginA, {y: false, z: true})\n * // Plugins:\n * .use([pluginB, pluginC])\n * // Two plugins, the second with options:\n * .use([pluginD, [pluginE, {}]])\n * // Preset with plugins and settings:\n * .use({plugins: [pluginF, [pluginG, {}]], settings: {position: false}})\n * // Settings only:\n * .use({settings: {position: false}})\n * ```\n *\n * @template {Array} [Parameters=[]]\n * @template {Node | string | undefined} [Input=undefined]\n * @template [Output=Input]\n *\n * @overload\n * @param {Preset | null | undefined} [preset]\n * @returns {Processor}\n *\n * @overload\n * @param {PluggableList} list\n * @returns {Processor}\n *\n * @overload\n * @param {Plugin} plugin\n * @param {...(Parameters | [boolean])} parameters\n * @returns {UsePlugin}\n *\n * @param {PluggableList | Plugin | Preset | null | undefined} value\n * Usable value.\n * @param {...unknown} parameters\n * Parameters, when a plugin is given as a usable value.\n * @returns {Processor}\n * Current processor.\n */\n use(value, ...parameters) {\n const attachers = this.attachers\n const namespace = this.namespace\n\n assertUnfrozen('use', this.frozen)\n\n if (value === null || value === undefined) {\n // Empty.\n } else if (typeof value === 'function') {\n addPlugin(value, parameters)\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n addList(value)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n\n return this\n\n /**\n * @param {Pluggable} value\n * @returns {undefined}\n */\n function add(value) {\n if (typeof value === 'function') {\n addPlugin(value, [])\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n const [plugin, ...parameters] =\n /** @type {PluginTuple>} */ (value)\n addPlugin(plugin, parameters)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n }\n\n /**\n * @param {Preset} result\n * @returns {undefined}\n */\n function addPreset(result) {\n if (!('plugins' in result) && !('settings' in result)) {\n throw new Error(\n 'Expected usable value but received an empty preset, which is probably a mistake: presets typically come with `plugins` and sometimes with `settings`, but this has neither'\n )\n }\n\n addList(result.plugins)\n\n if (result.settings) {\n namespace.settings = extend(true, namespace.settings, result.settings)\n }\n }\n\n /**\n * @param {PluggableList | null | undefined} plugins\n * @returns {undefined}\n */\n function addList(plugins) {\n let index = -1\n\n if (plugins === null || plugins === undefined) {\n // Empty.\n } else if (Array.isArray(plugins)) {\n while (++index < plugins.length) {\n const thing = plugins[index]\n add(thing)\n }\n } else {\n throw new TypeError('Expected a list of plugins, not `' + plugins + '`')\n }\n }\n\n /**\n * @param {Plugin} plugin\n * @param {Array} parameters\n * @returns {undefined}\n */\n function addPlugin(plugin, parameters) {\n let index = -1\n let entryIndex = -1\n\n while (++index < attachers.length) {\n if (attachers[index][0] === plugin) {\n entryIndex = index\n break\n }\n }\n\n if (entryIndex === -1) {\n attachers.push([plugin, ...parameters])\n }\n // Only set if there was at least a `primary` value, otherwise we’d change\n // `arguments.length`.\n else if (parameters.length > 0) {\n let [primary, ...rest] = parameters\n const currentPrimary = attachers[entryIndex][1]\n if (isPlainObj(currentPrimary) && isPlainObj(primary)) {\n primary = extend(true, currentPrimary, primary)\n }\n\n attachers[entryIndex] = [plugin, primary, ...rest]\n }\n }\n }\n}\n\n// Note: this returns a *callable* instance.\n// That’s why it’s documented as a function.\n/**\n * Create a new processor.\n *\n * @example\n * This example shows how a new processor can be created (from `remark`) and linked\n * to **stdin**(4) and **stdout**(4).\n *\n * ```js\n * import process from 'node:process'\n * import concatStream from 'concat-stream'\n * import {remark} from 'remark'\n *\n * process.stdin.pipe(\n * concatStream(function (buf) {\n * process.stdout.write(String(remark().processSync(buf)))\n * })\n * )\n * ```\n *\n * @returns\n * New *unfrozen* processor (`processor`).\n *\n * This processor is configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\nexport const unified = new Processor().freeze()\n\n/**\n * Assert a parser is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Parser}\n */\nfunction assertParser(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `parser`')\n }\n}\n\n/**\n * Assert a compiler is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Compiler}\n */\nfunction assertCompiler(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `compiler`')\n }\n}\n\n/**\n * Assert the processor is not frozen.\n *\n * @param {string} name\n * @param {unknown} frozen\n * @returns {asserts frozen is false}\n */\nfunction assertUnfrozen(name, frozen) {\n if (frozen) {\n throw new Error(\n 'Cannot call `' +\n name +\n '` on a frozen processor.\\nCreate a new processor first, by calling it: use `processor()` instead of `processor`.'\n )\n }\n}\n\n/**\n * Assert `node` is a unist node.\n *\n * @param {unknown} node\n * @returns {asserts node is Node}\n */\nfunction assertNode(node) {\n // `isPlainObj` unfortunately uses `any` instead of `unknown`.\n // type-coverage:ignore-next-line\n if (!isPlainObj(node) || typeof node.type !== 'string') {\n throw new TypeError('Expected node, got `' + node + '`')\n // Fine.\n }\n}\n\n/**\n * Assert that `complete` is `true`.\n *\n * @param {string} name\n * @param {string} asyncName\n * @param {unknown} complete\n * @returns {asserts complete is true}\n */\nfunction assertDone(name, asyncName, complete) {\n if (!complete) {\n throw new Error(\n '`' + name + '` finished async. Use `' + asyncName + '` instead'\n )\n }\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {VFile}\n */\nfunction vfile(value) {\n return looksLikeAVFile(value) ? value : new VFile(value)\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {value is VFile}\n */\nfunction looksLikeAVFile(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'message' in value &&\n 'messages' in value\n )\n}\n\n/**\n * @param {unknown} [value]\n * @returns {value is Value}\n */\nfunction looksLikeAValue(value) {\n return typeof value === 'string' || isUint8Array(value)\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","/*!\n * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: GPL-3.0-or-later\n */\n/**\n * @module public\n */\nimport { loadState } from '@nextcloud/initial-state';\n/**\n * Check if the current page is on a public share\n */\nexport function isPublicShare() {\n // check both the new initial state version and fallback to legacy input\n return (loadState('files_sharing', 'isPublic', null)\n ?? document.querySelector('input#isPublic[type=\"hidden\"][name=\"isPublic\"][value=\"1\"]') !== null);\n}\n/**\n * Get the sharing token for the current public share\n */\nexport function getSharingToken() {\n return (loadState('files_sharing', 'sharingToken', null)\n ?? document.querySelector('input#sharingToken[type=\"hidden\"]')?.value\n ?? null);\n}\n","import { l as logger } from \"./logger-D3RVzcfQ.mjs\";\nwindow._vue_richtext_widgets ??= {};\nwindow._registerWidget ??= (id, callback, onDestroy, props) => {\n registerWidget(id, callback, onDestroy, props);\n};\nfunction registerWidget(id, callback, onDestroy = () => {\n}, props) {\n const propsWithDefaults = {\n hasInteractiveView: true,\n fullWidth: false,\n ...props\n };\n if (window._vue_richtext_widgets[id]) {\n logger.error(`[ReferencePicker]: Widget for id ${id} already registered`);\n return;\n }\n window._vue_richtext_widgets[id] = {\n id,\n callback,\n onDestroy,\n ...propsWithDefaults\n };\n}\nfunction renderWidget(el, options) {\n const { richObjectType, richObject, accessible, interactive } = options;\n if (richObjectType === \"open-graph\") {\n return;\n }\n if (!window._vue_richtext_widgets[richObjectType]) {\n logger.error(\"Widget for rich object type \" + richObjectType + \" not registered\");\n return;\n }\n window._vue_richtext_widgets[richObjectType].callback(el, { richObjectType, richObject, accessible, interactive });\n}\nfunction destroyWidget(richObjectType, el) {\n if (richObjectType === \"open-graph\") {\n return;\n }\n if (!window._vue_richtext_widgets[richObjectType]) {\n return;\n }\n window._vue_richtext_widgets[richObjectType].onDestroy(el);\n}\nfunction isWidgetRegistered(id) {\n return !!window._vue_richtext_widgets[id];\n}\nfunction hasInteractiveView(id) {\n return !!window._vue_richtext_widgets[id]?.hasInteractiveView;\n}\nfunction hasFullWidth(id) {\n return !!window._vue_richtext_widgets[id]?.fullWidth;\n}\nwindow._vue_richtext_custom_picker_elements ??= {};\nwindow._registerCustomPickerElement ??= registerCustomPickerElement;\nclass NcCustomPickerRenderResult {\n element;\n object;\n /**\n * @param element - The HTML element\n * @param object - The object\n */\n constructor(element, object) {\n this.element = element;\n this.object = object;\n }\n}\nfunction isCustomPickerElementRegistered(id) {\n return !!window._vue_richtext_custom_picker_elements[id];\n}\nfunction getCustomPickerElementSize(id) {\n const size = window._vue_richtext_custom_picker_elements[id]?.size;\n if (size && [\"small\", \"normal\", \"large\", \"full\"].includes(size)) {\n return size;\n }\n return null;\n}\nfunction registerCustomPickerElement(id, callback, onDestroy = () => {\n}, size = \"large\") {\n if (window._vue_richtext_custom_picker_elements[id]) {\n logger.error(`Custom reference picker element for id ${id} already registered`);\n return;\n }\n window._vue_richtext_custom_picker_elements[id] = {\n id,\n callback,\n onDestroy,\n size\n };\n}\nfunction renderCustomPickerElement(el, options) {\n const { providerId, accessible } = options;\n if (!window._vue_richtext_custom_picker_elements[providerId]) {\n logger.error(`Custom reference picker element for reference provider ID ${providerId} not registered`);\n return;\n }\n return window._vue_richtext_custom_picker_elements[providerId].callback(el, { providerId, accessible });\n}\nfunction destroyCustomPickerElement(providerId, el, renderResult) {\n if (!window._vue_richtext_custom_picker_elements[providerId]) {\n return;\n }\n window._vue_richtext_custom_picker_elements[providerId].onDestroy(el, renderResult);\n}\nexport {\n NcCustomPickerRenderResult as N,\n renderWidget as a,\n destroyCustomPickerElement as b,\n isCustomPickerElementRegistered as c,\n destroyWidget as d,\n registerCustomPickerElement as e,\n renderCustomPickerElement as f,\n getCustomPickerElementSize as g,\n hasInteractiveView as h,\n isWidgetRegistered as i,\n hasFullWidth as j,\n registerWidget as r\n};\n//# sourceMappingURL=customPickerElements-4pQTZUnk.mjs.map\n","/**\n * @typedef {import('unist').Node} Node\n */\n\n/**\n * @typedef {Array | string} ChildrenOrValue\n * List to use as `children` or value to use as `value`.\n *\n * @typedef {Record} Props\n * Other fields to add to the node.\n */\n\n/**\n * Build a node.\n *\n * @template {string} T\n * @template {Props} P\n * @template {Array} C\n *\n * @overload\n * @param {T} type\n * @returns {{type: T}}\n *\n * @overload\n * @param {T} type\n * @param {P} props\n * @returns {{type: T} & P}\n *\n * @overload\n * @param {T} type\n * @param {string} value\n * @returns {{type: T, value: string}}\n *\n * @overload\n * @param {T} type\n * @param {P} props\n * @param {string} value\n * @returns {{type: T, value: string} & P}\n *\n * @overload\n * @param {T} type\n * @param {C} children\n * @returns {{type: T, children: C}}\n *\n * @overload\n * @param {T} type\n * @param {P} props\n * @param {C} children\n * @returns {{type: T, children: C} & P}\n *\n * @param {string} type\n * Node type.\n * @param {ChildrenOrValue | Props | null | undefined} [props]\n * Fields assigned to node (default: `undefined`).\n * @param {ChildrenOrValue | null | undefined} [value]\n * Children of node or value of `node` (cast to string).\n * @returns {Node}\n * Built node.\n */\nexport function u(type, props, value) {\n /** @type {Node} */\n const node = {type: String(type)}\n\n if (\n (value === undefined || value === null) &&\n (typeof props === 'string' || Array.isArray(props))\n ) {\n value = props\n } else {\n Object.assign(node, props)\n }\n\n if (Array.isArray(value)) {\n // @ts-expect-error: create a parent.\n node.children = value\n } else if (value !== undefined && value !== null) {\n // @ts-expect-error: create a literal.\n node.value = String(value)\n }\n\n return node\n}\n","import { getBaseUrl, getRootUrl } from \"@nextcloud/router\";\nimport { u } from \"unist-builder\";\nimport { visit, SKIP } from \"unist-util-visit\";\nimport { defineComponent, h } from \"vue\";\nimport { l as logger } from \"./logger-D3RVzcfQ.mjs\";\n/*!\n * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nconst URL_PATTERN = /(\\s|^)(https?:\\/\\/)([-A-Z0-9+_.]+(?::[0-9]+)?(?:\\/[-A-Z0-9+&@#%?=~_|!:,.;()]*)*)(\\s|$)/ig;\nconst URL_PATTERN_AUTOLINK = /(\\s|\\(|^)((https?:\\/\\/)([-A-Z0-9+_.]+[-A-Z0-9]+(?::[0-9]+)?(?:\\/[-A-Z0-9+&@#%?=~_|!:,.;()]*)*))(?=\\s|\\)|$)/ig;\nconst NcLink = defineComponent({\n name: \"NcLink\",\n props: {\n href: {\n type: String,\n required: true\n }\n },\n render() {\n return h(\"a\", {\n href: this.href,\n rel: \"noopener noreferrer\",\n target: \"_blank\",\n class: \"rich-text--external-link\"\n }, [this.href.trim()]);\n }\n});\nfunction remarkAutolink({ autolink, useMarkdown, useExtendedMarkdown }) {\n return function(tree) {\n if (useExtendedMarkdown || !useMarkdown || !autolink) {\n return;\n }\n visit(tree, (node) => node.type === \"text\", (node, index, parent) => {\n let parsed = parseUrl(node.value);\n if (typeof parsed === \"string\") {\n parsed = [u(\"text\", parsed)];\n } else {\n parsed = parsed.map((n) => {\n if (typeof n === \"string\") {\n return u(\"text\", n);\n }\n return u(\"link\", {\n url: n.props.href\n }, [u(\"text\", n.props.href)]);\n }).filter((x) => x).flat();\n }\n parent.children.splice(index, 1, ...parsed);\n return [SKIP, (index ?? 0) + parsed.length];\n });\n };\n}\nfunction parseUrl(text) {\n let match = URL_PATTERN_AUTOLINK.exec(text);\n const list = [];\n let start = 0;\n while (match !== null) {\n let href = match[2];\n let textAfter;\n let textBefore = text.substring(start, match.index + match[1].length);\n if (href[0] === \" \") {\n textBefore += href[0];\n href = href.substring(1).trim();\n }\n const lastChar = href[href.length - 1];\n if (lastChar === \".\" || lastChar === \",\" || lastChar === \";\" || match[0][0] === \"(\" && lastChar === \")\") {\n href = href.substring(0, href.length - 1);\n textAfter = lastChar;\n }\n list.push(textBefore);\n list.push({ component: NcLink, props: { href } });\n if (textAfter) {\n list.push(textAfter);\n }\n start = match.index + match[0].length;\n match = URL_PATTERN_AUTOLINK.exec(text);\n }\n list.push(text.substring(start));\n const joinedText = list.map((item) => typeof item === \"string\" ? item : item.props.href).join(\"\");\n if (text === joinedText) {\n return list;\n }\n logger.error(\"[NcRichText] Failed to reassemble the chunked text: \" + text);\n return text;\n}\nfunction getRoute(router, url) {\n const removePrefix = (str, prefix) => str.startsWith(prefix) ? str.slice(prefix.length) : str;\n const removePrefixes = (str, ...prefixes) => prefixes.reduce((acc, prefix) => removePrefix(acc, prefix), str);\n if (!router) {\n return null;\n }\n const isAbsoluteURL = /^https?:\\/\\//.test(url);\n const isNonHttpLink = /^[a-z][a-z0-9+.-]*:.+/.test(url);\n if (!isAbsoluteURL && isNonHttpLink) {\n return null;\n }\n if (isAbsoluteURL && !url.startsWith(getBaseUrl())) {\n return null;\n }\n if (!isAbsoluteURL && !url.startsWith(\"/\")) {\n return null;\n }\n const relativeUrl = isAbsoluteURL ? removePrefixes(url, getBaseUrl(), \"/index.php\") : url;\n const relativeRouterBase = removePrefixes(router.options.history.base, getRootUrl(), \"/index.php\");\n const potentialRouterPath = removePrefixes(relativeUrl, relativeRouterBase) || \"/\";\n const route = router.resolve(potentialRouterPath);\n if (!route.matched.length) {\n return null;\n }\n return route.fullPath;\n}\nexport {\n URL_PATTERN as U,\n getRoute as g,\n parseUrl as p,\n remarkAutolink as r\n};\n//# sourceMappingURL=autolink-U5pBzLgI.mjs.map\n","import { defineComponent, mergeModels, useModel, useTemplateRef, computed, createBlock, openBlock, unref, mergeProps, createSlots, withCtx, renderSlot } from \"vue\";\nimport { m as mdiArrowRight, a as mdiUndo, b as mdiClose } from \"./mdi-D_GPbmUY.mjs\";\nimport { r as register, a as t } from \"./_l10n-CeXHJQB0.mjs\";\nimport { N as NcIconSvgWrapper } from \"./NcIconSvgWrapper-5AA93z-F.mjs\";\nimport { N as NcInputField } from \"./NcInputField-D5lRaUiK.mjs\";\nregister();\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcTextField\",\n props: /* @__PURE__ */ mergeModels({\n class: {},\n inputClass: {},\n id: {},\n label: {},\n labelOutside: { type: Boolean },\n type: {},\n placeholder: {},\n showTrailingButton: { type: Boolean },\n trailingButtonLabel: { default: void 0 },\n success: { type: Boolean },\n error: { type: Boolean },\n helperText: {},\n disabled: { type: Boolean },\n pill: { type: Boolean },\n trailingButtonIcon: { default: \"close\" }\n }, {\n \"modelValue\": { default: \"\" },\n \"modelModifiers\": {}\n }),\n emits: [\"update:modelValue\"],\n setup(__props, { expose: __expose }) {\n const modelValue = useModel(__props, \"modelValue\");\n const props = __props;\n __expose({\n focus,\n select\n });\n const inputFieldInstance = useTemplateRef(\"inputField\");\n const defaultTrailingButtonLabels = {\n arrowEnd: t(\"Save changes\"),\n close: t(\"Clear text\"),\n undo: t(\"Undo changes\")\n };\n const NcInputFieldPropNames = new Set(Object.keys(NcInputField.props));\n const propsToForward = computed(() => {\n const sharedProps = Object.fromEntries(Object.entries(props).filter(([key]) => NcInputFieldPropNames.has(key)));\n sharedProps.trailingButtonLabel ??= defaultTrailingButtonLabels[props.trailingButtonIcon];\n return sharedProps;\n });\n function focus(options) {\n inputFieldInstance.value.focus(options);\n }\n function select() {\n inputFieldInstance.value.select();\n }\n return (_ctx, _cache) => {\n return openBlock(), createBlock(unref(NcInputField), mergeProps(propsToForward.value, {\n ref: \"inputField\",\n modelValue: modelValue.value,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => modelValue.value = $event)\n }), createSlots({ _: 2 }, [\n !!_ctx.$slots.icon ? {\n name: \"icon\",\n fn: withCtx(() => [\n renderSlot(_ctx.$slots, \"icon\")\n ]),\n key: \"0\"\n } : void 0,\n _ctx.type !== \"search\" ? {\n name: \"trailing-button-icon\",\n fn: withCtx(() => [\n _ctx.trailingButtonIcon === \"arrowEnd\" ? (openBlock(), createBlock(unref(NcIconSvgWrapper), {\n key: 0,\n directional: \"\",\n path: unref(mdiArrowRight)\n }, null, 8, [\"path\"])) : (openBlock(), createBlock(unref(NcIconSvgWrapper), {\n key: 1,\n path: _ctx.trailingButtonIcon === \"undo\" ? unref(mdiUndo) : unref(mdiClose)\n }, null, 8, [\"path\"]))\n ]),\n key: \"1\"\n } : void 0\n ]), 1040, [\"modelValue\"]);\n };\n }\n});\nexport {\n _sfc_main as _\n};\n//# sourceMappingURL=NcTextField.vue_vue_type_script_setup_true_lang-C7tMhmsN.mjs.map\n","import '../assets/referencePickerModal-B9tq1n_R.css';\nimport { createElementBlock, openBlock, mergeProps, createElementVNode, createCommentVNode, toDisplayString, resolveComponent, createVNode, withCtx, ref, nextTick, normalizeClass, createBlock, resolveDynamicComponent, normalizeStyle, createTextVNode, withKeys, withModifiers, createApp } from \"vue\";\nimport { emit } from \"@nextcloud/event-bus\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nimport { I as IconClose } from \"./Close-D6ngJ4t9.mjs\";\nimport { f as renderCustomPickerElement, b as destroyCustomPickerElement, c as isCustomPickerElementRegistered, d as destroyWidget, a as renderWidget, i as isWidgetRegistered, h as hasInteractiveView, j as hasFullWidth, g as getCustomPickerElementSize } from \"./customPickerElements-4pQTZUnk.mjs\";\nimport axios from \"@nextcloud/axios\";\nimport { loadState } from \"@nextcloud/initial-state\";\nimport { imagePath, generateOcsUrl } from \"@nextcloud/router\";\nimport { r as register, F as t8, a as t, G as t43, H as t39, I as t23, J as t24, j as t41, K as t31, p as t19, L as t12 } from \"./_l10n-CeXHJQB0.mjs\";\nimport { l as logger } from \"./logger-D3RVzcfQ.mjs\";\nimport { N as NcEmptyContent } from \"./NcEmptyContent-BdOezubv.mjs\";\nimport { _ as _sfc_main$a } from \"./NcHighlight.vue_vue_type_script_lang-DnWQDM_2.mjs\";\nimport { N as NcSelect } from \"./NcSelect-D8ZEOizf.mjs\";\nimport debounce from \"debounce\";\nimport { useElementSize, useIntersectionObserver } from \"@vueuse/core\";\nimport { RouterLink } from \"vue-router\";\nimport { N as NcButton } from \"./NcButton-DkC5k3Lb.mjs\";\nimport { g as getRoute } from \"./autolink-U5pBzLgI.mjs\";\nimport { N as NcLoadingIcon } from \"./NcLoadingIcon-b_ajZ_nQ.mjs\";\nimport { _ as _sfc_main$b } from \"./NcTextField.vue_vue_type_script_setup_true_lang-C7tMhmsN.mjs\";\nimport { I as IconDotsHorizontal } from \"./NcActions-B1Zg0lCE.mjs\";\nimport { N as NcModal } from \"./NcModal-vyUsS1qu.mjs\";\nconst _sfc_main$9 = {\n name: \"ArrowLeftIcon\",\n emits: [\"click\"],\n props: {\n title: {\n type: String\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n};\nconst _hoisted_1$9 = [\"aria-hidden\", \"aria-label\"];\nconst _hoisted_2$7 = [\"fill\", \"width\", \"height\"];\nconst _hoisted_3$6 = { d: \"M20,11V13H8L13.5,18.5L12.08,19.92L4.16,12L12.08,4.08L13.5,5.5L8,11H20Z\" };\nconst _hoisted_4$5 = { key: 0 };\nfunction _sfc_render$9(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"span\", mergeProps(_ctx.$attrs, {\n \"aria-hidden\": $props.title ? null : \"true\",\n \"aria-label\": $props.title,\n class: \"material-design-icon arrow-left-icon\",\n role: \"img\",\n onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit(\"click\", $event))\n }), [\n (openBlock(), createElementBlock(\"svg\", {\n fill: $props.fillColor,\n class: \"material-design-icon__svg\",\n width: $props.size,\n height: $props.size,\n viewBox: \"0 0 24 24\"\n }, [\n createElementVNode(\"path\", _hoisted_3$6, [\n $props.title ? (openBlock(), createElementBlock(\"title\", _hoisted_4$5, toDisplayString($props.title), 1)) : createCommentVNode(\"\", true)\n ])\n ], 8, _hoisted_2$7))\n ], 16, _hoisted_1$9);\n}\nconst ArrowLeftIcon = /* @__PURE__ */ _export_sfc(_sfc_main$9, [[\"render\", _sfc_render$9]]);\nconst _sfc_main$8 = {\n name: \"NcCustomPickerElement\",\n props: {\n /**\n * The reference provider\n */\n provider: {\n type: Object,\n required: true\n }\n },\n emits: [\n \"cancel\",\n \"submit\"\n ],\n data() {\n return {\n isRegistered: isCustomPickerElementRegistered(this.provider.id),\n renderResult: null\n };\n },\n mounted() {\n if (this.isRegistered) {\n this.renderElement();\n }\n },\n beforeUnmount() {\n if (this.isRegistered) {\n destroyCustomPickerElement(this.provider.id, this.$el, this.renderResult);\n }\n },\n methods: {\n renderElement() {\n if (this.$refs.domElement) {\n this.$refs.domElement.innerHTML = \"\";\n }\n const renderFunctionResult = renderCustomPickerElement(this.$refs.domElement, { providerId: this.provider.id, accessible: false });\n Promise.resolve(renderFunctionResult).then((result) => {\n this.renderResult = result;\n if (this.renderResult.object?._isVue && this.renderResult.object?.$on) {\n this.renderResult.object.$on(\"submit\", this.onSubmit);\n this.renderResult.object.$on(\"cancel\", this.onCancel);\n }\n this.renderResult.element.addEventListener(\"submit\", (e) => {\n this.onSubmit(e.detail);\n });\n this.renderResult.element.addEventListener(\"cancel\", this.onCancel);\n });\n },\n onSubmit(value) {\n this.$emit(\"submit\", value);\n },\n onCancel() {\n this.$emit(\"cancel\");\n }\n }\n};\nconst _hoisted_1$8 = { ref: \"domElement\" };\nfunction _sfc_render$8(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"div\", _hoisted_1$8, null, 512);\n}\nconst NcCustomPickerElement = /* @__PURE__ */ _export_sfc(_sfc_main$8, [[\"render\", _sfc_render$8], [\"__scopeId\", \"data-v-e408867a\"]]);\nconst _sfc_main$7 = {\n name: \"LinkVariantIcon\",\n emits: [\"click\"],\n props: {\n title: {\n type: String\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n};\nconst _hoisted_1$7 = [\"aria-hidden\", \"aria-label\"];\nconst _hoisted_2$6 = [\"fill\", \"width\", \"height\"];\nconst _hoisted_3$5 = { d: \"M10.59,13.41C11,13.8 11,14.44 10.59,14.83C10.2,15.22 9.56,15.22 9.17,14.83C7.22,12.88 7.22,9.71 9.17,7.76V7.76L12.71,4.22C14.66,2.27 17.83,2.27 19.78,4.22C21.73,6.17 21.73,9.34 19.78,11.29L18.29,12.78C18.3,11.96 18.17,11.14 17.89,10.36L18.36,9.88C19.54,8.71 19.54,6.81 18.36,5.64C17.19,4.46 15.29,4.46 14.12,5.64L10.59,9.17C9.41,10.34 9.41,12.24 10.59,13.41M13.41,9.17C13.8,8.78 14.44,8.78 14.83,9.17C16.78,11.12 16.78,14.29 14.83,16.24V16.24L11.29,19.78C9.34,21.73 6.17,21.73 4.22,19.78C2.27,17.83 2.27,14.66 4.22,12.71L5.71,11.22C5.7,12.04 5.83,12.86 6.11,13.65L5.64,14.12C4.46,15.29 4.46,17.19 5.64,18.36C6.81,19.54 8.71,19.54 9.88,18.36L13.41,14.83C14.59,13.66 14.59,11.76 13.41,10.59C13,10.2 13,9.56 13.41,9.17Z\" };\nconst _hoisted_4$4 = { key: 0 };\nfunction _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"span\", mergeProps(_ctx.$attrs, {\n \"aria-hidden\": $props.title ? null : \"true\",\n \"aria-label\": $props.title,\n class: \"material-design-icon link-variant-icon\",\n role: \"img\",\n onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit(\"click\", $event))\n }), [\n (openBlock(), createElementBlock(\"svg\", {\n fill: $props.fillColor,\n class: \"material-design-icon__svg\",\n width: $props.size,\n height: $props.size,\n viewBox: \"0 0 24 24\"\n }, [\n createElementVNode(\"path\", _hoisted_3$5, [\n $props.title ? (openBlock(), createElementBlock(\"title\", _hoisted_4$4, toDisplayString($props.title), 1)) : createCommentVNode(\"\", true)\n ])\n ], 8, _hoisted_2$6))\n ], 16, _hoisted_1$7);\n}\nconst LinkVariantIcon = /* @__PURE__ */ _export_sfc(_sfc_main$7, [[\"render\", _sfc_render$7]]);\nregister(t8);\nconst anyLinkProviderId = \"any-link\";\nconst anyLinkProvider = {\n id: anyLinkProviderId,\n title: t(\"Any link\"),\n order: 0,\n icon_url: imagePath(\"core\", \"filetypes/link.svg\")\n};\nwindow._vue_richtext_reference_providers ??= loadState(\"core\", \"reference-provider-list\", []);\nwindow._vue_richtext_reference_provider_timestamps ??= loadState(\"core\", \"reference-provider-timestamps\", {});\nfunction getProvider(providerId) {\n if (providerId === anyLinkProviderId) {\n return anyLinkProvider;\n }\n return getProviders().find((p) => p.id === providerId);\n}\nfunction getProviders() {\n return window._vue_richtext_reference_providers.filter((p) => {\n const keep = !!p.search_providers_ids && p.search_providers_ids.length > 0 || isCustomPickerElementRegistered(p.id);\n if (!keep) {\n logger.debug(`[smart picker] ${p.id} reference provider is discoverable but does not have any related search provider or custom picker component registered`);\n }\n return keep;\n });\n}\nfunction sortProviders(providerList) {\n const timestamps = window._vue_richtext_reference_provider_timestamps;\n return providerList.sort((a, b) => {\n return a.order === b.order ? 0 : a.order > b.order ? 1 : -1;\n }).sort((a, b) => {\n const ta = timestamps[a.id];\n const tb = timestamps[b.id];\n return ta === tb ? 0 : tb === void 0 ? -1 : ta === void 0 ? 1 : ta > tb ? -1 : 1;\n });\n}\nfunction searchProvider(query, limit) {\n const providers = getProviders();\n const escapedQuery = query.replace(/[/\\-\\\\^$*+?.()|[\\]{}]/g, \"\\\\$&\");\n const regexp = new RegExp(escapedQuery, \"i\");\n const sortedProviders = sortProviders(providers);\n const filteredSortedProviders = sortedProviders.filter((p) => {\n return p.title.match(regexp);\n });\n const searchResult = limit ? filteredSortedProviders.slice(0, limit) : filteredSortedProviders;\n if (query === \"\" || searchResult.length === 0) {\n searchResult.push(anyLinkProvider);\n }\n return searchResult;\n}\nasync function touchProvider(providerId) {\n const timestamp = Math.floor(Date.now() / 1e3);\n const url = generateOcsUrl(\"references/provider/{providerId}\", { providerId });\n await axios.put(url, { timestamp });\n window._vue_richtext_reference_provider_timestamps[providerId] = timestamp;\n}\nregister(t39, t43);\n/*!\n * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction isUrl(str) {\n try {\n return Boolean(new URL(str));\n } catch {\n return false;\n }\n}\nconst _sfc_main$6 = {\n name: \"NcProviderList\",\n components: {\n NcSelect,\n NcHighlight: _sfc_main$a,\n NcEmptyContent,\n LinkVariantIcon\n },\n emits: [\n \"selectProvider\",\n \"submit\"\n ],\n data() {\n return {\n selectedProvider: null,\n query: \"\",\n multiselectPlaceholder: t(\"Select provider\"),\n providerIconAlt: t(\"Provider icon\")\n };\n },\n computed: {\n options() {\n const result = [];\n if (this.query !== \"\" && isUrl(this.query)) {\n result.push({\n id: this.query,\n title: this.query,\n isLink: true\n });\n }\n result.push(...searchProvider(this.query));\n return result;\n }\n },\n methods: {\n focus() {\n setTimeout(() => {\n this.$refs[\"provider-select\"]?.$el?.querySelector(\"#provider-select-input\")?.focus();\n }, 300);\n },\n onProviderSelected(p) {\n if (p !== null) {\n if (p.isLink) {\n this.$emit(\"submit\", p.title);\n } else {\n this.$emit(\"selectProvider\", p);\n }\n this.selectedProvider = null;\n }\n },\n onSearch(query) {\n this.query = query;\n }\n }\n};\nconst _hoisted_1$6 = { class: \"provider-list\" };\nconst _hoisted_2$5 = {\n key: 0,\n class: \"provider\"\n};\nconst _hoisted_3$4 = {\n key: 1,\n class: \"provider\"\n};\nconst _hoisted_4$3 = [\"src\", \"alt\"];\nfunction _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_LinkVariantIcon = resolveComponent(\"LinkVariantIcon\");\n const _component_NcHighlight = resolveComponent(\"NcHighlight\");\n const _component_NcSelect = resolveComponent(\"NcSelect\");\n const _component_NcEmptyContent = resolveComponent(\"NcEmptyContent\");\n return openBlock(), createElementBlock(\"div\", _hoisted_1$6, [\n createVNode(_component_NcSelect, {\n ref: \"provider-select\",\n modelValue: $data.selectedProvider,\n \"onUpdate:modelValue\": [\n _cache[0] || (_cache[0] = ($event) => $data.selectedProvider = $event),\n $options.onProviderSelected\n ],\n class: \"provider-list--select\",\n \"input-id\": \"provider-select-input\",\n label: \"title\",\n placeholder: $data.multiselectPlaceholder,\n options: $options.options,\n \"append-to-body\": false,\n \"clear-search-on-select\": true,\n \"clear-search-on-blur\": () => false,\n filterable: false,\n onSearch: $options.onSearch\n }, {\n option: withCtx((option) => [\n option.isLink ? (openBlock(), createElementBlock(\"div\", _hoisted_2$5, [\n createVNode(_component_LinkVariantIcon, {\n class: \"link-icon\",\n size: 20\n }),\n createElementVNode(\"span\", null, toDisplayString(option.title), 1)\n ])) : (openBlock(), createElementBlock(\"div\", _hoisted_3$4, [\n createElementVNode(\"img\", {\n class: \"provider-icon\",\n src: option.icon_url,\n alt: $data.providerIconAlt\n }, null, 8, _hoisted_4$3),\n createVNode(_component_NcHighlight, {\n class: \"option-text\",\n search: $data.query,\n text: option.title\n }, null, 8, [\"search\", \"text\"])\n ]))\n ]),\n _: 1\n }, 8, [\"modelValue\", \"placeholder\", \"options\", \"onSearch\", \"onUpdate:modelValue\"]),\n createVNode(_component_NcEmptyContent, { class: \"provider-list--empty-content\" }, {\n icon: withCtx(() => [\n createVNode(_component_LinkVariantIcon)\n ]),\n _: 1\n })\n ]);\n}\nconst NcProviderList = /* @__PURE__ */ _export_sfc(_sfc_main$6, [[\"render\", _sfc_render$6], [\"__scopeId\", \"data-v-90c6aa3b\"]]);\nregister(t23);\nconst IDLE_TIMEOUT = 3 * 60 * 1e3;\nconst _sfc_main$5 = {\n name: \"NcReferenceWidget\",\n components: {\n NcButton\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n reference: {\n type: Object,\n required: true\n },\n interactive: {\n type: Boolean,\n default: true\n },\n interactiveOptIn: {\n type: Boolean,\n default: false\n }\n },\n setup() {\n const isVisible = ref(false);\n const widgetRoot = ref();\n const { width } = useElementSize(widgetRoot);\n useIntersectionObserver(widgetRoot, ([entry]) => {\n nextTick(() => {\n isVisible.value = entry.isIntersecting;\n });\n });\n return {\n width,\n isVisible,\n widgetRoot\n };\n },\n data() {\n return {\n showInteractive: false,\n rendered: false,\n idleTimeout: null\n };\n },\n computed: {\n isInteractive() {\n return !this.interactiveOptIn && this.interactive || this.showInteractive;\n },\n hasFullWidth() {\n return hasFullWidth(this.reference.richObjectType);\n },\n hasCustomWidget() {\n return isWidgetRegistered(this.reference.richObjectType);\n },\n hasInteractiveView() {\n return isWidgetRegistered(this.reference.richObjectType) && hasInteractiveView(this.reference.richObjectType);\n },\n noAccess() {\n return this.reference && !this.reference.accessible;\n },\n descriptionStyle() {\n if (this.numberOfLines === 0) {\n return {\n display: \"none\"\n };\n }\n const lineClamp = this.numberOfLines;\n return {\n lineClamp,\n webkitLineClamp: lineClamp\n };\n },\n numberOfLines() {\n const lineCountOffsets = [450, 550, 650, Infinity];\n return lineCountOffsets.findIndex((max) => this.width < max);\n },\n compactLink() {\n const link = this.reference.openGraphObject.link;\n if (!link) {\n return \"\";\n }\n if (link.startsWith(\"https://\")) {\n return link.substring(8);\n }\n if (link.startsWith(\"http://\")) {\n return link.substring(7);\n }\n return link;\n },\n route() {\n return getRoute(this.$router, this.reference.openGraphObject.link);\n },\n referenceWidgetLinkComponent() {\n return this.route ? RouterLink : \"a\";\n },\n referenceWidgetLinkProps() {\n return this.route ? { to: this.route } : { href: this.reference.openGraphObject.link, target: \"_blank\" };\n }\n },\n watch: {\n isVisible: {\n handler(val) {\n if (!val) {\n this.idleTimeout = setTimeout(() => {\n if (!this.isVisible) {\n this.destroyWidget();\n }\n }, IDLE_TIMEOUT);\n return;\n }\n if (this.idleTimeout) {\n clearTimeout(this.idleTimeout);\n this.idleTimeout = null;\n }\n if (!this.rendered) {\n this.renderWidget();\n }\n },\n immediate: true\n }\n },\n beforeUnmount() {\n this.destroyWidget();\n },\n methods: {\n t,\n enableInteractive() {\n this.showInteractive = true;\n this.renderWidget();\n },\n renderWidget() {\n if (!this.$refs.customWidget) {\n return;\n }\n if (this?.reference?.richObjectType === \"open-graph\") {\n return;\n }\n this.$refs.customWidget.innerHTML = \"\";\n const widget = document.createElement(\"div\");\n widget.style = \"width: 100%;\";\n this.$refs.customWidget.appendChild(widget);\n this.$nextTick(() => {\n renderWidget(widget, {\n ...this.reference,\n interactive: this.isInteractive\n });\n this.rendered = true;\n });\n },\n destroyWidget() {\n if (this.rendered) {\n destroyWidget(this.reference.richObjectType, this.$el);\n this.rendered = false;\n }\n }\n }\n};\nconst _hoisted_1$5 = [\"src\"];\nconst _hoisted_2$4 = { class: \"widget-default--details\" };\nconst _hoisted_3$3 = { class: \"widget-default--name\" };\nconst _hoisted_4$2 = { class: \"widget-default--link\" };\nfunction _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcButton = resolveComponent(\"NcButton\");\n return openBlock(), createElementBlock(\"div\", {\n ref: \"widgetRoot\",\n class: normalizeClass({ \"toggle-interactive\": $options.hasInteractiveView && !$options.isInteractive })\n }, [\n $props.reference && $options.hasCustomWidget ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n ref: \"customWidget\",\n class: normalizeClass([\"widget-custom\", { \"full-width\": $options.hasFullWidth }])\n }, null, 2)) : !$options.noAccess && $props.reference && $props.reference.openGraphObject && !$options.hasCustomWidget ? (openBlock(), createBlock(resolveDynamicComponent($options.referenceWidgetLinkComponent), mergeProps({ key: 1 }, $options.referenceWidgetLinkProps, {\n rel: \"noopener noreferrer\",\n class: \"widget-default\"\n }), {\n default: withCtx(() => [\n $props.reference.openGraphObject.thumb ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"widget-default--image\",\n src: $props.reference.openGraphObject.thumb\n }, null, 8, _hoisted_1$5)) : createCommentVNode(\"\", true),\n createElementVNode(\"div\", _hoisted_2$4, [\n createElementVNode(\"p\", _hoisted_3$3, toDisplayString($props.reference.openGraphObject.name), 1),\n createElementVNode(\"p\", {\n class: \"widget-default--description\",\n style: normalizeStyle($options.descriptionStyle)\n }, toDisplayString($props.reference.openGraphObject.description), 5),\n createElementVNode(\"p\", _hoisted_4$2, toDisplayString($options.compactLink), 1)\n ])\n ]),\n _: 1\n }, 16)) : createCommentVNode(\"\", true),\n $props.interactiveOptIn && $options.hasInteractiveView && !$options.isInteractive ? (openBlock(), createBlock(_component_NcButton, {\n key: 2,\n class: \"toggle-interactive--button\",\n onClick: $options.enableInteractive\n }, {\n default: withCtx(() => [\n createTextVNode(toDisplayString($options.t(\"Enable interactive view\")), 1)\n ]),\n _: 1\n }, 8, [\"onClick\"])) : createCommentVNode(\"\", true)\n ], 2);\n}\nconst NcReferenceWidget = /* @__PURE__ */ _export_sfc(_sfc_main$5, [[\"render\", _sfc_render$5], [\"__scopeId\", \"data-v-17076b70\"]]);\nregister(t24);\nconst _sfc_main$4 = {\n name: \"NcRawLinkInput\",\n components: {\n LinkVariantIcon,\n NcEmptyContent,\n NcLoadingIcon,\n NcReferenceWidget,\n NcTextField: _sfc_main$b\n },\n props: {\n /**\n * The reference provider\n */\n provider: {\n type: Object,\n required: true\n }\n },\n emits: [\n \"submit\"\n ],\n data() {\n return {\n inputValue: \"\",\n loading: false,\n reference: null,\n abortController: null,\n inputPlaceholder: t(\"Enter link\")\n };\n },\n computed: {\n isLinkValid() {\n return isUrl(this.inputValue);\n },\n debouncedUpdateReference() {\n return debounce(this.updateReference, 500);\n }\n },\n methods: {\n focus() {\n this.$refs[\"url-input\"].$el.getElementsByTagName(\"input\")[0]?.focus();\n },\n onSubmit(e) {\n const value = e.target.value;\n if (this.isLinkValid) {\n this.$emit(\"submit\", value);\n }\n },\n onClear() {\n this.inputValue = \"\";\n this.reference = null;\n },\n onInput() {\n this.reference = null;\n if (this.abortController) {\n this.abortController.abort();\n }\n if (this.isLinkValid) {\n this.debouncedUpdateReference();\n }\n },\n updateReference() {\n this.loading = true;\n this.abortController = new AbortController();\n axios.get(generateOcsUrl(\"references/resolve\", 2) + \"?reference=\" + encodeURIComponent(this.inputValue), {\n signal: this.abortController.signal\n }).then((response) => {\n this.reference = response.data.ocs.data.references[this.inputValue];\n }).catch((error) => {\n logger.error(\"[NcRawLinkInput] Failed to update reference\", { error });\n }).then(() => {\n this.loading = false;\n });\n }\n }\n};\nconst _hoisted_1$4 = { class: \"raw-link\" };\nconst _hoisted_2$3 = { class: \"input-wrapper\" };\nconst _hoisted_3$2 = [\"src\"];\nfunction _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcLoadingIcon = resolveComponent(\"NcLoadingIcon\");\n const _component_LinkVariantIcon = resolveComponent(\"LinkVariantIcon\");\n const _component_NcTextField = resolveComponent(\"NcTextField\");\n const _component_NcReferenceWidget = resolveComponent(\"NcReferenceWidget\");\n const _component_NcEmptyContent = resolveComponent(\"NcEmptyContent\");\n return openBlock(), createElementBlock(\"div\", _hoisted_1$4, [\n createElementVNode(\"div\", _hoisted_2$3, [\n createVNode(_component_NcTextField, {\n ref: \"url-input\",\n modelValue: $data.inputValue,\n \"onUpdate:modelValue\": [\n _cache[0] || (_cache[0] = ($event) => $data.inputValue = $event),\n $options.onInput\n ],\n \"show-trailing-button\": $data.inputValue !== \"\",\n label: $data.inputPlaceholder,\n onTrailingButtonClick: $options.onClear,\n onKeyup: withKeys($options.onSubmit, [\"enter\"])\n }, {\n default: withCtx(() => [\n $data.loading ? (openBlock(), createBlock(_component_NcLoadingIcon, {\n key: 0,\n size: 16\n })) : (openBlock(), createBlock(_component_LinkVariantIcon, {\n key: 1,\n size: 16\n }))\n ]),\n _: 1\n }, 8, [\"modelValue\", \"show-trailing-button\", \"label\", \"onTrailingButtonClick\", \"onUpdate:modelValue\", \"onKeyup\"])\n ]),\n $data.reference !== null ? (openBlock(), createBlock(_component_NcReferenceWidget, {\n key: 0,\n class: \"reference-widget\",\n reference: $data.reference\n }, null, 8, [\"reference\"])) : (openBlock(), createBlock(_component_NcEmptyContent, {\n key: 1,\n class: \"raw-link--empty-content\"\n }, {\n icon: withCtx(() => [\n $props.provider.icon_url ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"provider-icon\",\n src: $props.provider.icon_url\n }, null, 8, _hoisted_3$2)) : (openBlock(), createBlock(_component_LinkVariantIcon, { key: 1 }))\n ]),\n _: 1\n }))\n ]);\n}\nconst NcRawLinkInput = /* @__PURE__ */ _export_sfc(_sfc_main$4, [[\"render\", _sfc_render$4], [\"__scopeId\", \"data-v-6d7fc06a\"]]);\nconst _sfc_main$3 = {\n name: \"NcSearchResult\",\n components: {\n NcHighlight: _sfc_main$a\n },\n props: {\n /**\n * Unified search result entry\n */\n entry: {\n type: Object,\n required: true\n },\n /**\n * The query that led to getting this result\n * Used to highlight the entry text\n */\n query: {\n type: String,\n required: true\n }\n }\n};\nconst _hoisted_1$3 = { class: \"result\" };\nconst _hoisted_2$2 = [\"src\"];\nconst _hoisted_3$1 = { class: \"result--content\" };\nconst _hoisted_4$1 = { class: \"result--content--name\" };\nconst _hoisted_5$1 = { class: \"result--content--subline\" };\nfunction _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcHighlight = resolveComponent(\"NcHighlight\");\n return openBlock(), createElementBlock(\"div\", _hoisted_1$3, [\n $props.entry.icon ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n class: normalizeClass([{ [$props.entry.icon]: true, rounded: $props.entry.rounded }, \"result--icon-class\"])\n }, null, 2)) : (openBlock(), createElementBlock(\"img\", {\n key: 1,\n class: normalizeClass([\"result--image\", { rounded: $props.entry.rounded }]),\n src: $props.entry.thumbnailUrl\n }, null, 10, _hoisted_2$2)),\n createElementVNode(\"div\", _hoisted_3$1, [\n createElementVNode(\"span\", _hoisted_4$1, [\n createVNode(_component_NcHighlight, {\n search: $props.query,\n text: $props.entry.title\n }, null, 8, [\"search\", \"text\"])\n ]),\n createElementVNode(\"span\", _hoisted_5$1, [\n createVNode(_component_NcHighlight, {\n search: $props.query,\n text: $props.entry.subline\n }, null, 8, [\"search\", \"text\"])\n ])\n ])\n ]);\n}\nconst NcSearchResult = /* @__PURE__ */ _export_sfc(_sfc_main$3, [[\"render\", _sfc_render$3], [\"__scopeId\", \"data-v-059edcfb\"]]);\nregister(t31, t39, t41);\nconst LIMIT = 5;\nconst _sfc_main$2 = {\n name: \"NcSearch\",\n components: {\n LinkVariantIcon,\n DotsHorizontalIcon: IconDotsHorizontal,\n NcEmptyContent,\n NcSelect,\n NcSearchResult\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n /**\n * The selected reference provider\n */\n provider: {\n type: Object,\n required: true\n },\n showEmptyContent: {\n type: Boolean,\n default: true\n },\n /**\n * Placeholder of the search\n */\n searchPlaceholder: {\n type: String,\n default: null\n }\n },\n emits: [\n \"submit\"\n ],\n data() {\n return {\n searchQuery: \"\",\n selectedResult: null,\n resultsBySearchProvider: {},\n searching: false,\n searchingMoreOf: null,\n abortController: null,\n noOptionsText: t(\"Start typing to search\"),\n providerIconAlt: t(\"Provider icon\")\n };\n },\n computed: {\n mySearchPlaceholder() {\n return this.searchPlaceholder || t(\"Search\");\n },\n searchProviderIds() {\n return this.provider.search_providers_ids;\n },\n options() {\n if (this.searchQuery === \"\") {\n return [];\n }\n const options = [];\n if (isUrl(this.searchQuery)) {\n options.push(this.rawLinkEntry);\n }\n options.push(...this.formattedSearchResults);\n return options;\n },\n rawLinkEntry() {\n return {\n id: \"rawLinkEntry\",\n resourceUrl: this.searchQuery,\n isRawLink: true\n };\n },\n formattedSearchResults() {\n const results = [];\n this.searchProviderIds.forEach((pid) => {\n if (this.resultsBySearchProvider[pid].entries.length > 0) {\n if (this.searchProviderIds.length > 1 || this.resultsBySearchProvider[pid].entries.length > 1) {\n results.push({\n id: \"groupTitle-\" + pid,\n name: this.resultsBySearchProvider[pid].name,\n isCustomGroupTitle: true,\n providerId: pid\n });\n }\n const providerEntriesWithId = this.resultsBySearchProvider[pid].entries.map((entry, index) => {\n return {\n id: \"provider-\" + pid + \"-entry-\" + index,\n ...entry\n };\n });\n results.push(...providerEntriesWithId);\n if (this.resultsBySearchProvider[pid].isPaginated) {\n results.push({\n id: \"moreOf-\" + pid,\n name: this.resultsBySearchProvider[pid].name,\n isMore: true,\n providerId: pid,\n isLoading: this.searchingMoreOf === pid\n });\n }\n }\n });\n return results;\n },\n debouncedUpdateSearch() {\n return debounce(this.updateSearch, 500);\n }\n },\n mounted() {\n this.resetResults();\n },\n beforeUnmount() {\n this.cancelSearchRequests();\n },\n methods: {\n t,\n resetResults() {\n const resultsBySearchProvider = {};\n this.searchProviderIds.forEach((pid) => {\n resultsBySearchProvider[pid] = {\n entries: []\n };\n });\n this.resultsBySearchProvider = resultsBySearchProvider;\n },\n focus() {\n setTimeout(() => {\n this.$refs[\"search-select\"]?.$el?.querySelector(\"#search-select-input\")?.focus();\n }, 300);\n },\n cancelSearchRequests() {\n if (this.abortController) {\n this.abortController.abort();\n }\n },\n onSearchInput(query) {\n this.searchQuery = query;\n this.debouncedUpdateSearch();\n },\n onSelectResultSelected(item) {\n if (item !== null) {\n if (item.resourceUrl) {\n this.cancelSearchRequests();\n this.$emit(\"submit\", item.resourceUrl);\n } else if (item.isMore) {\n this.searchMoreOf(item.providerId).then(() => {\n this.selectedResult = null;\n });\n }\n }\n },\n searchMoreOf(searchProviderId) {\n this.searchingMoreOf = searchProviderId;\n this.cancelSearchRequests();\n return this.searchProviders(searchProviderId);\n },\n updateSearch() {\n this.cancelSearchRequests();\n this.resetResults();\n if (this.searchQuery === \"\") {\n this.searching = false;\n return;\n }\n return this.searchProviders();\n },\n searchProviders(searchProviderId = null) {\n this.abortController = new AbortController();\n this.searching = true;\n const searchPromises = searchProviderId === null ? [...this.searchProviderIds].map((pid) => {\n return this.searchOneProvider(pid);\n }) : [this.searchOneProvider(searchProviderId, this.resultsBySearchProvider[searchProviderId]?.cursor ?? null)];\n return Promise.allSettled(searchPromises).then((promises) => {\n const isOneCanceled = !!promises.find((p) => {\n return p.status === \"rejected\" && (p.reason.name === \"CanceledError\" || p.reason.code === \"ERR_CANCELED\");\n });\n if (!isOneCanceled) {\n this.searching = false;\n this.searchingMoreOf = null;\n }\n });\n },\n searchOneProvider(providerId, cursor = null) {\n const url = cursor === null ? generateOcsUrl(\"search/providers/{providerId}/search?term={term}&limit={limit}\", { providerId, term: this.searchQuery, limit: LIMIT }) : generateOcsUrl(\"search/providers/{providerId}/search?term={term}&limit={limit}&cursor={cursor}\", { providerId, term: this.searchQuery, limit: LIMIT, cursor });\n return axios.get(url, {\n signal: this.abortController.signal\n }).then((response) => {\n const data = response.data.ocs.data;\n this.resultsBySearchProvider[providerId].name = data.name;\n this.resultsBySearchProvider[providerId].cursor = data.cursor;\n this.resultsBySearchProvider[providerId].isPaginated = data.isPaginated;\n this.resultsBySearchProvider[providerId].entries.push(...data.entries);\n });\n }\n }\n};\nconst _hoisted_1$2 = {\n key: 0,\n class: \"custom-option\"\n};\nconst _hoisted_2$1 = { class: \"option-text\" };\nconst _hoisted_3 = {\n key: 2,\n class: \"custom-option group-name\"\n};\nconst _hoisted_4 = [\"src\"];\nconst _hoisted_5 = { class: \"option-text\" };\nconst _hoisted_6 = {\n key: 3,\n class: \"custom-option\"\n};\nconst _hoisted_7 = {\n key: 0,\n class: \"option-simple-icon icon-loading-small\"\n};\nconst _hoisted_8 = { class: \"option-text\" };\nconst _hoisted_9 = [\"alt\", \"src\"];\nfunction _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_LinkVariantIcon = resolveComponent(\"LinkVariantIcon\");\n const _component_NcSearchResult = resolveComponent(\"NcSearchResult\");\n const _component_DotsHorizontalIcon = resolveComponent(\"DotsHorizontalIcon\");\n const _component_NcSelect = resolveComponent(\"NcSelect\");\n const _component_NcEmptyContent = resolveComponent(\"NcEmptyContent\");\n return openBlock(), createElementBlock(\"div\", {\n class: normalizeClass([\"smart-picker-search\", { \"with-empty-content\": $props.showEmptyContent }])\n }, [\n createVNode(_component_NcSelect, {\n ref: \"search-select\",\n modelValue: $data.selectedResult,\n \"onUpdate:modelValue\": [\n _cache[0] || (_cache[0] = ($event) => $data.selectedResult = $event),\n $options.onSelectResultSelected\n ],\n class: \"smart-picker-search--select\",\n \"input-id\": \"search-select-input\",\n label: \"name\",\n placeholder: $options.mySearchPlaceholder,\n options: $options.options,\n \"append-to-body\": false,\n \"close-on-select\": false,\n \"clear-search-on-select\": false,\n \"clear-search-on-blur\": () => false,\n \"reset-focus-on-options-change\": false,\n filterable: false,\n autoscroll: true,\n \"reset-on-options-change\": false,\n loading: $data.searching,\n onSearch: $options.onSearchInput\n }, {\n option: withCtx((option) => [\n option.isRawLink ? (openBlock(), createElementBlock(\"div\", _hoisted_1$2, [\n createVNode(_component_LinkVariantIcon, {\n class: \"option-simple-icon\",\n size: 20\n }),\n createElementVNode(\"span\", _hoisted_2$1, toDisplayString($options.t(\"Raw link {options}\", { options: option.resourceUrl })), 1)\n ])) : option.resourceUrl ? (openBlock(), createBlock(_component_NcSearchResult, {\n key: 1,\n class: \"search-result\",\n entry: option,\n query: $data.searchQuery\n }, null, 8, [\"entry\", \"query\"])) : option.isCustomGroupTitle ? (openBlock(), createElementBlock(\"span\", _hoisted_3, [\n $props.provider.icon_url ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"provider-icon group-name-icon\",\n src: $props.provider.icon_url\n }, null, 8, _hoisted_4)) : createCommentVNode(\"\", true),\n createElementVNode(\"span\", _hoisted_5, [\n createElementVNode(\"strong\", null, toDisplayString(option.name), 1)\n ])\n ])) : option.isMore ? (openBlock(), createElementBlock(\"span\", _hoisted_6, [\n option.isLoading ? (openBlock(), createElementBlock(\"span\", _hoisted_7)) : (openBlock(), createBlock(_component_DotsHorizontalIcon, {\n key: 1,\n class: \"option-simple-icon\",\n size: 20\n })),\n createElementVNode(\"span\", _hoisted_8, toDisplayString($options.t('Load more \"{options}\"', { options: option.name })), 1)\n ])) : createCommentVNode(\"\", true)\n ]),\n \"no-options\": withCtx(() => [\n createTextVNode(toDisplayString($data.noOptionsText), 1)\n ]),\n _: 1\n }, 8, [\"modelValue\", \"placeholder\", \"options\", \"loading\", \"onSearch\", \"onUpdate:modelValue\"]),\n $props.showEmptyContent ? (openBlock(), createBlock(_component_NcEmptyContent, {\n key: 0,\n class: \"smart-picker-search--empty-content\"\n }, {\n icon: withCtx(() => [\n $props.provider.icon_url ? (openBlock(), createElementBlock(\"img\", {\n key: 0,\n class: \"provider-icon\",\n alt: $data.providerIconAlt,\n src: $props.provider.icon_url\n }, null, 8, _hoisted_9)) : (openBlock(), createBlock(_component_LinkVariantIcon, { key: 1 }))\n ]),\n _: 1\n })) : createCommentVNode(\"\", true)\n ], 2);\n}\nconst NcSearch = /* @__PURE__ */ _export_sfc(_sfc_main$2, [[\"render\", _sfc_render$2], [\"__scopeId\", \"data-v-e8abf1d4\"]]);\nconst MODES = {\n providerList: 1,\n standardLinkInput: 2,\n searchInput: 3,\n customElement: 4\n};\nconst _sfc_main$1 = {\n name: \"NcReferencePicker\",\n components: {\n NcCustomPickerElement,\n NcProviderList,\n NcRawLinkInput,\n NcSearch\n },\n props: {\n /**\n * Provider to select on creation\n * Default: null. Show the provider list\n */\n initialProvider: {\n type: Object,\n default: () => null\n },\n /**\n * Optional width in pixels\n * Default: 100%\n */\n width: {\n type: Number,\n default: null\n },\n /**\n * Focus on the provider list select input on creation\n * Default: true\n */\n focusOnCreate: {\n type: Boolean,\n default: true\n }\n },\n emits: [\n \"cancel\",\n \"cancelRawLink\",\n \"cancelSearch\",\n \"providerSelected\",\n \"submit\"\n ],\n data() {\n return {\n MODES,\n selectedProvider: this.initialProvider\n };\n },\n computed: {\n mode() {\n return this.selectedProvider === null ? MODES.providerList : isCustomPickerElementRegistered(this.selectedProvider.id) ? MODES.customElement : this.selectedProvider.search_providers_ids ? MODES.searchInput : MODES.standardLinkInput;\n },\n pickerWrapperStyle() {\n return {\n width: this.width ? this.width + \"px\" : void 0\n };\n }\n },\n mounted() {\n if (this.focusOnCreate) {\n if (this.initialProvider) {\n setTimeout(() => {\n this.$refs[\"url-input\"]?.focus();\n }, 300);\n } else {\n this.$nextTick(() => {\n this.$refs[\"provider-list\"]?.focus();\n });\n }\n }\n },\n methods: {\n onEscapePressed() {\n if (this.selectedProvider !== null) {\n this.deselectProvider();\n } else {\n this.cancelProviderSelection();\n }\n },\n onProviderSelected(provider) {\n this.selectedProvider = provider;\n this.$emit(\"providerSelected\", provider);\n this.$nextTick(() => {\n this.$refs[\"url-input\"]?.focus();\n });\n },\n cancelCustomElement() {\n this.deselectProvider();\n },\n cancelSearch() {\n this.$emit(\"cancelSearch\", this.selectedProvider?.title);\n this.deselectProvider();\n },\n cancelRawLinkInput() {\n this.$emit(\"cancelRawLink\", this.selectedProvider?.title);\n this.deselectProvider();\n },\n cancelProviderSelection() {\n this.$emit(\"cancel\");\n },\n submitLink(link) {\n if (this.selectedProvider !== null) {\n touchProvider(this.selectedProvider.id);\n }\n this.$emit(\"submit\", link);\n this.deselectProvider();\n },\n deselectProvider() {\n this.selectedProvider = null;\n this.$emit(\"providerSelected\", null);\n setTimeout(() => {\n this.$refs[\"provider-list\"]?.focus();\n }, 300);\n }\n }\n};\nconst _hoisted_1$1 = {\n key: 3,\n class: \"custom-element-wrapper\"\n};\nfunction _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcProviderList = resolveComponent(\"NcProviderList\");\n const _component_NcRawLinkInput = resolveComponent(\"NcRawLinkInput\");\n const _component_NcSearch = resolveComponent(\"NcSearch\");\n const _component_NcCustomPickerElement = resolveComponent(\"NcCustomPickerElement\");\n return openBlock(), createElementBlock(\"div\", {\n class: \"reference-picker\",\n style: normalizeStyle($options.pickerWrapperStyle),\n tabindex: \"-1\",\n onKeydown: _cache[0] || (_cache[0] = withKeys(withModifiers((...args) => $options.onEscapePressed && $options.onEscapePressed(...args), [\"stop\", \"prevent\"]), [\"esc\"]))\n }, [\n $options.mode === $data.MODES.providerList ? (openBlock(), createBlock(_component_NcProviderList, {\n key: 0,\n ref: \"provider-list\",\n onSelectProvider: $options.onProviderSelected,\n onSubmit: $options.submitLink,\n onCancel: $options.cancelProviderSelection\n }, null, 8, [\"onSelectProvider\", \"onSubmit\", \"onCancel\"])) : $options.mode === $data.MODES.standardLinkInput ? (openBlock(), createBlock(_component_NcRawLinkInput, {\n key: 1,\n ref: \"url-input\",\n provider: $data.selectedProvider,\n onSubmit: $options.submitLink,\n onCancel: $options.cancelRawLinkInput\n }, null, 8, [\"provider\", \"onSubmit\", \"onCancel\"])) : $options.mode === $data.MODES.searchInput ? (openBlock(), createBlock(_component_NcSearch, {\n key: 2,\n ref: \"url-input\",\n provider: $data.selectedProvider,\n onCancel: $options.cancelSearch,\n onSubmit: $options.submitLink\n }, null, 8, [\"provider\", \"onCancel\", \"onSubmit\"])) : $options.mode === $data.MODES.customElement ? (openBlock(), createElementBlock(\"div\", _hoisted_1$1, [\n createVNode(_component_NcCustomPickerElement, {\n provider: $data.selectedProvider,\n class: \"custom-element\",\n onSubmit: $options.submitLink,\n onCancel: $options.cancelCustomElement\n }, null, 8, [\"provider\", \"onSubmit\", \"onCancel\"])\n ])) : createCommentVNode(\"\", true)\n ], 36);\n}\nconst NcReferencePicker = /* @__PURE__ */ _export_sfc(_sfc_main$1, [[\"render\", _sfc_render$1], [\"__scopeId\", \"data-v-b193005a\"]]);\nregister(t12, t19);\nconst _sfc_main = {\n name: \"NcReferencePickerModal\",\n components: {\n NcReferencePicker,\n NcModal,\n NcButton,\n ArrowLeftIcon,\n CloseIcon: IconClose\n },\n props: {\n /**\n * Provider to select on creation\n * Show the provider list if no initial one is provided\n */\n initialProvider: {\n type: Object,\n default: () => null\n },\n /**\n * Focus on the input item on create\n */\n focusOnCreate: {\n type: Boolean,\n default: true\n },\n /**\n * If true, add the modal content to the Viewer trap elements via the event-bus\n */\n isInsideViewer: {\n type: Boolean,\n default: false\n }\n },\n emits: [\n \"cancel\",\n \"submit\"\n ],\n data() {\n return {\n show: true,\n selectedProvider: this.initialProvider,\n backButtonTitle: t(\"Back to provider selection\"),\n closeButtonTitle: t(\"Close\"),\n closeButtonLabel: t(\"Close Smart Picker\")\n };\n },\n computed: {\n isProviderSelected() {\n return this.selectedProvider !== null;\n },\n showBackButton() {\n return this.initialProvider === null && this.isProviderSelected;\n },\n modalSize() {\n return this.isProviderSelected && isCustomPickerElementRegistered(this.selectedProvider.id) ? getCustomPickerElementSize(this.selectedProvider.id) ?? \"large\" : \"normal\";\n },\n showModalName() {\n return !this.isProviderSelected || !isCustomPickerElementRegistered(this.selectedProvider.id);\n },\n modalName() {\n return this.isProviderSelected ? this.selectedProvider.title : t(\"Smart Picker\");\n }\n },\n mounted() {\n if (this.isInsideViewer) {\n const elem = this.$refs.modal_content;\n emit(\"viewer:trapElements:changed\", elem);\n }\n },\n methods: {\n onCancel() {\n this.show = false;\n this.$emit(\"cancel\");\n },\n onSubmit(value) {\n this.show = false;\n this.$emit(\"submit\", value);\n },\n onProviderSelect(provider) {\n this.selectedProvider = provider;\n if (provider === null && this.initialProvider !== null) {\n this.onCancel();\n }\n },\n onBackClicked() {\n this.$refs.referencePicker.deselectProvider();\n }\n }\n};\nconst _hoisted_1 = {\n ref: \"modal_content\",\n class: \"reference-picker-modal--content\"\n};\nconst _hoisted_2 = { key: 1 };\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_ArrowLeftIcon = resolveComponent(\"ArrowLeftIcon\");\n const _component_NcButton = resolveComponent(\"NcButton\");\n const _component_CloseIcon = resolveComponent(\"CloseIcon\");\n const _component_NcReferencePicker = resolveComponent(\"NcReferencePicker\");\n const _component_NcModal = resolveComponent(\"NcModal\");\n return $data.show ? (openBlock(), createBlock(_component_NcModal, {\n key: 0,\n size: $options.modalSize,\n class: \"reference-picker-modal\",\n onClose: $options.onCancel\n }, {\n default: withCtx(() => [\n createElementVNode(\"div\", _hoisted_1, [\n $options.showBackButton ? (openBlock(), createBlock(_component_NcButton, {\n key: 0,\n \"aria-label\": $data.backButtonTitle,\n title: $data.backButtonTitle,\n class: \"back-button\",\n onClick: $options.onBackClicked\n }, {\n icon: withCtx(() => [\n createVNode(_component_ArrowLeftIcon)\n ]),\n _: 1\n }, 8, [\"aria-label\", \"title\", \"onClick\"])) : createCommentVNode(\"\", true),\n createVNode(_component_NcButton, {\n class: \"close-button\",\n \"aria-label\": $data.closeButtonLabel,\n title: $data.closeButtonTitle,\n variant: \"tertiary\",\n onClick: $options.onCancel\n }, {\n icon: withCtx(() => [\n createVNode(_component_CloseIcon)\n ]),\n _: 1\n }, 8, [\"aria-label\", \"title\", \"onClick\"]),\n $options.showModalName ? (openBlock(), createElementBlock(\"h2\", _hoisted_2, toDisplayString($options.modalName), 1)) : createCommentVNode(\"\", true),\n createVNode(_component_NcReferencePicker, {\n ref: \"referencePicker\",\n \"initial-provider\": $props.initialProvider,\n \"focus-on-create\": $props.focusOnCreate,\n onProviderSelected: $options.onProviderSelect,\n onSubmit: $options.onSubmit,\n onCancel: $options.onCancel\n }, null, 8, [\"initial-provider\", \"focus-on-create\", \"onProviderSelected\", \"onSubmit\", \"onCancel\"])\n ], 512)\n ]),\n _: 1\n }, 8, [\"size\", \"onClose\"])) : createCommentVNode(\"\", true);\n}\nconst NcReferencePickerModal = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render], [\"__scopeId\", \"data-v-15018516\"]]);\nasync function getLinkWithPicker(providerId, isInsideViewer) {\n const modalId = \"referencePickerModal\";\n const modalElement = document.createElement(\"div\");\n modalElement.id = modalId;\n document.body.append(modalElement);\n const { promise, reject, resolve } = Promise.withResolvers();\n const initialProvider = providerId && getProvider(providerId) || null;\n const view = createApp(NcReferencePickerModal, {\n initialProvider,\n isInsideViewer,\n onCancel() {\n view.unmount();\n reject(new Error(\"User cancellation\"));\n },\n onSubmit(link) {\n view.unmount();\n resolve(link);\n }\n });\n view.mount(modalElement);\n return promise;\n}\nexport {\n NcReferencePicker as N,\n anyLinkProviderId as a,\n getProvider as b,\n getProviders as c,\n sortProviders as d,\n NcReferencePickerModal as e,\n NcReferenceWidget as f,\n getLinkWithPicker as g,\n NcSearch as h,\n searchProvider as s\n};\n//# sourceMappingURL=referencePickerModal-B2XHvg0V.mjs.map\n","import '../assets/NcRichText-Bx--sR58.css';\nimport rehypeExternalLinks from \"rehype-external-links\";\nimport rehype2react from \"rehype-react\";\nimport breaks from \"remark-breaks\";\nimport remarkParse from \"remark-parse\";\nimport remark2rehype from \"remark-rehype\";\nimport remarkUnlinkProtocols from \"remark-unlink-protocols\";\nimport { unified } from \"unified\";\nimport { resolveComponent, createElementBlock, createCommentVNode, openBlock, normalizeClass, Fragment, renderList, createBlock, ref, h } from \"vue\";\nimport { RouterLink } from \"vue-router\";\nimport { N as NcCheckboxRadioSwitch } from \"./NcCheckboxRadioSwitch-DdIGHhQz.mjs\";\nimport { getCurrentUser } from \"@nextcloud/auth\";\nimport axios from \"@nextcloud/axios\";\nimport { generateOcsUrl } from \"@nextcloud/router\";\nimport { getSharingToken } from \"@nextcloud/sharing/public\";\nimport { f as NcReferenceWidget } from \"./referencePickerModal-B2XHvg0V.mjs\";\nimport { U as URL_PATTERN, g as getRoute, p as parseUrl, r as remarkAutolink } from \"./autolink-U5pBzLgI.mjs\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nimport { c as createElementId } from \"./createElementId-DhjFt1I9.mjs\";\nimport { u } from \"unist-builder\";\nimport { visit, EXIT as EXIT$1, SKIP as SKIP$1 } from \"unist-util-visit\";\nconst _sfc_main$1 = {\n name: \"NcReferenceList\",\n components: {\n NcReferenceWidget\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n text: {\n type: String,\n default: \"\"\n },\n referenceData: {\n type: Array,\n default: null\n },\n limit: {\n type: Number,\n default: 1\n },\n displayFallback: {\n type: Boolean,\n default: false\n },\n interactive: {\n type: Boolean,\n default: true\n },\n interactiveOptIn: {\n type: Boolean,\n default: false\n }\n },\n emits: [\"loaded\"],\n data() {\n return {\n references: null,\n loading: true\n };\n },\n computed: {\n isVisible() {\n return this.loading || this.displayedReferences.length !== 0;\n },\n values() {\n if (this.referenceData) {\n return this.referenceData;\n }\n if (this.displayFallback && !this.loading && !this.references) {\n return [this.fallbackReference];\n }\n return this.references ? Object.values(this.references) : [];\n },\n firstReference() {\n return this.values[0] ?? null;\n },\n displayedReferences() {\n return this.values.filter(Boolean).slice(0, this.limit);\n },\n fallbackReference() {\n return {\n accessible: true,\n openGraphObject: {\n id: this.text,\n link: this.text,\n name: this.text\n },\n richObjectType: \"open-graph\"\n };\n }\n },\n watch: {\n text: \"fetch\"\n },\n mounted() {\n this.fetch();\n },\n methods: {\n fetch() {\n this.loading = true;\n if (this.referenceData) {\n this.references = null;\n this.loading = false;\n return;\n }\n if (!new RegExp(URL_PATTERN).exec(this.text)) {\n this.references = null;\n this.loading = false;\n return;\n }\n this.resolve().then((response) => {\n this.references = response.data.ocs.data.references;\n this.loading = false;\n this.$emit(\"loaded\");\n }).catch((error) => {\n logger.error(\"[NcReferenceList] Failed to extract references\", { error });\n this.loading = false;\n this.$emit(\"loaded\");\n });\n },\n resolve() {\n const match = new RegExp(URL_PATTERN).exec(this.text.trim());\n const isPublic = getCurrentUser() === null;\n if (this.limit === 1 && match) {\n return isPublic ? axios.get(generateOcsUrl(\"references/resolvePublic\") + `?reference=${encodeURIComponent(match[0])}&sharingToken=${getSharingToken()}`) : axios.get(generateOcsUrl(\"references/resolve\") + `?reference=${encodeURIComponent(match[0])}`);\n }\n return isPublic ? axios.post(generateOcsUrl(\"references/extractPublic\"), {\n text: this.text,\n resolve: true,\n limit: this.limit,\n sharingToken: getSharingToken()\n }) : axios.post(generateOcsUrl(\"references/extract\"), {\n text: this.text,\n resolve: true,\n limit: this.limit\n });\n }\n }\n};\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_NcReferenceWidget = resolveComponent(\"NcReferenceWidget\");\n return $options.isVisible ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n class: normalizeClass([\"widgets--list\", { \"icon-loading\": $data.loading }])\n }, [\n (openBlock(true), createElementBlock(Fragment, null, renderList($options.displayedReferences, (reference) => {\n return openBlock(), createBlock(_component_NcReferenceWidget, {\n key: reference.openGraphObject?.id,\n reference,\n interactive: $props.interactive,\n \"interactive-opt-in\": $props.interactiveOptIn\n }, null, 8, [\"reference\", \"interactive\", \"interactive-opt-in\"]);\n }), 128))\n ], 2)) : createCommentVNode(\"\", true);\n}\nconst NcReferenceList = /* @__PURE__ */ _export_sfc(_sfc_main$1, [[\"render\", _sfc_render], [\"__scopeId\", \"data-v-ddd65c9e\"]]);\nfunction ccount(value, character) {\n const source = String(value);\n if (typeof character !== \"string\") {\n throw new TypeError(\"Expected character\");\n }\n let count = 0;\n let index = source.indexOf(character);\n while (index !== -1) {\n count++;\n index = source.indexOf(character, index + character.length);\n }\n return count;\n}\nfunction ok$1() {\n}\nconst asciiAlpha = regexCheck(/[A-Za-z]/);\nconst asciiAlphanumeric = regexCheck(/[\\dA-Za-z]/);\nfunction asciiControl(code2) {\n return (\n // Special whitespace codes (which have negative values), C0 and Control\n // character DEL\n code2 !== null && (code2 < 32 || code2 === 127)\n );\n}\nfunction markdownLineEnding(code2) {\n return code2 !== null && code2 < -2;\n}\nfunction markdownLineEndingOrSpace(code2) {\n return code2 !== null && (code2 < 0 || code2 === 32);\n}\nfunction markdownSpace(code2) {\n return code2 === -2 || code2 === -1 || code2 === 32;\n}\nconst unicodePunctuation = regexCheck(new RegExp(\"\\\\p{P}|\\\\p{S}\", \"u\"));\nconst unicodeWhitespace = regexCheck(/\\s/);\nfunction regexCheck(regex) {\n return check;\n function check(code2) {\n return code2 !== null && code2 > -1 && regex.test(String.fromCharCode(code2));\n }\n}\nfunction escapeStringRegexp(string) {\n if (typeof string !== \"string\") {\n throw new TypeError(\"Expected a string\");\n }\n return string.replace(/[|\\\\{}()[\\]^$+*?.]/g, \"\\\\$&\").replace(/-/g, \"\\\\x2d\");\n}\nconst convert = (\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate) &\n * ((test?: null | undefined) => (node?: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((test?: Test) => Check)\n * )}\n */\n /**\n * @param {Test} [test]\n * @returns {Check}\n */\n (function(test) {\n if (test === null || test === void 0) {\n return ok;\n }\n if (typeof test === \"function\") {\n return castFactory(test);\n }\n if (typeof test === \"object\") {\n return Array.isArray(test) ? anyFactory(test) : propsFactory(test);\n }\n if (typeof test === \"string\") {\n return typeFactory(test);\n }\n throw new Error(\"Expected function, string, or object as test\");\n })\n);\nfunction anyFactory(tests) {\n const checks = [];\n let index = -1;\n while (++index < tests.length) {\n checks[index] = convert(tests[index]);\n }\n return castFactory(any);\n function any(...parameters) {\n let index2 = -1;\n while (++index2 < checks.length) {\n if (checks[index2].apply(this, parameters)) return true;\n }\n return false;\n }\n}\nfunction propsFactory(check) {\n const checkAsRecord = (\n /** @type {Record} */\n check\n );\n return castFactory(all2);\n function all2(node2) {\n const nodeAsRecord = (\n /** @type {Record} */\n /** @type {unknown} */\n node2\n );\n let key;\n for (key in check) {\n if (nodeAsRecord[key] !== checkAsRecord[key]) return false;\n }\n return true;\n }\n}\nfunction typeFactory(check) {\n return castFactory(type);\n function type(node2) {\n return node2 && node2.type === check;\n }\n}\nfunction castFactory(testFunction) {\n return check;\n function check(value, index, parent) {\n return Boolean(\n looksLikeANode(value) && testFunction.call(\n this,\n value,\n typeof index === \"number\" ? index : void 0,\n parent || void 0\n )\n );\n }\n}\nfunction ok() {\n return true;\n}\nfunction looksLikeANode(value) {\n return value !== null && typeof value === \"object\" && \"type\" in value;\n}\nfunction color(d) {\n return d;\n}\nconst empty = [];\nconst CONTINUE = true;\nconst EXIT = false;\nconst SKIP = \"skip\";\nfunction visitParents(tree, test, visitor, reverse) {\n let check;\n {\n check = test;\n }\n const is = convert(check);\n const step = 1;\n factory(tree, void 0, [])();\n function factory(node2, index, parents) {\n const value = (\n /** @type {Record} */\n node2 && typeof node2 === \"object\" ? node2 : {}\n );\n if (typeof value.type === \"string\") {\n const name = (\n // `hast`\n typeof value.tagName === \"string\" ? value.tagName : (\n // `xast`\n typeof value.name === \"string\" ? value.name : void 0\n )\n );\n Object.defineProperty(visit2, \"name\", {\n value: \"node (\" + color(node2.type + (name ? \"<\" + name + \">\" : \"\")) + \")\"\n });\n }\n return visit2;\n function visit2() {\n let result = empty;\n let subresult;\n let offset;\n let grandparents;\n if (is(node2, index, parents[parents.length - 1] || void 0)) {\n result = toResult(visitor(node2, parents));\n if (result[0] === EXIT) {\n return result;\n }\n }\n if (\"children\" in node2 && node2.children) {\n const nodeAsParent = (\n /** @type {UnistParent} */\n node2\n );\n if (nodeAsParent.children && result[0] !== SKIP) {\n offset = -1 + step;\n grandparents = parents.concat(nodeAsParent);\n while (offset > -1 && offset < nodeAsParent.children.length) {\n const child = nodeAsParent.children[offset];\n subresult = factory(child, offset, grandparents)();\n if (subresult[0] === EXIT) {\n return subresult;\n }\n offset = typeof subresult[1] === \"number\" ? subresult[1] : offset + step;\n }\n }\n }\n return result;\n }\n }\n}\nfunction toResult(value) {\n if (Array.isArray(value)) {\n return value;\n }\n if (typeof value === \"number\") {\n return [CONTINUE, value];\n }\n return value === null || value === void 0 ? empty : [value];\n}\nfunction findAndReplace(tree, list2, options) {\n const settings = options || {};\n const ignored = convert(settings.ignore || []);\n const pairs = toPairs(list2);\n let pairIndex = -1;\n while (++pairIndex < pairs.length) {\n visitParents(tree, \"text\", visitor);\n }\n function visitor(node2, parents) {\n let index = -1;\n let grandparent;\n while (++index < parents.length) {\n const parent = parents[index];\n const siblings = grandparent ? grandparent.children : void 0;\n if (ignored(\n parent,\n siblings ? siblings.indexOf(parent) : void 0,\n grandparent\n )) {\n return;\n }\n grandparent = parent;\n }\n if (grandparent) {\n return handler(node2, parents);\n }\n }\n function handler(node2, parents) {\n const parent = parents[parents.length - 1];\n const find = pairs[pairIndex][0];\n const replace2 = pairs[pairIndex][1];\n let start = 0;\n const siblings = parent.children;\n const index = siblings.indexOf(node2);\n let change = false;\n let nodes = [];\n find.lastIndex = 0;\n let match = find.exec(node2.value);\n while (match) {\n const position = match.index;\n const matchObject = {\n index: match.index,\n input: match.input,\n stack: [...parents, node2]\n };\n let value = replace2(...match, matchObject);\n if (typeof value === \"string\") {\n value = value.length > 0 ? { type: \"text\", value } : void 0;\n }\n if (value === false) {\n find.lastIndex = position + 1;\n } else {\n if (start !== position) {\n nodes.push({\n type: \"text\",\n value: node2.value.slice(start, position)\n });\n }\n if (Array.isArray(value)) {\n nodes.push(...value);\n } else if (value) {\n nodes.push(value);\n }\n start = position + match[0].length;\n change = true;\n }\n if (!find.global) {\n break;\n }\n match = find.exec(node2.value);\n }\n if (change) {\n if (start < node2.value.length) {\n nodes.push({ type: \"text\", value: node2.value.slice(start) });\n }\n parent.children.splice(index, 1, ...nodes);\n } else {\n nodes = [node2];\n }\n return index + nodes.length;\n }\n}\nfunction toPairs(tupleOrList) {\n const result = [];\n if (!Array.isArray(tupleOrList)) {\n throw new TypeError(\"Expected find and replace tuple or list of tuples\");\n }\n const list2 = !tupleOrList[0] || Array.isArray(tupleOrList[0]) ? tupleOrList : [tupleOrList];\n let index = -1;\n while (++index < list2.length) {\n const tuple = list2[index];\n result.push([toExpression(tuple[0]), toFunction(tuple[1])]);\n }\n return result;\n}\nfunction toExpression(find) {\n return typeof find === \"string\" ? new RegExp(escapeStringRegexp(find), \"g\") : find;\n}\nfunction toFunction(replace2) {\n return typeof replace2 === \"function\" ? replace2 : function() {\n return replace2;\n };\n}\nconst inConstruct = \"phrasing\";\nconst notInConstruct = [\"autolink\", \"link\", \"image\", \"label\"];\nfunction gfmAutolinkLiteralFromMarkdown() {\n return {\n transforms: [transformGfmAutolinkLiterals],\n enter: {\n literalAutolink: enterLiteralAutolink,\n literalAutolinkEmail: enterLiteralAutolinkValue,\n literalAutolinkHttp: enterLiteralAutolinkValue,\n literalAutolinkWww: enterLiteralAutolinkValue\n },\n exit: {\n literalAutolink: exitLiteralAutolink,\n literalAutolinkEmail: exitLiteralAutolinkEmail,\n literalAutolinkHttp: exitLiteralAutolinkHttp,\n literalAutolinkWww: exitLiteralAutolinkWww\n }\n };\n}\nfunction gfmAutolinkLiteralToMarkdown() {\n return {\n unsafe: [\n {\n character: \"@\",\n before: \"[+\\\\-.\\\\w]\",\n after: \"[\\\\-.\\\\w]\",\n inConstruct,\n notInConstruct\n },\n {\n character: \".\",\n before: \"[Ww]\",\n after: \"[\\\\-.\\\\w]\",\n inConstruct,\n notInConstruct\n },\n {\n character: \":\",\n before: \"[ps]\",\n after: \"\\\\/\",\n inConstruct,\n notInConstruct\n }\n ]\n };\n}\nfunction enterLiteralAutolink(token) {\n this.enter({ type: \"link\", title: null, url: \"\", children: [] }, token);\n}\nfunction enterLiteralAutolinkValue(token) {\n this.config.enter.autolinkProtocol.call(this, token);\n}\nfunction exitLiteralAutolinkHttp(token) {\n this.config.exit.autolinkProtocol.call(this, token);\n}\nfunction exitLiteralAutolinkWww(token) {\n this.config.exit.data.call(this, token);\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"link\");\n node2.url = \"http://\" + this.sliceSerialize(token);\n}\nfunction exitLiteralAutolinkEmail(token) {\n this.config.exit.autolinkEmail.call(this, token);\n}\nfunction exitLiteralAutolink(token) {\n this.exit(token);\n}\nfunction transformGfmAutolinkLiterals(tree) {\n findAndReplace(\n tree,\n [\n [/(https?:\\/\\/|www(?=\\.))([-.\\w]+)([^ \\t\\r\\n]*)/gi, findUrl],\n [/([-.\\w+]+)@([-\\w]+(?:\\.[-\\w]+)+)/g, findEmail]\n ],\n { ignore: [\"link\", \"linkReference\"] }\n );\n}\nfunction findUrl(_, protocol, domain2, path2, match) {\n let prefix = \"\";\n if (!previous(match)) {\n return false;\n }\n if (/^w/i.test(protocol)) {\n domain2 = protocol + domain2;\n protocol = \"\";\n prefix = \"http://\";\n }\n if (!isCorrectDomain(domain2)) {\n return false;\n }\n const parts = splitUrl(domain2 + path2);\n if (!parts[0]) return false;\n const result = {\n type: \"link\",\n title: null,\n url: prefix + protocol + parts[0],\n children: [{ type: \"text\", value: protocol + parts[0] }]\n };\n if (parts[1]) {\n return [result, { type: \"text\", value: parts[1] }];\n }\n return result;\n}\nfunction findEmail(_, atext, label, match) {\n if (\n // Not an expected previous character.\n !previous(match, true) || // Label ends in not allowed character.\n /[-\\d_]$/.test(label)\n ) {\n return false;\n }\n return {\n type: \"link\",\n title: null,\n url: \"mailto:\" + atext + \"@\" + label,\n children: [{ type: \"text\", value: atext + \"@\" + label }]\n };\n}\nfunction isCorrectDomain(domain2) {\n const parts = domain2.split(\".\");\n if (parts.length < 2 || parts[parts.length - 1] && (/_/.test(parts[parts.length - 1]) || !/[a-zA-Z\\d]/.test(parts[parts.length - 1])) || parts[parts.length - 2] && (/_/.test(parts[parts.length - 2]) || !/[a-zA-Z\\d]/.test(parts[parts.length - 2]))) {\n return false;\n }\n return true;\n}\nfunction splitUrl(url) {\n const trailExec = /[!\"&'),.:;<>?\\]}]+$/.exec(url);\n if (!trailExec) {\n return [url, void 0];\n }\n url = url.slice(0, trailExec.index);\n let trail2 = trailExec[0];\n let closingParenIndex = trail2.indexOf(\")\");\n const openingParens = ccount(url, \"(\");\n let closingParens = ccount(url, \")\");\n while (closingParenIndex !== -1 && openingParens > closingParens) {\n url += trail2.slice(0, closingParenIndex + 1);\n trail2 = trail2.slice(closingParenIndex + 1);\n closingParenIndex = trail2.indexOf(\")\");\n closingParens++;\n }\n return [url, trail2];\n}\nfunction previous(match, email) {\n const code2 = match.input.charCodeAt(match.index - 1);\n return (match.index === 0 || unicodeWhitespace(code2) || unicodePunctuation(code2)) && (!email || code2 !== 47);\n}\nfunction normalizeIdentifier(value) {\n return value.replace(/[\\t\\n\\r ]+/g, \" \").replace(/^ | $/g, \"\").toLowerCase().toUpperCase();\n}\nfootnoteReference.peek = footnoteReferencePeek;\nfunction enterFootnoteCallString() {\n this.buffer();\n}\nfunction enterFootnoteCall(token) {\n this.enter({ type: \"footnoteReference\", identifier: \"\", label: \"\" }, token);\n}\nfunction enterFootnoteDefinitionLabelString() {\n this.buffer();\n}\nfunction enterFootnoteDefinition(token) {\n this.enter(\n { type: \"footnoteDefinition\", identifier: \"\", label: \"\", children: [] },\n token\n );\n}\nfunction exitFootnoteCallString(token) {\n const label = this.resume();\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"footnoteReference\");\n node2.identifier = normalizeIdentifier(\n this.sliceSerialize(token)\n ).toLowerCase();\n node2.label = label;\n}\nfunction exitFootnoteCall(token) {\n this.exit(token);\n}\nfunction exitFootnoteDefinitionLabelString(token) {\n const label = this.resume();\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"footnoteDefinition\");\n node2.identifier = normalizeIdentifier(\n this.sliceSerialize(token)\n ).toLowerCase();\n node2.label = label;\n}\nfunction exitFootnoteDefinition(token) {\n this.exit(token);\n}\nfunction footnoteReferencePeek() {\n return \"[\";\n}\nfunction footnoteReference(node2, _, state, info) {\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[^\");\n const exit2 = state.enter(\"footnoteReference\");\n const subexit = state.enter(\"reference\");\n value += tracker.move(\n state.safe(state.associationId(node2), { after: \"]\", before: value })\n );\n subexit();\n exit2();\n value += tracker.move(\"]\");\n return value;\n}\nfunction gfmFootnoteFromMarkdown() {\n return {\n enter: {\n gfmFootnoteCallString: enterFootnoteCallString,\n gfmFootnoteCall: enterFootnoteCall,\n gfmFootnoteDefinitionLabelString: enterFootnoteDefinitionLabelString,\n gfmFootnoteDefinition: enterFootnoteDefinition\n },\n exit: {\n gfmFootnoteCallString: exitFootnoteCallString,\n gfmFootnoteCall: exitFootnoteCall,\n gfmFootnoteDefinitionLabelString: exitFootnoteDefinitionLabelString,\n gfmFootnoteDefinition: exitFootnoteDefinition\n }\n };\n}\nfunction gfmFootnoteToMarkdown(options) {\n let firstLineBlank = false;\n if (options && options.firstLineBlank) {\n firstLineBlank = true;\n }\n return {\n handlers: { footnoteDefinition, footnoteReference },\n // This is on by default already.\n unsafe: [{ character: \"[\", inConstruct: [\"label\", \"phrasing\", \"reference\"] }]\n };\n function footnoteDefinition(node2, _, state, info) {\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[^\");\n const exit2 = state.enter(\"footnoteDefinition\");\n const subexit = state.enter(\"label\");\n value += tracker.move(\n state.safe(state.associationId(node2), { before: value, after: \"]\" })\n );\n subexit();\n value += tracker.move(\"]:\");\n if (node2.children && node2.children.length > 0) {\n tracker.shift(4);\n value += tracker.move(\n (firstLineBlank ? \"\\n\" : \" \") + state.indentLines(\n state.containerFlow(node2, tracker.current()),\n firstLineBlank ? mapAll : mapExceptFirst\n )\n );\n }\n exit2();\n return value;\n }\n}\nfunction mapExceptFirst(line, index, blank) {\n return index === 0 ? line : mapAll(line, index, blank);\n}\nfunction mapAll(line, index, blank) {\n return (blank ? \"\" : \" \") + line;\n}\nconst constructsWithoutStrikethrough = [\n \"autolink\",\n \"destinationLiteral\",\n \"destinationRaw\",\n \"reference\",\n \"titleQuote\",\n \"titleApostrophe\"\n];\nhandleDelete.peek = peekDelete;\nfunction gfmStrikethroughFromMarkdown() {\n return {\n canContainEols: [\"delete\"],\n enter: { strikethrough: enterStrikethrough },\n exit: { strikethrough: exitStrikethrough }\n };\n}\nfunction gfmStrikethroughToMarkdown() {\n return {\n unsafe: [\n {\n character: \"~\",\n inConstruct: \"phrasing\",\n notInConstruct: constructsWithoutStrikethrough\n }\n ],\n handlers: { delete: handleDelete }\n };\n}\nfunction enterStrikethrough(token) {\n this.enter({ type: \"delete\", children: [] }, token);\n}\nfunction exitStrikethrough(token) {\n this.exit(token);\n}\nfunction handleDelete(node2, _, state, info) {\n const tracker = state.createTracker(info);\n const exit2 = state.enter(\"strikethrough\");\n let value = tracker.move(\"~~\");\n value += state.containerPhrasing(node2, {\n ...tracker.current(),\n before: value,\n after: \"~\"\n });\n value += tracker.move(\"~~\");\n exit2();\n return value;\n}\nfunction peekDelete() {\n return \"~\";\n}\nfunction defaultStringLength(value) {\n return value.length;\n}\nfunction markdownTable(table, options) {\n const settings = options || {};\n const align = (settings.align || []).concat();\n const stringLength = settings.stringLength || defaultStringLength;\n const alignments = [];\n const cellMatrix = [];\n const sizeMatrix = [];\n const longestCellByColumn = [];\n let mostCellsPerRow = 0;\n let rowIndex = -1;\n while (++rowIndex < table.length) {\n const row2 = [];\n const sizes2 = [];\n let columnIndex2 = -1;\n if (table[rowIndex].length > mostCellsPerRow) {\n mostCellsPerRow = table[rowIndex].length;\n }\n while (++columnIndex2 < table[rowIndex].length) {\n const cell = serialize(table[rowIndex][columnIndex2]);\n if (settings.alignDelimiters !== false) {\n const size = stringLength(cell);\n sizes2[columnIndex2] = size;\n if (longestCellByColumn[columnIndex2] === void 0 || size > longestCellByColumn[columnIndex2]) {\n longestCellByColumn[columnIndex2] = size;\n }\n }\n row2.push(cell);\n }\n cellMatrix[rowIndex] = row2;\n sizeMatrix[rowIndex] = sizes2;\n }\n let columnIndex = -1;\n if (typeof align === \"object\" && \"length\" in align) {\n while (++columnIndex < mostCellsPerRow) {\n alignments[columnIndex] = toAlignment(align[columnIndex]);\n }\n } else {\n const code2 = toAlignment(align);\n while (++columnIndex < mostCellsPerRow) {\n alignments[columnIndex] = code2;\n }\n }\n columnIndex = -1;\n const row = [];\n const sizes = [];\n while (++columnIndex < mostCellsPerRow) {\n const code2 = alignments[columnIndex];\n let before = \"\";\n let after = \"\";\n if (code2 === 99) {\n before = \":\";\n after = \":\";\n } else if (code2 === 108) {\n before = \":\";\n } else if (code2 === 114) {\n after = \":\";\n }\n let size = settings.alignDelimiters === false ? 1 : Math.max(\n 1,\n longestCellByColumn[columnIndex] - before.length - after.length\n );\n const cell = before + \"-\".repeat(size) + after;\n if (settings.alignDelimiters !== false) {\n size = before.length + size + after.length;\n if (size > longestCellByColumn[columnIndex]) {\n longestCellByColumn[columnIndex] = size;\n }\n sizes[columnIndex] = size;\n }\n row[columnIndex] = cell;\n }\n cellMatrix.splice(1, 0, row);\n sizeMatrix.splice(1, 0, sizes);\n rowIndex = -1;\n const lines = [];\n while (++rowIndex < cellMatrix.length) {\n const row2 = cellMatrix[rowIndex];\n const sizes2 = sizeMatrix[rowIndex];\n columnIndex = -1;\n const line = [];\n while (++columnIndex < mostCellsPerRow) {\n const cell = row2[columnIndex] || \"\";\n let before = \"\";\n let after = \"\";\n if (settings.alignDelimiters !== false) {\n const size = longestCellByColumn[columnIndex] - (sizes2[columnIndex] || 0);\n const code2 = alignments[columnIndex];\n if (code2 === 114) {\n before = \" \".repeat(size);\n } else if (code2 === 99) {\n if (size % 2) {\n before = \" \".repeat(size / 2 + 0.5);\n after = \" \".repeat(size / 2 - 0.5);\n } else {\n before = \" \".repeat(size / 2);\n after = before;\n }\n } else {\n after = \" \".repeat(size);\n }\n }\n if (settings.delimiterStart !== false && !columnIndex) {\n line.push(\"|\");\n }\n if (settings.padding !== false && // Don’t add the opening space if we’re not aligning and the cell is\n // empty: there will be a closing space.\n !(settings.alignDelimiters === false && cell === \"\") && (settings.delimiterStart !== false || columnIndex)) {\n line.push(\" \");\n }\n if (settings.alignDelimiters !== false) {\n line.push(before);\n }\n line.push(cell);\n if (settings.alignDelimiters !== false) {\n line.push(after);\n }\n if (settings.padding !== false) {\n line.push(\" \");\n }\n if (settings.delimiterEnd !== false || columnIndex !== mostCellsPerRow - 1) {\n line.push(\"|\");\n }\n }\n lines.push(\n settings.delimiterEnd === false ? line.join(\"\").replace(/ +$/, \"\") : line.join(\"\")\n );\n }\n return lines.join(\"\\n\");\n}\nfunction serialize(value) {\n return value === null || value === void 0 ? \"\" : String(value);\n}\nfunction toAlignment(value) {\n const code2 = typeof value === \"string\" ? value.codePointAt(0) : 0;\n return code2 === 67 || code2 === 99 ? 99 : code2 === 76 || code2 === 108 ? 108 : code2 === 82 || code2 === 114 ? 114 : 0;\n}\nfunction blockquote(node2, _, state, info) {\n const exit2 = state.enter(\"blockquote\");\n const tracker = state.createTracker(info);\n tracker.move(\"> \");\n tracker.shift(2);\n const value = state.indentLines(\n state.containerFlow(node2, tracker.current()),\n map$1\n );\n exit2();\n return value;\n}\nfunction map$1(line, _, blank) {\n return \">\" + (blank ? \"\" : \" \") + line;\n}\nfunction patternInScope(stack, pattern) {\n return listInScope(stack, pattern.inConstruct, true) && !listInScope(stack, pattern.notInConstruct, false);\n}\nfunction listInScope(stack, list2, none) {\n if (typeof list2 === \"string\") {\n list2 = [list2];\n }\n if (!list2 || list2.length === 0) {\n return none;\n }\n let index = -1;\n while (++index < list2.length) {\n if (stack.includes(list2[index])) {\n return true;\n }\n }\n return false;\n}\nfunction hardBreak(_, _1, state, info) {\n let index = -1;\n while (++index < state.unsafe.length) {\n if (state.unsafe[index].character === \"\\n\" && patternInScope(state.stack, state.unsafe[index])) {\n return /[ \\t]/.test(info.before) ? \"\" : \" \";\n }\n }\n return \"\\\\\\n\";\n}\nfunction longestStreak(value, substring) {\n const source = String(value);\n let index = source.indexOf(substring);\n let expected = index;\n let count = 0;\n let max = 0;\n if (typeof substring !== \"string\") {\n throw new TypeError(\"Expected substring\");\n }\n while (index !== -1) {\n if (index === expected) {\n if (++count > max) {\n max = count;\n }\n } else {\n count = 1;\n }\n expected = index + substring.length;\n index = source.indexOf(substring, expected);\n }\n return max;\n}\nfunction formatCodeAsIndented(node2, state) {\n return Boolean(\n state.options.fences === false && node2.value && // If there’s no info…\n !node2.lang && // And there’s a non-whitespace character…\n /[^ \\r\\n]/.test(node2.value) && // And the value doesn’t start or end in a blank…\n !/^[\\t ]*(?:[\\r\\n]|$)|(?:^|[\\r\\n])[\\t ]*$/.test(node2.value)\n );\n}\nfunction checkFence(state) {\n const marker = state.options.fence || \"`\";\n if (marker !== \"`\" && marker !== \"~\") {\n throw new Error(\n \"Cannot serialize code with `\" + marker + \"` for `options.fence`, expected `` ` `` or `~`\"\n );\n }\n return marker;\n}\nfunction code$1(node2, _, state, info) {\n const marker = checkFence(state);\n const raw = node2.value || \"\";\n const suffix = marker === \"`\" ? \"GraveAccent\" : \"Tilde\";\n if (formatCodeAsIndented(node2, state)) {\n const exit3 = state.enter(\"codeIndented\");\n const value2 = state.indentLines(raw, map);\n exit3();\n return value2;\n }\n const tracker = state.createTracker(info);\n const sequence = marker.repeat(Math.max(longestStreak(raw, marker) + 1, 3));\n const exit2 = state.enter(\"codeFenced\");\n let value = tracker.move(sequence);\n if (node2.lang) {\n const subexit = state.enter(`codeFencedLang${suffix}`);\n value += tracker.move(\n state.safe(node2.lang, {\n before: value,\n after: \" \",\n encode: [\"`\"],\n ...tracker.current()\n })\n );\n subexit();\n }\n if (node2.lang && node2.meta) {\n const subexit = state.enter(`codeFencedMeta${suffix}`);\n value += tracker.move(\" \");\n value += tracker.move(\n state.safe(node2.meta, {\n before: value,\n after: \"\\n\",\n encode: [\"`\"],\n ...tracker.current()\n })\n );\n subexit();\n }\n value += tracker.move(\"\\n\");\n if (raw) {\n value += tracker.move(raw + \"\\n\");\n }\n value += tracker.move(sequence);\n exit2();\n return value;\n}\nfunction map(line, _, blank) {\n return (blank ? \"\" : \" \") + line;\n}\nfunction checkQuote(state) {\n const marker = state.options.quote || '\"';\n if (marker !== '\"' && marker !== \"'\") {\n throw new Error(\n \"Cannot serialize title with `\" + marker + \"` for `options.quote`, expected `\\\"`, or `'`\"\n );\n }\n return marker;\n}\nfunction definition(node2, _, state, info) {\n const quote = checkQuote(state);\n const suffix = quote === '\"' ? \"Quote\" : \"Apostrophe\";\n const exit2 = state.enter(\"definition\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[\");\n value += tracker.move(\n state.safe(state.associationId(node2), {\n before: value,\n after: \"]\",\n ...tracker.current()\n })\n );\n value += tracker.move(\"]: \");\n subexit();\n if (\n // If there’s no url, or…\n !node2.url || // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node2.url)\n ) {\n subexit = state.enter(\"destinationLiteral\");\n value += tracker.move(\"<\");\n value += tracker.move(\n state.safe(node2.url, { before: value, after: \">\", ...tracker.current() })\n );\n value += tracker.move(\">\");\n } else {\n subexit = state.enter(\"destinationRaw\");\n value += tracker.move(\n state.safe(node2.url, {\n before: value,\n after: node2.title ? \" \" : \"\\n\",\n ...tracker.current()\n })\n );\n }\n subexit();\n if (node2.title) {\n subexit = state.enter(`title${suffix}`);\n value += tracker.move(\" \" + quote);\n value += tracker.move(\n state.safe(node2.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n );\n value += tracker.move(quote);\n subexit();\n }\n exit2();\n return value;\n}\nfunction checkEmphasis(state) {\n const marker = state.options.emphasis || \"*\";\n if (marker !== \"*\" && marker !== \"_\") {\n throw new Error(\n \"Cannot serialize emphasis with `\" + marker + \"` for `options.emphasis`, expected `*`, or `_`\"\n );\n }\n return marker;\n}\nfunction encodeCharacterReference(code2) {\n return \"&#x\" + code2.toString(16).toUpperCase() + \";\";\n}\nfunction classifyCharacter(code2) {\n if (code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)) {\n return 1;\n }\n if (unicodePunctuation(code2)) {\n return 2;\n }\n}\nfunction encodeInfo(outside, inside, marker) {\n const outsideKind = classifyCharacter(outside);\n const insideKind = classifyCharacter(inside);\n if (outsideKind === void 0) {\n return insideKind === void 0 ? (\n // Letter inside:\n // we have to encode *both* letters for `_` as it is looser.\n // it already forms for `*` (and GFMs `~`).\n marker === \"_\" ? { inside: true, outside: true } : { inside: false, outside: false }\n ) : insideKind === 1 ? (\n // Whitespace inside: encode both (letter, whitespace).\n { inside: true, outside: true }\n ) : (\n // Punctuation inside: encode outer (letter)\n { inside: false, outside: true }\n );\n }\n if (outsideKind === 1) {\n return insideKind === void 0 ? (\n // Letter inside: already forms.\n { inside: false, outside: false }\n ) : insideKind === 1 ? (\n // Whitespace inside: encode both (whitespace).\n { inside: true, outside: true }\n ) : (\n // Punctuation inside: already forms.\n { inside: false, outside: false }\n );\n }\n return insideKind === void 0 ? (\n // Letter inside: already forms.\n { inside: false, outside: false }\n ) : insideKind === 1 ? (\n // Whitespace inside: encode inner (whitespace).\n { inside: true, outside: false }\n ) : (\n // Punctuation inside: already forms.\n { inside: false, outside: false }\n );\n}\nemphasis.peek = emphasisPeek;\nfunction emphasis(node2, _, state, info) {\n const marker = checkEmphasis(state);\n const exit2 = state.enter(\"emphasis\");\n const tracker = state.createTracker(info);\n const before = tracker.move(marker);\n let between = tracker.move(\n state.containerPhrasing(node2, {\n after: marker,\n before,\n ...tracker.current()\n })\n );\n const betweenHead = between.charCodeAt(0);\n const open = encodeInfo(\n info.before.charCodeAt(info.before.length - 1),\n betweenHead,\n marker\n );\n if (open.inside) {\n between = encodeCharacterReference(betweenHead) + between.slice(1);\n }\n const betweenTail = between.charCodeAt(between.length - 1);\n const close = encodeInfo(info.after.charCodeAt(0), betweenTail, marker);\n if (close.inside) {\n between = between.slice(0, -1) + encodeCharacterReference(betweenTail);\n }\n const after = tracker.move(marker);\n exit2();\n state.attentionEncodeSurroundingInfo = {\n after: close.outside,\n before: open.outside\n };\n return before + between + after;\n}\nfunction emphasisPeek(_, _1, state) {\n return state.options.emphasis || \"*\";\n}\nconst emptyOptions$1 = {};\nfunction toString(value, options) {\n const settings = emptyOptions$1;\n const includeImageAlt = typeof settings.includeImageAlt === \"boolean\" ? settings.includeImageAlt : true;\n const includeHtml = typeof settings.includeHtml === \"boolean\" ? settings.includeHtml : true;\n return one(value, includeImageAlt, includeHtml);\n}\nfunction one(value, includeImageAlt, includeHtml) {\n if (node(value)) {\n if (\"value\" in value) {\n return value.type === \"html\" && !includeHtml ? \"\" : value.value;\n }\n if (includeImageAlt && \"alt\" in value && value.alt) {\n return value.alt;\n }\n if (\"children\" in value) {\n return all(value.children, includeImageAlt, includeHtml);\n }\n }\n if (Array.isArray(value)) {\n return all(value, includeImageAlt, includeHtml);\n }\n return \"\";\n}\nfunction all(values, includeImageAlt, includeHtml) {\n const result = [];\n let index = -1;\n while (++index < values.length) {\n result[index] = one(values[index], includeImageAlt, includeHtml);\n }\n return result.join(\"\");\n}\nfunction node(value) {\n return Boolean(value && typeof value === \"object\");\n}\nfunction formatHeadingAsSetext(node2, state) {\n let literalWithBreak = false;\n visit(node2, function(node3) {\n if (\"value\" in node3 && /\\r?\\n|\\r/.test(node3.value) || node3.type === \"break\") {\n literalWithBreak = true;\n return EXIT$1;\n }\n });\n return Boolean(\n (!node2.depth || node2.depth < 3) && toString(node2) && (state.options.setext || literalWithBreak)\n );\n}\nfunction heading(node2, _, state, info) {\n const rank = Math.max(Math.min(6, node2.depth || 1), 1);\n const tracker = state.createTracker(info);\n if (formatHeadingAsSetext(node2, state)) {\n const exit3 = state.enter(\"headingSetext\");\n const subexit2 = state.enter(\"phrasing\");\n const value2 = state.containerPhrasing(node2, {\n ...tracker.current(),\n before: \"\\n\",\n after: \"\\n\"\n });\n subexit2();\n exit3();\n return value2 + \"\\n\" + (rank === 1 ? \"=\" : \"-\").repeat(\n // The whole size…\n value2.length - // Minus the position of the character after the last EOL (or\n // 0 if there is none)…\n (Math.max(value2.lastIndexOf(\"\\r\"), value2.lastIndexOf(\"\\n\")) + 1)\n );\n }\n const sequence = \"#\".repeat(rank);\n const exit2 = state.enter(\"headingAtx\");\n const subexit = state.enter(\"phrasing\");\n tracker.move(sequence + \" \");\n let value = state.containerPhrasing(node2, {\n before: \"# \",\n after: \"\\n\",\n ...tracker.current()\n });\n if (/^[\\t ]/.test(value)) {\n value = encodeCharacterReference(value.charCodeAt(0)) + value.slice(1);\n }\n value = value ? sequence + \" \" + value : sequence;\n if (state.options.closeAtx) {\n value += \" \" + sequence;\n }\n subexit();\n exit2();\n return value;\n}\nhtml.peek = htmlPeek;\nfunction html(node2) {\n return node2.value || \"\";\n}\nfunction htmlPeek() {\n return \"<\";\n}\nimage.peek = imagePeek;\nfunction image(node2, _, state, info) {\n const quote = checkQuote(state);\n const suffix = quote === '\"' ? \"Quote\" : \"Apostrophe\";\n const exit2 = state.enter(\"image\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"![\");\n value += tracker.move(\n state.safe(node2.alt, { before: value, after: \"]\", ...tracker.current() })\n );\n value += tracker.move(\"](\");\n subexit();\n if (\n // If there’s no url but there is a title…\n !node2.url && node2.title || // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node2.url)\n ) {\n subexit = state.enter(\"destinationLiteral\");\n value += tracker.move(\"<\");\n value += tracker.move(\n state.safe(node2.url, { before: value, after: \">\", ...tracker.current() })\n );\n value += tracker.move(\">\");\n } else {\n subexit = state.enter(\"destinationRaw\");\n value += tracker.move(\n state.safe(node2.url, {\n before: value,\n after: node2.title ? \" \" : \")\",\n ...tracker.current()\n })\n );\n }\n subexit();\n if (node2.title) {\n subexit = state.enter(`title${suffix}`);\n value += tracker.move(\" \" + quote);\n value += tracker.move(\n state.safe(node2.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n );\n value += tracker.move(quote);\n subexit();\n }\n value += tracker.move(\")\");\n exit2();\n return value;\n}\nfunction imagePeek() {\n return \"!\";\n}\nimageReference.peek = imageReferencePeek;\nfunction imageReference(node2, _, state, info) {\n const type = node2.referenceType;\n const exit2 = state.enter(\"imageReference\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"![\");\n const alt = state.safe(node2.alt, {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n value += tracker.move(alt + \"][\");\n subexit();\n const stack = state.stack;\n state.stack = [];\n subexit = state.enter(\"reference\");\n const reference = state.safe(state.associationId(node2), {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n subexit();\n state.stack = stack;\n exit2();\n if (type === \"full\" || !alt || alt !== reference) {\n value += tracker.move(reference + \"]\");\n } else if (type === \"shortcut\") {\n value = value.slice(0, -1);\n } else {\n value += tracker.move(\"]\");\n }\n return value;\n}\nfunction imageReferencePeek() {\n return \"!\";\n}\ninlineCode.peek = inlineCodePeek;\nfunction inlineCode(node2, _, state) {\n let value = node2.value || \"\";\n let sequence = \"`\";\n let index = -1;\n while (new RegExp(\"(^|[^`])\" + sequence + \"([^`]|$)\").test(value)) {\n sequence += \"`\";\n }\n if (/[^ \\r\\n]/.test(value) && (/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value) || /^`|`$/.test(value))) {\n value = \" \" + value + \" \";\n }\n while (++index < state.unsafe.length) {\n const pattern = state.unsafe[index];\n const expression = state.compilePattern(pattern);\n let match;\n if (!pattern.atBreak) continue;\n while (match = expression.exec(value)) {\n let position = match.index;\n if (value.charCodeAt(position) === 10 && value.charCodeAt(position - 1) === 13) {\n position--;\n }\n value = value.slice(0, position) + \" \" + value.slice(match.index + 1);\n }\n }\n return sequence + value + sequence;\n}\nfunction inlineCodePeek() {\n return \"`\";\n}\nfunction formatLinkAsAutolink(node2, state) {\n const raw = toString(node2);\n return Boolean(\n !state.options.resourceLink && // If there’s a url…\n node2.url && // And there’s a no title…\n !node2.title && // And the content of `node` is a single text node…\n node2.children && node2.children.length === 1 && node2.children[0].type === \"text\" && // And if the url is the same as the content…\n (raw === node2.url || \"mailto:\" + raw === node2.url) && // And that starts w/ a protocol…\n /^[a-z][a-z+.-]+:/i.test(node2.url) && // And that doesn’t contain ASCII control codes (character escapes and\n // references don’t work), space, or angle brackets…\n !/[\\0- <>\\u007F]/.test(node2.url)\n );\n}\nlink.peek = linkPeek;\nfunction link(node2, _, state, info) {\n const quote = checkQuote(state);\n const suffix = quote === '\"' ? \"Quote\" : \"Apostrophe\";\n const tracker = state.createTracker(info);\n let exit2;\n let subexit;\n if (formatLinkAsAutolink(node2, state)) {\n const stack = state.stack;\n state.stack = [];\n exit2 = state.enter(\"autolink\");\n let value2 = tracker.move(\"<\");\n value2 += tracker.move(\n state.containerPhrasing(node2, {\n before: value2,\n after: \">\",\n ...tracker.current()\n })\n );\n value2 += tracker.move(\">\");\n exit2();\n state.stack = stack;\n return value2;\n }\n exit2 = state.enter(\"link\");\n subexit = state.enter(\"label\");\n let value = tracker.move(\"[\");\n value += tracker.move(\n state.containerPhrasing(node2, {\n before: value,\n after: \"](\",\n ...tracker.current()\n })\n );\n value += tracker.move(\"](\");\n subexit();\n if (\n // If there’s no url but there is a title…\n !node2.url && node2.title || // If there are control characters or whitespace.\n /[\\0- \\u007F]/.test(node2.url)\n ) {\n subexit = state.enter(\"destinationLiteral\");\n value += tracker.move(\"<\");\n value += tracker.move(\n state.safe(node2.url, { before: value, after: \">\", ...tracker.current() })\n );\n value += tracker.move(\">\");\n } else {\n subexit = state.enter(\"destinationRaw\");\n value += tracker.move(\n state.safe(node2.url, {\n before: value,\n after: node2.title ? \" \" : \")\",\n ...tracker.current()\n })\n );\n }\n subexit();\n if (node2.title) {\n subexit = state.enter(`title${suffix}`);\n value += tracker.move(\" \" + quote);\n value += tracker.move(\n state.safe(node2.title, {\n before: value,\n after: quote,\n ...tracker.current()\n })\n );\n value += tracker.move(quote);\n subexit();\n }\n value += tracker.move(\")\");\n exit2();\n return value;\n}\nfunction linkPeek(node2, _, state) {\n return formatLinkAsAutolink(node2, state) ? \"<\" : \"[\";\n}\nlinkReference.peek = linkReferencePeek;\nfunction linkReference(node2, _, state, info) {\n const type = node2.referenceType;\n const exit2 = state.enter(\"linkReference\");\n let subexit = state.enter(\"label\");\n const tracker = state.createTracker(info);\n let value = tracker.move(\"[\");\n const text2 = state.containerPhrasing(node2, {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n value += tracker.move(text2 + \"][\");\n subexit();\n const stack = state.stack;\n state.stack = [];\n subexit = state.enter(\"reference\");\n const reference = state.safe(state.associationId(node2), {\n before: value,\n after: \"]\",\n ...tracker.current()\n });\n subexit();\n state.stack = stack;\n exit2();\n if (type === \"full\" || !text2 || text2 !== reference) {\n value += tracker.move(reference + \"]\");\n } else if (type === \"shortcut\") {\n value = value.slice(0, -1);\n } else {\n value += tracker.move(\"]\");\n }\n return value;\n}\nfunction linkReferencePeek() {\n return \"[\";\n}\nfunction checkBullet(state) {\n const marker = state.options.bullet || \"*\";\n if (marker !== \"*\" && marker !== \"+\" && marker !== \"-\") {\n throw new Error(\n \"Cannot serialize items with `\" + marker + \"` for `options.bullet`, expected `*`, `+`, or `-`\"\n );\n }\n return marker;\n}\nfunction checkBulletOther(state) {\n const bullet = checkBullet(state);\n const bulletOther = state.options.bulletOther;\n if (!bulletOther) {\n return bullet === \"*\" ? \"-\" : \"*\";\n }\n if (bulletOther !== \"*\" && bulletOther !== \"+\" && bulletOther !== \"-\") {\n throw new Error(\n \"Cannot serialize items with `\" + bulletOther + \"` for `options.bulletOther`, expected `*`, `+`, or `-`\"\n );\n }\n if (bulletOther === bullet) {\n throw new Error(\n \"Expected `bullet` (`\" + bullet + \"`) and `bulletOther` (`\" + bulletOther + \"`) to be different\"\n );\n }\n return bulletOther;\n}\nfunction checkBulletOrdered(state) {\n const marker = state.options.bulletOrdered || \".\";\n if (marker !== \".\" && marker !== \")\") {\n throw new Error(\n \"Cannot serialize items with `\" + marker + \"` for `options.bulletOrdered`, expected `.` or `)`\"\n );\n }\n return marker;\n}\nfunction checkRule(state) {\n const marker = state.options.rule || \"*\";\n if (marker !== \"*\" && marker !== \"-\" && marker !== \"_\") {\n throw new Error(\n \"Cannot serialize rules with `\" + marker + \"` for `options.rule`, expected `*`, `-`, or `_`\"\n );\n }\n return marker;\n}\nfunction list(node2, parent, state, info) {\n const exit2 = state.enter(\"list\");\n const bulletCurrent = state.bulletCurrent;\n let bullet = node2.ordered ? checkBulletOrdered(state) : checkBullet(state);\n const bulletOther = node2.ordered ? bullet === \".\" ? \")\" : \".\" : checkBulletOther(state);\n let useDifferentMarker = parent && state.bulletLastUsed ? bullet === state.bulletLastUsed : false;\n if (!node2.ordered) {\n const firstListItem = node2.children ? node2.children[0] : void 0;\n if (\n // Bullet could be used as a thematic break marker:\n (bullet === \"*\" || bullet === \"-\") && // Empty first list item:\n firstListItem && (!firstListItem.children || !firstListItem.children[0]) && // Directly in two other list items:\n state.stack[state.stack.length - 1] === \"list\" && state.stack[state.stack.length - 2] === \"listItem\" && state.stack[state.stack.length - 3] === \"list\" && state.stack[state.stack.length - 4] === \"listItem\" && // That are each the first child.\n state.indexStack[state.indexStack.length - 1] === 0 && state.indexStack[state.indexStack.length - 2] === 0 && state.indexStack[state.indexStack.length - 3] === 0\n ) {\n useDifferentMarker = true;\n }\n if (checkRule(state) === bullet && firstListItem) {\n let index = -1;\n while (++index < node2.children.length) {\n const item = node2.children[index];\n if (item && item.type === \"listItem\" && item.children && item.children[0] && item.children[0].type === \"thematicBreak\") {\n useDifferentMarker = true;\n break;\n }\n }\n }\n }\n if (useDifferentMarker) {\n bullet = bulletOther;\n }\n state.bulletCurrent = bullet;\n const value = state.containerFlow(node2, info);\n state.bulletLastUsed = bullet;\n state.bulletCurrent = bulletCurrent;\n exit2();\n return value;\n}\nfunction checkListItemIndent(state) {\n const style = state.options.listItemIndent || \"one\";\n if (style !== \"tab\" && style !== \"one\" && style !== \"mixed\") {\n throw new Error(\n \"Cannot serialize items with `\" + style + \"` for `options.listItemIndent`, expected `tab`, `one`, or `mixed`\"\n );\n }\n return style;\n}\nfunction listItem(node2, parent, state, info) {\n const listItemIndent = checkListItemIndent(state);\n let bullet = state.bulletCurrent || checkBullet(state);\n if (parent && parent.type === \"list\" && parent.ordered) {\n bullet = (typeof parent.start === \"number\" && parent.start > -1 ? parent.start : 1) + (state.options.incrementListMarker === false ? 0 : parent.children.indexOf(node2)) + bullet;\n }\n let size = bullet.length + 1;\n if (listItemIndent === \"tab\" || listItemIndent === \"mixed\" && (parent && parent.type === \"list\" && parent.spread || node2.spread)) {\n size = Math.ceil(size / 4) * 4;\n }\n const tracker = state.createTracker(info);\n tracker.move(bullet + \" \".repeat(size - bullet.length));\n tracker.shift(size);\n const exit2 = state.enter(\"listItem\");\n const value = state.indentLines(\n state.containerFlow(node2, tracker.current()),\n map2\n );\n exit2();\n return value;\n function map2(line, index, blank) {\n if (index) {\n return (blank ? \"\" : \" \".repeat(size)) + line;\n }\n return (blank ? bullet : bullet + \" \".repeat(size - bullet.length)) + line;\n }\n}\nfunction paragraph(node2, _, state, info) {\n const exit2 = state.enter(\"paragraph\");\n const subexit = state.enter(\"phrasing\");\n const value = state.containerPhrasing(node2, info);\n subexit();\n exit2();\n return value;\n}\nconst phrasing = (\n /** @type {(node?: unknown) => node is Exclude} */\n convert([\n \"break\",\n \"delete\",\n \"emphasis\",\n // To do: next major: removed since footnotes were added to GFM.\n \"footnote\",\n \"footnoteReference\",\n \"image\",\n \"imageReference\",\n \"inlineCode\",\n // Enabled by `mdast-util-math`:\n \"inlineMath\",\n \"link\",\n \"linkReference\",\n // Enabled by `mdast-util-mdx`:\n \"mdxJsxTextElement\",\n // Enabled by `mdast-util-mdx`:\n \"mdxTextExpression\",\n \"strong\",\n \"text\",\n // Enabled by `mdast-util-directive`:\n \"textDirective\"\n ])\n);\nfunction root(node2, _, state, info) {\n const hasPhrasing = node2.children.some(function(d) {\n return phrasing(d);\n });\n const container = hasPhrasing ? state.containerPhrasing : state.containerFlow;\n return container.call(state, node2, info);\n}\nfunction checkStrong(state) {\n const marker = state.options.strong || \"*\";\n if (marker !== \"*\" && marker !== \"_\") {\n throw new Error(\n \"Cannot serialize strong with `\" + marker + \"` for `options.strong`, expected `*`, or `_`\"\n );\n }\n return marker;\n}\nstrong.peek = strongPeek;\nfunction strong(node2, _, state, info) {\n const marker = checkStrong(state);\n const exit2 = state.enter(\"strong\");\n const tracker = state.createTracker(info);\n const before = tracker.move(marker + marker);\n let between = tracker.move(\n state.containerPhrasing(node2, {\n after: marker,\n before,\n ...tracker.current()\n })\n );\n const betweenHead = between.charCodeAt(0);\n const open = encodeInfo(\n info.before.charCodeAt(info.before.length - 1),\n betweenHead,\n marker\n );\n if (open.inside) {\n between = encodeCharacterReference(betweenHead) + between.slice(1);\n }\n const betweenTail = between.charCodeAt(between.length - 1);\n const close = encodeInfo(info.after.charCodeAt(0), betweenTail, marker);\n if (close.inside) {\n between = between.slice(0, -1) + encodeCharacterReference(betweenTail);\n }\n const after = tracker.move(marker + marker);\n exit2();\n state.attentionEncodeSurroundingInfo = {\n after: close.outside,\n before: open.outside\n };\n return before + between + after;\n}\nfunction strongPeek(_, _1, state) {\n return state.options.strong || \"*\";\n}\nfunction text$1(node2, _, state, info) {\n return state.safe(node2.value, info);\n}\nfunction checkRuleRepetition(state) {\n const repetition = state.options.ruleRepetition || 3;\n if (repetition < 3) {\n throw new Error(\n \"Cannot serialize rules with repetition `\" + repetition + \"` for `options.ruleRepetition`, expected `3` or more\"\n );\n }\n return repetition;\n}\nfunction thematicBreak(_, _1, state) {\n const value = (checkRule(state) + (state.options.ruleSpaces ? \" \" : \"\")).repeat(checkRuleRepetition(state));\n return state.options.ruleSpaces ? value.slice(0, -1) : value;\n}\nconst handle = {\n blockquote,\n break: hardBreak,\n code: code$1,\n definition,\n emphasis,\n hardBreak,\n heading,\n html,\n image,\n imageReference,\n inlineCode,\n link,\n linkReference,\n list,\n listItem,\n paragraph,\n root,\n strong,\n text: text$1,\n thematicBreak\n};\nfunction gfmTableFromMarkdown() {\n return {\n enter: {\n table: enterTable,\n tableData: enterCell,\n tableHeader: enterCell,\n tableRow: enterRow\n },\n exit: {\n codeText: exitCodeText,\n table: exitTable,\n tableData: exit,\n tableHeader: exit,\n tableRow: exit\n }\n };\n}\nfunction enterTable(token) {\n const align = token._align;\n this.enter(\n {\n type: \"table\",\n align: align.map(function(d) {\n return d === \"none\" ? null : d;\n }),\n children: []\n },\n token\n );\n this.data.inTable = true;\n}\nfunction exitTable(token) {\n this.exit(token);\n this.data.inTable = void 0;\n}\nfunction enterRow(token) {\n this.enter({ type: \"tableRow\", children: [] }, token);\n}\nfunction exit(token) {\n this.exit(token);\n}\nfunction enterCell(token) {\n this.enter({ type: \"tableCell\", children: [] }, token);\n}\nfunction exitCodeText(token) {\n let value = this.resume();\n if (this.data.inTable) {\n value = value.replace(/\\\\([\\\\|])/g, replace);\n }\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"inlineCode\");\n node2.value = value;\n this.exit(token);\n}\nfunction replace($0, $1) {\n return $1 === \"|\" ? $1 : $0;\n}\nfunction gfmTableToMarkdown(options) {\n const settings = options || {};\n const padding = settings.tableCellPadding;\n const alignDelimiters = settings.tablePipeAlign;\n const stringLength = settings.stringLength;\n const around = padding ? \" \" : \"|\";\n return {\n unsafe: [\n { character: \"\\r\", inConstruct: \"tableCell\" },\n { character: \"\\n\", inConstruct: \"tableCell\" },\n // A pipe, when followed by a tab or space (padding), or a dash or colon\n // (unpadded delimiter row), could result in a table.\n { atBreak: true, character: \"|\", after: \"[\t :-]\" },\n // A pipe in a cell must be encoded.\n { character: \"|\", inConstruct: \"tableCell\" },\n // A colon must be followed by a dash, in which case it could start a\n // delimiter row.\n { atBreak: true, character: \":\", after: \"-\" },\n // A delimiter row can also start with a dash, when followed by more\n // dashes, a colon, or a pipe.\n // This is a stricter version than the built in check for lists, thematic\n // breaks, and setex heading underlines though:\n // \n { atBreak: true, character: \"-\", after: \"[:|-]\" }\n ],\n handlers: {\n inlineCode: inlineCodeWithTable,\n table: handleTable,\n tableCell: handleTableCell,\n tableRow: handleTableRow\n }\n };\n function handleTable(node2, _, state, info) {\n return serializeData(handleTableAsData(node2, state, info), node2.align);\n }\n function handleTableRow(node2, _, state, info) {\n const row = handleTableRowAsData(node2, state, info);\n const value = serializeData([row]);\n return value.slice(0, value.indexOf(\"\\n\"));\n }\n function handleTableCell(node2, _, state, info) {\n const exit2 = state.enter(\"tableCell\");\n const subexit = state.enter(\"phrasing\");\n const value = state.containerPhrasing(node2, {\n ...info,\n before: around,\n after: around\n });\n subexit();\n exit2();\n return value;\n }\n function serializeData(matrix, align) {\n return markdownTable(matrix, {\n align,\n // @ts-expect-error: `markdown-table` types should support `null`.\n alignDelimiters,\n // @ts-expect-error: `markdown-table` types should support `null`.\n padding,\n // @ts-expect-error: `markdown-table` types should support `null`.\n stringLength\n });\n }\n function handleTableAsData(node2, state, info) {\n const children = node2.children;\n let index = -1;\n const result = [];\n const subexit = state.enter(\"table\");\n while (++index < children.length) {\n result[index] = handleTableRowAsData(children[index], state, info);\n }\n subexit();\n return result;\n }\n function handleTableRowAsData(node2, state, info) {\n const children = node2.children;\n let index = -1;\n const result = [];\n const subexit = state.enter(\"tableRow\");\n while (++index < children.length) {\n result[index] = handleTableCell(children[index], node2, state, info);\n }\n subexit();\n return result;\n }\n function inlineCodeWithTable(node2, parent, state) {\n let value = handle.inlineCode(node2, parent, state);\n if (state.stack.includes(\"tableCell\")) {\n value = value.replace(/\\|/g, \"\\\\$&\");\n }\n return value;\n }\n}\nfunction gfmTaskListItemFromMarkdown() {\n return {\n exit: {\n taskListCheckValueChecked: exitCheck,\n taskListCheckValueUnchecked: exitCheck,\n paragraph: exitParagraphWithTaskListItem\n }\n };\n}\nfunction gfmTaskListItemToMarkdown() {\n return {\n unsafe: [{ atBreak: true, character: \"-\", after: \"[:|-]\" }],\n handlers: { listItem: listItemWithTaskListItem }\n };\n}\nfunction exitCheck(token) {\n const node2 = this.stack[this.stack.length - 2];\n ok$1(node2.type === \"listItem\");\n node2.checked = token.type === \"taskListCheckValueChecked\";\n}\nfunction exitParagraphWithTaskListItem(token) {\n const parent = this.stack[this.stack.length - 2];\n if (parent && parent.type === \"listItem\" && typeof parent.checked === \"boolean\") {\n const node2 = this.stack[this.stack.length - 1];\n ok$1(node2.type === \"paragraph\");\n const head = node2.children[0];\n if (head && head.type === \"text\") {\n const siblings = parent.children;\n let index = -1;\n let firstParaghraph;\n while (++index < siblings.length) {\n const sibling = siblings[index];\n if (sibling.type === \"paragraph\") {\n firstParaghraph = sibling;\n break;\n }\n }\n if (firstParaghraph === node2) {\n head.value = head.value.slice(1);\n if (head.value.length === 0) {\n node2.children.shift();\n } else if (node2.position && head.position && typeof head.position.start.offset === \"number\") {\n head.position.start.column++;\n head.position.start.offset++;\n node2.position.start = Object.assign({}, head.position.start);\n }\n }\n }\n }\n this.exit(token);\n}\nfunction listItemWithTaskListItem(node2, parent, state, info) {\n const head = node2.children[0];\n const checkable = typeof node2.checked === \"boolean\" && head && head.type === \"paragraph\";\n const checkbox = \"[\" + (node2.checked ? \"x\" : \" \") + \"] \";\n const tracker = state.createTracker(info);\n if (checkable) {\n tracker.move(checkbox);\n }\n let value = handle.listItem(node2, parent, state, {\n ...info,\n ...tracker.current()\n });\n if (checkable) {\n value = value.replace(/^(?:[*+-]|\\d+\\.)([\\r\\n]| {1,3})/, check);\n }\n return value;\n function check($0) {\n return $0 + checkbox;\n }\n}\nfunction gfmFromMarkdown() {\n return [\n gfmAutolinkLiteralFromMarkdown(),\n gfmFootnoteFromMarkdown(),\n gfmStrikethroughFromMarkdown(),\n gfmTableFromMarkdown(),\n gfmTaskListItemFromMarkdown()\n ];\n}\nfunction gfmToMarkdown(options) {\n return {\n extensions: [\n gfmAutolinkLiteralToMarkdown(),\n gfmFootnoteToMarkdown(options),\n gfmStrikethroughToMarkdown(),\n gfmTableToMarkdown(options),\n gfmTaskListItemToMarkdown()\n ]\n };\n}\nfunction splice(list2, start, remove, items) {\n const end = list2.length;\n let chunkStart = 0;\n let parameters;\n if (start < 0) {\n start = -start > end ? 0 : end + start;\n } else {\n start = start > end ? end : start;\n }\n remove = remove > 0 ? remove : 0;\n if (items.length < 1e4) {\n parameters = Array.from(items);\n parameters.unshift(start, remove);\n list2.splice(...parameters);\n } else {\n if (remove) list2.splice(start, remove);\n while (chunkStart < items.length) {\n parameters = items.slice(chunkStart, chunkStart + 1e4);\n parameters.unshift(start, 0);\n list2.splice(...parameters);\n chunkStart += 1e4;\n start += 1e4;\n }\n }\n}\nconst hasOwnProperty = {}.hasOwnProperty;\nfunction combineExtensions(extensions) {\n const all2 = {};\n let index = -1;\n while (++index < extensions.length) {\n syntaxExtension(all2, extensions[index]);\n }\n return all2;\n}\nfunction syntaxExtension(all2, extension) {\n let hook;\n for (hook in extension) {\n const maybe = hasOwnProperty.call(all2, hook) ? all2[hook] : void 0;\n const left = maybe || (all2[hook] = {});\n const right = extension[hook];\n let code2;\n if (right) {\n for (code2 in right) {\n if (!hasOwnProperty.call(left, code2)) left[code2] = [];\n const value = right[code2];\n constructs(\n // @ts-expect-error Looks like a list.\n left[code2],\n Array.isArray(value) ? value : value ? [value] : []\n );\n }\n }\n }\n}\nfunction constructs(existing, list2) {\n let index = -1;\n const before = [];\n while (++index < list2.length) {\n (list2[index].add === \"after\" ? existing : before).push(list2[index]);\n }\n splice(existing, 0, 0, before);\n}\nconst wwwPrefix = {\n tokenize: tokenizeWwwPrefix,\n partial: true\n};\nconst domain = {\n tokenize: tokenizeDomain,\n partial: true\n};\nconst path = {\n tokenize: tokenizePath,\n partial: true\n};\nconst trail = {\n tokenize: tokenizeTrail,\n partial: true\n};\nconst emailDomainDotTrail = {\n tokenize: tokenizeEmailDomainDotTrail,\n partial: true\n};\nconst wwwAutolink = {\n name: \"wwwAutolink\",\n tokenize: tokenizeWwwAutolink,\n previous: previousWww\n};\nconst protocolAutolink = {\n name: \"protocolAutolink\",\n tokenize: tokenizeProtocolAutolink,\n previous: previousProtocol\n};\nconst emailAutolink = {\n name: \"emailAutolink\",\n tokenize: tokenizeEmailAutolink,\n previous: previousEmail\n};\nconst text = {};\nfunction gfmAutolinkLiteral() {\n return {\n text\n };\n}\nlet code = 48;\nwhile (code < 123) {\n text[code] = emailAutolink;\n code++;\n if (code === 58) code = 65;\n else if (code === 91) code = 97;\n}\ntext[43] = emailAutolink;\ntext[45] = emailAutolink;\ntext[46] = emailAutolink;\ntext[95] = emailAutolink;\ntext[72] = [emailAutolink, protocolAutolink];\ntext[104] = [emailAutolink, protocolAutolink];\ntext[87] = [emailAutolink, wwwAutolink];\ntext[119] = [emailAutolink, wwwAutolink];\nfunction tokenizeEmailAutolink(effects, ok2, nok) {\n const self = this;\n let dot;\n let data;\n return start;\n function start(code2) {\n if (!gfmAtext(code2) || !previousEmail.call(self, self.previous) || previousUnbalanced(self.events)) {\n return nok(code2);\n }\n effects.enter(\"literalAutolink\");\n effects.enter(\"literalAutolinkEmail\");\n return atext(code2);\n }\n function atext(code2) {\n if (gfmAtext(code2)) {\n effects.consume(code2);\n return atext;\n }\n if (code2 === 64) {\n effects.consume(code2);\n return emailDomain;\n }\n return nok(code2);\n }\n function emailDomain(code2) {\n if (code2 === 46) {\n return effects.check(emailDomainDotTrail, emailDomainAfter, emailDomainDot)(code2);\n }\n if (code2 === 45 || code2 === 95 || asciiAlphanumeric(code2)) {\n data = true;\n effects.consume(code2);\n return emailDomain;\n }\n return emailDomainAfter(code2);\n }\n function emailDomainDot(code2) {\n effects.consume(code2);\n dot = true;\n return emailDomain;\n }\n function emailDomainAfter(code2) {\n if (data && dot && asciiAlpha(self.previous)) {\n effects.exit(\"literalAutolinkEmail\");\n effects.exit(\"literalAutolink\");\n return ok2(code2);\n }\n return nok(code2);\n }\n}\nfunction tokenizeWwwAutolink(effects, ok2, nok) {\n const self = this;\n return wwwStart;\n function wwwStart(code2) {\n if (code2 !== 87 && code2 !== 119 || !previousWww.call(self, self.previous) || previousUnbalanced(self.events)) {\n return nok(code2);\n }\n effects.enter(\"literalAutolink\");\n effects.enter(\"literalAutolinkWww\");\n return effects.check(wwwPrefix, effects.attempt(domain, effects.attempt(path, wwwAfter), nok), nok)(code2);\n }\n function wwwAfter(code2) {\n effects.exit(\"literalAutolinkWww\");\n effects.exit(\"literalAutolink\");\n return ok2(code2);\n }\n}\nfunction tokenizeProtocolAutolink(effects, ok2, nok) {\n const self = this;\n let buffer = \"\";\n let seen = false;\n return protocolStart;\n function protocolStart(code2) {\n if ((code2 === 72 || code2 === 104) && previousProtocol.call(self, self.previous) && !previousUnbalanced(self.events)) {\n effects.enter(\"literalAutolink\");\n effects.enter(\"literalAutolinkHttp\");\n buffer += String.fromCodePoint(code2);\n effects.consume(code2);\n return protocolPrefixInside;\n }\n return nok(code2);\n }\n function protocolPrefixInside(code2) {\n if (asciiAlpha(code2) && buffer.length < 5) {\n buffer += String.fromCodePoint(code2);\n effects.consume(code2);\n return protocolPrefixInside;\n }\n if (code2 === 58) {\n const protocol = buffer.toLowerCase();\n if (protocol === \"http\" || protocol === \"https\") {\n effects.consume(code2);\n return protocolSlashesInside;\n }\n }\n return nok(code2);\n }\n function protocolSlashesInside(code2) {\n if (code2 === 47) {\n effects.consume(code2);\n if (seen) {\n return afterProtocol;\n }\n seen = true;\n return protocolSlashesInside;\n }\n return nok(code2);\n }\n function afterProtocol(code2) {\n return code2 === null || asciiControl(code2) || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2) || unicodePunctuation(code2) ? nok(code2) : effects.attempt(domain, effects.attempt(path, protocolAfter), nok)(code2);\n }\n function protocolAfter(code2) {\n effects.exit(\"literalAutolinkHttp\");\n effects.exit(\"literalAutolink\");\n return ok2(code2);\n }\n}\nfunction tokenizeWwwPrefix(effects, ok2, nok) {\n let size = 0;\n return wwwPrefixInside;\n function wwwPrefixInside(code2) {\n if ((code2 === 87 || code2 === 119) && size < 3) {\n size++;\n effects.consume(code2);\n return wwwPrefixInside;\n }\n if (code2 === 46 && size === 3) {\n effects.consume(code2);\n return wwwPrefixAfter;\n }\n return nok(code2);\n }\n function wwwPrefixAfter(code2) {\n return code2 === null ? nok(code2) : ok2(code2);\n }\n}\nfunction tokenizeDomain(effects, ok2, nok) {\n let underscoreInLastSegment;\n let underscoreInLastLastSegment;\n let seen;\n return domainInside;\n function domainInside(code2) {\n if (code2 === 46 || code2 === 95) {\n return effects.check(trail, domainAfter, domainAtPunctuation)(code2);\n }\n if (code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2) || code2 !== 45 && unicodePunctuation(code2)) {\n return domainAfter(code2);\n }\n seen = true;\n effects.consume(code2);\n return domainInside;\n }\n function domainAtPunctuation(code2) {\n if (code2 === 95) {\n underscoreInLastSegment = true;\n } else {\n underscoreInLastLastSegment = underscoreInLastSegment;\n underscoreInLastSegment = void 0;\n }\n effects.consume(code2);\n return domainInside;\n }\n function domainAfter(code2) {\n if (underscoreInLastLastSegment || underscoreInLastSegment || !seen) {\n return nok(code2);\n }\n return ok2(code2);\n }\n}\nfunction tokenizePath(effects, ok2) {\n let sizeOpen = 0;\n let sizeClose = 0;\n return pathInside;\n function pathInside(code2) {\n if (code2 === 40) {\n sizeOpen++;\n effects.consume(code2);\n return pathInside;\n }\n if (code2 === 41 && sizeClose < sizeOpen) {\n return pathAtPunctuation(code2);\n }\n if (code2 === 33 || code2 === 34 || code2 === 38 || code2 === 39 || code2 === 41 || code2 === 42 || code2 === 44 || code2 === 46 || code2 === 58 || code2 === 59 || code2 === 60 || code2 === 63 || code2 === 93 || code2 === 95 || code2 === 126) {\n return effects.check(trail, ok2, pathAtPunctuation)(code2);\n }\n if (code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)) {\n return ok2(code2);\n }\n effects.consume(code2);\n return pathInside;\n }\n function pathAtPunctuation(code2) {\n if (code2 === 41) {\n sizeClose++;\n }\n effects.consume(code2);\n return pathInside;\n }\n}\nfunction tokenizeTrail(effects, ok2, nok) {\n return trail2;\n function trail2(code2) {\n if (code2 === 33 || code2 === 34 || code2 === 39 || code2 === 41 || code2 === 42 || code2 === 44 || code2 === 46 || code2 === 58 || code2 === 59 || code2 === 63 || code2 === 95 || code2 === 126) {\n effects.consume(code2);\n return trail2;\n }\n if (code2 === 38) {\n effects.consume(code2);\n return trailCharacterReferenceStart;\n }\n if (code2 === 93) {\n effects.consume(code2);\n return trailBracketAfter;\n }\n if (\n // `<` is an end.\n code2 === 60 || // So is whitespace.\n code2 === null || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)\n ) {\n return ok2(code2);\n }\n return nok(code2);\n }\n function trailBracketAfter(code2) {\n if (code2 === null || code2 === 40 || code2 === 91 || markdownLineEndingOrSpace(code2) || unicodeWhitespace(code2)) {\n return ok2(code2);\n }\n return trail2(code2);\n }\n function trailCharacterReferenceStart(code2) {\n return asciiAlpha(code2) ? trailCharacterReferenceInside(code2) : nok(code2);\n }\n function trailCharacterReferenceInside(code2) {\n if (code2 === 59) {\n effects.consume(code2);\n return trail2;\n }\n if (asciiAlpha(code2)) {\n effects.consume(code2);\n return trailCharacterReferenceInside;\n }\n return nok(code2);\n }\n}\nfunction tokenizeEmailDomainDotTrail(effects, ok2, nok) {\n return start;\n function start(code2) {\n effects.consume(code2);\n return after;\n }\n function after(code2) {\n return asciiAlphanumeric(code2) ? nok(code2) : ok2(code2);\n }\n}\nfunction previousWww(code2) {\n return code2 === null || code2 === 40 || code2 === 42 || code2 === 95 || code2 === 91 || code2 === 93 || code2 === 126 || markdownLineEndingOrSpace(code2);\n}\nfunction previousProtocol(code2) {\n return !asciiAlpha(code2);\n}\nfunction previousEmail(code2) {\n return !(code2 === 47 || gfmAtext(code2));\n}\nfunction gfmAtext(code2) {\n return code2 === 43 || code2 === 45 || code2 === 46 || code2 === 95 || asciiAlphanumeric(code2);\n}\nfunction previousUnbalanced(events) {\n let index = events.length;\n let result = false;\n while (index--) {\n const token = events[index][1];\n if ((token.type === \"labelLink\" || token.type === \"labelImage\") && !token._balanced) {\n result = true;\n break;\n }\n if (token._gfmAutolinkLiteralWalkedInto) {\n result = false;\n break;\n }\n }\n if (events.length > 0 && !result) {\n events[events.length - 1][1]._gfmAutolinkLiteralWalkedInto = true;\n }\n return result;\n}\nfunction resolveAll(constructs2, events, context) {\n const called = [];\n let index = -1;\n while (++index < constructs2.length) {\n const resolve = constructs2[index].resolveAll;\n if (resolve && !called.includes(resolve)) {\n events = resolve(events, context);\n called.push(resolve);\n }\n }\n return events;\n}\nfunction factorySpace(effects, ok2, type, max) {\n const limit = max ? max - 1 : Number.POSITIVE_INFINITY;\n let size = 0;\n return start;\n function start(code2) {\n if (markdownSpace(code2)) {\n effects.enter(type);\n return prefix(code2);\n }\n return ok2(code2);\n }\n function prefix(code2) {\n if (markdownSpace(code2) && size++ < limit) {\n effects.consume(code2);\n return prefix;\n }\n effects.exit(type);\n return ok2(code2);\n }\n}\nconst blankLine = {\n partial: true,\n tokenize: tokenizeBlankLine\n};\nfunction tokenizeBlankLine(effects, ok2, nok) {\n return start;\n function start(code2) {\n return markdownSpace(code2) ? factorySpace(effects, after, \"linePrefix\")(code2) : after(code2);\n }\n function after(code2) {\n return code2 === null || markdownLineEnding(code2) ? ok2(code2) : nok(code2);\n }\n}\nconst indent = {\n tokenize: tokenizeIndent,\n partial: true\n};\nfunction gfmFootnote() {\n return {\n document: {\n [91]: {\n name: \"gfmFootnoteDefinition\",\n tokenize: tokenizeDefinitionStart,\n continuation: {\n tokenize: tokenizeDefinitionContinuation\n },\n exit: gfmFootnoteDefinitionEnd\n }\n },\n text: {\n [91]: {\n name: \"gfmFootnoteCall\",\n tokenize: tokenizeGfmFootnoteCall\n },\n [93]: {\n name: \"gfmPotentialFootnoteCall\",\n add: \"after\",\n tokenize: tokenizePotentialGfmFootnoteCall,\n resolveTo: resolveToPotentialGfmFootnoteCall\n }\n }\n };\n}\nfunction tokenizePotentialGfmFootnoteCall(effects, ok2, nok) {\n const self = this;\n let index = self.events.length;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let labelStart;\n while (index--) {\n const token = self.events[index][1];\n if (token.type === \"labelImage\") {\n labelStart = token;\n break;\n }\n if (token.type === \"gfmFootnoteCall\" || token.type === \"labelLink\" || token.type === \"label\" || token.type === \"image\" || token.type === \"link\") {\n break;\n }\n }\n return start;\n function start(code2) {\n if (!labelStart || !labelStart._balanced) {\n return nok(code2);\n }\n const id = normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n }));\n if (id.codePointAt(0) !== 94 || !defined.includes(id.slice(1))) {\n return nok(code2);\n }\n effects.enter(\"gfmFootnoteCallLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallLabelMarker\");\n return ok2(code2);\n }\n}\nfunction resolveToPotentialGfmFootnoteCall(events, context) {\n let index = events.length;\n while (index--) {\n if (events[index][1].type === \"labelImage\" && events[index][0] === \"enter\") {\n events[index][1];\n break;\n }\n }\n events[index + 1][1].type = \"data\";\n events[index + 3][1].type = \"gfmFootnoteCallLabelMarker\";\n const call = {\n type: \"gfmFootnoteCall\",\n start: Object.assign({}, events[index + 3][1].start),\n end: Object.assign({}, events[events.length - 1][1].end)\n };\n const marker = {\n type: \"gfmFootnoteCallMarker\",\n start: Object.assign({}, events[index + 3][1].end),\n end: Object.assign({}, events[index + 3][1].end)\n };\n marker.end.column++;\n marker.end.offset++;\n marker.end._bufferIndex++;\n const string = {\n type: \"gfmFootnoteCallString\",\n start: Object.assign({}, marker.end),\n end: Object.assign({}, events[events.length - 1][1].start)\n };\n const chunk = {\n type: \"chunkString\",\n contentType: \"string\",\n start: Object.assign({}, string.start),\n end: Object.assign({}, string.end)\n };\n const replacement = [\n // Take the `labelImageMarker` (now `data`, the `!`)\n events[index + 1],\n events[index + 2],\n [\"enter\", call, context],\n // The `[`\n events[index + 3],\n events[index + 4],\n // The `^`.\n [\"enter\", marker, context],\n [\"exit\", marker, context],\n // Everything in between.\n [\"enter\", string, context],\n [\"enter\", chunk, context],\n [\"exit\", chunk, context],\n [\"exit\", string, context],\n // The ending (`]`, properly parsed and labelled).\n events[events.length - 2],\n events[events.length - 1],\n [\"exit\", call, context]\n ];\n events.splice(index, events.length - index + 1, ...replacement);\n return events;\n}\nfunction tokenizeGfmFootnoteCall(effects, ok2, nok) {\n const self = this;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let size = 0;\n let data;\n return start;\n function start(code2) {\n effects.enter(\"gfmFootnoteCall\");\n effects.enter(\"gfmFootnoteCallLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallLabelMarker\");\n return callStart;\n }\n function callStart(code2) {\n if (code2 !== 94) return nok(code2);\n effects.enter(\"gfmFootnoteCallMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallMarker\");\n effects.enter(\"gfmFootnoteCallString\");\n effects.enter(\"chunkString\").contentType = \"string\";\n return callData;\n }\n function callData(code2) {\n if (\n // Too long.\n size > 999 || // Closing brace with nothing.\n code2 === 93 && !data || // Space or tab is not supported by GFM for some reason.\n // `\\n` and `[` not being supported makes sense.\n code2 === null || code2 === 91 || markdownLineEndingOrSpace(code2)\n ) {\n return nok(code2);\n }\n if (code2 === 93) {\n effects.exit(\"chunkString\");\n const token = effects.exit(\"gfmFootnoteCallString\");\n if (!defined.includes(normalizeIdentifier(self.sliceSerialize(token)))) {\n return nok(code2);\n }\n effects.enter(\"gfmFootnoteCallLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteCallLabelMarker\");\n effects.exit(\"gfmFootnoteCall\");\n return ok2;\n }\n if (!markdownLineEndingOrSpace(code2)) {\n data = true;\n }\n size++;\n effects.consume(code2);\n return code2 === 92 ? callEscape : callData;\n }\n function callEscape(code2) {\n if (code2 === 91 || code2 === 92 || code2 === 93) {\n effects.consume(code2);\n size++;\n return callData;\n }\n return callData(code2);\n }\n}\nfunction tokenizeDefinitionStart(effects, ok2, nok) {\n const self = this;\n const defined = self.parser.gfmFootnotes || (self.parser.gfmFootnotes = []);\n let identifier;\n let size = 0;\n let data;\n return start;\n function start(code2) {\n effects.enter(\"gfmFootnoteDefinition\")._container = true;\n effects.enter(\"gfmFootnoteDefinitionLabel\");\n effects.enter(\"gfmFootnoteDefinitionLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteDefinitionLabelMarker\");\n return labelAtMarker;\n }\n function labelAtMarker(code2) {\n if (code2 === 94) {\n effects.enter(\"gfmFootnoteDefinitionMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteDefinitionMarker\");\n effects.enter(\"gfmFootnoteDefinitionLabelString\");\n effects.enter(\"chunkString\").contentType = \"string\";\n return labelInside;\n }\n return nok(code2);\n }\n function labelInside(code2) {\n if (\n // Too long.\n size > 999 || // Closing brace with nothing.\n code2 === 93 && !data || // Space or tab is not supported by GFM for some reason.\n // `\\n` and `[` not being supported makes sense.\n code2 === null || code2 === 91 || markdownLineEndingOrSpace(code2)\n ) {\n return nok(code2);\n }\n if (code2 === 93) {\n effects.exit(\"chunkString\");\n const token = effects.exit(\"gfmFootnoteDefinitionLabelString\");\n identifier = normalizeIdentifier(self.sliceSerialize(token));\n effects.enter(\"gfmFootnoteDefinitionLabelMarker\");\n effects.consume(code2);\n effects.exit(\"gfmFootnoteDefinitionLabelMarker\");\n effects.exit(\"gfmFootnoteDefinitionLabel\");\n return labelAfter;\n }\n if (!markdownLineEndingOrSpace(code2)) {\n data = true;\n }\n size++;\n effects.consume(code2);\n return code2 === 92 ? labelEscape : labelInside;\n }\n function labelEscape(code2) {\n if (code2 === 91 || code2 === 92 || code2 === 93) {\n effects.consume(code2);\n size++;\n return labelInside;\n }\n return labelInside(code2);\n }\n function labelAfter(code2) {\n if (code2 === 58) {\n effects.enter(\"definitionMarker\");\n effects.consume(code2);\n effects.exit(\"definitionMarker\");\n if (!defined.includes(identifier)) {\n defined.push(identifier);\n }\n return factorySpace(effects, whitespaceAfter, \"gfmFootnoteDefinitionWhitespace\");\n }\n return nok(code2);\n }\n function whitespaceAfter(code2) {\n return ok2(code2);\n }\n}\nfunction tokenizeDefinitionContinuation(effects, ok2, nok) {\n return effects.check(blankLine, ok2, effects.attempt(indent, ok2, nok));\n}\nfunction gfmFootnoteDefinitionEnd(effects) {\n effects.exit(\"gfmFootnoteDefinition\");\n}\nfunction tokenizeIndent(effects, ok2, nok) {\n const self = this;\n return factorySpace(effects, afterPrefix, \"gfmFootnoteDefinitionIndent\", 4 + 1);\n function afterPrefix(code2) {\n const tail = self.events[self.events.length - 1];\n return tail && tail[1].type === \"gfmFootnoteDefinitionIndent\" && tail[2].sliceSerialize(tail[1], true).length === 4 ? ok2(code2) : nok(code2);\n }\n}\nfunction gfmStrikethrough(options) {\n const options_ = options || {};\n let single = options_.singleTilde;\n const tokenizer = {\n name: \"strikethrough\",\n tokenize: tokenizeStrikethrough,\n resolveAll: resolveAllStrikethrough\n };\n if (single === null || single === void 0) {\n single = true;\n }\n return {\n text: {\n [126]: tokenizer\n },\n insideSpan: {\n null: [tokenizer]\n },\n attentionMarkers: {\n null: [126]\n }\n };\n function resolveAllStrikethrough(events, context) {\n let index = -1;\n while (++index < events.length) {\n if (events[index][0] === \"enter\" && events[index][1].type === \"strikethroughSequenceTemporary\" && events[index][1]._close) {\n let open = index;\n while (open--) {\n if (events[open][0] === \"exit\" && events[open][1].type === \"strikethroughSequenceTemporary\" && events[open][1]._open && // If the sizes are the same:\n events[index][1].end.offset - events[index][1].start.offset === events[open][1].end.offset - events[open][1].start.offset) {\n events[index][1].type = \"strikethroughSequence\";\n events[open][1].type = \"strikethroughSequence\";\n const strikethrough = {\n type: \"strikethrough\",\n start: Object.assign({}, events[open][1].start),\n end: Object.assign({}, events[index][1].end)\n };\n const text2 = {\n type: \"strikethroughText\",\n start: Object.assign({}, events[open][1].end),\n end: Object.assign({}, events[index][1].start)\n };\n const nextEvents = [[\"enter\", strikethrough, context], [\"enter\", events[open][1], context], [\"exit\", events[open][1], context], [\"enter\", text2, context]];\n const insideSpan = context.parser.constructs.insideSpan.null;\n if (insideSpan) {\n splice(nextEvents, nextEvents.length, 0, resolveAll(insideSpan, events.slice(open + 1, index), context));\n }\n splice(nextEvents, nextEvents.length, 0, [[\"exit\", text2, context], [\"enter\", events[index][1], context], [\"exit\", events[index][1], context], [\"exit\", strikethrough, context]]);\n splice(events, open - 1, index - open + 3, nextEvents);\n index = open + nextEvents.length - 2;\n break;\n }\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n if (events[index][1].type === \"strikethroughSequenceTemporary\") {\n events[index][1].type = \"data\";\n }\n }\n return events;\n }\n function tokenizeStrikethrough(effects, ok2, nok) {\n const previous2 = this.previous;\n const events = this.events;\n let size = 0;\n return start;\n function start(code2) {\n if (previous2 === 126 && events[events.length - 1][1].type !== \"characterEscape\") {\n return nok(code2);\n }\n effects.enter(\"strikethroughSequenceTemporary\");\n return more(code2);\n }\n function more(code2) {\n const before = classifyCharacter(previous2);\n if (code2 === 126) {\n if (size > 1) return nok(code2);\n effects.consume(code2);\n size++;\n return more;\n }\n if (size < 2 && !single) return nok(code2);\n const token = effects.exit(\"strikethroughSequenceTemporary\");\n const after = classifyCharacter(code2);\n token._open = !after || after === 2 && Boolean(before);\n token._close = !before || before === 2 && Boolean(after);\n return ok2(code2);\n }\n }\n}\nclass EditMap {\n /**\n * Create a new edit map.\n */\n constructor() {\n this.map = [];\n }\n /**\n * Create an edit: a remove and/or add at a certain place.\n *\n * @param {number} index\n * @param {number} remove\n * @param {Array} add\n * @returns {undefined}\n */\n add(index, remove, add) {\n addImplementation(this, index, remove, add);\n }\n // To do: add this when moving to `micromark`.\n // /**\n // * Create an edit: but insert `add` before existing additions.\n // *\n // * @param {number} index\n // * @param {number} remove\n // * @param {Array} add\n // * @returns {undefined}\n // */\n // addBefore(index, remove, add) {\n // addImplementation(this, index, remove, add, true)\n // }\n /**\n * Done, change the events.\n *\n * @param {Array} events\n * @returns {undefined}\n */\n consume(events) {\n this.map.sort(function(a, b) {\n return a[0] - b[0];\n });\n if (this.map.length === 0) {\n return;\n }\n let index = this.map.length;\n const vecs = [];\n while (index > 0) {\n index -= 1;\n vecs.push(events.slice(this.map[index][0] + this.map[index][1]), this.map[index][2]);\n events.length = this.map[index][0];\n }\n vecs.push(events.slice());\n events.length = 0;\n let slice = vecs.pop();\n while (slice) {\n for (const element of slice) {\n events.push(element);\n }\n slice = vecs.pop();\n }\n this.map.length = 0;\n }\n}\nfunction addImplementation(editMap, at, remove, add) {\n let index = 0;\n if (remove === 0 && add.length === 0) {\n return;\n }\n while (index < editMap.map.length) {\n if (editMap.map[index][0] === at) {\n editMap.map[index][1] += remove;\n editMap.map[index][2].push(...add);\n return;\n }\n index += 1;\n }\n editMap.map.push([at, remove, add]);\n}\nfunction gfmTableAlign(events, index) {\n let inDelimiterRow = false;\n const align = [];\n while (index < events.length) {\n const event = events[index];\n if (inDelimiterRow) {\n if (event[0] === \"enter\") {\n if (event[1].type === \"tableContent\") {\n align.push(events[index + 1][1].type === \"tableDelimiterMarker\" ? \"left\" : \"none\");\n }\n } else if (event[1].type === \"tableContent\") {\n if (events[index - 1][1].type === \"tableDelimiterMarker\") {\n const alignIndex = align.length - 1;\n align[alignIndex] = align[alignIndex] === \"left\" ? \"center\" : \"right\";\n }\n } else if (event[1].type === \"tableDelimiterRow\") {\n break;\n }\n } else if (event[0] === \"enter\" && event[1].type === \"tableDelimiterRow\") {\n inDelimiterRow = true;\n }\n index += 1;\n }\n return align;\n}\nfunction gfmTable() {\n return {\n flow: {\n null: {\n name: \"table\",\n tokenize: tokenizeTable,\n resolveAll: resolveTable\n }\n }\n };\n}\nfunction tokenizeTable(effects, ok2, nok) {\n const self = this;\n let size = 0;\n let sizeB = 0;\n let seen;\n return start;\n function start(code2) {\n let index = self.events.length - 1;\n while (index > -1) {\n const type = self.events[index][1].type;\n if (type === \"lineEnding\" || // Note: markdown-rs uses `whitespace` instead of `linePrefix`\n type === \"linePrefix\") index--;\n else break;\n }\n const tail = index > -1 ? self.events[index][1].type : null;\n const next = tail === \"tableHead\" || tail === \"tableRow\" ? bodyRowStart : headRowBefore;\n if (next === bodyRowStart && self.parser.lazy[self.now().line]) {\n return nok(code2);\n }\n return next(code2);\n }\n function headRowBefore(code2) {\n effects.enter(\"tableHead\");\n effects.enter(\"tableRow\");\n return headRowStart(code2);\n }\n function headRowStart(code2) {\n if (code2 === 124) {\n return headRowBreak(code2);\n }\n seen = true;\n sizeB += 1;\n return headRowBreak(code2);\n }\n function headRowBreak(code2) {\n if (code2 === null) {\n return nok(code2);\n }\n if (markdownLineEnding(code2)) {\n if (sizeB > 1) {\n sizeB = 0;\n self.interrupt = true;\n effects.exit(\"tableRow\");\n effects.enter(\"lineEnding\");\n effects.consume(code2);\n effects.exit(\"lineEnding\");\n return headDelimiterStart;\n }\n return nok(code2);\n }\n if (markdownSpace(code2)) {\n return factorySpace(effects, headRowBreak, \"whitespace\")(code2);\n }\n sizeB += 1;\n if (seen) {\n seen = false;\n size += 1;\n }\n if (code2 === 124) {\n effects.enter(\"tableCellDivider\");\n effects.consume(code2);\n effects.exit(\"tableCellDivider\");\n seen = true;\n return headRowBreak;\n }\n effects.enter(\"data\");\n return headRowData(code2);\n }\n function headRowData(code2) {\n if (code2 === null || code2 === 124 || markdownLineEndingOrSpace(code2)) {\n effects.exit(\"data\");\n return headRowBreak(code2);\n }\n effects.consume(code2);\n return code2 === 92 ? headRowEscape : headRowData;\n }\n function headRowEscape(code2) {\n if (code2 === 92 || code2 === 124) {\n effects.consume(code2);\n return headRowData;\n }\n return headRowData(code2);\n }\n function headDelimiterStart(code2) {\n self.interrupt = false;\n if (self.parser.lazy[self.now().line]) {\n return nok(code2);\n }\n effects.enter(\"tableDelimiterRow\");\n seen = false;\n if (markdownSpace(code2)) {\n return factorySpace(effects, headDelimiterBefore, \"linePrefix\", self.parser.constructs.disable.null.includes(\"codeIndented\") ? void 0 : 4)(code2);\n }\n return headDelimiterBefore(code2);\n }\n function headDelimiterBefore(code2) {\n if (code2 === 45 || code2 === 58) {\n return headDelimiterValueBefore(code2);\n }\n if (code2 === 124) {\n seen = true;\n effects.enter(\"tableCellDivider\");\n effects.consume(code2);\n effects.exit(\"tableCellDivider\");\n return headDelimiterCellBefore;\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterCellBefore(code2) {\n if (markdownSpace(code2)) {\n return factorySpace(effects, headDelimiterValueBefore, \"whitespace\")(code2);\n }\n return headDelimiterValueBefore(code2);\n }\n function headDelimiterValueBefore(code2) {\n if (code2 === 58) {\n sizeB += 1;\n seen = true;\n effects.enter(\"tableDelimiterMarker\");\n effects.consume(code2);\n effects.exit(\"tableDelimiterMarker\");\n return headDelimiterLeftAlignmentAfter;\n }\n if (code2 === 45) {\n sizeB += 1;\n return headDelimiterLeftAlignmentAfter(code2);\n }\n if (code2 === null || markdownLineEnding(code2)) {\n return headDelimiterCellAfter(code2);\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterLeftAlignmentAfter(code2) {\n if (code2 === 45) {\n effects.enter(\"tableDelimiterFiller\");\n return headDelimiterFiller(code2);\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterFiller(code2) {\n if (code2 === 45) {\n effects.consume(code2);\n return headDelimiterFiller;\n }\n if (code2 === 58) {\n seen = true;\n effects.exit(\"tableDelimiterFiller\");\n effects.enter(\"tableDelimiterMarker\");\n effects.consume(code2);\n effects.exit(\"tableDelimiterMarker\");\n return headDelimiterRightAlignmentAfter;\n }\n effects.exit(\"tableDelimiterFiller\");\n return headDelimiterRightAlignmentAfter(code2);\n }\n function headDelimiterRightAlignmentAfter(code2) {\n if (markdownSpace(code2)) {\n return factorySpace(effects, headDelimiterCellAfter, \"whitespace\")(code2);\n }\n return headDelimiterCellAfter(code2);\n }\n function headDelimiterCellAfter(code2) {\n if (code2 === 124) {\n return headDelimiterBefore(code2);\n }\n if (code2 === null || markdownLineEnding(code2)) {\n if (!seen || size !== sizeB) {\n return headDelimiterNok(code2);\n }\n effects.exit(\"tableDelimiterRow\");\n effects.exit(\"tableHead\");\n return ok2(code2);\n }\n return headDelimiterNok(code2);\n }\n function headDelimiterNok(code2) {\n return nok(code2);\n }\n function bodyRowStart(code2) {\n effects.enter(\"tableRow\");\n return bodyRowBreak(code2);\n }\n function bodyRowBreak(code2) {\n if (code2 === 124) {\n effects.enter(\"tableCellDivider\");\n effects.consume(code2);\n effects.exit(\"tableCellDivider\");\n return bodyRowBreak;\n }\n if (code2 === null || markdownLineEnding(code2)) {\n effects.exit(\"tableRow\");\n return ok2(code2);\n }\n if (markdownSpace(code2)) {\n return factorySpace(effects, bodyRowBreak, \"whitespace\")(code2);\n }\n effects.enter(\"data\");\n return bodyRowData(code2);\n }\n function bodyRowData(code2) {\n if (code2 === null || code2 === 124 || markdownLineEndingOrSpace(code2)) {\n effects.exit(\"data\");\n return bodyRowBreak(code2);\n }\n effects.consume(code2);\n return code2 === 92 ? bodyRowEscape : bodyRowData;\n }\n function bodyRowEscape(code2) {\n if (code2 === 92 || code2 === 124) {\n effects.consume(code2);\n return bodyRowData;\n }\n return bodyRowData(code2);\n }\n}\nfunction resolveTable(events, context) {\n let index = -1;\n let inFirstCellAwaitingPipe = true;\n let rowKind = 0;\n let lastCell = [0, 0, 0, 0];\n let cell = [0, 0, 0, 0];\n let afterHeadAwaitingFirstBodyRow = false;\n let lastTableEnd = 0;\n let currentTable;\n let currentBody;\n let currentCell;\n const map2 = new EditMap();\n while (++index < events.length) {\n const event = events[index];\n const token = event[1];\n if (event[0] === \"enter\") {\n if (token.type === \"tableHead\") {\n afterHeadAwaitingFirstBodyRow = false;\n if (lastTableEnd !== 0) {\n flushTableEnd(map2, context, lastTableEnd, currentTable, currentBody);\n currentBody = void 0;\n lastTableEnd = 0;\n }\n currentTable = {\n type: \"table\",\n start: Object.assign({}, token.start),\n // Note: correct end is set later.\n end: Object.assign({}, token.end)\n };\n map2.add(index, 0, [[\"enter\", currentTable, context]]);\n } else if (token.type === \"tableRow\" || token.type === \"tableDelimiterRow\") {\n inFirstCellAwaitingPipe = true;\n currentCell = void 0;\n lastCell = [0, 0, 0, 0];\n cell = [0, index + 1, 0, 0];\n if (afterHeadAwaitingFirstBodyRow) {\n afterHeadAwaitingFirstBodyRow = false;\n currentBody = {\n type: \"tableBody\",\n start: Object.assign({}, token.start),\n // Note: correct end is set later.\n end: Object.assign({}, token.end)\n };\n map2.add(index, 0, [[\"enter\", currentBody, context]]);\n }\n rowKind = token.type === \"tableDelimiterRow\" ? 2 : currentBody ? 3 : 1;\n } else if (rowKind && (token.type === \"data\" || token.type === \"tableDelimiterMarker\" || token.type === \"tableDelimiterFiller\")) {\n inFirstCellAwaitingPipe = false;\n if (cell[2] === 0) {\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map2, context, lastCell, rowKind, void 0, currentCell);\n lastCell = [0, 0, 0, 0];\n }\n cell[2] = index;\n }\n } else if (token.type === \"tableCellDivider\") {\n if (inFirstCellAwaitingPipe) {\n inFirstCellAwaitingPipe = false;\n } else {\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map2, context, lastCell, rowKind, void 0, currentCell);\n }\n lastCell = cell;\n cell = [lastCell[1], index, 0, 0];\n }\n }\n } else if (token.type === \"tableHead\") {\n afterHeadAwaitingFirstBodyRow = true;\n lastTableEnd = index;\n } else if (token.type === \"tableRow\" || token.type === \"tableDelimiterRow\") {\n lastTableEnd = index;\n if (lastCell[1] !== 0) {\n cell[0] = cell[1];\n currentCell = flushCell(map2, context, lastCell, rowKind, index, currentCell);\n } else if (cell[1] !== 0) {\n currentCell = flushCell(map2, context, cell, rowKind, index, currentCell);\n }\n rowKind = 0;\n } else if (rowKind && (token.type === \"data\" || token.type === \"tableDelimiterMarker\" || token.type === \"tableDelimiterFiller\")) {\n cell[3] = index;\n }\n }\n if (lastTableEnd !== 0) {\n flushTableEnd(map2, context, lastTableEnd, currentTable, currentBody);\n }\n map2.consume(context.events);\n index = -1;\n while (++index < context.events.length) {\n const event = context.events[index];\n if (event[0] === \"enter\" && event[1].type === \"table\") {\n event[1]._align = gfmTableAlign(context.events, index);\n }\n }\n return events;\n}\nfunction flushCell(map2, context, range, rowKind, rowEnd, previousCell) {\n const groupName = rowKind === 1 ? \"tableHeader\" : rowKind === 2 ? \"tableDelimiter\" : \"tableData\";\n const valueName = \"tableContent\";\n if (range[0] !== 0) {\n previousCell.end = Object.assign({}, getPoint(context.events, range[0]));\n map2.add(range[0], 0, [[\"exit\", previousCell, context]]);\n }\n const now = getPoint(context.events, range[1]);\n previousCell = {\n type: groupName,\n start: Object.assign({}, now),\n // Note: correct end is set later.\n end: Object.assign({}, now)\n };\n map2.add(range[1], 0, [[\"enter\", previousCell, context]]);\n if (range[2] !== 0) {\n const relatedStart = getPoint(context.events, range[2]);\n const relatedEnd = getPoint(context.events, range[3]);\n const valueToken = {\n type: valueName,\n start: Object.assign({}, relatedStart),\n end: Object.assign({}, relatedEnd)\n };\n map2.add(range[2], 0, [[\"enter\", valueToken, context]]);\n if (rowKind !== 2) {\n const start = context.events[range[2]];\n const end = context.events[range[3]];\n start[1].end = Object.assign({}, end[1].end);\n start[1].type = \"chunkText\";\n start[1].contentType = \"text\";\n if (range[3] > range[2] + 1) {\n const a = range[2] + 1;\n const b = range[3] - range[2] - 1;\n map2.add(a, b, []);\n }\n }\n map2.add(range[3] + 1, 0, [[\"exit\", valueToken, context]]);\n }\n if (rowEnd !== void 0) {\n previousCell.end = Object.assign({}, getPoint(context.events, rowEnd));\n map2.add(rowEnd, 0, [[\"exit\", previousCell, context]]);\n previousCell = void 0;\n }\n return previousCell;\n}\nfunction flushTableEnd(map2, context, index, table, tableBody) {\n const exits = [];\n const related = getPoint(context.events, index);\n if (tableBody) {\n tableBody.end = Object.assign({}, related);\n exits.push([\"exit\", tableBody, context]);\n }\n table.end = Object.assign({}, related);\n exits.push([\"exit\", table, context]);\n map2.add(index + 1, 0, exits);\n}\nfunction getPoint(events, index) {\n const event = events[index];\n const side = event[0] === \"enter\" ? \"start\" : \"end\";\n return event[1][side];\n}\nconst tasklistCheck = {\n name: \"tasklistCheck\",\n tokenize: tokenizeTasklistCheck\n};\nfunction gfmTaskListItem() {\n return {\n text: {\n [91]: tasklistCheck\n }\n };\n}\nfunction tokenizeTasklistCheck(effects, ok2, nok) {\n const self = this;\n return open;\n function open(code2) {\n if (\n // Exit if there’s stuff before.\n self.previous !== null || // Exit if not in the first content that is the first child of a list\n // item.\n !self._gfmTasklistFirstContentOfListItem\n ) {\n return nok(code2);\n }\n effects.enter(\"taskListCheck\");\n effects.enter(\"taskListCheckMarker\");\n effects.consume(code2);\n effects.exit(\"taskListCheckMarker\");\n return inside;\n }\n function inside(code2) {\n if (markdownLineEndingOrSpace(code2)) {\n effects.enter(\"taskListCheckValueUnchecked\");\n effects.consume(code2);\n effects.exit(\"taskListCheckValueUnchecked\");\n return close;\n }\n if (code2 === 88 || code2 === 120) {\n effects.enter(\"taskListCheckValueChecked\");\n effects.consume(code2);\n effects.exit(\"taskListCheckValueChecked\");\n return close;\n }\n return nok(code2);\n }\n function close(code2) {\n if (code2 === 93) {\n effects.enter(\"taskListCheckMarker\");\n effects.consume(code2);\n effects.exit(\"taskListCheckMarker\");\n effects.exit(\"taskListCheck\");\n return after;\n }\n return nok(code2);\n }\n function after(code2) {\n if (markdownLineEnding(code2)) {\n return ok2(code2);\n }\n if (markdownSpace(code2)) {\n return effects.check({\n tokenize: spaceThenNonSpace\n }, ok2, nok)(code2);\n }\n return nok(code2);\n }\n}\nfunction spaceThenNonSpace(effects, ok2, nok) {\n return factorySpace(effects, after, \"whitespace\");\n function after(code2) {\n return code2 === null ? nok(code2) : ok2(code2);\n }\n}\nfunction gfm(options) {\n return combineExtensions([\n gfmAutolinkLiteral(),\n gfmFootnote(),\n gfmStrikethrough(options),\n gfmTable(),\n gfmTaskListItem()\n ]);\n}\nconst emptyOptions = {};\nfunction remarkGfm(options) {\n const self = (\n /** @type {Processor} */\n this\n );\n const settings = options || emptyOptions;\n const data = self.data();\n const micromarkExtensions = data.micromarkExtensions || (data.micromarkExtensions = []);\n const fromMarkdownExtensions = data.fromMarkdownExtensions || (data.fromMarkdownExtensions = []);\n const toMarkdownExtensions = data.toMarkdownExtensions || (data.toMarkdownExtensions = []);\n micromarkExtensions.push(gfm(settings));\n fromMarkdownExtensions.push(gfmFromMarkdown());\n toMarkdownExtensions.push(gfmToMarkdown(settings));\n}\n/*!\n * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction isTextNode$1(node2) {\n return node2.type === \"text\";\n}\nconst transformPlaceholders = function(ast) {\n visit(ast, isTextNode$1, visitor);\n function visitor(node2, index, parent) {\n const placeholders = node2.value.split(/(\\{[a-z\\-_.0-9]+\\})/ig).map((entry) => {\n const matches = entry.match(/^\\{([a-z\\-_.0-9]+)\\}$/i);\n if (!matches) {\n return u(\"text\", entry);\n }\n const [, component] = matches;\n return u(\"element\", {\n tagName: `#${component}`,\n children: []\n });\n });\n parent.children.splice(index, 1, ...placeholders);\n }\n};\nconst remarkPlaceholder = () => transformPlaceholders;\n/*!\n * SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors\n * SPDX-License-Identifier: AGPL-3.0-or-later\n */\nfunction isTextNode(node2) {\n return [\"text\", \"code\", \"inlineCode\"].includes(node2.type);\n}\nconst remarkUnescape = function() {\n return function(tree) {\n visit(tree, isTextNode, (node2, index, parent) => {\n parent.children.splice(index, 1, {\n ...node2,\n value: node2.value.replace(/</gmi, \"<\").replace(/>/gmi, \">\")\n });\n return [SKIP$1, index + 1];\n });\n };\n};\nconst LINK_PROTOCOLS = [\"http\", \"https\", \"mailto\", \"tel\"];\nconst rehypeHighlight = ref(null);\nasync function importRehypeHighlightLibrary() {\n const module = await import(\"rehype-highlight\");\n rehypeHighlight.value = module.default;\n}\nconst _sfc_main = {\n name: \"NcRichText\",\n components: {\n NcReferenceList\n },\n /* eslint vue/require-prop-comment: warn -- TODO: Add a proper doc block about what this props do */\n props: {\n /**\n * The main text\n */\n text: {\n type: String,\n default: \"\"\n },\n arguments: {\n type: Object,\n default: () => {\n return {};\n }\n },\n referenceLimit: {\n type: Number,\n default: 0\n },\n referenceInteractive: {\n type: Boolean,\n default: true\n },\n referenceInteractiveOptIn: {\n type: Boolean,\n default: false\n },\n /** Provide data upfront to avoid extra http request */\n references: {\n type: Array,\n default: null\n },\n /** Provide basic Markdown syntax */\n useMarkdown: {\n type: Boolean,\n default: false\n },\n /** Provide GitHub Flavored Markdown syntax */\n useExtendedMarkdown: {\n type: Boolean,\n default: false\n },\n /** Provide event from rendered markdown inputs */\n interactive: {\n type: Boolean,\n default: false\n },\n /**\n * Automatically convert link-like text to markdown links\n */\n autolink: {\n type: Boolean,\n default: true\n }\n },\n emits: [\n \"interactTodo\"\n ],\n data() {\n return {\n parentId: createElementId()\n };\n },\n methods: {\n renderPlaintext() {\n const placeholders = this.text.split(/(\\{[a-z\\-_.0-9]+\\})/ig).map((entry) => {\n const matches = entry.match(/^\\{([a-z\\-_.0-9]+)\\}$/i);\n if (!matches) {\n return this.prepareTextNode(entry);\n }\n const argumentId = matches[1];\n const argument = this.arguments[argumentId];\n if (typeof argument === \"object\") {\n const { component, props } = argument;\n return h(typeof component === \"string\" ? resolveComponent(component) : component, {\n ...props,\n class: \"rich-text--component\"\n });\n }\n if (argument) {\n return h(\"span\", { class: \"rich-text--fallback\" }, argument);\n }\n return entry;\n });\n return h(\"div\", { class: \"rich-text--wrapper\" }, [\n h(\"div\", {}, placeholders.flat()),\n this.referenceLimit > 0 ? h(\"div\", { class: \"rich-text--reference-widget\" }, [\n h(NcReferenceList, {\n text: this.text,\n referenceData: this.references,\n interactive: this.referenceInteractive,\n interactiveOptIn: this.referenceInteractiveOptIn\n })\n ]) : null\n ]);\n },\n renderMarkdown() {\n const renderedMarkdown = unified().use(remarkParse).use(remarkAutolink, {\n autolink: this.autolink,\n useMarkdown: this.useMarkdown,\n useExtendedMarkdown: this.useExtendedMarkdown\n }).use(remarkUnescape).use(this.useExtendedMarkdown ? remarkGfm : void 0).use(breaks).use(remarkUnlinkProtocols, { except: LINK_PROTOCOLS }).use(remark2rehype, {\n handlers: {\n component(toHast, node2) {\n return toHast(node2, node2.component, { value: node2.value });\n }\n }\n }).use(this.useExtendedMarkdown ? rehypeHighlight.value : void 0).use(remarkPlaceholder).use(rehypeExternalLinks, {\n target: \"_blank\",\n rel: [\"noopener noreferrer\"]\n }).use(rehype2react, {\n Fragment,\n jsx: this.createElement,\n jsxs: this.createElement,\n elementAttributeNameCase: \"html\",\n prefix: false\n }).processSync(this.text.replace(/<[^>]+>/g, (match) => match.replace(/\")).result;\n return h(\"div\", { class: \"rich-text--wrapper rich-text--wrapper-markdown\" }, [\n renderedMarkdown,\n this.referenceLimit > 0 ? h(\"div\", { class: \"rich-text--reference-widget\" }, [\n h(NcReferenceList, {\n text: this.text,\n referenceData: this.references,\n interactive: this.referenceInteractive,\n interactiveOptIn: this.referenceInteractiveOptIn\n })\n ]) : null\n ]);\n },\n /**\n * Render plain text nodes\n *\n * @param {string} text - Content of the node\n */\n prepareTextNode(text2) {\n if (this.autolink) {\n text2 = parseUrl(text2);\n }\n if (Array.isArray(text2)) {\n return text2.map((entry) => {\n if (typeof entry === \"string\") {\n return entry;\n }\n const { component, props } = entry;\n const componentClass = component.name === \"NcLink\" ? void 0 : \"rich-text--component\";\n return h(component, {\n ...props,\n class: componentClass\n });\n });\n }\n return text2;\n },\n createElement(type, props, key) {\n if (key) {\n props.key = key;\n }\n const children = props.children ?? [];\n delete props.children;\n if (!String(type).startsWith(\"#\")) {\n let nestedNode = null;\n if (this.useExtendedMarkdown) {\n if (String(type) === \"code\" && !rehypeHighlight.value && props?.class?.includes(\"language\")) {\n importRehypeHighlightLibrary();\n }\n if (String(type) === \"li\" && Array.isArray(children) && children.length !== 0 && children[0].type === \"input\" && children[0].props.type === \"checkbox\") {\n const [inputNode, , ...labelParts] = children;\n const nestedNodeIndex = labelParts.findIndex((child) => [\"ul\", \"ol\", \"li\", \"blockquote\", \"pre\"].includes(child.type));\n if (nestedNodeIndex !== -1) {\n nestedNode = labelParts[nestedNodeIndex];\n labelParts.splice(nestedNodeIndex);\n }\n const id = this.parentId + \"-markdown-input-\" + createElementId();\n const propsToForward = { ...inputNode.props };\n delete propsToForward.checked;\n const inputComponent = h(NcCheckboxRadioSwitch, {\n ...propsToForward,\n modelValue: inputNode.props.checked,\n id,\n disabled: !this.interactive,\n \"onUpdate:modelValue\": () => {\n this.$emit(\"interactTodo\", id);\n }\n }, { default: () => labelParts });\n return h(type, props, [inputComponent, nestedNode]);\n }\n }\n if (String(type) === \"a\") {\n const route = getRoute(this.$router, props.href);\n if (route) {\n delete props.href;\n delete props.target;\n return h(RouterLink, {\n ...props,\n to: route\n }, { default: () => children });\n }\n }\n return h(type, props, children);\n }\n const placeholder = this.arguments[type.slice(1)];\n if (!placeholder) {\n return h(\"span\", { ...props, class: \"rich-text--fallback\" }, [`{${type.slice(1)}}`]);\n }\n if (!placeholder.component) {\n return h(\"span\", { ...props }, [placeholder]);\n }\n return h(\n typeof placeholder.component === \"string\" ? resolveComponent(placeholder.component) : placeholder.component,\n {\n ...props,\n ...placeholder.props,\n class: \"rich-text--component\"\n },\n { default: () => children }\n );\n }\n },\n render() {\n return this.useMarkdown || this.useExtendedMarkdown ? this.renderMarkdown() : this.renderPlaintext();\n }\n};\nconst NcRichText = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-bfd4d4b7\"]]);\nexport {\n NcRichText as N,\n NcReferenceList as a\n};\n//# sourceMappingURL=NcRichText-jQc4sfgS.mjs.map\n","\n\n\n\n\n","\n\n\n\n\n\n\n","\n\n\n\n\n","import { onClickOutside as onClickOutside$1, useActiveElement, useBattery, useBrowserLocation, useClipboard, useDark, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDocumentVisibility, useStorage as useStorage$1, isClient as isClient$1, useDraggable, useElementBounding as useElementBounding$1, useElementSize as useElementSize$1, useElementVisibility as useElementVisibility$1, useEyeDropper, useFullscreen, useGeolocation, useIdle, useMouse as useMouse$1, useMouseInElement as useMouseInElement$1, useMousePressed, useNetwork, useNow, useObjectUrl, useOffsetPagination, useOnline, usePageLeave, usePointer, usePointerLock, usePreferredColorScheme, usePreferredContrast, usePreferredDark as usePreferredDark$1, usePreferredLanguages, usePreferredReducedMotion, usePreferredReducedTransparency, useTimeAgo, useTimestamp, useVirtualList, useWindowFocus, useWindowSize } from '@vueuse/core';\nimport { defineComponent, shallowRef, h, toValue, computed, unref, reactive, hasInjectionContext, getCurrentInstance, onMounted, watchEffect, ref, watch, nextTick, toRefs } from 'vue';\nimport { isClient, toArray, watchImmediate, isObject, tryOnScopeDispose, noop, isIOS, injectLocal, pxValue, pausableWatch, tryOnMounted, toRef, useToggle, notNullish, watchOnce, promiseTimeout, until, useDebounceFn, useThrottleFn, tryOnUnmounted, reactiveOmit } from '@vueuse/shared';\n\nconst OnClickOutside = /* @__PURE__ */ defineComponent({\n name: \"OnClickOutside\",\n props: [\"as\", \"options\"],\n emits: [\"trigger\"],\n setup(props, { slots, emit }) {\n const target = shallowRef();\n onClickOutside$1(target, (e) => {\n emit(\"trigger\", e);\n }, props.options);\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default());\n };\n }\n});\n\nconst defaultWindow = isClient ? window : void 0;\n\nfunction unrefElement(elRef) {\n var _a;\n const plain = toValue(elRef);\n return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\n}\n\nfunction useEventListener(...args) {\n const cleanups = [];\n const cleanup = () => {\n cleanups.forEach((fn) => fn());\n cleanups.length = 0;\n };\n const register = (el, event, listener, options) => {\n el.addEventListener(event, listener, options);\n return () => el.removeEventListener(event, listener, options);\n };\n const firstParamTargets = computed(() => {\n const test = toArray(toValue(args[0])).filter((e) => e != null);\n return test.every((e) => typeof e !== \"string\") ? test : void 0;\n });\n const stopWatch = watchImmediate(\n () => {\n var _a, _b;\n return [\n (_b = (_a = firstParamTargets.value) == null ? void 0 : _a.map((e) => unrefElement(e))) != null ? _b : [defaultWindow].filter((e) => e != null),\n toArray(toValue(firstParamTargets.value ? args[1] : args[0])),\n toArray(unref(firstParamTargets.value ? args[2] : args[1])),\n // @ts-expect-error - TypeScript gets the correct types, but somehow still complains\n toValue(firstParamTargets.value ? args[3] : args[2])\n ];\n },\n ([raw_targets, raw_events, raw_listeners, raw_options]) => {\n cleanup();\n if (!(raw_targets == null ? void 0 : raw_targets.length) || !(raw_events == null ? void 0 : raw_events.length) || !(raw_listeners == null ? void 0 : raw_listeners.length))\n return;\n const optionsClone = isObject(raw_options) ? { ...raw_options } : raw_options;\n cleanups.push(\n ...raw_targets.flatMap(\n (el) => raw_events.flatMap(\n (event) => raw_listeners.map((listener) => register(el, event, listener, optionsClone))\n )\n )\n );\n },\n { flush: \"post\" }\n );\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(cleanup);\n return stop;\n}\n\nlet _iOSWorkaround = false;\nfunction onClickOutside(target, handler, options = {}) {\n const { window = defaultWindow, ignore = [], capture = true, detectIframe = false, controls = false } = options;\n if (!window) {\n return controls ? { stop: noop, cancel: noop, trigger: noop } : noop;\n }\n if (isIOS && !_iOSWorkaround) {\n _iOSWorkaround = true;\n const listenerOptions = { passive: true };\n Array.from(window.document.body.children).forEach((el) => el.addEventListener(\"click\", noop, listenerOptions));\n window.document.documentElement.addEventListener(\"click\", noop, listenerOptions);\n }\n let shouldListen = true;\n const shouldIgnore = (event) => {\n return toValue(ignore).some((target2) => {\n if (typeof target2 === \"string\") {\n return Array.from(window.document.querySelectorAll(target2)).some((el) => el === event.target || event.composedPath().includes(el));\n } else {\n const el = unrefElement(target2);\n return el && (event.target === el || event.composedPath().includes(el));\n }\n });\n };\n function hasMultipleRoots(target2) {\n const vm = toValue(target2);\n return vm && vm.$.subTree.shapeFlag === 16;\n }\n function checkMultipleRoots(target2, event) {\n const vm = toValue(target2);\n const children = vm.$.subTree && vm.$.subTree.children;\n if (children == null || !Array.isArray(children))\n return false;\n return children.some((child) => child.el === event.target || event.composedPath().includes(child.el));\n }\n const listener = (event) => {\n const el = unrefElement(target);\n if (event.target == null)\n return;\n if (!(el instanceof Element) && hasMultipleRoots(target) && checkMultipleRoots(target, event))\n return;\n if (!el || el === event.target || event.composedPath().includes(el))\n return;\n if (\"detail\" in event && event.detail === 0)\n shouldListen = !shouldIgnore(event);\n if (!shouldListen) {\n shouldListen = true;\n return;\n }\n handler(event);\n };\n let isProcessingClick = false;\n const cleanup = [\n useEventListener(window, \"click\", (event) => {\n if (!isProcessingClick) {\n isProcessingClick = true;\n setTimeout(() => {\n isProcessingClick = false;\n }, 0);\n listener(event);\n }\n }, { passive: true, capture }),\n useEventListener(window, \"pointerdown\", (e) => {\n const el = unrefElement(target);\n shouldListen = !shouldIgnore(e) && !!(el && !e.composedPath().includes(el));\n }, { passive: true }),\n detectIframe && useEventListener(window, \"blur\", (event) => {\n setTimeout(() => {\n var _a;\n const el = unrefElement(target);\n if (((_a = window.document.activeElement) == null ? void 0 : _a.tagName) === \"IFRAME\" && !(el == null ? void 0 : el.contains(window.document.activeElement))) {\n handler(event);\n }\n }, 0);\n }, { passive: true })\n ].filter(Boolean);\n const stop = () => cleanup.forEach((fn) => fn());\n if (controls) {\n return {\n stop,\n cancel: () => {\n shouldListen = false;\n },\n trigger: (event) => {\n shouldListen = true;\n listener(event);\n shouldListen = false;\n }\n };\n }\n return stop;\n}\n\nconst stopClickOutsideMap = /* @__PURE__ */ new WeakMap();\nconst vOnClickOutside = {\n mounted(el, binding) {\n const capture = !binding.modifiers.bubble;\n let stop;\n if (typeof binding.value === \"function\") {\n stop = onClickOutside(el, binding.value, { capture });\n } else {\n const [handler, options] = binding.value;\n stop = onClickOutside(el, handler, Object.assign({ capture }, options));\n }\n stopClickOutsideMap.set(el, stop);\n },\n unmounted(el) {\n const stop = stopClickOutsideMap.get(el);\n if (stop && typeof stop === \"function\") {\n stop();\n } else {\n stop == null ? void 0 : stop.stop();\n }\n stopClickOutsideMap.delete(el);\n }\n};\n\nfunction createKeyPredicate(keyFilter) {\n if (typeof keyFilter === \"function\")\n return keyFilter;\n else if (typeof keyFilter === \"string\")\n return (event) => event.key === keyFilter;\n else if (Array.isArray(keyFilter))\n return (event) => keyFilter.includes(event.key);\n return () => true;\n}\nfunction onKeyStroke(...args) {\n let key;\n let handler;\n let options = {};\n if (args.length === 3) {\n key = args[0];\n handler = args[1];\n options = args[2];\n } else if (args.length === 2) {\n if (typeof args[1] === \"object\") {\n key = true;\n handler = args[0];\n options = args[1];\n } else {\n key = args[0];\n handler = args[1];\n }\n } else {\n key = true;\n handler = args[0];\n }\n const {\n target = defaultWindow,\n eventName = \"keydown\",\n passive = false,\n dedupe = false\n } = options;\n const predicate = createKeyPredicate(key);\n const listener = (e) => {\n if (e.repeat && toValue(dedupe))\n return;\n if (predicate(e))\n handler(e);\n };\n return useEventListener(target, eventName, listener, passive);\n}\n\nconst vOnKeyStroke = {\n mounted(el, binding) {\n var _a, _b;\n const keys = (_b = (_a = binding.arg) == null ? void 0 : _a.split(\",\")) != null ? _b : true;\n if (typeof binding.value === \"function\") {\n onKeyStroke(keys, binding.value, {\n target: el\n });\n } else {\n const [handler, options] = binding.value;\n onKeyStroke(keys, handler, {\n target: el,\n ...options\n });\n }\n }\n};\n\nconst DEFAULT_DELAY = 500;\nconst DEFAULT_THRESHOLD = 10;\nfunction onLongPress(target, handler, options) {\n var _a, _b;\n const elementRef = computed(() => unrefElement(target));\n let timeout;\n let posStart;\n let startTimestamp;\n let hasLongPressed = false;\n function clear() {\n if (timeout) {\n clearTimeout(timeout);\n timeout = void 0;\n }\n posStart = void 0;\n startTimestamp = void 0;\n hasLongPressed = false;\n }\n function getDelay(ev) {\n const delay = options == null ? void 0 : options.delay;\n if (typeof delay === \"function\") {\n return delay(ev);\n }\n return delay != null ? delay : DEFAULT_DELAY;\n }\n function onRelease(ev) {\n var _a2, _b2, _c;\n const [_startTimestamp, _posStart, _hasLongPressed] = [startTimestamp, posStart, hasLongPressed];\n clear();\n if (!(options == null ? void 0 : options.onMouseUp) || !_posStart || !_startTimestamp)\n return;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - _posStart.x;\n const dy = ev.y - _posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n options.onMouseUp(ev.timeStamp - _startTimestamp, distance, _hasLongPressed);\n }\n function onDown(ev) {\n var _a2, _b2, _c;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n clear();\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n posStart = {\n x: ev.x,\n y: ev.y\n };\n startTimestamp = ev.timeStamp;\n timeout = setTimeout(\n () => {\n hasLongPressed = true;\n handler(ev);\n },\n getDelay(ev)\n );\n }\n function onMove(ev) {\n var _a2, _b2, _c, _d;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if (!posStart || (options == null ? void 0 : options.distanceThreshold) === false)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - posStart.x;\n const dy = ev.y - posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n if (distance >= ((_d = options == null ? void 0 : options.distanceThreshold) != null ? _d : DEFAULT_THRESHOLD))\n clear();\n }\n const listenerOptions = {\n capture: (_a = options == null ? void 0 : options.modifiers) == null ? void 0 : _a.capture,\n once: (_b = options == null ? void 0 : options.modifiers) == null ? void 0 : _b.once\n };\n const cleanup = [\n useEventListener(elementRef, \"pointerdown\", onDown, listenerOptions),\n useEventListener(elementRef, \"pointermove\", onMove, listenerOptions),\n useEventListener(elementRef, [\"pointerup\", \"pointerleave\"], onRelease, listenerOptions)\n ];\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nconst OnLongPress = /* @__PURE__ */ defineComponent({\n name: \"OnLongPress\",\n props: [\"as\", \"options\"],\n emits: [\"trigger\"],\n setup(props, { slots, emit }) {\n const target = shallowRef();\n onLongPress(\n target,\n (e) => {\n emit(\"trigger\", e);\n },\n props.options\n );\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default());\n };\n }\n});\n\nconst vOnLongPress = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n onLongPress(el, binding.value, { modifiers: binding.modifiers });\n else\n onLongPress(el, ...binding.value);\n }\n};\n\nconst UseActiveElement = /* @__PURE__ */ defineComponent({\n name: \"UseActiveElement\",\n setup(props, { slots }) {\n const data = reactive({\n element: useActiveElement()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseBattery = /* @__PURE__ */ defineComponent({\n name: \"UseBattery\",\n setup(props, { slots }) {\n const data = reactive(useBattery(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseBrowserLocation = /* @__PURE__ */ defineComponent({\n name: \"UseBrowserLocation\",\n setup(props, { slots }) {\n const data = reactive(useBrowserLocation());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseClipboard = /* @__PURE__ */ defineComponent({\n name: \"UseClipboard\",\n props: [\n \"source\",\n \"read\",\n \"navigator\",\n \"copiedDuring\",\n \"legacy\"\n ],\n setup(props, { slots }) {\n const data = reactive(useClipboard(props));\n return () => {\n var _a;\n return (_a = slots.default) == null ? void 0 : _a.call(slots, data);\n };\n }\n});\n\nconst _global = typeof globalThis !== \"undefined\" ? globalThis : typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : {};\nconst globalKey = \"__vueuse_ssr_handlers__\";\nconst handlers = /* @__PURE__ */ getHandlers();\nfunction getHandlers() {\n if (!(globalKey in _global))\n _global[globalKey] = _global[globalKey] || {};\n return _global[globalKey];\n}\nfunction getSSRHandler(key, fallback) {\n return handlers[key] || fallback;\n}\n\nconst ssrWidthSymbol = Symbol(\"vueuse-ssr-width\");\n// @__NO_SIDE_EFFECTS__\nfunction useSSRWidth() {\n const ssrWidth = hasInjectionContext() ? injectLocal(ssrWidthSymbol, null) : null;\n return typeof ssrWidth === \"number\" ? ssrWidth : void 0;\n}\n\n// @__NO_SIDE_EFFECTS__\nfunction useMounted() {\n const isMounted = shallowRef(false);\n const instance = getCurrentInstance();\n if (instance) {\n onMounted(() => {\n isMounted.value = true;\n }, instance);\n }\n return isMounted;\n}\n\n// @__NO_SIDE_EFFECTS__\nfunction useSupported(callback) {\n const isMounted = useMounted();\n return computed(() => {\n isMounted.value;\n return Boolean(callback());\n });\n}\n\nfunction useMediaQuery(query, options = {}) {\n const { window = defaultWindow, ssrWidth = useSSRWidth() } = options;\n const isSupported = useSupported(() => window && \"matchMedia\" in window && typeof window.matchMedia === \"function\");\n const ssrSupport = shallowRef(typeof ssrWidth === \"number\");\n const mediaQuery = shallowRef();\n const matches = shallowRef(false);\n const handler = (event) => {\n matches.value = event.matches;\n };\n watchEffect(() => {\n if (ssrSupport.value) {\n ssrSupport.value = !isSupported.value;\n const queryStrings = toValue(query).split(\",\");\n matches.value = queryStrings.some((queryString) => {\n const not = queryString.includes(\"not all\");\n const minWidth = queryString.match(/\\(\\s*min-width:\\s*(-?\\d+(?:\\.\\d*)?[a-z]+\\s*)\\)/);\n const maxWidth = queryString.match(/\\(\\s*max-width:\\s*(-?\\d+(?:\\.\\d*)?[a-z]+\\s*)\\)/);\n let res = Boolean(minWidth || maxWidth);\n if (minWidth && res) {\n res = ssrWidth >= pxValue(minWidth[1]);\n }\n if (maxWidth && res) {\n res = ssrWidth <= pxValue(maxWidth[1]);\n }\n return not ? !res : res;\n });\n return;\n }\n if (!isSupported.value)\n return;\n mediaQuery.value = window.matchMedia(toValue(query));\n matches.value = mediaQuery.value.matches;\n });\n useEventListener(mediaQuery, \"change\", handler, { passive: true });\n return computed(() => matches.value);\n}\n\n// @__NO_SIDE_EFFECTS__\nfunction usePreferredDark(options) {\n return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nfunction guessSerializerType(rawInit) {\n return rawInit == null ? \"any\" : rawInit instanceof Set ? \"set\" : rawInit instanceof Map ? \"map\" : rawInit instanceof Date ? \"date\" : typeof rawInit === \"boolean\" ? \"boolean\" : typeof rawInit === \"string\" ? \"string\" : typeof rawInit === \"object\" ? \"object\" : !Number.isNaN(rawInit) ? \"number\" : \"any\";\n}\n\nconst StorageSerializers = {\n boolean: {\n read: (v) => v === \"true\",\n write: (v) => String(v)\n },\n object: {\n read: (v) => JSON.parse(v),\n write: (v) => JSON.stringify(v)\n },\n number: {\n read: (v) => Number.parseFloat(v),\n write: (v) => String(v)\n },\n any: {\n read: (v) => v,\n write: (v) => String(v)\n },\n string: {\n read: (v) => v,\n write: (v) => String(v)\n },\n map: {\n read: (v) => new Map(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v.entries()))\n },\n set: {\n read: (v) => new Set(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v))\n },\n date: {\n read: (v) => new Date(v),\n write: (v) => v.toISOString()\n }\n};\nconst customStorageEventName = \"vueuse-storage\";\nfunction useStorage(key, defaults, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n mergeDefaults = false,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n },\n initOnMounted\n } = options;\n const data = (shallow ? shallowRef : ref)(typeof defaults === \"function\" ? defaults() : defaults);\n const keyComputed = computed(() => toValue(key));\n if (!storage) {\n try {\n storage = getSSRHandler(\"getDefaultStorage\", () => {\n var _a2;\n return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n })();\n } catch (e) {\n onError(e);\n }\n }\n if (!storage)\n return data;\n const rawInit = toValue(defaults);\n const type = guessSerializerType(rawInit);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(\n data,\n (newValue) => write(newValue),\n { flush, deep, eventFilter }\n );\n watch(keyComputed, () => update(), { flush });\n let firstMounted = false;\n const onStorageEvent = (ev) => {\n if (initOnMounted && !firstMounted) {\n return;\n }\n update(ev);\n };\n const onStorageCustomEvent = (ev) => {\n if (initOnMounted && !firstMounted) {\n return;\n }\n updateFromCustomEvent(ev);\n };\n if (window && listenToStorageChanges) {\n if (storage instanceof Storage)\n useEventListener(window, \"storage\", onStorageEvent, { passive: true });\n else\n useEventListener(window, customStorageEventName, onStorageCustomEvent);\n }\n if (initOnMounted) {\n tryOnMounted(() => {\n firstMounted = true;\n update();\n });\n } else {\n update();\n }\n function dispatchWriteEvent(oldValue, newValue) {\n if (window) {\n const payload = {\n key: keyComputed.value,\n oldValue,\n newValue,\n storageArea: storage\n };\n window.dispatchEvent(storage instanceof Storage ? new StorageEvent(\"storage\", payload) : new CustomEvent(customStorageEventName, {\n detail: payload\n }));\n }\n }\n function write(v) {\n try {\n const oldValue = storage.getItem(keyComputed.value);\n if (v == null) {\n dispatchWriteEvent(oldValue, null);\n storage.removeItem(keyComputed.value);\n } else {\n const serialized = serializer.write(v);\n if (oldValue !== serialized) {\n storage.setItem(keyComputed.value, serialized);\n dispatchWriteEvent(oldValue, serialized);\n }\n }\n } catch (e) {\n onError(e);\n }\n }\n function read(event) {\n const rawValue = event ? event.newValue : storage.getItem(keyComputed.value);\n if (rawValue == null) {\n if (writeDefaults && rawInit != null)\n storage.setItem(keyComputed.value, serializer.write(rawInit));\n return rawInit;\n } else if (!event && mergeDefaults) {\n const value = serializer.read(rawValue);\n if (typeof mergeDefaults === \"function\")\n return mergeDefaults(value, rawInit);\n else if (type === \"object\" && !Array.isArray(value))\n return { ...rawInit, ...value };\n return value;\n } else if (typeof rawValue !== \"string\") {\n return rawValue;\n } else {\n return serializer.read(rawValue);\n }\n }\n function update(event) {\n if (event && event.storageArea !== storage)\n return;\n if (event && event.key == null) {\n data.value = rawInit;\n return;\n }\n if (event && event.key !== keyComputed.value) {\n return;\n }\n pauseWatch();\n try {\n const serializedData = serializer.write(data.value);\n if (event === void 0 || (event == null ? void 0 : event.newValue) !== serializedData) {\n data.value = read(event);\n }\n } catch (e) {\n onError(e);\n } finally {\n if (event)\n nextTick(resumeWatch);\n else\n resumeWatch();\n }\n }\n function updateFromCustomEvent(event) {\n update(event.detail);\n }\n return data;\n}\n\nconst CSS_DISABLE_TRANS = \"*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}\";\nfunction useColorMode(options = {}) {\n const {\n selector = \"html\",\n attribute = \"class\",\n initialValue = \"auto\",\n window = defaultWindow,\n storage,\n storageKey = \"vueuse-color-scheme\",\n listenToStorageChanges = true,\n storageRef,\n emitAuto,\n disableTransition = true\n } = options;\n const modes = {\n auto: \"\",\n light: \"light\",\n dark: \"dark\",\n ...options.modes || {}\n };\n const preferredDark = usePreferredDark({ window });\n const system = computed(() => preferredDark.value ? \"dark\" : \"light\");\n const store = storageRef || (storageKey == null ? toRef(initialValue) : useStorage(storageKey, initialValue, storage, { window, listenToStorageChanges }));\n const state = computed(() => store.value === \"auto\" ? system.value : store.value);\n const updateHTMLAttrs = getSSRHandler(\n \"updateHTMLAttrs\",\n (selector2, attribute2, value) => {\n const el = typeof selector2 === \"string\" ? window == null ? void 0 : window.document.querySelector(selector2) : unrefElement(selector2);\n if (!el)\n return;\n const classesToAdd = /* @__PURE__ */ new Set();\n const classesToRemove = /* @__PURE__ */ new Set();\n let attributeToChange = null;\n if (attribute2 === \"class\") {\n const current = value.split(/\\s/g);\n Object.values(modes).flatMap((i) => (i || \"\").split(/\\s/g)).filter(Boolean).forEach((v) => {\n if (current.includes(v))\n classesToAdd.add(v);\n else\n classesToRemove.add(v);\n });\n } else {\n attributeToChange = { key: attribute2, value };\n }\n if (classesToAdd.size === 0 && classesToRemove.size === 0 && attributeToChange === null)\n return;\n let style;\n if (disableTransition) {\n style = window.document.createElement(\"style\");\n style.appendChild(document.createTextNode(CSS_DISABLE_TRANS));\n window.document.head.appendChild(style);\n }\n for (const c of classesToAdd) {\n el.classList.add(c);\n }\n for (const c of classesToRemove) {\n el.classList.remove(c);\n }\n if (attributeToChange) {\n el.setAttribute(attributeToChange.key, attributeToChange.value);\n }\n if (disableTransition) {\n window.getComputedStyle(style).opacity;\n document.head.removeChild(style);\n }\n }\n );\n function defaultOnChanged(mode) {\n var _a;\n updateHTMLAttrs(selector, attribute, (_a = modes[mode]) != null ? _a : mode);\n }\n function onChanged(mode) {\n if (options.onChanged)\n options.onChanged(mode, defaultOnChanged);\n else\n defaultOnChanged(mode);\n }\n watch(state, onChanged, { flush: \"post\", immediate: true });\n tryOnMounted(() => onChanged(state.value));\n const auto = computed({\n get() {\n return emitAuto ? store.value : state.value;\n },\n set(v) {\n store.value = v;\n }\n });\n return Object.assign(auto, { store, system, state });\n}\n\nconst UseColorMode = /* @__PURE__ */ defineComponent({\n name: \"UseColorMode\",\n props: [\"selector\", \"attribute\", \"modes\", \"onChanged\", \"storageKey\", \"storage\", \"emitAuto\"],\n setup(props, { slots }) {\n const mode = useColorMode(props);\n const data = reactive({\n mode,\n system: mode.system,\n store: mode.store\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDark = /* @__PURE__ */ defineComponent({\n name: \"UseDark\",\n props: [\"selector\", \"attribute\", \"valueDark\", \"valueLight\", \"onChanged\", \"storageKey\", \"storage\"],\n setup(props, { slots }) {\n const isDark = useDark(props);\n const data = reactive({\n isDark,\n toggleDark: useToggle(isDark)\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDeviceMotion = /* @__PURE__ */ defineComponent({\n name: \"UseDeviceMotion\",\n setup(props, { slots }) {\n const data = useDeviceMotion();\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDeviceOrientation = /* @__PURE__ */ defineComponent({\n name: \"UseDeviceOrientation\",\n setup(props, { slots }) {\n const data = reactive(useDeviceOrientation());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDevicePixelRatio = /* @__PURE__ */ defineComponent({\n name: \"UseDevicePixelRatio\",\n setup(props, { slots }) {\n const data = reactive({\n pixelRatio: useDevicePixelRatio()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDevicesList = /* @__PURE__ */ defineComponent({\n name: \"UseDevicesList\",\n props: [\"onUpdated\", \"requestPermissions\", \"constraints\"],\n setup(props, { slots }) {\n const data = reactive(useDevicesList(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDocumentVisibility = /* @__PURE__ */ defineComponent({\n name: \"UseDocumentVisibility\",\n setup(props, { slots }) {\n const data = reactive({\n visibility: useDocumentVisibility()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseDraggable = /* @__PURE__ */ defineComponent({\n name: \"UseDraggable\",\n props: [\n \"storageKey\",\n \"storageType\",\n \"initialValue\",\n \"exact\",\n \"preventDefault\",\n \"stopPropagation\",\n \"pointerTypes\",\n \"as\",\n \"handle\",\n \"axis\",\n \"onStart\",\n \"onMove\",\n \"onEnd\",\n \"disabled\",\n \"buttons\",\n \"containerElement\",\n \"capture\"\n ],\n setup(props, { slots }) {\n const target = shallowRef();\n const handle = computed(() => {\n var _a;\n return (_a = toValue(props.handle)) != null ? _a : target.value;\n });\n const containerElement = computed(() => {\n var _a;\n return (_a = props.containerElement) != null ? _a : void 0;\n });\n const disabled = computed(() => !!props.disabled);\n const storageValue = props.storageKey && useStorage$1(\n props.storageKey,\n toValue(props.initialValue) || { x: 0, y: 0 },\n isClient$1 ? props.storageType === \"session\" ? sessionStorage : localStorage : void 0\n );\n const initialValue = storageValue || props.initialValue || { x: 0, y: 0 };\n const onEnd = (position, event) => {\n var _a;\n (_a = props.onEnd) == null ? void 0 : _a.call(props, position, event);\n if (!storageValue)\n return;\n storageValue.value.x = position.x;\n storageValue.value.y = position.y;\n };\n const data = reactive(useDraggable(target, {\n ...props,\n handle,\n initialValue,\n onEnd,\n disabled,\n containerElement\n }));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target, style: `touch-action:none;${data.style}` }, slots.default(data));\n };\n }\n});\n\nconst UseElementBounding = /* @__PURE__ */ defineComponent({\n name: \"UseElementBounding\",\n props: [\"box\", \"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useElementBounding$1(target));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nfunction useMutationObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...mutationOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"MutationObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const value = toValue(target);\n const items = toArray(value).map(unrefElement).filter(notNullish);\n return new Set(items);\n });\n const stopWatch = watch(\n targets,\n (newTargets) => {\n cleanup();\n if (isSupported.value && newTargets.size) {\n observer = new MutationObserver(callback);\n newTargets.forEach((el) => observer.observe(el, mutationOptions));\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const takeRecords = () => {\n return observer == null ? void 0 : observer.takeRecords();\n };\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop,\n takeRecords\n };\n}\n\nfunction useResizeObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...observerOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"ResizeObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const _targets = toValue(target);\n return Array.isArray(_targets) ? _targets.map((el) => unrefElement(el)) : [unrefElement(_targets)];\n });\n const stopWatch = watch(\n targets,\n (els) => {\n cleanup();\n if (isSupported.value && window) {\n observer = new ResizeObserver(callback);\n for (const _el of els) {\n if (_el)\n observer.observe(_el, observerOptions);\n }\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\n };\n}\n\nfunction useElementBounding(target, options = {}) {\n const {\n reset = true,\n windowResize = true,\n windowScroll = true,\n immediate = true,\n updateTiming = \"sync\"\n } = options;\n const height = shallowRef(0);\n const bottom = shallowRef(0);\n const left = shallowRef(0);\n const right = shallowRef(0);\n const top = shallowRef(0);\n const width = shallowRef(0);\n const x = shallowRef(0);\n const y = shallowRef(0);\n function recalculate() {\n const el = unrefElement(target);\n if (!el) {\n if (reset) {\n height.value = 0;\n bottom.value = 0;\n left.value = 0;\n right.value = 0;\n top.value = 0;\n width.value = 0;\n x.value = 0;\n y.value = 0;\n }\n return;\n }\n const rect = el.getBoundingClientRect();\n height.value = rect.height;\n bottom.value = rect.bottom;\n left.value = rect.left;\n right.value = rect.right;\n top.value = rect.top;\n width.value = rect.width;\n x.value = rect.x;\n y.value = rect.y;\n }\n function update() {\n if (updateTiming === \"sync\")\n recalculate();\n else if (updateTiming === \"next-frame\")\n requestAnimationFrame(() => recalculate());\n }\n useResizeObserver(target, update);\n watch(() => unrefElement(target), (ele) => !ele && update());\n useMutationObserver(target, update, {\n attributeFilter: [\"style\", \"class\"]\n });\n if (windowScroll)\n useEventListener(\"scroll\", update, { capture: true, passive: true });\n if (windowResize)\n useEventListener(\"resize\", update, { passive: true });\n tryOnMounted(() => {\n if (immediate)\n update();\n });\n return {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y,\n update\n };\n}\n\nconst vElementBounding = {\n mounted(el, binding) {\n const [handler, options] = typeof binding.value === \"function\" ? [binding.value, {}] : binding.value;\n const {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y\n } = useElementBounding(el, options);\n watch([height, bottom, left, right, top, width, x, y], () => handler({ height, bottom, left, right, top, width, x, y }));\n }\n};\n\nfunction onElementRemoval(target, callback, options = {}) {\n const {\n window = defaultWindow,\n document = window == null ? void 0 : window.document,\n flush = \"sync\"\n } = options;\n if (!window || !document)\n return noop;\n let stopFn;\n const cleanupAndUpdate = (fn) => {\n stopFn == null ? void 0 : stopFn();\n stopFn = fn;\n };\n const stopWatch = watchEffect(() => {\n const el = unrefElement(target);\n if (el) {\n const { stop } = useMutationObserver(\n document,\n (mutationsList) => {\n const targetRemoved = mutationsList.map((mutation) => [...mutation.removedNodes]).flat().some((node) => node === el || node.contains(el));\n if (targetRemoved) {\n callback(mutationsList);\n }\n },\n {\n window,\n childList: true,\n subtree: true\n }\n );\n cleanupAndUpdate(stop);\n }\n }, { flush });\n const stopHandle = () => {\n stopWatch();\n cleanupAndUpdate();\n };\n tryOnScopeDispose(stopHandle);\n return stopHandle;\n}\n\nfunction useElementHover(el, options = {}) {\n const {\n delayEnter = 0,\n delayLeave = 0,\n triggerOnRemoval = false,\n window = defaultWindow\n } = options;\n const isHovered = shallowRef(false);\n let timer;\n const toggle = (entering) => {\n const delay = entering ? delayEnter : delayLeave;\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n }\n if (delay)\n timer = setTimeout(() => isHovered.value = entering, delay);\n else\n isHovered.value = entering;\n };\n if (!window)\n return isHovered;\n useEventListener(el, \"mouseenter\", () => toggle(true), { passive: true });\n useEventListener(el, \"mouseleave\", () => toggle(false), { passive: true });\n if (triggerOnRemoval) {\n onElementRemoval(\n computed(() => unrefElement(el)),\n () => toggle(false)\n );\n }\n return isHovered;\n}\n\nconst vElementHover = {\n mounted(el, binding) {\n const value = binding.value;\n if (typeof value === \"function\") {\n const isHovered = useElementHover(el);\n watch(isHovered, (v) => value(v));\n } else {\n const [handler, options] = value;\n const isHovered = useElementHover(el, options);\n watch(isHovered, (v) => handler(v));\n }\n }\n};\n\nconst UseElementSize = /* @__PURE__ */ defineComponent({\n name: \"UseElementSize\",\n props: [\"width\", \"height\", \"box\", \"as\"],\n setup(props, { slots }) {\n var _a, _b;\n const target = shallowRef();\n const data = reactive(useElementSize$1(target, { width: (_a = props.width) != null ? _a : 0, height: (_b = props.height) != null ? _b : 0 }, { box: props.box }));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n const { window = defaultWindow, box = \"content-box\" } = options;\n const isSVG = computed(() => {\n var _a, _b;\n return (_b = (_a = unrefElement(target)) == null ? void 0 : _a.namespaceURI) == null ? void 0 : _b.includes(\"svg\");\n });\n const width = shallowRef(initialSize.width);\n const height = shallowRef(initialSize.height);\n const { stop: stop1 } = useResizeObserver(\n target,\n ([entry]) => {\n const boxSize = box === \"border-box\" ? entry.borderBoxSize : box === \"content-box\" ? entry.contentBoxSize : entry.devicePixelContentBoxSize;\n if (window && isSVG.value) {\n const $elem = unrefElement(target);\n if ($elem) {\n const rect = $elem.getBoundingClientRect();\n width.value = rect.width;\n height.value = rect.height;\n }\n } else {\n if (boxSize) {\n const formatBoxSize = toArray(boxSize);\n width.value = formatBoxSize.reduce((acc, { inlineSize }) => acc + inlineSize, 0);\n height.value = formatBoxSize.reduce((acc, { blockSize }) => acc + blockSize, 0);\n } else {\n width.value = entry.contentRect.width;\n height.value = entry.contentRect.height;\n }\n }\n },\n options\n );\n tryOnMounted(() => {\n const ele = unrefElement(target);\n if (ele) {\n width.value = \"offsetWidth\" in ele ? ele.offsetWidth : initialSize.width;\n height.value = \"offsetHeight\" in ele ? ele.offsetHeight : initialSize.height;\n }\n });\n const stop2 = watch(\n () => unrefElement(target),\n (ele) => {\n width.value = ele ? initialSize.width : 0;\n height.value = ele ? initialSize.height : 0;\n }\n );\n function stop() {\n stop1();\n stop2();\n }\n return {\n width,\n height,\n stop\n };\n}\n\nconst vElementSize = {\n mounted(el, binding) {\n var _a;\n const handler = typeof binding.value === \"function\" ? binding.value : (_a = binding.value) == null ? void 0 : _a[0];\n const options = typeof binding.value === \"function\" ? [] : binding.value.slice(1);\n const { width, height } = useElementSize(el, ...options);\n watch([width, height], ([width2, height2]) => handler({ width: width2, height: height2 }));\n }\n};\n\nconst UseElementVisibility = /* @__PURE__ */ defineComponent({\n name: \"UseElementVisibility\",\n props: [\"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive({\n isVisible: useElementVisibility$1(target)\n });\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n const {\n root,\n rootMargin = \"0px\",\n threshold = 0,\n window = defaultWindow,\n immediate = true\n } = options;\n const isSupported = useSupported(() => window && \"IntersectionObserver\" in window);\n const targets = computed(() => {\n const _target = toValue(target);\n return toArray(_target).map(unrefElement).filter(notNullish);\n });\n let cleanup = noop;\n const isActive = shallowRef(immediate);\n const stopWatch = isSupported.value ? watch(\n () => [targets.value, unrefElement(root), isActive.value],\n ([targets2, root2]) => {\n cleanup();\n if (!isActive.value)\n return;\n if (!targets2.length)\n return;\n const observer = new IntersectionObserver(\n callback,\n {\n root: unrefElement(root2),\n rootMargin,\n threshold\n }\n );\n targets2.forEach((el) => el && observer.observe(el));\n cleanup = () => {\n observer.disconnect();\n cleanup = noop;\n };\n },\n { immediate, flush: \"post\" }\n ) : noop;\n const stop = () => {\n cleanup();\n stopWatch();\n isActive.value = false;\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n isActive,\n pause() {\n cleanup();\n isActive.value = false;\n },\n resume() {\n isActive.value = true;\n },\n stop\n };\n}\n\nfunction useElementVisibility(element, options = {}) {\n const {\n window = defaultWindow,\n scrollTarget,\n threshold = 0,\n rootMargin,\n once = false\n } = options;\n const elementIsVisible = shallowRef(false);\n const { stop } = useIntersectionObserver(\n element,\n (intersectionObserverEntries) => {\n let isIntersecting = elementIsVisible.value;\n let latestTime = 0;\n for (const entry of intersectionObserverEntries) {\n if (entry.time >= latestTime) {\n latestTime = entry.time;\n isIntersecting = entry.isIntersecting;\n }\n }\n elementIsVisible.value = isIntersecting;\n if (once) {\n watchOnce(elementIsVisible, () => {\n stop();\n });\n }\n },\n {\n root: scrollTarget,\n window,\n threshold,\n rootMargin: toValue(rootMargin)\n }\n );\n return elementIsVisible;\n}\n\nconst vElementVisibility = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\") {\n const handler = binding.value;\n const isVisible = useElementVisibility(el);\n watch(isVisible, (v) => handler(v), { immediate: true });\n } else {\n const [handler, options] = binding.value;\n const isVisible = useElementVisibility(el, options);\n watch(isVisible, (v) => handler(v), { immediate: true });\n }\n }\n};\n\nconst UseEyeDropper = /* @__PURE__ */ defineComponent({\n name: \"UseEyeDropper\",\n props: {\n sRGBHex: String\n },\n setup(props, { slots }) {\n const data = reactive(useEyeDropper());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseFullscreen = /* @__PURE__ */ defineComponent({\n name: \"UseFullscreen\",\n props: [\"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useFullscreen(target));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UseGeolocation = /* @__PURE__ */ defineComponent({\n name: \"UseGeolocation\",\n props: [\"enableHighAccuracy\", \"maximumAge\", \"timeout\", \"navigator\"],\n setup(props, { slots }) {\n const data = reactive(useGeolocation(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseIdle = /* @__PURE__ */ defineComponent({\n name: \"UseIdle\",\n props: [\"timeout\", \"events\", \"listenForVisibilityChange\", \"initialState\"],\n setup(props, { slots }) {\n const data = reactive(useIdle(props.timeout, props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nfunction useAsyncState(promise, initialState, options) {\n var _a;\n const {\n immediate = true,\n delay = 0,\n onError = (_a = globalThis.reportError) != null ? _a : noop,\n onSuccess = noop,\n resetOnExecute = true,\n shallow = true,\n throwError\n } = options != null ? options : {};\n const state = shallow ? shallowRef(initialState) : ref(initialState);\n const isReady = shallowRef(false);\n const isLoading = shallowRef(false);\n const error = shallowRef(void 0);\n async function execute(delay2 = 0, ...args) {\n if (resetOnExecute)\n state.value = toValue(initialState);\n error.value = void 0;\n isReady.value = false;\n isLoading.value = true;\n if (delay2 > 0)\n await promiseTimeout(delay2);\n const _promise = typeof promise === \"function\" ? promise(...args) : promise;\n try {\n const data = await _promise;\n state.value = data;\n isReady.value = true;\n onSuccess(data);\n } catch (e) {\n error.value = e;\n onError(e);\n if (throwError)\n throw e;\n } finally {\n isLoading.value = false;\n }\n return state.value;\n }\n if (immediate) {\n execute(delay);\n }\n const shell = {\n state,\n isReady,\n isLoading,\n error,\n execute,\n executeImmediate: (...args) => execute(0, ...args)\n };\n function waitUntilIsLoaded() {\n return new Promise((resolve, reject) => {\n until(isLoading).toBe(false).then(() => resolve(shell)).catch(reject);\n });\n }\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilIsLoaded().then(onFulfilled, onRejected);\n }\n };\n}\n\nasync function loadImage(options) {\n return new Promise((resolve, reject) => {\n const img = new Image();\n const { src, srcset, sizes, class: clazz, loading, crossorigin, referrerPolicy, width, height, decoding, fetchPriority, ismap, usemap } = options;\n img.src = src;\n if (srcset != null)\n img.srcset = srcset;\n if (sizes != null)\n img.sizes = sizes;\n if (clazz != null)\n img.className = clazz;\n if (loading != null)\n img.loading = loading;\n if (crossorigin != null)\n img.crossOrigin = crossorigin;\n if (referrerPolicy != null)\n img.referrerPolicy = referrerPolicy;\n if (width != null)\n img.width = width;\n if (height != null)\n img.height = height;\n if (decoding != null)\n img.decoding = decoding;\n if (fetchPriority != null)\n img.fetchPriority = fetchPriority;\n if (ismap != null)\n img.isMap = ismap;\n if (usemap != null)\n img.useMap = usemap;\n img.onload = () => resolve(img);\n img.onerror = reject;\n });\n}\nfunction useImage(options, asyncStateOptions = {}) {\n const state = useAsyncState(\n () => loadImage(toValue(options)),\n void 0,\n {\n resetOnExecute: true,\n ...asyncStateOptions\n }\n );\n watch(\n () => toValue(options),\n () => state.execute(asyncStateOptions.delay),\n { deep: true }\n );\n return state;\n}\n\nconst UseImage = /* @__PURE__ */ defineComponent({\n name: \"UseImage\",\n props: [\n \"src\",\n \"srcset\",\n \"sizes\",\n \"as\",\n \"alt\",\n \"class\",\n \"loading\",\n \"crossorigin\",\n \"referrerPolicy\",\n \"width\",\n \"height\",\n \"decoding\",\n \"fetchPriority\",\n \"ismap\",\n \"usemap\"\n ],\n setup(props, { slots }) {\n const data = reactive(useImage(props));\n return () => {\n if (data.isLoading && slots.loading)\n return slots.loading(data);\n else if (data.error && slots.error)\n return slots.error(data.error);\n if (slots.default)\n return slots.default(data);\n return h(props.as || \"img\", props);\n };\n }\n});\n\nfunction resolveElement(el) {\n if (typeof Window !== \"undefined\" && el instanceof Window)\n return el.document.documentElement;\n if (typeof Document !== \"undefined\" && el instanceof Document)\n return el.documentElement;\n return el;\n}\n\nconst ARRIVED_STATE_THRESHOLD_PIXELS = 1;\nfunction useScroll(element, options = {}) {\n const {\n throttle = 0,\n idle = 200,\n onStop = noop,\n onScroll = noop,\n offset = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n },\n observe: _observe = {\n mutation: false\n },\n eventListenerOptions = {\n capture: false,\n passive: true\n },\n behavior = \"auto\",\n window = defaultWindow,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const observe = typeof _observe === \"boolean\" ? {\n mutation: _observe\n } : _observe;\n const internalX = shallowRef(0);\n const internalY = shallowRef(0);\n const x = computed({\n get() {\n return internalX.value;\n },\n set(x2) {\n scrollTo(x2, void 0);\n }\n });\n const y = computed({\n get() {\n return internalY.value;\n },\n set(y2) {\n scrollTo(void 0, y2);\n }\n });\n function scrollTo(_x, _y) {\n var _a, _b, _c, _d;\n if (!window)\n return;\n const _element = toValue(element);\n if (!_element)\n return;\n (_c = _element instanceof Document ? window.document.body : _element) == null ? void 0 : _c.scrollTo({\n top: (_a = toValue(_y)) != null ? _a : y.value,\n left: (_b = toValue(_x)) != null ? _b : x.value,\n behavior: toValue(behavior)\n });\n const scrollContainer = ((_d = _element == null ? void 0 : _element.document) == null ? void 0 : _d.documentElement) || (_element == null ? void 0 : _element.documentElement) || _element;\n if (x != null)\n internalX.value = scrollContainer.scrollLeft;\n if (y != null)\n internalY.value = scrollContainer.scrollTop;\n }\n const isScrolling = shallowRef(false);\n const arrivedState = reactive({\n left: true,\n right: false,\n top: true,\n bottom: false\n });\n const directions = reactive({\n left: false,\n right: false,\n top: false,\n bottom: false\n });\n const onScrollEnd = (e) => {\n if (!isScrolling.value)\n return;\n isScrolling.value = false;\n directions.left = false;\n directions.right = false;\n directions.top = false;\n directions.bottom = false;\n onStop(e);\n };\n const onScrollEndDebounced = useDebounceFn(onScrollEnd, throttle + idle);\n const setArrivedState = (target) => {\n var _a;\n if (!window)\n return;\n const el = ((_a = target == null ? void 0 : target.document) == null ? void 0 : _a.documentElement) || (target == null ? void 0 : target.documentElement) || unrefElement(target);\n const { display, flexDirection, direction } = getComputedStyle(el);\n const directionMultipler = direction === \"rtl\" ? -1 : 1;\n const scrollLeft = el.scrollLeft;\n directions.left = scrollLeft < internalX.value;\n directions.right = scrollLeft > internalX.value;\n const left = Math.abs(scrollLeft * directionMultipler) <= (offset.left || 0);\n const right = Math.abs(scrollLeft * directionMultipler) + el.clientWidth >= el.scrollWidth - (offset.right || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"row-reverse\") {\n arrivedState.left = right;\n arrivedState.right = left;\n } else {\n arrivedState.left = left;\n arrivedState.right = right;\n }\n internalX.value = scrollLeft;\n let scrollTop = el.scrollTop;\n if (target === window.document && !scrollTop)\n scrollTop = window.document.body.scrollTop;\n directions.top = scrollTop < internalY.value;\n directions.bottom = scrollTop > internalY.value;\n const top = Math.abs(scrollTop) <= (offset.top || 0);\n const bottom = Math.abs(scrollTop) + el.clientHeight >= el.scrollHeight - (offset.bottom || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"column-reverse\") {\n arrivedState.top = bottom;\n arrivedState.bottom = top;\n } else {\n arrivedState.top = top;\n arrivedState.bottom = bottom;\n }\n internalY.value = scrollTop;\n };\n const onScrollHandler = (e) => {\n var _a;\n if (!window)\n return;\n const eventTarget = (_a = e.target.documentElement) != null ? _a : e.target;\n setArrivedState(eventTarget);\n isScrolling.value = true;\n onScrollEndDebounced(e);\n onScroll(e);\n };\n useEventListener(\n element,\n \"scroll\",\n throttle ? useThrottleFn(onScrollHandler, throttle, true, false) : onScrollHandler,\n eventListenerOptions\n );\n tryOnMounted(() => {\n try {\n const _element = toValue(element);\n if (!_element)\n return;\n setArrivedState(_element);\n } catch (e) {\n onError(e);\n }\n });\n if ((observe == null ? void 0 : observe.mutation) && element != null && element !== window && element !== document) {\n useMutationObserver(\n element,\n () => {\n const _element = toValue(element);\n if (!_element)\n return;\n setArrivedState(_element);\n },\n {\n attributes: true,\n childList: true,\n subtree: true\n }\n );\n }\n useEventListener(\n element,\n \"scrollend\",\n onScrollEnd,\n eventListenerOptions\n );\n return {\n x,\n y,\n isScrolling,\n arrivedState,\n directions,\n measure() {\n const _element = toValue(element);\n if (window && _element)\n setArrivedState(_element);\n }\n };\n}\n\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n var _a;\n const {\n direction = \"bottom\",\n interval = 100,\n canLoadMore = () => true\n } = options;\n const state = reactive(useScroll(\n element,\n {\n ...options,\n offset: {\n [direction]: (_a = options.distance) != null ? _a : 0,\n ...options.offset\n }\n }\n ));\n const promise = ref();\n const isLoading = computed(() => !!promise.value);\n const observedElement = computed(() => {\n return resolveElement(toValue(element));\n });\n const isElementVisible = useElementVisibility(observedElement);\n function checkAndLoad() {\n state.measure();\n if (!observedElement.value || !isElementVisible.value || !canLoadMore(observedElement.value))\n return;\n const { scrollHeight, clientHeight, scrollWidth, clientWidth } = observedElement.value;\n const isNarrower = direction === \"bottom\" || direction === \"top\" ? scrollHeight <= clientHeight : scrollWidth <= clientWidth;\n if (state.arrivedState[direction] || isNarrower) {\n if (!promise.value) {\n promise.value = Promise.all([\n onLoadMore(state),\n new Promise((resolve) => setTimeout(resolve, interval))\n ]).finally(() => {\n promise.value = null;\n nextTick(() => checkAndLoad());\n });\n }\n }\n }\n const stop = watch(\n () => [state.arrivedState[direction], isElementVisible.value],\n checkAndLoad,\n { immediate: true }\n );\n tryOnUnmounted(stop);\n return {\n isLoading,\n reset() {\n nextTick(() => checkAndLoad());\n }\n };\n}\n\nconst vInfiniteScroll = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n useInfiniteScroll(el, binding.value);\n else\n useInfiniteScroll(el, ...binding.value);\n }\n};\n\nconst vIntersectionObserver = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n useIntersectionObserver(el, binding.value);\n else\n useIntersectionObserver(el, ...binding.value);\n }\n};\n\nconst UseMouse = /* @__PURE__ */ defineComponent({\n name: \"UseMouse\",\n props: [\"touch\", \"resetOnTouchEnds\", \"initialValue\"],\n setup(props, { slots }) {\n const data = reactive(useMouse$1(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseMouseInElement = /* @__PURE__ */ defineComponent({\n name: \"UseMouseElement\",\n props: [\"handleOutside\", \"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useMouseInElement$1(target, props));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UseMouseBuiltinExtractors = {\n page: (event) => [event.pageX, event.pageY],\n client: (event) => [event.clientX, event.clientY],\n screen: (event) => [event.screenX, event.screenY],\n movement: (event) => event instanceof MouseEvent ? [event.movementX, event.movementY] : null\n};\nfunction useMouse(options = {}) {\n const {\n type = \"page\",\n touch = true,\n resetOnTouchEnds = false,\n initialValue = { x: 0, y: 0 },\n window = defaultWindow,\n target = window,\n scroll = true,\n eventFilter\n } = options;\n let _prevMouseEvent = null;\n let _prevScrollX = 0;\n let _prevScrollY = 0;\n const x = shallowRef(initialValue.x);\n const y = shallowRef(initialValue.y);\n const sourceType = shallowRef(null);\n const extractor = typeof type === \"function\" ? type : UseMouseBuiltinExtractors[type];\n const mouseHandler = (event) => {\n const result = extractor(event);\n _prevMouseEvent = event;\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"mouse\";\n }\n if (window) {\n _prevScrollX = window.scrollX;\n _prevScrollY = window.scrollY;\n }\n };\n const touchHandler = (event) => {\n if (event.touches.length > 0) {\n const result = extractor(event.touches[0]);\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"touch\";\n }\n }\n };\n const scrollHandler = () => {\n if (!_prevMouseEvent || !window)\n return;\n const pos = extractor(_prevMouseEvent);\n if (_prevMouseEvent instanceof MouseEvent && pos) {\n x.value = pos[0] + window.scrollX - _prevScrollX;\n y.value = pos[1] + window.scrollY - _prevScrollY;\n }\n };\n const reset = () => {\n x.value = initialValue.x;\n y.value = initialValue.y;\n };\n const mouseHandlerWrapper = eventFilter ? (event) => eventFilter(() => mouseHandler(event), {}) : (event) => mouseHandler(event);\n const touchHandlerWrapper = eventFilter ? (event) => eventFilter(() => touchHandler(event), {}) : (event) => touchHandler(event);\n const scrollHandlerWrapper = eventFilter ? () => eventFilter(() => scrollHandler(), {}) : () => scrollHandler();\n if (target) {\n const listenerOptions = { passive: true };\n useEventListener(target, [\"mousemove\", \"dragover\"], mouseHandlerWrapper, listenerOptions);\n if (touch && type !== \"movement\") {\n useEventListener(target, [\"touchstart\", \"touchmove\"], touchHandlerWrapper, listenerOptions);\n if (resetOnTouchEnds)\n useEventListener(target, \"touchend\", reset, listenerOptions);\n }\n if (scroll && type === \"page\")\n useEventListener(window, \"scroll\", scrollHandlerWrapper, listenerOptions);\n }\n return {\n x,\n y,\n sourceType\n };\n}\n\nfunction useMouseInElement(target, options = {}) {\n const {\n windowResize = true,\n windowScroll = true,\n handleOutside = true,\n window = defaultWindow\n } = options;\n const type = options.type || \"page\";\n const { x, y, sourceType } = useMouse(options);\n const targetRef = shallowRef(target != null ? target : window == null ? void 0 : window.document.body);\n const elementX = shallowRef(0);\n const elementY = shallowRef(0);\n const elementPositionX = shallowRef(0);\n const elementPositionY = shallowRef(0);\n const elementHeight = shallowRef(0);\n const elementWidth = shallowRef(0);\n const isOutside = shallowRef(true);\n function update() {\n if (!window)\n return;\n const el = unrefElement(targetRef);\n if (!el || !(el instanceof Element))\n return;\n const {\n left,\n top,\n width,\n height\n } = el.getBoundingClientRect();\n elementPositionX.value = left + (type === \"page\" ? window.pageXOffset : 0);\n elementPositionY.value = top + (type === \"page\" ? window.pageYOffset : 0);\n elementHeight.value = height;\n elementWidth.value = width;\n const elX = x.value - elementPositionX.value;\n const elY = y.value - elementPositionY.value;\n isOutside.value = width === 0 || height === 0 || elX < 0 || elY < 0 || elX > width || elY > height;\n if (handleOutside || !isOutside.value) {\n elementX.value = elX;\n elementY.value = elY;\n }\n }\n const stopFnList = [];\n function stop() {\n stopFnList.forEach((fn) => fn());\n stopFnList.length = 0;\n }\n tryOnMounted(() => {\n update();\n });\n if (window) {\n const {\n stop: stopResizeObserver\n } = useResizeObserver(targetRef, update);\n const {\n stop: stopMutationObserver\n } = useMutationObserver(targetRef, update, {\n attributeFilter: [\"style\", \"class\"]\n });\n const stopWatch = watch(\n [targetRef, x, y],\n update\n );\n stopFnList.push(\n stopResizeObserver,\n stopMutationObserver,\n stopWatch\n );\n useEventListener(\n document,\n \"mouseleave\",\n () => isOutside.value = true,\n { passive: true }\n );\n if (windowScroll) {\n stopFnList.push(\n useEventListener(\"scroll\", update, { capture: true, passive: true })\n );\n }\n if (windowResize) {\n stopFnList.push(\n useEventListener(\"resize\", update, { passive: true })\n );\n }\n }\n return {\n x,\n y,\n sourceType,\n elementX,\n elementY,\n elementPositionX,\n elementPositionY,\n elementHeight,\n elementWidth,\n isOutside,\n stop\n };\n}\n\nconst vMouseInElement = {\n mounted(el, binding) {\n const [handler, options] = typeof binding.value === \"function\" ? [binding.value, {}] : binding.value;\n const state = reactiveOmit(reactive(useMouseInElement(el, options)), \"stop\");\n watch(state, (val) => handler(val));\n }\n};\n\nconst UseMousePressed = /* @__PURE__ */ defineComponent({\n name: \"UseMousePressed\",\n props: [\"touch\", \"initialValue\", \"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(useMousePressed({ ...props, target }));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UseNetwork = /* @__PURE__ */ defineComponent({\n name: \"UseNetwork\",\n setup(props, { slots }) {\n const data = reactive(useNetwork());\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseNow = /* @__PURE__ */ defineComponent({\n name: \"UseNow\",\n props: [\"interval\"],\n setup(props, { slots }) {\n const data = reactive(useNow({ ...props, controls: true }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseObjectUrl = /* @__PURE__ */ defineComponent({\n name: \"UseObjectUrl\",\n props: [\n \"object\"\n ],\n setup(props, { slots }) {\n const object = toRef(props, \"object\");\n const url = useObjectUrl(object);\n return () => {\n if (slots.default && url.value)\n return slots.default(url);\n };\n }\n});\n\nconst UseOffsetPagination = /* @__PURE__ */ defineComponent({\n name: \"UseOffsetPagination\",\n props: [\n \"total\",\n \"page\",\n \"pageSize\",\n \"onPageChange\",\n \"onPageSizeChange\",\n \"onPageCountChange\"\n ],\n emits: [\n \"page-change\",\n \"page-size-change\",\n \"page-count-change\"\n ],\n setup(props, { slots, emit }) {\n const data = reactive(useOffsetPagination({\n ...props,\n onPageChange(...args) {\n var _a;\n (_a = props.onPageChange) == null ? void 0 : _a.call(props, ...args);\n emit(\"page-change\", ...args);\n },\n onPageSizeChange(...args) {\n var _a;\n (_a = props.onPageSizeChange) == null ? void 0 : _a.call(props, ...args);\n emit(\"page-size-change\", ...args);\n },\n onPageCountChange(...args) {\n var _a;\n (_a = props.onPageCountChange) == null ? void 0 : _a.call(props, ...args);\n emit(\"page-count-change\", ...args);\n }\n }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseOnline = /* @__PURE__ */ defineComponent({\n name: \"UseOnline\",\n setup(props, { slots }) {\n const data = reactive({\n isOnline: useOnline()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePageLeave = /* @__PURE__ */ defineComponent({\n name: \"UsePageLeave\",\n setup(props, { slots }) {\n const data = reactive({\n isLeft: usePageLeave()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePointer = /* @__PURE__ */ defineComponent({\n name: \"UsePointer\",\n props: [\n \"pointerTypes\",\n \"initialValue\",\n \"target\"\n ],\n setup(props, { slots }) {\n const el = shallowRef(null);\n const data = reactive(usePointer({\n ...props,\n target: props.target === \"self\" ? el : defaultWindow\n }));\n return () => {\n if (slots.default)\n return slots.default(data, { ref: el });\n };\n }\n});\n\nconst UsePointerLock = /*@__PURE__*/ defineComponent({\n name: \"UsePointerLock\",\n props: [\"as\"],\n setup(props, { slots }) {\n const target = shallowRef();\n const data = reactive(usePointerLock(target));\n return () => {\n if (slots.default)\n return h(props.as || \"div\", { ref: target }, slots.default(data));\n };\n }\n});\n\nconst UsePreferredColorScheme = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredColorScheme\",\n setup(props, { slots }) {\n const data = reactive({\n colorScheme: usePreferredColorScheme()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredContrast = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredContrast\",\n setup(props, { slots }) {\n const data = reactive({\n contrast: usePreferredContrast()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredDark = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredDark\",\n setup(props, { slots }) {\n const data = reactive({\n prefersDark: usePreferredDark$1()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredLanguages = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredLanguages\",\n setup(props, { slots }) {\n const data = reactive({\n languages: usePreferredLanguages()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredReducedMotion = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredReducedMotion\",\n setup(props, { slots }) {\n const data = reactive({\n motion: usePreferredReducedMotion()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UsePreferredReducedTransparency = /* @__PURE__ */ defineComponent({\n name: \"UsePreferredReducedTransparency\",\n setup(props, { slots }) {\n const data = reactive({\n transparency: usePreferredReducedTransparency()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst vResizeObserver = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\")\n useResizeObserver(el, binding.value);\n else\n useResizeObserver(el, ...binding.value);\n }\n};\n\nfunction useCssVar(prop, target, options = {}) {\n const { window = defaultWindow, initialValue, observe = false } = options;\n const variable = shallowRef(initialValue);\n const elRef = computed(() => {\n var _a;\n return unrefElement(target) || ((_a = window == null ? void 0 : window.document) == null ? void 0 : _a.documentElement);\n });\n function updateCssVar() {\n var _a;\n const key = toValue(prop);\n const el = toValue(elRef);\n if (el && window && key) {\n const value = (_a = window.getComputedStyle(el).getPropertyValue(key)) == null ? void 0 : _a.trim();\n variable.value = value || variable.value || initialValue;\n }\n }\n if (observe) {\n useMutationObserver(elRef, updateCssVar, {\n attributeFilter: [\"style\", \"class\"],\n window\n });\n }\n watch(\n [elRef, () => toValue(prop)],\n (_, old) => {\n if (old[0] && old[1])\n old[0].style.removeProperty(old[1]);\n updateCssVar();\n },\n { immediate: true }\n );\n watch(\n [variable, elRef],\n ([val, el]) => {\n const raw_prop = toValue(prop);\n if ((el == null ? void 0 : el.style) && raw_prop) {\n if (val == null)\n el.style.removeProperty(raw_prop);\n else\n el.style.setProperty(raw_prop, val);\n }\n },\n { immediate: true }\n );\n return variable;\n}\n\nconst topVarName = \"--vueuse-safe-area-top\";\nconst rightVarName = \"--vueuse-safe-area-right\";\nconst bottomVarName = \"--vueuse-safe-area-bottom\";\nconst leftVarName = \"--vueuse-safe-area-left\";\nfunction useScreenSafeArea() {\n const top = shallowRef(\"\");\n const right = shallowRef(\"\");\n const bottom = shallowRef(\"\");\n const left = shallowRef(\"\");\n if (isClient) {\n const topCssVar = useCssVar(topVarName);\n const rightCssVar = useCssVar(rightVarName);\n const bottomCssVar = useCssVar(bottomVarName);\n const leftCssVar = useCssVar(leftVarName);\n topCssVar.value = \"env(safe-area-inset-top, 0px)\";\n rightCssVar.value = \"env(safe-area-inset-right, 0px)\";\n bottomCssVar.value = \"env(safe-area-inset-bottom, 0px)\";\n leftCssVar.value = \"env(safe-area-inset-left, 0px)\";\n tryOnMounted(update);\n useEventListener(\"resize\", useDebounceFn(update), { passive: true });\n }\n function update() {\n top.value = getValue(topVarName);\n right.value = getValue(rightVarName);\n bottom.value = getValue(bottomVarName);\n left.value = getValue(leftVarName);\n }\n return {\n top,\n right,\n bottom,\n left,\n update\n };\n}\nfunction getValue(position) {\n return getComputedStyle(document.documentElement).getPropertyValue(position);\n}\n\nconst UseScreenSafeArea = /* @__PURE__ */ defineComponent({\n name: \"UseScreenSafeArea\",\n props: {\n top: Boolean,\n right: Boolean,\n bottom: Boolean,\n left: Boolean\n },\n setup(props, { slots }) {\n const {\n top,\n right,\n bottom,\n left\n } = useScreenSafeArea();\n return () => {\n if (slots.default) {\n return h(\"div\", {\n style: {\n paddingTop: props.top ? top.value : \"\",\n paddingRight: props.right ? right.value : \"\",\n paddingBottom: props.bottom ? bottom.value : \"\",\n paddingLeft: props.left ? left.value : \"\",\n boxSizing: \"border-box\",\n maxHeight: \"100vh\",\n maxWidth: \"100vw\",\n overflow: \"auto\"\n }\n }, slots.default());\n }\n };\n }\n});\n\nconst vScroll = {\n mounted(el, binding) {\n if (typeof binding.value === \"function\") {\n const handler = binding.value;\n const state = useScroll(el, {\n onScroll() {\n handler(state);\n },\n onStop() {\n handler(state);\n }\n });\n } else {\n const [handler, options] = binding.value;\n const state = useScroll(el, {\n ...options,\n onScroll(e) {\n var _a;\n (_a = options.onScroll) == null ? void 0 : _a.call(options, e);\n handler(state);\n },\n onStop(e) {\n var _a;\n (_a = options.onStop) == null ? void 0 : _a.call(options, e);\n handler(state);\n }\n });\n }\n }\n};\n\nfunction checkOverflowScroll(ele) {\n const style = window.getComputedStyle(ele);\n if (style.overflowX === \"scroll\" || style.overflowY === \"scroll\" || style.overflowX === \"auto\" && ele.clientWidth < ele.scrollWidth || style.overflowY === \"auto\" && ele.clientHeight < ele.scrollHeight) {\n return true;\n } else {\n const parent = ele.parentNode;\n if (!parent || parent.tagName === \"BODY\")\n return false;\n return checkOverflowScroll(parent);\n }\n}\nfunction preventDefault(rawEvent) {\n const e = rawEvent || window.event;\n const _target = e.target;\n if (checkOverflowScroll(_target))\n return false;\n if (e.touches.length > 1)\n return true;\n if (e.preventDefault)\n e.preventDefault();\n return false;\n}\nconst elInitialOverflow = /* @__PURE__ */ new WeakMap();\nfunction useScrollLock(element, initialState = false) {\n const isLocked = shallowRef(initialState);\n let stopTouchMoveListener = null;\n let initialOverflow = \"\";\n watch(toRef(element), (el) => {\n const target = resolveElement(toValue(el));\n if (target) {\n const ele = target;\n if (!elInitialOverflow.get(ele))\n elInitialOverflow.set(ele, ele.style.overflow);\n if (ele.style.overflow !== \"hidden\")\n initialOverflow = ele.style.overflow;\n if (ele.style.overflow === \"hidden\")\n return isLocked.value = true;\n if (isLocked.value)\n return ele.style.overflow = \"hidden\";\n }\n }, {\n immediate: true\n });\n const lock = () => {\n const el = resolveElement(toValue(element));\n if (!el || isLocked.value)\n return;\n if (isIOS) {\n stopTouchMoveListener = useEventListener(\n el,\n \"touchmove\",\n (e) => {\n preventDefault(e);\n },\n { passive: false }\n );\n }\n el.style.overflow = \"hidden\";\n isLocked.value = true;\n };\n const unlock = () => {\n const el = resolveElement(toValue(element));\n if (!el || !isLocked.value)\n return;\n if (isIOS)\n stopTouchMoveListener == null ? void 0 : stopTouchMoveListener();\n el.style.overflow = initialOverflow;\n elInitialOverflow.delete(el);\n isLocked.value = false;\n };\n tryOnScopeDispose(unlock);\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else unlock();\n }\n });\n}\n\nfunction onScrollLock() {\n let isMounted = false;\n const state = shallowRef(false);\n return (el, binding) => {\n state.value = binding.value;\n if (isMounted)\n return;\n isMounted = true;\n const isLocked = useScrollLock(el, binding.value);\n watch(state, (v) => isLocked.value = v);\n };\n}\nconst vScrollLock = onScrollLock();\n\nconst UseTimeAgo = /* @__PURE__ */ defineComponent({\n name: \"UseTimeAgo\",\n props: [\"time\", \"updateInterval\", \"max\", \"fullDateFormatter\", \"messages\", \"showSecond\"],\n setup(props, { slots }) {\n const data = reactive(useTimeAgo(() => props.time, { ...props, controls: true }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseTimestamp = /* @__PURE__ */ defineComponent({\n name: \"UseTimestamp\",\n props: [\"immediate\", \"interval\", \"offset\"],\n setup(props, { slots }) {\n const data = reactive(useTimestamp({ ...props, controls: true }));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseVirtualList = /* @__PURE__ */ defineComponent({\n name: \"UseVirtualList\",\n props: [\n \"list\",\n \"options\",\n \"height\"\n ],\n setup(props, { slots, expose }) {\n const { list: listRef } = toRefs(props);\n const { list, containerProps, wrapperProps, scrollTo } = useVirtualList(listRef, props.options);\n expose({ scrollTo });\n if (containerProps.style && typeof containerProps.style === \"object\" && !Array.isArray(containerProps.style))\n containerProps.style.height = props.height || \"300px\";\n return () => h(\"div\", { ...containerProps }, [\n h(\"div\", { ...wrapperProps.value }, list.value.map((item) => h(\"div\", { style: { overflow: \"hidden\", height: item.height } }, slots.default ? slots.default(item) : \"Please set content!\")))\n ]);\n }\n});\n\nconst UseWindowFocus = /* @__PURE__ */ defineComponent({\n name: \"UseWindowFocus\",\n setup(props, { slots }) {\n const data = reactive({\n focused: useWindowFocus()\n });\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nconst UseWindowSize = /* @__PURE__ */ defineComponent({\n name: \"UseWindowSize\",\n props: [\"initialWidth\", \"initialHeight\"],\n setup(props, { slots }) {\n const data = reactive(useWindowSize(props));\n return () => {\n if (slots.default)\n return slots.default(data);\n };\n }\n});\n\nexport { OnClickOutside, OnLongPress, UseActiveElement, UseBattery, UseBrowserLocation, UseClipboard, UseColorMode, UseDark, UseDeviceMotion, UseDeviceOrientation, UseDevicePixelRatio, UseDevicesList, UseDocumentVisibility, UseDraggable, UseElementBounding, UseElementSize, UseElementVisibility, UseEyeDropper, UseFullscreen, UseGeolocation, UseIdle, UseImage, UseMouse, UseMouseInElement, UseMousePressed, UseNetwork, UseNow, UseObjectUrl, UseOffsetPagination, UseOnline, UsePageLeave, UsePointer, UsePointerLock, UsePreferredColorScheme, UsePreferredContrast, UsePreferredDark, UsePreferredLanguages, UsePreferredReducedMotion, UsePreferredReducedTransparency, UseScreenSafeArea, UseTimeAgo, UseTimestamp, UseVirtualList, UseWindowFocus, UseWindowSize, vOnClickOutside as VOnClickOutside, vOnLongPress as VOnLongPress, vElementBounding, vElementHover, vElementSize, vElementVisibility, vInfiniteScroll, vIntersectionObserver, vMouseInElement, vOnClickOutside, vOnKeyStroke, vOnLongPress, vResizeObserver, vScroll, vScrollLock };\n","import { l as logger } from \"../../chunks/logger-D3RVzcfQ.mjs\";\nfunction registerContactsMenuAction(action) {\n window._nc_contacts_menu_hooks ??= {};\n if (window._nc_contacts_menu_hooks[action.id]) {\n logger.error(`ContactsMenu action for id ${action.id} has already been registered`, {\n action\n });\n return;\n }\n window._nc_contacts_menu_hooks[action.id] = action;\n}\nfunction getEnabledContactsMenuActions(entry) {\n if (!window._nc_contacts_menu_hooks) {\n return [];\n }\n return Object.values(window._nc_contacts_menu_hooks).filter((action) => action.enabled(entry));\n}\nexport {\n getEnabledContactsMenuActions,\n registerContactsMenuAction\n};\n//# sourceMappingURL=index.mjs.map\n","'use strict';\n\nObject.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });\n\nvar buffer = {};\n\nvar base64Js = {};\n\nbase64Js.byteLength = byteLength;\nbase64Js.toByteArray = toByteArray;\nbase64Js.fromByteArray = fromByteArray;\n\nvar lookup = [];\nvar revLookup = [];\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array;\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i];\n revLookup[code.charCodeAt(i)] = i;\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62;\nrevLookup['_'.charCodeAt(0)] = 63;\n\nfunction getLens (b64) {\n var len = b64.length;\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=');\n if (validLen === -1) validLen = len;\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4);\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64);\n var validLen = lens[0];\n var placeHoldersLen = lens[1];\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp;\n var lens = getLens(b64);\n var validLen = lens[0];\n var placeHoldersLen = lens[1];\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen));\n\n var curByte = 0;\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen;\n\n var i;\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)];\n arr[curByte++] = (tmp >> 16) & 0xFF;\n arr[curByte++] = (tmp >> 8) & 0xFF;\n arr[curByte++] = tmp & 0xFF;\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4);\n arr[curByte++] = tmp & 0xFF;\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2);\n arr[curByte++] = (tmp >> 8) & 0xFF;\n arr[curByte++] = tmp & 0xFF;\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp;\n var output = [];\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF);\n output.push(tripletToBase64(tmp));\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp;\n var len = uint8.length;\n var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes\n var parts = [];\n var maxChunkLength = 16383; // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)));\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1];\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n );\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1];\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n );\n }\n\n return parts.join('')\n}\n\nvar ieee754 = {};\n\n/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\n\nieee754.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\nieee754.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 * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n\n(function (exports) {\n\n\tconst base64 = base64Js;\n\tconst ieee754$1 = ieee754;\n\tconst customInspectSymbol =\n\t (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n\t ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n\t : null;\n\n\texports.Buffer = Buffer;\n\texports.SlowBuffer = SlowBuffer;\n\texports.INSPECT_MAX_BYTES = 50;\n\n\tconst K_MAX_LENGTH = 0x7fffffff;\n\texports.kMaxLength = K_MAX_LENGTH;\n\tconst { Uint8Array: GlobalUint8Array, ArrayBuffer: GlobalArrayBuffer, SharedArrayBuffer: GlobalSharedArrayBuffer } = globalThis;\n\n\t/**\n\t * If `Buffer.TYPED_ARRAY_SUPPORT`:\n\t * === true Use Uint8Array implementation (fastest)\n\t * === false Print warning and recommend using `buffer` v4.x which has an Object\n\t * implementation (most compatible, even IE6)\n\t *\n\t * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n\t * Opera 11.6+, iOS 4.2+.\n\t *\n\t * We report that the browser does not support typed arrays if the are not subclassable\n\t * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n\t * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n\t * for __proto__ and has a buggy typed array implementation.\n\t */\n\tBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport();\n\n\tif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n\t typeof console.error === 'function') {\n\t console.error(\n\t 'This browser lacks typed array (Uint8Array) support which is required by ' +\n\t '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n\t );\n\t}\n\n\tfunction typedArraySupport () {\n\t // Can typed array instances can be augmented?\n\t try {\n\t const arr = new GlobalUint8Array(1);\n\t const proto = { foo: function () { return 42 } };\n\t Object.setPrototypeOf(proto, GlobalUint8Array.prototype);\n\t Object.setPrototypeOf(arr, proto);\n\t return arr.foo() === 42\n\t } catch (e) {\n\t return false\n\t }\n\t}\n\n\tObject.defineProperty(Buffer.prototype, 'parent', {\n\t enumerable: true,\n\t get: function () {\n\t if (!Buffer.isBuffer(this)) return undefined\n\t return this.buffer\n\t }\n\t});\n\n\tObject.defineProperty(Buffer.prototype, 'offset', {\n\t enumerable: true,\n\t get: function () {\n\t if (!Buffer.isBuffer(this)) return undefined\n\t return this.byteOffset\n\t }\n\t});\n\n\tfunction createBuffer (length) {\n\t if (length > K_MAX_LENGTH) {\n\t throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n\t }\n\t // Return an augmented `Uint8Array` instance\n\t const buf = new GlobalUint8Array(length);\n\t Object.setPrototypeOf(buf, Buffer.prototype);\n\t return buf\n\t}\n\n\t/**\n\t * The Buffer constructor returns instances of `Uint8Array` that have their\n\t * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n\t * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n\t * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n\t * returns a single octet.\n\t *\n\t * The `Uint8Array` prototype remains unmodified.\n\t */\n\n\tfunction Buffer (arg, encodingOrOffset, length) {\n\t // Common case.\n\t if (typeof arg === 'number') {\n\t if (typeof encodingOrOffset === 'string') {\n\t throw new TypeError(\n\t 'The \"string\" argument must be of type string. Received type number'\n\t )\n\t }\n\t return allocUnsafe(arg)\n\t }\n\t return from(arg, encodingOrOffset, length)\n\t}\n\n\tBuffer.poolSize = 8192; // not used by this implementation\n\n\tfunction from (value, encodingOrOffset, length) {\n\t if (typeof value === 'string') {\n\t return fromString(value, encodingOrOffset)\n\t }\n\n\t if (GlobalArrayBuffer.isView(value)) {\n\t return fromArrayView(value)\n\t }\n\n\t if (value == null) {\n\t throw new TypeError(\n\t 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n\t 'or Array-like Object. Received type ' + (typeof value)\n\t )\n\t }\n\n\t if (isInstance(value, GlobalArrayBuffer) ||\n\t (value && isInstance(value.buffer, GlobalArrayBuffer))) {\n\t return fromArrayBuffer(value, encodingOrOffset, length)\n\t }\n\n\t if (typeof GlobalSharedArrayBuffer !== 'undefined' &&\n\t (isInstance(value, GlobalSharedArrayBuffer) ||\n\t (value && isInstance(value.buffer, GlobalSharedArrayBuffer)))) {\n\t return fromArrayBuffer(value, encodingOrOffset, length)\n\t }\n\n\t if (typeof value === 'number') {\n\t throw new TypeError(\n\t 'The \"value\" argument must not be of type number. Received type number'\n\t )\n\t }\n\n\t const valueOf = value.valueOf && value.valueOf();\n\t if (valueOf != null && valueOf !== value) {\n\t return Buffer.from(valueOf, encodingOrOffset, length)\n\t }\n\n\t const b = fromObject(value);\n\t if (b) return b\n\n\t if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n\t typeof value[Symbol.toPrimitive] === 'function') {\n\t return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length)\n\t }\n\n\t throw new TypeError(\n\t 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n\t 'or Array-like Object. Received type ' + (typeof value)\n\t )\n\t}\n\n\t/**\n\t * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n\t * if value is a number.\n\t * Buffer.from(str[, encoding])\n\t * Buffer.from(array)\n\t * Buffer.from(buffer)\n\t * Buffer.from(arrayBuffer[, byteOffset[, length]])\n\t **/\n\tBuffer.from = function (value, encodingOrOffset, length) {\n\t return from(value, encodingOrOffset, length)\n\t};\n\n\t// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n\t// https://github.com/feross/buffer/pull/148\n\tObject.setPrototypeOf(Buffer.prototype, GlobalUint8Array.prototype);\n\tObject.setPrototypeOf(Buffer, GlobalUint8Array);\n\n\tfunction assertSize (size) {\n\t if (typeof size !== 'number') {\n\t throw new TypeError('\"size\" argument must be of type number')\n\t } else if (size < 0) {\n\t throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n\t }\n\t}\n\n\tfunction alloc (size, fill, encoding) {\n\t assertSize(size);\n\t if (size <= 0) {\n\t return createBuffer(size)\n\t }\n\t if (fill !== undefined) {\n\t // Only pay attention to encoding if it's a string. This\n\t // prevents accidentally sending in a number that would\n\t // be interpreted as a start offset.\n\t return typeof encoding === 'string'\n\t ? createBuffer(size).fill(fill, encoding)\n\t : createBuffer(size).fill(fill)\n\t }\n\t return createBuffer(size)\n\t}\n\n\t/**\n\t * Creates a new filled Buffer instance.\n\t * alloc(size[, fill[, encoding]])\n\t **/\n\tBuffer.alloc = function (size, fill, encoding) {\n\t return alloc(size, fill, encoding)\n\t};\n\n\tfunction allocUnsafe (size) {\n\t assertSize(size);\n\t return createBuffer(size < 0 ? 0 : checked(size) | 0)\n\t}\n\n\t/**\n\t * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n\t * */\n\tBuffer.allocUnsafe = function (size) {\n\t return allocUnsafe(size)\n\t};\n\t/**\n\t * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n\t */\n\tBuffer.allocUnsafeSlow = function (size) {\n\t return allocUnsafe(size)\n\t};\n\n\tfunction fromString (string, encoding) {\n\t if (typeof encoding !== 'string' || encoding === '') {\n\t encoding = 'utf8';\n\t }\n\n\t if (!Buffer.isEncoding(encoding)) {\n\t throw new TypeError('Unknown encoding: ' + encoding)\n\t }\n\n\t const length = byteLength(string, encoding) | 0;\n\t let buf = createBuffer(length);\n\n\t const actual = buf.write(string, encoding);\n\n\t if (actual !== length) {\n\t // Writing a hex string, for example, that contains invalid characters will\n\t // cause everything after the first invalid character to be ignored. (e.g.\n\t // 'abxxcd' will be treated as 'ab')\n\t buf = buf.slice(0, actual);\n\t }\n\n\t return buf\n\t}\n\n\tfunction fromArrayLike (array) {\n\t const length = array.length < 0 ? 0 : checked(array.length) | 0;\n\t const buf = createBuffer(length);\n\t for (let i = 0; i < length; i += 1) {\n\t buf[i] = array[i] & 255;\n\t }\n\t return buf\n\t}\n\n\tfunction fromArrayView (arrayView) {\n\t if (isInstance(arrayView, GlobalUint8Array)) {\n\t const copy = new GlobalUint8Array(arrayView);\n\t return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n\t }\n\t return fromArrayLike(arrayView)\n\t}\n\n\tfunction fromArrayBuffer (array, byteOffset, length) {\n\t if (byteOffset < 0 || array.byteLength < byteOffset) {\n\t throw new RangeError('\"offset\" is outside of buffer bounds')\n\t }\n\n\t if (array.byteLength < byteOffset + (length || 0)) {\n\t throw new RangeError('\"length\" is outside of buffer bounds')\n\t }\n\n\t let buf;\n\t if (byteOffset === undefined && length === undefined) {\n\t buf = new GlobalUint8Array(array);\n\t } else if (length === undefined) {\n\t buf = new GlobalUint8Array(array, byteOffset);\n\t } else {\n\t buf = new GlobalUint8Array(array, byteOffset, length);\n\t }\n\n\t // Return an augmented `Uint8Array` instance\n\t Object.setPrototypeOf(buf, Buffer.prototype);\n\n\t return buf\n\t}\n\n\tfunction fromObject (obj) {\n\t if (Buffer.isBuffer(obj)) {\n\t const len = checked(obj.length) | 0;\n\t const buf = createBuffer(len);\n\n\t if (buf.length === 0) {\n\t return buf\n\t }\n\n\t obj.copy(buf, 0, 0, len);\n\t return buf\n\t }\n\n\t if (obj.length !== undefined) {\n\t if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n\t return createBuffer(0)\n\t }\n\t return fromArrayLike(obj)\n\t }\n\n\t if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n\t return fromArrayLike(obj.data)\n\t }\n\t}\n\n\tfunction checked (length) {\n\t // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n\t // length is NaN (which is otherwise coerced to zero.)\n\t if (length >= K_MAX_LENGTH) {\n\t throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n\t 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n\t }\n\t return length | 0\n\t}\n\n\tfunction SlowBuffer (length) {\n\t if (+length != length) { // eslint-disable-line eqeqeq\n\t length = 0;\n\t }\n\t return Buffer.alloc(+length)\n\t}\n\n\tBuffer.isBuffer = function isBuffer (b) {\n\t return b != null && b._isBuffer === true &&\n\t b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n\t};\n\n\tBuffer.compare = function compare (a, b) {\n\t if (isInstance(a, GlobalUint8Array)) a = Buffer.from(a, a.offset, a.byteLength);\n\t if (isInstance(b, GlobalUint8Array)) b = Buffer.from(b, b.offset, b.byteLength);\n\t if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n\t throw new TypeError(\n\t 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n\t )\n\t }\n\n\t if (a === b) return 0\n\n\t let x = a.length;\n\t let y = b.length;\n\n\t for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n\t if (a[i] !== b[i]) {\n\t x = a[i];\n\t y = b[i];\n\t break\n\t }\n\t }\n\n\t if (x < y) return -1\n\t if (y < x) return 1\n\t return 0\n\t};\n\n\tBuffer.isEncoding = function isEncoding (encoding) {\n\t switch (String(encoding).toLowerCase()) {\n\t case 'hex':\n\t case 'utf8':\n\t case 'utf-8':\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t case 'base64':\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return true\n\t default:\n\t return false\n\t }\n\t};\n\n\tBuffer.concat = function concat (list, length) {\n\t if (!Array.isArray(list)) {\n\t throw new TypeError('\"list\" argument must be an Array of Buffers')\n\t }\n\n\t if (list.length === 0) {\n\t return Buffer.alloc(0)\n\t }\n\n\t let i;\n\t if (length === undefined) {\n\t length = 0;\n\t for (i = 0; i < list.length; ++i) {\n\t length += list[i].length;\n\t }\n\t }\n\n\t const buffer = Buffer.allocUnsafe(length);\n\t let pos = 0;\n\t for (i = 0; i < list.length; ++i) {\n\t let buf = list[i];\n\t if (isInstance(buf, GlobalUint8Array)) {\n\t if (pos + buf.length > buffer.length) {\n\t if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf);\n\t buf.copy(buffer, pos);\n\t } else {\n\t GlobalUint8Array.prototype.set.call(\n\t buffer,\n\t buf,\n\t pos\n\t );\n\t }\n\t } else if (!Buffer.isBuffer(buf)) {\n\t throw new TypeError('\"list\" argument must be an Array of Buffers')\n\t } else {\n\t buf.copy(buffer, pos);\n\t }\n\t pos += buf.length;\n\t }\n\t return buffer\n\t};\n\n\tfunction byteLength (string, encoding) {\n\t if (Buffer.isBuffer(string)) {\n\t return string.length\n\t }\n\t if (GlobalArrayBuffer.isView(string) || isInstance(string, GlobalArrayBuffer)) {\n\t return string.byteLength\n\t }\n\t if (typeof string !== 'string') {\n\t throw new TypeError(\n\t 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n\t 'Received type ' + typeof string\n\t )\n\t }\n\n\t const len = string.length;\n\t const mustMatch = (arguments.length > 2 && arguments[2] === true);\n\t if (!mustMatch && len === 0) return 0\n\n\t // Use a for loop to avoid recursion\n\t let loweredCase = false;\n\t for (;;) {\n\t switch (encoding) {\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t return len\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8ToBytes(string).length\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return len * 2\n\t case 'hex':\n\t return len >>> 1\n\t case 'base64':\n\t return base64ToBytes(string).length\n\t default:\n\t if (loweredCase) {\n\t return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n\t }\n\t encoding = ('' + encoding).toLowerCase();\n\t loweredCase = true;\n\t }\n\t }\n\t}\n\tBuffer.byteLength = byteLength;\n\n\tfunction slowToString (encoding, start, end) {\n\t let loweredCase = false;\n\n\t // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n\t // property of a typed array.\n\n\t // This behaves neither like String nor Uint8Array in that we set start/end\n\t // to their upper/lower bounds if the value passed is out of range.\n\t // undefined is handled specially as per ECMA-262 6th Edition,\n\t // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n\t if (start === undefined || start < 0) {\n\t start = 0;\n\t }\n\t // Return early if start > this.length. Done here to prevent potential uint32\n\t // coercion fail below.\n\t if (start > this.length) {\n\t return ''\n\t }\n\n\t if (end === undefined || end > this.length) {\n\t end = this.length;\n\t }\n\n\t if (end <= 0) {\n\t return ''\n\t }\n\n\t // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n\t end >>>= 0;\n\t start >>>= 0;\n\n\t if (end <= start) {\n\t return ''\n\t }\n\n\t if (!encoding) encoding = 'utf8';\n\n\t while (true) {\n\t switch (encoding) {\n\t case 'hex':\n\t return hexSlice(this, start, end)\n\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8Slice(this, start, end)\n\n\t case 'ascii':\n\t return asciiSlice(this, start, end)\n\n\t case 'latin1':\n\t case 'binary':\n\t return latin1Slice(this, start, end)\n\n\t case 'base64':\n\t return base64Slice(this, start, end)\n\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return utf16leSlice(this, start, end)\n\n\t default:\n\t if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n\t encoding = (encoding + '').toLowerCase();\n\t loweredCase = true;\n\t }\n\t }\n\t}\n\n\t// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n\t// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n\t// reliably in a browserify context because there could be multiple different\n\t// copies of the 'buffer' package in use. This method works even for Buffer\n\t// instances that were created from another copy of the `buffer` package.\n\t// See: https://github.com/feross/buffer/issues/154\n\tBuffer.prototype._isBuffer = true;\n\n\tfunction swap (b, n, m) {\n\t const i = b[n];\n\t b[n] = b[m];\n\t b[m] = i;\n\t}\n\n\tBuffer.prototype.swap16 = function swap16 () {\n\t const len = this.length;\n\t if (len % 2 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 16-bits')\n\t }\n\t for (let i = 0; i < len; i += 2) {\n\t swap(this, i, i + 1);\n\t }\n\t return this\n\t};\n\n\tBuffer.prototype.swap32 = function swap32 () {\n\t const len = this.length;\n\t if (len % 4 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 32-bits')\n\t }\n\t for (let i = 0; i < len; i += 4) {\n\t swap(this, i, i + 3);\n\t swap(this, i + 1, i + 2);\n\t }\n\t return this\n\t};\n\n\tBuffer.prototype.swap64 = function swap64 () {\n\t const len = this.length;\n\t if (len % 8 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 64-bits')\n\t }\n\t for (let i = 0; i < len; i += 8) {\n\t swap(this, i, i + 7);\n\t swap(this, i + 1, i + 6);\n\t swap(this, i + 2, i + 5);\n\t swap(this, i + 3, i + 4);\n\t }\n\t return this\n\t};\n\n\tBuffer.prototype.toString = function toString () {\n\t const length = this.length;\n\t if (length === 0) return ''\n\t if (arguments.length === 0) return utf8Slice(this, 0, length)\n\t return slowToString.apply(this, arguments)\n\t};\n\n\tBuffer.prototype.toLocaleString = Buffer.prototype.toString;\n\n\tBuffer.prototype.equals = function equals (b) {\n\t if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n\t if (this === b) return true\n\t return Buffer.compare(this, b) === 0\n\t};\n\n\tBuffer.prototype.inspect = function inspect () {\n\t let str = '';\n\t const max = exports.INSPECT_MAX_BYTES;\n\t str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim();\n\t if (this.length > max) str += ' ... ';\n\t return ''\n\t};\n\tif (customInspectSymbol) {\n\t Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect;\n\t}\n\n\tBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n\t if (isInstance(target, GlobalUint8Array)) {\n\t target = Buffer.from(target, target.offset, target.byteLength);\n\t }\n\t if (!Buffer.isBuffer(target)) {\n\t throw new TypeError(\n\t 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n\t 'Received type ' + (typeof target)\n\t )\n\t }\n\n\t if (start === undefined) {\n\t start = 0;\n\t }\n\t if (end === undefined) {\n\t end = target ? target.length : 0;\n\t }\n\t if (thisStart === undefined) {\n\t thisStart = 0;\n\t }\n\t if (thisEnd === undefined) {\n\t thisEnd = this.length;\n\t }\n\n\t if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n\t throw new RangeError('out of range index')\n\t }\n\n\t if (thisStart >= thisEnd && start >= end) {\n\t return 0\n\t }\n\t if (thisStart >= thisEnd) {\n\t return -1\n\t }\n\t if (start >= end) {\n\t return 1\n\t }\n\n\t start >>>= 0;\n\t end >>>= 0;\n\t thisStart >>>= 0;\n\t thisEnd >>>= 0;\n\n\t if (this === target) return 0\n\n\t let x = thisEnd - thisStart;\n\t let y = end - start;\n\t const len = Math.min(x, y);\n\n\t const thisCopy = this.slice(thisStart, thisEnd);\n\t const targetCopy = target.slice(start, end);\n\n\t for (let i = 0; i < len; ++i) {\n\t if (thisCopy[i] !== targetCopy[i]) {\n\t x = thisCopy[i];\n\t y = targetCopy[i];\n\t break\n\t }\n\t }\n\n\t if (x < y) return -1\n\t if (y < x) return 1\n\t return 0\n\t};\n\n\t// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n\t// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n\t//\n\t// Arguments:\n\t// - buffer - a Buffer to search\n\t// - val - a string, Buffer, or number\n\t// - byteOffset - an index into `buffer`; will be clamped to an int32\n\t// - encoding - an optional encoding, relevant is val is a string\n\t// - dir - true for indexOf, false for lastIndexOf\n\tfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n\t // Empty buffer means no match\n\t if (buffer.length === 0) return -1\n\n\t // Normalize byteOffset\n\t if (typeof byteOffset === 'string') {\n\t encoding = byteOffset;\n\t byteOffset = 0;\n\t } else if (byteOffset > 0x7fffffff) {\n\t byteOffset = 0x7fffffff;\n\t } else if (byteOffset < -0x80000000) {\n\t byteOffset = -0x80000000;\n\t }\n\t byteOffset = +byteOffset; // Coerce to Number.\n\t if (numberIsNaN(byteOffset)) {\n\t // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n\t byteOffset = dir ? 0 : (buffer.length - 1);\n\t }\n\n\t // Normalize byteOffset: negative offsets start from the end of the buffer\n\t if (byteOffset < 0) byteOffset = buffer.length + byteOffset;\n\t if (byteOffset >= buffer.length) {\n\t if (dir) return -1\n\t else byteOffset = buffer.length - 1;\n\t } else if (byteOffset < 0) {\n\t if (dir) byteOffset = 0;\n\t else return -1\n\t }\n\n\t // Normalize val\n\t if (typeof val === 'string') {\n\t val = Buffer.from(val, encoding);\n\t }\n\n\t // Finally, search either indexOf (if dir is true) or lastIndexOf\n\t if (Buffer.isBuffer(val)) {\n\t // Special case: looking for empty string/buffer always fails\n\t if (val.length === 0) {\n\t return -1\n\t }\n\t return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n\t } else if (typeof val === 'number') {\n\t val = val & 0xFF; // Search for a byte value [0-255]\n\t if (typeof GlobalUint8Array.prototype.indexOf === 'function') {\n\t if (dir) {\n\t return GlobalUint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n\t } else {\n\t return GlobalUint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n\t }\n\t }\n\t return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n\t }\n\n\t throw new TypeError('val must be string, number or Buffer')\n\t}\n\n\tfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n\t let indexSize = 1;\n\t let arrLength = arr.length;\n\t let valLength = val.length;\n\n\t if (encoding !== undefined) {\n\t encoding = String(encoding).toLowerCase();\n\t if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n\t encoding === 'utf16le' || encoding === 'utf-16le') {\n\t if (arr.length < 2 || val.length < 2) {\n\t return -1\n\t }\n\t indexSize = 2;\n\t arrLength /= 2;\n\t valLength /= 2;\n\t byteOffset /= 2;\n\t }\n\t }\n\n\t function read (buf, i) {\n\t if (indexSize === 1) {\n\t return buf[i]\n\t } else {\n\t return buf.readUInt16BE(i * indexSize)\n\t }\n\t }\n\n\t let i;\n\t if (dir) {\n\t let foundIndex = -1;\n\t for (i = byteOffset; i < arrLength; i++) {\n\t if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n\t if (foundIndex === -1) foundIndex = i;\n\t if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n\t } else {\n\t if (foundIndex !== -1) i -= i - foundIndex;\n\t foundIndex = -1;\n\t }\n\t }\n\t } else {\n\t if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength;\n\t for (i = byteOffset; i >= 0; i--) {\n\t let found = true;\n\t for (let j = 0; j < valLength; j++) {\n\t if (read(arr, i + j) !== read(val, j)) {\n\t found = false;\n\t break\n\t }\n\t }\n\t if (found) return i\n\t }\n\t }\n\n\t return -1\n\t}\n\n\tBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n\t return this.indexOf(val, byteOffset, encoding) !== -1\n\t};\n\n\tBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n\t return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n\t};\n\n\tBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n\t return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n\t};\n\n\tfunction hexWrite (buf, string, offset, length) {\n\t offset = Number(offset) || 0;\n\t const remaining = buf.length - offset;\n\t if (!length) {\n\t length = remaining;\n\t } else {\n\t length = Number(length);\n\t if (length > remaining) {\n\t length = remaining;\n\t }\n\t }\n\n\t const strLen = string.length;\n\n\t if (length > strLen / 2) {\n\t length = strLen / 2;\n\t }\n\t let i;\n\t for (i = 0; i < length; ++i) {\n\t const parsed = parseInt(string.substr(i * 2, 2), 16);\n\t if (numberIsNaN(parsed)) return i\n\t buf[offset + i] = parsed;\n\t }\n\t return i\n\t}\n\n\tfunction utf8Write (buf, string, offset, length) {\n\t return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n\t}\n\n\tfunction asciiWrite (buf, string, offset, length) {\n\t return blitBuffer(asciiToBytes(string), buf, offset, length)\n\t}\n\n\tfunction base64Write (buf, string, offset, length) {\n\t return blitBuffer(base64ToBytes(string), buf, offset, length)\n\t}\n\n\tfunction ucs2Write (buf, string, offset, length) {\n\t return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n\t}\n\n\tBuffer.prototype.write = function write (string, offset, length, encoding) {\n\t // Buffer#write(string)\n\t if (offset === undefined) {\n\t encoding = 'utf8';\n\t length = this.length;\n\t offset = 0;\n\t // Buffer#write(string, encoding)\n\t } else if (length === undefined && typeof offset === 'string') {\n\t encoding = offset;\n\t length = this.length;\n\t offset = 0;\n\t // Buffer#write(string, offset[, length][, encoding])\n\t } else if (isFinite(offset)) {\n\t offset = offset >>> 0;\n\t if (isFinite(length)) {\n\t length = length >>> 0;\n\t if (encoding === undefined) encoding = 'utf8';\n\t } else {\n\t encoding = length;\n\t length = undefined;\n\t }\n\t } else {\n\t throw new Error(\n\t 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n\t )\n\t }\n\n\t const remaining = this.length - offset;\n\t if (length === undefined || length > remaining) length = remaining;\n\n\t if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n\t throw new RangeError('Attempt to write outside buffer bounds')\n\t }\n\n\t if (!encoding) encoding = 'utf8';\n\n\t let loweredCase = false;\n\t for (;;) {\n\t switch (encoding) {\n\t case 'hex':\n\t return hexWrite(this, string, offset, length)\n\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8Write(this, string, offset, length)\n\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t return asciiWrite(this, string, offset, length)\n\n\t case 'base64':\n\t // Warning: maxLength not taken into account in base64Write\n\t return base64Write(this, string, offset, length)\n\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return ucs2Write(this, string, offset, length)\n\n\t default:\n\t if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n\t encoding = ('' + encoding).toLowerCase();\n\t loweredCase = true;\n\t }\n\t }\n\t};\n\n\tBuffer.prototype.toJSON = function toJSON () {\n\t return {\n\t type: 'Buffer',\n\t data: Array.prototype.slice.call(this._arr || this, 0)\n\t }\n\t};\n\n\tfunction base64Slice (buf, start, end) {\n\t if (start === 0 && end === buf.length) {\n\t return base64.fromByteArray(buf)\n\t } else {\n\t return base64.fromByteArray(buf.slice(start, end))\n\t }\n\t}\n\n\tfunction utf8Slice (buf, start, end) {\n\t end = Math.min(buf.length, end);\n\t const res = [];\n\n\t let i = start;\n\t while (i < end) {\n\t const firstByte = buf[i];\n\t let codePoint = null;\n\t let bytesPerSequence = (firstByte > 0xEF)\n\t ? 4\n\t : (firstByte > 0xDF)\n\t ? 3\n\t : (firstByte > 0xBF)\n\t ? 2\n\t : 1;\n\n\t if (i + bytesPerSequence <= end) {\n\t let secondByte, thirdByte, fourthByte, tempCodePoint;\n\n\t switch (bytesPerSequence) {\n\t case 1:\n\t if (firstByte < 0x80) {\n\t codePoint = firstByte;\n\t }\n\t break\n\t case 2:\n\t secondByte = buf[i + 1];\n\t if ((secondByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F);\n\t if (tempCodePoint > 0x7F) {\n\t codePoint = tempCodePoint;\n\t }\n\t }\n\t break\n\t case 3:\n\t secondByte = buf[i + 1];\n\t thirdByte = buf[i + 2];\n\t if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F);\n\t if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n\t codePoint = tempCodePoint;\n\t }\n\t }\n\t break\n\t case 4:\n\t secondByte = buf[i + 1];\n\t thirdByte = buf[i + 2];\n\t fourthByte = buf[i + 3];\n\t if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F);\n\t if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n\t codePoint = tempCodePoint;\n\t }\n\t }\n\t }\n\t }\n\n\t if (codePoint === null) {\n\t // we did not generate a valid codePoint so insert a\n\t // replacement char (U+FFFD) and advance only 1 byte\n\t codePoint = 0xFFFD;\n\t bytesPerSequence = 1;\n\t } else if (codePoint > 0xFFFF) {\n\t // encode to utf16 (surrogate pair dance)\n\t codePoint -= 0x10000;\n\t res.push(codePoint >>> 10 & 0x3FF | 0xD800);\n\t codePoint = 0xDC00 | codePoint & 0x3FF;\n\t }\n\n\t res.push(codePoint);\n\t i += bytesPerSequence;\n\t }\n\n\t return decodeCodePointsArray(res)\n\t}\n\n\t// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n\t// the lowest limit is Chrome, with 0x10000 args.\n\t// We go 1 magnitude less, for safety\n\tconst MAX_ARGUMENTS_LENGTH = 0x1000;\n\n\tfunction decodeCodePointsArray (codePoints) {\n\t const len = codePoints.length;\n\t if (len <= MAX_ARGUMENTS_LENGTH) {\n\t return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n\t }\n\n\t // Decode in chunks to avoid \"call stack size exceeded\".\n\t let res = '';\n\t let i = 0;\n\t while (i < len) {\n\t res += String.fromCharCode.apply(\n\t String,\n\t codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n\t );\n\t }\n\t return res\n\t}\n\n\tfunction asciiSlice (buf, start, end) {\n\t let ret = '';\n\t end = Math.min(buf.length, end);\n\n\t for (let i = start; i < end; ++i) {\n\t ret += String.fromCharCode(buf[i] & 0x7F);\n\t }\n\t return ret\n\t}\n\n\tfunction latin1Slice (buf, start, end) {\n\t let ret = '';\n\t end = Math.min(buf.length, end);\n\n\t for (let i = start; i < end; ++i) {\n\t ret += String.fromCharCode(buf[i]);\n\t }\n\t return ret\n\t}\n\n\tfunction hexSlice (buf, start, end) {\n\t const len = buf.length;\n\n\t if (!start || start < 0) start = 0;\n\t if (!end || end < 0 || end > len) end = len;\n\n\t let out = '';\n\t for (let i = start; i < end; ++i) {\n\t out += hexSliceLookupTable[buf[i]];\n\t }\n\t return out\n\t}\n\n\tfunction utf16leSlice (buf, start, end) {\n\t const bytes = buf.slice(start, end);\n\t let res = '';\n\t // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n\t for (let i = 0; i < bytes.length - 1; i += 2) {\n\t res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256));\n\t }\n\t return res\n\t}\n\n\tBuffer.prototype.slice = function slice (start, end) {\n\t const len = this.length;\n\t start = ~~start;\n\t end = end === undefined ? len : ~~end;\n\n\t if (start < 0) {\n\t start += len;\n\t if (start < 0) start = 0;\n\t } else if (start > len) {\n\t start = len;\n\t }\n\n\t if (end < 0) {\n\t end += len;\n\t if (end < 0) end = 0;\n\t } else if (end > len) {\n\t end = len;\n\t }\n\n\t if (end < start) end = start;\n\n\t const newBuf = this.subarray(start, end);\n\t // Return an augmented `Uint8Array` instance\n\t Object.setPrototypeOf(newBuf, Buffer.prototype);\n\n\t return newBuf\n\t};\n\n\t/*\n\t * Need to make sure that buffer isn't trying to write out of bounds.\n\t */\n\tfunction checkOffset (offset, ext, length) {\n\t if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n\t if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n\t}\n\n\tBuffer.prototype.readUintLE =\n\tBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) checkOffset(offset, byteLength, this.length);\n\n\t let val = this[offset];\n\t let mul = 1;\n\t let i = 0;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t val += this[offset + i] * mul;\n\t }\n\n\t return val\n\t};\n\n\tBuffer.prototype.readUintBE =\n\tBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) {\n\t checkOffset(offset, byteLength, this.length);\n\t }\n\n\t let val = this[offset + --byteLength];\n\t let mul = 1;\n\t while (byteLength > 0 && (mul *= 0x100)) {\n\t val += this[offset + --byteLength] * mul;\n\t }\n\n\t return val\n\t};\n\n\tBuffer.prototype.readUint8 =\n\tBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 1, this.length);\n\t return this[offset]\n\t};\n\n\tBuffer.prototype.readUint16LE =\n\tBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t return this[offset] | (this[offset + 1] << 8)\n\t};\n\n\tBuffer.prototype.readUint16BE =\n\tBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t return (this[offset] << 8) | this[offset + 1]\n\t};\n\n\tBuffer.prototype.readUint32LE =\n\tBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return ((this[offset]) |\n\t (this[offset + 1] << 8) |\n\t (this[offset + 2] << 16)) +\n\t (this[offset + 3] * 0x1000000)\n\t};\n\n\tBuffer.prototype.readUint32BE =\n\tBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return (this[offset] * 0x1000000) +\n\t ((this[offset + 1] << 16) |\n\t (this[offset + 2] << 8) |\n\t this[offset + 3])\n\t};\n\n\tBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const lo = first +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 24;\n\n\t const hi = this[++offset] +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset] * 2 ** 16 +\n\t last * 2 ** 24;\n\n\t return BigInt(lo) + (BigInt(hi) << BigInt(32))\n\t});\n\n\tBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const hi = first * 2 ** 24 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset];\n\n\t const lo = this[++offset] * 2 ** 24 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t last;\n\n\t return (BigInt(hi) << BigInt(32)) + BigInt(lo)\n\t});\n\n\tBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) checkOffset(offset, byteLength, this.length);\n\n\t let val = this[offset];\n\t let mul = 1;\n\t let i = 0;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t val += this[offset + i] * mul;\n\t }\n\t mul *= 0x80;\n\n\t if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n\n\t return val\n\t};\n\n\tBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) checkOffset(offset, byteLength, this.length);\n\n\t let i = byteLength;\n\t let mul = 1;\n\t let val = this[offset + --i];\n\t while (i > 0 && (mul *= 0x100)) {\n\t val += this[offset + --i] * mul;\n\t }\n\t mul *= 0x80;\n\n\t if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n\n\t return val\n\t};\n\n\tBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 1, this.length);\n\t if (!(this[offset] & 0x80)) return (this[offset])\n\t return ((0xff - this[offset] + 1) * -1)\n\t};\n\n\tBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t const val = this[offset] | (this[offset + 1] << 8);\n\t return (val & 0x8000) ? val | 0xFFFF0000 : val\n\t};\n\n\tBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 2, this.length);\n\t const val = this[offset + 1] | (this[offset] << 8);\n\t return (val & 0x8000) ? val | 0xFFFF0000 : val\n\t};\n\n\tBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return (this[offset]) |\n\t (this[offset + 1] << 8) |\n\t (this[offset + 2] << 16) |\n\t (this[offset + 3] << 24)\n\t};\n\n\tBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\n\t return (this[offset] << 24) |\n\t (this[offset + 1] << 16) |\n\t (this[offset + 2] << 8) |\n\t (this[offset + 3])\n\t};\n\n\tBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const val = this[offset + 4] +\n\t this[offset + 5] * 2 ** 8 +\n\t this[offset + 6] * 2 ** 16 +\n\t (last << 24); // Overflow\n\n\t return (BigInt(val) << BigInt(32)) +\n\t BigInt(first +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 24)\n\t});\n\n\tBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE (offset) {\n\t offset = offset >>> 0;\n\t validateNumber(offset, 'offset');\n\t const first = this[offset];\n\t const last = this[offset + 7];\n\t if (first === undefined || last === undefined) {\n\t boundsError(offset, this.length - 8);\n\t }\n\n\t const val = (first << 24) + // Overflow\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t this[++offset];\n\n\t return (BigInt(val) << BigInt(32)) +\n\t BigInt(this[++offset] * 2 ** 24 +\n\t this[++offset] * 2 ** 16 +\n\t this[++offset] * 2 ** 8 +\n\t last)\n\t});\n\n\tBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\t return ieee754$1.read(this, offset, true, 23, 4)\n\t};\n\n\tBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 4, this.length);\n\t return ieee754$1.read(this, offset, false, 23, 4)\n\t};\n\n\tBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 8, this.length);\n\t return ieee754$1.read(this, offset, true, 52, 8)\n\t};\n\n\tBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n\t offset = offset >>> 0;\n\t if (!noAssert) checkOffset(offset, 8, this.length);\n\t return ieee754$1.read(this, offset, false, 52, 8)\n\t};\n\n\tfunction checkInt (buf, value, offset, ext, max, min) {\n\t if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n\t if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n\t if (offset + ext > buf.length) throw new RangeError('Index out of range')\n\t}\n\n\tBuffer.prototype.writeUintLE =\n\tBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) {\n\t const maxBytes = Math.pow(2, 8 * byteLength) - 1;\n\t checkInt(this, value, offset, byteLength, maxBytes, 0);\n\t }\n\n\t let mul = 1;\n\t let i = 0;\n\t this[offset] = value & 0xFF;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t this[offset + i] = (value / mul) & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeUintBE =\n\tBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t byteLength = byteLength >>> 0;\n\t if (!noAssert) {\n\t const maxBytes = Math.pow(2, 8 * byteLength) - 1;\n\t checkInt(this, value, offset, byteLength, maxBytes, 0);\n\t }\n\n\t let i = byteLength - 1;\n\t let mul = 1;\n\t this[offset + i] = value & 0xFF;\n\t while (--i >= 0 && (mul *= 0x100)) {\n\t this[offset + i] = (value / mul) & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeUint8 =\n\tBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0);\n\t this[offset] = (value & 0xff);\n\t return offset + 1\n\t};\n\n\tBuffer.prototype.writeUint16LE =\n\tBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n\t this[offset] = (value & 0xff);\n\t this[offset + 1] = (value >>> 8);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeUint16BE =\n\tBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n\t this[offset] = (value >>> 8);\n\t this[offset + 1] = (value & 0xff);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeUint32LE =\n\tBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n\t this[offset + 3] = (value >>> 24);\n\t this[offset + 2] = (value >>> 16);\n\t this[offset + 1] = (value >>> 8);\n\t this[offset] = (value & 0xff);\n\t return offset + 4\n\t};\n\n\tBuffer.prototype.writeUint32BE =\n\tBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n\t this[offset] = (value >>> 24);\n\t this[offset + 1] = (value >>> 16);\n\t this[offset + 2] = (value >>> 8);\n\t this[offset + 3] = (value & 0xff);\n\t return offset + 4\n\t};\n\n\tfunction wrtBigUInt64LE (buf, value, offset, min, max) {\n\t checkIntBI(value, min, max, buf, offset, 7);\n\n\t let lo = Number(value & BigInt(0xffffffff));\n\t buf[offset++] = lo;\n\t lo = lo >> 8;\n\t buf[offset++] = lo;\n\t lo = lo >> 8;\n\t buf[offset++] = lo;\n\t lo = lo >> 8;\n\t buf[offset++] = lo;\n\t let hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n\t buf[offset++] = hi;\n\t hi = hi >> 8;\n\t buf[offset++] = hi;\n\t hi = hi >> 8;\n\t buf[offset++] = hi;\n\t hi = hi >> 8;\n\t buf[offset++] = hi;\n\t return offset\n\t}\n\n\tfunction wrtBigUInt64BE (buf, value, offset, min, max) {\n\t checkIntBI(value, min, max, buf, offset, 7);\n\n\t let lo = Number(value & BigInt(0xffffffff));\n\t buf[offset + 7] = lo;\n\t lo = lo >> 8;\n\t buf[offset + 6] = lo;\n\t lo = lo >> 8;\n\t buf[offset + 5] = lo;\n\t lo = lo >> 8;\n\t buf[offset + 4] = lo;\n\t let hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n\t buf[offset + 3] = hi;\n\t hi = hi >> 8;\n\t buf[offset + 2] = hi;\n\t hi = hi >> 8;\n\t buf[offset + 1] = hi;\n\t hi = hi >> 8;\n\t buf[offset] = hi;\n\t return offset + 8\n\t}\n\n\tBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE (value, offset = 0) {\n\t return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n\t});\n\n\tBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE (value, offset = 0) {\n\t return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n\t});\n\n\tBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t const limit = Math.pow(2, (8 * byteLength) - 1);\n\n\t checkInt(this, value, offset, byteLength, limit - 1, -limit);\n\t }\n\n\t let i = 0;\n\t let mul = 1;\n\t let sub = 0;\n\t this[offset] = value & 0xFF;\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n\t sub = 1;\n\t }\n\t this[offset + i] = ((value / mul) >> 0) - sub & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t const limit = Math.pow(2, (8 * byteLength) - 1);\n\n\t checkInt(this, value, offset, byteLength, limit - 1, -limit);\n\t }\n\n\t let i = byteLength - 1;\n\t let mul = 1;\n\t let sub = 0;\n\t this[offset + i] = value & 0xFF;\n\t while (--i >= 0 && (mul *= 0x100)) {\n\t if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n\t sub = 1;\n\t }\n\t this[offset + i] = ((value / mul) >> 0) - sub & 0xFF;\n\t }\n\n\t return offset + byteLength\n\t};\n\n\tBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80);\n\t if (value < 0) value = 0xff + value + 1;\n\t this[offset] = (value & 0xff);\n\t return offset + 1\n\t};\n\n\tBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n\t this[offset] = (value & 0xff);\n\t this[offset + 1] = (value >>> 8);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n\t this[offset] = (value >>> 8);\n\t this[offset + 1] = (value & 0xff);\n\t return offset + 2\n\t};\n\n\tBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n\t this[offset] = (value & 0xff);\n\t this[offset + 1] = (value >>> 8);\n\t this[offset + 2] = (value >>> 16);\n\t this[offset + 3] = (value >>> 24);\n\t return offset + 4\n\t};\n\n\tBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n\t if (value < 0) value = 0xffffffff + value + 1;\n\t this[offset] = (value >>> 24);\n\t this[offset + 1] = (value >>> 16);\n\t this[offset + 2] = (value >>> 8);\n\t this[offset + 3] = (value & 0xff);\n\t return offset + 4\n\t};\n\n\tBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE (value, offset = 0) {\n\t return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n\t});\n\n\tBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE (value, offset = 0) {\n\t return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n\t});\n\n\tfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n\t if (offset + ext > buf.length) throw new RangeError('Index out of range')\n\t if (offset < 0) throw new RangeError('Index out of range')\n\t}\n\n\tfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t checkIEEE754(buf, value, offset, 4);\n\t }\n\t ieee754$1.write(buf, value, offset, littleEndian, 23, 4);\n\t return offset + 4\n\t}\n\n\tBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n\t return writeFloat(this, value, offset, true, noAssert)\n\t};\n\n\tBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n\t return writeFloat(this, value, offset, false, noAssert)\n\t};\n\n\tfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n\t value = +value;\n\t offset = offset >>> 0;\n\t if (!noAssert) {\n\t checkIEEE754(buf, value, offset, 8);\n\t }\n\t ieee754$1.write(buf, value, offset, littleEndian, 52, 8);\n\t return offset + 8\n\t}\n\n\tBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n\t return writeDouble(this, value, offset, true, noAssert)\n\t};\n\n\tBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n\t return writeDouble(this, value, offset, false, noAssert)\n\t};\n\n\t// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\n\tBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n\t if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n\t if (!start) start = 0;\n\t if (!end && end !== 0) end = this.length;\n\t if (targetStart >= target.length) targetStart = target.length;\n\t if (!targetStart) targetStart = 0;\n\t if (end > 0 && end < start) end = start;\n\n\t // Copy 0 bytes; we're done\n\t if (end === start) return 0\n\t if (target.length === 0 || this.length === 0) return 0\n\n\t // Fatal error conditions\n\t if (targetStart < 0) {\n\t throw new RangeError('targetStart out of bounds')\n\t }\n\t if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n\t if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n\t // Are we oob?\n\t if (end > this.length) end = this.length;\n\t if (target.length - targetStart < end - start) {\n\t end = target.length - targetStart + start;\n\t }\n\n\t const len = end - start;\n\n\t if (this === target && typeof GlobalUint8Array.prototype.copyWithin === 'function') {\n\t // Use built-in when available, missing from IE11\n\t this.copyWithin(targetStart, start, end);\n\t } else {\n\t GlobalUint8Array.prototype.set.call(\n\t target,\n\t this.subarray(start, end),\n\t targetStart\n\t );\n\t }\n\n\t return len\n\t};\n\n\t// Usage:\n\t// buffer.fill(number[, offset[, end]])\n\t// buffer.fill(buffer[, offset[, end]])\n\t// buffer.fill(string[, offset[, end]][, encoding])\n\tBuffer.prototype.fill = function fill (val, start, end, encoding) {\n\t // Handle string cases:\n\t if (typeof val === 'string') {\n\t if (typeof start === 'string') {\n\t encoding = start;\n\t start = 0;\n\t end = this.length;\n\t } else if (typeof end === 'string') {\n\t encoding = end;\n\t end = this.length;\n\t }\n\t if (encoding !== undefined && typeof encoding !== 'string') {\n\t throw new TypeError('encoding must be a string')\n\t }\n\t if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n\t throw new TypeError('Unknown encoding: ' + encoding)\n\t }\n\t if (val.length === 1) {\n\t const code = val.charCodeAt(0);\n\t if ((encoding === 'utf8' && code < 128) ||\n\t encoding === 'latin1') {\n\t // Fast path: If `val` fits into a single byte, use that numeric value.\n\t val = code;\n\t }\n\t }\n\t } else if (typeof val === 'number') {\n\t val = val & 255;\n\t } else if (typeof val === 'boolean') {\n\t val = Number(val);\n\t }\n\n\t // Invalid ranges are not set to a default, so can range check early.\n\t if (start < 0 || this.length < start || this.length < end) {\n\t throw new RangeError('Out of range index')\n\t }\n\n\t if (end <= start) {\n\t return this\n\t }\n\n\t start = start >>> 0;\n\t end = end === undefined ? this.length : end >>> 0;\n\n\t if (!val) val = 0;\n\n\t let i;\n\t if (typeof val === 'number') {\n\t for (i = start; i < end; ++i) {\n\t this[i] = val;\n\t }\n\t } else {\n\t const bytes = Buffer.isBuffer(val)\n\t ? val\n\t : Buffer.from(val, encoding);\n\t const len = bytes.length;\n\t if (len === 0) {\n\t throw new TypeError('The value \"' + val +\n\t '\" is invalid for argument \"value\"')\n\t }\n\t for (i = 0; i < end - start; ++i) {\n\t this[i + start] = bytes[i % len];\n\t }\n\t }\n\n\t return this\n\t};\n\n\t// CUSTOM ERRORS\n\t// =============\n\n\t// Simplified versions from Node, changed for Buffer-only usage\n\tconst errors = {};\n\tfunction E (sym, getMessage, Base) {\n\t errors[sym] = class NodeError extends Base {\n\t constructor () {\n\t super();\n\n\t Object.defineProperty(this, 'message', {\n\t value: getMessage.apply(this, arguments),\n\t writable: true,\n\t configurable: true\n\t });\n\n\t // Add the error code to the name to include it in the stack trace.\n\t this.name = `${this.name} [${sym}]`;\n\t // Access the stack to generate the error message including the error code\n\t // from the name.\n\t this.stack; // eslint-disable-line no-unused-expressions\n\t // Reset the name to the actual name.\n\t delete this.name;\n\t }\n\n\t get code () {\n\t return sym\n\t }\n\n\t set code (value) {\n\t Object.defineProperty(this, 'code', {\n\t configurable: true,\n\t enumerable: true,\n\t value,\n\t writable: true\n\t });\n\t }\n\n\t toString () {\n\t return `${this.name} [${sym}]: ${this.message}`\n\t }\n\t };\n\t}\n\n\tE('ERR_BUFFER_OUT_OF_BOUNDS',\n\t function (name) {\n\t if (name) {\n\t return `${name} is outside of buffer bounds`\n\t }\n\n\t return 'Attempt to access memory outside buffer bounds'\n\t }, RangeError);\n\tE('ERR_INVALID_ARG_TYPE',\n\t function (name, actual) {\n\t return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`\n\t }, TypeError);\n\tE('ERR_OUT_OF_RANGE',\n\t function (str, range, input) {\n\t let msg = `The value of \"${str}\" is out of range.`;\n\t let received = input;\n\t if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n\t received = addNumericalSeparator(String(input));\n\t } else if (typeof input === 'bigint') {\n\t received = String(input);\n\t if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n\t received = addNumericalSeparator(received);\n\t }\n\t received += 'n';\n\t }\n\t msg += ` It must be ${range}. Received ${received}`;\n\t return msg\n\t }, RangeError);\n\n\tfunction addNumericalSeparator (val) {\n\t let res = '';\n\t let i = val.length;\n\t const start = val[0] === '-' ? 1 : 0;\n\t for (; i >= start + 4; i -= 3) {\n\t res = `_${val.slice(i - 3, i)}${res}`;\n\t }\n\t return `${val.slice(0, i)}${res}`\n\t}\n\n\t// CHECK FUNCTIONS\n\t// ===============\n\n\tfunction checkBounds (buf, offset, byteLength) {\n\t validateNumber(offset, 'offset');\n\t if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n\t boundsError(offset, buf.length - (byteLength + 1));\n\t }\n\t}\n\n\tfunction checkIntBI (value, min, max, buf, offset, byteLength) {\n\t if (value > max || value < min) {\n\t const n = typeof min === 'bigint' ? 'n' : '';\n\t let range;\n\t if (byteLength > 3) {\n\t if (min === 0 || min === BigInt(0)) {\n\t range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`;\n\t } else {\n\t range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` +\n\t `${(byteLength + 1) * 8 - 1}${n}`;\n\t }\n\t } else {\n\t range = `>= ${min}${n} and <= ${max}${n}`;\n\t }\n\t throw new errors.ERR_OUT_OF_RANGE('value', range, value)\n\t }\n\t checkBounds(buf, offset, byteLength);\n\t}\n\n\tfunction validateNumber (value, name) {\n\t if (typeof value !== 'number') {\n\t throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value)\n\t }\n\t}\n\n\tfunction boundsError (value, length, type) {\n\t if (Math.floor(value) !== value) {\n\t validateNumber(value, type);\n\t throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value)\n\t }\n\n\t if (length < 0) {\n\t throw new errors.ERR_BUFFER_OUT_OF_BOUNDS()\n\t }\n\n\t throw new errors.ERR_OUT_OF_RANGE(type || 'offset',\n\t `>= ${type ? 1 : 0} and <= ${length}`,\n\t value)\n\t}\n\n\t// HELPER FUNCTIONS\n\t// ================\n\n\tconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g;\n\n\tfunction base64clean (str) {\n\t // Node takes equal signs as end of the Base64 encoding\n\t str = str.split('=')[0];\n\t // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n\t str = str.trim().replace(INVALID_BASE64_RE, '');\n\t // Node converts strings with length < 2 to ''\n\t if (str.length < 2) return ''\n\t // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n\t while (str.length % 4 !== 0) {\n\t str = str + '=';\n\t }\n\t return str\n\t}\n\n\tfunction utf8ToBytes (string, units) {\n\t units = units || Infinity;\n\t let codePoint;\n\t const length = string.length;\n\t let leadSurrogate = null;\n\t const bytes = [];\n\n\t for (let i = 0; i < length; ++i) {\n\t codePoint = string.charCodeAt(i);\n\n\t // is surrogate component\n\t if (codePoint > 0xD7FF && codePoint < 0xE000) {\n\t // last char was a lead\n\t if (!leadSurrogate) {\n\t // no lead yet\n\t if (codePoint > 0xDBFF) {\n\t // unexpected trail\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t continue\n\t } else if (i + 1 === length) {\n\t // unpaired lead\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t continue\n\t }\n\n\t // valid lead\n\t leadSurrogate = codePoint;\n\n\t continue\n\t }\n\n\t // 2 leads in a row\n\t if (codePoint < 0xDC00) {\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t leadSurrogate = codePoint;\n\t continue\n\t }\n\n\t // valid surrogate pair\n\t codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000;\n\t } else if (leadSurrogate) {\n\t // valid bmp char, but last char was a lead\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n\t }\n\n\t leadSurrogate = null;\n\n\t // encode utf8\n\t if (codePoint < 0x80) {\n\t if ((units -= 1) < 0) break\n\t bytes.push(codePoint);\n\t } else if (codePoint < 0x800) {\n\t if ((units -= 2) < 0) break\n\t bytes.push(\n\t codePoint >> 0x6 | 0xC0,\n\t codePoint & 0x3F | 0x80\n\t );\n\t } else if (codePoint < 0x10000) {\n\t if ((units -= 3) < 0) break\n\t bytes.push(\n\t codePoint >> 0xC | 0xE0,\n\t codePoint >> 0x6 & 0x3F | 0x80,\n\t codePoint & 0x3F | 0x80\n\t );\n\t } else if (codePoint < 0x110000) {\n\t if ((units -= 4) < 0) break\n\t bytes.push(\n\t codePoint >> 0x12 | 0xF0,\n\t codePoint >> 0xC & 0x3F | 0x80,\n\t codePoint >> 0x6 & 0x3F | 0x80,\n\t codePoint & 0x3F | 0x80\n\t );\n\t } else {\n\t throw new Error('Invalid code point')\n\t }\n\t }\n\n\t return bytes\n\t}\n\n\tfunction asciiToBytes (str) {\n\t const byteArray = [];\n\t for (let i = 0; i < str.length; ++i) {\n\t // Node's code seems to be doing this and not & 0x7F..\n\t byteArray.push(str.charCodeAt(i) & 0xFF);\n\t }\n\t return byteArray\n\t}\n\n\tfunction utf16leToBytes (str, units) {\n\t let c, hi, lo;\n\t const byteArray = [];\n\t for (let i = 0; i < str.length; ++i) {\n\t if ((units -= 2) < 0) break\n\n\t c = str.charCodeAt(i);\n\t hi = c >> 8;\n\t lo = c % 256;\n\t byteArray.push(lo);\n\t byteArray.push(hi);\n\t }\n\n\t return byteArray\n\t}\n\n\tfunction base64ToBytes (str) {\n\t return base64.toByteArray(base64clean(str))\n\t}\n\n\tfunction blitBuffer (src, dst, offset, length) {\n\t let i;\n\t for (i = 0; i < length; ++i) {\n\t if ((i + offset >= dst.length) || (i >= src.length)) break\n\t dst[i + offset] = src[i];\n\t }\n\t return i\n\t}\n\n\t// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n\t// the `instanceof` check but they should be treated as of that type.\n\t// See: https://github.com/feross/buffer/issues/166\n\tfunction isInstance (obj, type) {\n\t return obj instanceof type ||\n\t (obj != null && obj.constructor != null && obj.constructor.name != null &&\n\t obj.constructor.name === type.name)\n\t}\n\tfunction numberIsNaN (obj) {\n\t // For IE11 support\n\t return obj !== obj // eslint-disable-line no-self-compare\n\t}\n\n\t// Create lookup table for `toString('hex')`\n\t// See: https://github.com/feross/buffer/issues/219\n\tconst hexSliceLookupTable = (function () {\n\t const alphabet = '0123456789abcdef';\n\t const table = new Array(256);\n\t for (let i = 0; i < 16; ++i) {\n\t const i16 = i * 16;\n\t for (let j = 0; j < 16; ++j) {\n\t table[i16 + j] = alphabet[i] + alphabet[j];\n\t }\n\t }\n\t return table\n\t})();\n\n\t// Return not function with Error if BigInt not supported\n\tfunction defineBigIntMethod (fn) {\n\t return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn\n\t}\n\n\tfunction BufferBigIntNotDefined () {\n\t throw new Error('BigInt not supported')\n\t} \n} (buffer));\n\nconst Buffer = buffer.Buffer;\n\nexports.Blob = buffer.Blob;\nexports.BlobOptions = buffer.BlobOptions;\nexports.Buffer = buffer.Buffer;\nexports.File = buffer.File;\nexports.FileOptions = buffer.FileOptions;\nexports.INSPECT_MAX_BYTES = buffer.INSPECT_MAX_BYTES;\nexports.SlowBuffer = buffer.SlowBuffer;\nexports.TranscodeEncoding = buffer.TranscodeEncoding;\nexports.atob = buffer.atob;\nexports.btoa = buffer.btoa;\nexports.constants = buffer.constants;\nexports.default = Buffer;\nexports.isAscii = buffer.isAscii;\nexports.isUtf8 = buffer.isUtf8;\nexports.kMaxLength = buffer.kMaxLength;\nexports.kStringMaxLength = buffer.kStringMaxLength;\nexports.resolveObjectURL = buffer.resolveObjectURL;\nexports.transcode = buffer.transcode;\n//# sourceMappingURL=index.cjs.map\n","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict'\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nvar MAX_BYTES = 65536\n\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nvar MAX_UINT32 = 4294967295\n\nfunction oldBrowser () {\n throw new Error('Secure random number generation is not supported by this browser.\\nUse Chrome, Firefox or Internet Explorer 11')\n}\n\nvar Buffer = require('safe-buffer').Buffer\nvar crypto = global.crypto || global.msCrypto\n\nif (crypto && crypto.getRandomValues) {\n module.exports = randomBytes\n} else {\n module.exports = oldBrowser\n}\n\nfunction randomBytes (size, cb) {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n\n var bytes = Buffer.allocUnsafe(size)\n\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (var generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n\n if (typeof cb === 'function') {\n return process.nextTick(function () {\n cb(null, bytes)\n })\n }\n\n return bytes\n}\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","module.exports = require('events').EventEmitter;\n","'use strict';\n\n/** @type {import('./shams')} */\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\t/** @type {{ [k in symbol]?: unknown }} */\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (var _ in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\t// eslint-disable-next-line no-extra-parens\n\t\tvar descriptor = /** @type {PropertyDescriptor} */ (Object.getOwnPropertyDescriptor(obj, sym));\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Object;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Error;\n","'use strict';\n\n/** @type {import('./eval')} */\nmodule.exports = EvalError;\n","'use strict';\n\n/** @type {import('./range')} */\nmodule.exports = RangeError;\n","'use strict';\n\n/** @type {import('./ref')} */\nmodule.exports = ReferenceError;\n","'use strict';\n\n/** @type {import('./syntax')} */\nmodule.exports = SyntaxError;\n","'use strict';\n\n/** @type {import('./type')} */\nmodule.exports = TypeError;\n","'use strict';\n\n/** @type {import('./uri')} */\nmodule.exports = URIError;\n","'use strict';\n\n/** @type {import('./abs')} */\nmodule.exports = Math.abs;\n","'use strict';\n\n/** @type {import('./floor')} */\nmodule.exports = Math.floor;\n","'use strict';\n\n/** @type {import('./max')} */\nmodule.exports = Math.max;\n","'use strict';\n\n/** @type {import('./min')} */\nmodule.exports = Math.min;\n","'use strict';\n\n/** @type {import('./pow')} */\nmodule.exports = Math.pow;\n","'use strict';\n\n/** @type {import('./round')} */\nmodule.exports = Math.round;\n","'use strict';\n\n/** @type {import('./isNaN')} */\nmodule.exports = Number.isNaN || function isNaN(a) {\n\treturn a !== a;\n};\n","'use strict';\n\nvar $isNaN = require('./isNaN');\n\n/** @type {import('./sign')} */\nmodule.exports = function sign(number) {\n\tif ($isNaN(number) || number === 0) {\n\t\treturn number;\n\t}\n\treturn number < 0 ? -1 : +1;\n};\n","'use strict';\n\n/** @type {import('./gOPD')} */\nmodule.exports = Object.getOwnPropertyDescriptor;\n","'use strict';\n\n/** @type {import('.')} */\nvar $gOPD = require('./gOPD');\n\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict';\n\n/** @type {import('.')} */\nvar $defineProperty = Object.defineProperty || false;\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = false;\n\t}\n}\n\nmodule.exports = $defineProperty;\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\n/** @type {import('./Reflect.getPrototypeOf')} */\nmodule.exports = (typeof Reflect !== 'undefined' && Reflect.getPrototypeOf) || null;\n","'use strict';\n\nvar $Object = require('es-object-atoms');\n\n/** @type {import('./Object.getPrototypeOf')} */\nmodule.exports = $Object.getPrototypeOf || null;\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar toStr = Object.prototype.toString;\nvar max = Math.max;\nvar funcType = '[object Function]';\n\nvar concatty = function concatty(a, b) {\n var arr = [];\n\n for (var i = 0; i < a.length; i += 1) {\n arr[i] = a[i];\n }\n for (var j = 0; j < b.length; j += 1) {\n arr[j + a.length] = b[j];\n }\n\n return arr;\n};\n\nvar slicy = function slicy(arrLike, offset) {\n var arr = [];\n for (var i = offset || 0, j = 0; i < arrLike.length; i += 1, j += 1) {\n arr[j] = arrLike[i];\n }\n return arr;\n};\n\nvar joiny = function (arr, joiner) {\n var str = '';\n for (var i = 0; i < arr.length; i += 1) {\n str += arr[i];\n if (i + 1 < arr.length) {\n str += joiner;\n }\n }\n return str;\n};\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.apply(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slicy(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n concatty(args, arguments)\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n }\n return target.apply(\n that,\n concatty(args, arguments)\n );\n\n };\n\n var boundLength = max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs[i] = '$' + i;\n }\n\n bound = Function('binder', 'return function (' + joiny(boundArgs, ',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","'use strict';\n\n/** @type {import('./functionCall')} */\nmodule.exports = Function.prototype.call;\n","'use strict';\n\n/** @type {import('./functionApply')} */\nmodule.exports = Function.prototype.apply;\n","'use strict';\n\n/** @type {import('./reflectApply')} */\nmodule.exports = typeof Reflect !== 'undefined' && Reflect && Reflect.apply;\n","'use strict';\n\nvar bind = require('function-bind');\n\nvar $apply = require('./functionApply');\nvar $call = require('./functionCall');\nvar $reflectApply = require('./reflectApply');\n\n/** @type {import('./actualApply')} */\nmodule.exports = $reflectApply || bind.call($call, $apply);\n","'use strict';\n\nvar bind = require('function-bind');\nvar $TypeError = require('es-errors/type');\n\nvar $call = require('./functionCall');\nvar $actualApply = require('./actualApply');\n\n/** @type {(args: [Function, thisArg?: unknown, ...args: unknown[]]) => Function} TODO FIXME, find a way to use import('.') */\nmodule.exports = function callBindBasic(args) {\n\tif (args.length < 1 || typeof args[0] !== 'function') {\n\t\tthrow new $TypeError('a function is required');\n\t}\n\treturn $actualApply(bind, $call, args);\n};\n","'use strict';\n\nvar callBind = require('call-bind-apply-helpers');\nvar gOPD = require('gopd');\n\nvar hasProtoAccessor;\ntry {\n\t// eslint-disable-next-line no-extra-parens, no-proto\n\thasProtoAccessor = /** @type {{ __proto__?: typeof Array.prototype }} */ ([]).__proto__ === Array.prototype;\n} catch (e) {\n\tif (!e || typeof e !== 'object' || !('code' in e) || e.code !== 'ERR_PROTO_ACCESS') {\n\t\tthrow e;\n\t}\n}\n\n// eslint-disable-next-line no-extra-parens\nvar desc = !!hasProtoAccessor && gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));\n\nvar $Object = Object;\nvar $getPrototypeOf = $Object.getPrototypeOf;\n\n/** @type {import('./get')} */\nmodule.exports = desc && typeof desc.get === 'function'\n\t? callBind([desc.get])\n\t: typeof $getPrototypeOf === 'function'\n\t\t? /** @type {import('./get')} */ function getDunder(value) {\n\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\treturn $getPrototypeOf(value == null ? value : $Object(value));\n\t\t}\n\t\t: false;\n","'use strict';\n\nvar reflectGetProto = require('./Reflect.getPrototypeOf');\nvar originalGetProto = require('./Object.getPrototypeOf');\n\nvar getDunderProto = require('dunder-proto/get');\n\n/** @type {import('.')} */\nmodule.exports = reflectGetProto\n\t? function getProto(O) {\n\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\treturn reflectGetProto(O);\n\t}\n\t: originalGetProto\n\t\t? function getProto(O) {\n\t\t\tif (!O || (typeof O !== 'object' && typeof O !== 'function')) {\n\t\t\t\tthrow new TypeError('getProto: not an object');\n\t\t\t}\n\t\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\t\treturn originalGetProto(O);\n\t\t}\n\t\t: getDunderProto\n\t\t\t? function getProto(O) {\n\t\t\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\t\t\treturn getDunderProto(O);\n\t\t\t}\n\t\t\t: null;\n","'use strict';\n\nvar call = Function.prototype.call;\nvar $hasOwn = Object.prototype.hasOwnProperty;\nvar bind = require('function-bind');\n\n/** @type {import('.')} */\nmodule.exports = bind.call(call, $hasOwn);\n","'use strict';\n\nvar undefined;\n\nvar $Object = require('es-object-atoms');\n\nvar $Error = require('es-errors');\nvar $EvalError = require('es-errors/eval');\nvar $RangeError = require('es-errors/range');\nvar $ReferenceError = require('es-errors/ref');\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\nvar $URIError = require('es-errors/uri');\n\nvar abs = require('math-intrinsics/abs');\nvar floor = require('math-intrinsics/floor');\nvar max = require('math-intrinsics/max');\nvar min = require('math-intrinsics/min');\nvar pow = require('math-intrinsics/pow');\nvar round = require('math-intrinsics/round');\nvar sign = require('math-intrinsics/sign');\n\nvar $Function = Function;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = require('gopd');\nvar $defineProperty = require('es-define-property');\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\n\nvar getProto = require('get-proto');\nvar $ObjectGPO = require('get-proto/Object.getPrototypeOf');\nvar $ReflectGPO = require('get-proto/Reflect.getPrototypeOf');\n\nvar $apply = require('call-bind-apply-helpers/functionApply');\nvar $call = require('call-bind-apply-helpers/functionCall');\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' || !getProto ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t__proto__: null,\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols && getProto ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%BigInt64Array%': typeof BigInt64Array === 'undefined' ? undefined : BigInt64Array,\n\t'%BigUint64Array%': typeof BigUint64Array === 'undefined' ? undefined : BigUint64Array,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': $Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': $EvalError,\n\t'%Float16Array%': typeof Float16Array === 'undefined' ? undefined : Float16Array,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols && getProto ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': $Object,\n\t'%Object.getOwnPropertyDescriptor%': $gOPD,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': $RangeError,\n\t'%ReferenceError%': $ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols && getProto ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': $URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet,\n\n\t'%Function.prototype.call%': $call,\n\t'%Function.prototype.apply%': $apply,\n\t'%Object.defineProperty%': $defineProperty,\n\t'%Object.getPrototypeOf%': $ObjectGPO,\n\t'%Math.abs%': abs,\n\t'%Math.floor%': floor,\n\t'%Math.max%': max,\n\t'%Math.min%': min,\n\t'%Math.pow%': pow,\n\t'%Math.round%': round,\n\t'%Math.sign%': sign,\n\t'%Reflect.getPrototypeOf%': $ReflectGPO\n};\n\nif (getProto) {\n\ttry {\n\t\tnull.error; // eslint-disable-line no-unused-expressions\n\t} catch (e) {\n\t\t// https://github.com/tc39/proposal-shadowrealm/pull/384#issuecomment-1364264229\n\t\tvar errorProto = getProto(getProto(e));\n\t\tINTRINSICS['%Error.prototype%'] = errorProto;\n\t}\n}\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen && getProto) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t__proto__: null,\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('hasown');\nvar $concat = bind.call($call, Array.prototype.concat);\nvar $spliceApply = bind.call($apply, Array.prototype.splice);\nvar $replace = bind.call($call, String.prototype.replace);\nvar $strSlice = bind.call($call, String.prototype.slice);\nvar $exec = bind.call($call, RegExp.prototype.exec);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tif ($exec(/^%?[^%]*%?$/, name) === null) {\n\t\tthrow new $SyntaxError('`%` may not be present anywhere but at the beginning and end of the intrinsic name');\n\t}\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBindBasic = require('call-bind-apply-helpers');\n\n/** @type {(thisArg: string, searchString: string, position?: number) => number} */\nvar $indexOf = callBindBasic([GetIntrinsic('%String.prototype.indexOf%')]);\n\n/** @type {import('.')} */\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\t/* eslint no-extra-parens: 0 */\n\n\tvar intrinsic = /** @type {(this: unknown, ...args: unknown[]) => unknown} */ (GetIntrinsic(name, !!allowMissing));\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBindBasic(/** @type {const} */ ([intrinsic]));\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bound');\n\nvar $toString = callBound('Object.prototype.toString');\n\n/** @type {import('.')} */\nvar isStandardArguments = function isArguments(value) {\n\tif (\n\t\thasToStringTag\n\t\t&& value\n\t\t&& typeof value === 'object'\n\t\t&& Symbol.toStringTag in value\n\t) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\n/** @type {import('.')} */\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null\n\t\t&& typeof value === 'object'\n\t\t&& 'length' in value\n\t\t&& typeof value.length === 'number'\n\t\t&& value.length >= 0\n\t\t&& $toString(value) !== '[object Array]'\n\t\t&& 'callee' in value\n\t\t&& $toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\n// @ts-expect-error TODO make this not error\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\n/** @type {import('.')} */\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n","'use strict';\n\nvar callBound = require('call-bound');\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar hasOwn = require('hasown');\nvar gOPD = require('gopd');\n\n/** @type {import('.')} */\nvar fn;\n\nif (hasToStringTag) {\n\t/** @type {(receiver: ThisParameterType, ...args: Parameters) => ReturnType} */\n\tvar $exec = callBound('RegExp.prototype.exec');\n\t/** @type {object} */\n\tvar isRegexMarker = {};\n\n\tvar throwRegexMarker = function () {\n\t\tthrow isRegexMarker;\n\t};\n\t/** @type {{ toString(): never, valueOf(): never, [Symbol.toPrimitive]?(): never }} */\n\tvar badStringifier = {\n\t\ttoString: throwRegexMarker,\n\t\tvalueOf: throwRegexMarker\n\t};\n\n\tif (typeof Symbol.toPrimitive === 'symbol') {\n\t\tbadStringifier[Symbol.toPrimitive] = throwRegexMarker;\n\t}\n\n\t/** @type {import('.')} */\n\t// @ts-expect-error TS can't figure out that the $exec call always throws\n\t// eslint-disable-next-line consistent-return\n\tfn = function isRegex(value) {\n\t\tif (!value || typeof value !== 'object') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// eslint-disable-next-line no-extra-parens\n\t\tvar descriptor = /** @type {NonNullable} */ (gOPD)(/** @type {{ lastIndex?: unknown }} */ (value), 'lastIndex');\n\t\tvar hasLastIndexDataProperty = descriptor && hasOwn(descriptor, 'value');\n\t\tif (!hasLastIndexDataProperty) {\n\t\t\treturn false;\n\t\t}\n\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-extra-parens\n\t\t\t$exec(value, /** @type {string} */ (/** @type {unknown} */ (badStringifier)));\n\t\t} catch (e) {\n\t\t\treturn e === isRegexMarker;\n\t\t}\n\t};\n} else {\n\t/** @type {(receiver: ThisParameterType, ...args: Parameters) => ReturnType} */\n\tvar $toString = callBound('Object.prototype.toString');\n\t/** @const @type {'[object RegExp]'} */\n\tvar regexClass = '[object RegExp]';\n\n\t/** @type {import('.')} */\n\tfn = function isRegex(value) {\n\t\t// In older browsers, typeof regex incorrectly returns 'function'\n\t\tif (!value || (typeof value !== 'object' && typeof value !== 'function')) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn $toString(value) === regexClass;\n\t};\n}\n\nmodule.exports = fn;\n","'use strict';\n\nvar callBound = require('call-bound');\nvar isRegex = require('is-regex');\n\nvar $exec = callBound('RegExp.prototype.exec');\nvar $TypeError = require('es-errors/type');\n\n/** @type {import('.')} */\nmodule.exports = function regexTester(regex) {\n\tif (!isRegex(regex)) {\n\t\tthrow new $TypeError('`regex` must be a RegExp');\n\t}\n\treturn function test(s) {\n\t\treturn $exec(regex, s) !== null;\n\t};\n};\n","'use strict';\n\nvar callBound = require('call-bound');\nvar safeRegexTest = require('safe-regex-test');\nvar isFnRegex = safeRegexTest(/^\\s*(?:function)?\\*/);\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = require('get-proto');\n\nvar toStr = callBound('Object.prototype.toString');\nvar fnToStr = callBound('Function.prototype.toString');\n\nvar getGeneratorFunc = function () { // eslint-disable-line consistent-return\n\tif (!hasToStringTag) {\n\t\treturn false;\n\t}\n\ttry {\n\t\treturn Function('return function*() {}')();\n\t} catch (e) {\n\t}\n};\n/** @type {undefined | false | null | GeneratorFunctionConstructor} */\nvar GeneratorFunction;\n\n/** @type {import('.')} */\nmodule.exports = function isGeneratorFunction(fn) {\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\tif (isFnRegex(fnToStr(fn))) {\n\t\treturn true;\n\t}\n\tif (!hasToStringTag) {\n\t\tvar str = toStr(fn);\n\t\treturn str === '[object GeneratorFunction]';\n\t}\n\tif (!getProto) {\n\t\treturn false;\n\t}\n\tif (typeof GeneratorFunction === 'undefined') {\n\t\tvar generatorFunc = getGeneratorFunc();\n\t\tGeneratorFunction = generatorFunc\n\t\t\t// eslint-disable-next-line no-extra-parens\n\t\t\t? /** @type {GeneratorFunctionConstructor} */ (getProto(generatorFunc))\n\t\t\t: false;\n\t}\n\treturn getProto(fn) === GeneratorFunction;\n};\n","'use strict';\n\nvar fnToStr = Function.prototype.toString;\nvar reflectApply = typeof Reflect === 'object' && Reflect !== null && Reflect.apply;\nvar badArrayLike;\nvar isCallableMarker;\nif (typeof reflectApply === 'function' && typeof Object.defineProperty === 'function') {\n\ttry {\n\t\tbadArrayLike = Object.defineProperty({}, 'length', {\n\t\t\tget: function () {\n\t\t\t\tthrow isCallableMarker;\n\t\t\t}\n\t\t});\n\t\tisCallableMarker = {};\n\t\t// eslint-disable-next-line no-throw-literal\n\t\treflectApply(function () { throw 42; }, null, badArrayLike);\n\t} catch (_) {\n\t\tif (_ !== isCallableMarker) {\n\t\t\treflectApply = null;\n\t\t}\n\t}\n} else {\n\treflectApply = null;\n}\n\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n\ttry {\n\t\tvar fnStr = fnToStr.call(value);\n\t\treturn constructorRegex.test(fnStr);\n\t} catch (e) {\n\t\treturn false; // not a function\n\t}\n};\n\nvar tryFunctionObject = function tryFunctionToStr(value) {\n\ttry {\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tfnToStr.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\nvar toStr = Object.prototype.toString;\nvar objectClass = '[object Object]';\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar ddaClass = '[object HTMLAllCollection]'; // IE 11\nvar ddaClass2 = '[object HTML document.all class]';\nvar ddaClass3 = '[object HTMLCollection]'; // IE 9-10\nvar hasToStringTag = typeof Symbol === 'function' && !!Symbol.toStringTag; // better: use `has-tostringtag`\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar isDDA = function isDocumentDotAll() { return false; };\nif (typeof document === 'object') {\n\t// Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n\tvar all = document.all;\n\tif (toStr.call(all) === toStr.call(document.all)) {\n\t\tisDDA = function isDocumentDotAll(value) {\n\t\t\t/* globals document: false */\n\t\t\t// in IE 6-8, typeof document.all is \"object\" and it's truthy\n\t\t\tif ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n\t\t\t\ttry {\n\t\t\t\t\tvar str = toStr.call(value);\n\t\t\t\t\treturn (\n\t\t\t\t\t\tstr === ddaClass\n\t\t\t\t\t\t|| str === ddaClass2\n\t\t\t\t\t\t|| str === ddaClass3 // opera 12.16\n\t\t\t\t\t\t|| str === objectClass // IE 6-8\n\t\t\t\t\t) && value('') == null; // eslint-disable-line eqeqeq\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\t}\n}\n\nmodule.exports = reflectApply\n\t? function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\ttry {\n\t\t\treflectApply(value, null, badArrayLike);\n\t\t} catch (e) {\n\t\t\tif (e !== isCallableMarker) { return false; }\n\t\t}\n\t\treturn !isES6ClassFn(value) && tryFunctionObject(value);\n\t}\n\t: function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\tif (hasToStringTag) { return tryFunctionObject(value); }\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tvar strClass = toStr.call(value);\n\t\tif (strClass !== fnClass && strClass !== genClass && !(/^\\[object HTML/).test(strClass)) { return false; }\n\t\treturn tryFunctionObject(value);\n\t};\n","'use strict';\n\nvar isCallable = require('is-callable');\n\nvar toStr = Object.prototype.toString;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\n/** @type {(arr: A, iterator: (this: This | void, value: A[number], index: number, arr: A) => void, receiver: This | undefined) => void} */\nvar forEachArray = function forEachArray(array, iterator, receiver) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (hasOwnProperty.call(array, i)) {\n if (receiver == null) {\n iterator(array[i], i, array);\n } else {\n iterator.call(receiver, array[i], i, array);\n }\n }\n }\n};\n\n/** @type {(string: S, iterator: (this: This | void, value: S[number], index: number, string: S) => void, receiver: This | undefined) => void} */\nvar forEachString = function forEachString(string, iterator, receiver) {\n for (var i = 0, len = string.length; i < len; i++) {\n // no such thing as a sparse string.\n if (receiver == null) {\n iterator(string.charAt(i), i, string);\n } else {\n iterator.call(receiver, string.charAt(i), i, string);\n }\n }\n};\n\n/** @type {(obj: O, iterator: (this: This | void, value: O[keyof O], index: keyof O, obj: O) => void, receiver: This | undefined) => void} */\nvar forEachObject = function forEachObject(object, iterator, receiver) {\n for (var k in object) {\n if (hasOwnProperty.call(object, k)) {\n if (receiver == null) {\n iterator(object[k], k, object);\n } else {\n iterator.call(receiver, object[k], k, object);\n }\n }\n }\n};\n\n/** @type {(x: unknown) => x is readonly unknown[]} */\nfunction isArray(x) {\n return toStr.call(x) === '[object Array]';\n}\n\n/** @type {import('.')._internal} */\nmodule.exports = function forEach(list, iterator, thisArg) {\n if (!isCallable(iterator)) {\n throw new TypeError('iterator must be a function');\n }\n\n var receiver;\n if (arguments.length >= 3) {\n receiver = thisArg;\n }\n\n if (isArray(list)) {\n forEachArray(list, iterator, receiver);\n } else if (typeof list === 'string') {\n forEachString(list, iterator, receiver);\n } else {\n forEachObject(list, iterator, receiver);\n }\n};\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = [\n\t'Float16Array',\n\t'Float32Array',\n\t'Float64Array',\n\t'Int8Array',\n\t'Int16Array',\n\t'Int32Array',\n\t'Uint8Array',\n\t'Uint8ClampedArray',\n\t'Uint16Array',\n\t'Uint32Array',\n\t'BigInt64Array',\n\t'BigUint64Array'\n];\n","'use strict';\n\nvar possibleNames = require('possible-typed-array-names');\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\n/** @type {import('.')} */\nmodule.exports = function availableTypedArrays() {\n\tvar /** @type {ReturnType} */ out = [];\n\tfor (var i = 0; i < possibleNames.length; i++) {\n\t\tif (typeof g[possibleNames[i]] === 'function') {\n\t\t\t// @ts-expect-error\n\t\t\tout[out.length] = possibleNames[i];\n\t\t}\n\t}\n\treturn out;\n};\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\n\nvar gopd = require('gopd');\n\n/** @type {import('.')} */\nmodule.exports = function defineDataProperty(\n\tobj,\n\tproperty,\n\tvalue\n) {\n\tif (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) {\n\t\tthrow new $TypeError('`obj` must be an object or a function`');\n\t}\n\tif (typeof property !== 'string' && typeof property !== 'symbol') {\n\t\tthrow new $TypeError('`property` must be a string or a symbol`');\n\t}\n\tif (arguments.length > 3 && typeof arguments[3] !== 'boolean' && arguments[3] !== null) {\n\t\tthrow new $TypeError('`nonEnumerable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 4 && typeof arguments[4] !== 'boolean' && arguments[4] !== null) {\n\t\tthrow new $TypeError('`nonWritable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 5 && typeof arguments[5] !== 'boolean' && arguments[5] !== null) {\n\t\tthrow new $TypeError('`nonConfigurable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 6 && typeof arguments[6] !== 'boolean') {\n\t\tthrow new $TypeError('`loose`, if provided, must be a boolean');\n\t}\n\n\tvar nonEnumerable = arguments.length > 3 ? arguments[3] : null;\n\tvar nonWritable = arguments.length > 4 ? arguments[4] : null;\n\tvar nonConfigurable = arguments.length > 5 ? arguments[5] : null;\n\tvar loose = arguments.length > 6 ? arguments[6] : false;\n\n\t/* @type {false | TypedPropertyDescriptor} */\n\tvar desc = !!gopd && gopd(obj, property);\n\n\tif ($defineProperty) {\n\t\t$defineProperty(obj, property, {\n\t\t\tconfigurable: nonConfigurable === null && desc ? desc.configurable : !nonConfigurable,\n\t\t\tenumerable: nonEnumerable === null && desc ? desc.enumerable : !nonEnumerable,\n\t\t\tvalue: value,\n\t\t\twritable: nonWritable === null && desc ? desc.writable : !nonWritable\n\t\t});\n\t} else if (loose || (!nonEnumerable && !nonWritable && !nonConfigurable)) {\n\t\t// must fall back to [[Set]], and was not explicitly asked to make non-enumerable, non-writable, or non-configurable\n\t\tobj[property] = value; // eslint-disable-line no-param-reassign\n\t} else {\n\t\tthrow new $SyntaxError('This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.');\n\t}\n};\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar hasPropertyDescriptors = function hasPropertyDescriptors() {\n\treturn !!$defineProperty;\n};\n\nhasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() {\n\t// node v0.6 has a bug where array lengths can be Set but not Defined\n\tif (!$defineProperty) {\n\t\treturn null;\n\t}\n\ttry {\n\t\treturn $defineProperty([], 'length', { value: 1 }).length !== 1;\n\t} catch (e) {\n\t\t// In Firefox 4-22, defining length on an array throws an exception.\n\t\treturn true;\n\t}\n};\n\nmodule.exports = hasPropertyDescriptors;\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\n\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tif (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n\t\tthrow new $TypeError('`length` must be a positive 32-bit integer');\n\t}\n\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\n\tvar functionLengthIsConfigurable = true;\n\tvar functionLengthIsWritable = true;\n\tif ('length' in fn && gOPD) {\n\t\tvar desc = gOPD(fn, 'length');\n\t\tif (desc && !desc.configurable) {\n\t\t\tfunctionLengthIsConfigurable = false;\n\t\t}\n\t\tif (desc && !desc.writable) {\n\t\t\tfunctionLengthIsWritable = false;\n\t\t}\n\t}\n\n\tif (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length);\n\t\t}\n\t}\n\treturn fn;\n};\n","'use strict';\n\nvar bind = require('function-bind');\nvar $apply = require('./functionApply');\nvar actualApply = require('./actualApply');\n\n/** @type {import('./applyBind')} */\nmodule.exports = function applyBind() {\n\treturn actualApply(bind, $apply, arguments);\n};\n","'use strict';\n\nvar setFunctionLength = require('set-function-length');\n\nvar $defineProperty = require('es-define-property');\n\nvar callBindBasic = require('call-bind-apply-helpers');\nvar applyBind = require('call-bind-apply-helpers/applyBind');\n\nmodule.exports = function callBind(originalFunction) {\n\tvar func = callBindBasic(arguments);\n\tvar adjustedLength = originalFunction.length - (arguments.length - 1);\n\treturn setFunctionLength(\n\t\tfunc,\n\t\t1 + (adjustedLength > 0 ? adjustedLength : 0),\n\t\ttrue\n\t);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","'use strict';\n\nvar forEach = require('for-each');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBind = require('call-bind');\nvar callBound = require('call-bound');\nvar gOPD = require('gopd');\nvar getProto = require('get-proto');\n\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $slice = callBound('String.prototype.slice');\n\n/** @type {(array: readonly T[], value: unknown) => number} */\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n\tfor (var i = 0; i < array.length; i += 1) {\n\t\tif (array[i] === value) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n};\n\n/** @typedef {import('./types').Getter} Getter */\n/** @type {import('./types').Cache} */\nvar cache = { __proto__: null };\nif (hasToStringTag && gOPD && getProto) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tif (Symbol.toStringTag in arr && getProto) {\n\t\t\tvar proto = getProto(arr);\n\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\tif (!descriptor && proto) {\n\t\t\t\tvar superProto = getProto(proto);\n\t\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t}\n\t\t\t// @ts-expect-error TODO: fix\n\t\t\tcache['$' + typedArray] = callBind(descriptor.get);\n\t\t}\n\t});\n} else {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tvar fn = arr.slice || arr.set;\n\t\tif (fn) {\n\t\t\tcache[\n\t\t\t\t/** @type {`$${import('.').TypedArrayName}`} */ ('$' + typedArray)\n\t\t\t] = /** @type {import('./types').BoundSlice | import('./types').BoundSet} */ (\n\t\t\t\t// @ts-expect-error TODO FIXME\n\t\t\t\tcallBind(fn)\n\t\t\t);\n\t\t}\n\t});\n}\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t/** @type {Record<`\\$${import('.').TypedArrayName}`, Getter>} */ (cache),\n\t\t/** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */\n\t\tfunction (getter, typedArray) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t\t// @ts-expect-error a throw is fine here\n\t\t\t\t\tif ('$' + getter(value) === typedArray) {\n\t\t\t\t\t\tfound = /** @type {import('.').TypedArrayName} */ ($slice(typedArray, 1));\n\t\t\t\t\t}\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar trySlices = function tryAllSlices(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t/** @type {Record<`\\$${import('.').TypedArrayName}`, Getter>} */(cache),\n\t\t/** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */ function (getter, name) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t\t// @ts-expect-error a throw is fine here\n\t\t\t\t\tgetter(value);\n\t\t\t\t\tfound = /** @type {import('.').TypedArrayName} */ ($slice(name, 1));\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {import('.')} */\nmodule.exports = function whichTypedArray(value) {\n\tif (!value || typeof value !== 'object') { return false; }\n\tif (!hasToStringTag) {\n\t\t/** @type {string} */\n\t\tvar tag = $slice($toString(value), 8, -1);\n\t\tif ($indexOf(typedArrays, tag) > -1) {\n\t\t\treturn tag;\n\t\t}\n\t\tif (tag !== 'Object') {\n\t\t\treturn false;\n\t\t}\n\t\t// node < 0.6 hits here on real Typed Arrays\n\t\treturn trySlices(value);\n\t}\n\tif (!gOPD) { return null; } // unknown engine\n\treturn tryTypedArrays(value);\n};\n","'use strict';\n\nvar whichTypedArray = require('which-typed-array');\n\n/** @type {import('.')} */\nmodule.exports = function isTypedArray(value) {\n\treturn !!whichTypedArray(value);\n};\n","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\n\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\n\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\n\nvar ObjectToString = uncurryThis(Object.prototype.toString);\n\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\n\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\n\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\n\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch(e) {\n return false;\n }\n}\n\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n\treturn (\n\t\t(\n\t\t\ttypeof Promise !== 'undefined' &&\n\t\t\tinput instanceof Promise\n\t\t) ||\n\t\t(\n\t\t\tinput !== null &&\n\t\t\ttypeof input === 'object' &&\n\t\t\ttypeof input.then === 'function' &&\n\t\t\ttypeof input.catch === 'function'\n\t\t)\n\t);\n}\nexports.isPromise = isPromise;\n\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n\n return (\n isTypedArray(value) ||\n isDataView(value)\n );\n}\nexports.isArrayBufferView = isArrayBufferView;\n\n\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\n\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\n\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\n\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\n\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\n\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\n\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\n\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\n\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\n\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\n\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\n\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = (\n typeof Map !== 'undefined' &&\n isMapToString(new Map())\n);\n\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n\n return isMapToString.working\n ? isMapToString(value)\n : value instanceof Map;\n}\nexports.isMap = isMap;\n\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = (\n typeof Set !== 'undefined' &&\n isSetToString(new Set())\n);\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n\n return isSetToString.working\n ? isSetToString(value)\n : value instanceof Set;\n}\nexports.isSet = isSet;\n\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = (\n typeof WeakMap !== 'undefined' &&\n isWeakMapToString(new WeakMap())\n);\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n\n return isWeakMapToString.working\n ? isWeakMapToString(value)\n : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\n\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = (\n typeof WeakSet !== 'undefined' &&\n isWeakSetToString(new WeakSet())\n);\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\n\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n isArrayBufferToString(new ArrayBuffer())\n);\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n\n return isArrayBufferToString.working\n ? isArrayBufferToString(value)\n : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n typeof DataView !== 'undefined' &&\n isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))\n);\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n\n return isDataViewToString.working\n ? isDataViewToString(value)\n : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n\n return isSharedArrayBufferToString.working\n ? isSharedArrayBufferToString(value)\n : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\n\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\n\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\n\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\n\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\n\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\n\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\n\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\n\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\n\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\n\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\n\nfunction isBoxedPrimitive(value) {\n return (\n isNumberObject(value) ||\n isStringObject(value) ||\n isBooleanObject(value) ||\n isBigIntObject(value) ||\n isSymbolObject(value)\n );\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\n\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (\n isArrayBuffer(value) ||\n isSharedArrayBuffer(value)\n );\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function(method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function() {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnvRegex = /^$/;\n\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&')\n .replace(/\\*/g, '.*')\n .replace(/,/g, '$|^')\n .toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function(set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').slice(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.slice(1, -1);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\n\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb.bind(null, null, ret)) },\n function(rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\nvar _require2 = require('util'),\n inspect = _require2.inspect;\nvar custom = inspect && inspect.custom || 'inspect';\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\nmodule.exports = /*#__PURE__*/function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) ret += s + p.data;\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n }\n\n // Consumes a specified amount of characters from the buffered data.\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread(_objectSpread({}, options), {}, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n return BufferList;\n}();","'use strict';\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n return this;\n}\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n return Math.floor(hwm);\n }\n\n // Default value\n return state.objectMode ? 16 : 16 * 1024;\n}\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nrequire('inherits')(Writable, Stream);\nfunction nop() {}\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'finish' (and potentially 'end')\n this.autoDestroy = !!options.autoDestroy;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex);\n\n // legacy.\n this.writable = true;\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END();\n // TODO: defer error events consistently everywhere, not just the cb\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n return true;\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n return ret;\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n if (entry === null) state.lastBufferedRequest = null;\n }\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\nWritable.prototype._writev = null;\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n errorOrDestroy(stream, err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n return need;\n}\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n};\n/**/\n\nmodule.exports = Duplex;\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\nrequire('inherits')(Duplex, Readable);\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n process.nextTick(onEndNT, this);\n}\nfunction onEndNT(self) {\n self.end();\n}\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\n/**/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n callback.apply(this, args);\n };\n}\nfunction noop() {}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n var writableEnded = stream._writableState && stream._writableState.finished;\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n var onclose = function onclose() {\n var err;\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\nmodule.exports = eos;","'use strict';\n\nvar _Object$setPrototypeO;\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar finished = require('./end-of-stream');\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n if (resolve !== null) {\n var data = iter[kStream].read();\n // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n next: function next() {\n var _this = this;\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n if (error !== null) {\n return Promise.reject(error);\n }\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n }\n\n // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n var lastPromise = this[kLastPromise];\n var promise;\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n promise = new Promise(this[kHandlePromise]);\n }\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject];\n // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n iterator[kError] = err;\n return;\n }\n var resolve = iterator[kLastResolve];\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\nmodule.exports = createReadableStreamAsyncIterator;","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nmodule.exports = Readable;\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\nvar debugUtil = require('util');\nvar debug;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/buffer_list');\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;\n\n// Lazy loaded to improve the startup performance.\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\nrequire('inherits')(Readable, Stream);\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'end' (and potentially 'finish')\n this.autoDestroy = !!options.autoDestroy;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options);\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex);\n\n // legacy\n this.readable = true;\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n Stream.call(this);\n}\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n return er;\n}\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder;\n // If setEncoding(null), decoder.encoding equals utf8\n this._readableState.encoding = this._readableState.decoder.encoding;\n\n // Iterate over current buffer to convert already stored Buffers:\n var p = this._readableState.buffer.head;\n var content = '';\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n this._readableState.buffer.clear();\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n};\n\n// Don't raise the hwm > 1GB\nvar MAX_HWM = 0x40000000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n }\n\n // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n return dest;\n};\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0;\n\n // Try start flowing on next tick if stream isn't explicitly paused\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true;\n\n // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n state.paused = false;\n return this;\n};\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n if (!state.reading) {\n stream.read(0);\n }\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n this._readableState.paused = true;\n return this;\n};\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null);\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n return this;\n};\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n return createReadableStreamAsyncIterator(this);\n };\n}\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n});\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length);\n\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n return from(Readable, iterable, opts);\n };\n}\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\nvar Duplex = require('./_stream_duplex');\nrequire('inherits')(Transform, Duplex);\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null)\n // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\nfunction prefinish() {\n var _this = this;\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null)\n // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\nvar Transform = require('./_stream_transform');\nrequire('inherits')(PassThrough, Transform);\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar eos;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true;\n\n // request.destroy just do .end - .abort is what we want\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\nfunction call(fn) {\n fn();\n}\nfunction pipe(from, to) {\n return from.pipe(to);\n}\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\nmodule.exports = pipeline;","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/lib/_stream_readable.js');\nStream.Writable = require('readable-stream/lib/_stream_writable.js');\nStream.Duplex = require('readable-stream/lib/_stream_duplex.js');\nStream.Transform = require('readable-stream/lib/_stream_transform.js');\nStream.PassThrough = require('readable-stream/lib/_stream_passthrough.js');\nStream.finished = require('readable-stream/lib/internal/streams/end-of-stream.js')\nStream.pipeline = require('readable-stream/lib/internal/streams/pipeline.js')\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n","'use strict'\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('stream').Transform\nvar inherits = require('inherits')\n\nfunction HashBase (blockSize) {\n Transform.call(this)\n\n this._block = Buffer.allocUnsafe(blockSize)\n this._blockSize = blockSize\n this._blockOffset = 0\n this._length = [0, 0, 0, 0]\n\n this._finalized = false\n}\n\ninherits(HashBase, Transform)\n\nHashBase.prototype._transform = function (chunk, encoding, callback) {\n var error = null\n try {\n this.update(chunk, encoding)\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nHashBase.prototype._flush = function (callback) {\n var error = null\n try {\n this.push(this.digest())\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nvar useUint8Array = typeof Uint8Array !== 'undefined'\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined' &&\n typeof Uint8Array !== 'undefined' &&\n ArrayBuffer.isView &&\n (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT)\n\nfunction toBuffer (data, encoding) {\n // No need to do anything for exact instance\n // This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n if (data instanceof Buffer) return data\n\n // Convert strings to Buffer\n if (typeof data === 'string') return Buffer.from(data, encoding)\n\n /*\n * Wrap any TypedArray instances and DataViews\n * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n */\n if (useArrayBuffer && ArrayBuffer.isView(data)) {\n if (data.byteLength === 0) return Buffer.alloc(0) // Bug in Node.js <6.3.1, which treats this as out-of-bounds\n var res = Buffer.from(data.buffer, data.byteOffset, data.byteLength)\n // Recheck result size, as offset/length doesn't work on Node.js <5.10\n // We just go to Uint8Array case if this fails\n if (res.byteLength === data.byteLength) return res\n }\n\n /*\n * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n * Doesn't make sense with other TypedArray instances\n */\n if (useUint8Array && data instanceof Uint8Array) return Buffer.from(data)\n\n /*\n * Old Buffer polyfill on an engine that doesn't have TypedArray support\n * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n * Convert to our current Buffer implementation\n */\n if (\n Buffer.isBuffer(data) &&\n data.constructor &&\n typeof data.constructor.isBuffer === 'function' &&\n data.constructor.isBuffer(data)\n ) {\n return Buffer.from(data)\n }\n\n throw new TypeError('The \"data\" argument must be of type string or an instance of Buffer, TypedArray, or DataView.')\n}\n\nHashBase.prototype.update = function (data, encoding) {\n if (this._finalized) throw new Error('Digest already called')\n\n data = toBuffer(data, encoding) // asserts correct input type\n\n // consume data\n var block = this._block\n var offset = 0\n while (this._blockOffset + data.length - offset >= this._blockSize) {\n for (var i = this._blockOffset; i < this._blockSize;) block[i++] = data[offset++]\n this._update()\n this._blockOffset = 0\n }\n while (offset < data.length) block[this._blockOffset++] = data[offset++]\n\n // update length\n for (var j = 0, carry = data.length * 8; carry > 0; ++j) {\n this._length[j] += carry\n carry = (this._length[j] / 0x0100000000) | 0\n if (carry > 0) this._length[j] -= 0x0100000000 * carry\n }\n\n return this\n}\n\nHashBase.prototype._update = function () {\n throw new Error('_update is not implemented')\n}\n\nHashBase.prototype.digest = function (encoding) {\n if (this._finalized) throw new Error('Digest already called')\n this._finalized = true\n\n var digest = this._digest()\n if (encoding !== undefined) digest = digest.toString(encoding)\n\n // reset state\n this._block.fill(0)\n this._blockOffset = 0\n for (var i = 0; i < 4; ++i) this._length[i] = 0\n\n return digest\n}\n\nHashBase.prototype._digest = function () {\n throw new Error('_digest is not implemented')\n}\n\nmodule.exports = HashBase\n","'use strict'\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\nvar Buffer = require('safe-buffer').Buffer\n\nvar ARRAY16 = new Array(16)\n\nfunction MD5 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n}\n\ninherits(MD5, HashBase)\n\nMD5.prototype._update = function () {\n var M = ARRAY16\n for (var i = 0; i < 16; ++i) M[i] = this._block.readInt32LE(i * 4)\n\n var a = this._a\n var b = this._b\n var c = this._c\n var d = this._d\n\n a = fnF(a, b, c, d, M[0], 0xd76aa478, 7)\n d = fnF(d, a, b, c, M[1], 0xe8c7b756, 12)\n c = fnF(c, d, a, b, M[2], 0x242070db, 17)\n b = fnF(b, c, d, a, M[3], 0xc1bdceee, 22)\n a = fnF(a, b, c, d, M[4], 0xf57c0faf, 7)\n d = fnF(d, a, b, c, M[5], 0x4787c62a, 12)\n c = fnF(c, d, a, b, M[6], 0xa8304613, 17)\n b = fnF(b, c, d, a, M[7], 0xfd469501, 22)\n a = fnF(a, b, c, d, M[8], 0x698098d8, 7)\n d = fnF(d, a, b, c, M[9], 0x8b44f7af, 12)\n c = fnF(c, d, a, b, M[10], 0xffff5bb1, 17)\n b = fnF(b, c, d, a, M[11], 0x895cd7be, 22)\n a = fnF(a, b, c, d, M[12], 0x6b901122, 7)\n d = fnF(d, a, b, c, M[13], 0xfd987193, 12)\n c = fnF(c, d, a, b, M[14], 0xa679438e, 17)\n b = fnF(b, c, d, a, M[15], 0x49b40821, 22)\n\n a = fnG(a, b, c, d, M[1], 0xf61e2562, 5)\n d = fnG(d, a, b, c, M[6], 0xc040b340, 9)\n c = fnG(c, d, a, b, M[11], 0x265e5a51, 14)\n b = fnG(b, c, d, a, M[0], 0xe9b6c7aa, 20)\n a = fnG(a, b, c, d, M[5], 0xd62f105d, 5)\n d = fnG(d, a, b, c, M[10], 0x02441453, 9)\n c = fnG(c, d, a, b, M[15], 0xd8a1e681, 14)\n b = fnG(b, c, d, a, M[4], 0xe7d3fbc8, 20)\n a = fnG(a, b, c, d, M[9], 0x21e1cde6, 5)\n d = fnG(d, a, b, c, M[14], 0xc33707d6, 9)\n c = fnG(c, d, a, b, M[3], 0xf4d50d87, 14)\n b = fnG(b, c, d, a, M[8], 0x455a14ed, 20)\n a = fnG(a, b, c, d, M[13], 0xa9e3e905, 5)\n d = fnG(d, a, b, c, M[2], 0xfcefa3f8, 9)\n c = fnG(c, d, a, b, M[7], 0x676f02d9, 14)\n b = fnG(b, c, d, a, M[12], 0x8d2a4c8a, 20)\n\n a = fnH(a, b, c, d, M[5], 0xfffa3942, 4)\n d = fnH(d, a, b, c, M[8], 0x8771f681, 11)\n c = fnH(c, d, a, b, M[11], 0x6d9d6122, 16)\n b = fnH(b, c, d, a, M[14], 0xfde5380c, 23)\n a = fnH(a, b, c, d, M[1], 0xa4beea44, 4)\n d = fnH(d, a, b, c, M[4], 0x4bdecfa9, 11)\n c = fnH(c, d, a, b, M[7], 0xf6bb4b60, 16)\n b = fnH(b, c, d, a, M[10], 0xbebfbc70, 23)\n a = fnH(a, b, c, d, M[13], 0x289b7ec6, 4)\n d = fnH(d, a, b, c, M[0], 0xeaa127fa, 11)\n c = fnH(c, d, a, b, M[3], 0xd4ef3085, 16)\n b = fnH(b, c, d, a, M[6], 0x04881d05, 23)\n a = fnH(a, b, c, d, M[9], 0xd9d4d039, 4)\n d = fnH(d, a, b, c, M[12], 0xe6db99e5, 11)\n c = fnH(c, d, a, b, M[15], 0x1fa27cf8, 16)\n b = fnH(b, c, d, a, M[2], 0xc4ac5665, 23)\n\n a = fnI(a, b, c, d, M[0], 0xf4292244, 6)\n d = fnI(d, a, b, c, M[7], 0x432aff97, 10)\n c = fnI(c, d, a, b, M[14], 0xab9423a7, 15)\n b = fnI(b, c, d, a, M[5], 0xfc93a039, 21)\n a = fnI(a, b, c, d, M[12], 0x655b59c3, 6)\n d = fnI(d, a, b, c, M[3], 0x8f0ccc92, 10)\n c = fnI(c, d, a, b, M[10], 0xffeff47d, 15)\n b = fnI(b, c, d, a, M[1], 0x85845dd1, 21)\n a = fnI(a, b, c, d, M[8], 0x6fa87e4f, 6)\n d = fnI(d, a, b, c, M[15], 0xfe2ce6e0, 10)\n c = fnI(c, d, a, b, M[6], 0xa3014314, 15)\n b = fnI(b, c, d, a, M[13], 0x4e0811a1, 21)\n a = fnI(a, b, c, d, M[4], 0xf7537e82, 6)\n d = fnI(d, a, b, c, M[11], 0xbd3af235, 10)\n c = fnI(c, d, a, b, M[2], 0x2ad7d2bb, 15)\n b = fnI(b, c, d, a, M[9], 0xeb86d391, 21)\n\n this._a = (this._a + a) | 0\n this._b = (this._b + b) | 0\n this._c = (this._c + c) | 0\n this._d = (this._d + d) | 0\n}\n\nMD5.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = Buffer.allocUnsafe(16)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fnF (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnG (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnH (a, b, c, d, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnI (a, b, c, d, m, k, s) {\n return (rotl((a + ((c ^ (b | (~d)))) + m + k) | 0, s) + b) | 0\n}\n\nmodule.exports = MD5\n","'use strict'\nvar Buffer = require('buffer').Buffer\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\n\nvar ARRAY16 = new Array(16)\n\nvar zl = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n]\n\nvar zr = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n]\n\nvar sl = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n]\n\nvar sr = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n]\n\nvar hl = [0x00000000, 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xa953fd4e]\nvar hr = [0x50a28be6, 0x5c4dd124, 0x6d703ef3, 0x7a6d76e9, 0x00000000]\n\nfunction RIPEMD160 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n this._e = 0xc3d2e1f0\n}\n\ninherits(RIPEMD160, HashBase)\n\nRIPEMD160.prototype._update = function () {\n var words = ARRAY16\n for (var j = 0; j < 16; ++j) words[j] = this._block.readInt32LE(j * 4)\n\n var al = this._a | 0\n var bl = this._b | 0\n var cl = this._c | 0\n var dl = this._d | 0\n var el = this._e | 0\n\n var ar = this._a | 0\n var br = this._b | 0\n var cr = this._c | 0\n var dr = this._d | 0\n var er = this._e | 0\n\n // computation\n for (var i = 0; i < 80; i += 1) {\n var tl\n var tr\n if (i < 16) {\n tl = fn1(al, bl, cl, dl, el, words[zl[i]], hl[0], sl[i])\n tr = fn5(ar, br, cr, dr, er, words[zr[i]], hr[0], sr[i])\n } else if (i < 32) {\n tl = fn2(al, bl, cl, dl, el, words[zl[i]], hl[1], sl[i])\n tr = fn4(ar, br, cr, dr, er, words[zr[i]], hr[1], sr[i])\n } else if (i < 48) {\n tl = fn3(al, bl, cl, dl, el, words[zl[i]], hl[2], sl[i])\n tr = fn3(ar, br, cr, dr, er, words[zr[i]], hr[2], sr[i])\n } else if (i < 64) {\n tl = fn4(al, bl, cl, dl, el, words[zl[i]], hl[3], sl[i])\n tr = fn2(ar, br, cr, dr, er, words[zr[i]], hr[3], sr[i])\n } else { // if (i<80) {\n tl = fn5(al, bl, cl, dl, el, words[zl[i]], hl[4], sl[i])\n tr = fn1(ar, br, cr, dr, er, words[zr[i]], hr[4], sr[i])\n }\n\n al = el\n el = dl\n dl = rotl(cl, 10)\n cl = bl\n bl = tl\n\n ar = er\n er = dr\n dr = rotl(cr, 10)\n cr = br\n br = tr\n }\n\n // update state\n var t = (this._b + cl + dr) | 0\n this._b = (this._c + dl + er) | 0\n this._c = (this._d + el + ar) | 0\n this._d = (this._e + al + br) | 0\n this._e = (this._a + bl + cr) | 0\n this._a = t\n}\n\nRIPEMD160.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = Buffer.alloc ? Buffer.alloc(20) : new Buffer(20)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n buffer.writeInt32LE(this._e, 16)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fn1 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn2 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn3 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b | (~c)) ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn4 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn5 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ (c | (~d))) + m + k) | 0, s) + e) | 0\n}\n\nmodule.exports = RIPEMD160\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","'use strict';\n\nvar $TypeError = require('es-errors/type');\n\nvar callBound = require('call-bound');\n\n/** @type {undefined | ((thisArg: import('.').TypedArray) => Buffer)} */\nvar $typedArrayBuffer = callBound('TypedArray.prototype.buffer', true);\n\nvar isTypedArray = require('is-typed-array');\n\n/** @type {import('.')} */\n// node <= 0.10, < 0.11.4 has a nonconfigurable own property instead of a prototype getter\nmodule.exports = $typedArrayBuffer || function typedArrayBuffer(x) {\n\tif (!isTypedArray(x)) {\n\t\tthrow new $TypeError('Not a Typed Array');\n\t}\n\treturn x.buffer;\n};\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar isArray = require('isarray');\nvar typedArrayBuffer = require('typed-array-buffer');\n\nvar isView = ArrayBuffer.isView || function isView(obj) {\n\ttry {\n\t\ttypedArrayBuffer(obj);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\n\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined'\n\t&& typeof Uint8Array !== 'undefined';\nvar useFromArrayBuffer = useArrayBuffer && (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT);\n\nmodule.exports = function toBuffer(data, encoding) {\n\t/*\n\t * No need to do anything for exact instance\n\t * This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n\t */\n\tif (data instanceof Buffer) {\n\t\treturn data;\n\t}\n\n\tif (typeof data === 'string') {\n\t\treturn Buffer.from(data, encoding);\n\t}\n\n\t/*\n\t * Wrap any TypedArray instances and DataViews\n\t * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n\t */\n\tif (useArrayBuffer && isView(data)) {\n\t\t// Bug in Node.js <6.3.1, which treats this as out-of-bounds\n\t\tif (data.byteLength === 0) {\n\t\t\treturn Buffer.alloc(0);\n\t\t}\n\n\t\t// When Buffer is based on Uint8Array, we can just construct it from ArrayBuffer\n\t\tif (useFromArrayBuffer) {\n\t\t\tvar res = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n\t\t\t/*\n\t\t\t * Recheck result size, as offset/length doesn't work on Node.js <5.10\n\t\t\t * We just go to Uint8Array case if this fails\n\t\t\t */\n\t\t\tif (res.byteLength === data.byteLength) {\n\t\t\t\treturn res;\n\t\t\t}\n\t\t}\n\n\t\t// Convert to Uint8Array bytes and then to Buffer\n\t\tvar uint8 = data instanceof Uint8Array ? data : new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n\t\tvar result = Buffer.from(uint8);\n\n\t\t/*\n\t\t * Let's recheck that conversion succeeded\n\t\t * We have .length but not .byteLength when useFromArrayBuffer is false\n\t\t */\n\t\tif (result.length === data.byteLength) {\n\t\t\treturn result;\n\t\t}\n\t}\n\n\t/*\n\t * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n\t * Doesn't make sense with other TypedArray instances\n\t */\n\tif (useUint8Array && data instanceof Uint8Array) {\n\t\treturn Buffer.from(data);\n\t}\n\n\tvar isArr = isArray(data);\n\tif (isArr) {\n\t\tfor (var i = 0; i < data.length; i += 1) {\n\t\t\tvar x = data[i];\n\t\t\tif (\n\t\t\t\ttypeof x !== 'number'\n\t\t\t\t|| x < 0\n\t\t\t\t|| x > 255\n\t\t\t\t|| ~~x !== x // NaN and integer check\n\t\t\t) {\n\t\t\t\tthrow new RangeError('Array items must be numbers in the range 0-255.');\n\t\t\t}\n\t\t}\n\t}\n\n\t/*\n\t * Old Buffer polyfill on an engine that doesn't have TypedArray support\n\t * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n\t * Convert to our current Buffer implementation\n\t */\n\tif (\n\t\tisArr || (\n\t\t\tBuffer.isBuffer(data)\n\t\t\t\t&& data.constructor\n\t\t\t\t&& typeof data.constructor.isBuffer === 'function'\n\t\t\t\t&& data.constructor.isBuffer(data)\n\t\t)\n\t) {\n\t\treturn Buffer.from(data);\n\t}\n\n\tthrow new TypeError('The \"data\" argument must be a string, an Array, a Buffer, a Uint8Array, or a DataView.');\n};\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar toBuffer = require('to-buffer');\n\n// prototype class for hash functions\nfunction Hash(blockSize, finalSize) {\n\tthis._block = Buffer.alloc(blockSize);\n\tthis._finalSize = finalSize;\n\tthis._blockSize = blockSize;\n\tthis._len = 0;\n}\n\nHash.prototype.update = function (data, enc) {\n\t/* eslint no-param-reassign: 0 */\n\tdata = toBuffer(data, enc || 'utf8');\n\n\tvar block = this._block;\n\tvar blockSize = this._blockSize;\n\tvar length = data.length;\n\tvar accum = this._len;\n\n\tfor (var offset = 0; offset < length;) {\n\t\tvar assigned = accum % blockSize;\n\t\tvar remainder = Math.min(length - offset, blockSize - assigned);\n\n\t\tfor (var i = 0; i < remainder; i++) {\n\t\t\tblock[assigned + i] = data[offset + i];\n\t\t}\n\n\t\taccum += remainder;\n\t\toffset += remainder;\n\n\t\tif ((accum % blockSize) === 0) {\n\t\t\tthis._update(block);\n\t\t}\n\t}\n\n\tthis._len += length;\n\treturn this;\n};\n\nHash.prototype.digest = function (enc) {\n\tvar rem = this._len % this._blockSize;\n\n\tthis._block[rem] = 0x80;\n\n\t/*\n\t * zero (rem + 1) trailing bits, where (rem + 1) is the smallest\n\t * non-negative solution to the equation (length + 1 + (rem + 1)) === finalSize mod blockSize\n\t */\n\tthis._block.fill(0, rem + 1);\n\n\tif (rem >= this._finalSize) {\n\t\tthis._update(this._block);\n\t\tthis._block.fill(0);\n\t}\n\n\tvar bits = this._len * 8;\n\n\t// uint32\n\tif (bits <= 0xffffffff) {\n\t\tthis._block.writeUInt32BE(bits, this._blockSize - 4);\n\n\t\t// uint64\n\t} else {\n\t\tvar lowBits = (bits & 0xffffffff) >>> 0;\n\t\tvar highBits = (bits - lowBits) / 0x100000000;\n\n\t\tthis._block.writeUInt32BE(highBits, this._blockSize - 8);\n\t\tthis._block.writeUInt32BE(lowBits, this._blockSize - 4);\n\t}\n\n\tthis._update(this._block);\n\tvar hash = this._hash();\n\n\treturn enc ? hash.toString(enc) : hash;\n};\n\nHash.prototype._update = function () {\n\tthrow new Error('_update must be implemented by subclass');\n};\n\nmodule.exports = Hash;\n","'use strict';\n\n/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-0, as defined\n * in FIPS PUB 180-1\n * This source code is derived from sha1.js of the same repository.\n * The difference between SHA-0 and SHA-1 is just a bitwise rotate left\n * operation was added.\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0\n];\n\nvar W = new Array(80);\n\nfunction Sha() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha, Hash);\n\nSha.prototype.init = function () {\n\tthis._a = 0x67452301;\n\tthis._b = 0xefcdab89;\n\tthis._c = 0x98badcfe;\n\tthis._d = 0x10325476;\n\tthis._e = 0xc3d2e1f0;\n\n\treturn this;\n};\n\nfunction rotl5(num) {\n\treturn (num << 5) | (num >>> 27);\n}\n\nfunction rotl30(num) {\n\treturn (num << 30) | (num >>> 2);\n}\n\nfunction ft(s, b, c, d) {\n\tif (s === 0) {\n\t\treturn (b & c) | (~b & d);\n\t}\n\tif (s === 2) {\n\t\treturn (b & c) | (b & d) | (c & d);\n\t}\n\treturn b ^ c ^ d;\n}\n\nSha.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar a = this._a | 0;\n\tvar b = this._b | 0;\n\tvar c = this._c | 0;\n\tvar d = this._d | 0;\n\tvar e = this._e | 0;\n\n\tfor (var i = 0; i < 16; ++i) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t}\n\tfor (; i < 80; ++i) {\n\t\tw[i] = w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16];\n\t}\n\n\tfor (var j = 0; j < 80; ++j) {\n\t\tvar s = ~~(j / 20);\n\t\tvar t = (rotl5(a) + ft(s, b, c, d) + e + w[j] + K[s]) | 0;\n\n\t\te = d;\n\t\td = c;\n\t\tc = rotl30(b);\n\t\tb = a;\n\t\ta = t;\n\t}\n\n\tthis._a = (a + this._a) | 0;\n\tthis._b = (b + this._b) | 0;\n\tthis._c = (c + this._c) | 0;\n\tthis._d = (d + this._d) | 0;\n\tthis._e = (e + this._e) | 0;\n};\n\nSha.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(20);\n\n\tH.writeInt32BE(this._a | 0, 0);\n\tH.writeInt32BE(this._b | 0, 4);\n\tH.writeInt32BE(this._c | 0, 8);\n\tH.writeInt32BE(this._d | 0, 12);\n\tH.writeInt32BE(this._e | 0, 16);\n\n\treturn H;\n};\n\nmodule.exports = Sha;\n","'use strict';\n\n/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined\n * in FIPS PUB 180-1\n * Version 2.1a Copyright Paul Johnston 2000 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0\n];\n\nvar W = new Array(80);\n\nfunction Sha1() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha1, Hash);\n\nSha1.prototype.init = function () {\n\tthis._a = 0x67452301;\n\tthis._b = 0xefcdab89;\n\tthis._c = 0x98badcfe;\n\tthis._d = 0x10325476;\n\tthis._e = 0xc3d2e1f0;\n\n\treturn this;\n};\n\nfunction rotl1(num) {\n\treturn (num << 1) | (num >>> 31);\n}\n\nfunction rotl5(num) {\n\treturn (num << 5) | (num >>> 27);\n}\n\nfunction rotl30(num) {\n\treturn (num << 30) | (num >>> 2);\n}\n\nfunction ft(s, b, c, d) {\n\tif (s === 0) {\n\t\treturn (b & c) | (~b & d);\n\t}\n\tif (s === 2) {\n\t\treturn (b & c) | (b & d) | (c & d);\n\t}\n\treturn b ^ c ^ d;\n}\n\nSha1.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar a = this._a | 0;\n\tvar b = this._b | 0;\n\tvar c = this._c | 0;\n\tvar d = this._d | 0;\n\tvar e = this._e | 0;\n\n\tfor (var i = 0; i < 16; ++i) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t}\n\tfor (; i < 80; ++i) {\n\t\tw[i] = rotl1(w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n\t}\n\n\tfor (var j = 0; j < 80; ++j) {\n\t\tvar s = ~~(j / 20);\n\t\tvar t = (rotl5(a) + ft(s, b, c, d) + e + w[j] + K[s]) | 0;\n\n\t\te = d;\n\t\td = c;\n\t\tc = rotl30(b);\n\t\tb = a;\n\t\ta = t;\n\t}\n\n\tthis._a = (a + this._a) | 0;\n\tthis._b = (b + this._b) | 0;\n\tthis._c = (c + this._c) | 0;\n\tthis._d = (d + this._d) | 0;\n\tthis._e = (e + this._e) | 0;\n};\n\nSha1.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(20);\n\n\tH.writeInt32BE(this._a | 0, 0);\n\tH.writeInt32BE(this._b | 0, 4);\n\tH.writeInt32BE(this._c | 0, 8);\n\tH.writeInt32BE(this._d | 0, 12);\n\tH.writeInt32BE(this._e | 0, 16);\n\n\treturn H;\n};\n\nmodule.exports = Sha1;\n","'use strict';\n\n/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x428A2F98,\n\t0x71374491,\n\t0xB5C0FBCF,\n\t0xE9B5DBA5,\n\t0x3956C25B,\n\t0x59F111F1,\n\t0x923F82A4,\n\t0xAB1C5ED5,\n\t0xD807AA98,\n\t0x12835B01,\n\t0x243185BE,\n\t0x550C7DC3,\n\t0x72BE5D74,\n\t0x80DEB1FE,\n\t0x9BDC06A7,\n\t0xC19BF174,\n\t0xE49B69C1,\n\t0xEFBE4786,\n\t0x0FC19DC6,\n\t0x240CA1CC,\n\t0x2DE92C6F,\n\t0x4A7484AA,\n\t0x5CB0A9DC,\n\t0x76F988DA,\n\t0x983E5152,\n\t0xA831C66D,\n\t0xB00327C8,\n\t0xBF597FC7,\n\t0xC6E00BF3,\n\t0xD5A79147,\n\t0x06CA6351,\n\t0x14292967,\n\t0x27B70A85,\n\t0x2E1B2138,\n\t0x4D2C6DFC,\n\t0x53380D13,\n\t0x650A7354,\n\t0x766A0ABB,\n\t0x81C2C92E,\n\t0x92722C85,\n\t0xA2BFE8A1,\n\t0xA81A664B,\n\t0xC24B8B70,\n\t0xC76C51A3,\n\t0xD192E819,\n\t0xD6990624,\n\t0xF40E3585,\n\t0x106AA070,\n\t0x19A4C116,\n\t0x1E376C08,\n\t0x2748774C,\n\t0x34B0BCB5,\n\t0x391C0CB3,\n\t0x4ED8AA4A,\n\t0x5B9CCA4F,\n\t0x682E6FF3,\n\t0x748F82EE,\n\t0x78A5636F,\n\t0x84C87814,\n\t0x8CC70208,\n\t0x90BEFFFA,\n\t0xA4506CEB,\n\t0xBEF9A3F7,\n\t0xC67178F2\n];\n\nvar W = new Array(64);\n\nfunction Sha256() {\n\tthis.init();\n\n\tthis._w = W; // new Array(64)\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha256, Hash);\n\nSha256.prototype.init = function () {\n\tthis._a = 0x6a09e667;\n\tthis._b = 0xbb67ae85;\n\tthis._c = 0x3c6ef372;\n\tthis._d = 0xa54ff53a;\n\tthis._e = 0x510e527f;\n\tthis._f = 0x9b05688c;\n\tthis._g = 0x1f83d9ab;\n\tthis._h = 0x5be0cd19;\n\n\treturn this;\n};\n\nfunction ch(x, y, z) {\n\treturn z ^ (x & (y ^ z));\n}\n\nfunction maj(x, y, z) {\n\treturn (x & y) | (z & (x | y));\n}\n\nfunction sigma0(x) {\n\treturn ((x >>> 2) | (x << 30)) ^ ((x >>> 13) | (x << 19)) ^ ((x >>> 22) | (x << 10));\n}\n\nfunction sigma1(x) {\n\treturn ((x >>> 6) | (x << 26)) ^ ((x >>> 11) | (x << 21)) ^ ((x >>> 25) | (x << 7));\n}\n\nfunction gamma0(x) {\n\treturn ((x >>> 7) | (x << 25)) ^ ((x >>> 18) | (x << 14)) ^ (x >>> 3);\n}\n\nfunction gamma1(x) {\n\treturn ((x >>> 17) | (x << 15)) ^ ((x >>> 19) | (x << 13)) ^ (x >>> 10);\n}\n\nSha256.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar a = this._a | 0;\n\tvar b = this._b | 0;\n\tvar c = this._c | 0;\n\tvar d = this._d | 0;\n\tvar e = this._e | 0;\n\tvar f = this._f | 0;\n\tvar g = this._g | 0;\n\tvar h = this._h | 0;\n\n\tfor (var i = 0; i < 16; ++i) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t}\n\tfor (; i < 64; ++i) {\n\t\tw[i] = (gamma1(w[i - 2]) + w[i - 7] + gamma0(w[i - 15]) + w[i - 16]) | 0;\n\t}\n\n\tfor (var j = 0; j < 64; ++j) {\n\t\tvar T1 = (h + sigma1(e) + ch(e, f, g) + K[j] + w[j]) | 0;\n\t\tvar T2 = (sigma0(a) + maj(a, b, c)) | 0;\n\n\t\th = g;\n\t\tg = f;\n\t\tf = e;\n\t\te = (d + T1) | 0;\n\t\td = c;\n\t\tc = b;\n\t\tb = a;\n\t\ta = (T1 + T2) | 0;\n\t}\n\n\tthis._a = (a + this._a) | 0;\n\tthis._b = (b + this._b) | 0;\n\tthis._c = (c + this._c) | 0;\n\tthis._d = (d + this._d) | 0;\n\tthis._e = (e + this._e) | 0;\n\tthis._f = (f + this._f) | 0;\n\tthis._g = (g + this._g) | 0;\n\tthis._h = (h + this._h) | 0;\n};\n\nSha256.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(32);\n\n\tH.writeInt32BE(this._a, 0);\n\tH.writeInt32BE(this._b, 4);\n\tH.writeInt32BE(this._c, 8);\n\tH.writeInt32BE(this._d, 12);\n\tH.writeInt32BE(this._e, 16);\n\tH.writeInt32BE(this._f, 20);\n\tH.writeInt32BE(this._g, 24);\n\tH.writeInt32BE(this._h, 28);\n\n\treturn H;\n};\n\nmodule.exports = Sha256;\n","'use strict';\n\n/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits');\nvar Sha256 = require('./sha256');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar W = new Array(64);\n\nfunction Sha224() {\n\tthis.init();\n\n\tthis._w = W; // new Array(64)\n\n\tHash.call(this, 64, 56);\n}\n\ninherits(Sha224, Sha256);\n\nSha224.prototype.init = function () {\n\tthis._a = 0xc1059ed8;\n\tthis._b = 0x367cd507;\n\tthis._c = 0x3070dd17;\n\tthis._d = 0xf70e5939;\n\tthis._e = 0xffc00b31;\n\tthis._f = 0x68581511;\n\tthis._g = 0x64f98fa7;\n\tthis._h = 0xbefa4fa4;\n\n\treturn this;\n};\n\nSha224.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(28);\n\n\tH.writeInt32BE(this._a, 0);\n\tH.writeInt32BE(this._b, 4);\n\tH.writeInt32BE(this._c, 8);\n\tH.writeInt32BE(this._d, 12);\n\tH.writeInt32BE(this._e, 16);\n\tH.writeInt32BE(this._f, 20);\n\tH.writeInt32BE(this._g, 24);\n\n\treturn H;\n};\n\nmodule.exports = Sha224;\n","'use strict';\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar K = [\n\t0x428a2f98,\n\t0xd728ae22,\n\t0x71374491,\n\t0x23ef65cd,\n\t0xb5c0fbcf,\n\t0xec4d3b2f,\n\t0xe9b5dba5,\n\t0x8189dbbc,\n\t0x3956c25b,\n\t0xf348b538,\n\t0x59f111f1,\n\t0xb605d019,\n\t0x923f82a4,\n\t0xaf194f9b,\n\t0xab1c5ed5,\n\t0xda6d8118,\n\t0xd807aa98,\n\t0xa3030242,\n\t0x12835b01,\n\t0x45706fbe,\n\t0x243185be,\n\t0x4ee4b28c,\n\t0x550c7dc3,\n\t0xd5ffb4e2,\n\t0x72be5d74,\n\t0xf27b896f,\n\t0x80deb1fe,\n\t0x3b1696b1,\n\t0x9bdc06a7,\n\t0x25c71235,\n\t0xc19bf174,\n\t0xcf692694,\n\t0xe49b69c1,\n\t0x9ef14ad2,\n\t0xefbe4786,\n\t0x384f25e3,\n\t0x0fc19dc6,\n\t0x8b8cd5b5,\n\t0x240ca1cc,\n\t0x77ac9c65,\n\t0x2de92c6f,\n\t0x592b0275,\n\t0x4a7484aa,\n\t0x6ea6e483,\n\t0x5cb0a9dc,\n\t0xbd41fbd4,\n\t0x76f988da,\n\t0x831153b5,\n\t0x983e5152,\n\t0xee66dfab,\n\t0xa831c66d,\n\t0x2db43210,\n\t0xb00327c8,\n\t0x98fb213f,\n\t0xbf597fc7,\n\t0xbeef0ee4,\n\t0xc6e00bf3,\n\t0x3da88fc2,\n\t0xd5a79147,\n\t0x930aa725,\n\t0x06ca6351,\n\t0xe003826f,\n\t0x14292967,\n\t0x0a0e6e70,\n\t0x27b70a85,\n\t0x46d22ffc,\n\t0x2e1b2138,\n\t0x5c26c926,\n\t0x4d2c6dfc,\n\t0x5ac42aed,\n\t0x53380d13,\n\t0x9d95b3df,\n\t0x650a7354,\n\t0x8baf63de,\n\t0x766a0abb,\n\t0x3c77b2a8,\n\t0x81c2c92e,\n\t0x47edaee6,\n\t0x92722c85,\n\t0x1482353b,\n\t0xa2bfe8a1,\n\t0x4cf10364,\n\t0xa81a664b,\n\t0xbc423001,\n\t0xc24b8b70,\n\t0xd0f89791,\n\t0xc76c51a3,\n\t0x0654be30,\n\t0xd192e819,\n\t0xd6ef5218,\n\t0xd6990624,\n\t0x5565a910,\n\t0xf40e3585,\n\t0x5771202a,\n\t0x106aa070,\n\t0x32bbd1b8,\n\t0x19a4c116,\n\t0xb8d2d0c8,\n\t0x1e376c08,\n\t0x5141ab53,\n\t0x2748774c,\n\t0xdf8eeb99,\n\t0x34b0bcb5,\n\t0xe19b48a8,\n\t0x391c0cb3,\n\t0xc5c95a63,\n\t0x4ed8aa4a,\n\t0xe3418acb,\n\t0x5b9cca4f,\n\t0x7763e373,\n\t0x682e6ff3,\n\t0xd6b2b8a3,\n\t0x748f82ee,\n\t0x5defb2fc,\n\t0x78a5636f,\n\t0x43172f60,\n\t0x84c87814,\n\t0xa1f0ab72,\n\t0x8cc70208,\n\t0x1a6439ec,\n\t0x90befffa,\n\t0x23631e28,\n\t0xa4506ceb,\n\t0xde82bde9,\n\t0xbef9a3f7,\n\t0xb2c67915,\n\t0xc67178f2,\n\t0xe372532b,\n\t0xca273ece,\n\t0xea26619c,\n\t0xd186b8c7,\n\t0x21c0c207,\n\t0xeada7dd6,\n\t0xcde0eb1e,\n\t0xf57d4f7f,\n\t0xee6ed178,\n\t0x06f067aa,\n\t0x72176fba,\n\t0x0a637dc5,\n\t0xa2c898a6,\n\t0x113f9804,\n\t0xbef90dae,\n\t0x1b710b35,\n\t0x131c471b,\n\t0x28db77f5,\n\t0x23047d84,\n\t0x32caab7b,\n\t0x40c72493,\n\t0x3c9ebe0a,\n\t0x15c9bebc,\n\t0x431d67c4,\n\t0x9c100d4c,\n\t0x4cc5d4be,\n\t0xcb3e42b6,\n\t0x597f299c,\n\t0xfc657e2a,\n\t0x5fcb6fab,\n\t0x3ad6faec,\n\t0x6c44198c,\n\t0x4a475817\n];\n\nvar W = new Array(160);\n\nfunction Sha512() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 128, 112);\n}\n\ninherits(Sha512, Hash);\n\nSha512.prototype.init = function () {\n\tthis._ah = 0x6a09e667;\n\tthis._bh = 0xbb67ae85;\n\tthis._ch = 0x3c6ef372;\n\tthis._dh = 0xa54ff53a;\n\tthis._eh = 0x510e527f;\n\tthis._fh = 0x9b05688c;\n\tthis._gh = 0x1f83d9ab;\n\tthis._hh = 0x5be0cd19;\n\n\tthis._al = 0xf3bcc908;\n\tthis._bl = 0x84caa73b;\n\tthis._cl = 0xfe94f82b;\n\tthis._dl = 0x5f1d36f1;\n\tthis._el = 0xade682d1;\n\tthis._fl = 0x2b3e6c1f;\n\tthis._gl = 0xfb41bd6b;\n\tthis._hl = 0x137e2179;\n\n\treturn this;\n};\n\nfunction Ch(x, y, z) {\n\treturn z ^ (x & (y ^ z));\n}\n\nfunction maj(x, y, z) {\n\treturn (x & y) | (z & (x | y));\n}\n\nfunction sigma0(x, xl) {\n\treturn ((x >>> 28) | (xl << 4)) ^ ((xl >>> 2) | (x << 30)) ^ ((xl >>> 7) | (x << 25));\n}\n\nfunction sigma1(x, xl) {\n\treturn ((x >>> 14) | (xl << 18)) ^ ((x >>> 18) | (xl << 14)) ^ ((xl >>> 9) | (x << 23));\n}\n\nfunction Gamma0(x, xl) {\n\treturn ((x >>> 1) | (xl << 31)) ^ ((x >>> 8) | (xl << 24)) ^ (x >>> 7);\n}\n\nfunction Gamma0l(x, xl) {\n\treturn ((x >>> 1) | (xl << 31)) ^ ((x >>> 8) | (xl << 24)) ^ ((x >>> 7) | (xl << 25));\n}\n\nfunction Gamma1(x, xl) {\n\treturn ((x >>> 19) | (xl << 13)) ^ ((xl >>> 29) | (x << 3)) ^ (x >>> 6);\n}\n\nfunction Gamma1l(x, xl) {\n\treturn ((x >>> 19) | (xl << 13)) ^ ((xl >>> 29) | (x << 3)) ^ ((x >>> 6) | (xl << 26));\n}\n\nfunction getCarry(a, b) {\n\treturn (a >>> 0) < (b >>> 0) ? 1 : 0;\n}\n\nSha512.prototype._update = function (M) {\n\tvar w = this._w;\n\n\tvar ah = this._ah | 0;\n\tvar bh = this._bh | 0;\n\tvar ch = this._ch | 0;\n\tvar dh = this._dh | 0;\n\tvar eh = this._eh | 0;\n\tvar fh = this._fh | 0;\n\tvar gh = this._gh | 0;\n\tvar hh = this._hh | 0;\n\n\tvar al = this._al | 0;\n\tvar bl = this._bl | 0;\n\tvar cl = this._cl | 0;\n\tvar dl = this._dl | 0;\n\tvar el = this._el | 0;\n\tvar fl = this._fl | 0;\n\tvar gl = this._gl | 0;\n\tvar hl = this._hl | 0;\n\n\tfor (var i = 0; i < 32; i += 2) {\n\t\tw[i] = M.readInt32BE(i * 4);\n\t\tw[i + 1] = M.readInt32BE((i * 4) + 4);\n\t}\n\tfor (; i < 160; i += 2) {\n\t\tvar xh = w[i - (15 * 2)];\n\t\tvar xl = w[i - (15 * 2) + 1];\n\t\tvar gamma0 = Gamma0(xh, xl);\n\t\tvar gamma0l = Gamma0l(xl, xh);\n\n\t\txh = w[i - (2 * 2)];\n\t\txl = w[i - (2 * 2) + 1];\n\t\tvar gamma1 = Gamma1(xh, xl);\n\t\tvar gamma1l = Gamma1l(xl, xh);\n\n\t\t// w[i] = gamma0 + w[i - 7] + gamma1 + w[i - 16]\n\t\tvar Wi7h = w[i - (7 * 2)];\n\t\tvar Wi7l = w[i - (7 * 2) + 1];\n\n\t\tvar Wi16h = w[i - (16 * 2)];\n\t\tvar Wi16l = w[i - (16 * 2) + 1];\n\n\t\tvar Wil = (gamma0l + Wi7l) | 0;\n\t\tvar Wih = (gamma0 + Wi7h + getCarry(Wil, gamma0l)) | 0;\n\t\tWil = (Wil + gamma1l) | 0;\n\t\tWih = (Wih + gamma1 + getCarry(Wil, gamma1l)) | 0;\n\t\tWil = (Wil + Wi16l) | 0;\n\t\tWih = (Wih + Wi16h + getCarry(Wil, Wi16l)) | 0;\n\n\t\tw[i] = Wih;\n\t\tw[i + 1] = Wil;\n\t}\n\n\tfor (var j = 0; j < 160; j += 2) {\n\t\tWih = w[j];\n\t\tWil = w[j + 1];\n\n\t\tvar majh = maj(ah, bh, ch);\n\t\tvar majl = maj(al, bl, cl);\n\n\t\tvar sigma0h = sigma0(ah, al);\n\t\tvar sigma0l = sigma0(al, ah);\n\t\tvar sigma1h = sigma1(eh, el);\n\t\tvar sigma1l = sigma1(el, eh);\n\n\t\t// t1 = h + sigma1 + ch + K[j] + w[j]\n\t\tvar Kih = K[j];\n\t\tvar Kil = K[j + 1];\n\n\t\tvar chh = Ch(eh, fh, gh);\n\t\tvar chl = Ch(el, fl, gl);\n\n\t\tvar t1l = (hl + sigma1l) | 0;\n\t\tvar t1h = (hh + sigma1h + getCarry(t1l, hl)) | 0;\n\t\tt1l = (t1l + chl) | 0;\n\t\tt1h = (t1h + chh + getCarry(t1l, chl)) | 0;\n\t\tt1l = (t1l + Kil) | 0;\n\t\tt1h = (t1h + Kih + getCarry(t1l, Kil)) | 0;\n\t\tt1l = (t1l + Wil) | 0;\n\t\tt1h = (t1h + Wih + getCarry(t1l, Wil)) | 0;\n\n\t\t// t2 = sigma0 + maj\n\t\tvar t2l = (sigma0l + majl) | 0;\n\t\tvar t2h = (sigma0h + majh + getCarry(t2l, sigma0l)) | 0;\n\n\t\thh = gh;\n\t\thl = gl;\n\t\tgh = fh;\n\t\tgl = fl;\n\t\tfh = eh;\n\t\tfl = el;\n\t\tel = (dl + t1l) | 0;\n\t\teh = (dh + t1h + getCarry(el, dl)) | 0;\n\t\tdh = ch;\n\t\tdl = cl;\n\t\tch = bh;\n\t\tcl = bl;\n\t\tbh = ah;\n\t\tbl = al;\n\t\tal = (t1l + t2l) | 0;\n\t\tah = (t1h + t2h + getCarry(al, t1l)) | 0;\n\t}\n\n\tthis._al = (this._al + al) | 0;\n\tthis._bl = (this._bl + bl) | 0;\n\tthis._cl = (this._cl + cl) | 0;\n\tthis._dl = (this._dl + dl) | 0;\n\tthis._el = (this._el + el) | 0;\n\tthis._fl = (this._fl + fl) | 0;\n\tthis._gl = (this._gl + gl) | 0;\n\tthis._hl = (this._hl + hl) | 0;\n\n\tthis._ah = (this._ah + ah + getCarry(this._al, al)) | 0;\n\tthis._bh = (this._bh + bh + getCarry(this._bl, bl)) | 0;\n\tthis._ch = (this._ch + ch + getCarry(this._cl, cl)) | 0;\n\tthis._dh = (this._dh + dh + getCarry(this._dl, dl)) | 0;\n\tthis._eh = (this._eh + eh + getCarry(this._el, el)) | 0;\n\tthis._fh = (this._fh + fh + getCarry(this._fl, fl)) | 0;\n\tthis._gh = (this._gh + gh + getCarry(this._gl, gl)) | 0;\n\tthis._hh = (this._hh + hh + getCarry(this._hl, hl)) | 0;\n};\n\nSha512.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(64);\n\n\tfunction writeInt64BE(h, l, offset) {\n\t\tH.writeInt32BE(h, offset);\n\t\tH.writeInt32BE(l, offset + 4);\n\t}\n\n\twriteInt64BE(this._ah, this._al, 0);\n\twriteInt64BE(this._bh, this._bl, 8);\n\twriteInt64BE(this._ch, this._cl, 16);\n\twriteInt64BE(this._dh, this._dl, 24);\n\twriteInt64BE(this._eh, this._el, 32);\n\twriteInt64BE(this._fh, this._fl, 40);\n\twriteInt64BE(this._gh, this._gl, 48);\n\twriteInt64BE(this._hh, this._hl, 56);\n\n\treturn H;\n};\n\nmodule.exports = Sha512;\n","'use strict';\n\nvar inherits = require('inherits');\nvar SHA512 = require('./sha512');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar W = new Array(160);\n\nfunction Sha384() {\n\tthis.init();\n\tthis._w = W;\n\n\tHash.call(this, 128, 112);\n}\n\ninherits(Sha384, SHA512);\n\nSha384.prototype.init = function () {\n\tthis._ah = 0xcbbb9d5d;\n\tthis._bh = 0x629a292a;\n\tthis._ch = 0x9159015a;\n\tthis._dh = 0x152fecd8;\n\tthis._eh = 0x67332667;\n\tthis._fh = 0x8eb44a87;\n\tthis._gh = 0xdb0c2e0d;\n\tthis._hh = 0x47b5481d;\n\n\tthis._al = 0xc1059ed8;\n\tthis._bl = 0x367cd507;\n\tthis._cl = 0x3070dd17;\n\tthis._dl = 0xf70e5939;\n\tthis._el = 0xffc00b31;\n\tthis._fl = 0x68581511;\n\tthis._gl = 0x64f98fa7;\n\tthis._hl = 0xbefa4fa4;\n\n\treturn this;\n};\n\nSha384.prototype._hash = function () {\n\tvar H = Buffer.allocUnsafe(48);\n\n\tfunction writeInt64BE(h, l, offset) {\n\t\tH.writeInt32BE(h, offset);\n\t\tH.writeInt32BE(l, offset + 4);\n\t}\n\n\twriteInt64BE(this._ah, this._al, 0);\n\twriteInt64BE(this._bh, this._bl, 8);\n\twriteInt64BE(this._ch, this._cl, 16);\n\twriteInt64BE(this._dh, this._dl, 24);\n\twriteInt64BE(this._eh, this._el, 32);\n\twriteInt64BE(this._fh, this._fl, 40);\n\n\treturn H;\n};\n\nmodule.exports = Sha384;\n","'use strict';\n\nmodule.exports = function SHA(algorithm) {\n\tvar alg = algorithm.toLowerCase();\n\n\tvar Algorithm = module.exports[alg];\n\tif (!Algorithm) {\n\t\tthrow new Error(alg + ' is not supported (we accept pull requests)');\n\t}\n\n\treturn new Algorithm();\n};\n\nmodule.exports.sha = require('./sha');\nmodule.exports.sha1 = require('./sha1');\nmodule.exports.sha224 = require('./sha224');\nmodule.exports.sha256 = require('./sha256');\nmodule.exports.sha384 = require('./sha384');\nmodule.exports.sha512 = require('./sha512');\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar Transform = require('stream').Transform;\nvar StringDecoder = require('string_decoder').StringDecoder;\nvar inherits = require('inherits');\n\nfunction CipherBase(hashMode) {\n\tTransform.call(this);\n\tthis.hashMode = typeof hashMode === 'string';\n\tif (this.hashMode) {\n\t\tthis[hashMode] = this._finalOrDigest;\n\t} else {\n\t\tthis['final'] = this._finalOrDigest;\n\t}\n\tif (this._final) {\n\t\tthis.__final = this._final;\n\t\tthis._final = null;\n\t}\n\tthis._decoder = null;\n\tthis._encoding = null;\n}\ninherits(CipherBase, Transform);\n\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined'\n\t&& typeof Uint8Array !== 'undefined'\n\t&& ArrayBuffer.isView\n\t&& (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT);\n\nfunction toBuffer(data, encoding) {\n\t/*\n\t * No need to do anything for exact instance\n\t * This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n\t */\n\tif (data instanceof Buffer) {\n\t\treturn data;\n\t}\n\n\t// Convert strings to Buffer\n\tif (typeof data === 'string') {\n\t\treturn Buffer.from(data, encoding);\n\t}\n\n\t/*\n\t * Wrap any TypedArray instances and DataViews\n\t * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n\t */\n\tif (useArrayBuffer && ArrayBuffer.isView(data)) {\n\t\t// Bug in Node.js <6.3.1, which treats this as out-of-bounds\n\t\tif (data.byteLength === 0) {\n\t\t\treturn Buffer.alloc(0);\n\t\t}\n\n\t\tvar res = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n\t\t/*\n\t\t * Recheck result size, as offset/length doesn't work on Node.js <5.10\n\t\t * We just go to Uint8Array case if this fails\n\t\t */\n\t\tif (res.byteLength === data.byteLength) {\n\t\t\treturn res;\n\t\t}\n\t}\n\n\t/*\n\t * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n\t * Doesn't make sense with other TypedArray instances\n\t */\n\tif (useUint8Array && data instanceof Uint8Array) {\n\t\treturn Buffer.from(data);\n\t}\n\n\t/*\n\t * Old Buffer polyfill on an engine that doesn't have TypedArray support\n\t * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n\t * Convert to our current Buffer implementation\n\t */\n\tif (\n\t\tBuffer.isBuffer(data)\n\t\t\t&& data.constructor\n\t\t\t&& typeof data.constructor.isBuffer === 'function'\n\t\t\t&& data.constructor.isBuffer(data)\n\t) {\n\t\treturn Buffer.from(data);\n\t}\n\n\tthrow new TypeError('The \"data\" argument must be of type string or an instance of Buffer, TypedArray, or DataView.');\n}\n\nCipherBase.prototype.update = function (data, inputEnc, outputEnc) {\n\tvar bufferData = toBuffer(data, inputEnc); // asserts correct input type\n\tvar outData = this._update(bufferData);\n\tif (this.hashMode) {\n\t\treturn this;\n\t}\n\n\tif (outputEnc) {\n\t\toutData = this._toString(outData, outputEnc);\n\t}\n\n\treturn outData;\n};\n\nCipherBase.prototype.setAutoPadding = function () {};\nCipherBase.prototype.getAuthTag = function () {\n\tthrow new Error('trying to get auth tag in unsupported state');\n};\n\nCipherBase.prototype.setAuthTag = function () {\n\tthrow new Error('trying to set auth tag in unsupported state');\n};\n\nCipherBase.prototype.setAAD = function () {\n\tthrow new Error('trying to set aad in unsupported state');\n};\n\nCipherBase.prototype._transform = function (data, _, next) {\n\tvar err;\n\ttry {\n\t\tif (this.hashMode) {\n\t\t\tthis._update(data);\n\t\t} else {\n\t\t\tthis.push(this._update(data));\n\t\t}\n\t} catch (e) {\n\t\terr = e;\n\t} finally {\n\t\tnext(err);\n\t}\n};\nCipherBase.prototype._flush = function (done) {\n\tvar err;\n\ttry {\n\t\tthis.push(this.__final());\n\t} catch (e) {\n\t\terr = e;\n\t}\n\n\tdone(err);\n};\nCipherBase.prototype._finalOrDigest = function (outputEnc) {\n\tvar outData = this.__final() || Buffer.alloc(0);\n\tif (outputEnc) {\n\t\toutData = this._toString(outData, outputEnc, true);\n\t}\n\treturn outData;\n};\n\nCipherBase.prototype._toString = function (value, enc, fin) {\n\tif (!this._decoder) {\n\t\tthis._decoder = new StringDecoder(enc);\n\t\tthis._encoding = enc;\n\t}\n\n\tif (this._encoding !== enc) {\n\t\tthrow new Error('can’t switch encodings');\n\t}\n\n\tvar out = this._decoder.write(value);\n\tif (fin) {\n\t\tout += this._decoder.end();\n\t}\n\n\treturn out;\n};\n\nmodule.exports = CipherBase;\n","'use strict'\nvar inherits = require('inherits')\nvar MD5 = require('md5.js')\nvar RIPEMD160 = require('ripemd160')\nvar sha = require('sha.js')\nvar Base = require('cipher-base')\n\nfunction Hash (hash) {\n Base.call(this, 'digest')\n\n this._hash = hash\n}\n\ninherits(Hash, Base)\n\nHash.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHash.prototype._final = function () {\n return this._hash.digest()\n}\n\nmodule.exports = function createHash (alg) {\n alg = alg.toLowerCase()\n if (alg === 'md5') return new MD5()\n if (alg === 'rmd160' || alg === 'ripemd160') return new RIPEMD160()\n\n return new Hash(sha(alg))\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar Base = require('cipher-base')\n\nvar ZEROS = Buffer.alloc(128)\nvar blocksize = 64\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n this._alg = alg\n this._key = key\n\n if (key.length > blocksize) {\n key = alg(key)\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n\n this._hash = [ipad]\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.push(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._alg(Buffer.concat(this._hash))\n return this._alg(Buffer.concat([this._opad, h]))\n}\nmodule.exports = Hmac\n","var MD5 = require('md5.js')\n\nmodule.exports = function (buffer) {\n return new MD5().update(buffer).digest()\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Legacy = require('./legacy')\nvar Base = require('cipher-base')\nvar Buffer = require('safe-buffer').Buffer\nvar md5 = require('create-hash/md5')\nvar RIPEMD160 = require('ripemd160')\n\nvar sha = require('sha.js')\n\nvar ZEROS = Buffer.alloc(128)\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64\n\n this._alg = alg\n this._key = key\n if (key.length > blocksize) {\n var hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n key = hash.update(key).digest()\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n this._hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n this._hash.update(ipad)\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._hash.digest()\n var hash = this._alg === 'rmd160' ? new RIPEMD160() : sha(this._alg)\n return hash.update(this._opad).update(h).digest()\n}\n\nmodule.exports = function createHmac (alg, key) {\n alg = alg.toLowerCase()\n if (alg === 'rmd160' || alg === 'ripemd160') {\n return new Hmac('rmd160', key)\n }\n if (alg === 'md5') {\n return new Legacy(md5, key)\n }\n return new Hmac(alg, key)\n}\n","'use strict';\n\nmodule.exports = require('./browser/algorithms.json');\n","'use strict';\n\nvar MAX_ALLOC = Math.pow(2, 30) - 1; // default in iojs\n\nmodule.exports = function (iterations, keylen) {\n\tif (typeof iterations !== 'number') {\n\t\tthrow new TypeError('Iterations not a number');\n\t}\n\n\tif (iterations < 0) {\n\t\tthrow new TypeError('Bad iterations');\n\t}\n\n\tif (typeof keylen !== 'number') {\n\t\tthrow new TypeError('Key length not a number');\n\t}\n\n\tif (keylen < 0 || keylen > MAX_ALLOC || keylen !== keylen) { /* eslint no-self-compare: 0 */\n\t\tthrow new TypeError('Bad key length');\n\t}\n};\n","'use strict';\n\nvar defaultEncoding;\n/* istanbul ignore next */\nif (global.process && global.process.browser) {\n\tdefaultEncoding = 'utf-8';\n} else if (global.process && global.process.version) {\n\tvar pVersionMajor = parseInt(process.version.split('.')[0].slice(1), 10);\n\n\tdefaultEncoding = pVersionMajor >= 6 ? 'utf-8' : 'binary';\n} else {\n\tdefaultEncoding = 'utf-8';\n}\nmodule.exports = defaultEncoding;\n","'use strict'\nvar intSize = 4\nvar zeroBuffer = new Buffer(intSize)\nzeroBuffer.fill(0)\n\nvar charSize = 8\nvar hashSize = 16\n\nfunction toArray (buf) {\n if ((buf.length % intSize) !== 0) {\n var len = buf.length + (intSize - (buf.length % intSize))\n buf = Buffer.concat([buf, zeroBuffer], len)\n }\n\n var arr = new Array(buf.length >>> 2)\n for (var i = 0, j = 0; i < buf.length; i += intSize, j++) {\n arr[j] = buf.readInt32LE(i)\n }\n\n return arr\n}\n\nmodule.exports = function hash (buf, fn) {\n var arr = fn(toArray(buf), buf.length * charSize)\n buf = new Buffer(hashSize)\n for (var i = 0; i < arr.length; i++) {\n buf.writeInt32LE(arr[i], i << 2, true)\n }\n return buf\n}\n","'use strict'\n/*\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\n\nvar makeHash = require('./make-hash')\n\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length\n */\nfunction core_md5 (x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << ((len) % 32)\n x[(((len + 64) >>> 9) << 4) + 14] = len\n\n var a = 1732584193\n var b = -271733879\n var c = -1732584194\n var d = 271733878\n\n for (var i = 0; i < x.length; i += 16) {\n var olda = a\n var oldb = b\n var oldc = c\n var oldd = d\n\n a = md5_ff(a, b, c, d, x[i + 0], 7, -680876936)\n d = md5_ff(d, a, b, c, x[i + 1], 12, -389564586)\n c = md5_ff(c, d, a, b, x[i + 2], 17, 606105819)\n b = md5_ff(b, c, d, a, x[i + 3], 22, -1044525330)\n a = md5_ff(a, b, c, d, x[i + 4], 7, -176418897)\n d = md5_ff(d, a, b, c, x[i + 5], 12, 1200080426)\n c = md5_ff(c, d, a, b, x[i + 6], 17, -1473231341)\n b = md5_ff(b, c, d, a, x[i + 7], 22, -45705983)\n a = md5_ff(a, b, c, d, x[i + 8], 7, 1770035416)\n d = md5_ff(d, a, b, c, x[i + 9], 12, -1958414417)\n c = md5_ff(c, d, a, b, x[i + 10], 17, -42063)\n b = md5_ff(b, c, d, a, x[i + 11], 22, -1990404162)\n a = md5_ff(a, b, c, d, x[i + 12], 7, 1804603682)\n d = md5_ff(d, a, b, c, x[i + 13], 12, -40341101)\n c = md5_ff(c, d, a, b, x[i + 14], 17, -1502002290)\n b = md5_ff(b, c, d, a, x[i + 15], 22, 1236535329)\n\n a = md5_gg(a, b, c, d, x[i + 1], 5, -165796510)\n d = md5_gg(d, a, b, c, x[i + 6], 9, -1069501632)\n c = md5_gg(c, d, a, b, x[i + 11], 14, 643717713)\n b = md5_gg(b, c, d, a, x[i + 0], 20, -373897302)\n a = md5_gg(a, b, c, d, x[i + 5], 5, -701558691)\n d = md5_gg(d, a, b, c, x[i + 10], 9, 38016083)\n c = md5_gg(c, d, a, b, x[i + 15], 14, -660478335)\n b = md5_gg(b, c, d, a, x[i + 4], 20, -405537848)\n a = md5_gg(a, b, c, d, x[i + 9], 5, 568446438)\n d = md5_gg(d, a, b, c, x[i + 14], 9, -1019803690)\n c = md5_gg(c, d, a, b, x[i + 3], 14, -187363961)\n b = md5_gg(b, c, d, a, x[i + 8], 20, 1163531501)\n a = md5_gg(a, b, c, d, x[i + 13], 5, -1444681467)\n d = md5_gg(d, a, b, c, x[i + 2], 9, -51403784)\n c = md5_gg(c, d, a, b, x[i + 7], 14, 1735328473)\n b = md5_gg(b, c, d, a, x[i + 12], 20, -1926607734)\n\n a = md5_hh(a, b, c, d, x[i + 5], 4, -378558)\n d = md5_hh(d, a, b, c, x[i + 8], 11, -2022574463)\n c = md5_hh(c, d, a, b, x[i + 11], 16, 1839030562)\n b = md5_hh(b, c, d, a, x[i + 14], 23, -35309556)\n a = md5_hh(a, b, c, d, x[i + 1], 4, -1530992060)\n d = md5_hh(d, a, b, c, x[i + 4], 11, 1272893353)\n c = md5_hh(c, d, a, b, x[i + 7], 16, -155497632)\n b = md5_hh(b, c, d, a, x[i + 10], 23, -1094730640)\n a = md5_hh(a, b, c, d, x[i + 13], 4, 681279174)\n d = md5_hh(d, a, b, c, x[i + 0], 11, -358537222)\n c = md5_hh(c, d, a, b, x[i + 3], 16, -722521979)\n b = md5_hh(b, c, d, a, x[i + 6], 23, 76029189)\n a = md5_hh(a, b, c, d, x[i + 9], 4, -640364487)\n d = md5_hh(d, a, b, c, x[i + 12], 11, -421815835)\n c = md5_hh(c, d, a, b, x[i + 15], 16, 530742520)\n b = md5_hh(b, c, d, a, x[i + 2], 23, -995338651)\n\n a = md5_ii(a, b, c, d, x[i + 0], 6, -198630844)\n d = md5_ii(d, a, b, c, x[i + 7], 10, 1126891415)\n c = md5_ii(c, d, a, b, x[i + 14], 15, -1416354905)\n b = md5_ii(b, c, d, a, x[i + 5], 21, -57434055)\n a = md5_ii(a, b, c, d, x[i + 12], 6, 1700485571)\n d = md5_ii(d, a, b, c, x[i + 3], 10, -1894986606)\n c = md5_ii(c, d, a, b, x[i + 10], 15, -1051523)\n b = md5_ii(b, c, d, a, x[i + 1], 21, -2054922799)\n a = md5_ii(a, b, c, d, x[i + 8], 6, 1873313359)\n d = md5_ii(d, a, b, c, x[i + 15], 10, -30611744)\n c = md5_ii(c, d, a, b, x[i + 6], 15, -1560198380)\n b = md5_ii(b, c, d, a, x[i + 13], 21, 1309151649)\n a = md5_ii(a, b, c, d, x[i + 4], 6, -145523070)\n d = md5_ii(d, a, b, c, x[i + 11], 10, -1120210379)\n c = md5_ii(c, d, a, b, x[i + 2], 15, 718787259)\n b = md5_ii(b, c, d, a, x[i + 9], 21, -343485551)\n\n a = safe_add(a, olda)\n b = safe_add(b, oldb)\n c = safe_add(c, oldc)\n d = safe_add(d, oldd)\n }\n\n return [a, b, c, d]\n}\n\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\nfunction md5_cmn (q, a, b, x, s, t) {\n return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s), b)\n}\n\nfunction md5_ff (a, b, c, d, x, s, t) {\n return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t)\n}\n\nfunction md5_gg (a, b, c, d, x, s, t) {\n return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t)\n}\n\nfunction md5_hh (a, b, c, d, x, s, t) {\n return md5_cmn(b ^ c ^ d, a, b, x, s, t)\n}\n\nfunction md5_ii (a, b, c, d, x, s, t) {\n return md5_cmn(c ^ (b | (~d)), a, b, x, s, t)\n}\n\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\nfunction safe_add (x, y) {\n var lsw = (x & 0xFFFF) + (y & 0xFFFF)\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16)\n return (msw << 16) | (lsw & 0xFFFF)\n}\n\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\nfunction bit_rol (num, cnt) {\n return (num << cnt) | (num >>> (32 - cnt))\n}\n\nmodule.exports = function md5 (buf) {\n return makeHash(buf, core_md5)\n}\n","'use strict'\nvar Transform = require('stream').Transform\nvar inherits = require('inherits')\n\nfunction HashBase (blockSize) {\n Transform.call(this)\n\n this._block = new Buffer(blockSize)\n this._blockSize = blockSize\n this._blockOffset = 0\n this._length = [0, 0, 0, 0]\n\n this._finalized = false\n}\n\ninherits(HashBase, Transform)\n\nHashBase.prototype._transform = function (chunk, encoding, callback) {\n var error = null\n try {\n if (encoding !== 'buffer') chunk = new Buffer(chunk, encoding)\n this.update(chunk)\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nHashBase.prototype._flush = function (callback) {\n var error = null\n try {\n this.push(this._digest())\n } catch (err) {\n error = err\n }\n\n callback(error)\n}\n\nHashBase.prototype.update = function (data, encoding) {\n if (!Buffer.isBuffer(data) && typeof data !== 'string') throw new TypeError('Data must be a string or a buffer')\n if (this._finalized) throw new Error('Digest already called')\n if (!Buffer.isBuffer(data)) data = new Buffer(data, encoding || 'binary')\n\n // consume data\n var block = this._block\n var offset = 0\n while (this._blockOffset + data.length - offset >= this._blockSize) {\n for (var i = this._blockOffset; i < this._blockSize;) block[i++] = data[offset++]\n this._update()\n this._blockOffset = 0\n }\n while (offset < data.length) block[this._blockOffset++] = data[offset++]\n\n // update length\n for (var j = 0, carry = data.length * 8; carry > 0; ++j) {\n this._length[j] += carry\n carry = (this._length[j] / 0x0100000000) | 0\n if (carry > 0) this._length[j] -= 0x0100000000 * carry\n }\n\n return this\n}\n\nHashBase.prototype._update = function (data) {\n throw new Error('_update is not implemented')\n}\n\nHashBase.prototype.digest = function (encoding) {\n if (this._finalized) throw new Error('Digest already called')\n this._finalized = true\n\n var digest = this._digest()\n if (encoding !== undefined) digest = digest.toString(encoding)\n return digest\n}\n\nHashBase.prototype._digest = function () {\n throw new Error('_digest is not implemented')\n}\n\nmodule.exports = HashBase\n","'use strict'\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\n\nfunction RIPEMD160 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n this._e = 0xc3d2e1f0\n}\n\ninherits(RIPEMD160, HashBase)\n\nRIPEMD160.prototype._update = function () {\n var m = new Array(16)\n for (var i = 0; i < 16; ++i) m[i] = this._block.readInt32LE(i * 4)\n\n var al = this._a\n var bl = this._b\n var cl = this._c\n var dl = this._d\n var el = this._e\n\n // Mj = 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15\n // K = 0x00000000\n // Sj = 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8\n al = fn1(al, bl, cl, dl, el, m[0], 0x00000000, 11); cl = rotl(cl, 10)\n el = fn1(el, al, bl, cl, dl, m[1], 0x00000000, 14); bl = rotl(bl, 10)\n dl = fn1(dl, el, al, bl, cl, m[2], 0x00000000, 15); al = rotl(al, 10)\n cl = fn1(cl, dl, el, al, bl, m[3], 0x00000000, 12); el = rotl(el, 10)\n bl = fn1(bl, cl, dl, el, al, m[4], 0x00000000, 5); dl = rotl(dl, 10)\n al = fn1(al, bl, cl, dl, el, m[5], 0x00000000, 8); cl = rotl(cl, 10)\n el = fn1(el, al, bl, cl, dl, m[6], 0x00000000, 7); bl = rotl(bl, 10)\n dl = fn1(dl, el, al, bl, cl, m[7], 0x00000000, 9); al = rotl(al, 10)\n cl = fn1(cl, dl, el, al, bl, m[8], 0x00000000, 11); el = rotl(el, 10)\n bl = fn1(bl, cl, dl, el, al, m[9], 0x00000000, 13); dl = rotl(dl, 10)\n al = fn1(al, bl, cl, dl, el, m[10], 0x00000000, 14); cl = rotl(cl, 10)\n el = fn1(el, al, bl, cl, dl, m[11], 0x00000000, 15); bl = rotl(bl, 10)\n dl = fn1(dl, el, al, bl, cl, m[12], 0x00000000, 6); al = rotl(al, 10)\n cl = fn1(cl, dl, el, al, bl, m[13], 0x00000000, 7); el = rotl(el, 10)\n bl = fn1(bl, cl, dl, el, al, m[14], 0x00000000, 9); dl = rotl(dl, 10)\n al = fn1(al, bl, cl, dl, el, m[15], 0x00000000, 8); cl = rotl(cl, 10)\n\n // Mj = 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8\n // K = 0x5a827999\n // Sj = 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12\n el = fn2(el, al, bl, cl, dl, m[7], 0x5a827999, 7); bl = rotl(bl, 10)\n dl = fn2(dl, el, al, bl, cl, m[4], 0x5a827999, 6); al = rotl(al, 10)\n cl = fn2(cl, dl, el, al, bl, m[13], 0x5a827999, 8); el = rotl(el, 10)\n bl = fn2(bl, cl, dl, el, al, m[1], 0x5a827999, 13); dl = rotl(dl, 10)\n al = fn2(al, bl, cl, dl, el, m[10], 0x5a827999, 11); cl = rotl(cl, 10)\n el = fn2(el, al, bl, cl, dl, m[6], 0x5a827999, 9); bl = rotl(bl, 10)\n dl = fn2(dl, el, al, bl, cl, m[15], 0x5a827999, 7); al = rotl(al, 10)\n cl = fn2(cl, dl, el, al, bl, m[3], 0x5a827999, 15); el = rotl(el, 10)\n bl = fn2(bl, cl, dl, el, al, m[12], 0x5a827999, 7); dl = rotl(dl, 10)\n al = fn2(al, bl, cl, dl, el, m[0], 0x5a827999, 12); cl = rotl(cl, 10)\n el = fn2(el, al, bl, cl, dl, m[9], 0x5a827999, 15); bl = rotl(bl, 10)\n dl = fn2(dl, el, al, bl, cl, m[5], 0x5a827999, 9); al = rotl(al, 10)\n cl = fn2(cl, dl, el, al, bl, m[2], 0x5a827999, 11); el = rotl(el, 10)\n bl = fn2(bl, cl, dl, el, al, m[14], 0x5a827999, 7); dl = rotl(dl, 10)\n al = fn2(al, bl, cl, dl, el, m[11], 0x5a827999, 13); cl = rotl(cl, 10)\n el = fn2(el, al, bl, cl, dl, m[8], 0x5a827999, 12); bl = rotl(bl, 10)\n\n // Mj = 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12\n // K = 0x6ed9eba1\n // Sj = 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5\n dl = fn3(dl, el, al, bl, cl, m[3], 0x6ed9eba1, 11); al = rotl(al, 10)\n cl = fn3(cl, dl, el, al, bl, m[10], 0x6ed9eba1, 13); el = rotl(el, 10)\n bl = fn3(bl, cl, dl, el, al, m[14], 0x6ed9eba1, 6); dl = rotl(dl, 10)\n al = fn3(al, bl, cl, dl, el, m[4], 0x6ed9eba1, 7); cl = rotl(cl, 10)\n el = fn3(el, al, bl, cl, dl, m[9], 0x6ed9eba1, 14); bl = rotl(bl, 10)\n dl = fn3(dl, el, al, bl, cl, m[15], 0x6ed9eba1, 9); al = rotl(al, 10)\n cl = fn3(cl, dl, el, al, bl, m[8], 0x6ed9eba1, 13); el = rotl(el, 10)\n bl = fn3(bl, cl, dl, el, al, m[1], 0x6ed9eba1, 15); dl = rotl(dl, 10)\n al = fn3(al, bl, cl, dl, el, m[2], 0x6ed9eba1, 14); cl = rotl(cl, 10)\n el = fn3(el, al, bl, cl, dl, m[7], 0x6ed9eba1, 8); bl = rotl(bl, 10)\n dl = fn3(dl, el, al, bl, cl, m[0], 0x6ed9eba1, 13); al = rotl(al, 10)\n cl = fn3(cl, dl, el, al, bl, m[6], 0x6ed9eba1, 6); el = rotl(el, 10)\n bl = fn3(bl, cl, dl, el, al, m[13], 0x6ed9eba1, 5); dl = rotl(dl, 10)\n al = fn3(al, bl, cl, dl, el, m[11], 0x6ed9eba1, 12); cl = rotl(cl, 10)\n el = fn3(el, al, bl, cl, dl, m[5], 0x6ed9eba1, 7); bl = rotl(bl, 10)\n dl = fn3(dl, el, al, bl, cl, m[12], 0x6ed9eba1, 5); al = rotl(al, 10)\n\n // Mj = 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2\n // K = 0x8f1bbcdc\n // Sj = 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12\n cl = fn4(cl, dl, el, al, bl, m[1], 0x8f1bbcdc, 11); el = rotl(el, 10)\n bl = fn4(bl, cl, dl, el, al, m[9], 0x8f1bbcdc, 12); dl = rotl(dl, 10)\n al = fn4(al, bl, cl, dl, el, m[11], 0x8f1bbcdc, 14); cl = rotl(cl, 10)\n el = fn4(el, al, bl, cl, dl, m[10], 0x8f1bbcdc, 15); bl = rotl(bl, 10)\n dl = fn4(dl, el, al, bl, cl, m[0], 0x8f1bbcdc, 14); al = rotl(al, 10)\n cl = fn4(cl, dl, el, al, bl, m[8], 0x8f1bbcdc, 15); el = rotl(el, 10)\n bl = fn4(bl, cl, dl, el, al, m[12], 0x8f1bbcdc, 9); dl = rotl(dl, 10)\n al = fn4(al, bl, cl, dl, el, m[4], 0x8f1bbcdc, 8); cl = rotl(cl, 10)\n el = fn4(el, al, bl, cl, dl, m[13], 0x8f1bbcdc, 9); bl = rotl(bl, 10)\n dl = fn4(dl, el, al, bl, cl, m[3], 0x8f1bbcdc, 14); al = rotl(al, 10)\n cl = fn4(cl, dl, el, al, bl, m[7], 0x8f1bbcdc, 5); el = rotl(el, 10)\n bl = fn4(bl, cl, dl, el, al, m[15], 0x8f1bbcdc, 6); dl = rotl(dl, 10)\n al = fn4(al, bl, cl, dl, el, m[14], 0x8f1bbcdc, 8); cl = rotl(cl, 10)\n el = fn4(el, al, bl, cl, dl, m[5], 0x8f1bbcdc, 6); bl = rotl(bl, 10)\n dl = fn4(dl, el, al, bl, cl, m[6], 0x8f1bbcdc, 5); al = rotl(al, 10)\n cl = fn4(cl, dl, el, al, bl, m[2], 0x8f1bbcdc, 12); el = rotl(el, 10)\n\n // Mj = 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n // K = 0xa953fd4e\n // Sj = 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n bl = fn5(bl, cl, dl, el, al, m[4], 0xa953fd4e, 9); dl = rotl(dl, 10)\n al = fn5(al, bl, cl, dl, el, m[0], 0xa953fd4e, 15); cl = rotl(cl, 10)\n el = fn5(el, al, bl, cl, dl, m[5], 0xa953fd4e, 5); bl = rotl(bl, 10)\n dl = fn5(dl, el, al, bl, cl, m[9], 0xa953fd4e, 11); al = rotl(al, 10)\n cl = fn5(cl, dl, el, al, bl, m[7], 0xa953fd4e, 6); el = rotl(el, 10)\n bl = fn5(bl, cl, dl, el, al, m[12], 0xa953fd4e, 8); dl = rotl(dl, 10)\n al = fn5(al, bl, cl, dl, el, m[2], 0xa953fd4e, 13); cl = rotl(cl, 10)\n el = fn5(el, al, bl, cl, dl, m[10], 0xa953fd4e, 12); bl = rotl(bl, 10)\n dl = fn5(dl, el, al, bl, cl, m[14], 0xa953fd4e, 5); al = rotl(al, 10)\n cl = fn5(cl, dl, el, al, bl, m[1], 0xa953fd4e, 12); el = rotl(el, 10)\n bl = fn5(bl, cl, dl, el, al, m[3], 0xa953fd4e, 13); dl = rotl(dl, 10)\n al = fn5(al, bl, cl, dl, el, m[8], 0xa953fd4e, 14); cl = rotl(cl, 10)\n el = fn5(el, al, bl, cl, dl, m[11], 0xa953fd4e, 11); bl = rotl(bl, 10)\n dl = fn5(dl, el, al, bl, cl, m[6], 0xa953fd4e, 8); al = rotl(al, 10)\n cl = fn5(cl, dl, el, al, bl, m[15], 0xa953fd4e, 5); el = rotl(el, 10)\n bl = fn5(bl, cl, dl, el, al, m[13], 0xa953fd4e, 6); dl = rotl(dl, 10)\n\n var ar = this._a\n var br = this._b\n var cr = this._c\n var dr = this._d\n var er = this._e\n\n // M'j = 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12\n // K' = 0x50a28be6\n // S'j = 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6\n ar = fn5(ar, br, cr, dr, er, m[5], 0x50a28be6, 8); cr = rotl(cr, 10)\n er = fn5(er, ar, br, cr, dr, m[14], 0x50a28be6, 9); br = rotl(br, 10)\n dr = fn5(dr, er, ar, br, cr, m[7], 0x50a28be6, 9); ar = rotl(ar, 10)\n cr = fn5(cr, dr, er, ar, br, m[0], 0x50a28be6, 11); er = rotl(er, 10)\n br = fn5(br, cr, dr, er, ar, m[9], 0x50a28be6, 13); dr = rotl(dr, 10)\n ar = fn5(ar, br, cr, dr, er, m[2], 0x50a28be6, 15); cr = rotl(cr, 10)\n er = fn5(er, ar, br, cr, dr, m[11], 0x50a28be6, 15); br = rotl(br, 10)\n dr = fn5(dr, er, ar, br, cr, m[4], 0x50a28be6, 5); ar = rotl(ar, 10)\n cr = fn5(cr, dr, er, ar, br, m[13], 0x50a28be6, 7); er = rotl(er, 10)\n br = fn5(br, cr, dr, er, ar, m[6], 0x50a28be6, 7); dr = rotl(dr, 10)\n ar = fn5(ar, br, cr, dr, er, m[15], 0x50a28be6, 8); cr = rotl(cr, 10)\n er = fn5(er, ar, br, cr, dr, m[8], 0x50a28be6, 11); br = rotl(br, 10)\n dr = fn5(dr, er, ar, br, cr, m[1], 0x50a28be6, 14); ar = rotl(ar, 10)\n cr = fn5(cr, dr, er, ar, br, m[10], 0x50a28be6, 14); er = rotl(er, 10)\n br = fn5(br, cr, dr, er, ar, m[3], 0x50a28be6, 12); dr = rotl(dr, 10)\n ar = fn5(ar, br, cr, dr, er, m[12], 0x50a28be6, 6); cr = rotl(cr, 10)\n\n // M'j = 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2\n // K' = 0x5c4dd124\n // S'j = 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11\n er = fn4(er, ar, br, cr, dr, m[6], 0x5c4dd124, 9); br = rotl(br, 10)\n dr = fn4(dr, er, ar, br, cr, m[11], 0x5c4dd124, 13); ar = rotl(ar, 10)\n cr = fn4(cr, dr, er, ar, br, m[3], 0x5c4dd124, 15); er = rotl(er, 10)\n br = fn4(br, cr, dr, er, ar, m[7], 0x5c4dd124, 7); dr = rotl(dr, 10)\n ar = fn4(ar, br, cr, dr, er, m[0], 0x5c4dd124, 12); cr = rotl(cr, 10)\n er = fn4(er, ar, br, cr, dr, m[13], 0x5c4dd124, 8); br = rotl(br, 10)\n dr = fn4(dr, er, ar, br, cr, m[5], 0x5c4dd124, 9); ar = rotl(ar, 10)\n cr = fn4(cr, dr, er, ar, br, m[10], 0x5c4dd124, 11); er = rotl(er, 10)\n br = fn4(br, cr, dr, er, ar, m[14], 0x5c4dd124, 7); dr = rotl(dr, 10)\n ar = fn4(ar, br, cr, dr, er, m[15], 0x5c4dd124, 7); cr = rotl(cr, 10)\n er = fn4(er, ar, br, cr, dr, m[8], 0x5c4dd124, 12); br = rotl(br, 10)\n dr = fn4(dr, er, ar, br, cr, m[12], 0x5c4dd124, 7); ar = rotl(ar, 10)\n cr = fn4(cr, dr, er, ar, br, m[4], 0x5c4dd124, 6); er = rotl(er, 10)\n br = fn4(br, cr, dr, er, ar, m[9], 0x5c4dd124, 15); dr = rotl(dr, 10)\n ar = fn4(ar, br, cr, dr, er, m[1], 0x5c4dd124, 13); cr = rotl(cr, 10)\n er = fn4(er, ar, br, cr, dr, m[2], 0x5c4dd124, 11); br = rotl(br, 10)\n\n // M'j = 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13\n // K' = 0x6d703ef3\n // S'j = 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5\n dr = fn3(dr, er, ar, br, cr, m[15], 0x6d703ef3, 9); ar = rotl(ar, 10)\n cr = fn3(cr, dr, er, ar, br, m[5], 0x6d703ef3, 7); er = rotl(er, 10)\n br = fn3(br, cr, dr, er, ar, m[1], 0x6d703ef3, 15); dr = rotl(dr, 10)\n ar = fn3(ar, br, cr, dr, er, m[3], 0x6d703ef3, 11); cr = rotl(cr, 10)\n er = fn3(er, ar, br, cr, dr, m[7], 0x6d703ef3, 8); br = rotl(br, 10)\n dr = fn3(dr, er, ar, br, cr, m[14], 0x6d703ef3, 6); ar = rotl(ar, 10)\n cr = fn3(cr, dr, er, ar, br, m[6], 0x6d703ef3, 6); er = rotl(er, 10)\n br = fn3(br, cr, dr, er, ar, m[9], 0x6d703ef3, 14); dr = rotl(dr, 10)\n ar = fn3(ar, br, cr, dr, er, m[11], 0x6d703ef3, 12); cr = rotl(cr, 10)\n er = fn3(er, ar, br, cr, dr, m[8], 0x6d703ef3, 13); br = rotl(br, 10)\n dr = fn3(dr, er, ar, br, cr, m[12], 0x6d703ef3, 5); ar = rotl(ar, 10)\n cr = fn3(cr, dr, er, ar, br, m[2], 0x6d703ef3, 14); er = rotl(er, 10)\n br = fn3(br, cr, dr, er, ar, m[10], 0x6d703ef3, 13); dr = rotl(dr, 10)\n ar = fn3(ar, br, cr, dr, er, m[0], 0x6d703ef3, 13); cr = rotl(cr, 10)\n er = fn3(er, ar, br, cr, dr, m[4], 0x6d703ef3, 7); br = rotl(br, 10)\n dr = fn3(dr, er, ar, br, cr, m[13], 0x6d703ef3, 5); ar = rotl(ar, 10)\n\n // M'j = 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14\n // K' = 0x7a6d76e9\n // S'j = 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8\n cr = fn2(cr, dr, er, ar, br, m[8], 0x7a6d76e9, 15); er = rotl(er, 10)\n br = fn2(br, cr, dr, er, ar, m[6], 0x7a6d76e9, 5); dr = rotl(dr, 10)\n ar = fn2(ar, br, cr, dr, er, m[4], 0x7a6d76e9, 8); cr = rotl(cr, 10)\n er = fn2(er, ar, br, cr, dr, m[1], 0x7a6d76e9, 11); br = rotl(br, 10)\n dr = fn2(dr, er, ar, br, cr, m[3], 0x7a6d76e9, 14); ar = rotl(ar, 10)\n cr = fn2(cr, dr, er, ar, br, m[11], 0x7a6d76e9, 14); er = rotl(er, 10)\n br = fn2(br, cr, dr, er, ar, m[15], 0x7a6d76e9, 6); dr = rotl(dr, 10)\n ar = fn2(ar, br, cr, dr, er, m[0], 0x7a6d76e9, 14); cr = rotl(cr, 10)\n er = fn2(er, ar, br, cr, dr, m[5], 0x7a6d76e9, 6); br = rotl(br, 10)\n dr = fn2(dr, er, ar, br, cr, m[12], 0x7a6d76e9, 9); ar = rotl(ar, 10)\n cr = fn2(cr, dr, er, ar, br, m[2], 0x7a6d76e9, 12); er = rotl(er, 10)\n br = fn2(br, cr, dr, er, ar, m[13], 0x7a6d76e9, 9); dr = rotl(dr, 10)\n ar = fn2(ar, br, cr, dr, er, m[9], 0x7a6d76e9, 12); cr = rotl(cr, 10)\n er = fn2(er, ar, br, cr, dr, m[7], 0x7a6d76e9, 5); br = rotl(br, 10)\n dr = fn2(dr, er, ar, br, cr, m[10], 0x7a6d76e9, 15); ar = rotl(ar, 10)\n cr = fn2(cr, dr, er, ar, br, m[14], 0x7a6d76e9, 8); er = rotl(er, 10)\n\n // M'j = 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n // K' = 0x00000000\n // S'j = 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n br = fn1(br, cr, dr, er, ar, m[12], 0x00000000, 8); dr = rotl(dr, 10)\n ar = fn1(ar, br, cr, dr, er, m[15], 0x00000000, 5); cr = rotl(cr, 10)\n er = fn1(er, ar, br, cr, dr, m[10], 0x00000000, 12); br = rotl(br, 10)\n dr = fn1(dr, er, ar, br, cr, m[4], 0x00000000, 9); ar = rotl(ar, 10)\n cr = fn1(cr, dr, er, ar, br, m[1], 0x00000000, 12); er = rotl(er, 10)\n br = fn1(br, cr, dr, er, ar, m[5], 0x00000000, 5); dr = rotl(dr, 10)\n ar = fn1(ar, br, cr, dr, er, m[8], 0x00000000, 14); cr = rotl(cr, 10)\n er = fn1(er, ar, br, cr, dr, m[7], 0x00000000, 6); br = rotl(br, 10)\n dr = fn1(dr, er, ar, br, cr, m[6], 0x00000000, 8); ar = rotl(ar, 10)\n cr = fn1(cr, dr, er, ar, br, m[2], 0x00000000, 13); er = rotl(er, 10)\n br = fn1(br, cr, dr, er, ar, m[13], 0x00000000, 6); dr = rotl(dr, 10)\n ar = fn1(ar, br, cr, dr, er, m[14], 0x00000000, 5); cr = rotl(cr, 10)\n er = fn1(er, ar, br, cr, dr, m[0], 0x00000000, 15); br = rotl(br, 10)\n dr = fn1(dr, er, ar, br, cr, m[3], 0x00000000, 13); ar = rotl(ar, 10)\n cr = fn1(cr, dr, er, ar, br, m[9], 0x00000000, 11); er = rotl(er, 10)\n br = fn1(br, cr, dr, er, ar, m[11], 0x00000000, 11); dr = rotl(dr, 10)\n\n // change state\n var t = (this._b + cl + dr) | 0\n this._b = (this._c + dl + er) | 0\n this._c = (this._d + el + ar) | 0\n this._d = (this._e + al + br) | 0\n this._e = (this._a + bl + cr) | 0\n this._a = t\n}\n\nRIPEMD160.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = new Buffer(20)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n buffer.writeInt32LE(this._e, 16)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fn1 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn2 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn3 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b | (~c)) ^ d) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn4 (a, b, c, d, e, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + e) | 0\n}\n\nfunction fn5 (a, b, c, d, e, m, k, s) {\n return (rotl((a + (b ^ (c | (~d))) + m + k) | 0, s) + e) | 0\n}\n\nmodule.exports = RIPEMD160\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar toBuffer = require('to-buffer');\n\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = useUint8Array && typeof ArrayBuffer !== 'undefined';\nvar isView = useArrayBuffer && ArrayBuffer.isView;\n\nmodule.exports = function (thing, encoding, name) {\n\tif (\n\t\ttypeof thing === 'string'\n\t\t|| Buffer.isBuffer(thing)\n\t\t|| (useUint8Array && thing instanceof Uint8Array)\n\t\t|| (isView && isView(thing))\n\t) {\n\t\treturn toBuffer(thing, encoding);\n\t}\n\tthrow new TypeError(name + ' must be a string, a Buffer, a Uint8Array, or a DataView');\n};\n","'use strict';\n\nvar md5 = require('create-hash/md5');\nvar RIPEMD160 = require('ripemd160');\nvar sha = require('sha.js');\nvar Buffer = require('safe-buffer').Buffer;\n\nvar checkParameters = require('./precondition');\nvar defaultEncoding = require('./default-encoding');\nvar toBuffer = require('./to-buffer');\n\nvar ZEROS = Buffer.alloc(128);\nvar sizes = {\n\t__proto__: null,\n\tmd5: 16,\n\tsha1: 20,\n\tsha224: 28,\n\tsha256: 32,\n\tsha384: 48,\n\tsha512: 64,\n\t'sha512-256': 32,\n\tripemd160: 20,\n\trmd160: 20\n};\n\nvar mapping = {\n\t__proto__: null,\n\t'sha-1': 'sha1',\n\t'sha-224': 'sha224',\n\t'sha-256': 'sha256',\n\t'sha-384': 'sha384',\n\t'sha-512': 'sha512',\n\t'ripemd-160': 'ripemd160'\n};\n\nfunction rmd160Func(data) {\n\treturn new RIPEMD160().update(data).digest();\n}\n\nfunction getDigest(alg) {\n\tfunction shaFunc(data) {\n\t\treturn sha(alg).update(data).digest();\n\t}\n\n\tif (alg === 'rmd160' || alg === 'ripemd160') {\n\t\treturn rmd160Func;\n\t}\n\tif (alg === 'md5') {\n\t\treturn md5;\n\t}\n\treturn shaFunc;\n}\n\nfunction Hmac(alg, key, saltLen) {\n\tvar hash = getDigest(alg);\n\tvar blocksize = alg === 'sha512' || alg === 'sha384' ? 128 : 64;\n\n\tif (key.length > blocksize) {\n\t\tkey = hash(key);\n\t} else if (key.length < blocksize) {\n\t\tkey = Buffer.concat([key, ZEROS], blocksize);\n\t}\n\n\tvar ipad = Buffer.allocUnsafe(blocksize + sizes[alg]);\n\tvar opad = Buffer.allocUnsafe(blocksize + sizes[alg]);\n\tfor (var i = 0; i < blocksize; i++) {\n\t\tipad[i] = key[i] ^ 0x36;\n\t\topad[i] = key[i] ^ 0x5C;\n\t}\n\n\tvar ipad1 = Buffer.allocUnsafe(blocksize + saltLen + 4);\n\tipad.copy(ipad1, 0, 0, blocksize);\n\tthis.ipad1 = ipad1;\n\tthis.ipad2 = ipad;\n\tthis.opad = opad;\n\tthis.alg = alg;\n\tthis.blocksize = blocksize;\n\tthis.hash = hash;\n\tthis.size = sizes[alg];\n}\n\nHmac.prototype.run = function (data, ipad) {\n\tdata.copy(ipad, this.blocksize);\n\tvar h = this.hash(ipad);\n\th.copy(this.opad, this.blocksize);\n\treturn this.hash(this.opad);\n};\n\nfunction pbkdf2(password, salt, iterations, keylen, digest) {\n\tcheckParameters(iterations, keylen);\n\tpassword = toBuffer(password, defaultEncoding, 'Password');\n\tsalt = toBuffer(salt, defaultEncoding, 'Salt');\n\n\tvar lowerDigest = (digest || 'sha1').toLowerCase();\n\tvar mappedDigest = mapping[lowerDigest] || lowerDigest;\n\tvar size = sizes[mappedDigest];\n\tif (typeof size !== 'number' || !size) {\n\t\tthrow new TypeError('Digest algorithm not supported: ' + digest);\n\t}\n\n\tvar hmac = new Hmac(mappedDigest, password, salt.length);\n\n\tvar DK = Buffer.allocUnsafe(keylen);\n\tvar block1 = Buffer.allocUnsafe(salt.length + 4);\n\tsalt.copy(block1, 0, 0, salt.length);\n\n\tvar destPos = 0;\n\tvar hLen = size;\n\tvar l = Math.ceil(keylen / hLen);\n\n\tfor (var i = 1; i <= l; i++) {\n\t\tblock1.writeUInt32BE(i, salt.length);\n\n\t\tvar T = hmac.run(block1, hmac.ipad1);\n\t\tvar U = T;\n\n\t\tfor (var j = 1; j < iterations; j++) {\n\t\t\tU = hmac.run(U, hmac.ipad2);\n\t\t\tfor (var k = 0; k < hLen; k++) {\n\t\t\t\tT[k] ^= U[k];\n\t\t\t}\n\t\t}\n\n\t\tT.copy(DK, destPos);\n\t\tdestPos += hLen;\n\t}\n\n\treturn DK;\n}\n\nmodule.exports = pbkdf2;\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\n\nvar checkParameters = require('./precondition');\nvar defaultEncoding = require('./default-encoding');\nvar sync = require('./sync');\nvar toBuffer = require('./to-buffer');\n\nvar ZERO_BUF;\nvar subtle = global.crypto && global.crypto.subtle;\nvar toBrowser = {\n\tsha: 'SHA-1',\n\t'sha-1': 'SHA-1',\n\tsha1: 'SHA-1',\n\tsha256: 'SHA-256',\n\t'sha-256': 'SHA-256',\n\tsha384: 'SHA-384',\n\t'sha-384': 'SHA-384',\n\t'sha-512': 'SHA-512',\n\tsha512: 'SHA-512'\n};\nvar checks = [];\nvar nextTick;\nfunction getNextTick() {\n\tif (nextTick) {\n\t\treturn nextTick;\n\t}\n\tif (global.process && global.process.nextTick) {\n\t\tnextTick = global.process.nextTick;\n\t} else if (global.queueMicrotask) {\n\t\tnextTick = global.queueMicrotask;\n\t} else if (global.setImmediate) {\n\t\tnextTick = global.setImmediate;\n\t} else {\n\t\tnextTick = global.setTimeout;\n\t}\n\treturn nextTick;\n}\nfunction browserPbkdf2(password, salt, iterations, length, algo) {\n\treturn subtle.importKey('raw', password, { name: 'PBKDF2' }, false, ['deriveBits']).then(function (key) {\n\t\treturn subtle.deriveBits({\n\t\t\tname: 'PBKDF2',\n\t\t\tsalt: salt,\n\t\t\titerations: iterations,\n\t\t\thash: {\n\t\t\t\tname: algo\n\t\t\t}\n\t\t}, key, length << 3);\n\t}).then(function (res) {\n\t\treturn Buffer.from(res);\n\t});\n}\nfunction checkNative(algo) {\n\tif (global.process && !global.process.browser) {\n\t\treturn Promise.resolve(false);\n\t}\n\tif (!subtle || !subtle.importKey || !subtle.deriveBits) {\n\t\treturn Promise.resolve(false);\n\t}\n\tif (checks[algo] !== undefined) {\n\t\treturn checks[algo];\n\t}\n\tZERO_BUF = ZERO_BUF || Buffer.alloc(8);\n\tvar prom = browserPbkdf2(ZERO_BUF, ZERO_BUF, 10, 128, algo)\n\t\t.then(\n\t\t\tfunction () { return true; },\n\t\t\tfunction () { return false; }\n\t\t);\n\tchecks[algo] = prom;\n\treturn prom;\n}\n\nfunction resolvePromise(promise, callback) {\n\tpromise.then(function (out) {\n\t\tgetNextTick()(function () {\n\t\t\tcallback(null, out);\n\t\t});\n\t}, function (e) {\n\t\tgetNextTick()(function () {\n\t\t\tcallback(e);\n\t\t});\n\t});\n}\nmodule.exports = function (password, salt, iterations, keylen, digest, callback) {\n\tif (typeof digest === 'function') {\n\t\tcallback = digest;\n\t\tdigest = undefined;\n\t}\n\n\tdigest = digest || 'sha1';\n\tvar algo = toBrowser[digest.toLowerCase()];\n\n\tif (!algo || typeof global.Promise !== 'function') {\n\t\tgetNextTick()(function () {\n\t\t\tvar out;\n\t\t\ttry {\n\t\t\t\tout = sync(password, salt, iterations, keylen, digest);\n\t\t\t} catch (e) {\n\t\t\t\tcallback(e);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tcallback(null, out);\n\t\t});\n\t\treturn;\n\t}\n\n\tcheckParameters(iterations, keylen);\n\tpassword = toBuffer(password, defaultEncoding, 'Password');\n\tsalt = toBuffer(salt, defaultEncoding, 'Salt');\n\tif (typeof callback !== 'function') {\n\t\tthrow new Error('No callback provided to pbkdf2');\n\t}\n\n\tresolvePromise(checkNative(algo).then(function (resp) {\n\t\tif (resp) {\n\t\t\treturn browserPbkdf2(password, salt, iterations, keylen, algo);\n\t\t}\n\n\t\treturn sync(password, salt, iterations, keylen, digest);\n\t}), callback);\n};\n","'use strict';\n\nexports.pbkdf2 = require('./lib/async');\nexports.pbkdf2Sync = require('./lib/sync');\n","'use strict';\n\nexports.readUInt32BE = function readUInt32BE(bytes, off) {\n var res = (bytes[0 + off] << 24) |\n (bytes[1 + off] << 16) |\n (bytes[2 + off] << 8) |\n bytes[3 + off];\n return res >>> 0;\n};\n\nexports.writeUInt32BE = function writeUInt32BE(bytes, value, off) {\n bytes[0 + off] = value >>> 24;\n bytes[1 + off] = (value >>> 16) & 0xff;\n bytes[2 + off] = (value >>> 8) & 0xff;\n bytes[3 + off] = value & 0xff;\n};\n\nexports.ip = function ip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n }\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.rip = function rip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 0; i < 4; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n for (var i = 4; i < 8; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.pc1 = function pc1(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n // 7, 15, 23, 31, 39, 47, 55, 63\n // 6, 14, 22, 30, 39, 47, 55, 63\n // 5, 13, 21, 29, 39, 47, 55, 63\n // 4, 12, 20, 28\n for (var i = 7; i >= 5; i--) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n\n // 1, 9, 17, 25, 33, 41, 49, 57\n // 2, 10, 18, 26, 34, 42, 50, 58\n // 3, 11, 19, 27, 35, 43, 51, 59\n // 36, 44, 52, 60\n for (var i = 1; i <= 3; i++) {\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.r28shl = function r28shl(num, shift) {\n return ((num << shift) & 0xfffffff) | (num >>> (28 - shift));\n};\n\nvar pc2table = [\n // inL => outL\n 14, 11, 17, 4, 27, 23, 25, 0,\n 13, 22, 7, 18, 5, 9, 16, 24,\n 2, 20, 12, 21, 1, 8, 15, 26,\n\n // inR => outR\n 15, 4, 25, 19, 9, 1, 26, 16,\n 5, 11, 23, 8, 12, 7, 17, 0,\n 22, 3, 10, 14, 6, 20, 27, 24\n];\n\nexports.pc2 = function pc2(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n var len = pc2table.length >>> 1;\n for (var i = 0; i < len; i++) {\n outL <<= 1;\n outL |= (inL >>> pc2table[i]) & 0x1;\n }\n for (var i = len; i < pc2table.length; i++) {\n outR <<= 1;\n outR |= (inR >>> pc2table[i]) & 0x1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.expand = function expand(r, out, off) {\n var outL = 0;\n var outR = 0;\n\n outL = ((r & 1) << 5) | (r >>> 27);\n for (var i = 23; i >= 15; i -= 4) {\n outL <<= 6;\n outL |= (r >>> i) & 0x3f;\n }\n for (var i = 11; i >= 3; i -= 4) {\n outR |= (r >>> i) & 0x3f;\n outR <<= 6;\n }\n outR |= ((r & 0x1f) << 1) | (r >>> 31);\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nvar sTable = [\n 14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1,\n 3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8,\n 4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7,\n 15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13,\n\n 15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14,\n 9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5,\n 0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2,\n 5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9,\n\n 10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10,\n 1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1,\n 13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7,\n 11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12,\n\n 7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3,\n 1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9,\n 10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8,\n 15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14,\n\n 2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1,\n 8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6,\n 4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13,\n 15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3,\n\n 12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5,\n 0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8,\n 9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10,\n 7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13,\n\n 4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10,\n 3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6,\n 1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7,\n 10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12,\n\n 13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4,\n 10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2,\n 7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13,\n 0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11\n];\n\nexports.substitute = function substitute(inL, inR) {\n var out = 0;\n for (var i = 0; i < 4; i++) {\n var b = (inL >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n for (var i = 0; i < 4; i++) {\n var b = (inR >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[4 * 0x40 + i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n return out >>> 0;\n};\n\nvar permuteTable = [\n 16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22,\n 30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7\n];\n\nexports.permute = function permute(num) {\n var out = 0;\n for (var i = 0; i < permuteTable.length; i++) {\n out <<= 1;\n out |= (num >>> permuteTable[i]) & 0x1;\n }\n return out >>> 0;\n};\n\nexports.padSplit = function padSplit(num, size, group) {\n var str = num.toString(2);\n while (str.length < size)\n str = '0' + str;\n\n var out = [];\n for (var i = 0; i < size; i += group)\n out.push(str.slice(i, i + group));\n return out.join(' ');\n};\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\n\nfunction Cipher(options) {\n this.options = options;\n\n this.type = this.options.type;\n this.blockSize = 8;\n this._init();\n\n this.buffer = new Array(this.blockSize);\n this.bufferOff = 0;\n this.padding = options.padding !== false\n}\nmodule.exports = Cipher;\n\nCipher.prototype._init = function _init() {\n // Might be overrided\n};\n\nCipher.prototype.update = function update(data) {\n if (data.length === 0)\n return [];\n\n if (this.type === 'decrypt')\n return this._updateDecrypt(data);\n else\n return this._updateEncrypt(data);\n};\n\nCipher.prototype._buffer = function _buffer(data, off) {\n // Append data to buffer\n var min = Math.min(this.buffer.length - this.bufferOff, data.length - off);\n for (var i = 0; i < min; i++)\n this.buffer[this.bufferOff + i] = data[off + i];\n this.bufferOff += min;\n\n // Shift next\n return min;\n};\n\nCipher.prototype._flushBuffer = function _flushBuffer(out, off) {\n this._update(this.buffer, 0, out, off);\n this.bufferOff = 0;\n return this.blockSize;\n};\n\nCipher.prototype._updateEncrypt = function _updateEncrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = ((this.bufferOff + data.length) / this.blockSize) | 0;\n var out = new Array(count * this.blockSize);\n\n if (this.bufferOff !== 0) {\n inputOff += this._buffer(data, inputOff);\n\n if (this.bufferOff === this.buffer.length)\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Write blocks\n var max = data.length - ((data.length - inputOff) % this.blockSize);\n for (; inputOff < max; inputOff += this.blockSize) {\n this._update(data, inputOff, out, outputOff);\n outputOff += this.blockSize;\n }\n\n // Queue rest\n for (; inputOff < data.length; inputOff++, this.bufferOff++)\n this.buffer[this.bufferOff] = data[inputOff];\n\n return out;\n};\n\nCipher.prototype._updateDecrypt = function _updateDecrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = Math.ceil((this.bufferOff + data.length) / this.blockSize) - 1;\n var out = new Array(count * this.blockSize);\n\n // TODO(indutny): optimize it, this is far from optimal\n for (; count > 0; count--) {\n inputOff += this._buffer(data, inputOff);\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Buffer rest of the input\n inputOff += this._buffer(data, inputOff);\n\n return out;\n};\n\nCipher.prototype.final = function final(buffer) {\n var first;\n if (buffer)\n first = this.update(buffer);\n\n var last;\n if (this.type === 'encrypt')\n last = this._finalEncrypt();\n else\n last = this._finalDecrypt();\n\n if (first)\n return first.concat(last);\n else\n return last;\n};\n\nCipher.prototype._pad = function _pad(buffer, off) {\n if (off === 0)\n return false;\n\n while (off < buffer.length)\n buffer[off++] = 0;\n\n return true;\n};\n\nCipher.prototype._finalEncrypt = function _finalEncrypt() {\n if (!this._pad(this.buffer, this.bufferOff))\n return [];\n\n var out = new Array(this.blockSize);\n this._update(this.buffer, 0, out, 0);\n return out;\n};\n\nCipher.prototype._unpad = function _unpad(buffer) {\n return buffer;\n};\n\nCipher.prototype._finalDecrypt = function _finalDecrypt() {\n assert.equal(this.bufferOff, this.blockSize, 'Not enough data to decrypt');\n var out = new Array(this.blockSize);\n this._flushBuffer(out, 0);\n\n return this._unpad(out);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar utils = require('./utils');\nvar Cipher = require('./cipher');\n\nfunction DESState() {\n this.tmp = new Array(2);\n this.keys = null;\n}\n\nfunction DES(options) {\n Cipher.call(this, options);\n\n var state = new DESState();\n this._desState = state;\n\n this.deriveKeys(state, options.key);\n}\ninherits(DES, Cipher);\nmodule.exports = DES;\n\nDES.create = function create(options) {\n return new DES(options);\n};\n\nvar shiftTable = [\n 1, 1, 2, 2, 2, 2, 2, 2,\n 1, 2, 2, 2, 2, 2, 2, 1\n];\n\nDES.prototype.deriveKeys = function deriveKeys(state, key) {\n state.keys = new Array(16 * 2);\n\n assert.equal(key.length, this.blockSize, 'Invalid key length');\n\n var kL = utils.readUInt32BE(key, 0);\n var kR = utils.readUInt32BE(key, 4);\n\n utils.pc1(kL, kR, state.tmp, 0);\n kL = state.tmp[0];\n kR = state.tmp[1];\n for (var i = 0; i < state.keys.length; i += 2) {\n var shift = shiftTable[i >>> 1];\n kL = utils.r28shl(kL, shift);\n kR = utils.r28shl(kR, shift);\n utils.pc2(kL, kR, state.keys, i);\n }\n};\n\nDES.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._desState;\n\n var l = utils.readUInt32BE(inp, inOff);\n var r = utils.readUInt32BE(inp, inOff + 4);\n\n // Initial Permutation\n utils.ip(l, r, state.tmp, 0);\n l = state.tmp[0];\n r = state.tmp[1];\n\n if (this.type === 'encrypt')\n this._encrypt(state, l, r, state.tmp, 0);\n else\n this._decrypt(state, l, r, state.tmp, 0);\n\n l = state.tmp[0];\n r = state.tmp[1];\n\n utils.writeUInt32BE(out, l, outOff);\n utils.writeUInt32BE(out, r, outOff + 4);\n};\n\nDES.prototype._pad = function _pad(buffer, off) {\n if (this.padding === false) {\n return false;\n }\n\n var value = buffer.length - off;\n for (var i = off; i < buffer.length; i++)\n buffer[i] = value;\n\n return true;\n};\n\nDES.prototype._unpad = function _unpad(buffer) {\n if (this.padding === false) {\n return buffer;\n }\n\n var pad = buffer[buffer.length - 1];\n for (var i = buffer.length - pad; i < buffer.length; i++)\n assert.equal(buffer[i], pad);\n\n return buffer.slice(0, buffer.length - pad);\n};\n\nDES.prototype._encrypt = function _encrypt(state, lStart, rStart, out, off) {\n var l = lStart;\n var r = rStart;\n\n // Apply f() x16 times\n for (var i = 0; i < state.keys.length; i += 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(r, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = r;\n r = (l ^ f) >>> 0;\n l = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(r, l, out, off);\n};\n\nDES.prototype._decrypt = function _decrypt(state, lStart, rStart, out, off) {\n var l = rStart;\n var r = lStart;\n\n // Apply f() x16 times\n for (var i = state.keys.length - 2; i >= 0; i -= 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(l, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = l;\n l = (r ^ f) >>> 0;\n r = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(l, r, out, off);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar proto = {};\n\nfunction CBCState(iv) {\n assert.equal(iv.length, 8, 'Invalid IV length');\n\n this.iv = new Array(8);\n for (var i = 0; i < this.iv.length; i++)\n this.iv[i] = iv[i];\n}\n\nfunction instantiate(Base) {\n function CBC(options) {\n Base.call(this, options);\n this._cbcInit();\n }\n inherits(CBC, Base);\n\n var keys = Object.keys(proto);\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n CBC.prototype[key] = proto[key];\n }\n\n CBC.create = function create(options) {\n return new CBC(options);\n };\n\n return CBC;\n}\n\nexports.instantiate = instantiate;\n\nproto._cbcInit = function _cbcInit() {\n var state = new CBCState(this.options.iv);\n this._cbcState = state;\n};\n\nproto._update = function _update(inp, inOff, out, outOff) {\n var state = this._cbcState;\n var superProto = this.constructor.super_.prototype;\n\n var iv = state.iv;\n if (this.type === 'encrypt') {\n for (var i = 0; i < this.blockSize; i++)\n iv[i] ^= inp[inOff + i];\n\n superProto._update.call(this, iv, 0, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = out[outOff + i];\n } else {\n superProto._update.call(this, inp, inOff, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n out[outOff + i] ^= iv[i];\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = inp[inOff + i];\n }\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar Cipher = require('./cipher');\nvar DES = require('./des');\n\nfunction EDEState(type, key) {\n assert.equal(key.length, 24, 'Invalid key length');\n\n var k1 = key.slice(0, 8);\n var k2 = key.slice(8, 16);\n var k3 = key.slice(16, 24);\n\n if (type === 'encrypt') {\n this.ciphers = [\n DES.create({ type: 'encrypt', key: k1 }),\n DES.create({ type: 'decrypt', key: k2 }),\n DES.create({ type: 'encrypt', key: k3 })\n ];\n } else {\n this.ciphers = [\n DES.create({ type: 'decrypt', key: k3 }),\n DES.create({ type: 'encrypt', key: k2 }),\n DES.create({ type: 'decrypt', key: k1 })\n ];\n }\n}\n\nfunction EDE(options) {\n Cipher.call(this, options);\n\n var state = new EDEState(this.type, this.options.key);\n this._edeState = state;\n}\ninherits(EDE, Cipher);\n\nmodule.exports = EDE;\n\nEDE.create = function create(options) {\n return new EDE(options);\n};\n\nEDE.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._edeState;\n\n state.ciphers[0]._update(inp, inOff, out, outOff);\n state.ciphers[1]._update(out, outOff, out, outOff);\n state.ciphers[2]._update(out, outOff, out, outOff);\n};\n\nEDE.prototype._pad = DES.prototype._pad;\nEDE.prototype._unpad = DES.prototype._unpad;\n","'use strict';\n\nexports.utils = require('./des/utils');\nexports.Cipher = require('./des/cipher');\nexports.DES = require('./des/des');\nexports.CBC = require('./des/cbc');\nexports.EDE = require('./des/ede');\n","var CipherBase = require('cipher-base')\nvar des = require('des.js')\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar modes = {\n 'des-ede3-cbc': des.CBC.instantiate(des.EDE),\n 'des-ede3': des.EDE,\n 'des-ede-cbc': des.CBC.instantiate(des.EDE),\n 'des-ede': des.EDE,\n 'des-cbc': des.CBC.instantiate(des.DES),\n 'des-ecb': des.DES\n}\nmodes.des = modes['des-cbc']\nmodes.des3 = modes['des-ede3-cbc']\nmodule.exports = DES\ninherits(DES, CipherBase)\nfunction DES (opts) {\n CipherBase.call(this)\n var modeName = opts.mode.toLowerCase()\n var mode = modes[modeName]\n var type\n if (opts.decrypt) {\n type = 'decrypt'\n } else {\n type = 'encrypt'\n }\n var key = opts.key\n if (!Buffer.isBuffer(key)) {\n key = Buffer.from(key)\n }\n if (modeName === 'des-ede' || modeName === 'des-ede-cbc') {\n key = Buffer.concat([key, key.slice(0, 8)])\n }\n var iv = opts.iv\n if (!Buffer.isBuffer(iv)) {\n iv = Buffer.from(iv)\n }\n this._des = mode.create({\n key: key,\n iv: iv,\n type: type\n })\n}\nDES.prototype._update = function (data) {\n return Buffer.from(this._des.update(data))\n}\nDES.prototype._final = function () {\n return Buffer.from(this._des.final())\n}\n","exports.encrypt = function (self, block) {\n return self._cipher.encryptBlock(block)\n}\n\nexports.decrypt = function (self, block) {\n return self._cipher.decryptBlock(block)\n}\n","module.exports = function xor (a, b) {\n var length = Math.min(a.length, b.length)\n var buffer = new Buffer(length)\n\n for (var i = 0; i < length; ++i) {\n buffer[i] = a[i] ^ b[i]\n }\n\n return buffer\n}\n","var xor = require('buffer-xor')\n\nexports.encrypt = function (self, block) {\n var data = xor(block, self._prev)\n\n self._prev = self._cipher.encryptBlock(data)\n return self._prev\n}\n\nexports.decrypt = function (self, block) {\n var pad = self._prev\n\n self._prev = block\n var out = self._cipher.decryptBlock(block)\n\n return xor(out, pad)\n}\n","var Buffer = require('safe-buffer').Buffer\nvar xor = require('buffer-xor')\n\nfunction encryptStart (self, data, decrypt) {\n var len = data.length\n var out = xor(data, self._cache)\n self._cache = self._cache.slice(len)\n self._prev = Buffer.concat([self._prev, decrypt ? data : out])\n return out\n}\n\nexports.encrypt = function (self, data, decrypt) {\n var out = Buffer.allocUnsafe(0)\n var len\n\n while (data.length) {\n if (self._cache.length === 0) {\n self._cache = self._cipher.encryptBlock(self._prev)\n self._prev = Buffer.allocUnsafe(0)\n }\n\n if (self._cache.length <= data.length) {\n len = self._cache.length\n out = Buffer.concat([out, encryptStart(self, data.slice(0, len), decrypt)])\n data = data.slice(len)\n } else {\n out = Buffer.concat([out, encryptStart(self, data, decrypt)])\n break\n }\n }\n\n return out\n}\n","var Buffer = require('safe-buffer').Buffer\n\nfunction encryptByte (self, byteParam, decrypt) {\n var pad = self._cipher.encryptBlock(self._prev)\n var out = pad[0] ^ byteParam\n\n self._prev = Buffer.concat([\n self._prev.slice(1),\n Buffer.from([decrypt ? byteParam : out])\n ])\n\n return out\n}\n\nexports.encrypt = function (self, chunk, decrypt) {\n var len = chunk.length\n var out = Buffer.allocUnsafe(len)\n var i = -1\n\n while (++i < len) {\n out[i] = encryptByte(self, chunk[i], decrypt)\n }\n\n return out\n}\n","var Buffer = require('safe-buffer').Buffer\n\nfunction encryptByte (self, byteParam, decrypt) {\n var pad\n var i = -1\n var len = 8\n var out = 0\n var bit, value\n while (++i < len) {\n pad = self._cipher.encryptBlock(self._prev)\n bit = (byteParam & (1 << (7 - i))) ? 0x80 : 0\n value = pad[0] ^ bit\n out += ((value & 0x80) >> (i % 8))\n self._prev = shiftIn(self._prev, decrypt ? bit : value)\n }\n return out\n}\n\nfunction shiftIn (buffer, value) {\n var len = buffer.length\n var i = -1\n var out = Buffer.allocUnsafe(buffer.length)\n buffer = Buffer.concat([buffer, Buffer.from([value])])\n\n while (++i < len) {\n out[i] = buffer[i] << 1 | buffer[i + 1] >> (7)\n }\n\n return out\n}\n\nexports.encrypt = function (self, chunk, decrypt) {\n var len = chunk.length\n var out = Buffer.allocUnsafe(len)\n var i = -1\n\n while (++i < len) {\n out[i] = encryptByte(self, chunk[i], decrypt)\n }\n\n return out\n}\n","var xor = require('buffer-xor')\n\nfunction getBlock (self) {\n self._prev = self._cipher.encryptBlock(self._prev)\n return self._prev\n}\n\nexports.encrypt = function (self, chunk) {\n while (self._cache.length < chunk.length) {\n self._cache = Buffer.concat([self._cache, getBlock(self)])\n }\n\n var pad = self._cache.slice(0, chunk.length)\n self._cache = self._cache.slice(chunk.length)\n return xor(chunk, pad)\n}\n","function incr32 (iv) {\n var len = iv.length\n var item\n while (len--) {\n item = iv.readUInt8(len)\n if (item === 255) {\n iv.writeUInt8(0, len)\n } else {\n item++\n iv.writeUInt8(item, len)\n break\n }\n }\n}\nmodule.exports = incr32\n","var xor = require('buffer-xor')\nvar Buffer = require('safe-buffer').Buffer\nvar incr32 = require('../incr32')\n\nfunction getBlock (self) {\n var out = self._cipher.encryptBlockRaw(self._prev)\n incr32(self._prev)\n return out\n}\n\nvar blockSize = 16\nexports.encrypt = function (self, chunk) {\n var chunkNum = Math.ceil(chunk.length / blockSize)\n var start = self._cache.length\n self._cache = Buffer.concat([\n self._cache,\n Buffer.allocUnsafe(chunkNum * blockSize)\n ])\n for (var i = 0; i < chunkNum; i++) {\n var out = getBlock(self)\n var offset = start + i * blockSize\n self._cache.writeUInt32BE(out[0], offset + 0)\n self._cache.writeUInt32BE(out[1], offset + 4)\n self._cache.writeUInt32BE(out[2], offset + 8)\n self._cache.writeUInt32BE(out[3], offset + 12)\n }\n var pad = self._cache.slice(0, chunk.length)\n self._cache = self._cache.slice(chunk.length)\n return xor(chunk, pad)\n}\n","var modeModules = {\n ECB: require('./ecb'),\n CBC: require('./cbc'),\n CFB: require('./cfb'),\n CFB8: require('./cfb8'),\n CFB1: require('./cfb1'),\n OFB: require('./ofb'),\n CTR: require('./ctr'),\n GCM: require('./ctr')\n}\n\nvar modes = require('./list.json')\n\nfor (var key in modes) {\n modes[key].module = modeModules[modes[key].mode]\n}\n\nmodule.exports = modes\n","// based on the aes implimentation in triple sec\n// https://github.com/keybase/triplesec\n// which is in turn based on the one from crypto-js\n// https://code.google.com/p/crypto-js/\n\nvar Buffer = require('safe-buffer').Buffer\n\nfunction asUInt32Array (buf) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n\n var len = (buf.length / 4) | 0\n var out = new Array(len)\n\n for (var i = 0; i < len; i++) {\n out[i] = buf.readUInt32BE(i * 4)\n }\n\n return out\n}\n\nfunction scrubVec (v) {\n for (var i = 0; i < v.length; v++) {\n v[i] = 0\n }\n}\n\nfunction cryptBlock (M, keySchedule, SUB_MIX, SBOX, nRounds) {\n var SUB_MIX0 = SUB_MIX[0]\n var SUB_MIX1 = SUB_MIX[1]\n var SUB_MIX2 = SUB_MIX[2]\n var SUB_MIX3 = SUB_MIX[3]\n\n var s0 = M[0] ^ keySchedule[0]\n var s1 = M[1] ^ keySchedule[1]\n var s2 = M[2] ^ keySchedule[2]\n var s3 = M[3] ^ keySchedule[3]\n var t0, t1, t2, t3\n var ksRow = 4\n\n for (var round = 1; round < nRounds; round++) {\n t0 = SUB_MIX0[s0 >>> 24] ^ SUB_MIX1[(s1 >>> 16) & 0xff] ^ SUB_MIX2[(s2 >>> 8) & 0xff] ^ SUB_MIX3[s3 & 0xff] ^ keySchedule[ksRow++]\n t1 = SUB_MIX0[s1 >>> 24] ^ SUB_MIX1[(s2 >>> 16) & 0xff] ^ SUB_MIX2[(s3 >>> 8) & 0xff] ^ SUB_MIX3[s0 & 0xff] ^ keySchedule[ksRow++]\n t2 = SUB_MIX0[s2 >>> 24] ^ SUB_MIX1[(s3 >>> 16) & 0xff] ^ SUB_MIX2[(s0 >>> 8) & 0xff] ^ SUB_MIX3[s1 & 0xff] ^ keySchedule[ksRow++]\n t3 = SUB_MIX0[s3 >>> 24] ^ SUB_MIX1[(s0 >>> 16) & 0xff] ^ SUB_MIX2[(s1 >>> 8) & 0xff] ^ SUB_MIX3[s2 & 0xff] ^ keySchedule[ksRow++]\n s0 = t0\n s1 = t1\n s2 = t2\n s3 = t3\n }\n\n t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++]\n t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++]\n t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++]\n t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++]\n t0 = t0 >>> 0\n t1 = t1 >>> 0\n t2 = t2 >>> 0\n t3 = t3 >>> 0\n\n return [t0, t1, t2, t3]\n}\n\n// AES constants\nvar RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36]\nvar G = (function () {\n // Compute double table\n var d = new Array(256)\n for (var j = 0; j < 256; j++) {\n if (j < 128) {\n d[j] = j << 1\n } else {\n d[j] = (j << 1) ^ 0x11b\n }\n }\n\n var SBOX = []\n var INV_SBOX = []\n var SUB_MIX = [[], [], [], []]\n var INV_SUB_MIX = [[], [], [], []]\n\n // Walk GF(2^8)\n var x = 0\n var xi = 0\n for (var i = 0; i < 256; ++i) {\n // Compute sbox\n var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4)\n sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63\n SBOX[x] = sx\n INV_SBOX[sx] = x\n\n // Compute multiplication\n var x2 = d[x]\n var x4 = d[x2]\n var x8 = d[x4]\n\n // Compute sub bytes, mix columns tables\n var t = (d[sx] * 0x101) ^ (sx * 0x1010100)\n SUB_MIX[0][x] = (t << 24) | (t >>> 8)\n SUB_MIX[1][x] = (t << 16) | (t >>> 16)\n SUB_MIX[2][x] = (t << 8) | (t >>> 24)\n SUB_MIX[3][x] = t\n\n // Compute inv sub bytes, inv mix columns tables\n t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100)\n INV_SUB_MIX[0][sx] = (t << 24) | (t >>> 8)\n INV_SUB_MIX[1][sx] = (t << 16) | (t >>> 16)\n INV_SUB_MIX[2][sx] = (t << 8) | (t >>> 24)\n INV_SUB_MIX[3][sx] = t\n\n if (x === 0) {\n x = xi = 1\n } else {\n x = x2 ^ d[d[d[x8 ^ x2]]]\n xi ^= d[d[xi]]\n }\n }\n\n return {\n SBOX: SBOX,\n INV_SBOX: INV_SBOX,\n SUB_MIX: SUB_MIX,\n INV_SUB_MIX: INV_SUB_MIX\n }\n})()\n\nfunction AES (key) {\n this._key = asUInt32Array(key)\n this._reset()\n}\n\nAES.blockSize = 4 * 4\nAES.keySize = 256 / 8\nAES.prototype.blockSize = AES.blockSize\nAES.prototype.keySize = AES.keySize\nAES.prototype._reset = function () {\n var keyWords = this._key\n var keySize = keyWords.length\n var nRounds = keySize + 6\n var ksRows = (nRounds + 1) * 4\n\n var keySchedule = []\n for (var k = 0; k < keySize; k++) {\n keySchedule[k] = keyWords[k]\n }\n\n for (k = keySize; k < ksRows; k++) {\n var t = keySchedule[k - 1]\n\n if (k % keySize === 0) {\n t = (t << 8) | (t >>> 24)\n t =\n (G.SBOX[t >>> 24] << 24) |\n (G.SBOX[(t >>> 16) & 0xff] << 16) |\n (G.SBOX[(t >>> 8) & 0xff] << 8) |\n (G.SBOX[t & 0xff])\n\n t ^= RCON[(k / keySize) | 0] << 24\n } else if (keySize > 6 && k % keySize === 4) {\n t =\n (G.SBOX[t >>> 24] << 24) |\n (G.SBOX[(t >>> 16) & 0xff] << 16) |\n (G.SBOX[(t >>> 8) & 0xff] << 8) |\n (G.SBOX[t & 0xff])\n }\n\n keySchedule[k] = keySchedule[k - keySize] ^ t\n }\n\n var invKeySchedule = []\n for (var ik = 0; ik < ksRows; ik++) {\n var ksR = ksRows - ik\n var tt = keySchedule[ksR - (ik % 4 ? 0 : 4)]\n\n if (ik < 4 || ksR <= 4) {\n invKeySchedule[ik] = tt\n } else {\n invKeySchedule[ik] =\n G.INV_SUB_MIX[0][G.SBOX[tt >>> 24]] ^\n G.INV_SUB_MIX[1][G.SBOX[(tt >>> 16) & 0xff]] ^\n G.INV_SUB_MIX[2][G.SBOX[(tt >>> 8) & 0xff]] ^\n G.INV_SUB_MIX[3][G.SBOX[tt & 0xff]]\n }\n }\n\n this._nRounds = nRounds\n this._keySchedule = keySchedule\n this._invKeySchedule = invKeySchedule\n}\n\nAES.prototype.encryptBlockRaw = function (M) {\n M = asUInt32Array(M)\n return cryptBlock(M, this._keySchedule, G.SUB_MIX, G.SBOX, this._nRounds)\n}\n\nAES.prototype.encryptBlock = function (M) {\n var out = this.encryptBlockRaw(M)\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0], 0)\n buf.writeUInt32BE(out[1], 4)\n buf.writeUInt32BE(out[2], 8)\n buf.writeUInt32BE(out[3], 12)\n return buf\n}\n\nAES.prototype.decryptBlock = function (M) {\n M = asUInt32Array(M)\n\n // swap\n var m1 = M[1]\n M[1] = M[3]\n M[3] = m1\n\n var out = cryptBlock(M, this._invKeySchedule, G.INV_SUB_MIX, G.INV_SBOX, this._nRounds)\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0], 0)\n buf.writeUInt32BE(out[3], 4)\n buf.writeUInt32BE(out[2], 8)\n buf.writeUInt32BE(out[1], 12)\n return buf\n}\n\nAES.prototype.scrub = function () {\n scrubVec(this._keySchedule)\n scrubVec(this._invKeySchedule)\n scrubVec(this._key)\n}\n\nmodule.exports.AES = AES\n","var Buffer = require('safe-buffer').Buffer\nvar ZEROES = Buffer.alloc(16, 0)\n\nfunction toArray (buf) {\n return [\n buf.readUInt32BE(0),\n buf.readUInt32BE(4),\n buf.readUInt32BE(8),\n buf.readUInt32BE(12)\n ]\n}\n\nfunction fromArray (out) {\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0] >>> 0, 0)\n buf.writeUInt32BE(out[1] >>> 0, 4)\n buf.writeUInt32BE(out[2] >>> 0, 8)\n buf.writeUInt32BE(out[3] >>> 0, 12)\n return buf\n}\n\nfunction GHASH (key) {\n this.h = key\n this.state = Buffer.alloc(16, 0)\n this.cache = Buffer.allocUnsafe(0)\n}\n\n// from http://bitwiseshiftleft.github.io/sjcl/doc/symbols/src/core_gcm.js.html\n// by Juho Vähä-Herttua\nGHASH.prototype.ghash = function (block) {\n var i = -1\n while (++i < block.length) {\n this.state[i] ^= block[i]\n }\n this._multiply()\n}\n\nGHASH.prototype._multiply = function () {\n var Vi = toArray(this.h)\n var Zi = [0, 0, 0, 0]\n var j, xi, lsbVi\n var i = -1\n while (++i < 128) {\n xi = (this.state[~~(i / 8)] & (1 << (7 - (i % 8)))) !== 0\n if (xi) {\n // Z_i+1 = Z_i ^ V_i\n Zi[0] ^= Vi[0]\n Zi[1] ^= Vi[1]\n Zi[2] ^= Vi[2]\n Zi[3] ^= Vi[3]\n }\n\n // Store the value of LSB(V_i)\n lsbVi = (Vi[3] & 1) !== 0\n\n // V_i+1 = V_i >> 1\n for (j = 3; j > 0; j--) {\n Vi[j] = (Vi[j] >>> 1) | ((Vi[j - 1] & 1) << 31)\n }\n Vi[0] = Vi[0] >>> 1\n\n // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R\n if (lsbVi) {\n Vi[0] = Vi[0] ^ (0xe1 << 24)\n }\n }\n this.state = fromArray(Zi)\n}\n\nGHASH.prototype.update = function (buf) {\n this.cache = Buffer.concat([this.cache, buf])\n var chunk\n while (this.cache.length >= 16) {\n chunk = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n this.ghash(chunk)\n }\n}\n\nGHASH.prototype.final = function (abl, bl) {\n if (this.cache.length) {\n this.ghash(Buffer.concat([this.cache, ZEROES], 16))\n }\n\n this.ghash(fromArray([0, abl, 0, bl]))\n return this.state\n}\n\nmodule.exports = GHASH\n","var aes = require('./aes')\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\nvar GHASH = require('./ghash')\nvar xor = require('buffer-xor')\nvar incr32 = require('./incr32')\n\nfunction xorTest (a, b) {\n var out = 0\n if (a.length !== b.length) out++\n\n var len = Math.min(a.length, b.length)\n for (var i = 0; i < len; ++i) {\n out += (a[i] ^ b[i])\n }\n\n return out\n}\n\nfunction calcIv (self, iv, ck) {\n if (iv.length === 12) {\n self._finID = Buffer.concat([iv, Buffer.from([0, 0, 0, 1])])\n return Buffer.concat([iv, Buffer.from([0, 0, 0, 2])])\n }\n var ghash = new GHASH(ck)\n var len = iv.length\n var toPad = len % 16\n ghash.update(iv)\n if (toPad) {\n toPad = 16 - toPad\n ghash.update(Buffer.alloc(toPad, 0))\n }\n ghash.update(Buffer.alloc(8, 0))\n var ivBits = len * 8\n var tail = Buffer.alloc(8)\n tail.writeUIntBE(ivBits, 0, 8)\n ghash.update(tail)\n self._finID = ghash.state\n var out = Buffer.from(self._finID)\n incr32(out)\n return out\n}\nfunction StreamCipher (mode, key, iv, decrypt) {\n Transform.call(this)\n\n var h = Buffer.alloc(4, 0)\n\n this._cipher = new aes.AES(key)\n var ck = this._cipher.encryptBlock(h)\n this._ghash = new GHASH(ck)\n iv = calcIv(this, iv, ck)\n\n this._prev = Buffer.from(iv)\n this._cache = Buffer.allocUnsafe(0)\n this._secCache = Buffer.allocUnsafe(0)\n this._decrypt = decrypt\n this._alen = 0\n this._len = 0\n this._mode = mode\n\n this._authTag = null\n this._called = false\n}\n\ninherits(StreamCipher, Transform)\n\nStreamCipher.prototype._update = function (chunk) {\n if (!this._called && this._alen) {\n var rump = 16 - (this._alen % 16)\n if (rump < 16) {\n rump = Buffer.alloc(rump, 0)\n this._ghash.update(rump)\n }\n }\n\n this._called = true\n var out = this._mode.encrypt(this, chunk)\n if (this._decrypt) {\n this._ghash.update(chunk)\n } else {\n this._ghash.update(out)\n }\n this._len += chunk.length\n return out\n}\n\nStreamCipher.prototype._final = function () {\n if (this._decrypt && !this._authTag) throw new Error('Unsupported state or unable to authenticate data')\n\n var tag = xor(this._ghash.final(this._alen * 8, this._len * 8), this._cipher.encryptBlock(this._finID))\n if (this._decrypt && xorTest(tag, this._authTag)) throw new Error('Unsupported state or unable to authenticate data')\n\n this._authTag = tag\n this._cipher.scrub()\n}\n\nStreamCipher.prototype.getAuthTag = function getAuthTag () {\n if (this._decrypt || !Buffer.isBuffer(this._authTag)) throw new Error('Attempting to get auth tag in unsupported state')\n\n return this._authTag\n}\n\nStreamCipher.prototype.setAuthTag = function setAuthTag (tag) {\n if (!this._decrypt) throw new Error('Attempting to set auth tag in unsupported state')\n\n this._authTag = tag\n}\n\nStreamCipher.prototype.setAAD = function setAAD (buf) {\n if (this._called) throw new Error('Attempting to set AAD in unsupported state')\n\n this._ghash.update(buf)\n this._alen += buf.length\n}\n\nmodule.exports = StreamCipher\n","var aes = require('./aes')\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\n\nfunction StreamCipher (mode, key, iv, decrypt) {\n Transform.call(this)\n\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._cache = Buffer.allocUnsafe(0)\n this._secCache = Buffer.allocUnsafe(0)\n this._decrypt = decrypt\n this._mode = mode\n}\n\ninherits(StreamCipher, Transform)\n\nStreamCipher.prototype._update = function (chunk) {\n return this._mode.encrypt(this, chunk, this._decrypt)\n}\n\nStreamCipher.prototype._final = function () {\n this._cipher.scrub()\n}\n\nmodule.exports = StreamCipher\n","var Buffer = require('safe-buffer').Buffer\nvar MD5 = require('md5.js')\n\n/* eslint-disable camelcase */\nfunction EVP_BytesToKey (password, salt, keyBits, ivLen) {\n if (!Buffer.isBuffer(password)) password = Buffer.from(password, 'binary')\n if (salt) {\n if (!Buffer.isBuffer(salt)) salt = Buffer.from(salt, 'binary')\n if (salt.length !== 8) throw new RangeError('salt should be Buffer with 8 byte length')\n }\n\n var keyLen = keyBits / 8\n var key = Buffer.alloc(keyLen)\n var iv = Buffer.alloc(ivLen || 0)\n var tmp = Buffer.alloc(0)\n\n while (keyLen > 0 || ivLen > 0) {\n var hash = new MD5()\n hash.update(tmp)\n hash.update(password)\n if (salt) hash.update(salt)\n tmp = hash.digest()\n\n var used = 0\n\n if (keyLen > 0) {\n var keyStart = key.length - keyLen\n used = Math.min(keyLen, tmp.length)\n tmp.copy(key, keyStart, 0, used)\n keyLen -= used\n }\n\n if (used < tmp.length && ivLen > 0) {\n var ivStart = iv.length - ivLen\n var length = Math.min(ivLen, tmp.length - used)\n tmp.copy(iv, ivStart, used, used + length)\n ivLen -= length\n }\n }\n\n tmp.fill(0)\n return { key: key, iv: iv }\n}\n\nmodule.exports = EVP_BytesToKey\n","var MODES = require('./modes')\nvar AuthCipher = require('./authCipher')\nvar Buffer = require('safe-buffer').Buffer\nvar StreamCipher = require('./streamCipher')\nvar Transform = require('cipher-base')\nvar aes = require('./aes')\nvar ebtk = require('evp_bytestokey')\nvar inherits = require('inherits')\n\nfunction Cipher (mode, key, iv) {\n Transform.call(this)\n\n this._cache = new Splitter()\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._mode = mode\n this._autopadding = true\n}\n\ninherits(Cipher, Transform)\n\nCipher.prototype._update = function (data) {\n this._cache.add(data)\n var chunk\n var thing\n var out = []\n\n while ((chunk = this._cache.get())) {\n thing = this._mode.encrypt(this, chunk)\n out.push(thing)\n }\n\n return Buffer.concat(out)\n}\n\nvar PADDING = Buffer.alloc(16, 0x10)\n\nCipher.prototype._final = function () {\n var chunk = this._cache.flush()\n if (this._autopadding) {\n chunk = this._mode.encrypt(this, chunk)\n this._cipher.scrub()\n return chunk\n }\n\n if (!chunk.equals(PADDING)) {\n this._cipher.scrub()\n throw new Error('data not multiple of block length')\n }\n}\n\nCipher.prototype.setAutoPadding = function (setTo) {\n this._autopadding = !!setTo\n return this\n}\n\nfunction Splitter () {\n this.cache = Buffer.allocUnsafe(0)\n}\n\nSplitter.prototype.add = function (data) {\n this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function () {\n if (this.cache.length > 15) {\n var out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n return null\n}\n\nSplitter.prototype.flush = function () {\n var len = 16 - this.cache.length\n var padBuff = Buffer.allocUnsafe(len)\n\n var i = -1\n while (++i < len) {\n padBuff.writeUInt8(len, i)\n }\n\n return Buffer.concat([this.cache, padBuff])\n}\n\nfunction createCipheriv (suite, password, iv) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n if (typeof password === 'string') password = Buffer.from(password)\n if (password.length !== config.key / 8) throw new TypeError('invalid key length ' + password.length)\n\n if (typeof iv === 'string') iv = Buffer.from(iv)\n if (config.mode !== 'GCM' && iv.length !== config.iv) throw new TypeError('invalid iv length ' + iv.length)\n\n if (config.type === 'stream') {\n return new StreamCipher(config.module, password, iv)\n } else if (config.type === 'auth') {\n return new AuthCipher(config.module, password, iv)\n }\n\n return new Cipher(config.module, password, iv)\n}\n\nfunction createCipher (suite, password) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n var keys = ebtk(password, false, config.key, config.iv)\n return createCipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createCipheriv = createCipheriv\nexports.createCipher = createCipher\n","var AuthCipher = require('./authCipher')\nvar Buffer = require('safe-buffer').Buffer\nvar MODES = require('./modes')\nvar StreamCipher = require('./streamCipher')\nvar Transform = require('cipher-base')\nvar aes = require('./aes')\nvar ebtk = require('evp_bytestokey')\nvar inherits = require('inherits')\n\nfunction Decipher (mode, key, iv) {\n Transform.call(this)\n\n this._cache = new Splitter()\n this._last = void 0\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._mode = mode\n this._autopadding = true\n}\n\ninherits(Decipher, Transform)\n\nDecipher.prototype._update = function (data) {\n this._cache.add(data)\n var chunk\n var thing\n var out = []\n while ((chunk = this._cache.get(this._autopadding))) {\n thing = this._mode.decrypt(this, chunk)\n out.push(thing)\n }\n return Buffer.concat(out)\n}\n\nDecipher.prototype._final = function () {\n var chunk = this._cache.flush()\n if (this._autopadding) {\n return unpad(this._mode.decrypt(this, chunk))\n } else if (chunk) {\n throw new Error('data not multiple of block length')\n }\n}\n\nDecipher.prototype.setAutoPadding = function (setTo) {\n this._autopadding = !!setTo\n return this\n}\n\nfunction Splitter () {\n this.cache = Buffer.allocUnsafe(0)\n}\n\nSplitter.prototype.add = function (data) {\n this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function (autoPadding) {\n var out\n if (autoPadding) {\n if (this.cache.length > 16) {\n out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n } else {\n if (this.cache.length >= 16) {\n out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n }\n\n return null\n}\n\nSplitter.prototype.flush = function () {\n if (this.cache.length) return this.cache\n}\n\nfunction unpad (last) {\n var padded = last[15]\n if (padded < 1 || padded > 16) {\n throw new Error('unable to decrypt data')\n }\n var i = -1\n while (++i < padded) {\n if (last[(i + (16 - padded))] !== padded) {\n throw new Error('unable to decrypt data')\n }\n }\n if (padded === 16) return\n\n return last.slice(0, 16 - padded)\n}\n\nfunction createDecipheriv (suite, password, iv) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n if (typeof iv === 'string') iv = Buffer.from(iv)\n if (config.mode !== 'GCM' && iv.length !== config.iv) throw new TypeError('invalid iv length ' + iv.length)\n\n if (typeof password === 'string') password = Buffer.from(password)\n if (password.length !== config.key / 8) throw new TypeError('invalid key length ' + password.length)\n\n if (config.type === 'stream') {\n return new StreamCipher(config.module, password, iv, true)\n } else if (config.type === 'auth') {\n return new AuthCipher(config.module, password, iv, true)\n }\n\n return new Decipher(config.module, password, iv)\n}\n\nfunction createDecipher (suite, password) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n var keys = ebtk(password, false, config.key, config.iv)\n return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createDecipher = createDecipher\nexports.createDecipheriv = createDecipheriv\n","var ciphers = require('./encrypter')\nvar deciphers = require('./decrypter')\nvar modes = require('./modes/list.json')\n\nfunction getCiphers () {\n return Object.keys(modes)\n}\n\nexports.createCipher = exports.Cipher = ciphers.createCipher\nexports.createCipheriv = exports.Cipheriv = ciphers.createCipheriv\nexports.createDecipher = exports.Decipher = deciphers.createDecipher\nexports.createDecipheriv = exports.Decipheriv = deciphers.createDecipheriv\nexports.listCiphers = exports.getCiphers = getCiphers\n","exports['des-ecb'] = {\n key: 8,\n iv: 0\n}\nexports['des-cbc'] = exports.des = {\n key: 8,\n iv: 8\n}\nexports['des-ede3-cbc'] = exports.des3 = {\n key: 24,\n iv: 8\n}\nexports['des-ede3'] = {\n key: 24,\n iv: 0\n}\nexports['des-ede-cbc'] = {\n key: 16,\n iv: 8\n}\nexports['des-ede'] = {\n key: 16,\n iv: 0\n}\n","var DES = require('browserify-des')\nvar aes = require('browserify-aes/browser')\nvar aesModes = require('browserify-aes/modes')\nvar desModes = require('browserify-des/modes')\nvar ebtk = require('evp_bytestokey')\n\nfunction createCipher (suite, password) {\n suite = suite.toLowerCase()\n\n var keyLen, ivLen\n if (aesModes[suite]) {\n keyLen = aesModes[suite].key\n ivLen = aesModes[suite].iv\n } else if (desModes[suite]) {\n keyLen = desModes[suite].key * 8\n ivLen = desModes[suite].iv\n } else {\n throw new TypeError('invalid suite type')\n }\n\n var keys = ebtk(password, false, keyLen, ivLen)\n return createCipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createDecipher (suite, password) {\n suite = suite.toLowerCase()\n\n var keyLen, ivLen\n if (aesModes[suite]) {\n keyLen = aesModes[suite].key\n ivLen = aesModes[suite].iv\n } else if (desModes[suite]) {\n keyLen = desModes[suite].key * 8\n ivLen = desModes[suite].iv\n } else {\n throw new TypeError('invalid suite type')\n }\n\n var keys = ebtk(password, false, keyLen, ivLen)\n return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createCipheriv (suite, key, iv) {\n suite = suite.toLowerCase()\n if (aesModes[suite]) return aes.createCipheriv(suite, key, iv)\n if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite })\n\n throw new TypeError('invalid suite type')\n}\n\nfunction createDecipheriv (suite, key, iv) {\n suite = suite.toLowerCase()\n if (aesModes[suite]) return aes.createDecipheriv(suite, key, iv)\n if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite, decrypt: true })\n\n throw new TypeError('invalid suite type')\n}\n\nfunction getCiphers () {\n return Object.keys(desModes).concat(aes.getCiphers())\n}\n\nexports.createCipher = exports.Cipher = createCipher\nexports.createCipheriv = exports.Cipheriv = createCipheriv\nexports.createDecipher = exports.Decipher = createDecipher\nexports.createDecipheriv = exports.Decipheriv = createDecipheriv\nexports.listCiphers = exports.getCiphers = getCiphers\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var r;\n\nmodule.exports = function rand(len) {\n if (!r)\n r = new Rand(null);\n\n return r.generate(len);\n};\n\nfunction Rand(rand) {\n this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n if (this.rand.getBytes)\n return this.rand.getBytes(n);\n\n var res = new Uint8Array(n);\n for (var i = 0; i < res.length; i++)\n res[i] = this.rand.getByte();\n return res;\n};\n\nif (typeof self === 'object') {\n if (self.crypto && self.crypto.getRandomValues) {\n // Modern browsers\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.crypto.getRandomValues(arr);\n return arr;\n };\n } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n // IE\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.msCrypto.getRandomValues(arr);\n return arr;\n };\n\n // Safari's WebWorkers do not have `crypto`\n } else if (typeof window === 'object') {\n // Old junk\n Rand.prototype._rand = function() {\n throw new Error('Not implemented yet');\n };\n }\n} else {\n // Node.js or Web worker with no crypto support\n try {\n var crypto = require('crypto');\n if (typeof crypto.randomBytes !== 'function')\n throw new Error('Not supported');\n\n Rand.prototype._rand = function _rand(n) {\n return crypto.randomBytes(n);\n };\n } catch (e) {\n }\n}\n","var bn = require('bn.js');\nvar brorand = require('brorand');\n\nfunction MillerRabin(rand) {\n this.rand = rand || new brorand.Rand();\n}\nmodule.exports = MillerRabin;\n\nMillerRabin.create = function create(rand) {\n return new MillerRabin(rand);\n};\n\nMillerRabin.prototype._randbelow = function _randbelow(n) {\n var len = n.bitLength();\n var min_bytes = Math.ceil(len / 8);\n\n // Generage random bytes until a number less than n is found.\n // This ensures that 0..n-1 have an equal probability of being selected.\n do\n var a = new bn(this.rand.generate(min_bytes));\n while (a.cmp(n) >= 0);\n\n return a;\n};\n\nMillerRabin.prototype._randrange = function _randrange(start, stop) {\n // Generate a random number greater than or equal to start and less than stop.\n var size = stop.sub(start);\n return start.add(this._randbelow(size));\n};\n\nMillerRabin.prototype.test = function test(n, k, cb) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n var prime = true;\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n if (cb)\n cb(a);\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return false;\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s)\n return false;\n }\n\n return prime;\n};\n\nMillerRabin.prototype.getDivisor = function getDivisor(n, k) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n\n var g = n.gcd(a);\n if (g.cmpn(1) !== 0)\n return g;\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return x.fromRed().subn(1).gcd(n);\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s) {\n x = x.redSqr();\n return x.fromRed().subn(1).gcd(n);\n }\n }\n\n return false;\n};\n","var randomBytes = require('randombytes');\nmodule.exports = findPrime;\nfindPrime.simpleSieve = simpleSieve;\nfindPrime.fermatTest = fermatTest;\nvar BN = require('bn.js');\nvar TWENTYFOUR = new BN(24);\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar ONE = new BN(1);\nvar TWO = new BN(2);\nvar FIVE = new BN(5);\nvar SIXTEEN = new BN(16);\nvar EIGHT = new BN(8);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar ELEVEN = new BN(11);\nvar FOUR = new BN(4);\nvar TWELVE = new BN(12);\nvar primes = null;\n\nfunction _getPrimes() {\n if (primes !== null)\n return primes;\n\n var limit = 0x100000;\n var res = [];\n res[0] = 2;\n for (var i = 1, k = 3; k < limit; k += 2) {\n var sqrt = Math.ceil(Math.sqrt(k));\n for (var j = 0; j < i && res[j] <= sqrt; j++)\n if (k % res[j] === 0)\n break;\n\n if (i !== j && res[j] <= sqrt)\n continue;\n\n res[i++] = k;\n }\n primes = res;\n return res;\n}\n\nfunction simpleSieve(p) {\n var primes = _getPrimes();\n\n for (var i = 0; i < primes.length; i++)\n if (p.modn(primes[i]) === 0) {\n if (p.cmpn(primes[i]) === 0) {\n return true;\n } else {\n return false;\n }\n }\n\n return true;\n}\n\nfunction fermatTest(p) {\n var red = BN.mont(p);\n return TWO.toRed(red).redPow(p.subn(1)).fromRed().cmpn(1) === 0;\n}\n\nfunction findPrime(bits, gen) {\n if (bits < 16) {\n // this is what openssl does\n if (gen === 2 || gen === 5) {\n return new BN([0x8c, 0x7b]);\n } else {\n return new BN([0x8c, 0x27]);\n }\n }\n gen = new BN(gen);\n\n var num, n2;\n\n while (true) {\n num = new BN(randomBytes(Math.ceil(bits / 8)));\n while (num.bitLength() > bits) {\n num.ishrn(1);\n }\n if (num.isEven()) {\n num.iadd(ONE);\n }\n if (!num.testn(1)) {\n num.iadd(TWO);\n }\n if (!gen.cmp(TWO)) {\n while (num.mod(TWENTYFOUR).cmp(ELEVEN)) {\n num.iadd(FOUR);\n }\n } else if (!gen.cmp(FIVE)) {\n while (num.mod(TEN).cmp(THREE)) {\n num.iadd(FOUR);\n }\n }\n n2 = num.shrn(1);\n if (simpleSieve(n2) && simpleSieve(num) &&\n fermatTest(n2) && fermatTest(num) &&\n millerRabin.test(n2) && millerRabin.test(num)) {\n return num;\n }\n }\n\n}\n","var BN = require('bn.js');\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar TWENTYFOUR = new BN(24);\nvar ELEVEN = new BN(11);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar primes = require('./generatePrime');\nvar randomBytes = require('randombytes');\nmodule.exports = DH;\n\nfunction setPublicKey(pub, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc);\n }\n this._pub = new BN(pub);\n return this;\n}\n\nfunction setPrivateKey(priv, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc);\n }\n this._priv = new BN(priv);\n return this;\n}\n\nvar primeCache = {};\nfunction checkPrime(prime, generator) {\n var gen = generator.toString('hex');\n var hex = [gen, prime.toString(16)].join('_');\n if (hex in primeCache) {\n return primeCache[hex];\n }\n var error = 0;\n\n if (prime.isEven() ||\n !primes.simpleSieve ||\n !primes.fermatTest(prime) ||\n !millerRabin.test(prime)) {\n //not a prime so +1\n error += 1;\n\n if (gen === '02' || gen === '05') {\n // we'd be able to check the generator\n // it would fail so +8\n error += 8;\n } else {\n //we wouldn't be able to test the generator\n // so +4\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n }\n if (!millerRabin.test(prime.shrn(1))) {\n //not a safe prime\n error += 2;\n }\n var rem;\n switch (gen) {\n case '02':\n if (prime.mod(TWENTYFOUR).cmp(ELEVEN)) {\n // unsuidable generator\n error += 8;\n }\n break;\n case '05':\n rem = prime.mod(TEN);\n if (rem.cmp(THREE) && rem.cmp(SEVEN)) {\n // prime mod 10 needs to equal 3 or 7\n error += 8;\n }\n break;\n default:\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n}\n\nfunction DH(prime, generator, malleable) {\n this.setGenerator(generator);\n this.__prime = new BN(prime);\n this._prime = BN.mont(this.__prime);\n this._primeLen = prime.length;\n this._pub = undefined;\n this._priv = undefined;\n this._primeCode = undefined;\n if (malleable) {\n this.setPublicKey = setPublicKey;\n this.setPrivateKey = setPrivateKey;\n } else {\n this._primeCode = 8;\n }\n}\nObject.defineProperty(DH.prototype, 'verifyError', {\n enumerable: true,\n get: function () {\n if (typeof this._primeCode !== 'number') {\n this._primeCode = checkPrime(this.__prime, this.__gen);\n }\n return this._primeCode;\n }\n});\nDH.prototype.generateKeys = function () {\n if (!this._priv) {\n this._priv = new BN(randomBytes(this._primeLen));\n }\n this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed();\n return this.getPublicKey();\n};\n\nDH.prototype.computeSecret = function (other) {\n other = new BN(other);\n other = other.toRed(this._prime);\n var secret = other.redPow(this._priv).fromRed();\n var out = new Buffer(secret.toArray());\n var prime = this.getPrime();\n if (out.length < prime.length) {\n var front = new Buffer(prime.length - out.length);\n front.fill(0);\n out = Buffer.concat([front, out]);\n }\n return out;\n};\n\nDH.prototype.getPublicKey = function getPublicKey(enc) {\n return formatReturnValue(this._pub, enc);\n};\n\nDH.prototype.getPrivateKey = function getPrivateKey(enc) {\n return formatReturnValue(this._priv, enc);\n};\n\nDH.prototype.getPrime = function (enc) {\n return formatReturnValue(this.__prime, enc);\n};\n\nDH.prototype.getGenerator = function (enc) {\n return formatReturnValue(this._gen, enc);\n};\n\nDH.prototype.setGenerator = function (gen, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(gen)) {\n gen = new Buffer(gen, enc);\n }\n this.__gen = gen;\n this._gen = new BN(gen);\n return this;\n};\n\nfunction formatReturnValue(bn, enc) {\n var buf = new Buffer(bn.toArray());\n if (!enc) {\n return buf;\n } else {\n return buf.toString(enc);\n }\n}\n","var generatePrime = require('./lib/generatePrime')\nvar primes = require('./lib/primes.json')\n\nvar DH = require('./lib/dh')\n\nfunction getDiffieHellman (mod) {\n var prime = new Buffer(primes[mod].prime, 'hex')\n var gen = new Buffer(primes[mod].gen, 'hex')\n\n return new DH(prime, gen)\n}\n\nvar ENCODINGS = {\n 'binary': true, 'hex': true, 'base64': true\n}\n\nfunction createDiffieHellman (prime, enc, generator, genc) {\n if (Buffer.isBuffer(enc) || ENCODINGS[enc] === undefined) {\n return createDiffieHellman(prime, 'binary', enc, generator)\n }\n\n enc = enc || 'binary'\n genc = genc || 'binary'\n generator = generator || new Buffer([2])\n\n if (!Buffer.isBuffer(generator)) {\n generator = new Buffer(generator, genc)\n }\n\n if (typeof prime === 'number') {\n return new DH(generatePrime(prime, generator), generator, true)\n }\n\n if (!Buffer.isBuffer(prime)) {\n prime = new Buffer(prime, enc)\n }\n\n return new DH(prime, generator, true)\n}\n\nexports.DiffieHellmanGroup = exports.createDiffieHellmanGroup = exports.getDiffieHellman = getDiffieHellman\nexports.createDiffieHellman = exports.DiffieHellman = createDiffieHellman\n","'use strict';\n\nif (typeof process === 'undefined' ||\n !process.version ||\n process.version.indexOf('v0.') === 0 ||\n process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n module.exports = { nextTick: nextTick };\n} else {\n module.exports = process\n}\n\nfunction nextTick(fn, arg1, arg2, arg3) {\n if (typeof fn !== 'function') {\n throw new TypeError('\"callback\" argument must be a function');\n }\n var len = arguments.length;\n var args, i;\n switch (len) {\n case 0:\n case 1:\n return process.nextTick(fn);\n case 2:\n return process.nextTick(function afterTickOne() {\n fn.call(null, arg1);\n });\n case 3:\n return process.nextTick(function afterTickTwo() {\n fn.call(null, arg1, arg2);\n });\n case 4:\n return process.nextTick(function afterTickThree() {\n fn.call(null, arg1, arg2, arg3);\n });\n default:\n args = new Array(len - 1);\n i = 0;\n while (i < args.length) {\n args[i++] = arguments[i];\n }\n return process.nextTick(function afterTick() {\n fn.apply(null, args);\n });\n }\n}\n\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","module.exports = require('events').EventEmitter;\n","/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\n\nfunction isArray(arg) {\n if (Array.isArray) {\n return Array.isArray(arg);\n }\n return objectToString(arg) === '[object Array]';\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n return (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('buffer').Buffer.isBuffer;\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n","'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Buffer = require('safe-buffer').Buffer;\nvar util = require('util');\n\nfunction copyBuffer(src, target, offset) {\n src.copy(target, offset);\n}\n\nmodule.exports = function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n\n BufferList.prototype.push = function push(v) {\n var entry = { data: v, next: null };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n };\n\n BufferList.prototype.unshift = function unshift(v) {\n var entry = { data: v, next: this.head };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n };\n\n BufferList.prototype.shift = function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n };\n\n BufferList.prototype.clear = function clear() {\n this.head = this.tail = null;\n this.length = 0;\n };\n\n BufferList.prototype.join = function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) {\n ret += s + p.data;\n }return ret;\n };\n\n BufferList.prototype.concat = function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n };\n\n return BufferList;\n}();\n\nif (util && util.inspect && util.inspect.custom) {\n module.exports.prototype[util.inspect.custom] = function () {\n var obj = util.inspect({ length: this.length });\n return this.constructor.name + ' ' + obj;\n };\n}","'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n pna.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n pna.nextTick(emitErrorNT, this, err);\n }\n }\n\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n pna.nextTick(emitErrorNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n pna.nextTick(emitErrorNT, _this, err);\n }\n } else if (cb) {\n cb(err);\n }\n });\n\n return this;\n}\n\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\n\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\n\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : pna.nextTick;\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nutil.inherits(Writable, Stream);\n\nfunction nop() {}\n\nfunction WritableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n var isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n var hwm = options.highWaterMark;\n var writableHwm = options.writableHighWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\n if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (writableHwm || writableHwm === 0)) this.highWaterMark = writableHwm;else this.highWaterMark = defaultHwm;\n\n // cast to ints.\n this.highWaterMark = Math.floor(this.highWaterMark);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function () {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function (object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function (object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n if (!realHasInstance.call(Writable, this) && !(this instanceof Duplex)) {\n return new Writable(options);\n }\n\n this._writableState = new WritableState(options, this);\n\n // legacy.\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n\n if (typeof options.writev === 'function') this._writev = options.writev;\n\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n\n if (typeof options.final === 'function') this._final = options.final;\n }\n\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n this.emit('error', new Error('Cannot pipe, not readable'));\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new Error('write after end');\n // TODO: defer error events consistently everywhere, not just the cb\n stream.emit('error', er);\n pna.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var valid = true;\n var er = false;\n\n if (chunk === null) {\n er = new TypeError('May not write null values to stream');\n } else if (typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n if (er) {\n stream.emit('error', er);\n pna.nextTick(cb, er);\n valid = false;\n }\n return valid;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\n if (typeof cb !== 'function') cb = nop;\n\n if (state.ended) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n\n return ret;\n};\n\nWritable.prototype.cork = function () {\n var state = this._writableState;\n\n state.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\n\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n\n state.length += len;\n\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n pna.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n pna.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n\n onwriteStateUpdate(state);\n\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state);\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n /**/\n asyncWrite(afterWrite, stream, state, finished, cb);\n /**/\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new Error('_write() is not implemented'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n};\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n stream.emit('error', err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function') {\n state.pendingcb++;\n state.finalCalled = true;\n pna.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n }\n }\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) pna.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\n\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\n\nObject.defineProperty(Writable.prototype, 'destroyed', {\n get: function () {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\n\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n this.end();\n cb(err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) {\n keys.push(key);\n }return keys;\n};\n/**/\n\nmodule.exports = Duplex;\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\n{\n // avoid scope creep, the keys array can then be collected\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n\n Readable.call(this, options);\n Writable.call(this, options);\n\n if (options && options.readable === false) this.readable = false;\n\n if (options && options.writable === false) this.writable = false;\n\n this.allowHalfOpen = true;\n if (options && options.allowHalfOpen === false) this.allowHalfOpen = false;\n\n this.once('end', onend);\n}\n\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._writableState.highWaterMark;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // if we allow half-open state, or if the writable side ended,\n // then we're ok.\n if (this.allowHalfOpen || this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n pna.nextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n get: function () {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});\n\nDuplex.prototype._destroy = function (err, cb) {\n this.push(null);\n this.end();\n\n pna.nextTick(cb, err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\nmodule.exports = Readable;\n\n/**/\nvar isArray = require('isarray');\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function (emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar debugUtil = require('util');\nvar debug = void 0;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function () {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/BufferList');\nvar destroyImpl = require('./internal/streams/destroy');\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\n\nfunction ReadableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n var isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n var hwm = options.highWaterMark;\n var readableHwm = options.readableHighWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\n if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (readableHwm || readableHwm === 0)) this.highWaterMark = readableHwm;else this.highWaterMark = defaultHwm;\n\n // cast to ints.\n this.highWaterMark = Math.floor(this.highWaterMark);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n if (!(this instanceof Readable)) return new Readable(options);\n\n this._readableState = new ReadableState(options, this);\n\n // legacy\n this.readable = true;\n\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n\n Stream.call(this);\n}\n\nObject.defineProperty(Readable.prototype, 'destroyed', {\n get: function () {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\n\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n this.push(null);\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\n\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n stream.emit('error', er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (addToFront) {\n if (state.endEmitted) stream.emit('error', new Error('stream.unshift() after end event'));else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n stream.emit('error', new Error('stream.push() after EOF'));\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n }\n }\n\n return needMoreData(state);\n}\n\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n stream.emit('data', chunk);\n stream.read(0);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\n\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n return er;\n}\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes. This is to work around cases where hwm=0,\n// such as the repl. Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n}\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this._readableState.decoder = new StringDecoder(enc);\n this._readableState.encoding = enc;\n return this;\n};\n\n// Don't raise the hwm > 8MB\nvar MAX_HWM = 0x800000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = true;\n n = 0;\n } else {\n state.length -= n;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n\n return ret;\n};\n\nfunction onEofChunk(stream, state) {\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n\n // emit 'readable' now to make sure it gets picked up.\n emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n if (state.sync) pna.nextTick(emitReadable_, stream);else emitReadable_(stream);\n }\n}\n\nfunction emitReadable_(stream) {\n debug('emit readable');\n stream.emit('readable');\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n pna.nextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n var len = state.length;\n while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;else len = state.length;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n this.emit('error', new Error('_read() is not implemented'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) pna.nextTick(endFn);else src.once('end', endFn);\n\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n // If the user pushes more data while we're writing to dest then we'll end up\n // in ondata again. However, we only want to increase awaitDrain once because\n // dest will only emit one 'drain' event for the multiple writes.\n // => Introduce a guard on increasing awaitDrain.\n var increasedAwaitDrain = false;\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n increasedAwaitDrain = false;\n var ret = dest.write(chunk);\n if (false === ret && !increasedAwaitDrain) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n increasedAwaitDrain = true;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function () {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = { hasUnpiped: false };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this, { hasUnpiped: false });\n }return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\n dest.emit('unpipe', this, unpipeInfo);\n\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n\n if (ev === 'data') {\n // Start flowing on next tick if stream isn't explicitly paused\n if (this._readableState.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n var state = this._readableState;\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.emittedReadable = false;\n if (!state.reading) {\n pna.nextTick(nReadingNextTick, this);\n } else if (state.length) {\n emitReadable(this);\n }\n }\n }\n\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n state.flowing = true;\n resume(this, state);\n }\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n pna.nextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n if (!state.reading) {\n debug('resume read 0');\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n state.awaitDrain = 0;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (false !== this._readableState.flowing) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null) {}\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n\n var state = this._readableState;\n var paused = false;\n\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n\n _this.push(null);\n });\n\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function (method) {\n return function () {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return this;\n};\n\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._readableState.highWaterMark;\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = fromListPartial(n, state.buffer, state.decoder);\n }\n\n return ret;\n}\n\n// Extracts only enough buffered data to satisfy the amount requested.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromListPartial(n, list, hasStrings) {\n var ret;\n if (n < list.head.data.length) {\n // slice is the same for buffers and strings\n ret = list.head.data.slice(0, n);\n list.head.data = list.head.data.slice(n);\n } else if (n === list.head.data.length) {\n // first chunk is a perfect match\n ret = list.shift();\n } else {\n // result spans more than one buffer\n ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list);\n }\n return ret;\n}\n\n// Copies a specified amount of characters from the list of buffered data\n// chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBufferString(n, list) {\n var p = list.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\n// Copies a specified amount of bytes from the list of buffered data chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBuffer(n, list) {\n var ret = Buffer.allocUnsafe(n);\n var p = list.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n\n // If we get here before consuming all the bytes, then that is a\n // bug in node. Should never happen.\n if (state.length > 0) throw new Error('\"endReadable()\" called on non-empty stream');\n\n if (!state.endEmitted) {\n state.ended = true;\n pna.nextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n }\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(Transform, Duplex);\n\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n\n var cb = ts.writecb;\n\n if (!cb) {\n return this.emit('error', new Error('write callback called multiple times'));\n }\n\n ts.writechunk = null;\n ts.writecb = null;\n\n if (data != null) // single equals check for both `null` and `undefined`\n this.push(data);\n\n cb(er);\n\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n\n Duplex.call(this, options);\n\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\n\nfunction prefinish() {\n var _this = this;\n\n if (typeof this._flush === 'function') {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n throw new Error('_transform() is not implemented');\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nTransform.prototype._destroy = function (err, cb) {\n var _this2 = this;\n\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n _this2.emit('close');\n });\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n\n if (data != null) // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new Error('Calling transform done when ws.length != 0');\n\n if (stream._transformState.transforming) throw new Error('Calling transform done when still transforming');\n\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this._strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // '0' - '9'\n if (c >= 48 && c <= 57) {\n return c - 48;\n // 'A' - 'F'\n } else if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n } else {\n assert(false, 'Invalid character in ' + string);\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this._strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var b = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n b = c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n b = c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n b = c;\n }\n assert(c >= 0 && b < mul, 'Invalid character');\n r += b;\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this._strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n function move (dest, src) {\n dest.words = src.words;\n dest.length = src.length;\n dest.negative = src.negative;\n dest.red = src.red;\n }\n\n BN.prototype._move = function _move (dest) {\n move(dest, this);\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype._strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n // Check Symbol.for because not everywhere where Symbol defined\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol#Browser_compatibility\n if (typeof Symbol !== 'undefined' && typeof Symbol.for === 'function') {\n try {\n BN.prototype[Symbol.for('nodejs.util.inspect.custom')] = inspect;\n } catch (e) {\n BN.prototype.inspect = inspect;\n }\n } else {\n BN.prototype.inspect = inspect;\n }\n\n function inspect () {\n return (this.red ? '';\n }\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modrn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16, 2);\n };\n\n if (Buffer) {\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n return this.toArrayLike(Buffer, endian, length);\n };\n }\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n var allocate = function allocate (ArrayType, size) {\n if (ArrayType.allocUnsafe) {\n return ArrayType.allocUnsafe(size);\n }\n return new ArrayType(size);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n this._strip();\n\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n var res = allocate(ArrayType, reqLength);\n var postfix = endian === 'le' ? 'LE' : 'BE';\n this['_toArrayLike' + postfix](res, byteLength);\n return res;\n };\n\n BN.prototype._toArrayLikeLE = function _toArrayLikeLE (res, byteLength) {\n var position = 0;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position++] = word & 0xff;\n if (position < res.length) {\n res[position++] = (word >> 8) & 0xff;\n }\n if (position < res.length) {\n res[position++] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position < res.length) {\n res[position++] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position < res.length) {\n res[position++] = carry;\n\n while (position < res.length) {\n res[position++] = 0;\n }\n }\n };\n\n BN.prototype._toArrayLikeBE = function _toArrayLikeBE (res, byteLength) {\n var position = res.length - 1;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position--] = word & 0xff;\n if (position >= 0) {\n res[position--] = (word >> 8) & 0xff;\n }\n if (position >= 0) {\n res[position--] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position >= 0) {\n res[position--] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position >= 0) {\n res[position--] = carry;\n\n while (position >= 0) {\n res[position--] = 0;\n }\n }\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] >>> wbit) & 0x01;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this._strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this._strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this._strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this._strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this._strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this._strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n function jumboMulTo (self, num, out) {\n // Temporary disable, see https://github.com/indutny/bn.js/issues/211\n // var fftm = new FFTM();\n // return fftm.mulp(self, num, out);\n return bigMulTo(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out._strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this._strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) <= num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this._strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this._strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this._strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q._strip();\n }\n a._strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || (r2 === 1 && cmp === 0)) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modrn = function modrn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return isNegNum ? -acc : acc;\n };\n\n // WARNING: DEPRECATED\n BN.prototype.modn = function modn (num) {\n return this.modrn(num);\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n this._strip();\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this._strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is a BN v4 instance\n r.strip();\n } else {\n // r is a BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n\n move(a, a.umod(this.m)._forceRed(this));\n return a;\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","'use strict';\n\nvar BN = require('bn.js');\nvar randomBytes = require('randombytes');\nvar Buffer = require('safe-buffer').Buffer;\n\nfunction getr(priv) {\n\tvar len = priv.modulus.byteLength();\n\tvar r;\n\tdo {\n\t\tr = new BN(randomBytes(len));\n\t} while (r.cmp(priv.modulus) >= 0 || !r.umod(priv.prime1) || !r.umod(priv.prime2));\n\treturn r;\n}\n\nfunction blind(priv) {\n\tvar r = getr(priv);\n\tvar blinder = r.toRed(BN.mont(priv.modulus)).redPow(new BN(priv.publicExponent)).fromRed();\n\treturn { blinder: blinder, unblinder: r.invm(priv.modulus) };\n}\n\nfunction crt(msg, priv) {\n\tvar blinds = blind(priv);\n\tvar len = priv.modulus.byteLength();\n\tvar blinded = new BN(msg).mul(blinds.blinder).umod(priv.modulus);\n\tvar c1 = blinded.toRed(BN.mont(priv.prime1));\n\tvar c2 = blinded.toRed(BN.mont(priv.prime2));\n\tvar qinv = priv.coefficient;\n\tvar p = priv.prime1;\n\tvar q = priv.prime2;\n\tvar m1 = c1.redPow(priv.exponent1).fromRed();\n\tvar m2 = c2.redPow(priv.exponent2).fromRed();\n\tvar h = m1.isub(m2).imul(qinv).umod(p).imul(q);\n\treturn m2.iadd(h).imul(blinds.unblinder).umod(priv.modulus).toArrayLike(Buffer, 'be', len);\n}\ncrt.getr = getr;\n\nmodule.exports = crt;\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n","'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\nvar minAssert = require('minimalistic-assert');\nvar minUtils = require('minimalistic-crypto-utils');\n\nutils.assert = minAssert;\nutils.toArray = minUtils.toArray;\nutils.zero2 = minUtils.zero2;\nutils.toHex = minUtils.toHex;\nutils.encode = minUtils.encode;\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w, bits) {\n var naf = new Array(Math.max(num.bitLength(), bits) + 1);\n var i;\n for (i = 0; i < naf.length; i += 1) {\n naf[i] = 0;\n }\n\n var ws = 1 << (w + 1);\n var k = num.clone();\n\n for (i = 0; i < naf.length; i++) {\n var z;\n var mod = k.andln(ws - 1);\n if (k.isOdd()) {\n if (mod > (ws >> 1) - 1)\n z = (ws >> 1) - mod;\n else\n z = mod;\n k.isubn(z);\n } else {\n z = 0;\n }\n\n naf[i] = z;\n k.iushrn(1);\n }\n\n return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n var jsf = [\n [],\n [],\n ];\n\n k1 = k1.clone();\n k2 = k2.clone();\n var d1 = 0;\n var d2 = 0;\n var m8;\n while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n // First phase\n var m14 = (k1.andln(3) + d1) & 3;\n var m24 = (k2.andln(3) + d2) & 3;\n if (m14 === 3)\n m14 = -1;\n if (m24 === 3)\n m24 = -1;\n var u1;\n if ((m14 & 1) === 0) {\n u1 = 0;\n } else {\n m8 = (k1.andln(7) + d1) & 7;\n if ((m8 === 3 || m8 === 5) && m24 === 2)\n u1 = -m14;\n else\n u1 = m14;\n }\n jsf[0].push(u1);\n\n var u2;\n if ((m24 & 1) === 0) {\n u2 = 0;\n } else {\n m8 = (k2.andln(7) + d2) & 7;\n if ((m8 === 3 || m8 === 5) && m14 === 2)\n u2 = -m24;\n else\n u2 = m24;\n }\n jsf[1].push(u2);\n\n // Second phase\n if (2 * d1 === u1 + 1)\n d1 = 1 - d1;\n if (2 * d2 === u2 + 1)\n d2 = 1 - d2;\n k1.iushrn(1);\n k2.iushrn(1);\n }\n\n return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, name, computer) {\n var key = '_' + name;\n obj.prototype[name] = function cachedProperty() {\n return this[key] !== undefined ? this[key] :\n this[key] = computer.call(this);\n };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n this.type = type;\n this.p = new BN(conf.p, 16);\n\n // Use Montgomery, when there is no fast reduction for the prime\n this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n // Useful for many curves\n this.zero = new BN(0).toRed(this.red);\n this.one = new BN(1).toRed(this.red);\n this.two = new BN(2).toRed(this.red);\n\n // Curve configuration, optional\n this.n = conf.n && new BN(conf.n, 16);\n this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n // Temporary arrays\n this._wnafT1 = new Array(4);\n this._wnafT2 = new Array(4);\n this._wnafT3 = new Array(4);\n this._wnafT4 = new Array(4);\n\n this._bitLength = this.n ? this.n.bitLength() : 0;\n\n // Generalized Greg Maxwell's trick\n var adjustCount = this.n && this.p.div(this.n);\n if (!adjustCount || adjustCount.cmpn(100) > 0) {\n this.redN = null;\n } else {\n this._maxwellTrick = true;\n this.redN = this.n.toRed(this.red);\n }\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n assert(p.precomputed);\n var doubles = p._getDoubles();\n\n var naf = getNAF(k, 1, this._bitLength);\n var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n I /= 3;\n\n // Translate into more windowed form\n var repr = [];\n var j;\n var nafW;\n for (j = 0; j < naf.length; j += doubles.step) {\n nafW = 0;\n for (var l = j + doubles.step - 1; l >= j; l--)\n nafW = (nafW << 1) + naf[l];\n repr.push(nafW);\n }\n\n var a = this.jpoint(null, null, null);\n var b = this.jpoint(null, null, null);\n for (var i = I; i > 0; i--) {\n for (j = 0; j < repr.length; j++) {\n nafW = repr[j];\n if (nafW === i)\n b = b.mixedAdd(doubles.points[j]);\n else if (nafW === -i)\n b = b.mixedAdd(doubles.points[j].neg());\n }\n a = a.add(b);\n }\n return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n var w = 4;\n\n // Precompute window\n var nafPoints = p._getNAFPoints(w);\n w = nafPoints.wnd;\n var wnd = nafPoints.points;\n\n // Get NAF form\n var naf = getNAF(k, w, this._bitLength);\n\n // Add `this`*(N+1) for every w-NAF index\n var acc = this.jpoint(null, null, null);\n for (var i = naf.length - 1; i >= 0; i--) {\n // Count zeroes\n for (var l = 0; i >= 0 && naf[i] === 0; i--)\n l++;\n if (i >= 0)\n l++;\n acc = acc.dblp(l);\n\n if (i < 0)\n break;\n var z = naf[i];\n assert(z !== 0);\n if (p.type === 'affine') {\n // J +- P\n if (z > 0)\n acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n else\n acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n } else {\n // J +- J\n if (z > 0)\n acc = acc.add(wnd[(z - 1) >> 1]);\n else\n acc = acc.add(wnd[(-z - 1) >> 1].neg());\n }\n }\n return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n points,\n coeffs,\n len,\n jacobianResult) {\n var wndWidth = this._wnafT1;\n var wnd = this._wnafT2;\n var naf = this._wnafT3;\n\n // Fill all arrays\n var max = 0;\n var i;\n var j;\n var p;\n for (i = 0; i < len; i++) {\n p = points[i];\n var nafPoints = p._getNAFPoints(defW);\n wndWidth[i] = nafPoints.wnd;\n wnd[i] = nafPoints.points;\n }\n\n // Comb small window NAFs\n for (i = len - 1; i >= 1; i -= 2) {\n var a = i - 1;\n var b = i;\n if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength);\n naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength);\n max = Math.max(naf[a].length, max);\n max = Math.max(naf[b].length, max);\n continue;\n }\n\n var comb = [\n points[a], /* 1 */\n null, /* 3 */\n null, /* 5 */\n points[b], /* 7 */\n ];\n\n // Try to avoid Projective points, if possible\n if (points[a].y.cmp(points[b].y) === 0) {\n comb[1] = points[a].add(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].add(points[b].neg());\n } else {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n }\n\n var index = [\n -3, /* -1 -1 */\n -1, /* -1 0 */\n -5, /* -1 1 */\n -7, /* 0 -1 */\n 0, /* 0 0 */\n 7, /* 0 1 */\n 5, /* 1 -1 */\n 1, /* 1 0 */\n 3, /* 1 1 */\n ];\n\n var jsf = getJSF(coeffs[a], coeffs[b]);\n max = Math.max(jsf[0].length, max);\n naf[a] = new Array(max);\n naf[b] = new Array(max);\n for (j = 0; j < max; j++) {\n var ja = jsf[0][j] | 0;\n var jb = jsf[1][j] | 0;\n\n naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n naf[b][j] = 0;\n wnd[a] = comb;\n }\n }\n\n var acc = this.jpoint(null, null, null);\n var tmp = this._wnafT4;\n for (i = max; i >= 0; i--) {\n var k = 0;\n\n while (i >= 0) {\n var zero = true;\n for (j = 0; j < len; j++) {\n tmp[j] = naf[j][i] | 0;\n if (tmp[j] !== 0)\n zero = false;\n }\n if (!zero)\n break;\n k++;\n i--;\n }\n if (i >= 0)\n k++;\n acc = acc.dblp(k);\n if (i < 0)\n break;\n\n for (j = 0; j < len; j++) {\n var z = tmp[j];\n p;\n if (z === 0)\n continue;\n else if (z > 0)\n p = wnd[j][(z - 1) >> 1];\n else if (z < 0)\n p = wnd[j][(-z - 1) >> 1].neg();\n\n if (p.type === 'affine')\n acc = acc.mixedAdd(p);\n else\n acc = acc.add(p);\n }\n }\n // Zeroify references\n for (i = 0; i < len; i++)\n wnd[i] = null;\n\n if (jacobianResult)\n return acc;\n else\n return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n this.curve = curve;\n this.type = type;\n this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n bytes = utils.toArray(bytes, enc);\n\n var len = this.p.byteLength();\n\n // uncompressed, hybrid-odd, hybrid-even\n if ((bytes[0] === 0x04 || bytes[0] === 0x06 || bytes[0] === 0x07) &&\n bytes.length - 1 === 2 * len) {\n if (bytes[0] === 0x06)\n assert(bytes[bytes.length - 1] % 2 === 0);\n else if (bytes[0] === 0x07)\n assert(bytes[bytes.length - 1] % 2 === 1);\n\n var res = this.point(bytes.slice(1, 1 + len),\n bytes.slice(1 + len, 1 + 2 * len));\n\n return res;\n } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n bytes.length - 1 === len) {\n return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n }\n throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n var len = this.curve.p.byteLength();\n var x = this.getX().toArray('be', len);\n\n if (compact)\n return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n return [ 0x04 ].concat(x, this.getY().toArray('be', len));\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n if (this.precomputed)\n return this;\n\n var precomputed = {\n doubles: null,\n naf: null,\n beta: null,\n };\n precomputed.naf = this._getNAFPoints(8);\n precomputed.doubles = this._getDoubles(4, power);\n precomputed.beta = this._getBeta();\n this.precomputed = precomputed;\n\n return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n if (!this.precomputed)\n return false;\n\n var doubles = this.precomputed.doubles;\n if (!doubles)\n return false;\n\n return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n if (this.precomputed && this.precomputed.doubles)\n return this.precomputed.doubles;\n\n var doubles = [ this ];\n var acc = this;\n for (var i = 0; i < power; i += step) {\n for (var j = 0; j < step; j++)\n acc = acc.dbl();\n doubles.push(acc);\n }\n return {\n step: step,\n points: doubles,\n };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n if (this.precomputed && this.precomputed.naf)\n return this.precomputed.naf;\n\n var res = [ this ];\n var max = (1 << wnd) - 1;\n var dbl = max === 1 ? null : this.dbl();\n for (var i = 1; i < max; i++)\n res[i] = res[i - 1].add(dbl);\n return {\n wnd: wnd,\n points: res,\n };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n var r = this;\n for (var i = 0; i < k; i++)\n r = r.dbl();\n return r;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction ShortCurve(conf) {\n Base.call(this, 'short', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.tinv = this.two.redInvm();\n\n this.zeroA = this.a.fromRed().cmpn(0) === 0;\n this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n // If the curve is endomorphic, precalculate beta and lambda\n this.endo = this._getEndomorphism(conf);\n this._endoWnafT1 = new Array(4);\n this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n // No efficient endomorphism\n if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n return;\n\n // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n var beta;\n var lambda;\n if (conf.beta) {\n beta = new BN(conf.beta, 16).toRed(this.red);\n } else {\n var betas = this._getEndoRoots(this.p);\n // Choose the smallest beta\n beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n beta = beta.toRed(this.red);\n }\n if (conf.lambda) {\n lambda = new BN(conf.lambda, 16);\n } else {\n // Choose the lambda that is matching selected beta\n var lambdas = this._getEndoRoots(this.n);\n if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n lambda = lambdas[0];\n } else {\n lambda = lambdas[1];\n assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n }\n }\n\n // Get basis vectors, used for balanced length-two representation\n var basis;\n if (conf.basis) {\n basis = conf.basis.map(function(vec) {\n return {\n a: new BN(vec.a, 16),\n b: new BN(vec.b, 16),\n };\n });\n } else {\n basis = this._getEndoBasis(lambda);\n }\n\n return {\n beta: beta,\n lambda: lambda,\n basis: basis,\n };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n // Find roots of for x^2 + x + 1 in F\n // Root = (-1 +- Sqrt(-3)) / 2\n //\n var red = num === this.p ? this.red : BN.mont(num);\n var tinv = new BN(2).toRed(red).redInvm();\n var ntinv = tinv.redNeg();\n\n var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n var l1 = ntinv.redAdd(s).fromRed();\n var l2 = ntinv.redSub(s).fromRed();\n return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n // aprxSqrt >= sqrt(this.n)\n var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n // 3.74\n // Run EGCD, until r(L + 1) < aprxSqrt\n var u = lambda;\n var v = this.n.clone();\n var x1 = new BN(1);\n var y1 = new BN(0);\n var x2 = new BN(0);\n var y2 = new BN(1);\n\n // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n var a0;\n var b0;\n // First vector\n var a1;\n var b1;\n // Second vector\n var a2;\n var b2;\n\n var prevR;\n var i = 0;\n var r;\n var x;\n while (u.cmpn(0) !== 0) {\n var q = v.div(u);\n r = v.sub(q.mul(u));\n x = x2.sub(q.mul(x1));\n var y = y2.sub(q.mul(y1));\n\n if (!a1 && r.cmp(aprxSqrt) < 0) {\n a0 = prevR.neg();\n b0 = x1;\n a1 = r.neg();\n b1 = x;\n } else if (a1 && ++i === 2) {\n break;\n }\n prevR = r;\n\n v = u;\n u = r;\n x2 = x1;\n x1 = x;\n y2 = y1;\n y1 = y;\n }\n a2 = r.neg();\n b2 = x;\n\n var len1 = a1.sqr().add(b1.sqr());\n var len2 = a2.sqr().add(b2.sqr());\n if (len2.cmp(len1) >= 0) {\n a2 = a0;\n b2 = b0;\n }\n\n // Normalize signs\n if (a1.negative) {\n a1 = a1.neg();\n b1 = b1.neg();\n }\n if (a2.negative) {\n a2 = a2.neg();\n b2 = b2.neg();\n }\n\n return [\n { a: a1, b: b1 },\n { a: a2, b: b2 },\n ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n var basis = this.endo.basis;\n var v1 = basis[0];\n var v2 = basis[1];\n\n var c1 = v2.b.mul(k).divRound(this.n);\n var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n var p1 = c1.mul(v1.a);\n var p2 = c2.mul(v2.a);\n var q1 = c1.mul(v1.b);\n var q2 = c2.mul(v2.b);\n\n // Calculate answer\n var k1 = k.sub(p1).sub(p2);\n var k2 = q1.add(q2).neg();\n return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n // XXX Is there any way to tell if the number is odd without converting it\n // to non-red form?\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n if (point.inf)\n return true;\n\n var x = point.x;\n var y = point.y;\n\n var ax = this.a.redMul(x);\n var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n function _endoWnafMulAdd(points, coeffs, jacobianResult) {\n var npoints = this._endoWnafT1;\n var ncoeffs = this._endoWnafT2;\n for (var i = 0; i < points.length; i++) {\n var split = this._endoSplit(coeffs[i]);\n var p = points[i];\n var beta = p._getBeta();\n\n if (split.k1.negative) {\n split.k1.ineg();\n p = p.neg(true);\n }\n if (split.k2.negative) {\n split.k2.ineg();\n beta = beta.neg(true);\n }\n\n npoints[i * 2] = p;\n npoints[i * 2 + 1] = beta;\n ncoeffs[i * 2] = split.k1;\n ncoeffs[i * 2 + 1] = split.k2;\n }\n var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult);\n\n // Clean-up references to points and coefficients\n for (var j = 0; j < i * 2; j++) {\n npoints[j] = null;\n ncoeffs[j] = null;\n }\n return res;\n };\n\nfunction Point(curve, x, y, isRed) {\n Base.BasePoint.call(this, curve, 'affine');\n if (x === null && y === null) {\n this.x = null;\n this.y = null;\n this.inf = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n // Force redgomery representation when loading from JSON\n if (isRed) {\n this.x.forceRed(this.curve.red);\n this.y.forceRed(this.curve.red);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n this.inf = false;\n }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n if (!this.curve.endo)\n return;\n\n var pre = this.precomputed;\n if (pre && pre.beta)\n return pre.beta;\n\n var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n if (pre) {\n var curve = this.curve;\n var endoMul = function(p) {\n return curve.point(p.x.redMul(curve.endo.beta), p.y);\n };\n pre.beta = beta;\n beta.precomputed = {\n beta: null,\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(endoMul),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(endoMul),\n },\n };\n }\n return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n if (!this.precomputed)\n return [ this.x, this.y ];\n\n return [ this.x, this.y, this.precomputed && {\n doubles: this.precomputed.doubles && {\n step: this.precomputed.doubles.step,\n points: this.precomputed.doubles.points.slice(1),\n },\n naf: this.precomputed.naf && {\n wnd: this.precomputed.naf.wnd,\n points: this.precomputed.naf.points.slice(1),\n },\n } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n if (typeof obj === 'string')\n obj = JSON.parse(obj);\n var res = curve.point(obj[0], obj[1], red);\n if (!obj[2])\n return res;\n\n function obj2point(obj) {\n return curve.point(obj[0], obj[1], red);\n }\n\n var pre = obj[2];\n res.precomputed = {\n beta: null,\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: [ res ].concat(pre.doubles.points.map(obj2point)),\n },\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: [ res ].concat(pre.naf.points.map(obj2point)),\n },\n };\n return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.inf)\n return p;\n\n // P + O = P\n if (p.inf)\n return this;\n\n // P + P = 2P\n if (this.eq(p))\n return this.dbl();\n\n // P + (-P) = O\n if (this.neg().eq(p))\n return this.curve.point(null, null);\n\n // P + Q = O\n if (this.x.cmp(p.x) === 0)\n return this.curve.point(null, null);\n\n var c = this.y.redSub(p.y);\n if (c.cmpn(0) !== 0)\n c = c.redMul(this.x.redSub(p.x).redInvm());\n var nx = c.redSqr().redISub(this.x).redISub(p.x);\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.inf)\n return this;\n\n // 2P = O\n var ys1 = this.y.redAdd(this.y);\n if (ys1.cmpn(0) === 0)\n return this.curve.point(null, null);\n\n var a = this.curve.a;\n\n var x2 = this.x.redSqr();\n var dyinv = ys1.redInvm();\n var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n k = new BN(k, 16);\n if (this.isInfinity())\n return this;\n else if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else if (this.curve.endo)\n return this.curve._endoWnafMulAdd([ this ], [ k ]);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs, true);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2, true);\n};\n\nPoint.prototype.eq = function eq(p) {\n return this === p ||\n this.inf === p.inf &&\n (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n if (this.inf)\n return this;\n\n var res = this.curve.point(this.x, this.y.redNeg());\n if (_precompute && this.precomputed) {\n var pre = this.precomputed;\n var negate = function(p) {\n return p.neg();\n };\n res.precomputed = {\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(negate),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(negate),\n },\n };\n }\n return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n if (this.inf)\n return this.curve.jpoint(null, null, null);\n\n var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n Base.BasePoint.call(this, curve, 'jacobian');\n if (x === null && y === null && z === null) {\n this.x = this.curve.one;\n this.y = this.curve.one;\n this.z = new BN(0);\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = new BN(z, 16);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n\n this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n if (this.isInfinity())\n return this.curve.point(null, null);\n\n var zinv = this.z.redInvm();\n var zinv2 = zinv.redSqr();\n var ax = this.x.redMul(zinv2);\n var ay = this.y.redMul(zinv2).redMul(zinv);\n\n return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.isInfinity())\n return p;\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 12M + 4S + 7A\n var pz2 = p.z.redSqr();\n var z2 = this.z.redSqr();\n var u1 = this.x.redMul(pz2);\n var u2 = p.x.redMul(z2);\n var s1 = this.y.redMul(pz2.redMul(p.z));\n var s2 = p.y.redMul(z2.redMul(this.z));\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(p.z).redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n // O + P = P\n if (this.isInfinity())\n return p.toJ();\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 8M + 3S + 7A\n var z2 = this.z.redSqr();\n var u1 = this.x;\n var u2 = p.x.redMul(z2);\n var s1 = this.y;\n var s2 = p.y.redMul(z2).redMul(this.z);\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n if (pow === 0)\n return this;\n if (this.isInfinity())\n return this;\n if (!pow)\n return this.dbl();\n\n var i;\n if (this.curve.zeroA || this.curve.threeA) {\n var r = this;\n for (i = 0; i < pow; i++)\n r = r.dbl();\n return r;\n }\n\n // 1M + 2S + 1A + N * (4S + 5M + 8A)\n // N = 1 => 6M + 6S + 9A\n var a = this.curve.a;\n var tinv = this.curve.tinv;\n\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n // Reuse results\n var jyd = jy.redAdd(jy);\n for (i = 0; i < pow; i++) {\n var jx2 = jx.redSqr();\n var jyd2 = jyd.redSqr();\n var jyd4 = jyd2.redSqr();\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var t1 = jx.redMul(jyd2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n var dny = c.redMul(t2);\n dny = dny.redIAdd(dny).redISub(jyd4);\n var nz = jyd.redMul(jz);\n if (i + 1 < pow)\n jz4 = jz4.redMul(jyd4);\n\n jx = nx;\n jz = nz;\n jyd = dny;\n }\n\n return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n if (this.curve.zeroA)\n return this._zeroDbl();\n else if (this.curve.threeA)\n return this._threeDbl();\n else\n return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 14A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // T = M ^ 2 - 2*S\n var t = m.redSqr().redISub(s).redISub(s);\n\n // 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2*Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-dbl-2009-l\n // 2M + 5S + 13A\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = B^2\n var c = b.redSqr();\n // D = 2 * ((X1 + B)^2 - A - C)\n var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n d = d.redIAdd(d);\n // E = 3 * A\n var e = a.redAdd(a).redIAdd(a);\n // F = E^2\n var f = e.redSqr();\n\n // 8 * C\n var c8 = c.redIAdd(c);\n c8 = c8.redIAdd(c8);\n c8 = c8.redIAdd(c8);\n\n // X3 = F - 2 * D\n nx = f.redISub(d).redISub(d);\n // Y3 = E * (D - X3) - 8 * C\n ny = e.redMul(d.redISub(nx)).redISub(c8);\n // Z3 = 2 * Y1 * Z1\n nz = this.y.redMul(this.z);\n nz = nz.redIAdd(nz);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 15A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a\n var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n // T = M^2 - 2 * S\n var t = m.redSqr().redISub(s).redISub(s);\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2 * Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n // 3M + 5S\n\n // delta = Z1^2\n var delta = this.z.redSqr();\n // gamma = Y1^2\n var gamma = this.y.redSqr();\n // beta = X1 * gamma\n var beta = this.x.redMul(gamma);\n // alpha = 3 * (X1 - delta) * (X1 + delta)\n var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n alpha = alpha.redAdd(alpha).redIAdd(alpha);\n // X3 = alpha^2 - 8 * beta\n var beta4 = beta.redIAdd(beta);\n beta4 = beta4.redIAdd(beta4);\n var beta8 = beta4.redAdd(beta4);\n nx = alpha.redSqr().redISub(beta8);\n // Z3 = (Y1 + Z1)^2 - gamma - delta\n nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n var ggamma8 = gamma.redSqr();\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n var a = this.curve.a;\n\n // 4M + 6S + 10A\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n var jx2 = jx.redSqr();\n var jy2 = jy.redSqr();\n\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var jxd4 = jx.redAdd(jx);\n jxd4 = jxd4.redIAdd(jxd4);\n var t1 = jxd4.redMul(jy2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n\n var jyd8 = jy2.redSqr();\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n var ny = c.redMul(t2).redISub(jyd8);\n var nz = jy.redAdd(jy).redMul(jz);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n if (!this.curve.zeroA)\n return this.dbl().add(this);\n\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n // 5M + 10S + ...\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // ZZ = Z1^2\n var zz = this.z.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // M = 3 * XX + a * ZZ2; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // MM = M^2\n var mm = m.redSqr();\n // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n e = e.redIAdd(e);\n e = e.redAdd(e).redIAdd(e);\n e = e.redISub(mm);\n // EE = E^2\n var ee = e.redSqr();\n // T = 16*YYYY\n var t = yyyy.redIAdd(yyyy);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n // U = (M + E)^2 - MM - EE - T\n var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n // X3 = 4 * (X1 * EE - 4 * YY * U)\n var yyu4 = yy.redMul(u);\n yyu4 = yyu4.redIAdd(yyu4);\n yyu4 = yyu4.redIAdd(yyu4);\n var nx = this.x.redMul(ee).redISub(yyu4);\n nx = nx.redIAdd(nx);\n nx = nx.redIAdd(nx);\n // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n // Z3 = (Z1 + E)^2 - ZZ - EE\n var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n k = new BN(k, kbase);\n\n return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n if (p.type === 'affine')\n return this.eq(p.toJ());\n\n if (this === p)\n return true;\n\n // x1 * z2^2 == x2 * z1^2\n var z2 = this.z.redSqr();\n var pz2 = p.z.redSqr();\n if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n return false;\n\n // y1 * z2^3 == y2 * z1^3\n var z3 = z2.redMul(this.z);\n var pz3 = pz2.redMul(p.z);\n return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.eqXToP = function eqXToP(x) {\n var zs = this.z.redSqr();\n var rx = x.toRed(this.curve.red).redMul(zs);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(zs);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\nJPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar utils = require('../utils');\n\nfunction MontCurve(conf) {\n Base.call(this, 'mont', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.i4 = new BN(4).toRed(this.red).redInvm();\n this.two = new BN(2).toRed(this.red);\n this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n var x = point.normalize().x;\n var x2 = x.redSqr();\n var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n var y = rhs.redSqrt();\n\n return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && z === null) {\n this.x = this.curve.one;\n this.z = this.curve.zero;\n } else {\n this.x = new BN(x, 16);\n this.z = new BN(z, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n // 2M + 2S + 4A\n\n // A = X1 + Z1\n var a = this.x.redAdd(this.z);\n // AA = A^2\n var aa = a.redSqr();\n // B = X1 - Z1\n var b = this.x.redSub(this.z);\n // BB = B^2\n var bb = b.redSqr();\n // C = AA - BB\n var c = aa.redSub(bb);\n // X3 = AA * BB\n var nx = aa.redMul(bb);\n // Z3 = C * (BB + A24 * C)\n var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n // 4M + 2S + 6A\n\n // A = X2 + Z2\n var a = this.x.redAdd(this.z);\n // B = X2 - Z2\n var b = this.x.redSub(this.z);\n // C = X3 + Z3\n var c = p.x.redAdd(p.z);\n // D = X3 - Z3\n var d = p.x.redSub(p.z);\n // DA = D * A\n var da = d.redMul(a);\n // CB = C * B\n var cb = c.redMul(b);\n // X5 = Z1 * (DA + CB)^2\n var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n // Z5 = X1 * (DA - CB)^2\n var nz = diff.x.redMul(da.redISub(cb).redSqr());\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n var t = k.clone();\n var a = this; // (N / 2) * Q + Q\n var b = this.curve.point(null, null); // (N / 2) * Q\n var c = this; // Q\n\n for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n bits.push(t.andln(1));\n\n for (var i = bits.length - 1; i >= 0; i--) {\n if (bits[i] === 0) {\n // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n a = a.diffAdd(b, c);\n // N * Q = 2 * ((N / 2) * Q + Q))\n b = b.dbl();\n } else {\n // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n b = a.diffAdd(b, c);\n // N * Q + Q = 2 * ((N / 2) * Q + Q)\n a = a.dbl();\n }\n }\n return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.jumlAdd = function jumlAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n this.x = this.x.redMul(this.z.redInvm());\n this.z = this.curve.one;\n return this;\n};\n\nPoint.prototype.getX = function getX() {\n // Normalize coordinates\n this.normalize();\n\n return this.x.fromRed();\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction EdwardsCurve(conf) {\n // NOTE: Important as we are creating point in Base.call()\n this.twisted = (conf.a | 0) !== 1;\n this.mOneA = this.twisted && (conf.a | 0) === -1;\n this.extended = this.mOneA;\n\n Base.call(this, 'edwards', conf);\n\n this.a = new BN(conf.a, 16).umod(this.red.m);\n this.a = this.a.toRed(this.red);\n this.c = new BN(conf.c, 16).toRed(this.red);\n this.c2 = this.c.redSqr();\n this.d = new BN(conf.d, 16).toRed(this.red);\n this.dd = this.d.redAdd(this.d);\n\n assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n if (this.mOneA)\n return num.redNeg();\n else\n return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n if (this.oneC)\n return num;\n else\n return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var x2 = x.redSqr();\n var rhs = this.c2.redSub(this.a.redMul(x2));\n var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n var y2 = rhs.redMul(lhs.redInvm());\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n y = new BN(y, 16);\n if (!y.red)\n y = y.toRed(this.red);\n\n // x^2 = (y^2 - c^2) / (c^2 d y^2 - a)\n var y2 = y.redSqr();\n var lhs = y2.redSub(this.c2);\n var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a);\n var x2 = lhs.redMul(rhs.redInvm());\n\n if (x2.cmp(this.zero) === 0) {\n if (odd)\n throw new Error('invalid point');\n else\n return this.point(this.zero, y);\n }\n\n var x = x2.redSqrt();\n if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n if (x.fromRed().isOdd() !== odd)\n x = x.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n if (point.isInfinity())\n return true;\n\n // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n point.normalize();\n\n var x2 = point.x.redSqr();\n var y2 = point.y.redSqr();\n var lhs = x2.redMul(this.a).redAdd(y2);\n var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && y === null && z === null) {\n this.x = this.curve.zero;\n this.y = this.curve.one;\n this.z = this.curve.one;\n this.t = this.curve.zero;\n this.zOne = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = z ? new BN(z, 16) : this.curve.one;\n this.t = t && new BN(t, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n if (this.t && !this.t.red)\n this.t = this.t.toRed(this.curve.red);\n this.zOne = this.z === this.curve.one;\n\n // Use extended coordinates\n if (this.curve.extended && !this.t) {\n this.t = this.x.redMul(this.y);\n if (!this.zOne)\n this.t = this.t.redMul(this.z.redInvm());\n }\n }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.x.cmpn(0) === 0 &&\n (this.y.cmp(this.z) === 0 ||\n (this.zOne && this.y.cmp(this.curve.c) === 0));\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #doubling-dbl-2008-hwcd\n // 4M + 4S\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = 2 * Z1^2\n var c = this.z.redSqr();\n c = c.redIAdd(c);\n // D = a * A\n var d = this.curve._mulA(a);\n // E = (X1 + Y1)^2 - A - B\n var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n // G = D + B\n var g = d.redAdd(b);\n // F = G - C\n var f = g.redSub(c);\n // H = D - B\n var h = d.redSub(b);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #doubling-dbl-2008-bbjlp\n // #doubling-dbl-2007-bl\n // and others\n // Generally 3M + 4S or 2M + 4S\n\n // B = (X1 + Y1)^2\n var b = this.x.redAdd(this.y).redSqr();\n // C = X1^2\n var c = this.x.redSqr();\n // D = Y1^2\n var d = this.y.redSqr();\n\n var nx;\n var ny;\n var nz;\n var e;\n var h;\n var j;\n if (this.curve.twisted) {\n // E = a * C\n e = this.curve._mulA(c);\n // F = E + D\n var f = e.redAdd(d);\n if (this.zOne) {\n // X3 = (B - C - D) * (F - 2)\n nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F^2 - 2 * F\n nz = f.redSqr().redSub(f).redSub(f);\n } else {\n // H = Z1^2\n h = this.z.redSqr();\n // J = F - 2 * H\n j = f.redSub(h).redISub(h);\n // X3 = (B-C-D)*J\n nx = b.redSub(c).redISub(d).redMul(j);\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F * J\n nz = f.redMul(j);\n }\n } else {\n // E = C + D\n e = c.redAdd(d);\n // H = (c * Z1)^2\n h = this.curve._mulC(this.z).redSqr();\n // J = E - 2 * H\n j = e.redSub(h).redSub(h);\n // X3 = c * (B - E) * J\n nx = this.curve._mulC(b.redISub(e)).redMul(j);\n // Y3 = c * E * (C - D)\n ny = this.curve._mulC(e).redMul(c.redISub(d));\n // Z3 = E * J\n nz = e.redMul(j);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n // Double in extended coordinates\n if (this.curve.extended)\n return this._extDbl();\n else\n return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #addition-add-2008-hwcd-3\n // 8M\n\n // A = (Y1 - X1) * (Y2 - X2)\n var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n // B = (Y1 + X1) * (Y2 + X2)\n var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n // C = T1 * k * T2\n var c = this.t.redMul(this.curve.dd).redMul(p.t);\n // D = Z1 * 2 * Z2\n var d = this.z.redMul(p.z.redAdd(p.z));\n // E = B - A\n var e = b.redSub(a);\n // F = D - C\n var f = d.redSub(c);\n // G = D + C\n var g = d.redAdd(c);\n // H = B + A\n var h = b.redAdd(a);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #addition-add-2008-bbjlp\n // #addition-add-2007-bl\n // 10M + 1S\n\n // A = Z1 * Z2\n var a = this.z.redMul(p.z);\n // B = A^2\n var b = a.redSqr();\n // C = X1 * X2\n var c = this.x.redMul(p.x);\n // D = Y1 * Y2\n var d = this.y.redMul(p.y);\n // E = d * C * D\n var e = this.curve.d.redMul(c).redMul(d);\n // F = B - E\n var f = b.redSub(e);\n // G = B + E\n var g = b.redAdd(e);\n // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n var nx = a.redMul(f).redMul(tmp);\n var ny;\n var nz;\n if (this.curve.twisted) {\n // Y3 = A * G * (D - a * C)\n ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n // Z3 = F * G\n nz = f.redMul(g);\n } else {\n // Y3 = A * G * (D - C)\n ny = a.redMul(g).redMul(d.redSub(c));\n // Z3 = c * F * G\n nz = this.curve._mulC(f).redMul(g);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n if (this.isInfinity())\n return p;\n if (p.isInfinity())\n return this;\n\n if (this.curve.extended)\n return this._extAdd(p);\n else\n return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, false);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, true);\n};\n\nPoint.prototype.normalize = function normalize() {\n if (this.zOne)\n return this;\n\n // Normalize coordinates\n var zi = this.z.redInvm();\n this.x = this.x.redMul(zi);\n this.y = this.y.redMul(zi);\n if (this.t)\n this.t = this.t.redMul(zi);\n this.z = this.curve.one;\n this.zOne = true;\n return this;\n};\n\nPoint.prototype.neg = function neg() {\n return this.curve.point(this.x.redNeg(),\n this.y,\n this.z,\n this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n this.normalize();\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n this.normalize();\n return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n return this === other ||\n this.getX().cmp(other.getX()) === 0 &&\n this.getY().cmp(other.getY()) === 0;\n};\n\nPoint.prototype.eqXToP = function eqXToP(x) {\n var rx = x.toRed(this.curve.red).redMul(this.z);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(this.z);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n","'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n return false;\n }\n if (i < 0 || i + 1 >= msg.length) {\n return false;\n }\n return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg === 'string') {\n if (!enc) {\n // Inspired by stringToUtf8ByteArray() in closure-library by Google\n // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n // Apache License 2.0\n // https://github.com/google/closure-library/blob/master/LICENSE\n var p = 0;\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n if (c < 128) {\n res[p++] = c;\n } else if (c < 2048) {\n res[p++] = (c >> 6) | 192;\n res[p++] = (c & 63) | 128;\n } else if (isSurrogatePair(msg, i)) {\n c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n res[p++] = (c >> 18) | 240;\n res[p++] = ((c >> 12) & 63) | 128;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n } else {\n res[p++] = (c >> 12) | 224;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n }\n }\n } else if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n }\n } else {\n for (i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n }\n return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n var res = (w >>> 24) |\n ((w >>> 8) & 0xff00) |\n ((w << 8) & 0xff0000) |\n ((w & 0xff) << 24);\n return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n var res = '';\n for (var i = 0; i < msg.length; i++) {\n var w = msg[i];\n if (endian === 'little')\n w = htonl(w);\n res += zero8(w.toString(16));\n }\n return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n if (word.length === 7)\n return '0' + word;\n else if (word.length === 6)\n return '00' + word;\n else if (word.length === 5)\n return '000' + word;\n else if (word.length === 4)\n return '0000' + word;\n else if (word.length === 3)\n return '00000' + word;\n else if (word.length === 2)\n return '000000' + word;\n else if (word.length === 1)\n return '0000000' + word;\n else\n return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n var len = end - start;\n assert(len % 4 === 0);\n var res = new Array(len / 4);\n for (var i = 0, k = start; i < res.length; i++, k += 4) {\n var w;\n if (endian === 'big')\n w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n else\n w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n res[i] = w >>> 0;\n }\n return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n var res = new Array(msg.length * 4);\n for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n var m = msg[i];\n if (endian === 'big') {\n res[k] = m >>> 24;\n res[k + 1] = (m >>> 16) & 0xff;\n res[k + 2] = (m >>> 8) & 0xff;\n res[k + 3] = m & 0xff;\n } else {\n res[k + 3] = m >>> 24;\n res[k + 2] = (m >>> 16) & 0xff;\n res[k + 1] = (m >>> 8) & 0xff;\n res[k] = m & 0xff;\n }\n }\n return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n var bh = buf[pos];\n var bl = buf[pos + 1];\n\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n buf[pos] = hi >>> 0;\n buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n var lo = al + bl;\n return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n\n var hi = ah + bh + ch + dh + carry;\n return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n var lo = al + bl + cl + dl;\n return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n lo = (lo + el) >>> 0;\n carry += lo < el ? 1 : 0;\n\n var hi = ah + bh + ch + dh + eh + carry;\n return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var lo = al + bl + cl + dl + el;\n\n return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n var r = (al << (32 - num)) | (ah >>> num);\n return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n this.pending = null;\n this.pendingTotal = 0;\n this.blockSize = this.constructor.blockSize;\n this.outSize = this.constructor.outSize;\n this.hmacStrength = this.constructor.hmacStrength;\n this.padLength = this.constructor.padLength / 8;\n this.endian = 'big';\n\n this._delta8 = this.blockSize / 8;\n this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n // Convert message to array, pad it, and join into 32bit blocks\n msg = utils.toArray(msg, enc);\n if (!this.pending)\n this.pending = msg;\n else\n this.pending = this.pending.concat(msg);\n this.pendingTotal += msg.length;\n\n // Enough data, try updating\n if (this.pending.length >= this._delta8) {\n msg = this.pending;\n\n // Process pending data in blocks\n var r = msg.length % this._delta8;\n this.pending = msg.slice(msg.length - r, msg.length);\n if (this.pending.length === 0)\n this.pending = null;\n\n msg = utils.join32(msg, 0, msg.length - r, this.endian);\n for (var i = 0; i < msg.length; i += this._delta32)\n this._update(msg, i, i + this._delta32);\n }\n\n return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n this.update(this._pad());\n assert(this.pending === null);\n\n return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n var len = this.pendingTotal;\n var bytes = this._delta8;\n var k = bytes - ((len + this.padLength) % bytes);\n var res = new Array(k + this.padLength);\n res[0] = 0x80;\n for (var i = 1; i < k; i++)\n res[i] = 0;\n\n // Append length\n len <<= 3;\n if (this.endian === 'big') {\n for (var t = 8; t < this.padLength; t++)\n res[i++] = 0;\n\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = len & 0xff;\n } else {\n res[i++] = len & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n\n for (t = 8; t < this.padLength; t++)\n res[i++] = 0;\n }\n\n return res;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n if (s === 0)\n return ch32(x, y, z);\n if (s === 1 || s === 3)\n return p32(x, y, z);\n if (s === 2)\n return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n 0x5A827999, 0x6ED9EBA1,\n 0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n if (!(this instanceof SHA1))\n return new SHA1();\n\n BlockHash.call(this);\n this.h = [\n 0x67452301, 0xefcdab89, 0x98badcfe,\n 0x10325476, 0xc3d2e1f0 ];\n this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n\n for(; i < W.length; i++)\n W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n\n for (i = 0; i < W.length; i++) {\n var s = ~~(i / 20);\n var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n e = d;\n d = c;\n c = rotl32(b, 30);\n b = a;\n a = t;\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n if (!(this instanceof SHA256))\n return new SHA256();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n ];\n this.k = sha256_K;\n this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i++)\n W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n var f = this.h[5];\n var g = this.h[6];\n var h = this.h[7];\n\n assert(this.k.length === W.length);\n for (i = 0; i < W.length; i++) {\n var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n var T2 = sum32(s0_256(a), maj32(a, b, c));\n h = g;\n g = f;\n f = e;\n e = sum32(d, T1);\n d = c;\n c = b;\n b = a;\n a = sum32(T1, T2);\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n this.h[5] = sum32(this.h[5], f);\n this.h[6] = sum32(this.h[6], g);\n this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n if (!(this instanceof SHA224))\n return new SHA224();\n\n SHA256.call(this);\n this.h = [\n 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n // Just truncate output\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 7), 'big');\n else\n return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n if (!(this instanceof SHA512))\n return new SHA512();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xf3bcc908,\n 0xbb67ae85, 0x84caa73b,\n 0x3c6ef372, 0xfe94f82b,\n 0xa54ff53a, 0x5f1d36f1,\n 0x510e527f, 0xade682d1,\n 0x9b05688c, 0x2b3e6c1f,\n 0x1f83d9ab, 0xfb41bd6b,\n 0x5be0cd19, 0x137e2179 ];\n this.k = sha512_K;\n this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n var W = this.W;\n\n // 32 x 32bit words\n for (var i = 0; i < 32; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i += 2) {\n var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2\n var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n var c1_hi = W[i - 14]; // i - 7\n var c1_lo = W[i - 13];\n var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15\n var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n var c3_hi = W[i - 32]; // i - 16\n var c3_lo = W[i - 31];\n\n W[i] = sum64_4_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n W[i + 1] = sum64_4_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n this._prepareBlock(msg, start);\n\n var W = this.W;\n\n var ah = this.h[0];\n var al = this.h[1];\n var bh = this.h[2];\n var bl = this.h[3];\n var ch = this.h[4];\n var cl = this.h[5];\n var dh = this.h[6];\n var dl = this.h[7];\n var eh = this.h[8];\n var el = this.h[9];\n var fh = this.h[10];\n var fl = this.h[11];\n var gh = this.h[12];\n var gl = this.h[13];\n var hh = this.h[14];\n var hl = this.h[15];\n\n assert(this.k.length === W.length);\n for (var i = 0; i < W.length; i += 2) {\n var c0_hi = hh;\n var c0_lo = hl;\n var c1_hi = s1_512_hi(eh, el);\n var c1_lo = s1_512_lo(eh, el);\n var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n var c3_hi = this.k[i];\n var c3_lo = this.k[i + 1];\n var c4_hi = W[i];\n var c4_lo = W[i + 1];\n\n var T1_hi = sum64_5_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n var T1_lo = sum64_5_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n\n c0_hi = s0_512_hi(ah, al);\n c0_lo = s0_512_lo(ah, al);\n c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n hh = gh;\n hl = gl;\n\n gh = fh;\n gl = fl;\n\n fh = eh;\n fl = el;\n\n eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n dh = ch;\n dl = cl;\n\n ch = bh;\n cl = bl;\n\n bh = ah;\n bl = al;\n\n ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n }\n\n sum64(this.h, 0, ah, al);\n sum64(this.h, 2, bh, bl);\n sum64(this.h, 4, ch, cl);\n sum64(this.h, 6, dh, dl);\n sum64(this.h, 8, eh, el);\n sum64(this.h, 10, fh, fl);\n sum64(this.h, 12, gh, gl);\n sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ ((~xh) & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ ((~xl) & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 28);\n var c1_hi = rotr64_hi(xl, xh, 2); // 34\n var c2_hi = rotr64_hi(xl, xh, 7); // 39\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 28);\n var c1_lo = rotr64_lo(xl, xh, 2); // 34\n var c2_lo = rotr64_lo(xl, xh, 7); // 39\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 14);\n var c1_hi = rotr64_hi(xh, xl, 18);\n var c2_hi = rotr64_hi(xl, xh, 9); // 41\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 14);\n var c1_lo = rotr64_lo(xh, xl, 18);\n var c2_lo = rotr64_lo(xl, xh, 9); // 41\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 1);\n var c1_hi = rotr64_hi(xh, xl, 8);\n var c2_hi = shr64_hi(xh, xl, 7);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 1);\n var c1_lo = rotr64_lo(xh, xl, 8);\n var c2_lo = shr64_lo(xh, xl, 7);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 19);\n var c1_hi = rotr64_hi(xl, xh, 29); // 61\n var c2_hi = shr64_hi(xh, xl, 6);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 19);\n var c1_lo = rotr64_lo(xl, xh, 29); // 61\n var c2_lo = shr64_lo(xh, xl, 6);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n","'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n if (!(this instanceof SHA384))\n return new SHA384();\n\n SHA512.call(this);\n this.h = [\n 0xcbbb9d5d, 0xc1059ed8,\n 0x629a292a, 0x367cd507,\n 0x9159015a, 0x3070dd17,\n 0x152fecd8, 0xf70e5939,\n 0x67332667, 0xffc00b31,\n 0x8eb44a87, 0x68581511,\n 0xdb0c2e0d, 0x64f98fa7,\n 0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 12), 'big');\n else\n return utils.split32(this.h.slice(0, 12), 'big');\n};\n","'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n","'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n if (!(this instanceof RIPEMD160))\n return new RIPEMD160();\n\n BlockHash.call(this);\n\n this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n var A = this.h[0];\n var B = this.h[1];\n var C = this.h[2];\n var D = this.h[3];\n var E = this.h[4];\n var Ah = A;\n var Bh = B;\n var Ch = C;\n var Dh = D;\n var Eh = E;\n for (var j = 0; j < 80; j++) {\n var T = sum32(\n rotl32(\n sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n s[j]),\n E);\n A = E;\n E = D;\n D = rotl32(C, 10);\n C = B;\n B = T;\n T = sum32(\n rotl32(\n sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n sh[j]),\n Eh);\n Ah = Eh;\n Eh = Dh;\n Dh = rotl32(Ch, 10);\n Ch = Bh;\n Bh = T;\n }\n T = sum32_3(this.h[1], C, Dh);\n this.h[1] = sum32_3(this.h[2], D, Eh);\n this.h[2] = sum32_3(this.h[3], E, Ah);\n this.h[3] = sum32_3(this.h[4], A, Bh);\n this.h[4] = sum32_3(this.h[0], B, Ch);\n this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'little');\n else\n return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n if (j <= 15)\n return x ^ y ^ z;\n else if (j <= 31)\n return (x & y) | ((~x) & z);\n else if (j <= 47)\n return (x | (~y)) ^ z;\n else if (j <= 63)\n return (x & z) | (y & (~z));\n else\n return x ^ (y | (~z));\n}\n\nfunction K(j) {\n if (j <= 15)\n return 0x00000000;\n else if (j <= 31)\n return 0x5a827999;\n else if (j <= 47)\n return 0x6ed9eba1;\n else if (j <= 63)\n return 0x8f1bbcdc;\n else\n return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n if (j <= 15)\n return 0x50a28be6;\n else if (j <= 31)\n return 0x5c4dd124;\n else if (j <= 47)\n return 0x6d703ef3;\n else if (j <= 63)\n return 0x7a6d76e9;\n else\n return 0x00000000;\n}\n\nvar r = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n if (!(this instanceof Hmac))\n return new Hmac(hash, key, enc);\n this.Hash = hash;\n this.blockSize = hash.blockSize / 8;\n this.outSize = hash.outSize / 8;\n this.inner = null;\n this.outer = null;\n\n this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n // Shorten key, if needed\n if (key.length > this.blockSize)\n key = new this.Hash().update(key).digest();\n assert(key.length <= this.blockSize);\n\n // Add padding to key\n for (var i = key.length; i < this.blockSize; i++)\n key.push(0);\n\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x36;\n this.inner = new this.Hash().update(key);\n\n // 0x36 ^ 0x5c = 0x6a\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x6a;\n this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n this.inner.update(msg, enc);\n return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n this.outer.update(this.inner.digest());\n return this.outer.digest(enc);\n};\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","module.exports = {\n doubles: {\n step: 4,\n points: [\n [\n 'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n 'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821',\n ],\n [\n '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf',\n ],\n [\n '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n 'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695',\n ],\n [\n '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9',\n ],\n [\n '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36',\n ],\n [\n '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f',\n ],\n [\n 'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999',\n ],\n [\n '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n 'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09',\n ],\n [\n 'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d',\n ],\n [\n 'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n 'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088',\n ],\n [\n 'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d',\n ],\n [\n '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8',\n ],\n [\n '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a',\n ],\n [\n '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453',\n ],\n [\n '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160',\n ],\n [\n '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0',\n ],\n [\n '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6',\n ],\n [\n '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589',\n ],\n [\n '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n 'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17',\n ],\n [\n 'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda',\n ],\n [\n 'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd',\n ],\n [\n '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2',\n ],\n [\n '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6',\n ],\n [\n 'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f',\n ],\n [\n '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n 'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01',\n ],\n [\n 'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3',\n ],\n [\n 'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n 'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f',\n ],\n [\n 'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7',\n ],\n [\n 'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n 'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78',\n ],\n [\n 'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1',\n ],\n [\n '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n 'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150',\n ],\n [\n '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82',\n ],\n [\n 'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc',\n ],\n [\n '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n 'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b',\n ],\n [\n 'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51',\n ],\n [\n 'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45',\n ],\n [\n 'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n 'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120',\n ],\n [\n '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84',\n ],\n [\n '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d',\n ],\n [\n '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n 'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d',\n ],\n [\n '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8',\n ],\n [\n 'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8',\n ],\n [\n '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac',\n ],\n [\n '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n 'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f',\n ],\n [\n '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962',\n ],\n [\n 'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907',\n ],\n [\n '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n 'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec',\n ],\n [\n 'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n 'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d',\n ],\n [\n 'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414',\n ],\n [\n '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n 'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd',\n ],\n [\n '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n 'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0',\n ],\n [\n 'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811',\n ],\n [\n 'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1',\n ],\n [\n 'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c',\n ],\n [\n '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n 'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73',\n ],\n [\n '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd',\n ],\n [\n 'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n 'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405',\n ],\n [\n '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n 'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589',\n ],\n [\n '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e',\n ],\n [\n '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27',\n ],\n [\n 'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n 'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1',\n ],\n [\n '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482',\n ],\n [\n '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945',\n ],\n [\n 'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573',\n ],\n [\n 'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n 'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82',\n ],\n ],\n },\n naf: {\n wnd: 7,\n points: [\n [\n 'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672',\n ],\n [\n '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n 'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6',\n ],\n [\n '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da',\n ],\n [\n 'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n 'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37',\n ],\n [\n '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n 'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b',\n ],\n [\n 'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n 'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81',\n ],\n [\n 'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58',\n ],\n [\n 'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77',\n ],\n [\n '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a',\n ],\n [\n '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c',\n ],\n [\n '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67',\n ],\n [\n '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402',\n ],\n [\n 'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n 'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55',\n ],\n [\n 'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482',\n ],\n [\n '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n 'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82',\n ],\n [\n '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n 'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396',\n ],\n [\n '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49',\n ],\n [\n '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf',\n ],\n [\n '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a',\n ],\n [\n '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n 'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7',\n ],\n [\n 'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n 'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933',\n ],\n [\n '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a',\n ],\n [\n '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6',\n ],\n [\n 'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n 'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37',\n ],\n [\n '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e',\n ],\n [\n 'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n 'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6',\n ],\n [\n 'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n 'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476',\n ],\n [\n '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40',\n ],\n [\n '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61',\n ],\n [\n '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683',\n ],\n [\n 'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5',\n ],\n [\n '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b',\n ],\n [\n 'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417',\n ],\n [\n '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n 'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868',\n ],\n [\n '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n 'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a',\n ],\n [\n 'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n 'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6',\n ],\n [\n '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996',\n ],\n [\n '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n 'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e',\n ],\n [\n 'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n 'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d',\n ],\n [\n '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2',\n ],\n [\n '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n 'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e',\n ],\n [\n '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437',\n ],\n [\n '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n 'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311',\n ],\n [\n 'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4',\n ],\n [\n '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575',\n ],\n [\n '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n 'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d',\n ],\n [\n '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n 'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d',\n ],\n [\n 'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n 'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629',\n ],\n [\n 'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n 'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06',\n ],\n [\n '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374',\n ],\n [\n '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee',\n ],\n [\n 'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1',\n ],\n [\n 'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n 'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b',\n ],\n [\n '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661',\n ],\n [\n '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6',\n ],\n [\n 'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e',\n ],\n [\n '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d',\n ],\n [\n 'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n 'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc',\n ],\n [\n '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n 'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4',\n ],\n [\n '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c',\n ],\n [\n 'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b',\n ],\n [\n 'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913',\n ],\n [\n '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154',\n ],\n [\n '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865',\n ],\n [\n '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n 'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc',\n ],\n [\n '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n 'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224',\n ],\n [\n '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e',\n ],\n [\n '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6',\n ],\n [\n '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511',\n ],\n [\n '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n 'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b',\n ],\n [\n 'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n 'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2',\n ],\n [\n '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n 'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c',\n ],\n [\n 'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3',\n ],\n [\n 'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d',\n ],\n [\n 'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700',\n ],\n [\n 'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4',\n ],\n [\n '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n 'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196',\n ],\n [\n '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4',\n ],\n [\n '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n 'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257',\n ],\n [\n 'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n 'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13',\n ],\n [\n 'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096',\n ],\n [\n 'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n 'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38',\n ],\n [\n 'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f',\n ],\n [\n '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448',\n ],\n [\n 'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a',\n ],\n [\n 'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4',\n ],\n [\n '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437',\n ],\n [\n '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n 'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7',\n ],\n [\n 'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d',\n ],\n [\n 'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a',\n ],\n [\n 'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54',\n ],\n [\n '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77',\n ],\n [\n 'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n 'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517',\n ],\n [\n '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n 'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10',\n ],\n [\n 'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n 'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125',\n ],\n [\n 'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e',\n ],\n [\n '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n 'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1',\n ],\n [\n 'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2',\n ],\n [\n 'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423',\n ],\n [\n 'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8',\n ],\n [\n '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n 'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758',\n ],\n [\n '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n 'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375',\n ],\n [\n 'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d',\n ],\n [\n '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n 'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec',\n ],\n [\n '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0',\n ],\n [\n '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n 'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c',\n ],\n [\n 'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n 'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4',\n ],\n [\n '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n 'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f',\n ],\n [\n '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649',\n ],\n [\n '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n 'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826',\n ],\n [\n '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5',\n ],\n [\n 'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n 'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87',\n ],\n [\n '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b',\n ],\n [\n 'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc',\n ],\n [\n '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c',\n ],\n [\n 'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n 'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f',\n ],\n [\n 'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a',\n ],\n [\n 'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n 'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46',\n ],\n [\n '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n 'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f',\n ],\n [\n '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03',\n ],\n [\n '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n 'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08',\n ],\n [\n '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8',\n ],\n [\n '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373',\n ],\n [\n '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n 'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3',\n ],\n [\n '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8',\n ],\n [\n '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1',\n ],\n [\n '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9',\n ],\n ],\n },\n};\n","'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar curve = require('./curve');\nvar utils = require('./utils');\n\nvar assert = utils.assert;\n\nfunction PresetCurve(options) {\n if (options.type === 'short')\n this.curve = new curve.short(options);\n else if (options.type === 'edwards')\n this.curve = new curve.edwards(options);\n else\n this.curve = new curve.mont(options);\n this.g = this.curve.g;\n this.n = this.curve.n;\n this.hash = options.hash;\n\n assert(this.g.validate(), 'Invalid curve');\n assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n get: function() {\n var curve = new PresetCurve(options);\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n value: curve,\n });\n return curve;\n },\n });\n}\n\ndefineCurve('p192', {\n type: 'short',\n prime: 'p192',\n p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n hash: hash.sha256,\n gRed: false,\n g: [\n '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811',\n ],\n});\n\ndefineCurve('p224', {\n type: 'short',\n prime: 'p224',\n p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n hash: hash.sha256,\n gRed: false,\n g: [\n 'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n 'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34',\n ],\n});\n\ndefineCurve('p256', {\n type: 'short',\n prime: null,\n p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n hash: hash.sha256,\n gRed: false,\n g: [\n '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5',\n ],\n});\n\ndefineCurve('p384', {\n type: 'short',\n prime: null,\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 ffffffff',\n a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 fffffffc',\n b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n 'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n hash: hash.sha384,\n gRed: false,\n g: [\n 'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n '5502f25d bf55296c 3a545e38 72760ab7',\n '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f',\n ],\n});\n\ndefineCurve('p521', {\n type: 'short',\n prime: null,\n p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff',\n a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff fffffffc',\n b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n 'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n hash: hash.sha512,\n gRed: false,\n g: [\n '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n 'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n '3fad0761 353c7086 a272c240 88be9476 9fd16650',\n ],\n});\n\ndefineCurve('curve25519', {\n type: 'mont',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '76d06',\n b: '1',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '9',\n ],\n});\n\ndefineCurve('ed25519', {\n type: 'edwards',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '-1',\n c: '1',\n // -121665 * (121666^(-1)) (mod P)\n d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n // 4/5\n '6666666666666666666666666666666666666666666666666666666666666658',\n ],\n});\n\nvar pre;\ntry {\n pre = require('./precomputed/secp256k1');\n} catch (e) {\n pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n type: 'short',\n prime: 'k256',\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n a: '0',\n b: '7',\n n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n h: '1',\n hash: hash.sha256,\n\n // Precomputed endomorphism\n beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n basis: [\n {\n a: '3086d221a7d46bcde86c90e49284eb15',\n b: '-e4437ed6010e88286f547fa90abfe4c3',\n },\n {\n a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n b: '3086d221a7d46bcde86c90e49284eb15',\n },\n ],\n\n gRed: false,\n g: [\n '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n pre,\n ],\n});\n","'use strict';\n\nvar hash = require('hash.js');\nvar utils = require('minimalistic-crypto-utils');\nvar assert = require('minimalistic-assert');\n\nfunction HmacDRBG(options) {\n if (!(this instanceof HmacDRBG))\n return new HmacDRBG(options);\n this.hash = options.hash;\n this.predResist = !!options.predResist;\n\n this.outLen = this.hash.outSize;\n this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n this._reseed = null;\n this.reseedInterval = null;\n this.K = null;\n this.V = null;\n\n var entropy = utils.toArray(options.entropy, options.entropyEnc || 'hex');\n var nonce = utils.toArray(options.nonce, options.nonceEnc || 'hex');\n var pers = utils.toArray(options.pers, options.persEnc || 'hex');\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n var seed = entropy.concat(nonce).concat(pers);\n\n this.K = new Array(this.outLen / 8);\n this.V = new Array(this.outLen / 8);\n for (var i = 0; i < this.V.length; i++) {\n this.K[i] = 0x00;\n this.V[i] = 0x01;\n }\n\n this._update(seed);\n this._reseed = 1;\n this.reseedInterval = 0x1000000000000; // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n var kmac = this._hmac()\n .update(this.V)\n .update([ 0x00 ]);\n if (seed)\n kmac = kmac.update(seed);\n this.K = kmac.digest();\n this.V = this._hmac().update(this.V).digest();\n if (!seed)\n return;\n\n this.K = this._hmac()\n .update(this.V)\n .update([ 0x01 ])\n .update(seed)\n .digest();\n this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n // Optional entropy enc\n if (typeof entropyEnc !== 'string') {\n addEnc = add;\n add = entropyEnc;\n entropyEnc = null;\n }\n\n entropy = utils.toArray(entropy, entropyEnc);\n add = utils.toArray(add, addEnc);\n\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n this._update(entropy.concat(add || []));\n this._reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n if (this._reseed > this.reseedInterval)\n throw new Error('Reseed is required');\n\n // Optional encoding\n if (typeof enc !== 'string') {\n addEnc = add;\n add = enc;\n enc = null;\n }\n\n // Optional additional data\n if (add) {\n add = utils.toArray(add, addEnc || 'hex');\n this._update(add);\n }\n\n var temp = [];\n while (temp.length < len) {\n this.V = this._hmac().update(this.V).digest();\n temp = temp.concat(this.V);\n }\n\n var res = temp.slice(0, len);\n this._update(add);\n this._reseed++;\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction KeyPair(ec, options) {\n this.ec = ec;\n this.priv = null;\n this.pub = null;\n\n // KeyPair(ec, { priv: ..., pub: ... })\n if (options.priv)\n this._importPrivate(options.priv, options.privEnc);\n if (options.pub)\n this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n if (pub instanceof KeyPair)\n return pub;\n\n return new KeyPair(ec, {\n pub: pub,\n pubEnc: enc,\n });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n if (priv instanceof KeyPair)\n return priv;\n\n return new KeyPair(ec, {\n priv: priv,\n privEnc: enc,\n });\n};\n\nKeyPair.prototype.validate = function validate() {\n var pub = this.getPublic();\n\n if (pub.isInfinity())\n return { result: false, reason: 'Invalid public key' };\n if (!pub.validate())\n return { result: false, reason: 'Public key is not a point' };\n if (!pub.mul(this.ec.curve.n).isInfinity())\n return { result: false, reason: 'Public key * N != O' };\n\n return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n // compact is optional argument\n if (typeof compact === 'string') {\n enc = compact;\n compact = null;\n }\n\n if (!this.pub)\n this.pub = this.ec.g.mul(this.priv);\n\n if (!enc)\n return this.pub;\n\n return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n if (enc === 'hex')\n return this.priv.toString(16, 2);\n else\n return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n this.priv = new BN(key, enc || 16);\n\n // Ensure that the priv won't be bigger than n, otherwise we may fail\n // in fixed multiplication method\n this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n if (key.x || key.y) {\n // Montgomery points only have an `x` coordinate.\n // Weierstrass/Edwards points on the other hand have both `x` and\n // `y` coordinates.\n if (this.ec.curve.type === 'mont') {\n assert(key.x, 'Need x coordinate');\n } else if (this.ec.curve.type === 'short' ||\n this.ec.curve.type === 'edwards') {\n assert(key.x && key.y, 'Need both x and y coordinate');\n }\n this.pub = this.ec.curve.point(key.x, key.y);\n return;\n }\n this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n if(!pub.validate()) {\n assert(pub.validate(), 'public point not validated');\n }\n return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature, options) {\n return this.ec.verify(msg, signature, this, undefined, options);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n return '';\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n if (options instanceof Signature)\n return options;\n\n if (this._importDER(options, enc))\n return;\n\n assert(options.r && options.s, 'Signature without r or s');\n this.r = new BN(options.r, 16);\n this.s = new BN(options.s, 16);\n if (options.recoveryParam === undefined)\n this.recoveryParam = null;\n else\n this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n this.place = 0;\n}\n\nfunction getLength(buf, p) {\n var initial = buf[p.place++];\n if (!(initial & 0x80)) {\n return initial;\n }\n var octetLen = initial & 0xf;\n\n // Indefinite length or overflow\n if (octetLen === 0 || octetLen > 4) {\n return false;\n }\n\n if(buf[p.place] === 0x00) {\n return false;\n }\n\n var val = 0;\n for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n val <<= 8;\n val |= buf[off];\n val >>>= 0;\n }\n\n // Leading zeroes\n if (val <= 0x7f) {\n return false;\n }\n\n p.place = off;\n return val;\n}\n\nfunction rmPadding(buf) {\n var i = 0;\n var len = buf.length - 1;\n while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n i++;\n }\n if (i === 0) {\n return buf;\n }\n return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n data = utils.toArray(data, enc);\n var p = new Position();\n if (data[p.place++] !== 0x30) {\n return false;\n }\n var len = getLength(data, p);\n if (len === false) {\n return false;\n }\n if ((len + p.place) !== data.length) {\n return false;\n }\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var rlen = getLength(data, p);\n if (rlen === false) {\n return false;\n }\n if ((data[p.place] & 128) !== 0) {\n return false;\n }\n var r = data.slice(p.place, rlen + p.place);\n p.place += rlen;\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var slen = getLength(data, p);\n if (slen === false) {\n return false;\n }\n if (data.length !== slen + p.place) {\n return false;\n }\n if ((data[p.place] & 128) !== 0) {\n return false;\n }\n var s = data.slice(p.place, slen + p.place);\n if (r[0] === 0) {\n if (r[1] & 0x80) {\n r = r.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n if (s[0] === 0) {\n if (s[1] & 0x80) {\n s = s.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n\n this.r = new BN(r);\n this.s = new BN(s);\n this.recoveryParam = null;\n\n return true;\n};\n\nfunction constructLength(arr, len) {\n if (len < 0x80) {\n arr.push(len);\n return;\n }\n var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n arr.push(octets | 0x80);\n while (--octets) {\n arr.push((len >>> (octets << 3)) & 0xff);\n }\n arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n var r = this.r.toArray();\n var s = this.s.toArray();\n\n // Pad values\n if (r[0] & 0x80)\n r = [ 0 ].concat(r);\n // Pad values\n if (s[0] & 0x80)\n s = [ 0 ].concat(s);\n\n r = rmPadding(r);\n s = rmPadding(s);\n\n while (!s[0] && !(s[1] & 0x80)) {\n s = s.slice(1);\n }\n var arr = [ 0x02 ];\n constructLength(arr, r.length);\n arr = arr.concat(r);\n arr.push(0x02);\n constructLength(arr, s.length);\n var backHalf = arr.concat(s);\n var res = [ 0x30 ];\n constructLength(res, backHalf.length);\n res = res.concat(backHalf);\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar HmacDRBG = require('hmac-drbg');\nvar utils = require('../utils');\nvar curves = require('../curves');\nvar rand = require('brorand');\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n if (!(this instanceof EC))\n return new EC(options);\n\n // Shortcut `elliptic.ec(curve-name)`\n if (typeof options === 'string') {\n assert(Object.prototype.hasOwnProperty.call(curves, options),\n 'Unknown curve ' + options);\n\n options = curves[options];\n }\n\n // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n if (options instanceof curves.PresetCurve)\n options = { curve: options };\n\n this.curve = options.curve.curve;\n this.n = this.curve.n;\n this.nh = this.n.ushrn(1);\n this.g = this.curve.g;\n\n // Point on curve\n this.g = options.curve.g;\n this.g.precompute(options.curve.n.bitLength() + 1);\n\n // Hash for function for DRBG\n this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n if (!options)\n options = {};\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n entropy: options.entropy || rand(this.hash.hmacStrength),\n entropyEnc: options.entropy && options.entropyEnc || 'utf8',\n nonce: this.n.toArray(),\n });\n\n var bytes = this.n.byteLength();\n var ns2 = this.n.sub(new BN(2));\n for (;;) {\n var priv = new BN(drbg.generate(bytes));\n if (priv.cmp(ns2) > 0)\n continue;\n\n priv.iaddn(1);\n return this.keyFromPrivate(priv);\n }\n};\n\nEC.prototype._truncateToN = function _truncateToN(msg, truncOnly, bitLength) {\n var byteLength;\n if (BN.isBN(msg) || typeof msg === 'number') {\n msg = new BN(msg, 16);\n byteLength = msg.byteLength();\n } else if (typeof msg === 'object') {\n // BN assumes an array-like input and asserts length\n byteLength = msg.length;\n msg = new BN(msg, 16);\n } else {\n // BN converts the value to string\n var str = msg.toString();\n // HEX encoding\n byteLength = (str.length + 1) >>> 1;\n msg = new BN(str, 16);\n }\n // Allow overriding\n if (typeof bitLength !== 'number') {\n bitLength = byteLength * 8;\n }\n var delta = bitLength - this.n.bitLength();\n if (delta > 0)\n msg = msg.ushrn(delta);\n if (!truncOnly && msg.cmp(this.n) >= 0)\n return msg.sub(this.n);\n else\n return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n if (typeof enc === 'object') {\n options = enc;\n enc = null;\n }\n if (!options)\n options = {};\n\n if (typeof msg !== 'string' && typeof msg !== 'number' && !BN.isBN(msg)) {\n assert(typeof msg === 'object' && msg && typeof msg.length === 'number',\n 'Expected message to be an array-like, a hex string, or a BN instance');\n assert((msg.length >>> 0) === msg.length); // non-negative 32-bit integer\n for (var i = 0; i < msg.length; i++) assert((msg[i] & 255) === msg[i]);\n }\n\n key = this.keyFromPrivate(key, enc);\n msg = this._truncateToN(msg, false, options.msgBitLength);\n\n // Would fail further checks, but let's make the error message clear\n assert(!msg.isNeg(), 'Can not sign a negative message');\n\n // Zero-extend key to provide enough entropy\n var bytes = this.n.byteLength();\n var bkey = key.getPrivate().toArray('be', bytes);\n\n // Zero-extend nonce to have the same byte size as N\n var nonce = msg.toArray('be', bytes);\n\n // Recheck nonce to be bijective to msg\n assert((new BN(nonce)).eq(msg), 'Can not sign message');\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n entropy: bkey,\n nonce: nonce,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n });\n\n // Number of bytes to generate\n var ns1 = this.n.sub(new BN(1));\n\n for (var iter = 0; ; iter++) {\n var k = options.k ?\n options.k(iter) :\n new BN(drbg.generate(this.n.byteLength()));\n k = this._truncateToN(k, true);\n if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n continue;\n\n var kp = this.g.mul(k);\n if (kp.isInfinity())\n continue;\n\n var kpX = kp.getX();\n var r = kpX.umod(this.n);\n if (r.cmpn(0) === 0)\n continue;\n\n var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n s = s.umod(this.n);\n if (s.cmpn(0) === 0)\n continue;\n\n var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n (kpX.cmp(r) !== 0 ? 2 : 0);\n\n // Use complement of `s`, if it is > `n / 2`\n if (options.canonical && s.cmp(this.nh) > 0) {\n s = this.n.sub(s);\n recoveryParam ^= 1;\n }\n\n return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc, options) {\n if (!options)\n options = {};\n\n msg = this._truncateToN(msg, false, options.msgBitLength);\n key = this.keyFromPublic(key, enc);\n signature = new Signature(signature, 'hex');\n\n // Perform primitive values validation\n var r = signature.r;\n var s = signature.s;\n if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n return false;\n if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n return false;\n\n // Validate signature\n var sinv = s.invm(this.n);\n var u1 = sinv.mul(msg).umod(this.n);\n var u2 = sinv.mul(r).umod(this.n);\n var p;\n\n if (!this.curve._maxwellTrick) {\n p = this.g.mulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n return p.getX().umod(this.n).cmp(r) === 0;\n }\n\n // NOTE: Greg Maxwell's trick, inspired by:\n // https://git.io/vad3K\n\n p = this.g.jmulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n // Compare `p.x` of Jacobian point with `r`,\n // this will do `p.x == r * p.z^2` instead of multiplying `p.x` by the\n // inverse of `p.z^2`\n return p.eqXToP(r);\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n assert((3 & j) === j, 'The recovery param is more than two bits');\n signature = new Signature(signature, enc);\n\n var n = this.n;\n var e = new BN(msg);\n var r = signature.r;\n var s = signature.s;\n\n // A set LSB signifies that the y-coordinate is odd\n var isYOdd = j & 1;\n var isSecondKey = j >> 1;\n if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n throw new Error('Unable to find sencond key candinate');\n\n // 1.1. Let x = r + jn.\n if (isSecondKey)\n r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n else\n r = this.curve.pointFromX(r, isYOdd);\n\n var rInv = signature.r.invm(n);\n var s1 = n.sub(e).mul(rInv).umod(n);\n var s2 = s.mul(rInv).umod(n);\n\n // 1.6.1 Compute Q = r^-1 (sR - eG)\n // Q = r^-1 (sR + -eG)\n return this.g.mulAdd(s1, r, s2);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n signature = new Signature(signature, enc);\n if (signature.recoveryParam !== null)\n return signature.recoveryParam;\n\n for (var i = 0; i < 4; i++) {\n var Qprime;\n try {\n Qprime = this.recoverPubKey(e, signature, i);\n } catch (e) {\n continue;\n }\n\n if (Qprime.eq(Q))\n return i;\n }\n throw new Error('Unable to find valid recovery factor');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n this.eddsa = eddsa;\n this._secret = parseBytes(params.secret);\n if (eddsa.isPoint(params.pub))\n this._pub = params.pub;\n else\n this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n if (pub instanceof KeyPair)\n return pub;\n return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n if (secret instanceof KeyPair)\n return secret;\n return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n return this._secret;\n};\n\ncachedProperty(KeyPair, 'pubBytes', function pubBytes() {\n return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, 'pub', function pub() {\n if (this._pubBytes)\n return this.eddsa.decodePoint(this._pubBytes);\n return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, 'privBytes', function privBytes() {\n var eddsa = this.eddsa;\n var hash = this.hash();\n var lastIx = eddsa.encodingLength - 1;\n\n var a = hash.slice(0, eddsa.encodingLength);\n a[0] &= 248;\n a[lastIx] &= 127;\n a[lastIx] |= 64;\n\n return a;\n});\n\ncachedProperty(KeyPair, 'priv', function priv() {\n return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, 'hash', function hash() {\n return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, 'messagePrefix', function messagePrefix() {\n return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n assert(this._secret, 'KeyPair can only verify');\n return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n assert(this._secret, 'KeyPair is public only');\n return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array|Object} sig -\n* @param {Array|Point} [sig.R] - R point as Point or bytes\n* @param {Array|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array} [sig.Rencoded] - R point encoded\n* @param {Array} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n this.eddsa = eddsa;\n\n if (typeof sig !== 'object')\n sig = parseBytes(sig);\n\n if (Array.isArray(sig)) {\n assert(sig.length === eddsa.encodingLength * 2, 'Signature has invalid size');\n sig = {\n R: sig.slice(0, eddsa.encodingLength),\n S: sig.slice(eddsa.encodingLength),\n };\n }\n\n assert(sig.R && sig.S, 'Signature without R or S');\n\n if (eddsa.isPoint(sig.R))\n this._R = sig.R;\n if (sig.S instanceof BN)\n this._S = sig.S;\n\n this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, 'S', function S() {\n return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, 'R', function R() {\n return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, 'Rencoded', function Rencoded() {\n return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, 'Sencoded', function Sencoded() {\n return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n","'use strict';\n\nvar hash = require('hash.js');\nvar curves = require('../curves');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n if (!(this instanceof EDDSA))\n return new EDDSA(curve);\n\n curve = curves[curve].curve;\n this.curve = curve;\n this.g = curve.g;\n this.g.precompute(curve.n.bitLength() + 1);\n\n this.pointClass = curve.point().constructor;\n this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n message = parseBytes(message);\n var key = this.keyFromSecret(secret);\n var r = this.hashInt(key.messagePrefix(), message);\n var R = this.g.mul(r);\n var Rencoded = this.encodePoint(R);\n var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n .mul(key.priv());\n var S = r.add(s_).umod(this.curve.n);\n return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n message = parseBytes(message);\n sig = this.makeSignature(sig);\n if (sig.S().gte(sig.eddsa.curve.n) || sig.S().isNeg()) {\n return false;\n }\n var key = this.keyFromPublic(pub);\n var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n var SG = this.g.mul(sig.S());\n var RplusAh = sig.R().add(key.pub().mul(h));\n return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n var hash = this.hash();\n for (var i = 0; i < arguments.length; i++)\n hash.update(arguments[i]);\n return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n if (sig instanceof Signature)\n return sig;\n return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n var enc = point.getY().toArray('le', this.encodingLength);\n enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n bytes = utils.parseBytes(bytes);\n\n var lastIx = bytes.length - 1;\n var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n var y = utils.intFromLE(normed);\n return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n return val instanceof this.pointClass;\n};\n","'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var indexOf = function (xs, item) {\n if (xs.indexOf) return xs.indexOf(item);\n else for (var i = 0; i < xs.length; i++) {\n if (xs[i] === item) return i;\n }\n return -1;\n};\nvar Object_keys = function (obj) {\n if (Object.keys) return Object.keys(obj)\n else {\n var res = [];\n for (var key in obj) res.push(key)\n return res;\n }\n};\n\nvar forEach = function (xs, fn) {\n if (xs.forEach) return xs.forEach(fn)\n else for (var i = 0; i < xs.length; i++) {\n fn(xs[i], i, xs);\n }\n};\n\nvar defineProp = (function() {\n try {\n Object.defineProperty({}, '_', {});\n return function(obj, name, value) {\n Object.defineProperty(obj, name, {\n writable: true,\n enumerable: false,\n configurable: true,\n value: value\n })\n };\n } catch(e) {\n return function(obj, name, value) {\n obj[name] = value;\n };\n }\n}());\n\nvar globals = ['Array', 'Boolean', 'Date', 'Error', 'EvalError', 'Function',\n'Infinity', 'JSON', 'Math', 'NaN', 'Number', 'Object', 'RangeError',\n'ReferenceError', 'RegExp', 'String', 'SyntaxError', 'TypeError', 'URIError',\n'decodeURI', 'decodeURIComponent', 'encodeURI', 'encodeURIComponent', 'escape',\n'eval', 'isFinite', 'isNaN', 'parseFloat', 'parseInt', 'undefined', 'unescape'];\n\nfunction Context() {}\nContext.prototype = {};\n\nvar Script = exports.Script = function NodeScript (code) {\n if (!(this instanceof Script)) return new Script(code);\n this.code = code;\n};\n\nScript.prototype.runInContext = function (context) {\n if (!(context instanceof Context)) {\n throw new TypeError(\"needs a 'context' argument.\");\n }\n \n var iframe = document.createElement('iframe');\n if (!iframe.style) iframe.style = {};\n iframe.style.display = 'none';\n \n document.body.appendChild(iframe);\n \n var win = iframe.contentWindow;\n var wEval = win.eval, wExecScript = win.execScript;\n\n if (!wEval && wExecScript) {\n // win.eval() magically appears when this is called in IE:\n wExecScript.call(win, 'null');\n wEval = win.eval;\n }\n \n forEach(Object_keys(context), function (key) {\n win[key] = context[key];\n });\n forEach(globals, function (key) {\n if (context[key]) {\n win[key] = context[key];\n }\n });\n \n var winKeys = Object_keys(win);\n\n var res = wEval.call(win, this.code);\n \n forEach(Object_keys(win), function (key) {\n // Avoid copying circular objects like `top` and `window` by only\n // updating existing context properties or new properties in the `win`\n // that was only introduced after the eval.\n if (key in context || indexOf(winKeys, key) === -1) {\n context[key] = win[key];\n }\n });\n\n forEach(globals, function (key) {\n if (!(key in context)) {\n defineProp(context, key, win[key]);\n }\n });\n \n document.body.removeChild(iframe);\n \n return res;\n};\n\nScript.prototype.runInThisContext = function () {\n return eval(this.code); // maybe...\n};\n\nScript.prototype.runInNewContext = function (context) {\n var ctx = Script.createContext(context);\n var res = this.runInContext(ctx);\n\n if (context) {\n forEach(Object_keys(ctx), function (key) {\n context[key] = ctx[key];\n });\n }\n\n return res;\n};\n\nforEach(Object_keys(Script.prototype), function (name) {\n exports[name] = Script[name] = function (code) {\n var s = Script(code);\n return s[name].apply(s, [].slice.call(arguments, 1));\n };\n});\n\nexports.isContext = function (context) {\n return context instanceof Context;\n};\n\nexports.createScript = function (code) {\n return exports.Script(code);\n};\n\nexports.createContext = Script.createContext = function (context) {\n var copy = new Context();\n if(typeof context === 'object') {\n forEach(Object_keys(context), function (key) {\n copy[key] = context[key];\n });\n }\n return copy;\n};\n","var asn1 = require('../asn1');\nvar inherits = require('inherits');\n\nvar api = exports;\n\napi.define = function define(name, body) {\n return new Entity(name, body);\n};\n\nfunction Entity(name, body) {\n this.name = name;\n this.body = body;\n\n this.decoders = {};\n this.encoders = {};\n};\n\nEntity.prototype._createNamed = function createNamed(base) {\n var named;\n try {\n named = require('vm').runInThisContext(\n '(function ' + this.name + '(entity) {\\n' +\n ' this._initNamed(entity);\\n' +\n '})'\n );\n } catch (e) {\n named = function (entity) {\n this._initNamed(entity);\n };\n }\n inherits(named, base);\n named.prototype._initNamed = function initnamed(entity) {\n base.call(this, entity);\n };\n\n return new named(this);\n};\n\nEntity.prototype._getDecoder = function _getDecoder(enc) {\n enc = enc || 'der';\n // Lazily create decoder\n if (!this.decoders.hasOwnProperty(enc))\n this.decoders[enc] = this._createNamed(asn1.decoders[enc]);\n return this.decoders[enc];\n};\n\nEntity.prototype.decode = function decode(data, enc, options) {\n return this._getDecoder(enc).decode(data, options);\n};\n\nEntity.prototype._getEncoder = function _getEncoder(enc) {\n enc = enc || 'der';\n // Lazily create encoder\n if (!this.encoders.hasOwnProperty(enc))\n this.encoders[enc] = this._createNamed(asn1.encoders[enc]);\n return this.encoders[enc];\n};\n\nEntity.prototype.encode = function encode(data, enc, /* internal */ reporter) {\n return this._getEncoder(enc).encode(data, reporter);\n};\n","var inherits = require('inherits');\n\nfunction Reporter(options) {\n this._reporterState = {\n obj: null,\n path: [],\n options: options || {},\n errors: []\n };\n}\nexports.Reporter = Reporter;\n\nReporter.prototype.isError = function isError(obj) {\n return obj instanceof ReporterError;\n};\n\nReporter.prototype.save = function save() {\n var state = this._reporterState;\n\n return { obj: state.obj, pathLen: state.path.length };\n};\n\nReporter.prototype.restore = function restore(data) {\n var state = this._reporterState;\n\n state.obj = data.obj;\n state.path = state.path.slice(0, data.pathLen);\n};\n\nReporter.prototype.enterKey = function enterKey(key) {\n return this._reporterState.path.push(key);\n};\n\nReporter.prototype.exitKey = function exitKey(index) {\n var state = this._reporterState;\n\n state.path = state.path.slice(0, index - 1);\n};\n\nReporter.prototype.leaveKey = function leaveKey(index, key, value) {\n var state = this._reporterState;\n\n this.exitKey(index);\n if (state.obj !== null)\n state.obj[key] = value;\n};\n\nReporter.prototype.path = function path() {\n return this._reporterState.path.join('/');\n};\n\nReporter.prototype.enterObject = function enterObject() {\n var state = this._reporterState;\n\n var prev = state.obj;\n state.obj = {};\n return prev;\n};\n\nReporter.prototype.leaveObject = function leaveObject(prev) {\n var state = this._reporterState;\n\n var now = state.obj;\n state.obj = prev;\n return now;\n};\n\nReporter.prototype.error = function error(msg) {\n var err;\n var state = this._reporterState;\n\n var inherited = msg instanceof ReporterError;\n if (inherited) {\n err = msg;\n } else {\n err = new ReporterError(state.path.map(function(elem) {\n return '[' + JSON.stringify(elem) + ']';\n }).join(''), msg.message || msg, msg.stack);\n }\n\n if (!state.options.partial)\n throw err;\n\n if (!inherited)\n state.errors.push(err);\n\n return err;\n};\n\nReporter.prototype.wrapResult = function wrapResult(result) {\n var state = this._reporterState;\n if (!state.options.partial)\n return result;\n\n return {\n result: this.isError(result) ? null : result,\n errors: state.errors\n };\n};\n\nfunction ReporterError(path, msg) {\n this.path = path;\n this.rethrow(msg);\n};\ninherits(ReporterError, Error);\n\nReporterError.prototype.rethrow = function rethrow(msg) {\n this.message = msg + ' at: ' + (this.path || '(shallow)');\n if (Error.captureStackTrace)\n Error.captureStackTrace(this, ReporterError);\n\n if (!this.stack) {\n try {\n // IE only adds stack when thrown\n throw new Error(this.message);\n } catch (e) {\n this.stack = e.stack;\n }\n }\n return this;\n};\n","var inherits = require('inherits');\nvar Reporter = require('../base').Reporter;\nvar Buffer = require('buffer').Buffer;\n\nfunction DecoderBuffer(base, options) {\n Reporter.call(this, options);\n if (!Buffer.isBuffer(base)) {\n this.error('Input not Buffer');\n return;\n }\n\n this.base = base;\n this.offset = 0;\n this.length = base.length;\n}\ninherits(DecoderBuffer, Reporter);\nexports.DecoderBuffer = DecoderBuffer;\n\nDecoderBuffer.prototype.save = function save() {\n return { offset: this.offset, reporter: Reporter.prototype.save.call(this) };\n};\n\nDecoderBuffer.prototype.restore = function restore(save) {\n // Return skipped data\n var res = new DecoderBuffer(this.base);\n res.offset = save.offset;\n res.length = this.offset;\n\n this.offset = save.offset;\n Reporter.prototype.restore.call(this, save.reporter);\n\n return res;\n};\n\nDecoderBuffer.prototype.isEmpty = function isEmpty() {\n return this.offset === this.length;\n};\n\nDecoderBuffer.prototype.readUInt8 = function readUInt8(fail) {\n if (this.offset + 1 <= this.length)\n return this.base.readUInt8(this.offset++, true);\n else\n return this.error(fail || 'DecoderBuffer overrun');\n}\n\nDecoderBuffer.prototype.skip = function skip(bytes, fail) {\n if (!(this.offset + bytes <= this.length))\n return this.error(fail || 'DecoderBuffer overrun');\n\n var res = new DecoderBuffer(this.base);\n\n // Share reporter state\n res._reporterState = this._reporterState;\n\n res.offset = this.offset;\n res.length = this.offset + bytes;\n this.offset += bytes;\n return res;\n}\n\nDecoderBuffer.prototype.raw = function raw(save) {\n return this.base.slice(save ? save.offset : this.offset, this.length);\n}\n\nfunction EncoderBuffer(value, reporter) {\n if (Array.isArray(value)) {\n this.length = 0;\n this.value = value.map(function(item) {\n if (!(item instanceof EncoderBuffer))\n item = new EncoderBuffer(item, reporter);\n this.length += item.length;\n return item;\n }, this);\n } else if (typeof value === 'number') {\n if (!(0 <= value && value <= 0xff))\n return reporter.error('non-byte EncoderBuffer value');\n this.value = value;\n this.length = 1;\n } else if (typeof value === 'string') {\n this.value = value;\n this.length = Buffer.byteLength(value);\n } else if (Buffer.isBuffer(value)) {\n this.value = value;\n this.length = value.length;\n } else {\n return reporter.error('Unsupported type: ' + typeof value);\n }\n}\nexports.EncoderBuffer = EncoderBuffer;\n\nEncoderBuffer.prototype.join = function join(out, offset) {\n if (!out)\n out = new Buffer(this.length);\n if (!offset)\n offset = 0;\n\n if (this.length === 0)\n return out;\n\n if (Array.isArray(this.value)) {\n this.value.forEach(function(item) {\n item.join(out, offset);\n offset += item.length;\n });\n } else {\n if (typeof this.value === 'number')\n out[offset] = this.value;\n else if (typeof this.value === 'string')\n out.write(this.value, offset);\n else if (Buffer.isBuffer(this.value))\n this.value.copy(out, offset);\n offset += this.length;\n }\n\n return out;\n};\n","var Reporter = require('../base').Reporter;\nvar EncoderBuffer = require('../base').EncoderBuffer;\nvar DecoderBuffer = require('../base').DecoderBuffer;\nvar assert = require('minimalistic-assert');\n\n// Supported tags\nvar tags = [\n 'seq', 'seqof', 'set', 'setof', 'objid', 'bool',\n 'gentime', 'utctime', 'null_', 'enum', 'int', 'objDesc',\n 'bitstr', 'bmpstr', 'charstr', 'genstr', 'graphstr', 'ia5str', 'iso646str',\n 'numstr', 'octstr', 'printstr', 't61str', 'unistr', 'utf8str', 'videostr'\n];\n\n// Public methods list\nvar methods = [\n 'key', 'obj', 'use', 'optional', 'explicit', 'implicit', 'def', 'choice',\n 'any', 'contains'\n].concat(tags);\n\n// Overrided methods list\nvar overrided = [\n '_peekTag', '_decodeTag', '_use',\n '_decodeStr', '_decodeObjid', '_decodeTime',\n '_decodeNull', '_decodeInt', '_decodeBool', '_decodeList',\n\n '_encodeComposite', '_encodeStr', '_encodeObjid', '_encodeTime',\n '_encodeNull', '_encodeInt', '_encodeBool'\n];\n\nfunction Node(enc, parent) {\n var state = {};\n this._baseState = state;\n\n state.enc = enc;\n\n state.parent = parent || null;\n state.children = null;\n\n // State\n state.tag = null;\n state.args = null;\n state.reverseArgs = null;\n state.choice = null;\n state.optional = false;\n state.any = false;\n state.obj = false;\n state.use = null;\n state.useDecoder = null;\n state.key = null;\n state['default'] = null;\n state.explicit = null;\n state.implicit = null;\n state.contains = null;\n\n // Should create new instance on each method\n if (!state.parent) {\n state.children = [];\n this._wrap();\n }\n}\nmodule.exports = Node;\n\nvar stateProps = [\n 'enc', 'parent', 'children', 'tag', 'args', 'reverseArgs', 'choice',\n 'optional', 'any', 'obj', 'use', 'alteredUse', 'key', 'default', 'explicit',\n 'implicit', 'contains'\n];\n\nNode.prototype.clone = function clone() {\n var state = this._baseState;\n var cstate = {};\n stateProps.forEach(function(prop) {\n cstate[prop] = state[prop];\n });\n var res = new this.constructor(cstate.parent);\n res._baseState = cstate;\n return res;\n};\n\nNode.prototype._wrap = function wrap() {\n var state = this._baseState;\n methods.forEach(function(method) {\n this[method] = function _wrappedMethod() {\n var clone = new this.constructor(this);\n state.children.push(clone);\n return clone[method].apply(clone, arguments);\n };\n }, this);\n};\n\nNode.prototype._init = function init(body) {\n var state = this._baseState;\n\n assert(state.parent === null);\n body.call(this);\n\n // Filter children\n state.children = state.children.filter(function(child) {\n return child._baseState.parent === this;\n }, this);\n assert.equal(state.children.length, 1, 'Root node can have only one child');\n};\n\nNode.prototype._useArgs = function useArgs(args) {\n var state = this._baseState;\n\n // Filter children and args\n var children = args.filter(function(arg) {\n return arg instanceof this.constructor;\n }, this);\n args = args.filter(function(arg) {\n return !(arg instanceof this.constructor);\n }, this);\n\n if (children.length !== 0) {\n assert(state.children === null);\n state.children = children;\n\n // Replace parent to maintain backward link\n children.forEach(function(child) {\n child._baseState.parent = this;\n }, this);\n }\n if (args.length !== 0) {\n assert(state.args === null);\n state.args = args;\n state.reverseArgs = args.map(function(arg) {\n if (typeof arg !== 'object' || arg.constructor !== Object)\n return arg;\n\n var res = {};\n Object.keys(arg).forEach(function(key) {\n if (key == (key | 0))\n key |= 0;\n var value = arg[key];\n res[value] = key;\n });\n return res;\n });\n }\n};\n\n//\n// Overrided methods\n//\n\noverrided.forEach(function(method) {\n Node.prototype[method] = function _overrided() {\n var state = this._baseState;\n throw new Error(method + ' not implemented for encoding: ' + state.enc);\n };\n});\n\n//\n// Public methods\n//\n\ntags.forEach(function(tag) {\n Node.prototype[tag] = function _tagMethod() {\n var state = this._baseState;\n var args = Array.prototype.slice.call(arguments);\n\n assert(state.tag === null);\n state.tag = tag;\n\n this._useArgs(args);\n\n return this;\n };\n});\n\nNode.prototype.use = function use(item) {\n assert(item);\n var state = this._baseState;\n\n assert(state.use === null);\n state.use = item;\n\n return this;\n};\n\nNode.prototype.optional = function optional() {\n var state = this._baseState;\n\n state.optional = true;\n\n return this;\n};\n\nNode.prototype.def = function def(val) {\n var state = this._baseState;\n\n assert(state['default'] === null);\n state['default'] = val;\n state.optional = true;\n\n return this;\n};\n\nNode.prototype.explicit = function explicit(num) {\n var state = this._baseState;\n\n assert(state.explicit === null && state.implicit === null);\n state.explicit = num;\n\n return this;\n};\n\nNode.prototype.implicit = function implicit(num) {\n var state = this._baseState;\n\n assert(state.explicit === null && state.implicit === null);\n state.implicit = num;\n\n return this;\n};\n\nNode.prototype.obj = function obj() {\n var state = this._baseState;\n var args = Array.prototype.slice.call(arguments);\n\n state.obj = true;\n\n if (args.length !== 0)\n this._useArgs(args);\n\n return this;\n};\n\nNode.prototype.key = function key(newKey) {\n var state = this._baseState;\n\n assert(state.key === null);\n state.key = newKey;\n\n return this;\n};\n\nNode.prototype.any = function any() {\n var state = this._baseState;\n\n state.any = true;\n\n return this;\n};\n\nNode.prototype.choice = function choice(obj) {\n var state = this._baseState;\n\n assert(state.choice === null);\n state.choice = obj;\n this._useArgs(Object.keys(obj).map(function(key) {\n return obj[key];\n }));\n\n return this;\n};\n\nNode.prototype.contains = function contains(item) {\n var state = this._baseState;\n\n assert(state.use === null);\n state.contains = item;\n\n return this;\n};\n\n//\n// Decoding\n//\n\nNode.prototype._decode = function decode(input, options) {\n var state = this._baseState;\n\n // Decode root node\n if (state.parent === null)\n return input.wrapResult(state.children[0]._decode(input, options));\n\n var result = state['default'];\n var present = true;\n\n var prevKey = null;\n if (state.key !== null)\n prevKey = input.enterKey(state.key);\n\n // Check if tag is there\n if (state.optional) {\n var tag = null;\n if (state.explicit !== null)\n tag = state.explicit;\n else if (state.implicit !== null)\n tag = state.implicit;\n else if (state.tag !== null)\n tag = state.tag;\n\n if (tag === null && !state.any) {\n // Trial and Error\n var save = input.save();\n try {\n if (state.choice === null)\n this._decodeGeneric(state.tag, input, options);\n else\n this._decodeChoice(input, options);\n present = true;\n } catch (e) {\n present = false;\n }\n input.restore(save);\n } else {\n present = this._peekTag(input, tag, state.any);\n\n if (input.isError(present))\n return present;\n }\n }\n\n // Push object on stack\n var prevObj;\n if (state.obj && present)\n prevObj = input.enterObject();\n\n if (present) {\n // Unwrap explicit values\n if (state.explicit !== null) {\n var explicit = this._decodeTag(input, state.explicit);\n if (input.isError(explicit))\n return explicit;\n input = explicit;\n }\n\n var start = input.offset;\n\n // Unwrap implicit and normal values\n if (state.use === null && state.choice === null) {\n if (state.any)\n var save = input.save();\n var body = this._decodeTag(\n input,\n state.implicit !== null ? state.implicit : state.tag,\n state.any\n );\n if (input.isError(body))\n return body;\n\n if (state.any)\n result = input.raw(save);\n else\n input = body;\n }\n\n if (options && options.track && state.tag !== null)\n options.track(input.path(), start, input.length, 'tagged');\n\n if (options && options.track && state.tag !== null)\n options.track(input.path(), input.offset, input.length, 'content');\n\n // Select proper method for tag\n if (state.any)\n result = result;\n else if (state.choice === null)\n result = this._decodeGeneric(state.tag, input, options);\n else\n result = this._decodeChoice(input, options);\n\n if (input.isError(result))\n return result;\n\n // Decode children\n if (!state.any && state.choice === null && state.children !== null) {\n state.children.forEach(function decodeChildren(child) {\n // NOTE: We are ignoring errors here, to let parser continue with other\n // parts of encoded data\n child._decode(input, options);\n });\n }\n\n // Decode contained/encoded by schema, only in bit or octet strings\n if (state.contains && (state.tag === 'octstr' || state.tag === 'bitstr')) {\n var data = new DecoderBuffer(result);\n result = this._getUse(state.contains, input._reporterState.obj)\n ._decode(data, options);\n }\n }\n\n // Pop object\n if (state.obj && present)\n result = input.leaveObject(prevObj);\n\n // Set key\n if (state.key !== null && (result !== null || present === true))\n input.leaveKey(prevKey, state.key, result);\n else if (prevKey !== null)\n input.exitKey(prevKey);\n\n return result;\n};\n\nNode.prototype._decodeGeneric = function decodeGeneric(tag, input, options) {\n var state = this._baseState;\n\n if (tag === 'seq' || tag === 'set')\n return null;\n if (tag === 'seqof' || tag === 'setof')\n return this._decodeList(input, tag, state.args[0], options);\n else if (/str$/.test(tag))\n return this._decodeStr(input, tag, options);\n else if (tag === 'objid' && state.args)\n return this._decodeObjid(input, state.args[0], state.args[1], options);\n else if (tag === 'objid')\n return this._decodeObjid(input, null, null, options);\n else if (tag === 'gentime' || tag === 'utctime')\n return this._decodeTime(input, tag, options);\n else if (tag === 'null_')\n return this._decodeNull(input, options);\n else if (tag === 'bool')\n return this._decodeBool(input, options);\n else if (tag === 'objDesc')\n return this._decodeStr(input, tag, options);\n else if (tag === 'int' || tag === 'enum')\n return this._decodeInt(input, state.args && state.args[0], options);\n\n if (state.use !== null) {\n return this._getUse(state.use, input._reporterState.obj)\n ._decode(input, options);\n } else {\n return input.error('unknown tag: ' + tag);\n }\n};\n\nNode.prototype._getUse = function _getUse(entity, obj) {\n\n var state = this._baseState;\n // Create altered use decoder if implicit is set\n state.useDecoder = this._use(entity, obj);\n assert(state.useDecoder._baseState.parent === null);\n state.useDecoder = state.useDecoder._baseState.children[0];\n if (state.implicit !== state.useDecoder._baseState.implicit) {\n state.useDecoder = state.useDecoder.clone();\n state.useDecoder._baseState.implicit = state.implicit;\n }\n return state.useDecoder;\n};\n\nNode.prototype._decodeChoice = function decodeChoice(input, options) {\n var state = this._baseState;\n var result = null;\n var match = false;\n\n Object.keys(state.choice).some(function(key) {\n var save = input.save();\n var node = state.choice[key];\n try {\n var value = node._decode(input, options);\n if (input.isError(value))\n return false;\n\n result = { type: key, value: value };\n match = true;\n } catch (e) {\n input.restore(save);\n return false;\n }\n return true;\n }, this);\n\n if (!match)\n return input.error('Choice not matched');\n\n return result;\n};\n\n//\n// Encoding\n//\n\nNode.prototype._createEncoderBuffer = function createEncoderBuffer(data) {\n return new EncoderBuffer(data, this.reporter);\n};\n\nNode.prototype._encode = function encode(data, reporter, parent) {\n var state = this._baseState;\n if (state['default'] !== null && state['default'] === data)\n return;\n\n var result = this._encodeValue(data, reporter, parent);\n if (result === undefined)\n return;\n\n if (this._skipDefault(result, reporter, parent))\n return;\n\n return result;\n};\n\nNode.prototype._encodeValue = function encode(data, reporter, parent) {\n var state = this._baseState;\n\n // Decode root node\n if (state.parent === null)\n return state.children[0]._encode(data, reporter || new Reporter());\n\n var result = null;\n\n // Set reporter to share it with a child class\n this.reporter = reporter;\n\n // Check if data is there\n if (state.optional && data === undefined) {\n if (state['default'] !== null)\n data = state['default']\n else\n return;\n }\n\n // Encode children first\n var content = null;\n var primitive = false;\n if (state.any) {\n // Anything that was given is translated to buffer\n result = this._createEncoderBuffer(data);\n } else if (state.choice) {\n result = this._encodeChoice(data, reporter);\n } else if (state.contains) {\n content = this._getUse(state.contains, parent)._encode(data, reporter);\n primitive = true;\n } else if (state.children) {\n content = state.children.map(function(child) {\n if (child._baseState.tag === 'null_')\n return child._encode(null, reporter, data);\n\n if (child._baseState.key === null)\n return reporter.error('Child should have a key');\n var prevKey = reporter.enterKey(child._baseState.key);\n\n if (typeof data !== 'object')\n return reporter.error('Child expected, but input is not object');\n\n var res = child._encode(data[child._baseState.key], reporter, data);\n reporter.leaveKey(prevKey);\n\n return res;\n }, this).filter(function(child) {\n return child;\n });\n content = this._createEncoderBuffer(content);\n } else {\n if (state.tag === 'seqof' || state.tag === 'setof') {\n // TODO(indutny): this should be thrown on DSL level\n if (!(state.args && state.args.length === 1))\n return reporter.error('Too many args for : ' + state.tag);\n\n if (!Array.isArray(data))\n return reporter.error('seqof/setof, but data is not Array');\n\n var child = this.clone();\n child._baseState.implicit = null;\n content = this._createEncoderBuffer(data.map(function(item) {\n var state = this._baseState;\n\n return this._getUse(state.args[0], data)._encode(item, reporter);\n }, child));\n } else if (state.use !== null) {\n result = this._getUse(state.use, parent)._encode(data, reporter);\n } else {\n content = this._encodePrimitive(state.tag, data);\n primitive = true;\n }\n }\n\n // Encode data itself\n var result;\n if (!state.any && state.choice === null) {\n var tag = state.implicit !== null ? state.implicit : state.tag;\n var cls = state.implicit === null ? 'universal' : 'context';\n\n if (tag === null) {\n if (state.use === null)\n reporter.error('Tag could be omitted only for .use()');\n } else {\n if (state.use === null)\n result = this._encodeComposite(tag, primitive, cls, content);\n }\n }\n\n // Wrap in explicit\n if (state.explicit !== null)\n result = this._encodeComposite(state.explicit, false, 'context', result);\n\n return result;\n};\n\nNode.prototype._encodeChoice = function encodeChoice(data, reporter) {\n var state = this._baseState;\n\n var node = state.choice[data.type];\n if (!node) {\n assert(\n false,\n data.type + ' not found in ' +\n JSON.stringify(Object.keys(state.choice)));\n }\n return node._encode(data.value, reporter);\n};\n\nNode.prototype._encodePrimitive = function encodePrimitive(tag, data) {\n var state = this._baseState;\n\n if (/str$/.test(tag))\n return this._encodeStr(data, tag);\n else if (tag === 'objid' && state.args)\n return this._encodeObjid(data, state.reverseArgs[0], state.args[1]);\n else if (tag === 'objid')\n return this._encodeObjid(data, null, null);\n else if (tag === 'gentime' || tag === 'utctime')\n return this._encodeTime(data, tag);\n else if (tag === 'null_')\n return this._encodeNull();\n else if (tag === 'int' || tag === 'enum')\n return this._encodeInt(data, state.args && state.reverseArgs[0]);\n else if (tag === 'bool')\n return this._encodeBool(data);\n else if (tag === 'objDesc')\n return this._encodeStr(data, tag);\n else\n throw new Error('Unsupported tag: ' + tag);\n};\n\nNode.prototype._isNumstr = function isNumstr(str) {\n return /^[0-9 ]*$/.test(str);\n};\n\nNode.prototype._isPrintstr = function isPrintstr(str) {\n return /^[A-Za-z0-9 '\\(\\)\\+,\\-\\.\\/:=\\?]*$/.test(str);\n};\n","var base = exports;\n\nbase.Reporter = require('./reporter').Reporter;\nbase.DecoderBuffer = require('./buffer').DecoderBuffer;\nbase.EncoderBuffer = require('./buffer').EncoderBuffer;\nbase.Node = require('./node');\n","var constants = require('../constants');\n\nexports.tagClass = {\n 0: 'universal',\n 1: 'application',\n 2: 'context',\n 3: 'private'\n};\nexports.tagClassByName = constants._reverse(exports.tagClass);\n\nexports.tag = {\n 0x00: 'end',\n 0x01: 'bool',\n 0x02: 'int',\n 0x03: 'bitstr',\n 0x04: 'octstr',\n 0x05: 'null_',\n 0x06: 'objid',\n 0x07: 'objDesc',\n 0x08: 'external',\n 0x09: 'real',\n 0x0a: 'enum',\n 0x0b: 'embed',\n 0x0c: 'utf8str',\n 0x0d: 'relativeOid',\n 0x10: 'seq',\n 0x11: 'set',\n 0x12: 'numstr',\n 0x13: 'printstr',\n 0x14: 't61str',\n 0x15: 'videostr',\n 0x16: 'ia5str',\n 0x17: 'utctime',\n 0x18: 'gentime',\n 0x19: 'graphstr',\n 0x1a: 'iso646str',\n 0x1b: 'genstr',\n 0x1c: 'unistr',\n 0x1d: 'charstr',\n 0x1e: 'bmpstr'\n};\nexports.tagByName = constants._reverse(exports.tag);\n","var constants = exports;\n\n// Helper\nconstants._reverse = function reverse(map) {\n var res = {};\n\n Object.keys(map).forEach(function(key) {\n // Convert key to integer if it is stringified\n if ((key | 0) == key)\n key = key | 0;\n\n var value = map[key];\n res[value] = key;\n });\n\n return res;\n};\n\nconstants.der = require('./der');\n","var inherits = require('inherits');\n\nvar asn1 = require('../../asn1');\nvar base = asn1.base;\nvar bignum = asn1.bignum;\n\n// Import DER constants\nvar der = asn1.constants.der;\n\nfunction DERDecoder(entity) {\n this.enc = 'der';\n this.name = entity.name;\n this.entity = entity;\n\n // Construct base tree\n this.tree = new DERNode();\n this.tree._init(entity.body);\n};\nmodule.exports = DERDecoder;\n\nDERDecoder.prototype.decode = function decode(data, options) {\n if (!(data instanceof base.DecoderBuffer))\n data = new base.DecoderBuffer(data, options);\n\n return this.tree._decode(data, options);\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n base.Node.call(this, 'der', parent);\n}\ninherits(DERNode, base.Node);\n\nDERNode.prototype._peekTag = function peekTag(buffer, tag, any) {\n if (buffer.isEmpty())\n return false;\n\n var state = buffer.save();\n var decodedTag = derDecodeTag(buffer, 'Failed to peek tag: \"' + tag + '\"');\n if (buffer.isError(decodedTag))\n return decodedTag;\n\n buffer.restore(state);\n\n return decodedTag.tag === tag || decodedTag.tagStr === tag ||\n (decodedTag.tagStr + 'of') === tag || any;\n};\n\nDERNode.prototype._decodeTag = function decodeTag(buffer, tag, any) {\n var decodedTag = derDecodeTag(buffer,\n 'Failed to decode tag of \"' + tag + '\"');\n if (buffer.isError(decodedTag))\n return decodedTag;\n\n var len = derDecodeLen(buffer,\n decodedTag.primitive,\n 'Failed to get length of \"' + tag + '\"');\n\n // Failure\n if (buffer.isError(len))\n return len;\n\n if (!any &&\n decodedTag.tag !== tag &&\n decodedTag.tagStr !== tag &&\n decodedTag.tagStr + 'of' !== tag) {\n return buffer.error('Failed to match tag: \"' + tag + '\"');\n }\n\n if (decodedTag.primitive || len !== null)\n return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n\n // Indefinite length... find END tag\n var state = buffer.save();\n var res = this._skipUntilEnd(\n buffer,\n 'Failed to skip indefinite length body: \"' + this.tag + '\"');\n if (buffer.isError(res))\n return res;\n\n len = buffer.offset - state.offset;\n buffer.restore(state);\n return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n};\n\nDERNode.prototype._skipUntilEnd = function skipUntilEnd(buffer, fail) {\n while (true) {\n var tag = derDecodeTag(buffer, fail);\n if (buffer.isError(tag))\n return tag;\n var len = derDecodeLen(buffer, tag.primitive, fail);\n if (buffer.isError(len))\n return len;\n\n var res;\n if (tag.primitive || len !== null)\n res = buffer.skip(len)\n else\n res = this._skipUntilEnd(buffer, fail);\n\n // Failure\n if (buffer.isError(res))\n return res;\n\n if (tag.tagStr === 'end')\n break;\n }\n};\n\nDERNode.prototype._decodeList = function decodeList(buffer, tag, decoder,\n options) {\n var result = [];\n while (!buffer.isEmpty()) {\n var possibleEnd = this._peekTag(buffer, 'end');\n if (buffer.isError(possibleEnd))\n return possibleEnd;\n\n var res = decoder.decode(buffer, 'der', options);\n if (buffer.isError(res) && possibleEnd)\n break;\n result.push(res);\n }\n return result;\n};\n\nDERNode.prototype._decodeStr = function decodeStr(buffer, tag) {\n if (tag === 'bitstr') {\n var unused = buffer.readUInt8();\n if (buffer.isError(unused))\n return unused;\n return { unused: unused, data: buffer.raw() };\n } else if (tag === 'bmpstr') {\n var raw = buffer.raw();\n if (raw.length % 2 === 1)\n return buffer.error('Decoding of string type: bmpstr length mismatch');\n\n var str = '';\n for (var i = 0; i < raw.length / 2; i++) {\n str += String.fromCharCode(raw.readUInt16BE(i * 2));\n }\n return str;\n } else if (tag === 'numstr') {\n var numstr = buffer.raw().toString('ascii');\n if (!this._isNumstr(numstr)) {\n return buffer.error('Decoding of string type: ' +\n 'numstr unsupported characters');\n }\n return numstr;\n } else if (tag === 'octstr') {\n return buffer.raw();\n } else if (tag === 'objDesc') {\n return buffer.raw();\n } else if (tag === 'printstr') {\n var printstr = buffer.raw().toString('ascii');\n if (!this._isPrintstr(printstr)) {\n return buffer.error('Decoding of string type: ' +\n 'printstr unsupported characters');\n }\n return printstr;\n } else if (/str$/.test(tag)) {\n return buffer.raw().toString();\n } else {\n return buffer.error('Decoding of string type: ' + tag + ' unsupported');\n }\n};\n\nDERNode.prototype._decodeObjid = function decodeObjid(buffer, values, relative) {\n var result;\n var identifiers = [];\n var ident = 0;\n while (!buffer.isEmpty()) {\n var subident = buffer.readUInt8();\n ident <<= 7;\n ident |= subident & 0x7f;\n if ((subident & 0x80) === 0) {\n identifiers.push(ident);\n ident = 0;\n }\n }\n if (subident & 0x80)\n identifiers.push(ident);\n\n var first = (identifiers[0] / 40) | 0;\n var second = identifiers[0] % 40;\n\n if (relative)\n result = identifiers;\n else\n result = [first, second].concat(identifiers.slice(1));\n\n if (values) {\n var tmp = values[result.join(' ')];\n if (tmp === undefined)\n tmp = values[result.join('.')];\n if (tmp !== undefined)\n result = tmp;\n }\n\n return result;\n};\n\nDERNode.prototype._decodeTime = function decodeTime(buffer, tag) {\n var str = buffer.raw().toString();\n if (tag === 'gentime') {\n var year = str.slice(0, 4) | 0;\n var mon = str.slice(4, 6) | 0;\n var day = str.slice(6, 8) | 0;\n var hour = str.slice(8, 10) | 0;\n var min = str.slice(10, 12) | 0;\n var sec = str.slice(12, 14) | 0;\n } else if (tag === 'utctime') {\n var year = str.slice(0, 2) | 0;\n var mon = str.slice(2, 4) | 0;\n var day = str.slice(4, 6) | 0;\n var hour = str.slice(6, 8) | 0;\n var min = str.slice(8, 10) | 0;\n var sec = str.slice(10, 12) | 0;\n if (year < 70)\n year = 2000 + year;\n else\n year = 1900 + year;\n } else {\n return buffer.error('Decoding ' + tag + ' time is not supported yet');\n }\n\n return Date.UTC(year, mon - 1, day, hour, min, sec, 0);\n};\n\nDERNode.prototype._decodeNull = function decodeNull(buffer) {\n return null;\n};\n\nDERNode.prototype._decodeBool = function decodeBool(buffer) {\n var res = buffer.readUInt8();\n if (buffer.isError(res))\n return res;\n else\n return res !== 0;\n};\n\nDERNode.prototype._decodeInt = function decodeInt(buffer, values) {\n // Bigint, return as it is (assume big endian)\n var raw = buffer.raw();\n var res = new bignum(raw);\n\n if (values)\n res = values[res.toString(10)] || res;\n\n return res;\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n if (typeof entity === 'function')\n entity = entity(obj);\n return entity._getDecoder('der').tree;\n};\n\n// Utility methods\n\nfunction derDecodeTag(buf, fail) {\n var tag = buf.readUInt8(fail);\n if (buf.isError(tag))\n return tag;\n\n var cls = der.tagClass[tag >> 6];\n var primitive = (tag & 0x20) === 0;\n\n // Multi-octet tag - load\n if ((tag & 0x1f) === 0x1f) {\n var oct = tag;\n tag = 0;\n while ((oct & 0x80) === 0x80) {\n oct = buf.readUInt8(fail);\n if (buf.isError(oct))\n return oct;\n\n tag <<= 7;\n tag |= oct & 0x7f;\n }\n } else {\n tag &= 0x1f;\n }\n var tagStr = der.tag[tag];\n\n return {\n cls: cls,\n primitive: primitive,\n tag: tag,\n tagStr: tagStr\n };\n}\n\nfunction derDecodeLen(buf, primitive, fail) {\n var len = buf.readUInt8(fail);\n if (buf.isError(len))\n return len;\n\n // Indefinite form\n if (!primitive && len === 0x80)\n return null;\n\n // Definite form\n if ((len & 0x80) === 0) {\n // Short form\n return len;\n }\n\n // Long form\n var num = len & 0x7f;\n if (num > 4)\n return buf.error('length octect is too long');\n\n len = 0;\n for (var i = 0; i < num; i++) {\n len <<= 8;\n var j = buf.readUInt8(fail);\n if (buf.isError(j))\n return j;\n len |= j;\n }\n\n return len;\n}\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar DERDecoder = require('./der');\n\nfunction PEMDecoder(entity) {\n DERDecoder.call(this, entity);\n this.enc = 'pem';\n};\ninherits(PEMDecoder, DERDecoder);\nmodule.exports = PEMDecoder;\n\nPEMDecoder.prototype.decode = function decode(data, options) {\n var lines = data.toString().split(/[\\r\\n]+/g);\n\n var label = options.label.toUpperCase();\n\n var re = /^-----(BEGIN|END) ([^-]+)-----$/;\n var start = -1;\n var end = -1;\n for (var i = 0; i < lines.length; i++) {\n var match = lines[i].match(re);\n if (match === null)\n continue;\n\n if (match[2] !== label)\n continue;\n\n if (start === -1) {\n if (match[1] !== 'BEGIN')\n break;\n start = i;\n } else {\n if (match[1] !== 'END')\n break;\n end = i;\n break;\n }\n }\n if (start === -1 || end === -1)\n throw new Error('PEM section not found for: ' + label);\n\n var base64 = lines.slice(start + 1, end).join('');\n // Remove excessive symbols\n base64.replace(/[^a-z0-9\\+\\/=]+/gi, '');\n\n var input = new Buffer(base64, 'base64');\n return DERDecoder.prototype.decode.call(this, input, options);\n};\n","var decoders = exports;\n\ndecoders.der = require('./der');\ndecoders.pem = require('./pem');\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar asn1 = require('../../asn1');\nvar base = asn1.base;\n\n// Import DER constants\nvar der = asn1.constants.der;\n\nfunction DEREncoder(entity) {\n this.enc = 'der';\n this.name = entity.name;\n this.entity = entity;\n\n // Construct base tree\n this.tree = new DERNode();\n this.tree._init(entity.body);\n};\nmodule.exports = DEREncoder;\n\nDEREncoder.prototype.encode = function encode(data, reporter) {\n return this.tree._encode(data, reporter).join();\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n base.Node.call(this, 'der', parent);\n}\ninherits(DERNode, base.Node);\n\nDERNode.prototype._encodeComposite = function encodeComposite(tag,\n primitive,\n cls,\n content) {\n var encodedTag = encodeTag(tag, primitive, cls, this.reporter);\n\n // Short form\n if (content.length < 0x80) {\n var header = new Buffer(2);\n header[0] = encodedTag;\n header[1] = content.length;\n return this._createEncoderBuffer([ header, content ]);\n }\n\n // Long form\n // Count octets required to store length\n var lenOctets = 1;\n for (var i = content.length; i >= 0x100; i >>= 8)\n lenOctets++;\n\n var header = new Buffer(1 + 1 + lenOctets);\n header[0] = encodedTag;\n header[1] = 0x80 | lenOctets;\n\n for (var i = 1 + lenOctets, j = content.length; j > 0; i--, j >>= 8)\n header[i] = j & 0xff;\n\n return this._createEncoderBuffer([ header, content ]);\n};\n\nDERNode.prototype._encodeStr = function encodeStr(str, tag) {\n if (tag === 'bitstr') {\n return this._createEncoderBuffer([ str.unused | 0, str.data ]);\n } else if (tag === 'bmpstr') {\n var buf = new Buffer(str.length * 2);\n for (var i = 0; i < str.length; i++) {\n buf.writeUInt16BE(str.charCodeAt(i), i * 2);\n }\n return this._createEncoderBuffer(buf);\n } else if (tag === 'numstr') {\n if (!this._isNumstr(str)) {\n return this.reporter.error('Encoding of string type: numstr supports ' +\n 'only digits and space');\n }\n return this._createEncoderBuffer(str);\n } else if (tag === 'printstr') {\n if (!this._isPrintstr(str)) {\n return this.reporter.error('Encoding of string type: printstr supports ' +\n 'only latin upper and lower case letters, ' +\n 'digits, space, apostrophe, left and rigth ' +\n 'parenthesis, plus sign, comma, hyphen, ' +\n 'dot, slash, colon, equal sign, ' +\n 'question mark');\n }\n return this._createEncoderBuffer(str);\n } else if (/str$/.test(tag)) {\n return this._createEncoderBuffer(str);\n } else if (tag === 'objDesc') {\n return this._createEncoderBuffer(str);\n } else {\n return this.reporter.error('Encoding of string type: ' + tag +\n ' unsupported');\n }\n};\n\nDERNode.prototype._encodeObjid = function encodeObjid(id, values, relative) {\n if (typeof id === 'string') {\n if (!values)\n return this.reporter.error('string objid given, but no values map found');\n if (!values.hasOwnProperty(id))\n return this.reporter.error('objid not found in values map');\n id = values[id].split(/[\\s\\.]+/g);\n for (var i = 0; i < id.length; i++)\n id[i] |= 0;\n } else if (Array.isArray(id)) {\n id = id.slice();\n for (var i = 0; i < id.length; i++)\n id[i] |= 0;\n }\n\n if (!Array.isArray(id)) {\n return this.reporter.error('objid() should be either array or string, ' +\n 'got: ' + JSON.stringify(id));\n }\n\n if (!relative) {\n if (id[1] >= 40)\n return this.reporter.error('Second objid identifier OOB');\n id.splice(0, 2, id[0] * 40 + id[1]);\n }\n\n // Count number of octets\n var size = 0;\n for (var i = 0; i < id.length; i++) {\n var ident = id[i];\n for (size++; ident >= 0x80; ident >>= 7)\n size++;\n }\n\n var objid = new Buffer(size);\n var offset = objid.length - 1;\n for (var i = id.length - 1; i >= 0; i--) {\n var ident = id[i];\n objid[offset--] = ident & 0x7f;\n while ((ident >>= 7) > 0)\n objid[offset--] = 0x80 | (ident & 0x7f);\n }\n\n return this._createEncoderBuffer(objid);\n};\n\nfunction two(num) {\n if (num < 10)\n return '0' + num;\n else\n return num;\n}\n\nDERNode.prototype._encodeTime = function encodeTime(time, tag) {\n var str;\n var date = new Date(time);\n\n if (tag === 'gentime') {\n str = [\n two(date.getFullYear()),\n two(date.getUTCMonth() + 1),\n two(date.getUTCDate()),\n two(date.getUTCHours()),\n two(date.getUTCMinutes()),\n two(date.getUTCSeconds()),\n 'Z'\n ].join('');\n } else if (tag === 'utctime') {\n str = [\n two(date.getFullYear() % 100),\n two(date.getUTCMonth() + 1),\n two(date.getUTCDate()),\n two(date.getUTCHours()),\n two(date.getUTCMinutes()),\n two(date.getUTCSeconds()),\n 'Z'\n ].join('');\n } else {\n this.reporter.error('Encoding ' + tag + ' time is not supported yet');\n }\n\n return this._encodeStr(str, 'octstr');\n};\n\nDERNode.prototype._encodeNull = function encodeNull() {\n return this._createEncoderBuffer('');\n};\n\nDERNode.prototype._encodeInt = function encodeInt(num, values) {\n if (typeof num === 'string') {\n if (!values)\n return this.reporter.error('String int or enum given, but no values map');\n if (!values.hasOwnProperty(num)) {\n return this.reporter.error('Values map doesn\\'t contain: ' +\n JSON.stringify(num));\n }\n num = values[num];\n }\n\n // Bignum, assume big endian\n if (typeof num !== 'number' && !Buffer.isBuffer(num)) {\n var numArray = num.toArray();\n if (!num.sign && numArray[0] & 0x80) {\n numArray.unshift(0);\n }\n num = new Buffer(numArray);\n }\n\n if (Buffer.isBuffer(num)) {\n var size = num.length;\n if (num.length === 0)\n size++;\n\n var out = new Buffer(size);\n num.copy(out);\n if (num.length === 0)\n out[0] = 0\n return this._createEncoderBuffer(out);\n }\n\n if (num < 0x80)\n return this._createEncoderBuffer(num);\n\n if (num < 0x100)\n return this._createEncoderBuffer([0, num]);\n\n var size = 1;\n for (var i = num; i >= 0x100; i >>= 8)\n size++;\n\n var out = new Array(size);\n for (var i = out.length - 1; i >= 0; i--) {\n out[i] = num & 0xff;\n num >>= 8;\n }\n if(out[0] & 0x80) {\n out.unshift(0);\n }\n\n return this._createEncoderBuffer(new Buffer(out));\n};\n\nDERNode.prototype._encodeBool = function encodeBool(value) {\n return this._createEncoderBuffer(value ? 0xff : 0);\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n if (typeof entity === 'function')\n entity = entity(obj);\n return entity._getEncoder('der').tree;\n};\n\nDERNode.prototype._skipDefault = function skipDefault(dataBuffer, reporter, parent) {\n var state = this._baseState;\n var i;\n if (state['default'] === null)\n return false;\n\n var data = dataBuffer.join();\n if (state.defaultBuffer === undefined)\n state.defaultBuffer = this._encodeValue(state['default'], reporter, parent).join();\n\n if (data.length !== state.defaultBuffer.length)\n return false;\n\n for (i=0; i < data.length; i++)\n if (data[i] !== state.defaultBuffer[i])\n return false;\n\n return true;\n};\n\n// Utility methods\n\nfunction encodeTag(tag, primitive, cls, reporter) {\n var res;\n\n if (tag === 'seqof')\n tag = 'seq';\n else if (tag === 'setof')\n tag = 'set';\n\n if (der.tagByName.hasOwnProperty(tag))\n res = der.tagByName[tag];\n else if (typeof tag === 'number' && (tag | 0) === tag)\n res = tag;\n else\n return reporter.error('Unknown tag: ' + tag);\n\n if (res >= 0x1f)\n return reporter.error('Multi-octet tag encoding unsupported');\n\n if (!primitive)\n res |= 0x20;\n\n res |= (der.tagClassByName[cls || 'universal'] << 6);\n\n return res;\n}\n","var inherits = require('inherits');\n\nvar DEREncoder = require('./der');\n\nfunction PEMEncoder(entity) {\n DEREncoder.call(this, entity);\n this.enc = 'pem';\n};\ninherits(PEMEncoder, DEREncoder);\nmodule.exports = PEMEncoder;\n\nPEMEncoder.prototype.encode = function encode(data, options) {\n var buf = DEREncoder.prototype.encode.call(this, data);\n\n var p = buf.toString('base64');\n var out = [ '-----BEGIN ' + options.label + '-----' ];\n for (var i = 0; i < p.length; i += 64)\n out.push(p.slice(i, i + 64));\n out.push('-----END ' + options.label + '-----');\n return out.join('\\n');\n};\n","var encoders = exports;\n\nencoders.der = require('./der');\nencoders.pem = require('./pem');\n","var asn1 = exports;\n\nasn1.bignum = require('bn.js');\n\nasn1.define = require('./asn1/api').define;\nasn1.base = require('./asn1/base');\nasn1.constants = require('./asn1/constants');\nasn1.decoders = require('./asn1/decoders');\nasn1.encoders = require('./asn1/encoders');\n","// from https://github.com/Rantanen/node-dtls/blob/25a7dc861bda38cfeac93a723500eea4f0ac2e86/Certificate.js\n// thanks to @Rantanen\n\n'use strict';\n\nvar asn = require('asn1.js');\n\nvar Time = asn.define('Time', function () {\n\tthis.choice({\n\t\tutcTime: this.utctime(),\n\t\tgeneralTime: this.gentime()\n\t});\n});\n\nvar AttributeTypeValue = asn.define('AttributeTypeValue', function () {\n\tthis.seq().obj(\n\t\tthis.key('type').objid(),\n\t\tthis.key('value').any()\n\t);\n});\n\nvar AlgorithmIdentifier = asn.define('AlgorithmIdentifier', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').objid(),\n\t\tthis.key('parameters').optional(),\n\t\tthis.key('curve').objid().optional()\n\t);\n});\n\nvar SubjectPublicKeyInfo = asn.define('SubjectPublicKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('subjectPublicKey').bitstr()\n\t);\n});\n\nvar RelativeDistinguishedName = asn.define('RelativeDistinguishedName', function () {\n\tthis.setof(AttributeTypeValue);\n});\n\nvar RDNSequence = asn.define('RDNSequence', function () {\n\tthis.seqof(RelativeDistinguishedName);\n});\n\nvar Name = asn.define('Name', function () {\n\tthis.choice({\n\t\trdnSequence: this.use(RDNSequence)\n\t});\n});\n\nvar Validity = asn.define('Validity', function () {\n\tthis.seq().obj(\n\t\tthis.key('notBefore').use(Time),\n\t\tthis.key('notAfter').use(Time)\n\t);\n});\n\nvar Extension = asn.define('Extension', function () {\n\tthis.seq().obj(\n\t\tthis.key('extnID').objid(),\n\t\tthis.key('critical').bool().def(false),\n\t\tthis.key('extnValue').octstr()\n\t);\n});\n\nvar TBSCertificate = asn.define('TBSCertificate', function () {\n\tthis.seq().obj(\n\t\tthis.key('version').explicit(0)['int']().optional(),\n\t\tthis.key('serialNumber')['int'](),\n\t\tthis.key('signature').use(AlgorithmIdentifier),\n\t\tthis.key('issuer').use(Name),\n\t\tthis.key('validity').use(Validity),\n\t\tthis.key('subject').use(Name),\n\t\tthis.key('subjectPublicKeyInfo').use(SubjectPublicKeyInfo),\n\t\tthis.key('issuerUniqueID').implicit(1).bitstr().optional(),\n\t\tthis.key('subjectUniqueID').implicit(2).bitstr().optional(),\n\t\tthis.key('extensions').explicit(3).seqof(Extension).optional()\n\t);\n});\n\nvar X509Certificate = asn.define('X509Certificate', function () {\n\tthis.seq().obj(\n\t\tthis.key('tbsCertificate').use(TBSCertificate),\n\t\tthis.key('signatureAlgorithm').use(AlgorithmIdentifier),\n\t\tthis.key('signatureValue').bitstr()\n\t);\n});\n\nmodule.exports = X509Certificate;\n","// from https://github.com/indutny/self-signed/blob/gh-pages/lib/asn1.js\n// Fedor, you are amazing.\n\n'use strict';\n\nvar asn1 = require('asn1.js');\n\nexports.certificate = require('./certificate');\n\nvar RSAPrivateKey = asn1.define('RSAPrivateKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('modulus')['int'](),\n\t\tthis.key('publicExponent')['int'](),\n\t\tthis.key('privateExponent')['int'](),\n\t\tthis.key('prime1')['int'](),\n\t\tthis.key('prime2')['int'](),\n\t\tthis.key('exponent1')['int'](),\n\t\tthis.key('exponent2')['int'](),\n\t\tthis.key('coefficient')['int']()\n\t);\n});\nexports.RSAPrivateKey = RSAPrivateKey;\n\nvar RSAPublicKey = asn1.define('RSAPublicKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('modulus')['int'](),\n\t\tthis.key('publicExponent')['int']()\n\t);\n});\nexports.RSAPublicKey = RSAPublicKey;\n\nvar AlgorithmIdentifier = asn1.define('AlgorithmIdentifier', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').objid(),\n\t\tthis.key('none').null_().optional(),\n\t\tthis.key('curve').objid().optional(),\n\t\tthis.key('params').seq().obj(\n\t\t\tthis.key('p')['int'](),\n\t\t\tthis.key('q')['int'](),\n\t\t\tthis.key('g')['int']()\n\t\t).optional()\n\t);\n});\n\nvar PublicKey = asn1.define('SubjectPublicKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('subjectPublicKey').bitstr()\n\t);\n});\nexports.PublicKey = PublicKey;\n\nvar PrivateKeyInfo = asn1.define('PrivateKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('subjectPrivateKey').octstr()\n\t);\n});\nexports.PrivateKey = PrivateKeyInfo;\nvar EncryptedPrivateKeyInfo = asn1.define('EncryptedPrivateKeyInfo', function () {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').seq().obj(\n\t\t\tthis.key('id').objid(),\n\t\t\tthis.key('decrypt').seq().obj(\n\t\t\t\tthis.key('kde').seq().obj(\n\t\t\t\t\tthis.key('id').objid(),\n\t\t\t\t\tthis.key('kdeparams').seq().obj(\n\t\t\t\t\t\tthis.key('salt').octstr(),\n\t\t\t\t\t\tthis.key('iters')['int']()\n\t\t\t\t\t)\n\t\t\t\t),\n\t\t\t\tthis.key('cipher').seq().obj(\n\t\t\t\t\tthis.key('algo').objid(),\n\t\t\t\t\tthis.key('iv').octstr()\n\t\t\t\t)\n\t\t\t)\n\t\t),\n\t\tthis.key('subjectPrivateKey').octstr()\n\t);\n});\n\nexports.EncryptedPrivateKey = EncryptedPrivateKeyInfo;\n\nvar DSAPrivateKey = asn1.define('DSAPrivateKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('p')['int'](),\n\t\tthis.key('q')['int'](),\n\t\tthis.key('g')['int'](),\n\t\tthis.key('pub_key')['int'](),\n\t\tthis.key('priv_key')['int']()\n\t);\n});\nexports.DSAPrivateKey = DSAPrivateKey;\n\nexports.DSAparam = asn1.define('DSAparam', function () {\n\tthis['int']();\n});\n\nvar ECParameters = asn1.define('ECParameters', function () {\n\tthis.choice({\n\t\tnamedCurve: this.objid()\n\t});\n});\n\nvar ECPrivateKey = asn1.define('ECPrivateKey', function () {\n\tthis.seq().obj(\n\t\tthis.key('version')['int'](),\n\t\tthis.key('privateKey').octstr(),\n\t\tthis.key('parameters').optional().explicit(0).use(ECParameters),\n\t\tthis.key('publicKey').optional().explicit(1).bitstr()\n\t);\n});\nexports.ECPrivateKey = ECPrivateKey;\n\nexports.signature = asn1.define('signature', function () {\n\tthis.seq().obj(\n\t\tthis.key('r')['int'](),\n\t\tthis.key('s')['int']()\n\t);\n});\n","'use strict';\n\n// adapted from https://github.com/apatil/pemstrip\nvar findProc = /Proc-Type: 4,ENCRYPTED[\\n\\r]+DEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)[\\n\\r]+([0-9A-z\\n\\r+/=]+)[\\n\\r]+/m;\nvar startRegex = /^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----/m;\nvar fullRegex = /^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----([0-9A-z\\n\\r+/=]+)-----END \\1-----$/m;\nvar evp = require('evp_bytestokey');\nvar ciphers = require('browserify-aes');\nvar Buffer = require('safe-buffer').Buffer;\nmodule.exports = function (okey, password) {\n\tvar key = okey.toString();\n\tvar match = key.match(findProc);\n\tvar decrypted;\n\tif (!match) {\n\t\tvar match2 = key.match(fullRegex);\n\t\tdecrypted = Buffer.from(match2[2].replace(/[\\r\\n]/g, ''), 'base64');\n\t} else {\n\t\tvar suite = 'aes' + match[1];\n\t\tvar iv = Buffer.from(match[2], 'hex');\n\t\tvar cipherText = Buffer.from(match[3].replace(/[\\r\\n]/g, ''), 'base64');\n\t\tvar cipherKey = evp(password, iv.slice(0, 8), parseInt(match[1], 10)).key;\n\t\tvar out = [];\n\t\tvar cipher = ciphers.createDecipheriv(suite, cipherKey, iv);\n\t\tout.push(cipher.update(cipherText));\n\t\tout.push(cipher['final']());\n\t\tdecrypted = Buffer.concat(out);\n\t}\n\tvar tag = key.match(startRegex)[1];\n\treturn {\n\t\ttag: tag,\n\t\tdata: decrypted\n\t};\n};\n","'use strict';\n\nvar asn1 = require('./asn1');\nvar aesid = require('./aesid.json');\nvar fixProc = require('./fixProc');\nvar ciphers = require('browserify-aes');\nvar compat = require('pbkdf2');\nvar Buffer = require('safe-buffer').Buffer;\n\nfunction decrypt(data, password) {\n\tvar salt = data.algorithm.decrypt.kde.kdeparams.salt;\n\tvar iters = parseInt(data.algorithm.decrypt.kde.kdeparams.iters.toString(), 10);\n\tvar algo = aesid[data.algorithm.decrypt.cipher.algo.join('.')];\n\tvar iv = data.algorithm.decrypt.cipher.iv;\n\tvar cipherText = data.subjectPrivateKey;\n\tvar keylen = parseInt(algo.split('-')[1], 10) / 8;\n\tvar key = compat.pbkdf2Sync(password, salt, iters, keylen, 'sha1');\n\tvar cipher = ciphers.createDecipheriv(algo, key, iv);\n\tvar out = [];\n\tout.push(cipher.update(cipherText));\n\tout.push(cipher['final']());\n\treturn Buffer.concat(out);\n}\n\nfunction parseKeys(buffer) {\n\tvar password;\n\tif (typeof buffer === 'object' && !Buffer.isBuffer(buffer)) {\n\t\tpassword = buffer.passphrase;\n\t\tbuffer = buffer.key;\n\t}\n\tif (typeof buffer === 'string') {\n\t\tbuffer = Buffer.from(buffer);\n\t}\n\n\tvar stripped = fixProc(buffer, password);\n\n\tvar type = stripped.tag;\n\tvar data = stripped.data;\n\tvar subtype, ndata;\n\tswitch (type) {\n\t\tcase 'CERTIFICATE':\n\t\t\tndata = asn1.certificate.decode(data, 'der').tbsCertificate.subjectPublicKeyInfo;\n\t\t\t// falls through\n\t\tcase 'PUBLIC KEY':\n\t\t\tif (!ndata) {\n\t\t\t\tndata = asn1.PublicKey.decode(data, 'der');\n\t\t\t}\n\t\t\tsubtype = ndata.algorithm.algorithm.join('.');\n\t\t\tswitch (subtype) {\n\t\t\t\tcase '1.2.840.113549.1.1.1':\n\t\t\t\t\treturn asn1.RSAPublicKey.decode(ndata.subjectPublicKey.data, 'der');\n\t\t\t\tcase '1.2.840.10045.2.1':\n\t\t\t\t\tndata.subjectPrivateKey = ndata.subjectPublicKey;\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttype: 'ec',\n\t\t\t\t\t\tdata: ndata\n\t\t\t\t\t};\n\t\t\t\tcase '1.2.840.10040.4.1':\n\t\t\t\t\tndata.algorithm.params.pub_key = asn1.DSAparam.decode(ndata.subjectPublicKey.data, 'der');\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttype: 'dsa',\n\t\t\t\t\t\tdata: ndata.algorithm.params\n\t\t\t\t\t};\n\t\t\t\tdefault: throw new Error('unknown key id ' + subtype);\n\t\t\t}\n\t\t\t// throw new Error('unknown key type ' + type)\n\t\tcase 'ENCRYPTED PRIVATE KEY':\n\t\t\tdata = asn1.EncryptedPrivateKey.decode(data, 'der');\n\t\t\tdata = decrypt(data, password);\n\t\t\t// falls through\n\t\tcase 'PRIVATE KEY':\n\t\t\tndata = asn1.PrivateKey.decode(data, 'der');\n\t\t\tsubtype = ndata.algorithm.algorithm.join('.');\n\t\t\tswitch (subtype) {\n\t\t\t\tcase '1.2.840.113549.1.1.1':\n\t\t\t\t\treturn asn1.RSAPrivateKey.decode(ndata.subjectPrivateKey, 'der');\n\t\t\t\tcase '1.2.840.10045.2.1':\n\t\t\t\t\treturn {\n\t\t\t\t\t\tcurve: ndata.algorithm.curve,\n\t\t\t\t\t\tprivateKey: asn1.ECPrivateKey.decode(ndata.subjectPrivateKey, 'der').privateKey\n\t\t\t\t\t};\n\t\t\t\tcase '1.2.840.10040.4.1':\n\t\t\t\t\tndata.algorithm.params.priv_key = asn1.DSAparam.decode(ndata.subjectPrivateKey, 'der');\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttype: 'dsa',\n\t\t\t\t\t\tparams: ndata.algorithm.params\n\t\t\t\t\t};\n\t\t\t\tdefault: throw new Error('unknown key id ' + subtype);\n\t\t\t}\n\t\t\t// throw new Error('unknown key type ' + type)\n\t\tcase 'RSA PUBLIC KEY':\n\t\t\treturn asn1.RSAPublicKey.decode(data, 'der');\n\t\tcase 'RSA PRIVATE KEY':\n\t\t\treturn asn1.RSAPrivateKey.decode(data, 'der');\n\t\tcase 'DSA PRIVATE KEY':\n\t\t\treturn {\n\t\t\t\ttype: 'dsa',\n\t\t\t\tparams: asn1.DSAPrivateKey.decode(data, 'der')\n\t\t\t};\n\t\tcase 'EC PRIVATE KEY':\n\t\t\tdata = asn1.ECPrivateKey.decode(data, 'der');\n\t\t\treturn {\n\t\t\t\tcurve: data.parameters.value,\n\t\t\t\tprivateKey: data.privateKey\n\t\t\t};\n\t\tdefault: throw new Error('unknown key type ' + type);\n\t}\n}\nparseKeys.signature = asn1.signature;\n\nmodule.exports = parseKeys;\n","'use strict';\n\n// much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js\nvar Buffer = require('safe-buffer').Buffer;\nvar createHmac = require('create-hmac');\nvar crt = require('browserify-rsa');\nvar EC = require('elliptic').ec;\nvar BN = require('bn.js');\nvar parseKeys = require('parse-asn1');\nvar curves = require('./curves.json');\n\nvar RSA_PKCS1_PADDING = 1;\n\nfunction sign(hash, key, hashType, signType, tag) {\n var priv = parseKeys(key);\n if (priv.curve) {\n // rsa keys can be interpreted as ecdsa ones in openssl\n if (signType !== 'ecdsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong private key type'); }\n return ecSign(hash, priv);\n } else if (priv.type === 'dsa') {\n if (signType !== 'dsa') { throw new Error('wrong private key type'); }\n return dsaSign(hash, priv, hashType);\n }\n if (signType !== 'rsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong private key type'); }\n if (key.padding !== undefined && key.padding !== RSA_PKCS1_PADDING) { throw new Error('illegal or unsupported padding mode'); }\n\n hash = Buffer.concat([tag, hash]);\n var len = priv.modulus.byteLength();\n var pad = [0, 1];\n while (hash.length + pad.length + 1 < len) { pad.push(0xff); }\n pad.push(0x00);\n var i = -1;\n while (++i < hash.length) { pad.push(hash[i]); }\n\n var out = crt(pad, priv);\n return out;\n}\n\nfunction ecSign(hash, priv) {\n var curveId = curves[priv.curve.join('.')];\n if (!curveId) { throw new Error('unknown curve ' + priv.curve.join('.')); }\n\n var curve = new EC(curveId);\n var key = curve.keyFromPrivate(priv.privateKey);\n var out = key.sign(hash);\n\n return Buffer.from(out.toDER());\n}\n\nfunction dsaSign(hash, priv, algo) {\n var x = priv.params.priv_key;\n var p = priv.params.p;\n var q = priv.params.q;\n var g = priv.params.g;\n var r = new BN(0);\n var k;\n var H = bits2int(hash, q).mod(q);\n var s = false;\n var kv = getKey(x, q, hash, algo);\n while (s === false) {\n k = makeKey(q, kv, algo);\n r = makeR(g, k, p, q);\n s = k.invm(q).imul(H.add(x.mul(r))).mod(q);\n if (s.cmpn(0) === 0) {\n s = false;\n r = new BN(0);\n }\n }\n return toDER(r, s);\n}\n\nfunction toDER(r, s) {\n r = r.toArray();\n s = s.toArray();\n\n // Pad values\n if (r[0] & 0x80) { r = [0].concat(r); }\n if (s[0] & 0x80) { s = [0].concat(s); }\n\n var total = r.length + s.length + 4;\n var res = [\n 0x30, total, 0x02, r.length\n ];\n res = res.concat(r, [0x02, s.length], s);\n return Buffer.from(res);\n}\n\nfunction getKey(x, q, hash, algo) {\n x = Buffer.from(x.toArray());\n if (x.length < q.byteLength()) {\n var zeros = Buffer.alloc(q.byteLength() - x.length);\n x = Buffer.concat([zeros, x]);\n }\n var hlen = hash.length;\n var hbits = bits2octets(hash, q);\n var v = Buffer.alloc(hlen);\n v.fill(1);\n var k = Buffer.alloc(hlen);\n k = createHmac(algo, k).update(v).update(Buffer.from([0])).update(x).update(hbits).digest();\n v = createHmac(algo, k).update(v).digest();\n k = createHmac(algo, k).update(v).update(Buffer.from([1])).update(x).update(hbits).digest();\n v = createHmac(algo, k).update(v).digest();\n return { k: k, v: v };\n}\n\nfunction bits2int(obits, q) {\n var bits = new BN(obits);\n var shift = (obits.length << 3) - q.bitLength();\n if (shift > 0) { bits.ishrn(shift); }\n return bits;\n}\n\nfunction bits2octets(bits, q) {\n bits = bits2int(bits, q);\n bits = bits.mod(q);\n var out = Buffer.from(bits.toArray());\n if (out.length < q.byteLength()) {\n var zeros = Buffer.alloc(q.byteLength() - out.length);\n out = Buffer.concat([zeros, out]);\n }\n return out;\n}\n\nfunction makeKey(q, kv, algo) {\n var t;\n var k;\n\n do {\n t = Buffer.alloc(0);\n\n while (t.length * 8 < q.bitLength()) {\n kv.v = createHmac(algo, kv.k).update(kv.v).digest();\n t = Buffer.concat([t, kv.v]);\n }\n\n k = bits2int(t, q);\n kv.k = createHmac(algo, kv.k).update(kv.v).update(Buffer.from([0])).digest();\n kv.v = createHmac(algo, kv.k).update(kv.v).digest();\n } while (k.cmp(q) !== -1);\n\n return k;\n}\n\nfunction makeR(g, k, p, q) {\n return g.toRed(BN.mont(p)).redPow(k).fromRed().mod(q);\n}\n\nmodule.exports = sign;\nmodule.exports.getKey = getKey;\nmodule.exports.makeKey = makeKey;\n","'use strict';\n\n// much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js\nvar Buffer = require('safe-buffer').Buffer;\nvar BN = require('bn.js');\nvar EC = require('elliptic').ec;\nvar parseKeys = require('parse-asn1');\nvar curves = require('./curves.json');\n\nfunction verify(sig, hash, key, signType, tag) {\n var pub = parseKeys(key);\n if (pub.type === 'ec') {\n // rsa keys can be interpreted as ecdsa ones in openssl\n if (signType !== 'ecdsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong public key type'); }\n return ecVerify(sig, hash, pub);\n } else if (pub.type === 'dsa') {\n if (signType !== 'dsa') { throw new Error('wrong public key type'); }\n return dsaVerify(sig, hash, pub);\n }\n if (signType !== 'rsa' && signType !== 'ecdsa/rsa') { throw new Error('wrong public key type'); }\n\n hash = Buffer.concat([tag, hash]);\n var len = pub.modulus.byteLength();\n var pad = [1];\n var padNum = 0;\n while (hash.length + pad.length + 2 < len) {\n pad.push(0xff);\n padNum += 1;\n }\n pad.push(0x00);\n var i = -1;\n while (++i < hash.length) {\n pad.push(hash[i]);\n }\n pad = Buffer.from(pad);\n var red = BN.mont(pub.modulus);\n sig = new BN(sig).toRed(red);\n\n sig = sig.redPow(new BN(pub.publicExponent));\n sig = Buffer.from(sig.fromRed().toArray());\n var out = padNum < 8 ? 1 : 0;\n len = Math.min(sig.length, pad.length);\n if (sig.length !== pad.length) { out = 1; }\n\n i = -1;\n while (++i < len) { out |= sig[i] ^ pad[i]; }\n return out === 0;\n}\n\nfunction ecVerify(sig, hash, pub) {\n var curveId = curves[pub.data.algorithm.curve.join('.')];\n if (!curveId) { throw new Error('unknown curve ' + pub.data.algorithm.curve.join('.')); }\n\n var curve = new EC(curveId);\n var pubkey = pub.data.subjectPrivateKey.data;\n\n return curve.verify(hash, sig, pubkey);\n}\n\nfunction dsaVerify(sig, hash, pub) {\n var p = pub.data.p;\n var q = pub.data.q;\n var g = pub.data.g;\n var y = pub.data.pub_key;\n var unpacked = parseKeys.signature.decode(sig, 'der');\n var s = unpacked.s;\n var r = unpacked.r;\n checkValue(s, q);\n checkValue(r, q);\n var montp = BN.mont(p);\n var w = s.invm(q);\n var v = g.toRed(montp)\n .redPow(new BN(hash).mul(w).mod(q))\n .fromRed()\n .mul(y.toRed(montp).redPow(r.mul(w).mod(q)).fromRed())\n .mod(p)\n .mod(q);\n return v.cmp(r) === 0;\n}\n\nfunction checkValue(b, q) {\n if (b.cmpn(0) <= 0) { throw new Error('invalid sig'); }\n if (b.cmp(q) >= 0) { throw new Error('invalid sig'); }\n}\n\nmodule.exports = verify;\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar createHash = require('create-hash');\nvar stream = require('readable-stream');\nvar inherits = require('inherits');\nvar sign = require('./sign');\nvar verify = require('./verify');\n\nvar algorithms = require('./algorithms.json');\nObject.keys(algorithms).forEach(function (key) {\n algorithms[key].id = Buffer.from(algorithms[key].id, 'hex');\n algorithms[key.toLowerCase()] = algorithms[key];\n});\n\nfunction Sign(algorithm) {\n stream.Writable.call(this);\n\n var data = algorithms[algorithm];\n if (!data) { throw new Error('Unknown message digest'); }\n\n this._hashType = data.hash;\n this._hash = createHash(data.hash);\n this._tag = data.id;\n this._signType = data.sign;\n}\ninherits(Sign, stream.Writable);\n\nSign.prototype._write = function _write(data, _, done) {\n this._hash.update(data);\n done();\n};\n\nSign.prototype.update = function update(data, enc) {\n this._hash.update(typeof data === 'string' ? Buffer.from(data, enc) : data);\n\n return this;\n};\n\nSign.prototype.sign = function signMethod(key, enc) {\n this.end();\n var hash = this._hash.digest();\n var sig = sign(hash, key, this._hashType, this._signType, this._tag);\n\n return enc ? sig.toString(enc) : sig;\n};\n\nfunction Verify(algorithm) {\n stream.Writable.call(this);\n\n var data = algorithms[algorithm];\n if (!data) { throw new Error('Unknown message digest'); }\n\n this._hash = createHash(data.hash);\n this._tag = data.id;\n this._signType = data.sign;\n}\ninherits(Verify, stream.Writable);\n\nVerify.prototype._write = function _write(data, _, done) {\n this._hash.update(data);\n done();\n};\n\nVerify.prototype.update = function update(data, enc) {\n this._hash.update(typeof data === 'string' ? Buffer.from(data, enc) : data);\n\n return this;\n};\n\nVerify.prototype.verify = function verifyMethod(key, sig, enc) {\n var sigBuffer = typeof sig === 'string' ? Buffer.from(sig, enc) : sig;\n\n this.end();\n var hash = this._hash.digest();\n return verify(sigBuffer, hash, key, this._signType, this._tag);\n};\n\nfunction createSign(algorithm) {\n return new Sign(algorithm);\n}\n\nfunction createVerify(algorithm) {\n return new Verify(algorithm);\n}\n\nmodule.exports = {\n Sign: createSign,\n Verify: createVerify,\n createSign: createSign,\n createVerify: createVerify\n};\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var elliptic = require('elliptic')\nvar BN = require('bn.js')\n\nmodule.exports = function createECDH (curve) {\n return new ECDH(curve)\n}\n\nvar aliases = {\n secp256k1: {\n name: 'secp256k1',\n byteLength: 32\n },\n secp224r1: {\n name: 'p224',\n byteLength: 28\n },\n prime256v1: {\n name: 'p256',\n byteLength: 32\n },\n prime192v1: {\n name: 'p192',\n byteLength: 24\n },\n ed25519: {\n name: 'ed25519',\n byteLength: 32\n },\n secp384r1: {\n name: 'p384',\n byteLength: 48\n },\n secp521r1: {\n name: 'p521',\n byteLength: 66\n }\n}\n\naliases.p224 = aliases.secp224r1\naliases.p256 = aliases.secp256r1 = aliases.prime256v1\naliases.p192 = aliases.secp192r1 = aliases.prime192v1\naliases.p384 = aliases.secp384r1\naliases.p521 = aliases.secp521r1\n\nfunction ECDH (curve) {\n this.curveType = aliases[curve]\n if (!this.curveType) {\n this.curveType = {\n name: curve\n }\n }\n this.curve = new elliptic.ec(this.curveType.name) // eslint-disable-line new-cap\n this.keys = void 0\n}\n\nECDH.prototype.generateKeys = function (enc, format) {\n this.keys = this.curve.genKeyPair()\n return this.getPublicKey(enc, format)\n}\n\nECDH.prototype.computeSecret = function (other, inenc, enc) {\n inenc = inenc || 'utf8'\n if (!Buffer.isBuffer(other)) {\n other = new Buffer(other, inenc)\n }\n var otherPub = this.curve.keyFromPublic(other).getPublic()\n var out = otherPub.mul(this.keys.getPrivate()).getX()\n return formatReturnValue(out, enc, this.curveType.byteLength)\n}\n\nECDH.prototype.getPublicKey = function (enc, format) {\n var key = this.keys.getPublic(format === 'compressed', true)\n if (format === 'hybrid') {\n if (key[key.length - 1] % 2) {\n key[0] = 7\n } else {\n key[0] = 6\n }\n }\n return formatReturnValue(key, enc)\n}\n\nECDH.prototype.getPrivateKey = function (enc) {\n return formatReturnValue(this.keys.getPrivate(), enc)\n}\n\nECDH.prototype.setPublicKey = function (pub, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc)\n }\n this.keys._importPublic(pub)\n return this\n}\n\nECDH.prototype.setPrivateKey = function (priv, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc)\n }\n\n var _priv = new BN(priv)\n _priv = _priv.toString(16)\n this.keys = this.curve.genKeyPair()\n this.keys._importPrivate(_priv)\n return this\n}\n\nfunction formatReturnValue (bn, enc, len) {\n if (!Array.isArray(bn)) {\n bn = bn.toArray()\n }\n var buf = new Buffer(bn)\n if (len && buf.length < len) {\n var zeros = new Buffer(len - buf.length)\n zeros.fill(0)\n buf = Buffer.concat([zeros, buf])\n }\n if (!enc) {\n return buf\n } else {\n return buf.toString(enc)\n }\n}\n","var createHash = require('create-hash')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function (seed, len) {\n var t = Buffer.alloc(0)\n var i = 0\n var c\n while (t.length < len) {\n c = i2ops(i++)\n t = Buffer.concat([t, createHash('sha1').update(seed).update(c).digest()])\n }\n return t.slice(0, len)\n}\n\nfunction i2ops (c) {\n var out = Buffer.allocUnsafe(4)\n out.writeUInt32BE(c, 0)\n return out\n}\n","module.exports = function xor (a, b) {\n var len = a.length\n var i = -1\n while (++i < len) {\n a[i] ^= b[i]\n }\n return a\n}\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var BN = require('bn.js')\nvar Buffer = require('safe-buffer').Buffer\n\nfunction withPublic (paddedMsg, key) {\n return Buffer.from(paddedMsg\n .toRed(BN.mont(key.modulus))\n .redPow(new BN(key.publicExponent))\n .fromRed()\n .toArray())\n}\n\nmodule.exports = withPublic\n","var parseKeys = require('parse-asn1')\nvar randomBytes = require('randombytes')\nvar createHash = require('create-hash')\nvar mgf = require('./mgf')\nvar xor = require('./xor')\nvar BN = require('bn.js')\nvar withPublic = require('./withPublic')\nvar crt = require('browserify-rsa')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function publicEncrypt (publicKey, msg, reverse) {\n var padding\n if (publicKey.padding) {\n padding = publicKey.padding\n } else if (reverse) {\n padding = 1\n } else {\n padding = 4\n }\n var key = parseKeys(publicKey)\n var paddedMsg\n if (padding === 4) {\n paddedMsg = oaep(key, msg)\n } else if (padding === 1) {\n paddedMsg = pkcs1(key, msg, reverse)\n } else if (padding === 3) {\n paddedMsg = new BN(msg)\n if (paddedMsg.cmp(key.modulus) >= 0) {\n throw new Error('data too long for modulus')\n }\n } else {\n throw new Error('unknown padding')\n }\n if (reverse) {\n return crt(paddedMsg, key)\n } else {\n return withPublic(paddedMsg, key)\n }\n}\n\nfunction oaep (key, msg) {\n var k = key.modulus.byteLength()\n var mLen = msg.length\n var iHash = createHash('sha1').update(Buffer.alloc(0)).digest()\n var hLen = iHash.length\n var hLen2 = 2 * hLen\n if (mLen > k - hLen2 - 2) {\n throw new Error('message too long')\n }\n var ps = Buffer.alloc(k - mLen - hLen2 - 2)\n var dblen = k - hLen - 1\n var seed = randomBytes(hLen)\n var maskedDb = xor(Buffer.concat([iHash, ps, Buffer.alloc(1, 1), msg], dblen), mgf(seed, dblen))\n var maskedSeed = xor(seed, mgf(maskedDb, hLen))\n return new BN(Buffer.concat([Buffer.alloc(1), maskedSeed, maskedDb], k))\n}\nfunction pkcs1 (key, msg, reverse) {\n var mLen = msg.length\n var k = key.modulus.byteLength()\n if (mLen > k - 11) {\n throw new Error('message too long')\n }\n var ps\n if (reverse) {\n ps = Buffer.alloc(k - mLen - 3, 0xff)\n } else {\n ps = nonZero(k - mLen - 3)\n }\n return new BN(Buffer.concat([Buffer.from([0, reverse ? 1 : 2]), ps, Buffer.alloc(1), msg], k))\n}\nfunction nonZero (len) {\n var out = Buffer.allocUnsafe(len)\n var i = 0\n var cache = randomBytes(len * 2)\n var cur = 0\n var num\n while (i < len) {\n if (cur === cache.length) {\n cache = randomBytes(len * 2)\n cur = 0\n }\n num = cache[cur++]\n if (num) {\n out[i++] = num\n }\n }\n return out\n}\n","var parseKeys = require('parse-asn1')\nvar mgf = require('./mgf')\nvar xor = require('./xor')\nvar BN = require('bn.js')\nvar crt = require('browserify-rsa')\nvar createHash = require('create-hash')\nvar withPublic = require('./withPublic')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function privateDecrypt (privateKey, enc, reverse) {\n var padding\n if (privateKey.padding) {\n padding = privateKey.padding\n } else if (reverse) {\n padding = 1\n } else {\n padding = 4\n }\n\n var key = parseKeys(privateKey)\n var k = key.modulus.byteLength()\n if (enc.length > k || new BN(enc).cmp(key.modulus) >= 0) {\n throw new Error('decryption error')\n }\n var msg\n if (reverse) {\n msg = withPublic(new BN(enc), key)\n } else {\n msg = crt(enc, key)\n }\n var zBuffer = Buffer.alloc(k - msg.length)\n msg = Buffer.concat([zBuffer, msg], k)\n if (padding === 4) {\n return oaep(key, msg)\n } else if (padding === 1) {\n return pkcs1(key, msg, reverse)\n } else if (padding === 3) {\n return msg\n } else {\n throw new Error('unknown padding')\n }\n}\n\nfunction oaep (key, msg) {\n var k = key.modulus.byteLength()\n var iHash = createHash('sha1').update(Buffer.alloc(0)).digest()\n var hLen = iHash.length\n if (msg[0] !== 0) {\n throw new Error('decryption error')\n }\n var maskedSeed = msg.slice(1, hLen + 1)\n var maskedDb = msg.slice(hLen + 1)\n var seed = xor(maskedSeed, mgf(maskedDb, hLen))\n var db = xor(maskedDb, mgf(seed, k - hLen - 1))\n if (compare(iHash, db.slice(0, hLen))) {\n throw new Error('decryption error')\n }\n var i = hLen\n while (db[i] === 0) {\n i++\n }\n if (db[i++] !== 1) {\n throw new Error('decryption error')\n }\n return db.slice(i)\n}\n\nfunction pkcs1 (key, msg, reverse) {\n var p1 = msg.slice(0, 2)\n var i = 2\n var status = 0\n while (msg[i++] !== 0) {\n if (i >= msg.length) {\n status++\n break\n }\n }\n var ps = msg.slice(2, i - 1)\n\n if ((p1.toString('hex') !== '0002' && !reverse) || (p1.toString('hex') !== '0001' && reverse)) {\n status++\n }\n if (ps.length < 8) {\n status++\n }\n if (status) {\n throw new Error('decryption error')\n }\n return msg.slice(i)\n}\nfunction compare (a, b) {\n a = Buffer.from(a)\n b = Buffer.from(b)\n var dif = 0\n var len = a.length\n if (a.length !== b.length) {\n dif++\n len = Math.min(a.length, b.length)\n }\n var i = -1\n while (++i < len) {\n dif += (a[i] ^ b[i])\n }\n return dif\n}\n","exports.publicEncrypt = require('./publicEncrypt')\nexports.privateDecrypt = require('./privateDecrypt')\n\nexports.privateEncrypt = function privateEncrypt (key, buf) {\n return exports.publicEncrypt(key, buf, true)\n}\n\nexports.publicDecrypt = function publicDecrypt (key, buf) {\n return exports.privateDecrypt(key, buf, true)\n}\n","'use strict'\n\nfunction oldBrowser () {\n throw new Error('secure random number generation not supported by this browser\\nuse chrome, FireFox or Internet Explorer 11')\n}\nvar safeBuffer = require('safe-buffer')\nvar randombytes = require('randombytes')\nvar Buffer = safeBuffer.Buffer\nvar kBufferMaxLength = safeBuffer.kMaxLength\nvar crypto = global.crypto || global.msCrypto\nvar kMaxUint32 = Math.pow(2, 32) - 1\nfunction assertOffset (offset, length) {\n if (typeof offset !== 'number' || offset !== offset) { // eslint-disable-line no-self-compare\n throw new TypeError('offset must be a number')\n }\n\n if (offset > kMaxUint32 || offset < 0) {\n throw new TypeError('offset must be a uint32')\n }\n\n if (offset > kBufferMaxLength || offset > length) {\n throw new RangeError('offset out of range')\n }\n}\n\nfunction assertSize (size, offset, length) {\n if (typeof size !== 'number' || size !== size) { // eslint-disable-line no-self-compare\n throw new TypeError('size must be a number')\n }\n\n if (size > kMaxUint32 || size < 0) {\n throw new TypeError('size must be a uint32')\n }\n\n if (size + offset > length || size > kBufferMaxLength) {\n throw new RangeError('buffer too small')\n }\n}\nif ((crypto && crypto.getRandomValues) || !process.browser) {\n exports.randomFill = randomFill\n exports.randomFillSync = randomFillSync\n} else {\n exports.randomFill = oldBrowser\n exports.randomFillSync = oldBrowser\n}\nfunction randomFill (buf, offset, size, cb) {\n if (!Buffer.isBuffer(buf) && !(buf instanceof global.Uint8Array)) {\n throw new TypeError('\"buf\" argument must be a Buffer or Uint8Array')\n }\n\n if (typeof offset === 'function') {\n cb = offset\n offset = 0\n size = buf.length\n } else if (typeof size === 'function') {\n cb = size\n size = buf.length - offset\n } else if (typeof cb !== 'function') {\n throw new TypeError('\"cb\" argument must be a function')\n }\n assertOffset(offset, buf.length)\n assertSize(size, offset, buf.length)\n return actualFill(buf, offset, size, cb)\n}\n\nfunction actualFill (buf, offset, size, cb) {\n if (process.browser) {\n var ourBuf = buf.buffer\n var uint = new Uint8Array(ourBuf, offset, size)\n crypto.getRandomValues(uint)\n if (cb) {\n process.nextTick(function () {\n cb(null, buf)\n })\n return\n }\n return buf\n }\n if (cb) {\n randombytes(size, function (err, bytes) {\n if (err) {\n return cb(err)\n }\n bytes.copy(buf, offset)\n cb(null, buf)\n })\n return\n }\n var bytes = randombytes(size)\n bytes.copy(buf, offset)\n return buf\n}\nfunction randomFillSync (buf, offset, size) {\n if (typeof offset === 'undefined') {\n offset = 0\n }\n if (!Buffer.isBuffer(buf) && !(buf instanceof global.Uint8Array)) {\n throw new TypeError('\"buf\" argument must be a Buffer or Uint8Array')\n }\n\n assertOffset(offset, buf.length)\n\n if (size === undefined) size = buf.length - offset\n\n assertSize(size, offset, buf.length)\n\n return actualFill(buf, offset, size)\n}\n","'use strict';\n\n// eslint-disable-next-line no-multi-assign\nexports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes');\n\n// eslint-disable-next-line no-multi-assign\nexports.createHash = exports.Hash = require('create-hash');\n\n// eslint-disable-next-line no-multi-assign\nexports.createHmac = exports.Hmac = require('create-hmac');\n\nvar algos = require('browserify-sign/algos');\nvar algoKeys = Object.keys(algos);\nvar hashes = [\n\t'sha1',\n\t'sha224',\n\t'sha256',\n\t'sha384',\n\t'sha512',\n\t'md5',\n\t'rmd160'\n].concat(algoKeys);\n\nexports.getHashes = function () {\n\treturn hashes;\n};\n\nvar p = require('pbkdf2');\nexports.pbkdf2 = p.pbkdf2;\nexports.pbkdf2Sync = p.pbkdf2Sync;\n\nvar aes = require('browserify-cipher');\n\nexports.Cipher = aes.Cipher;\nexports.createCipher = aes.createCipher;\nexports.Cipheriv = aes.Cipheriv;\nexports.createCipheriv = aes.createCipheriv;\nexports.Decipher = aes.Decipher;\nexports.createDecipher = aes.createDecipher;\nexports.Decipheriv = aes.Decipheriv;\nexports.createDecipheriv = aes.createDecipheriv;\nexports.getCiphers = aes.getCiphers;\nexports.listCiphers = aes.listCiphers;\n\nvar dh = require('diffie-hellman');\n\nexports.DiffieHellmanGroup = dh.DiffieHellmanGroup;\nexports.createDiffieHellmanGroup = dh.createDiffieHellmanGroup;\nexports.getDiffieHellman = dh.getDiffieHellman;\nexports.createDiffieHellman = dh.createDiffieHellman;\nexports.DiffieHellman = dh.DiffieHellman;\n\nvar sign = require('browserify-sign');\n\nexports.createSign = sign.createSign;\nexports.Sign = sign.Sign;\nexports.createVerify = sign.createVerify;\nexports.Verify = sign.Verify;\n\nexports.createECDH = require('create-ecdh');\n\nvar publicEncrypt = require('public-encrypt');\n\nexports.publicEncrypt = publicEncrypt.publicEncrypt;\nexports.privateEncrypt = publicEncrypt.privateEncrypt;\nexports.publicDecrypt = publicEncrypt.publicDecrypt;\nexports.privateDecrypt = publicEncrypt.privateDecrypt;\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\n// [\n// 'createCredentials'\n// ].forEach(function (name) {\n// exports[name] = function () {\n// throw new Error('sorry, ' + name + ' is not implemented yet\\nwe accept pull requests\\nhttps://github.com/browserify/crypto-browserify');\n// };\n// });\n\nvar rf = require('randomfill');\n\nexports.randomFill = rf.randomFill;\nexports.randomFillSync = rf.randomFillSync;\n\nexports.createCredentials = function () {\n\tthrow new Error('sorry, createCredentials is not implemented yet\\nwe accept pull requests\\nhttps://github.com/browserify/crypto-browserify');\n};\n\nexports.constants = {\n\tDH_CHECK_P_NOT_SAFE_PRIME: 2,\n\tDH_CHECK_P_NOT_PRIME: 1,\n\tDH_UNABLE_TO_CHECK_GENERATOR: 4,\n\tDH_NOT_SUITABLE_GENERATOR: 8,\n\tNPN_ENABLED: 1,\n\tALPN_ENABLED: 1,\n\tRSA_PKCS1_PADDING: 1,\n\tRSA_SSLV23_PADDING: 2,\n\tRSA_NO_PADDING: 3,\n\tRSA_PKCS1_OAEP_PADDING: 4,\n\tRSA_X931_PADDING: 5,\n\tRSA_PKCS1_PSS_PADDING: 6,\n\tPOINT_CONVERSION_COMPRESSED: 2,\n\tPOINT_CONVERSION_UNCOMPRESSED: 4,\n\tPOINT_CONVERSION_HYBRID: 6\n};\n","import { r as register, t as t3, a as t } from \"./_l10n-CeXHJQB0.mjs\";\nregister(t3);\nclass Color {\n /**\n * @param r - The red value\n * @param g - The green value\n * @param b - The blue value\n * @param name - The name of the color\n */\n constructor(r, g, b, name) {\n this.r = r;\n this.g = g;\n this.b = b;\n this.name = name;\n this.r = Math.min(r, 255);\n this.g = Math.min(g, 255);\n this.b = Math.min(b, 255);\n this.name = name;\n }\n /**\n * The hexadecimal color string.\n */\n get color() {\n const toHex = (int) => `00${int.toString(16)}`.slice(-2);\n return `#${toHex(this.r)}${toHex(this.g)}${toHex(this.b)}`;\n }\n}\nfunction calculateStepIncrement(steps, color1, color2) {\n return {\n r: (color2.r - color1.r) / steps,\n g: (color2.g - color1.g) / steps,\n b: (color2.b - color1.b) / steps\n };\n}\nfunction mixPalette(steps, color1, color2) {\n const palette = [];\n palette.push(color1);\n const increment = calculateStepIncrement(steps, color1, color2);\n for (let i = 1; i < steps; i++) {\n const r = Math.floor(color1.r + increment.r * i);\n const g = Math.floor(color1.g + increment.g * i);\n const b = Math.floor(color1.b + increment.b * i);\n palette.push(new Color(r, g, b));\n }\n return palette;\n}\nconst defaultPalette = [\n /* eslint-disable @stylistic/function-call-argument-newline -- Allow to put translators comments */\n new Color(\n 182,\n 70,\n 157,\n t(\"Purple\")\n ),\n new Color(\n 191,\n 103,\n 139,\n t(\"Rosy brown\")\n // TRANSLATORS: A color name for RGB(191, 103, 139)\n ),\n new Color(\n 201,\n 136,\n 121,\n t(\"Feldspar\")\n // TRANSLATORS: A color name for RGB(201, 136, 121)\n ),\n new Color(\n 211,\n 169,\n 103,\n t(\"Whiskey\")\n // TRANSLATORS: A color name for RGB(211, 169, 103)\n ),\n new Color(\n 221,\n 203,\n 85,\n t(\"Gold\")\n ),\n new Color(\n 165,\n 184,\n 114,\n t(\"Olivine\")\n // TRANSLATORS: A color name for RGB(165, 184, 114)\n ),\n new Color(\n 110,\n 166,\n 143,\n t(\"Acapulco\")\n // TRANSLATORS: A color name for RGB(110, 166, 143)\n ),\n new Color(\n 55,\n 148,\n 172,\n t(\"Boston Blue\")\n // TRANSLATORS: A color name for RGB(55, 148, 172)\n ),\n new Color(\n 0,\n 130,\n 201,\n t(\"Nextcloud blue\")\n ),\n new Color(\n 45,\n 115,\n 190,\n t(\"Mariner\")\n // TRANSLATORS: A color name for RGB(45, 115, 190)\n ),\n new Color(\n 91,\n 100,\n 179,\n t(\"Blue Violet\")\n // TRANSLATORS: A color name for RGB(91, 100, 179)\n ),\n new Color(\n 136,\n 85,\n 168,\n t(\"Deluge\")\n // TRANSLATORS: A color name for RGB(136, 85, 168)\n )\n /* eslint-enable @stylistic/function-call-argument-newline */\n];\nfunction generatePalette(steps) {\n const red = new Color(182, 70, 157, t(\"Purple\"));\n const yellow = new Color(221, 203, 85, t(\"Gold\"));\n const blue = new Color(0, 130, 201, t(\"Nextcloud blue\"));\n const palette1 = mixPalette(steps, red, yellow);\n const palette2 = mixPalette(steps, yellow, blue);\n const palette3 = mixPalette(steps, blue, red);\n return palette1.concat(palette2).concat(palette3);\n}\nexport {\n Color as C,\n defaultPalette as d,\n generatePalette as g\n};\n//# sourceMappingURL=colors-BZi52VLk.mjs.map\n","import { createHash } from \"crypto-browserify\";\nimport { g as generatePalette } from \"../../chunks/colors-BZi52VLk.mjs\";\nfunction hashCode(str) {\n let hash = str;\n if (str.match(/^([0-9a-f]{4}-?){8}$/) === null) {\n hash = createHash(\"md5\").update(str).digest(\"hex\");\n }\n hash = hash.replace(/[^0-9a-f]/g, \"\");\n let finalInt = 0;\n for (let i = 0; i < hash.length; i++) {\n finalInt += parseInt(hash.charAt(i), 16);\n }\n return finalInt;\n}\nfunction usernameToColor(username) {\n const steps = 6;\n const finalPalette = generatePalette(steps);\n const hash = hashCode(username.toLocaleLowerCase());\n return finalPalette[hash % finalPalette.length];\n}\nexport {\n usernameToColor\n};\n//# sourceMappingURL=index.mjs.map\n","'use strict';\n\n(function (global) {\n\n // minimal symbol polyfill for IE11 and others\n if (typeof Symbol !== 'function') {\n var Symbol = function(name) {\n return name;\n }\n\n Symbol.nonNative = true;\n }\n\n const STATE_PLAINTEXT = Symbol('plaintext');\n const STATE_HTML = Symbol('html');\n const STATE_COMMENT = Symbol('comment');\n\n const ALLOWED_TAGS_REGEX = /<(\\w*)>/g;\n const NORMALIZE_TAG_REGEX = /<\\/?([^\\s\\/>]+)/;\n\n function striptags(html, allowable_tags, tag_replacement) {\n html = html || '';\n allowable_tags = allowable_tags || [];\n tag_replacement = tag_replacement || '';\n\n let context = init_context(allowable_tags, tag_replacement);\n\n return striptags_internal(html, context);\n }\n\n function init_striptags_stream(allowable_tags, tag_replacement) {\n allowable_tags = allowable_tags || [];\n tag_replacement = tag_replacement || '';\n\n let context = init_context(allowable_tags, tag_replacement);\n\n return function striptags_stream(html) {\n return striptags_internal(html || '', context);\n };\n }\n\n striptags.init_streaming_mode = init_striptags_stream;\n\n function init_context(allowable_tags, tag_replacement) {\n allowable_tags = parse_allowable_tags(allowable_tags);\n\n return {\n allowable_tags : allowable_tags,\n tag_replacement: tag_replacement,\n\n state : STATE_PLAINTEXT,\n tag_buffer : '',\n depth : 0,\n in_quote_char : ''\n };\n }\n\n function striptags_internal(html, context) {\n if (typeof html != \"string\") {\n throw new TypeError(\"'html' parameter must be a string\");\n }\n\n let allowable_tags = context.allowable_tags;\n let tag_replacement = context.tag_replacement;\n\n let state = context.state;\n let tag_buffer = context.tag_buffer;\n let depth = context.depth;\n let in_quote_char = context.in_quote_char;\n let output = '';\n\n for (let idx = 0, length = html.length; idx < length; idx++) {\n let char = html[idx];\n\n if (state === STATE_PLAINTEXT) {\n switch (char) {\n case '<':\n state = STATE_HTML;\n tag_buffer += char;\n break;\n\n default:\n output += char;\n break;\n }\n }\n\n else if (state === STATE_HTML) {\n switch (char) {\n case '<':\n // ignore '<' if inside a quote\n if (in_quote_char) {\n break;\n }\n\n // we're seeing a nested '<'\n depth++;\n break;\n\n case '>':\n // ignore '>' if inside a quote\n if (in_quote_char) {\n break;\n }\n\n // something like this is happening: '<<>>'\n if (depth) {\n depth--;\n\n break;\n }\n\n // this is closing the tag in tag_buffer\n in_quote_char = '';\n state = STATE_PLAINTEXT;\n tag_buffer += '>';\n\n if (allowable_tags.has(normalize_tag(tag_buffer))) {\n output += tag_buffer;\n } else {\n output += tag_replacement;\n }\n\n tag_buffer = '';\n break;\n\n case '\"':\n case '\\'':\n // catch both single and double quotes\n\n if (char === in_quote_char) {\n in_quote_char = '';\n } else {\n in_quote_char = in_quote_char || char;\n }\n\n tag_buffer += char;\n break;\n\n case '-':\n if (tag_buffer === '':\n if (tag_buffer.slice(-2) == '--') {\n // close the comment\n state = STATE_PLAINTEXT;\n }\n\n tag_buffer = '';\n break;\n\n default:\n tag_buffer += char;\n break;\n }\n }\n }\n\n // save the context for future iterations\n context.state = state;\n context.tag_buffer = tag_buffer;\n context.depth = depth;\n context.in_quote_char = in_quote_char;\n\n return output;\n }\n\n function parse_allowable_tags(allowable_tags) {\n let tag_set = new Set();\n\n if (typeof allowable_tags === 'string') {\n let match;\n\n while ((match = ALLOWED_TAGS_REGEX.exec(allowable_tags))) {\n tag_set.add(match[1]);\n }\n }\n\n else if (!Symbol.nonNative &&\n typeof allowable_tags[Symbol.iterator] === 'function') {\n\n tag_set = new Set(allowable_tags);\n }\n\n else if (typeof allowable_tags.forEach === 'function') {\n // IE11 compatible\n allowable_tags.forEach(tag_set.add, tag_set);\n }\n\n return tag_set;\n }\n\n function normalize_tag(tag_buffer) {\n let match = NORMALIZE_TAG_REGEX.exec(tag_buffer);\n\n return match ? match[1].toLowerCase() : null;\n }\n\n if (typeof define === 'function' && define.amd) {\n // AMD\n define(function module_factory() { return striptags; });\n }\n\n else if (typeof module === 'object' && module.exports) {\n // Node\n module.exports = striptags;\n }\n\n else {\n // Browser\n global.striptags = striptags;\n }\n}(this));\n","import '../assets/NcMentionBubble-ptHUq68a.css';\nimport { generateUrl } from \"@nextcloud/router\";\nimport { checkIfDarkTheme } from \"../functions/isDarkTheme/index.mjs\";\nfunction getAvatarUrl(user, options) {\n const size = (options?.size || 64) <= 64 ? 64 : 512;\n const guestUrl = options?.isGuest ? \"/guest\" : \"\";\n const themeUrl = options?.isDarkTheme ?? checkIfDarkTheme(document.body) ? \"/dark\" : \"\";\n return generateUrl(`/avatar${guestUrl}/{user}/{size}${themeUrl}`, {\n user,\n size\n });\n}\nexport {\n getAvatarUrl as g\n};\n//# sourceMappingURL=NcMentionBubble.vue_vue_type_style_index_0_scoped_45238efd_lang-D6LzDiYf.mjs.map\n","import '../assets/NcUserStatusIcon-D8HqS9GC.css';\nimport { defineComponent, mergeModels, useModel, computed, watch, createElementBlock, createCommentVNode, openBlock, normalizeClass } from \"vue\";\nimport axios from \"@nextcloud/axios\";\nimport { getCapabilities } from \"@nextcloud/capabilities\";\nimport { generateOcsUrl } from \"@nextcloud/router\";\nimport { r as register, B as t11, a as t } from \"./_l10n-CeXHJQB0.mjs\";\nimport { l as logger } from \"./logger-D3RVzcfQ.mjs\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst awaySvg = '\\n\\n\t\\n\\n';\nconst busySvg = '\\n\\n\t\\n\\n';\nconst dndSvg = '\\n\\n\t\\n\\n';\nconst invisibleSvg = '\\n\\n\t\\n\\n';\nconst onlineSvg = '\\n\\n\t\\n\\n';\nregister();\nregister(t11);\nfunction getUserStatusText(status) {\n switch (status) {\n case \"away\":\n return t(\"away\");\n // TRANSLATORS: User status if the user is currently away from keyboard\n case \"busy\":\n return t(\"busy\");\n case \"dnd\":\n return t(\"do not disturb\");\n case \"online\":\n return t(\"online\");\n case \"invisible\":\n return t(\"invisible\");\n case \"offline\":\n return t(\"offline\");\n default:\n return status;\n }\n}\nconst _hoisted_1 = [\"aria-hidden\", \"aria-label\", \"innerHTML\"];\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n __name: \"NcUserStatusIcon\",\n props: /* @__PURE__ */ mergeModels({\n user: { default: void 0 },\n ariaHidden: { type: [Boolean, String], default: false }\n }, {\n \"status\": {},\n \"statusModifiers\": {}\n }),\n emits: [\"update:status\"],\n setup(__props) {\n const status = useModel(__props, \"status\");\n const props = __props;\n const isInvisible = computed(() => status.value && [\"invisible\", \"offline\"].includes(status.value));\n const ariaLabel = computed(() => status.value && (!props.ariaHidden || props.ariaHidden === \"false\") ? t(\"User status: {status}\", { status: getUserStatusText(status.value) }) : void 0);\n watch(() => props.user, async (user) => {\n if (!status.value && user && getCapabilities()?.user_status?.enabled) {\n try {\n const { data } = await axios.get(generateOcsUrl(\"/apps/user_status/api/v1/statuses/{user}\", { user }));\n status.value = data.ocs?.data?.status;\n } catch (error) {\n logger.debug(\"Error while fetching user status\", { error });\n }\n }\n }, { immediate: true });\n const matchSvg = {\n online: onlineSvg,\n away: awaySvg,\n busy: busySvg,\n dnd: dndSvg,\n invisible: invisibleSvg,\n offline: invisibleSvg\n };\n const activeSvg = computed(() => status.value && matchSvg[status.value]);\n return (_ctx, _cache) => {\n return status.value ? (openBlock(), createElementBlock(\"span\", {\n key: 0,\n class: normalizeClass([\"user-status-icon\", {\n \"user-status-icon--invisible\": isInvisible.value\n }]),\n \"aria-hidden\": !ariaLabel.value || void 0,\n \"aria-label\": ariaLabel.value,\n role: \"img\",\n innerHTML: activeSvg.value\n }, null, 10, _hoisted_1)) : createCommentVNode(\"\", true);\n };\n }\n});\nconst NcUserStatusIcon = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__scopeId\", \"data-v-009e879d\"]]);\nexport {\n NcUserStatusIcon as N,\n getUserStatusText as g\n};\n//# sourceMappingURL=NcUserStatusIcon-DiX6zPGT.mjs.map\n","const ActionGlobalMixin = {\n beforeUpdate() {\n this.text = this.getText();\n },\n data() {\n return {\n // $slots are not reactive.\n // We need to update the content manually\n text: this.getText()\n };\n },\n computed: {\n isLongText() {\n return this.text && this.text.trim().length > 20;\n }\n },\n methods: {\n getText() {\n return this.$slots.default?.()[0].children?.trim?.() || \"\";\n }\n }\n};\nexport {\n ActionGlobalMixin as A\n};\n//# sourceMappingURL=actionGlobal-BZFdtdJL.mjs.map\n","import { warn } from \"vue\";\nimport { N as NC_ACTIONS_CLOSE_MENU } from \"./useNcActions-CiGWxAJE.mjs\";\nimport { A as ActionGlobalMixin } from \"./actionGlobal-BZFdtdJL.mjs\";\nconst ActionTextMixin = {\n mixins: [ActionGlobalMixin],\n props: {\n /**\n * Icon to show with the action, can be either a CSS class or an URL\n */\n icon: {\n type: String,\n default: \"\"\n },\n /**\n * The main text content of the entry.\n */\n name: {\n type: String,\n default: \"\"\n },\n /**\n * The title attribute of the element.\n */\n title: {\n type: String,\n default: \"\"\n },\n /**\n * Whether we close the Actions menu after the click\n */\n closeAfterClick: {\n type: Boolean,\n default: false\n },\n /**\n * Aria label for the button. Not needed if the button has text.\n */\n ariaLabel: {\n type: String,\n default: null\n }\n },\n inject: {\n closeMenu: {\n from: NC_ACTIONS_CLOSE_MENU\n }\n },\n emits: [\n \"click\"\n ],\n created() {\n if (\"ariaHidden\" in this.$attrs) {\n warn(\"[NcAction*]: Do not set the ariaHidden attribute as the root element will inherit the incorrect aria-hidden.\");\n }\n },\n computed: {\n /**\n * Check if icon prop is an URL\n *\n * @return {boolean} Whether the icon prop is an URL\n */\n isIconUrl() {\n try {\n return !!new URL(this.icon, this.icon.startsWith(\"/\") ? window.location.origin : void 0);\n } catch {\n return false;\n }\n }\n },\n methods: {\n onClick(event) {\n this.$emit(\"click\", event);\n if (this.closeAfterClick) {\n this.closeMenu(false);\n }\n }\n }\n};\nexport {\n ActionTextMixin as A\n};\n//# sourceMappingURL=actionText-DYzDdbVe.mjs.map\n","import '../assets/NcActionButton-D7bnKlOt.css';\nimport { c as mdiChevronRight, d as mdiCheck } from \"./mdi-D_GPbmUY.mjs\";\nimport { N as NcIconSvgWrapper } from \"./NcIconSvgWrapper-5AA93z-F.mjs\";\nimport { A as ActionTextMixin } from \"./actionText-DYzDdbVe.mjs\";\nimport { a as NC_ACTIONS_IS_SEMANTIC_MENU } from \"./useNcActions-CiGWxAJE.mjs\";\nimport { resolveComponent, createElementBlock, openBlock, normalizeClass, createElementVNode, mergeProps, renderSlot, createBlock, createCommentVNode, normalizeStyle, toDisplayString } from \"vue\";\nimport { _ as _export_sfc } from \"./_plugin-vue_export-helper-1tPrXgE0.mjs\";\nconst _sfc_main = {\n name: \"NcActionButton\",\n components: {\n NcIconSvgWrapper\n },\n mixins: [ActionTextMixin],\n inject: {\n isInSemanticMenu: {\n from: NC_ACTIONS_IS_SEMANTIC_MENU,\n default: false\n }\n },\n props: {\n /**\n * disabled state of the action button\n */\n disabled: {\n type: Boolean,\n default: false\n },\n /**\n * If this is a menu, a chevron icon will\n * be added at the end of the line\n */\n isMenu: {\n type: Boolean,\n default: false\n },\n /**\n * The button's behavior, by default the button acts like a normal button with optional toggle button behavior if `modelValue` is `true` or `false`.\n * But you can also set to checkbox button behavior with tri-state or radio button like behavior.\n * This extends the native HTML button type attribute.\n */\n type: {\n type: String,\n default: \"button\",\n validator: (behavior) => [\"button\", \"checkbox\", \"radio\", \"reset\", \"submit\"].includes(behavior)\n },\n /**\n * The buttons state if `type` is 'checkbox' or 'radio' (meaning if it is pressed / selected).\n * For checkbox and toggle button behavior - boolean value.\n * For radio button behavior - could be a boolean checked or a string with the value of the button.\n * Note: Unlike native radio buttons, NcActionButton are not grouped by name, so you need to connect them by bind correct modelValue.\n *\n * **This is not availabe for `type='submit'` or `type='reset'`**\n *\n * If using `type='checkbox'` a `model-value` of `true` means checked, `false` means unchecked and `null` means indeterminate (tri-state)\n * For `type='radio'` `null` is equal to `false`\n */\n modelValue: {\n type: [Boolean, String],\n default: null\n },\n /**\n * The value used for the `modelValue` when this component is used with radio behavior\n * Similar to the `value` attribute of ``\n */\n value: {\n type: String,\n default: null\n },\n /**\n * Small underlying text content of the entry\n */\n description: {\n type: String,\n default: \"\"\n }\n },\n emits: [\"update:modelValue\"],\n setup() {\n return {\n mdiCheck,\n mdiChevronRight\n };\n },\n computed: {\n /**\n * determines if the action is focusable\n *\n * @return {boolean} is the action focusable ?\n */\n isFocusable() {\n return !this.disabled;\n },\n /**\n * The current \"checked\" or \"pressed\" state for the model behavior\n */\n isChecked() {\n if (this.type === \"radio\" && typeof this.modelValue !== \"boolean\") {\n return this.modelValue === this.value;\n }\n return this.modelValue;\n },\n /**\n * The native HTML type to set on the button\n */\n nativeType() {\n if (this.type === \"submit\" || this.type === \"reset\") {\n return this.type;\n }\n return \"button\";\n },\n /**\n * HTML attributes to bind to the