diff --git a/.obsidian/appearance.json b/.obsidian/appearance.json index d9941ff..01b5e37 100644 --- a/.obsidian/appearance.json +++ b/.obsidian/appearance.json @@ -6,5 +6,6 @@ "textFontFamily": "IBM Plex Mono,monospace", "monospaceFontFamily": "IBM Plex Mono", "baseFontSize": 19, - "enabledCssSnippets": [] + "enabledCssSnippets": [], + "accentColor": "" } \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-git/data.json b/.obsidian/plugins/obsidian-git/data.json index d360cd6..11956f7 100644 --- a/.obsidian/plugins/obsidian-git/data.json +++ b/.obsidian/plugins/obsidian-git/data.json @@ -20,5 +20,8 @@ "basePath": "", "differentIntervalCommitAndPush": true, "changedFilesInStatusBar": true, - "username": "" + "username": "", + "showedMobileNotice": true, + "refreshSourceControlTimer": 7000, + "showBranchStatusBar": true } \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-git/main.js b/.obsidian/plugins/obsidian-git/main.js index 361ebee..61f132a 100644 --- a/.obsidian/plugins/obsidian-git/main.js +++ b/.obsidian/plugins/obsidian-git/main.js @@ -1,32 +1,18 @@ /* THIS IS A GENERATED/BUNDLED FILE BY ESBUILD -if you want to view the source visit the plugins github repository (https://github.com/phibr0/obsidian-dictionary) +if you want to view the source visit the plugins github repository (https://github.com/denolehov/obsidian-git) */ var __create = Object.create; var __defProp = Object.defineProperty; -var __defProps = Object.defineProperties; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; -var __getOwnPropDescs = Object.getOwnPropertyDescriptors; var __getOwnPropNames = Object.getOwnPropertyNames; -var __getOwnPropSymbols = Object.getOwnPropertySymbols; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; -var __propIsEnum = Object.prototype.propertyIsEnumerable; -var __defNormalProp = (obj, key2, value) => key2 in obj ? __defProp(obj, key2, { enumerable: true, configurable: true, writable: true, value }) : obj[key2] = value; -var __spreadValues = (a, b) => { - for (var prop in b || (b = {})) - if (__hasOwnProp.call(b, prop)) - __defNormalProp(a, prop, b[prop]); - if (__getOwnPropSymbols) - for (var prop of __getOwnPropSymbols(b)) { - if (__propIsEnum.call(b, prop)) - __defNormalProp(a, prop, b[prop]); - } - return a; -}; -var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); var __markAsModule = (target) => __defProp(target, "__esModule", { value: true }); +var __esm = (fn, res) => function __init() { + return fn && (res = (0, fn[Object.keys(fn)[0]])(fn = 0)), res; +}; var __commonJS = (cb, mod) => function __require() { return mod || (0, cb[Object.keys(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; }; @@ -46,30 +32,7202 @@ var __reExport = (target, module2, desc) => { var __toModule = (module2) => { return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2); }; -var __async = (__this, __arguments, generator) => { - return new Promise((resolve, reject) => { - var fulfilled = (value) => { + +// node_modules/base64-js/index.js +var require_base64_js = __commonJS({ + "node_modules/base64-js/index.js"(exports) { + init_polyfill_buffer(); + "use strict"; + exports.byteLength = byteLength; + exports.toByteArray = toByteArray; + exports.fromByteArray = fromByteArray; + var lookup = []; + var revLookup = []; + var Arr = typeof Uint8Array !== "undefined" ? Uint8Array : Array; + var code = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + for (i = 0, len = code.length; i < len; ++i) { + lookup[i] = code[i]; + revLookup[code.charCodeAt(i)] = i; + } + var i; + var len; + revLookup["-".charCodeAt(0)] = 62; + revLookup["_".charCodeAt(0)] = 63; + function getLens(b64) { + var len2 = b64.length; + if (len2 % 4 > 0) { + throw new Error("Invalid string. Length must be a multiple of 4"); + } + var validLen = b64.indexOf("="); + if (validLen === -1) + validLen = len2; + var placeHoldersLen = validLen === len2 ? 0 : 4 - validLen % 4; + return [validLen, placeHoldersLen]; + } + function byteLength(b64) { + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + return (validLen + placeHoldersLen) * 3 / 4 - placeHoldersLen; + } + function _byteLength(b64, validLen, placeHoldersLen) { + return (validLen + placeHoldersLen) * 3 / 4 - placeHoldersLen; + } + function toByteArray(b64) { + var tmp; + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen)); + var curByte = 0; + var len2 = placeHoldersLen > 0 ? validLen - 4 : validLen; + var i2; + for (i2 = 0; i2 < len2; i2 += 4) { + tmp = revLookup[b64.charCodeAt(i2)] << 18 | revLookup[b64.charCodeAt(i2 + 1)] << 12 | revLookup[b64.charCodeAt(i2 + 2)] << 6 | revLookup[b64.charCodeAt(i2 + 3)]; + arr[curByte++] = tmp >> 16 & 255; + arr[curByte++] = tmp >> 8 & 255; + arr[curByte++] = tmp & 255; + } + if (placeHoldersLen === 2) { + tmp = revLookup[b64.charCodeAt(i2)] << 2 | revLookup[b64.charCodeAt(i2 + 1)] >> 4; + arr[curByte++] = tmp & 255; + } + if (placeHoldersLen === 1) { + tmp = revLookup[b64.charCodeAt(i2)] << 10 | revLookup[b64.charCodeAt(i2 + 1)] << 4 | revLookup[b64.charCodeAt(i2 + 2)] >> 2; + arr[curByte++] = tmp >> 8 & 255; + arr[curByte++] = tmp & 255; + } + return arr; + } + function tripletToBase64(num2) { + return lookup[num2 >> 18 & 63] + lookup[num2 >> 12 & 63] + lookup[num2 >> 6 & 63] + lookup[num2 & 63]; + } + function encodeChunk(uint8, start, end) { + var tmp; + var output = []; + for (var i2 = start; i2 < end; i2 += 3) { + tmp = (uint8[i2] << 16 & 16711680) + (uint8[i2 + 1] << 8 & 65280) + (uint8[i2 + 2] & 255); + output.push(tripletToBase64(tmp)); + } + return output.join(""); + } + function fromByteArray(uint8) { + var tmp; + var len2 = uint8.length; + var extraBytes = len2 % 3; + var parts = []; + var maxChunkLength = 16383; + for (var i2 = 0, len22 = len2 - extraBytes; i2 < len22; i2 += maxChunkLength) { + parts.push(encodeChunk(uint8, i2, i2 + maxChunkLength > len22 ? len22 : i2 + maxChunkLength)); + } + if (extraBytes === 1) { + tmp = uint8[len2 - 1]; + parts.push(lookup[tmp >> 2] + lookup[tmp << 4 & 63] + "=="); + } else if (extraBytes === 2) { + tmp = (uint8[len2 - 2] << 8) + uint8[len2 - 1]; + parts.push(lookup[tmp >> 10] + lookup[tmp >> 4 & 63] + lookup[tmp << 2 & 63] + "="); + } + return parts.join(""); + } + } +}); + +// node_modules/ieee754/index.js +var require_ieee754 = __commonJS({ + "node_modules/ieee754/index.js"(exports) { + init_polyfill_buffer(); + exports.read = function(buffer2, offset, isLE, mLen, nBytes) { + var e, m; + var eLen = nBytes * 8 - mLen - 1; + var eMax = (1 << eLen) - 1; + var eBias = eMax >> 1; + var nBits = -7; + var i = isLE ? nBytes - 1 : 0; + var d = isLE ? -1 : 1; + var s = buffer2[offset + i]; + i += d; + e = s & (1 << -nBits) - 1; + s >>= -nBits; + nBits += eLen; + for (; nBits > 0; e = e * 256 + buffer2[offset + i], i += d, nBits -= 8) { + } + m = e & (1 << -nBits) - 1; + e >>= -nBits; + nBits += mLen; + for (; nBits > 0; m = m * 256 + buffer2[offset + i], i += d, nBits -= 8) { + } + if (e === 0) { + e = 1 - eBias; + } else if (e === eMax) { + return m ? NaN : (s ? -1 : 1) * Infinity; + } else { + m = m + Math.pow(2, mLen); + e = e - eBias; + } + return (s ? -1 : 1) * m * Math.pow(2, e - mLen); + }; + exports.write = function(buffer2, value, offset, isLE, mLen, nBytes) { + var e, m, c; + var eLen = nBytes * 8 - mLen - 1; + var eMax = (1 << eLen) - 1; + var eBias = eMax >> 1; + var rt = mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0; + var i = isLE ? 0 : nBytes - 1; + var d = isLE ? 1 : -1; + var s = value < 0 || value === 0 && 1 / value < 0 ? 1 : 0; + value = Math.abs(value); + if (isNaN(value) || value === Infinity) { + m = isNaN(value) ? 1 : 0; + e = eMax; + } else { + e = Math.floor(Math.log(value) / Math.LN2); + if (value * (c = Math.pow(2, -e)) < 1) { + e--; + c *= 2; + } + if (e + eBias >= 1) { + value += rt / c; + } else { + value += rt * Math.pow(2, 1 - eBias); + } + if (value * c >= 2) { + e++; + c /= 2; + } + if (e + eBias >= eMax) { + m = 0; + e = eMax; + } else if (e + eBias >= 1) { + m = (value * c - 1) * Math.pow(2, mLen); + e = e + eBias; + } else { + m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen); + e = 0; + } + } + for (; mLen >= 8; buffer2[offset + i] = m & 255, i += d, m /= 256, mLen -= 8) { + } + e = e << mLen | m; + eLen += mLen; + for (; eLen > 0; buffer2[offset + i] = e & 255, i += d, e /= 256, eLen -= 8) { + } + buffer2[offset + i - d] |= s * 128; + }; + } +}); + +// node_modules/buffer/index.js +var require_buffer = __commonJS({ + "node_modules/buffer/index.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var base64 = require_base64_js(); + var ieee754 = require_ieee754(); + var customInspectSymbol = typeof Symbol === "function" && typeof Symbol["for"] === "function" ? Symbol["for"]("nodejs.util.inspect.custom") : null; + exports.Buffer = Buffer3; + exports.SlowBuffer = SlowBuffer; + exports.INSPECT_MAX_BYTES = 50; + var K_MAX_LENGTH = 2147483647; + exports.kMaxLength = K_MAX_LENGTH; + Buffer3.TYPED_ARRAY_SUPPORT = typedArraySupport(); + if (!Buffer3.TYPED_ARRAY_SUPPORT && typeof console !== "undefined" && 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 typedArraySupport() { try { - step(generator.next(value)); + const arr = new Uint8Array(1); + const proto = { foo: function() { + return 42; + } }; + Object.setPrototypeOf(proto, Uint8Array.prototype); + Object.setPrototypeOf(arr, proto); + return arr.foo() === 42; } catch (e) { - reject(e); + return false; + } + } + Object.defineProperty(Buffer3.prototype, "parent", { + enumerable: true, + get: function() { + if (!Buffer3.isBuffer(this)) + return void 0; + return this.buffer; + } + }); + Object.defineProperty(Buffer3.prototype, "offset", { + enumerable: true, + get: function() { + if (!Buffer3.isBuffer(this)) + return void 0; + return this.byteOffset; + } + }); + function createBuffer(length) { + if (length > K_MAX_LENGTH) { + throw new RangeError('The value "' + length + '" is invalid for option "size"'); + } + const buf = new Uint8Array(length); + Object.setPrototypeOf(buf, Buffer3.prototype); + return buf; + } + function Buffer3(arg, encodingOrOffset, length) { + if (typeof arg === "number") { + if (typeof encodingOrOffset === "string") { + throw new TypeError('The "string" argument must be of type string. Received type number'); + } + return allocUnsafe(arg); + } + return from(arg, encodingOrOffset, length); + } + Buffer3.poolSize = 8192; + function from(value, encodingOrOffset, length) { + if (typeof value === "string") { + return fromString(value, encodingOrOffset); + } + if (ArrayBuffer.isView(value)) { + return fromArrayView(value); + } + if (value == null) { + throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value); + } + if (isInstance(value, ArrayBuffer) || value && isInstance(value.buffer, ArrayBuffer)) { + return fromArrayBuffer(value, encodingOrOffset, length); + } + if (typeof SharedArrayBuffer !== "undefined" && (isInstance(value, SharedArrayBuffer) || value && isInstance(value.buffer, SharedArrayBuffer))) { + return fromArrayBuffer(value, encodingOrOffset, length); + } + if (typeof value === "number") { + throw new TypeError('The "value" argument must not be of type number. Received type number'); + } + const valueOf = value.valueOf && value.valueOf(); + if (valueOf != null && valueOf !== value) { + return Buffer3.from(valueOf, encodingOrOffset, length); + } + const b = fromObject(value); + if (b) + return b; + if (typeof Symbol !== "undefined" && Symbol.toPrimitive != null && typeof value[Symbol.toPrimitive] === "function") { + return Buffer3.from(value[Symbol.toPrimitive]("string"), encodingOrOffset, length); + } + throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value); + } + Buffer3.from = function(value, encodingOrOffset, length) { + return from(value, encodingOrOffset, length); + }; + Object.setPrototypeOf(Buffer3.prototype, Uint8Array.prototype); + Object.setPrototypeOf(Buffer3, Uint8Array); + function assertSize(size) { + if (typeof size !== "number") { + throw new TypeError('"size" argument must be of type number'); + } else if (size < 0) { + throw new RangeError('The value "' + size + '" is invalid for option "size"'); + } + } + function alloc(size, fill, encoding) { + assertSize(size); + if (size <= 0) { + return createBuffer(size); + } + if (fill !== void 0) { + return typeof encoding === "string" ? createBuffer(size).fill(fill, encoding) : createBuffer(size).fill(fill); + } + return createBuffer(size); + } + Buffer3.alloc = function(size, fill, encoding) { + return alloc(size, fill, encoding); + }; + function allocUnsafe(size) { + assertSize(size); + return createBuffer(size < 0 ? 0 : checked(size) | 0); + } + Buffer3.allocUnsafe = function(size) { + return allocUnsafe(size); + }; + Buffer3.allocUnsafeSlow = function(size) { + return allocUnsafe(size); + }; + function fromString(string, encoding) { + if (typeof encoding !== "string" || encoding === "") { + encoding = "utf8"; + } + if (!Buffer3.isEncoding(encoding)) { + throw new TypeError("Unknown encoding: " + encoding); + } + const length = byteLength(string, encoding) | 0; + let buf = createBuffer(length); + const actual = buf.write(string, encoding); + if (actual !== length) { + buf = buf.slice(0, actual); + } + return buf; + } + function fromArrayLike(array) { + const length = array.length < 0 ? 0 : checked(array.length) | 0; + const buf = createBuffer(length); + for (let i = 0; i < length; i += 1) { + buf[i] = array[i] & 255; + } + return buf; + } + function fromArrayView(arrayView) { + if (isInstance(arrayView, Uint8Array)) { + const copy2 = new Uint8Array(arrayView); + return fromArrayBuffer(copy2.buffer, copy2.byteOffset, copy2.byteLength); + } + return fromArrayLike(arrayView); + } + function fromArrayBuffer(array, byteOffset, length) { + if (byteOffset < 0 || array.byteLength < byteOffset) { + throw new RangeError('"offset" is outside of buffer bounds'); + } + if (array.byteLength < byteOffset + (length || 0)) { + throw new RangeError('"length" is outside of buffer bounds'); + } + let buf; + if (byteOffset === void 0 && length === void 0) { + buf = new Uint8Array(array); + } else if (length === void 0) { + buf = new Uint8Array(array, byteOffset); + } else { + buf = new Uint8Array(array, byteOffset, length); + } + Object.setPrototypeOf(buf, Buffer3.prototype); + return buf; + } + function fromObject(obj) { + if (Buffer3.isBuffer(obj)) { + const len = checked(obj.length) | 0; + const buf = createBuffer(len); + if (buf.length === 0) { + return buf; + } + obj.copy(buf, 0, 0, len); + return buf; + } + if (obj.length !== void 0) { + if (typeof obj.length !== "number" || numberIsNaN(obj.length)) { + return createBuffer(0); + } + return fromArrayLike(obj); + } + if (obj.type === "Buffer" && Array.isArray(obj.data)) { + return fromArrayLike(obj.data); + } + } + function checked(length) { + if (length >= K_MAX_LENGTH) { + throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x" + K_MAX_LENGTH.toString(16) + " bytes"); + } + return length | 0; + } + function SlowBuffer(length) { + if (+length != length) { + length = 0; + } + return Buffer3.alloc(+length); + } + Buffer3.isBuffer = function isBuffer(b) { + return b != null && b._isBuffer === true && b !== Buffer3.prototype; + }; + Buffer3.compare = function compare(a, b) { + if (isInstance(a, Uint8Array)) + a = Buffer3.from(a, a.offset, a.byteLength); + if (isInstance(b, Uint8Array)) + b = Buffer3.from(b, b.offset, b.byteLength); + if (!Buffer3.isBuffer(a) || !Buffer3.isBuffer(b)) { + throw new TypeError('The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array'); + } + if (a === b) + return 0; + let x = a.length; + let y = b.length; + for (let i = 0, len = Math.min(x, y); i < len; ++i) { + if (a[i] !== b[i]) { + x = a[i]; + y = b[i]; + break; + } + } + if (x < y) + return -1; + if (y < x) + return 1; + return 0; + }; + Buffer3.isEncoding = function isEncoding(encoding) { + switch (String(encoding).toLowerCase()) { + case "hex": + case "utf8": + case "utf-8": + case "ascii": + case "latin1": + case "binary": + case "base64": + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return true; + default: + return false; } }; - var rejected = (value) => { - try { - step(generator.throw(value)); - } catch (e) { - reject(e); + Buffer3.concat = function concat(list, length) { + if (!Array.isArray(list)) { + throw new TypeError('"list" argument must be an Array of Buffers'); + } + if (list.length === 0) { + return Buffer3.alloc(0); + } + let i; + if (length === void 0) { + length = 0; + for (i = 0; i < list.length; ++i) { + length += list[i].length; + } + } + const buffer2 = Buffer3.allocUnsafe(length); + let pos = 0; + for (i = 0; i < list.length; ++i) { + let buf = list[i]; + if (isInstance(buf, Uint8Array)) { + if (pos + buf.length > buffer2.length) { + if (!Buffer3.isBuffer(buf)) + buf = Buffer3.from(buf); + buf.copy(buffer2, pos); + } else { + Uint8Array.prototype.set.call(buffer2, buf, pos); + } + } else if (!Buffer3.isBuffer(buf)) { + throw new TypeError('"list" argument must be an Array of Buffers'); + } else { + buf.copy(buffer2, pos); + } + pos += buf.length; + } + return buffer2; + }; + function byteLength(string, encoding) { + if (Buffer3.isBuffer(string)) { + return string.length; + } + if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) { + return string.byteLength; + } + if (typeof string !== "string") { + throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type ' + typeof string); + } + const len = string.length; + const mustMatch = arguments.length > 2 && arguments[2] === true; + if (!mustMatch && len === 0) + return 0; + let loweredCase = false; + for (; ; ) { + switch (encoding) { + case "ascii": + case "latin1": + case "binary": + return len; + case "utf8": + case "utf-8": + return utf8ToBytes(string).length; + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return len * 2; + case "hex": + return len >>> 1; + case "base64": + return base64ToBytes(string).length; + default: + if (loweredCase) { + return mustMatch ? -1 : utf8ToBytes(string).length; + } + encoding = ("" + encoding).toLowerCase(); + loweredCase = true; + } + } + } + Buffer3.byteLength = byteLength; + function slowToString(encoding, start, end) { + let loweredCase = false; + if (start === void 0 || start < 0) { + start = 0; + } + if (start > this.length) { + return ""; + } + if (end === void 0 || end > this.length) { + end = this.length; + } + if (end <= 0) { + return ""; + } + end >>>= 0; + start >>>= 0; + if (end <= start) { + return ""; + } + if (!encoding) + encoding = "utf8"; + while (true) { + switch (encoding) { + case "hex": + return hexSlice(this, start, end); + case "utf8": + case "utf-8": + return utf8Slice(this, start, end); + case "ascii": + return asciiSlice(this, start, end); + case "latin1": + case "binary": + return latin1Slice(this, start, end); + case "base64": + return base64Slice(this, start, end); + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return utf16leSlice(this, start, end); + default: + if (loweredCase) + throw new TypeError("Unknown encoding: " + encoding); + encoding = (encoding + "").toLowerCase(); + loweredCase = true; + } + } + } + Buffer3.prototype._isBuffer = true; + function swap(b, n, m) { + const i = b[n]; + b[n] = b[m]; + b[m] = i; + } + Buffer3.prototype.swap16 = function swap16() { + const len = this.length; + if (len % 2 !== 0) { + throw new RangeError("Buffer size must be a multiple of 16-bits"); + } + for (let i = 0; i < len; i += 2) { + swap(this, i, i + 1); + } + return this; + }; + Buffer3.prototype.swap32 = function swap32() { + const len = this.length; + if (len % 4 !== 0) { + throw new RangeError("Buffer size must be a multiple of 32-bits"); + } + for (let i = 0; i < len; i += 4) { + swap(this, i, i + 3); + swap(this, i + 1, i + 2); + } + return this; + }; + Buffer3.prototype.swap64 = function swap64() { + const len = this.length; + if (len % 8 !== 0) { + throw new RangeError("Buffer size must be a multiple of 64-bits"); + } + for (let i = 0; i < len; i += 8) { + swap(this, i, i + 7); + swap(this, i + 1, i + 6); + swap(this, i + 2, i + 5); + swap(this, i + 3, i + 4); + } + return this; + }; + Buffer3.prototype.toString = function toString() { + const length = this.length; + if (length === 0) + return ""; + if (arguments.length === 0) + return utf8Slice(this, 0, length); + return slowToString.apply(this, arguments); + }; + Buffer3.prototype.toLocaleString = Buffer3.prototype.toString; + Buffer3.prototype.equals = function equals2(b) { + if (!Buffer3.isBuffer(b)) + throw new TypeError("Argument must be a Buffer"); + if (this === b) + return true; + return Buffer3.compare(this, b) === 0; + }; + Buffer3.prototype.inspect = function inspect() { + let str = ""; + const max = exports.INSPECT_MAX_BYTES; + str = this.toString("hex", 0, max).replace(/(.{2})/g, "$1 ").trim(); + if (this.length > max) + str += " ... "; + return ""; + }; + if (customInspectSymbol) { + Buffer3.prototype[customInspectSymbol] = Buffer3.prototype.inspect; + } + Buffer3.prototype.compare = function compare(target, start, end, thisStart, thisEnd) { + if (isInstance(target, Uint8Array)) { + target = Buffer3.from(target, target.offset, target.byteLength); + } + if (!Buffer3.isBuffer(target)) { + throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type ' + typeof target); + } + if (start === void 0) { + start = 0; + } + if (end === void 0) { + end = target ? target.length : 0; + } + if (thisStart === void 0) { + thisStart = 0; + } + if (thisEnd === void 0) { + thisEnd = this.length; + } + if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) { + throw new RangeError("out of range index"); + } + if (thisStart >= thisEnd && start >= end) { + return 0; + } + if (thisStart >= thisEnd) { + return -1; + } + if (start >= end) { + return 1; + } + start >>>= 0; + end >>>= 0; + thisStart >>>= 0; + thisEnd >>>= 0; + if (this === target) + return 0; + let x = thisEnd - thisStart; + let y = end - start; + const len = Math.min(x, y); + const thisCopy = this.slice(thisStart, thisEnd); + const targetCopy = target.slice(start, end); + for (let i = 0; i < len; ++i) { + if (thisCopy[i] !== targetCopy[i]) { + x = thisCopy[i]; + y = targetCopy[i]; + break; + } + } + if (x < y) + return -1; + if (y < x) + return 1; + return 0; + }; + function bidirectionalIndexOf(buffer2, val, byteOffset, encoding, dir) { + if (buffer2.length === 0) + return -1; + if (typeof byteOffset === "string") { + encoding = byteOffset; + byteOffset = 0; + } else if (byteOffset > 2147483647) { + byteOffset = 2147483647; + } else if (byteOffset < -2147483648) { + byteOffset = -2147483648; + } + byteOffset = +byteOffset; + if (numberIsNaN(byteOffset)) { + byteOffset = dir ? 0 : buffer2.length - 1; + } + if (byteOffset < 0) + byteOffset = buffer2.length + byteOffset; + if (byteOffset >= buffer2.length) { + if (dir) + return -1; + else + byteOffset = buffer2.length - 1; + } else if (byteOffset < 0) { + if (dir) + byteOffset = 0; + else + return -1; + } + if (typeof val === "string") { + val = Buffer3.from(val, encoding); + } + if (Buffer3.isBuffer(val)) { + if (val.length === 0) { + return -1; + } + return arrayIndexOf(buffer2, val, byteOffset, encoding, dir); + } else if (typeof val === "number") { + val = val & 255; + if (typeof Uint8Array.prototype.indexOf === "function") { + if (dir) { + return Uint8Array.prototype.indexOf.call(buffer2, val, byteOffset); + } else { + return Uint8Array.prototype.lastIndexOf.call(buffer2, val, byteOffset); + } + } + return arrayIndexOf(buffer2, [val], byteOffset, encoding, dir); + } + throw new TypeError("val must be string, number or Buffer"); + } + function arrayIndexOf(arr, val, byteOffset, encoding, dir) { + let indexSize = 1; + let arrLength = arr.length; + let valLength = val.length; + if (encoding !== void 0) { + encoding = String(encoding).toLowerCase(); + if (encoding === "ucs2" || encoding === "ucs-2" || encoding === "utf16le" || encoding === "utf-16le") { + if (arr.length < 2 || val.length < 2) { + return -1; + } + indexSize = 2; + arrLength /= 2; + valLength /= 2; + byteOffset /= 2; + } + } + function read(buf, i2) { + if (indexSize === 1) { + return buf[i2]; + } else { + return buf.readUInt16BE(i2 * indexSize); + } + } + let i; + if (dir) { + let foundIndex = -1; + for (i = byteOffset; i < arrLength; i++) { + if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) { + if (foundIndex === -1) + foundIndex = i; + if (i - foundIndex + 1 === valLength) + return foundIndex * indexSize; + } else { + if (foundIndex !== -1) + i -= i - foundIndex; + foundIndex = -1; + } + } + } else { + if (byteOffset + valLength > arrLength) + byteOffset = arrLength - valLength; + for (i = byteOffset; i >= 0; i--) { + let found = true; + for (let j = 0; j < valLength; j++) { + if (read(arr, i + j) !== read(val, j)) { + found = false; + break; + } + } + if (found) + return i; + } + } + return -1; + } + Buffer3.prototype.includes = function includes(val, byteOffset, encoding) { + return this.indexOf(val, byteOffset, encoding) !== -1; + }; + Buffer3.prototype.indexOf = function indexOf(val, byteOffset, encoding) { + return bidirectionalIndexOf(this, val, byteOffset, encoding, true); + }; + Buffer3.prototype.lastIndexOf = function lastIndexOf(val, byteOffset, encoding) { + return bidirectionalIndexOf(this, val, byteOffset, encoding, false); + }; + function hexWrite(buf, string, offset, length) { + offset = Number(offset) || 0; + const remaining = buf.length - offset; + if (!length) { + length = remaining; + } else { + length = Number(length); + if (length > remaining) { + length = remaining; + } + } + const strLen = string.length; + if (length > strLen / 2) { + length = strLen / 2; + } + let i; + for (i = 0; i < length; ++i) { + const parsed = parseInt(string.substr(i * 2, 2), 16); + if (numberIsNaN(parsed)) + return i; + buf[offset + i] = parsed; + } + return i; + } + function utf8Write(buf, string, offset, length) { + return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length); + } + function asciiWrite(buf, string, offset, length) { + return blitBuffer(asciiToBytes(string), buf, offset, length); + } + function base64Write(buf, string, offset, length) { + return blitBuffer(base64ToBytes(string), buf, offset, length); + } + function ucs2Write(buf, string, offset, length) { + return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length); + } + Buffer3.prototype.write = function write(string, offset, length, encoding) { + if (offset === void 0) { + encoding = "utf8"; + length = this.length; + offset = 0; + } else if (length === void 0 && typeof offset === "string") { + encoding = offset; + length = this.length; + offset = 0; + } else if (isFinite(offset)) { + offset = offset >>> 0; + if (isFinite(length)) { + length = length >>> 0; + if (encoding === void 0) + encoding = "utf8"; + } else { + encoding = length; + length = void 0; + } + } else { + throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported"); + } + const remaining = this.length - offset; + if (length === void 0 || length > remaining) + length = remaining; + if (string.length > 0 && (length < 0 || offset < 0) || offset > this.length) { + throw new RangeError("Attempt to write outside buffer bounds"); + } + if (!encoding) + encoding = "utf8"; + let loweredCase = false; + for (; ; ) { + switch (encoding) { + case "hex": + return hexWrite(this, string, offset, length); + case "utf8": + case "utf-8": + return utf8Write(this, string, offset, length); + case "ascii": + case "latin1": + case "binary": + return asciiWrite(this, string, offset, length); + case "base64": + return base64Write(this, string, offset, length); + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return ucs2Write(this, string, offset, length); + default: + if (loweredCase) + throw new TypeError("Unknown encoding: " + encoding); + encoding = ("" + encoding).toLowerCase(); + loweredCase = true; + } } }; - var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected); - step((generator = generator.apply(__this, __arguments)).next()); - }); -}; + Buffer3.prototype.toJSON = function toJSON() { + return { + type: "Buffer", + data: Array.prototype.slice.call(this._arr || this, 0) + }; + }; + function base64Slice(buf, start, end) { + if (start === 0 && end === buf.length) { + return base64.fromByteArray(buf); + } else { + return base64.fromByteArray(buf.slice(start, end)); + } + } + function utf8Slice(buf, start, end) { + end = Math.min(buf.length, end); + const res = []; + let i = start; + while (i < end) { + const firstByte = buf[i]; + let codePoint = null; + let bytesPerSequence = firstByte > 239 ? 4 : firstByte > 223 ? 3 : firstByte > 191 ? 2 : 1; + if (i + bytesPerSequence <= end) { + let secondByte, thirdByte, fourthByte, tempCodePoint; + switch (bytesPerSequence) { + case 1: + if (firstByte < 128) { + codePoint = firstByte; + } + break; + case 2: + secondByte = buf[i + 1]; + if ((secondByte & 192) === 128) { + tempCodePoint = (firstByte & 31) << 6 | secondByte & 63; + if (tempCodePoint > 127) { + codePoint = tempCodePoint; + } + } + break; + case 3: + secondByte = buf[i + 1]; + thirdByte = buf[i + 2]; + if ((secondByte & 192) === 128 && (thirdByte & 192) === 128) { + tempCodePoint = (firstByte & 15) << 12 | (secondByte & 63) << 6 | thirdByte & 63; + if (tempCodePoint > 2047 && (tempCodePoint < 55296 || tempCodePoint > 57343)) { + codePoint = tempCodePoint; + } + } + break; + case 4: + secondByte = buf[i + 1]; + thirdByte = buf[i + 2]; + fourthByte = buf[i + 3]; + if ((secondByte & 192) === 128 && (thirdByte & 192) === 128 && (fourthByte & 192) === 128) { + tempCodePoint = (firstByte & 15) << 18 | (secondByte & 63) << 12 | (thirdByte & 63) << 6 | fourthByte & 63; + if (tempCodePoint > 65535 && tempCodePoint < 1114112) { + codePoint = tempCodePoint; + } + } + } + } + if (codePoint === null) { + codePoint = 65533; + bytesPerSequence = 1; + } else if (codePoint > 65535) { + codePoint -= 65536; + res.push(codePoint >>> 10 & 1023 | 55296); + codePoint = 56320 | codePoint & 1023; + } + res.push(codePoint); + i += bytesPerSequence; + } + return decodeCodePointsArray(res); + } + var MAX_ARGUMENTS_LENGTH = 4096; + function decodeCodePointsArray(codePoints) { + const len = codePoints.length; + if (len <= MAX_ARGUMENTS_LENGTH) { + return String.fromCharCode.apply(String, codePoints); + } + let res = ""; + let i = 0; + while (i < len) { + res += String.fromCharCode.apply(String, codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)); + } + return res; + } + function asciiSlice(buf, start, end) { + let ret = ""; + end = Math.min(buf.length, end); + for (let i = start; i < end; ++i) { + ret += String.fromCharCode(buf[i] & 127); + } + return ret; + } + function latin1Slice(buf, start, end) { + let ret = ""; + end = Math.min(buf.length, end); + for (let i = start; i < end; ++i) { + ret += String.fromCharCode(buf[i]); + } + return ret; + } + function hexSlice(buf, start, end) { + const len = buf.length; + if (!start || start < 0) + start = 0; + if (!end || end < 0 || end > len) + end = len; + let out = ""; + for (let i = start; i < end; ++i) { + out += hexSliceLookupTable[buf[i]]; + } + return out; + } + function utf16leSlice(buf, start, end) { + const bytes = buf.slice(start, end); + let res = ""; + for (let i = 0; i < bytes.length - 1; i += 2) { + res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256); + } + return res; + } + Buffer3.prototype.slice = function slice(start, end) { + const len = this.length; + start = ~~start; + end = end === void 0 ? len : ~~end; + if (start < 0) { + start += len; + if (start < 0) + start = 0; + } else if (start > len) { + start = len; + } + if (end < 0) { + end += len; + if (end < 0) + end = 0; + } else if (end > len) { + end = len; + } + if (end < start) + end = start; + const newBuf = this.subarray(start, end); + Object.setPrototypeOf(newBuf, Buffer3.prototype); + return newBuf; + }; + function checkOffset(offset, ext, length) { + if (offset % 1 !== 0 || offset < 0) + throw new RangeError("offset is not uint"); + if (offset + ext > length) + throw new RangeError("Trying to access beyond buffer length"); + } + Buffer3.prototype.readUintLE = Buffer3.prototype.readUIntLE = function readUIntLE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) + checkOffset(offset, byteLength2, this.length); + let val = this[offset]; + let mul = 1; + let i = 0; + while (++i < byteLength2 && (mul *= 256)) { + val += this[offset + i] * mul; + } + return val; + }; + Buffer3.prototype.readUintBE = Buffer3.prototype.readUIntBE = function readUIntBE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) { + checkOffset(offset, byteLength2, this.length); + } + let val = this[offset + --byteLength2]; + let mul = 1; + while (byteLength2 > 0 && (mul *= 256)) { + val += this[offset + --byteLength2] * mul; + } + return val; + }; + Buffer3.prototype.readUint8 = Buffer3.prototype.readUInt8 = function readUInt8(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 1, this.length); + return this[offset]; + }; + Buffer3.prototype.readUint16LE = Buffer3.prototype.readUInt16LE = function readUInt16LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + return this[offset] | this[offset + 1] << 8; + }; + Buffer3.prototype.readUint16BE = Buffer3.prototype.readUInt16BE = function readUInt16BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + return this[offset] << 8 | this[offset + 1]; + }; + Buffer3.prototype.readUint32LE = Buffer3.prototype.readUInt32LE = function readUInt32LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return (this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16) + this[offset + 3] * 16777216; + }; + Buffer3.prototype.readUint32BE = Buffer3.prototype.readUInt32BE = function readUInt32BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return this[offset] * 16777216 + (this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]); + }; + Buffer3.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const lo = first2 + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 24; + const hi = this[++offset] + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + last2 * 2 ** 24; + return BigInt(lo) + (BigInt(hi) << BigInt(32)); + }); + Buffer3.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const hi = first2 * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + this[++offset]; + const lo = this[++offset] * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + last2; + return (BigInt(hi) << BigInt(32)) + BigInt(lo); + }); + Buffer3.prototype.readIntLE = function readIntLE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) + checkOffset(offset, byteLength2, this.length); + let val = this[offset]; + let mul = 1; + let i = 0; + while (++i < byteLength2 && (mul *= 256)) { + val += this[offset + i] * mul; + } + mul *= 128; + if (val >= mul) + val -= Math.pow(2, 8 * byteLength2); + return val; + }; + Buffer3.prototype.readIntBE = function readIntBE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) + checkOffset(offset, byteLength2, this.length); + let i = byteLength2; + let mul = 1; + let val = this[offset + --i]; + while (i > 0 && (mul *= 256)) { + val += this[offset + --i] * mul; + } + mul *= 128; + if (val >= mul) + val -= Math.pow(2, 8 * byteLength2); + return val; + }; + Buffer3.prototype.readInt8 = function readInt8(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 1, this.length); + if (!(this[offset] & 128)) + return this[offset]; + return (255 - this[offset] + 1) * -1; + }; + Buffer3.prototype.readInt16LE = function readInt16LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + const val = this[offset] | this[offset + 1] << 8; + return val & 32768 ? val | 4294901760 : val; + }; + Buffer3.prototype.readInt16BE = function readInt16BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + const val = this[offset + 1] | this[offset] << 8; + return val & 32768 ? val | 4294901760 : val; + }; + Buffer3.prototype.readInt32LE = function readInt32LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16 | this[offset + 3] << 24; + }; + Buffer3.prototype.readInt32BE = function readInt32BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return this[offset] << 24 | this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]; + }; + Buffer3.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const val = this[offset + 4] + this[offset + 5] * 2 ** 8 + this[offset + 6] * 2 ** 16 + (last2 << 24); + return (BigInt(val) << BigInt(32)) + BigInt(first2 + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 24); + }); + Buffer3.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const val = (first2 << 24) + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + this[++offset]; + return (BigInt(val) << BigInt(32)) + BigInt(this[++offset] * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + last2); + }); + Buffer3.prototype.readFloatLE = function readFloatLE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return ieee754.read(this, offset, true, 23, 4); + }; + Buffer3.prototype.readFloatBE = function readFloatBE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return ieee754.read(this, offset, false, 23, 4); + }; + Buffer3.prototype.readDoubleLE = function readDoubleLE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 8, this.length); + return ieee754.read(this, offset, true, 52, 8); + }; + Buffer3.prototype.readDoubleBE = function readDoubleBE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 8, this.length); + return ieee754.read(this, offset, false, 52, 8); + }; + function checkInt(buf, value, offset, ext, max, min) { + if (!Buffer3.isBuffer(buf)) + throw new TypeError('"buffer" argument must be a Buffer instance'); + if (value > max || value < min) + throw new RangeError('"value" argument is out of bounds'); + if (offset + ext > buf.length) + throw new RangeError("Index out of range"); + } + Buffer3.prototype.writeUintLE = Buffer3.prototype.writeUIntLE = function writeUIntLE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) { + const maxBytes = Math.pow(2, 8 * byteLength2) - 1; + checkInt(this, value, offset, byteLength2, maxBytes, 0); + } + let mul = 1; + let i = 0; + this[offset] = value & 255; + while (++i < byteLength2 && (mul *= 256)) { + this[offset + i] = value / mul & 255; + } + return offset + byteLength2; + }; + Buffer3.prototype.writeUintBE = Buffer3.prototype.writeUIntBE = function writeUIntBE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) { + const maxBytes = Math.pow(2, 8 * byteLength2) - 1; + checkInt(this, value, offset, byteLength2, maxBytes, 0); + } + let i = byteLength2 - 1; + let mul = 1; + this[offset + i] = value & 255; + while (--i >= 0 && (mul *= 256)) { + this[offset + i] = value / mul & 255; + } + return offset + byteLength2; + }; + Buffer3.prototype.writeUint8 = Buffer3.prototype.writeUInt8 = function writeUInt8(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 1, 255, 0); + this[offset] = value & 255; + return offset + 1; + }; + Buffer3.prototype.writeUint16LE = Buffer3.prototype.writeUInt16LE = function writeUInt16LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 65535, 0); + this[offset] = value & 255; + this[offset + 1] = value >>> 8; + return offset + 2; + }; + Buffer3.prototype.writeUint16BE = Buffer3.prototype.writeUInt16BE = function writeUInt16BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 65535, 0); + this[offset] = value >>> 8; + this[offset + 1] = value & 255; + return offset + 2; + }; + Buffer3.prototype.writeUint32LE = Buffer3.prototype.writeUInt32LE = function writeUInt32LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 4294967295, 0); + this[offset + 3] = value >>> 24; + this[offset + 2] = value >>> 16; + this[offset + 1] = value >>> 8; + this[offset] = value & 255; + return offset + 4; + }; + Buffer3.prototype.writeUint32BE = Buffer3.prototype.writeUInt32BE = function writeUInt32BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 4294967295, 0); + this[offset] = value >>> 24; + this[offset + 1] = value >>> 16; + this[offset + 2] = value >>> 8; + this[offset + 3] = value & 255; + return offset + 4; + }; + function wrtBigUInt64LE(buf, value, offset, min, max) { + checkIntBI(value, min, max, buf, offset, 7); + let lo = Number(value & BigInt(4294967295)); + buf[offset++] = lo; + lo = lo >> 8; + buf[offset++] = lo; + lo = lo >> 8; + buf[offset++] = lo; + lo = lo >> 8; + buf[offset++] = lo; + let hi = Number(value >> BigInt(32) & BigInt(4294967295)); + buf[offset++] = hi; + hi = hi >> 8; + buf[offset++] = hi; + hi = hi >> 8; + buf[offset++] = hi; + hi = hi >> 8; + buf[offset++] = hi; + return offset; + } + function wrtBigUInt64BE(buf, value, offset, min, max) { + checkIntBI(value, min, max, buf, offset, 7); + let lo = Number(value & BigInt(4294967295)); + buf[offset + 7] = lo; + lo = lo >> 8; + buf[offset + 6] = lo; + lo = lo >> 8; + buf[offset + 5] = lo; + lo = lo >> 8; + buf[offset + 4] = lo; + let hi = Number(value >> BigInt(32) & BigInt(4294967295)); + buf[offset + 3] = hi; + hi = hi >> 8; + buf[offset + 2] = hi; + hi = hi >> 8; + buf[offset + 1] = hi; + hi = hi >> 8; + buf[offset] = hi; + return offset + 8; + } + Buffer3.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE(value, offset = 0) { + return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt("0xffffffffffffffff")); + }); + Buffer3.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE(value, offset = 0) { + return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt("0xffffffffffffffff")); + }); + Buffer3.prototype.writeIntLE = function writeIntLE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + const limit = Math.pow(2, 8 * byteLength2 - 1); + checkInt(this, value, offset, byteLength2, limit - 1, -limit); + } + let i = 0; + let mul = 1; + let sub = 0; + this[offset] = value & 255; + while (++i < byteLength2 && (mul *= 256)) { + if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) { + sub = 1; + } + this[offset + i] = (value / mul >> 0) - sub & 255; + } + return offset + byteLength2; + }; + Buffer3.prototype.writeIntBE = function writeIntBE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + const limit = Math.pow(2, 8 * byteLength2 - 1); + checkInt(this, value, offset, byteLength2, limit - 1, -limit); + } + let i = byteLength2 - 1; + let mul = 1; + let sub = 0; + this[offset + i] = value & 255; + while (--i >= 0 && (mul *= 256)) { + if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) { + sub = 1; + } + this[offset + i] = (value / mul >> 0) - sub & 255; + } + return offset + byteLength2; + }; + Buffer3.prototype.writeInt8 = function writeInt8(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 1, 127, -128); + if (value < 0) + value = 255 + value + 1; + this[offset] = value & 255; + return offset + 1; + }; + Buffer3.prototype.writeInt16LE = function writeInt16LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 32767, -32768); + this[offset] = value & 255; + this[offset + 1] = value >>> 8; + return offset + 2; + }; + Buffer3.prototype.writeInt16BE = function writeInt16BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 32767, -32768); + this[offset] = value >>> 8; + this[offset + 1] = value & 255; + return offset + 2; + }; + Buffer3.prototype.writeInt32LE = function writeInt32LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 2147483647, -2147483648); + this[offset] = value & 255; + this[offset + 1] = value >>> 8; + this[offset + 2] = value >>> 16; + this[offset + 3] = value >>> 24; + return offset + 4; + }; + Buffer3.prototype.writeInt32BE = function writeInt32BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 2147483647, -2147483648); + if (value < 0) + value = 4294967295 + value + 1; + this[offset] = value >>> 24; + this[offset + 1] = value >>> 16; + this[offset + 2] = value >>> 8; + this[offset + 3] = value & 255; + return offset + 4; + }; + Buffer3.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE(value, offset = 0) { + return wrtBigUInt64LE(this, value, offset, -BigInt("0x8000000000000000"), BigInt("0x7fffffffffffffff")); + }); + Buffer3.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE(value, offset = 0) { + return wrtBigUInt64BE(this, value, offset, -BigInt("0x8000000000000000"), BigInt("0x7fffffffffffffff")); + }); + function checkIEEE754(buf, value, offset, ext, max, min) { + if (offset + ext > buf.length) + throw new RangeError("Index out of range"); + if (offset < 0) + throw new RangeError("Index out of range"); + } + function writeFloat(buf, value, offset, littleEndian, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + checkIEEE754(buf, value, offset, 4, 34028234663852886e22, -34028234663852886e22); + } + ieee754.write(buf, value, offset, littleEndian, 23, 4); + return offset + 4; + } + Buffer3.prototype.writeFloatLE = function writeFloatLE(value, offset, noAssert) { + return writeFloat(this, value, offset, true, noAssert); + }; + Buffer3.prototype.writeFloatBE = function writeFloatBE(value, offset, noAssert) { + return writeFloat(this, value, offset, false, noAssert); + }; + function writeDouble(buf, value, offset, littleEndian, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + checkIEEE754(buf, value, offset, 8, 17976931348623157e292, -17976931348623157e292); + } + ieee754.write(buf, value, offset, littleEndian, 52, 8); + return offset + 8; + } + Buffer3.prototype.writeDoubleLE = function writeDoubleLE(value, offset, noAssert) { + return writeDouble(this, value, offset, true, noAssert); + }; + Buffer3.prototype.writeDoubleBE = function writeDoubleBE(value, offset, noAssert) { + return writeDouble(this, value, offset, false, noAssert); + }; + Buffer3.prototype.copy = function copy2(target, targetStart, start, end) { + if (!Buffer3.isBuffer(target)) + throw new TypeError("argument should be a Buffer"); + if (!start) + start = 0; + if (!end && end !== 0) + end = this.length; + if (targetStart >= target.length) + targetStart = target.length; + if (!targetStart) + targetStart = 0; + if (end > 0 && end < start) + end = start; + if (end === start) + return 0; + if (target.length === 0 || this.length === 0) + return 0; + if (targetStart < 0) { + throw new RangeError("targetStart out of bounds"); + } + if (start < 0 || start >= this.length) + throw new RangeError("Index out of range"); + if (end < 0) + throw new RangeError("sourceEnd out of bounds"); + if (end > this.length) + end = this.length; + if (target.length - targetStart < end - start) { + end = target.length - targetStart + start; + } + const len = end - start; + if (this === target && typeof Uint8Array.prototype.copyWithin === "function") { + this.copyWithin(targetStart, start, end); + } else { + Uint8Array.prototype.set.call(target, this.subarray(start, end), targetStart); + } + return len; + }; + Buffer3.prototype.fill = function fill(val, start, end, encoding) { + if (typeof val === "string") { + if (typeof start === "string") { + encoding = start; + start = 0; + end = this.length; + } else if (typeof end === "string") { + encoding = end; + end = this.length; + } + if (encoding !== void 0 && typeof encoding !== "string") { + throw new TypeError("encoding must be a string"); + } + if (typeof encoding === "string" && !Buffer3.isEncoding(encoding)) { + throw new TypeError("Unknown encoding: " + encoding); + } + if (val.length === 1) { + const code = val.charCodeAt(0); + if (encoding === "utf8" && code < 128 || encoding === "latin1") { + val = code; + } + } + } else if (typeof val === "number") { + val = val & 255; + } else if (typeof val === "boolean") { + val = Number(val); + } + if (start < 0 || this.length < start || this.length < end) { + throw new RangeError("Out of range index"); + } + if (end <= start) { + return this; + } + start = start >>> 0; + end = end === void 0 ? this.length : end >>> 0; + if (!val) + val = 0; + let i; + if (typeof val === "number") { + for (i = start; i < end; ++i) { + this[i] = val; + } + } else { + const bytes = Buffer3.isBuffer(val) ? val : Buffer3.from(val, encoding); + const len = bytes.length; + if (len === 0) { + throw new TypeError('The value "' + val + '" is invalid for argument "value"'); + } + for (i = 0; i < end - start; ++i) { + this[i + start] = bytes[i % len]; + } + } + return this; + }; + var errors = {}; + function E(sym, getMessage, Base) { + errors[sym] = class NodeError extends Base { + constructor() { + super(); + Object.defineProperty(this, "message", { + value: getMessage.apply(this, arguments), + writable: true, + configurable: true + }); + this.name = `${this.name} [${sym}]`; + this.stack; + delete this.name; + } + get code() { + return sym; + } + set code(value) { + Object.defineProperty(this, "code", { + configurable: true, + enumerable: true, + value, + writable: true + }); + } + toString() { + return `${this.name} [${sym}]: ${this.message}`; + } + }; + } + E("ERR_BUFFER_OUT_OF_BOUNDS", function(name) { + if (name) { + return `${name} is outside of buffer bounds`; + } + return "Attempt to access memory outside buffer bounds"; + }, RangeError); + E("ERR_INVALID_ARG_TYPE", function(name, actual) { + return `The "${name}" argument must be of type number. Received type ${typeof actual}`; + }, TypeError); + E("ERR_OUT_OF_RANGE", function(str, range, input) { + let msg = `The value of "${str}" is out of range.`; + let received = input; + if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) { + received = addNumericalSeparator(String(input)); + } else if (typeof input === "bigint") { + received = String(input); + if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) { + received = addNumericalSeparator(received); + } + received += "n"; + } + msg += ` It must be ${range}. Received ${received}`; + return msg; + }, RangeError); + function addNumericalSeparator(val) { + let res = ""; + let i = val.length; + const start = val[0] === "-" ? 1 : 0; + for (; i >= start + 4; i -= 3) { + res = `_${val.slice(i - 3, i)}${res}`; + } + return `${val.slice(0, i)}${res}`; + } + function checkBounds(buf, offset, byteLength2) { + validateNumber(offset, "offset"); + if (buf[offset] === void 0 || buf[offset + byteLength2] === void 0) { + boundsError(offset, buf.length - (byteLength2 + 1)); + } + } + function checkIntBI(value, min, max, buf, offset, byteLength2) { + if (value > max || value < min) { + const n = typeof min === "bigint" ? "n" : ""; + let range; + if (byteLength2 > 3) { + if (min === 0 || min === BigInt(0)) { + range = `>= 0${n} and < 2${n} ** ${(byteLength2 + 1) * 8}${n}`; + } else { + range = `>= -(2${n} ** ${(byteLength2 + 1) * 8 - 1}${n}) and < 2 ** ${(byteLength2 + 1) * 8 - 1}${n}`; + } + } else { + range = `>= ${min}${n} and <= ${max}${n}`; + } + throw new errors.ERR_OUT_OF_RANGE("value", range, value); + } + checkBounds(buf, offset, byteLength2); + } + function validateNumber(value, name) { + if (typeof value !== "number") { + throw new errors.ERR_INVALID_ARG_TYPE(name, "number", value); + } + } + function boundsError(value, length, type) { + if (Math.floor(value) !== value) { + validateNumber(value, type); + throw new errors.ERR_OUT_OF_RANGE(type || "offset", "an integer", value); + } + if (length < 0) { + throw new errors.ERR_BUFFER_OUT_OF_BOUNDS(); + } + throw new errors.ERR_OUT_OF_RANGE(type || "offset", `>= ${type ? 1 : 0} and <= ${length}`, value); + } + var INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g; + function base64clean(str) { + str = str.split("=")[0]; + str = str.trim().replace(INVALID_BASE64_RE, ""); + if (str.length < 2) + return ""; + while (str.length % 4 !== 0) { + str = str + "="; + } + return str; + } + function utf8ToBytes(string, units) { + units = units || Infinity; + let codePoint; + const length = string.length; + let leadSurrogate = null; + const bytes = []; + for (let i = 0; i < length; ++i) { + codePoint = string.charCodeAt(i); + if (codePoint > 55295 && codePoint < 57344) { + if (!leadSurrogate) { + if (codePoint > 56319) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + continue; + } else if (i + 1 === length) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + continue; + } + leadSurrogate = codePoint; + continue; + } + if (codePoint < 56320) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + leadSurrogate = codePoint; + continue; + } + codePoint = (leadSurrogate - 55296 << 10 | codePoint - 56320) + 65536; + } else if (leadSurrogate) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + } + leadSurrogate = null; + if (codePoint < 128) { + if ((units -= 1) < 0) + break; + bytes.push(codePoint); + } else if (codePoint < 2048) { + if ((units -= 2) < 0) + break; + bytes.push(codePoint >> 6 | 192, codePoint & 63 | 128); + } else if (codePoint < 65536) { + if ((units -= 3) < 0) + break; + bytes.push(codePoint >> 12 | 224, codePoint >> 6 & 63 | 128, codePoint & 63 | 128); + } else if (codePoint < 1114112) { + if ((units -= 4) < 0) + break; + bytes.push(codePoint >> 18 | 240, codePoint >> 12 & 63 | 128, codePoint >> 6 & 63 | 128, codePoint & 63 | 128); + } else { + throw new Error("Invalid code point"); + } + } + return bytes; + } + function asciiToBytes(str) { + const byteArray = []; + for (let i = 0; i < str.length; ++i) { + byteArray.push(str.charCodeAt(i) & 255); + } + return byteArray; + } + function utf16leToBytes(str, units) { + let c, hi, lo; + const byteArray = []; + for (let i = 0; i < str.length; ++i) { + if ((units -= 2) < 0) + break; + c = str.charCodeAt(i); + hi = c >> 8; + lo = c % 256; + byteArray.push(lo); + byteArray.push(hi); + } + return byteArray; + } + function base64ToBytes(str) { + return base64.toByteArray(base64clean(str)); + } + function blitBuffer(src, dst, offset, length) { + let i; + for (i = 0; i < length; ++i) { + if (i + offset >= dst.length || i >= src.length) + break; + dst[i + offset] = src[i]; + } + return i; + } + function isInstance(obj, type) { + return obj instanceof type || obj != null && obj.constructor != null && obj.constructor.name != null && obj.constructor.name === type.name; + } + function numberIsNaN(obj) { + return obj !== obj; + } + var hexSliceLookupTable = function() { + const alphabet = "0123456789abcdef"; + const table = new Array(256); + for (let i = 0; i < 16; ++i) { + const i16 = i * 16; + for (let j = 0; j < 16; ++j) { + table[i16 + j] = alphabet[i] + alphabet[j]; + } + } + return table; + }(); + function defineBigIntMethod(fn) { + return typeof BigInt === "undefined" ? BufferBigIntNotDefined : fn; + } + function BufferBigIntNotDefined() { + throw new Error("BigInt not supported"); + } + } +}); + +// polyfill_buffer.js +var import_obsidian, buffer, Buffer2; +var init_polyfill_buffer = __esm({ + "polyfill_buffer.js"() { + import_obsidian = __toModule(require("obsidian")); + if (import_obsidian.Platform.isMobileApp) { + buffer = require_buffer().Buffer; + } else { + buffer = global.Buffer; + } + Buffer2 = buffer; + } +}); + +// node_modules/async-lock/lib/index.js +var require_lib = __commonJS({ + "node_modules/async-lock/lib/index.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + var AsyncLock2 = function(opts) { + opts = opts || {}; + this.Promise = opts.Promise || Promise; + this.queues = Object.create(null); + this.domainReentrant = opts.domainReentrant || false; + if (this.domainReentrant) { + if (typeof process === "undefined" || typeof process.domain === "undefined") { + throw new Error("Domain-reentrant locks require `process.domain` to exist. Please flip `opts.domainReentrant = false`, use a NodeJS version that still implements Domain, or install a browser polyfill."); + } + this.domains = Object.create(null); + } + this.timeout = opts.timeout || AsyncLock2.DEFAULT_TIMEOUT; + this.maxOccupationTime = opts.maxOccupationTime || AsyncLock2.DEFAULT_MAX_OCCUPATION_TIME; + if (opts.maxPending === Infinity || Number.isInteger(opts.maxPending) && opts.maxPending >= 0) { + this.maxPending = opts.maxPending; + } else { + this.maxPending = AsyncLock2.DEFAULT_MAX_PENDING; + } + }; + AsyncLock2.DEFAULT_TIMEOUT = 0; + AsyncLock2.DEFAULT_MAX_OCCUPATION_TIME = 0; + AsyncLock2.DEFAULT_MAX_PENDING = 1e3; + AsyncLock2.prototype.acquire = function(key2, fn, cb, opts) { + if (Array.isArray(key2)) { + return this._acquireBatch(key2, fn, cb, opts); + } + if (typeof fn !== "function") { + throw new Error("You must pass a function to execute"); + } + var deferredResolve = null; + var deferredReject = null; + var deferred2 = null; + if (typeof cb !== "function") { + opts = cb; + cb = null; + deferred2 = new this.Promise(function(resolve, reject) { + deferredResolve = resolve; + deferredReject = reject; + }); + } + opts = opts || {}; + var resolved = false; + var timer = null; + var occupationTimer = null; + var self3 = this; + var done = function(locked, err, ret) { + if (occupationTimer) { + clearTimeout(occupationTimer); + occupationTimer = null; + } + if (locked) { + if (!!self3.queues[key2] && self3.queues[key2].length === 0) { + delete self3.queues[key2]; + } + if (self3.domainReentrant) { + delete self3.domains[key2]; + } + } + if (!resolved) { + if (!deferred2) { + if (typeof cb === "function") { + cb(err, ret); + } + } else { + if (err) { + deferredReject(err); + } else { + deferredResolve(ret); + } + } + resolved = true; + } + if (locked) { + if (!!self3.queues[key2] && self3.queues[key2].length > 0) { + self3.queues[key2].shift()(); + } + } + }; + var exec = function(locked) { + if (resolved) { + return done(locked); + } + if (timer) { + clearTimeout(timer); + timer = null; + } + if (self3.domainReentrant && locked) { + self3.domains[key2] = process.domain; + } + if (fn.length === 1) { + var called = false; + try { + fn(function(err, ret) { + if (!called) { + called = true; + done(locked, err, ret); + } + }); + } catch (err) { + if (!called) { + called = true; + done(locked, err); + } + } + } else { + self3._promiseTry(function() { + return fn(); + }).then(function(ret) { + done(locked, void 0, ret); + }, function(error) { + done(locked, error); + }); + } + }; + if (self3.domainReentrant && !!process.domain) { + exec = process.domain.bind(exec); + } + if (!self3.queues[key2]) { + self3.queues[key2] = []; + exec(true); + } else if (self3.domainReentrant && !!process.domain && process.domain === self3.domains[key2]) { + exec(false); + } else if (self3.queues[key2].length >= self3.maxPending) { + done(false, new Error("Too many pending tasks in queue " + key2)); + } else { + var taskFn = function() { + exec(true); + }; + if (opts.skipQueue) { + self3.queues[key2].unshift(taskFn); + } else { + self3.queues[key2].push(taskFn); + } + var timeout = opts.timeout || self3.timeout; + if (timeout) { + timer = setTimeout(function() { + timer = null; + done(false, new Error("async-lock timed out in queue " + key2)); + }, timeout); + } + } + var maxOccupationTime = opts.maxOccupationTime || self3.maxOccupationTime; + if (maxOccupationTime) { + occupationTimer = setTimeout(function() { + if (!!self3.queues[key2]) { + done(false, new Error("Maximum occupation time is exceeded in queue " + key2)); + } + }, maxOccupationTime); + } + if (deferred2) { + return deferred2; + } + }; + AsyncLock2.prototype._acquireBatch = function(keys, fn, cb, opts) { + if (typeof cb !== "function") { + opts = cb; + cb = null; + } + var self3 = this; + var getFn = function(key2, fn2) { + return function(cb2) { + self3.acquire(key2, fn2, cb2, opts); + }; + }; + var fnx = keys.reduceRight(function(prev, key2) { + return getFn(key2, prev); + }, fn); + if (typeof cb === "function") { + fnx(cb); + } else { + return new this.Promise(function(resolve, reject) { + if (fnx.length === 1) { + fnx(function(err, ret) { + if (err) { + reject(err); + } else { + resolve(ret); + } + }); + } else { + resolve(fnx()); + } + }); + } + }; + AsyncLock2.prototype.isBusy = function(key2) { + if (!key2) { + return Object.keys(this.queues).length > 0; + } else { + return !!this.queues[key2]; + } + }; + AsyncLock2.prototype._promiseTry = function(fn) { + try { + return this.Promise.resolve(fn()); + } catch (e) { + return this.Promise.reject(e); + } + }; + module2.exports = AsyncLock2; + } +}); + +// node_modules/async-lock/index.js +var require_async_lock = __commonJS({ + "node_modules/async-lock/index.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + module2.exports = require_lib(); + } +}); + +// node_modules/inherits/inherits_browser.js +var require_inherits_browser = __commonJS({ + "node_modules/inherits/inherits_browser.js"(exports, module2) { + init_polyfill_buffer(); + if (typeof Object.create === "function") { + module2.exports = function inherits(ctor, superCtor) { + if (superCtor) { + ctor.super_ = superCtor; + ctor.prototype = Object.create(superCtor.prototype, { + constructor: { + value: ctor, + enumerable: false, + writable: true, + configurable: true + } + }); + } + }; + } else { + module2.exports = function inherits(ctor, superCtor) { + if (superCtor) { + ctor.super_ = superCtor; + var TempCtor = function() { + }; + TempCtor.prototype = superCtor.prototype; + ctor.prototype = new TempCtor(); + ctor.prototype.constructor = ctor; + } + }; + } + } +}); + +// node_modules/safe-buffer/index.js +var require_safe_buffer = __commonJS({ + "node_modules/safe-buffer/index.js"(exports, module2) { + init_polyfill_buffer(); + var buffer2 = require_buffer(); + var Buffer3 = buffer2.Buffer; + function copyProps(src, dst) { + for (var key2 in src) { + dst[key2] = src[key2]; + } + } + if (Buffer3.from && Buffer3.alloc && Buffer3.allocUnsafe && Buffer3.allocUnsafeSlow) { + module2.exports = buffer2; + } else { + copyProps(buffer2, exports); + exports.Buffer = SafeBuffer; + } + function SafeBuffer(arg, encodingOrOffset, length) { + return Buffer3(arg, encodingOrOffset, length); + } + SafeBuffer.prototype = Object.create(Buffer3.prototype); + copyProps(Buffer3, SafeBuffer); + SafeBuffer.from = function(arg, encodingOrOffset, length) { + if (typeof arg === "number") { + throw new TypeError("Argument must not be a number"); + } + return Buffer3(arg, encodingOrOffset, length); + }; + SafeBuffer.alloc = function(size, fill, encoding) { + if (typeof size !== "number") { + throw new TypeError("Argument must be a number"); + } + var buf = Buffer3(size); + if (fill !== void 0) { + if (typeof encoding === "string") { + buf.fill(fill, encoding); + } else { + buf.fill(fill); + } + } else { + buf.fill(0); + } + return buf; + }; + SafeBuffer.allocUnsafe = function(size) { + if (typeof size !== "number") { + throw new TypeError("Argument must be a number"); + } + return Buffer3(size); + }; + SafeBuffer.allocUnsafeSlow = function(size) { + if (typeof size !== "number") { + throw new TypeError("Argument must be a number"); + } + return buffer2.SlowBuffer(size); + }; + } +}); + +// node_modules/sha.js/hash.js +var require_hash = __commonJS({ + "node_modules/sha.js/hash.js"(exports, module2) { + init_polyfill_buffer(); + var Buffer3 = require_safe_buffer().Buffer; + function Hash2(blockSize, finalSize) { + this._block = Buffer3.alloc(blockSize); + this._finalSize = finalSize; + this._blockSize = blockSize; + this._len = 0; + } + Hash2.prototype.update = function(data, enc) { + if (typeof data === "string") { + enc = enc || "utf8"; + data = Buffer3.from(data, enc); + } + var block = this._block; + var blockSize = this._blockSize; + var length = data.length; + var accum = this._len; + for (var offset = 0; offset < length; ) { + var assigned = accum % blockSize; + var remainder = Math.min(length - offset, blockSize - assigned); + for (var i = 0; i < remainder; i++) { + block[assigned + i] = data[offset + i]; + } + accum += remainder; + offset += remainder; + if (accum % blockSize === 0) { + this._update(block); + } + } + this._len += length; + return this; + }; + Hash2.prototype.digest = function(enc) { + var rem = this._len % this._blockSize; + this._block[rem] = 128; + this._block.fill(0, rem + 1); + if (rem >= this._finalSize) { + this._update(this._block); + this._block.fill(0); + } + var bits = this._len * 8; + if (bits <= 4294967295) { + this._block.writeUInt32BE(bits, this._blockSize - 4); + } else { + var lowBits = (bits & 4294967295) >>> 0; + var highBits = (bits - lowBits) / 4294967296; + this._block.writeUInt32BE(highBits, this._blockSize - 8); + this._block.writeUInt32BE(lowBits, this._blockSize - 4); + } + this._update(this._block); + var hash2 = this._hash(); + return enc ? hash2.toString(enc) : hash2; + }; + Hash2.prototype._update = function() { + throw new Error("_update must be implemented by subclass"); + }; + module2.exports = Hash2; + } +}); + +// node_modules/sha.js/sha1.js +var require_sha1 = __commonJS({ + "node_modules/sha.js/sha1.js"(exports, module2) { + init_polyfill_buffer(); + var inherits = require_inherits_browser(); + var Hash2 = require_hash(); + var Buffer3 = require_safe_buffer().Buffer; + var K = [ + 1518500249, + 1859775393, + 2400959708 | 0, + 3395469782 | 0 + ]; + var W = new Array(80); + function Sha1() { + this.init(); + this._w = W; + Hash2.call(this, 64, 56); + } + inherits(Sha1, Hash2); + Sha1.prototype.init = function() { + this._a = 1732584193; + this._b = 4023233417; + this._c = 2562383102; + this._d = 271733878; + this._e = 3285377520; + return this; + }; + function rotl1(num2) { + return num2 << 1 | num2 >>> 31; + } + function rotl5(num2) { + return num2 << 5 | num2 >>> 27; + } + function rotl30(num2) { + return num2 << 30 | num2 >>> 2; + } + function ft(s, b, c, d) { + if (s === 0) + return b & c | ~b & d; + if (s === 2) + return b & c | b & d | c & d; + return b ^ c ^ d; + } + Sha1.prototype._update = function(M) { + var W2 = this._w; + var a = this._a | 0; + var b = this._b | 0; + var c = this._c | 0; + var d = this._d | 0; + var e = this._e | 0; + for (var i = 0; i < 16; ++i) + W2[i] = M.readInt32BE(i * 4); + for (; i < 80; ++i) + W2[i] = rotl1(W2[i - 3] ^ W2[i - 8] ^ W2[i - 14] ^ W2[i - 16]); + for (var j = 0; j < 80; ++j) { + var s = ~~(j / 20); + var t = rotl5(a) + ft(s, b, c, d) + e + W2[j] + K[s] | 0; + e = d; + d = c; + c = rotl30(b); + b = a; + a = t; + } + this._a = a + this._a | 0; + this._b = b + this._b | 0; + this._c = c + this._c | 0; + this._d = d + this._d | 0; + this._e = e + this._e | 0; + }; + Sha1.prototype._hash = function() { + var H = Buffer3.allocUnsafe(20); + H.writeInt32BE(this._a | 0, 0); + H.writeInt32BE(this._b | 0, 4); + H.writeInt32BE(this._c | 0, 8); + H.writeInt32BE(this._d | 0, 12); + H.writeInt32BE(this._e | 0, 16); + return H; + }; + module2.exports = Sha1; + } +}); + +// node_modules/crc-32/crc32.js +var require_crc32 = __commonJS({ + "node_modules/crc-32/crc32.js"(exports) { + init_polyfill_buffer(); + var CRC32; + (function(factory) { + if (typeof DO_NOT_EXPORT_CRC === "undefined") { + if (typeof exports === "object") { + factory(exports); + } else if (typeof define === "function" && define.amd) { + define(function() { + var module3 = {}; + factory(module3); + return module3; + }); + } else { + factory(CRC32 = {}); + } + } else { + factory(CRC32 = {}); + } + })(function(CRC322) { + CRC322.version = "1.2.2"; + function signed_crc_table() { + var c = 0, table = new Array(256); + for (var n = 0; n != 256; ++n) { + c = n; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + table[n] = c; + } + return typeof Int32Array !== "undefined" ? new Int32Array(table) : table; + } + var T0 = signed_crc_table(); + function slice_by_16_tables(T) { + var c = 0, v = 0, n = 0, table = typeof Int32Array !== "undefined" ? new Int32Array(4096) : new Array(4096); + for (n = 0; n != 256; ++n) + table[n] = T[n]; + for (n = 0; n != 256; ++n) { + v = T[n]; + for (c = 256 + n; c < 4096; c += 256) + v = table[c] = v >>> 8 ^ T[v & 255]; + } + var out = []; + for (n = 1; n != 16; ++n) + out[n - 1] = typeof Int32Array !== "undefined" ? table.subarray(n * 256, n * 256 + 256) : table.slice(n * 256, n * 256 + 256); + return out; + } + var TT = slice_by_16_tables(T0); + var T1 = TT[0], T2 = TT[1], T3 = TT[2], T4 = TT[3], T5 = TT[4]; + var T6 = TT[5], T7 = TT[6], T8 = TT[7], T9 = TT[8], Ta = TT[9]; + var Tb = TT[10], Tc = TT[11], Td = TT[12], Te = TT[13], Tf = TT[14]; + function crc32_bstr(bstr, seed) { + var C = seed ^ -1; + for (var i = 0, L = bstr.length; i < L; ) + C = C >>> 8 ^ T0[(C ^ bstr.charCodeAt(i++)) & 255]; + return ~C; + } + function crc32_buf(B, seed) { + var C = seed ^ -1, L = B.length - 15, i = 0; + for (; i < L; ) + C = Tf[B[i++] ^ C & 255] ^ Te[B[i++] ^ C >> 8 & 255] ^ Td[B[i++] ^ C >> 16 & 255] ^ Tc[B[i++] ^ C >>> 24] ^ Tb[B[i++]] ^ Ta[B[i++]] ^ T9[B[i++]] ^ T8[B[i++]] ^ T7[B[i++]] ^ T6[B[i++]] ^ T5[B[i++]] ^ T4[B[i++]] ^ T3[B[i++]] ^ T2[B[i++]] ^ T1[B[i++]] ^ T0[B[i++]]; + L += 15; + while (i < L) + C = C >>> 8 ^ T0[(C ^ B[i++]) & 255]; + return ~C; + } + function crc32_str(str, seed) { + var C = seed ^ -1; + for (var i = 0, L = str.length, c = 0, d = 0; i < L; ) { + c = str.charCodeAt(i++); + if (c < 128) { + C = C >>> 8 ^ T0[(C ^ c) & 255]; + } else if (c < 2048) { + C = C >>> 8 ^ T0[(C ^ (192 | c >> 6 & 31)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c & 63)) & 255]; + } else if (c >= 55296 && c < 57344) { + c = (c & 1023) + 64; + d = str.charCodeAt(i++) & 1023; + C = C >>> 8 ^ T0[(C ^ (240 | c >> 8 & 7)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c >> 2 & 63)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | d >> 6 & 15 | (c & 3) << 4)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | d & 63)) & 255]; + } else { + C = C >>> 8 ^ T0[(C ^ (224 | c >> 12 & 15)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c >> 6 & 63)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c & 63)) & 255]; + } + } + return ~C; + } + CRC322.table = T0; + CRC322.bstr = crc32_bstr; + CRC322.buf = crc32_buf; + CRC322.str = crc32_str; + }); + } +}); + +// node_modules/pako/lib/utils/common.js +var require_common = __commonJS({ + "node_modules/pako/lib/utils/common.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var TYPED_OK = typeof Uint8Array !== "undefined" && typeof Uint16Array !== "undefined" && typeof Int32Array !== "undefined"; + function _has(obj, key2) { + return Object.prototype.hasOwnProperty.call(obj, key2); + } + exports.assign = function(obj) { + var sources = Array.prototype.slice.call(arguments, 1); + while (sources.length) { + var source = sources.shift(); + if (!source) { + continue; + } + if (typeof source !== "object") { + throw new TypeError(source + "must be non-object"); + } + for (var p in source) { + if (_has(source, p)) { + obj[p] = source[p]; + } + } + } + return obj; + }; + exports.shrinkBuf = function(buf, size) { + if (buf.length === size) { + return buf; + } + if (buf.subarray) { + return buf.subarray(0, size); + } + buf.length = size; + return buf; + }; + var fnTyped = { + arraySet: function(dest, src, src_offs, len, dest_offs) { + if (src.subarray && dest.subarray) { + dest.set(src.subarray(src_offs, src_offs + len), dest_offs); + return; + } + for (var i = 0; i < len; i++) { + dest[dest_offs + i] = src[src_offs + i]; + } + }, + flattenChunks: function(chunks) { + var i, l, len, pos, chunk, result; + len = 0; + for (i = 0, l = chunks.length; i < l; i++) { + len += chunks[i].length; + } + result = new Uint8Array(len); + pos = 0; + for (i = 0, l = chunks.length; i < l; i++) { + chunk = chunks[i]; + result.set(chunk, pos); + pos += chunk.length; + } + return result; + } + }; + var fnUntyped = { + arraySet: function(dest, src, src_offs, len, dest_offs) { + for (var i = 0; i < len; i++) { + dest[dest_offs + i] = src[src_offs + i]; + } + }, + flattenChunks: function(chunks) { + return [].concat.apply([], chunks); + } + }; + exports.setTyped = function(on) { + if (on) { + exports.Buf8 = Uint8Array; + exports.Buf16 = Uint16Array; + exports.Buf32 = Int32Array; + exports.assign(exports, fnTyped); + } else { + exports.Buf8 = Array; + exports.Buf16 = Array; + exports.Buf32 = Array; + exports.assign(exports, fnUntyped); + } + }; + exports.setTyped(TYPED_OK); + } +}); + +// node_modules/pako/lib/zlib/trees.js +var require_trees = __commonJS({ + "node_modules/pako/lib/zlib/trees.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var utils = require_common(); + var Z_FIXED = 4; + var Z_BINARY = 0; + var Z_TEXT = 1; + var Z_UNKNOWN = 2; + function zero(buf) { + var len = buf.length; + while (--len >= 0) { + buf[len] = 0; + } + } + var STORED_BLOCK = 0; + var STATIC_TREES = 1; + var DYN_TREES = 2; + var MIN_MATCH = 3; + var MAX_MATCH = 258; + var LENGTH_CODES = 29; + var LITERALS = 256; + var L_CODES = LITERALS + 1 + LENGTH_CODES; + var D_CODES = 30; + var BL_CODES = 19; + var HEAP_SIZE = 2 * L_CODES + 1; + var MAX_BITS = 15; + var Buf_size = 16; + var MAX_BL_BITS = 7; + var END_BLOCK = 256; + var REP_3_6 = 16; + var REPZ_3_10 = 17; + var REPZ_11_138 = 18; + var extra_lbits = [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0]; + var extra_dbits = [0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13]; + var extra_blbits = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7]; + var bl_order = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]; + var DIST_CODE_LEN = 512; + var static_ltree = new Array((L_CODES + 2) * 2); + zero(static_ltree); + var static_dtree = new Array(D_CODES * 2); + zero(static_dtree); + var _dist_code = new Array(DIST_CODE_LEN); + zero(_dist_code); + var _length_code = new Array(MAX_MATCH - MIN_MATCH + 1); + zero(_length_code); + var base_length = new Array(LENGTH_CODES); + zero(base_length); + var base_dist = new Array(D_CODES); + zero(base_dist); + function StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) { + this.static_tree = static_tree; + this.extra_bits = extra_bits; + this.extra_base = extra_base; + this.elems = elems; + this.max_length = max_length; + this.has_stree = static_tree && static_tree.length; + } + var static_l_desc; + var static_d_desc; + var static_bl_desc; + function TreeDesc(dyn_tree, stat_desc) { + this.dyn_tree = dyn_tree; + this.max_code = 0; + this.stat_desc = stat_desc; + } + function d_code(dist) { + return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)]; + } + function put_short(s, w) { + s.pending_buf[s.pending++] = w & 255; + s.pending_buf[s.pending++] = w >>> 8 & 255; + } + function send_bits(s, value, length) { + if (s.bi_valid > Buf_size - length) { + s.bi_buf |= value << s.bi_valid & 65535; + put_short(s, s.bi_buf); + s.bi_buf = value >> Buf_size - s.bi_valid; + s.bi_valid += length - Buf_size; + } else { + s.bi_buf |= value << s.bi_valid & 65535; + s.bi_valid += length; + } + } + function send_code(s, c, tree) { + send_bits(s, tree[c * 2], tree[c * 2 + 1]); + } + function bi_reverse(code, len) { + var res = 0; + do { + res |= code & 1; + code >>>= 1; + res <<= 1; + } while (--len > 0); + return res >>> 1; + } + function bi_flush(s) { + if (s.bi_valid === 16) { + put_short(s, s.bi_buf); + s.bi_buf = 0; + s.bi_valid = 0; + } else if (s.bi_valid >= 8) { + s.pending_buf[s.pending++] = s.bi_buf & 255; + s.bi_buf >>= 8; + s.bi_valid -= 8; + } + } + function gen_bitlen(s, desc) { + var tree = desc.dyn_tree; + var max_code = desc.max_code; + var stree = desc.stat_desc.static_tree; + var has_stree = desc.stat_desc.has_stree; + var extra = desc.stat_desc.extra_bits; + var base = desc.stat_desc.extra_base; + var max_length = desc.stat_desc.max_length; + var h; + var n, m; + var bits; + var xbits; + var f; + var overflow = 0; + for (bits = 0; bits <= MAX_BITS; bits++) { + s.bl_count[bits] = 0; + } + tree[s.heap[s.heap_max] * 2 + 1] = 0; + for (h = s.heap_max + 1; h < HEAP_SIZE; h++) { + n = s.heap[h]; + bits = tree[tree[n * 2 + 1] * 2 + 1] + 1; + if (bits > max_length) { + bits = max_length; + overflow++; + } + tree[n * 2 + 1] = bits; + if (n > max_code) { + continue; + } + s.bl_count[bits]++; + xbits = 0; + if (n >= base) { + xbits = extra[n - base]; + } + f = tree[n * 2]; + s.opt_len += f * (bits + xbits); + if (has_stree) { + s.static_len += f * (stree[n * 2 + 1] + xbits); + } + } + if (overflow === 0) { + return; + } + do { + bits = max_length - 1; + while (s.bl_count[bits] === 0) { + bits--; + } + s.bl_count[bits]--; + s.bl_count[bits + 1] += 2; + s.bl_count[max_length]--; + overflow -= 2; + } while (overflow > 0); + for (bits = max_length; bits !== 0; bits--) { + n = s.bl_count[bits]; + while (n !== 0) { + m = s.heap[--h]; + if (m > max_code) { + continue; + } + if (tree[m * 2 + 1] !== bits) { + s.opt_len += (bits - tree[m * 2 + 1]) * tree[m * 2]; + tree[m * 2 + 1] = bits; + } + n--; + } + } + } + function gen_codes(tree, max_code, bl_count) { + var next_code = new Array(MAX_BITS + 1); + var code = 0; + var bits; + var n; + for (bits = 1; bits <= MAX_BITS; bits++) { + next_code[bits] = code = code + bl_count[bits - 1] << 1; + } + for (n = 0; n <= max_code; n++) { + var len = tree[n * 2 + 1]; + if (len === 0) { + continue; + } + tree[n * 2] = bi_reverse(next_code[len]++, len); + } + } + function tr_static_init() { + var n; + var bits; + var length; + var code; + var dist; + var bl_count = new Array(MAX_BITS + 1); + length = 0; + for (code = 0; code < LENGTH_CODES - 1; code++) { + base_length[code] = length; + for (n = 0; n < 1 << extra_lbits[code]; n++) { + _length_code[length++] = code; + } + } + _length_code[length - 1] = code; + dist = 0; + for (code = 0; code < 16; code++) { + base_dist[code] = dist; + for (n = 0; n < 1 << extra_dbits[code]; n++) { + _dist_code[dist++] = code; + } + } + dist >>= 7; + for (; code < D_CODES; code++) { + base_dist[code] = dist << 7; + for (n = 0; n < 1 << extra_dbits[code] - 7; n++) { + _dist_code[256 + dist++] = code; + } + } + for (bits = 0; bits <= MAX_BITS; bits++) { + bl_count[bits] = 0; + } + n = 0; + while (n <= 143) { + static_ltree[n * 2 + 1] = 8; + n++; + bl_count[8]++; + } + while (n <= 255) { + static_ltree[n * 2 + 1] = 9; + n++; + bl_count[9]++; + } + while (n <= 279) { + static_ltree[n * 2 + 1] = 7; + n++; + bl_count[7]++; + } + while (n <= 287) { + static_ltree[n * 2 + 1] = 8; + n++; + bl_count[8]++; + } + gen_codes(static_ltree, L_CODES + 1, bl_count); + for (n = 0; n < D_CODES; n++) { + static_dtree[n * 2 + 1] = 5; + static_dtree[n * 2] = bi_reverse(n, 5); + } + static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS + 1, L_CODES, MAX_BITS); + static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES, MAX_BITS); + static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES, MAX_BL_BITS); + } + function init_block(s) { + var n; + for (n = 0; n < L_CODES; n++) { + s.dyn_ltree[n * 2] = 0; + } + for (n = 0; n < D_CODES; n++) { + s.dyn_dtree[n * 2] = 0; + } + for (n = 0; n < BL_CODES; n++) { + s.bl_tree[n * 2] = 0; + } + s.dyn_ltree[END_BLOCK * 2] = 1; + s.opt_len = s.static_len = 0; + s.last_lit = s.matches = 0; + } + function bi_windup(s) { + if (s.bi_valid > 8) { + put_short(s, s.bi_buf); + } else if (s.bi_valid > 0) { + s.pending_buf[s.pending++] = s.bi_buf; + } + s.bi_buf = 0; + s.bi_valid = 0; + } + function copy_block(s, buf, len, header) { + bi_windup(s); + if (header) { + put_short(s, len); + put_short(s, ~len); + } + utils.arraySet(s.pending_buf, s.window, buf, len, s.pending); + s.pending += len; + } + function smaller(tree, n, m, depth) { + var _n2 = n * 2; + var _m2 = m * 2; + return tree[_n2] < tree[_m2] || tree[_n2] === tree[_m2] && depth[n] <= depth[m]; + } + function pqdownheap(s, tree, k) { + var v = s.heap[k]; + var j = k << 1; + while (j <= s.heap_len) { + if (j < s.heap_len && smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) { + j++; + } + if (smaller(tree, v, s.heap[j], s.depth)) { + break; + } + s.heap[k] = s.heap[j]; + k = j; + j <<= 1; + } + s.heap[k] = v; + } + function compress_block(s, ltree, dtree) { + var dist; + var lc; + var lx = 0; + var code; + var extra; + if (s.last_lit !== 0) { + do { + dist = s.pending_buf[s.d_buf + lx * 2] << 8 | s.pending_buf[s.d_buf + lx * 2 + 1]; + lc = s.pending_buf[s.l_buf + lx]; + lx++; + if (dist === 0) { + send_code(s, lc, ltree); + } else { + code = _length_code[lc]; + send_code(s, code + LITERALS + 1, ltree); + extra = extra_lbits[code]; + if (extra !== 0) { + lc -= base_length[code]; + send_bits(s, lc, extra); + } + dist--; + code = d_code(dist); + send_code(s, code, dtree); + extra = extra_dbits[code]; + if (extra !== 0) { + dist -= base_dist[code]; + send_bits(s, dist, extra); + } + } + } while (lx < s.last_lit); + } + send_code(s, END_BLOCK, ltree); + } + function build_tree(s, desc) { + var tree = desc.dyn_tree; + var stree = desc.stat_desc.static_tree; + var has_stree = desc.stat_desc.has_stree; + var elems = desc.stat_desc.elems; + var n, m; + var max_code = -1; + var node; + s.heap_len = 0; + s.heap_max = HEAP_SIZE; + for (n = 0; n < elems; n++) { + if (tree[n * 2] !== 0) { + s.heap[++s.heap_len] = max_code = n; + s.depth[n] = 0; + } else { + tree[n * 2 + 1] = 0; + } + } + while (s.heap_len < 2) { + node = s.heap[++s.heap_len] = max_code < 2 ? ++max_code : 0; + tree[node * 2] = 1; + s.depth[node] = 0; + s.opt_len--; + if (has_stree) { + s.static_len -= stree[node * 2 + 1]; + } + } + desc.max_code = max_code; + for (n = s.heap_len >> 1; n >= 1; n--) { + pqdownheap(s, tree, n); + } + node = elems; + do { + n = s.heap[1]; + s.heap[1] = s.heap[s.heap_len--]; + pqdownheap(s, tree, 1); + m = s.heap[1]; + s.heap[--s.heap_max] = n; + s.heap[--s.heap_max] = m; + tree[node * 2] = tree[n * 2] + tree[m * 2]; + s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1; + tree[n * 2 + 1] = tree[m * 2 + 1] = node; + s.heap[1] = node++; + pqdownheap(s, tree, 1); + } while (s.heap_len >= 2); + s.heap[--s.heap_max] = s.heap[1]; + gen_bitlen(s, desc); + gen_codes(tree, max_code, s.bl_count); + } + function scan_tree(s, tree, max_code) { + var n; + var prevlen = -1; + var curlen; + var nextlen = tree[0 * 2 + 1]; + var count = 0; + var max_count = 7; + var min_count = 4; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } + tree[(max_code + 1) * 2 + 1] = 65535; + for (n = 0; n <= max_code; n++) { + curlen = nextlen; + nextlen = tree[(n + 1) * 2 + 1]; + if (++count < max_count && curlen === nextlen) { + continue; + } else if (count < min_count) { + s.bl_tree[curlen * 2] += count; + } else if (curlen !== 0) { + if (curlen !== prevlen) { + s.bl_tree[curlen * 2]++; + } + s.bl_tree[REP_3_6 * 2]++; + } else if (count <= 10) { + s.bl_tree[REPZ_3_10 * 2]++; + } else { + s.bl_tree[REPZ_11_138 * 2]++; + } + count = 0; + prevlen = curlen; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } else if (curlen === nextlen) { + max_count = 6; + min_count = 3; + } else { + max_count = 7; + min_count = 4; + } + } + } + function send_tree(s, tree, max_code) { + var n; + var prevlen = -1; + var curlen; + var nextlen = tree[0 * 2 + 1]; + var count = 0; + var max_count = 7; + var min_count = 4; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } + for (n = 0; n <= max_code; n++) { + curlen = nextlen; + nextlen = tree[(n + 1) * 2 + 1]; + if (++count < max_count && curlen === nextlen) { + continue; + } else if (count < min_count) { + do { + send_code(s, curlen, s.bl_tree); + } while (--count !== 0); + } else if (curlen !== 0) { + if (curlen !== prevlen) { + send_code(s, curlen, s.bl_tree); + count--; + } + send_code(s, REP_3_6, s.bl_tree); + send_bits(s, count - 3, 2); + } else if (count <= 10) { + send_code(s, REPZ_3_10, s.bl_tree); + send_bits(s, count - 3, 3); + } else { + send_code(s, REPZ_11_138, s.bl_tree); + send_bits(s, count - 11, 7); + } + count = 0; + prevlen = curlen; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } else if (curlen === nextlen) { + max_count = 6; + min_count = 3; + } else { + max_count = 7; + min_count = 4; + } + } + } + function build_bl_tree(s) { + var max_blindex; + scan_tree(s, s.dyn_ltree, s.l_desc.max_code); + scan_tree(s, s.dyn_dtree, s.d_desc.max_code); + build_tree(s, s.bl_desc); + for (max_blindex = BL_CODES - 1; max_blindex >= 3; max_blindex--) { + if (s.bl_tree[bl_order[max_blindex] * 2 + 1] !== 0) { + break; + } + } + s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4; + return max_blindex; + } + function send_all_trees(s, lcodes, dcodes, blcodes) { + var rank; + send_bits(s, lcodes - 257, 5); + send_bits(s, dcodes - 1, 5); + send_bits(s, blcodes - 4, 4); + for (rank = 0; rank < blcodes; rank++) { + send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1], 3); + } + send_tree(s, s.dyn_ltree, lcodes - 1); + send_tree(s, s.dyn_dtree, dcodes - 1); + } + function detect_data_type(s) { + var black_mask = 4093624447; + var n; + for (n = 0; n <= 31; n++, black_mask >>>= 1) { + if (black_mask & 1 && s.dyn_ltree[n * 2] !== 0) { + return Z_BINARY; + } + } + if (s.dyn_ltree[9 * 2] !== 0 || s.dyn_ltree[10 * 2] !== 0 || s.dyn_ltree[13 * 2] !== 0) { + return Z_TEXT; + } + for (n = 32; n < LITERALS; n++) { + if (s.dyn_ltree[n * 2] !== 0) { + return Z_TEXT; + } + } + return Z_BINARY; + } + var static_init_done = false; + function _tr_init(s) { + if (!static_init_done) { + tr_static_init(); + static_init_done = true; + } + s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc); + s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc); + s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc); + s.bi_buf = 0; + s.bi_valid = 0; + init_block(s); + } + function _tr_stored_block(s, buf, stored_len, last2) { + send_bits(s, (STORED_BLOCK << 1) + (last2 ? 1 : 0), 3); + copy_block(s, buf, stored_len, true); + } + function _tr_align(s) { + send_bits(s, STATIC_TREES << 1, 3); + send_code(s, END_BLOCK, static_ltree); + bi_flush(s); + } + function _tr_flush_block(s, buf, stored_len, last2) { + var opt_lenb, static_lenb; + var max_blindex = 0; + if (s.level > 0) { + if (s.strm.data_type === Z_UNKNOWN) { + s.strm.data_type = detect_data_type(s); + } + build_tree(s, s.l_desc); + build_tree(s, s.d_desc); + max_blindex = build_bl_tree(s); + opt_lenb = s.opt_len + 3 + 7 >>> 3; + static_lenb = s.static_len + 3 + 7 >>> 3; + if (static_lenb <= opt_lenb) { + opt_lenb = static_lenb; + } + } else { + opt_lenb = static_lenb = stored_len + 5; + } + if (stored_len + 4 <= opt_lenb && buf !== -1) { + _tr_stored_block(s, buf, stored_len, last2); + } else if (s.strategy === Z_FIXED || static_lenb === opt_lenb) { + send_bits(s, (STATIC_TREES << 1) + (last2 ? 1 : 0), 3); + compress_block(s, static_ltree, static_dtree); + } else { + send_bits(s, (DYN_TREES << 1) + (last2 ? 1 : 0), 3); + send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1); + compress_block(s, s.dyn_ltree, s.dyn_dtree); + } + init_block(s); + if (last2) { + bi_windup(s); + } + } + function _tr_tally(s, dist, lc) { + s.pending_buf[s.d_buf + s.last_lit * 2] = dist >>> 8 & 255; + s.pending_buf[s.d_buf + s.last_lit * 2 + 1] = dist & 255; + s.pending_buf[s.l_buf + s.last_lit] = lc & 255; + s.last_lit++; + if (dist === 0) { + s.dyn_ltree[lc * 2]++; + } else { + s.matches++; + dist--; + s.dyn_ltree[(_length_code[lc] + LITERALS + 1) * 2]++; + s.dyn_dtree[d_code(dist) * 2]++; + } + return s.last_lit === s.lit_bufsize - 1; + } + exports._tr_init = _tr_init; + exports._tr_stored_block = _tr_stored_block; + exports._tr_flush_block = _tr_flush_block; + exports._tr_tally = _tr_tally; + exports._tr_align = _tr_align; + } +}); + +// node_modules/pako/lib/zlib/adler32.js +var require_adler32 = __commonJS({ + "node_modules/pako/lib/zlib/adler32.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + function adler32(adler, buf, len, pos) { + var s1 = adler & 65535 | 0, s2 = adler >>> 16 & 65535 | 0, n = 0; + while (len !== 0) { + n = len > 2e3 ? 2e3 : len; + len -= n; + do { + s1 = s1 + buf[pos++] | 0; + s2 = s2 + s1 | 0; + } while (--n); + s1 %= 65521; + s2 %= 65521; + } + return s1 | s2 << 16 | 0; + } + module2.exports = adler32; + } +}); + +// node_modules/pako/lib/zlib/crc32.js +var require_crc322 = __commonJS({ + "node_modules/pako/lib/zlib/crc32.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + function makeTable() { + var c, table = []; + for (var n = 0; n < 256; n++) { + c = n; + for (var k = 0; k < 8; k++) { + c = c & 1 ? 3988292384 ^ c >>> 1 : c >>> 1; + } + table[n] = c; + } + return table; + } + var crcTable = makeTable(); + function crc322(crc, buf, len, pos) { + var t = crcTable, end = pos + len; + crc ^= -1; + for (var i = pos; i < end; i++) { + crc = crc >>> 8 ^ t[(crc ^ buf[i]) & 255]; + } + return crc ^ -1; + } + module2.exports = crc322; + } +}); + +// node_modules/pako/lib/zlib/messages.js +var require_messages = __commonJS({ + "node_modules/pako/lib/zlib/messages.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + module2.exports = { + 2: "need dictionary", + 1: "stream end", + 0: "", + "-1": "file error", + "-2": "stream error", + "-3": "data error", + "-4": "insufficient memory", + "-5": "buffer error", + "-6": "incompatible version" + }; + } +}); + +// node_modules/pako/lib/zlib/deflate.js +var require_deflate = __commonJS({ + "node_modules/pako/lib/zlib/deflate.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var utils = require_common(); + var trees = require_trees(); + var adler32 = require_adler32(); + var crc322 = require_crc322(); + var msg = require_messages(); + var Z_NO_FLUSH = 0; + var Z_PARTIAL_FLUSH = 1; + var Z_FULL_FLUSH = 3; + var Z_FINISH = 4; + var Z_BLOCK = 5; + var Z_OK = 0; + var Z_STREAM_END = 1; + var Z_STREAM_ERROR = -2; + var Z_DATA_ERROR = -3; + var Z_BUF_ERROR = -5; + var Z_DEFAULT_COMPRESSION = -1; + var Z_FILTERED = 1; + var Z_HUFFMAN_ONLY = 2; + var Z_RLE = 3; + var Z_FIXED = 4; + var Z_DEFAULT_STRATEGY = 0; + var Z_UNKNOWN = 2; + var Z_DEFLATED = 8; + var MAX_MEM_LEVEL = 9; + var MAX_WBITS = 15; + var DEF_MEM_LEVEL = 8; + var LENGTH_CODES = 29; + var LITERALS = 256; + var L_CODES = LITERALS + 1 + LENGTH_CODES; + var D_CODES = 30; + var BL_CODES = 19; + var HEAP_SIZE = 2 * L_CODES + 1; + var MAX_BITS = 15; + var MIN_MATCH = 3; + var MAX_MATCH = 258; + var MIN_LOOKAHEAD = MAX_MATCH + MIN_MATCH + 1; + var PRESET_DICT = 32; + var INIT_STATE = 42; + var EXTRA_STATE = 69; + var NAME_STATE = 73; + var COMMENT_STATE = 91; + var HCRC_STATE = 103; + var BUSY_STATE = 113; + var FINISH_STATE = 666; + var BS_NEED_MORE = 1; + var BS_BLOCK_DONE = 2; + var BS_FINISH_STARTED = 3; + var BS_FINISH_DONE = 4; + var OS_CODE = 3; + function err(strm, errorCode) { + strm.msg = msg[errorCode]; + return errorCode; + } + function rank(f) { + return (f << 1) - (f > 4 ? 9 : 0); + } + function zero(buf) { + var len = buf.length; + while (--len >= 0) { + buf[len] = 0; + } + } + function flush_pending(strm) { + var s = strm.state; + var len = s.pending; + if (len > strm.avail_out) { + len = strm.avail_out; + } + if (len === 0) { + return; + } + utils.arraySet(strm.output, s.pending_buf, s.pending_out, len, strm.next_out); + strm.next_out += len; + s.pending_out += len; + strm.total_out += len; + strm.avail_out -= len; + s.pending -= len; + if (s.pending === 0) { + s.pending_out = 0; + } + } + function flush_block_only(s, last2) { + trees._tr_flush_block(s, s.block_start >= 0 ? s.block_start : -1, s.strstart - s.block_start, last2); + s.block_start = s.strstart; + flush_pending(s.strm); + } + function put_byte(s, b) { + s.pending_buf[s.pending++] = b; + } + function putShortMSB(s, b) { + s.pending_buf[s.pending++] = b >>> 8 & 255; + s.pending_buf[s.pending++] = b & 255; + } + function read_buf(strm, buf, start, size) { + var len = strm.avail_in; + if (len > size) { + len = size; + } + if (len === 0) { + return 0; + } + strm.avail_in -= len; + utils.arraySet(buf, strm.input, strm.next_in, len, start); + if (strm.state.wrap === 1) { + strm.adler = adler32(strm.adler, buf, len, start); + } else if (strm.state.wrap === 2) { + strm.adler = crc322(strm.adler, buf, len, start); + } + strm.next_in += len; + strm.total_in += len; + return len; + } + function longest_match(s, cur_match) { + var chain_length = s.max_chain_length; + var scan = s.strstart; + var match; + var len; + var best_len = s.prev_length; + var nice_match = s.nice_match; + var limit = s.strstart > s.w_size - MIN_LOOKAHEAD ? s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0; + var _win = s.window; + var wmask = s.w_mask; + var prev = s.prev; + var strend = s.strstart + MAX_MATCH; + var scan_end1 = _win[scan + best_len - 1]; + var scan_end = _win[scan + best_len]; + if (s.prev_length >= s.good_match) { + chain_length >>= 2; + } + if (nice_match > s.lookahead) { + nice_match = s.lookahead; + } + do { + match = cur_match; + if (_win[match + best_len] !== scan_end || _win[match + best_len - 1] !== scan_end1 || _win[match] !== _win[scan] || _win[++match] !== _win[scan + 1]) { + continue; + } + scan += 2; + match++; + do { + } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && scan < strend); + len = MAX_MATCH - (strend - scan); + scan = strend - MAX_MATCH; + if (len > best_len) { + s.match_start = cur_match; + best_len = len; + if (len >= nice_match) { + break; + } + scan_end1 = _win[scan + best_len - 1]; + scan_end = _win[scan + best_len]; + } + } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0); + if (best_len <= s.lookahead) { + return best_len; + } + return s.lookahead; + } + function fill_window(s) { + var _w_size = s.w_size; + var p, n, m, more, str; + do { + more = s.window_size - s.lookahead - s.strstart; + if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) { + utils.arraySet(s.window, s.window, _w_size, _w_size, 0); + s.match_start -= _w_size; + s.strstart -= _w_size; + s.block_start -= _w_size; + n = s.hash_size; + p = n; + do { + m = s.head[--p]; + s.head[p] = m >= _w_size ? m - _w_size : 0; + } while (--n); + n = _w_size; + p = n; + do { + m = s.prev[--p]; + s.prev[p] = m >= _w_size ? m - _w_size : 0; + } while (--n); + more += _w_size; + } + if (s.strm.avail_in === 0) { + break; + } + n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more); + s.lookahead += n; + if (s.lookahead + s.insert >= MIN_MATCH) { + str = s.strstart - s.insert; + s.ins_h = s.window[str]; + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[str + 1]) & s.hash_mask; + while (s.insert) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask; + s.prev[str & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = str; + str++; + s.insert--; + if (s.lookahead + s.insert < MIN_MATCH) { + break; + } + } + } + } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0); + } + function deflate_stored(s, flush2) { + var max_block_size = 65535; + if (max_block_size > s.pending_buf_size - 5) { + max_block_size = s.pending_buf_size - 5; + } + for (; ; ) { + if (s.lookahead <= 1) { + fill_window(s); + if (s.lookahead === 0 && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + s.strstart += s.lookahead; + s.lookahead = 0; + var max_start = s.block_start + max_block_size; + if (s.strstart === 0 || s.strstart >= max_start) { + s.lookahead = s.strstart - max_start; + s.strstart = max_start; + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + if (s.strstart - s.block_start >= s.w_size - MIN_LOOKAHEAD) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = 0; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.strstart > s.block_start) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_NEED_MORE; + } + function deflate_fast(s, flush2) { + var hash_head; + var bflush; + for (; ; ) { + if (s.lookahead < MIN_LOOKAHEAD) { + fill_window(s); + if (s.lookahead < MIN_LOOKAHEAD && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + hash_head = 0; + if (s.lookahead >= MIN_MATCH) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } + if (hash_head !== 0 && s.strstart - hash_head <= s.w_size - MIN_LOOKAHEAD) { + s.match_length = longest_match(s, hash_head); + } + if (s.match_length >= MIN_MATCH) { + bflush = trees._tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH); + s.lookahead -= s.match_length; + if (s.match_length <= s.max_lazy_match && s.lookahead >= MIN_MATCH) { + s.match_length--; + do { + s.strstart++; + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } while (--s.match_length !== 0); + s.strstart++; + } else { + s.strstart += s.match_length; + s.match_length = 0; + s.ins_h = s.window[s.strstart]; + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + 1]) & s.hash_mask; + } + } else { + bflush = trees._tr_tally(s, 0, s.window[s.strstart]); + s.lookahead--; + s.strstart++; + } + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function deflate_slow(s, flush2) { + var hash_head; + var bflush; + var max_insert; + for (; ; ) { + if (s.lookahead < MIN_LOOKAHEAD) { + fill_window(s); + if (s.lookahead < MIN_LOOKAHEAD && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + hash_head = 0; + if (s.lookahead >= MIN_MATCH) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } + s.prev_length = s.match_length; + s.prev_match = s.match_start; + s.match_length = MIN_MATCH - 1; + if (hash_head !== 0 && s.prev_length < s.max_lazy_match && s.strstart - hash_head <= s.w_size - MIN_LOOKAHEAD) { + s.match_length = longest_match(s, hash_head); + if (s.match_length <= 5 && (s.strategy === Z_FILTERED || s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096)) { + s.match_length = MIN_MATCH - 1; + } + } + if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) { + max_insert = s.strstart + s.lookahead - MIN_MATCH; + bflush = trees._tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH); + s.lookahead -= s.prev_length - 1; + s.prev_length -= 2; + do { + if (++s.strstart <= max_insert) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } + } while (--s.prev_length !== 0); + s.match_available = 0; + s.match_length = MIN_MATCH - 1; + s.strstart++; + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } else if (s.match_available) { + bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]); + if (bflush) { + flush_block_only(s, false); + } + s.strstart++; + s.lookahead--; + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } else { + s.match_available = 1; + s.strstart++; + s.lookahead--; + } + } + if (s.match_available) { + bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]); + s.match_available = 0; + } + s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function deflate_rle(s, flush2) { + var bflush; + var prev; + var scan, strend; + var _win = s.window; + for (; ; ) { + if (s.lookahead <= MAX_MATCH) { + fill_window(s); + if (s.lookahead <= MAX_MATCH && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + s.match_length = 0; + if (s.lookahead >= MIN_MATCH && s.strstart > 0) { + scan = s.strstart - 1; + prev = _win[scan]; + if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) { + strend = s.strstart + MAX_MATCH; + do { + } while (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && scan < strend); + s.match_length = MAX_MATCH - (strend - scan); + if (s.match_length > s.lookahead) { + s.match_length = s.lookahead; + } + } + } + if (s.match_length >= MIN_MATCH) { + bflush = trees._tr_tally(s, 1, s.match_length - MIN_MATCH); + s.lookahead -= s.match_length; + s.strstart += s.match_length; + s.match_length = 0; + } else { + bflush = trees._tr_tally(s, 0, s.window[s.strstart]); + s.lookahead--; + s.strstart++; + } + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = 0; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function deflate_huff(s, flush2) { + var bflush; + for (; ; ) { + if (s.lookahead === 0) { + fill_window(s); + if (s.lookahead === 0) { + if (flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + break; + } + } + s.match_length = 0; + bflush = trees._tr_tally(s, 0, s.window[s.strstart]); + s.lookahead--; + s.strstart++; + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = 0; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function Config(good_length, max_lazy, nice_length, max_chain, func) { + this.good_length = good_length; + this.max_lazy = max_lazy; + this.nice_length = nice_length; + this.max_chain = max_chain; + this.func = func; + } + var configuration_table; + configuration_table = [ + new Config(0, 0, 0, 0, deflate_stored), + new Config(4, 4, 8, 4, deflate_fast), + new Config(4, 5, 16, 8, deflate_fast), + new Config(4, 6, 32, 32, deflate_fast), + new Config(4, 4, 16, 16, deflate_slow), + new Config(8, 16, 32, 32, deflate_slow), + new Config(8, 16, 128, 128, deflate_slow), + new Config(8, 32, 128, 256, deflate_slow), + new Config(32, 128, 258, 1024, deflate_slow), + new Config(32, 258, 258, 4096, deflate_slow) + ]; + function lm_init(s) { + s.window_size = 2 * s.w_size; + zero(s.head); + s.max_lazy_match = configuration_table[s.level].max_lazy; + s.good_match = configuration_table[s.level].good_length; + s.nice_match = configuration_table[s.level].nice_length; + s.max_chain_length = configuration_table[s.level].max_chain; + s.strstart = 0; + s.block_start = 0; + s.lookahead = 0; + s.insert = 0; + s.match_length = s.prev_length = MIN_MATCH - 1; + s.match_available = 0; + s.ins_h = 0; + } + function DeflateState() { + this.strm = null; + this.status = 0; + this.pending_buf = null; + this.pending_buf_size = 0; + this.pending_out = 0; + this.pending = 0; + this.wrap = 0; + this.gzhead = null; + this.gzindex = 0; + this.method = Z_DEFLATED; + this.last_flush = -1; + this.w_size = 0; + this.w_bits = 0; + this.w_mask = 0; + this.window = null; + this.window_size = 0; + this.prev = null; + this.head = null; + this.ins_h = 0; + this.hash_size = 0; + this.hash_bits = 0; + this.hash_mask = 0; + this.hash_shift = 0; + this.block_start = 0; + this.match_length = 0; + this.prev_match = 0; + this.match_available = 0; + this.strstart = 0; + this.match_start = 0; + this.lookahead = 0; + this.prev_length = 0; + this.max_chain_length = 0; + this.max_lazy_match = 0; + this.level = 0; + this.strategy = 0; + this.good_match = 0; + this.nice_match = 0; + this.dyn_ltree = new utils.Buf16(HEAP_SIZE * 2); + this.dyn_dtree = new utils.Buf16((2 * D_CODES + 1) * 2); + this.bl_tree = new utils.Buf16((2 * BL_CODES + 1) * 2); + zero(this.dyn_ltree); + zero(this.dyn_dtree); + zero(this.bl_tree); + this.l_desc = null; + this.d_desc = null; + this.bl_desc = null; + this.bl_count = new utils.Buf16(MAX_BITS + 1); + this.heap = new utils.Buf16(2 * L_CODES + 1); + zero(this.heap); + this.heap_len = 0; + this.heap_max = 0; + this.depth = new utils.Buf16(2 * L_CODES + 1); + zero(this.depth); + this.l_buf = 0; + this.lit_bufsize = 0; + this.last_lit = 0; + this.d_buf = 0; + this.opt_len = 0; + this.static_len = 0; + this.matches = 0; + this.insert = 0; + this.bi_buf = 0; + this.bi_valid = 0; + } + function deflateResetKeep(strm) { + var s; + if (!strm || !strm.state) { + return err(strm, Z_STREAM_ERROR); + } + strm.total_in = strm.total_out = 0; + strm.data_type = Z_UNKNOWN; + s = strm.state; + s.pending = 0; + s.pending_out = 0; + if (s.wrap < 0) { + s.wrap = -s.wrap; + } + s.status = s.wrap ? INIT_STATE : BUSY_STATE; + strm.adler = s.wrap === 2 ? 0 : 1; + s.last_flush = Z_NO_FLUSH; + trees._tr_init(s); + return Z_OK; + } + function deflateReset(strm) { + var ret = deflateResetKeep(strm); + if (ret === Z_OK) { + lm_init(strm.state); + } + return ret; + } + function deflateSetHeader(strm, head) { + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + if (strm.state.wrap !== 2) { + return Z_STREAM_ERROR; + } + strm.state.gzhead = head; + return Z_OK; + } + function deflateInit2(strm, level, method, windowBits, memLevel, strategy) { + if (!strm) { + return Z_STREAM_ERROR; + } + var wrap = 1; + if (level === Z_DEFAULT_COMPRESSION) { + level = 6; + } + if (windowBits < 0) { + wrap = 0; + windowBits = -windowBits; + } else if (windowBits > 15) { + wrap = 2; + windowBits -= 16; + } + if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED || windowBits < 8 || windowBits > 15 || level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED) { + return err(strm, Z_STREAM_ERROR); + } + if (windowBits === 8) { + windowBits = 9; + } + var s = new DeflateState(); + strm.state = s; + s.strm = strm; + s.wrap = wrap; + s.gzhead = null; + s.w_bits = windowBits; + s.w_size = 1 << s.w_bits; + s.w_mask = s.w_size - 1; + s.hash_bits = memLevel + 7; + s.hash_size = 1 << s.hash_bits; + s.hash_mask = s.hash_size - 1; + s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH); + s.window = new utils.Buf8(s.w_size * 2); + s.head = new utils.Buf16(s.hash_size); + s.prev = new utils.Buf16(s.w_size); + s.lit_bufsize = 1 << memLevel + 6; + s.pending_buf_size = s.lit_bufsize * 4; + s.pending_buf = new utils.Buf8(s.pending_buf_size); + s.d_buf = 1 * s.lit_bufsize; + s.l_buf = (1 + 2) * s.lit_bufsize; + s.level = level; + s.strategy = strategy; + s.method = method; + return deflateReset(strm); + } + function deflateInit(strm, level) { + return deflateInit2(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY); + } + function deflate2(strm, flush2) { + var old_flush, s; + var beg, val; + if (!strm || !strm.state || flush2 > Z_BLOCK || flush2 < 0) { + return strm ? err(strm, Z_STREAM_ERROR) : Z_STREAM_ERROR; + } + s = strm.state; + if (!strm.output || !strm.input && strm.avail_in !== 0 || s.status === FINISH_STATE && flush2 !== Z_FINISH) { + return err(strm, strm.avail_out === 0 ? Z_BUF_ERROR : Z_STREAM_ERROR); + } + s.strm = strm; + old_flush = s.last_flush; + s.last_flush = flush2; + if (s.status === INIT_STATE) { + if (s.wrap === 2) { + strm.adler = 0; + put_byte(s, 31); + put_byte(s, 139); + put_byte(s, 8); + if (!s.gzhead) { + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, s.level === 9 ? 2 : s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ? 4 : 0); + put_byte(s, OS_CODE); + s.status = BUSY_STATE; + } else { + put_byte(s, (s.gzhead.text ? 1 : 0) + (s.gzhead.hcrc ? 2 : 0) + (!s.gzhead.extra ? 0 : 4) + (!s.gzhead.name ? 0 : 8) + (!s.gzhead.comment ? 0 : 16)); + put_byte(s, s.gzhead.time & 255); + put_byte(s, s.gzhead.time >> 8 & 255); + put_byte(s, s.gzhead.time >> 16 & 255); + put_byte(s, s.gzhead.time >> 24 & 255); + put_byte(s, s.level === 9 ? 2 : s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ? 4 : 0); + put_byte(s, s.gzhead.os & 255); + if (s.gzhead.extra && s.gzhead.extra.length) { + put_byte(s, s.gzhead.extra.length & 255); + put_byte(s, s.gzhead.extra.length >> 8 & 255); + } + if (s.gzhead.hcrc) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending, 0); + } + s.gzindex = 0; + s.status = EXTRA_STATE; + } + } else { + var header = Z_DEFLATED + (s.w_bits - 8 << 4) << 8; + var level_flags = -1; + if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) { + level_flags = 0; + } else if (s.level < 6) { + level_flags = 1; + } else if (s.level === 6) { + level_flags = 2; + } else { + level_flags = 3; + } + header |= level_flags << 6; + if (s.strstart !== 0) { + header |= PRESET_DICT; + } + header += 31 - header % 31; + s.status = BUSY_STATE; + putShortMSB(s, header); + if (s.strstart !== 0) { + putShortMSB(s, strm.adler >>> 16); + putShortMSB(s, strm.adler & 65535); + } + strm.adler = 1; + } + } + if (s.status === EXTRA_STATE) { + if (s.gzhead.extra) { + beg = s.pending; + while (s.gzindex < (s.gzhead.extra.length & 65535)) { + if (s.pending === s.pending_buf_size) { + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + flush_pending(strm); + beg = s.pending; + if (s.pending === s.pending_buf_size) { + break; + } + } + put_byte(s, s.gzhead.extra[s.gzindex] & 255); + s.gzindex++; + } + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + if (s.gzindex === s.gzhead.extra.length) { + s.gzindex = 0; + s.status = NAME_STATE; + } + } else { + s.status = NAME_STATE; + } + } + if (s.status === NAME_STATE) { + if (s.gzhead.name) { + beg = s.pending; + do { + if (s.pending === s.pending_buf_size) { + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + flush_pending(strm); + beg = s.pending; + if (s.pending === s.pending_buf_size) { + val = 1; + break; + } + } + if (s.gzindex < s.gzhead.name.length) { + val = s.gzhead.name.charCodeAt(s.gzindex++) & 255; + } else { + val = 0; + } + put_byte(s, val); + } while (val !== 0); + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + if (val === 0) { + s.gzindex = 0; + s.status = COMMENT_STATE; + } + } else { + s.status = COMMENT_STATE; + } + } + if (s.status === COMMENT_STATE) { + if (s.gzhead.comment) { + beg = s.pending; + do { + if (s.pending === s.pending_buf_size) { + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + flush_pending(strm); + beg = s.pending; + if (s.pending === s.pending_buf_size) { + val = 1; + break; + } + } + if (s.gzindex < s.gzhead.comment.length) { + val = s.gzhead.comment.charCodeAt(s.gzindex++) & 255; + } else { + val = 0; + } + put_byte(s, val); + } while (val !== 0); + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + if (val === 0) { + s.status = HCRC_STATE; + } + } else { + s.status = HCRC_STATE; + } + } + if (s.status === HCRC_STATE) { + if (s.gzhead.hcrc) { + if (s.pending + 2 > s.pending_buf_size) { + flush_pending(strm); + } + if (s.pending + 2 <= s.pending_buf_size) { + put_byte(s, strm.adler & 255); + put_byte(s, strm.adler >> 8 & 255); + strm.adler = 0; + s.status = BUSY_STATE; + } + } else { + s.status = BUSY_STATE; + } + } + if (s.pending !== 0) { + flush_pending(strm); + if (strm.avail_out === 0) { + s.last_flush = -1; + return Z_OK; + } + } else if (strm.avail_in === 0 && rank(flush2) <= rank(old_flush) && flush2 !== Z_FINISH) { + return err(strm, Z_BUF_ERROR); + } + if (s.status === FINISH_STATE && strm.avail_in !== 0) { + return err(strm, Z_BUF_ERROR); + } + if (strm.avail_in !== 0 || s.lookahead !== 0 || flush2 !== Z_NO_FLUSH && s.status !== FINISH_STATE) { + var bstate = s.strategy === Z_HUFFMAN_ONLY ? deflate_huff(s, flush2) : s.strategy === Z_RLE ? deflate_rle(s, flush2) : configuration_table[s.level].func(s, flush2); + if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) { + s.status = FINISH_STATE; + } + if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) { + if (strm.avail_out === 0) { + s.last_flush = -1; + } + return Z_OK; + } + if (bstate === BS_BLOCK_DONE) { + if (flush2 === Z_PARTIAL_FLUSH) { + trees._tr_align(s); + } else if (flush2 !== Z_BLOCK) { + trees._tr_stored_block(s, 0, 0, false); + if (flush2 === Z_FULL_FLUSH) { + zero(s.head); + if (s.lookahead === 0) { + s.strstart = 0; + s.block_start = 0; + s.insert = 0; + } + } + } + flush_pending(strm); + if (strm.avail_out === 0) { + s.last_flush = -1; + return Z_OK; + } + } + } + if (flush2 !== Z_FINISH) { + return Z_OK; + } + if (s.wrap <= 0) { + return Z_STREAM_END; + } + if (s.wrap === 2) { + put_byte(s, strm.adler & 255); + put_byte(s, strm.adler >> 8 & 255); + put_byte(s, strm.adler >> 16 & 255); + put_byte(s, strm.adler >> 24 & 255); + put_byte(s, strm.total_in & 255); + put_byte(s, strm.total_in >> 8 & 255); + put_byte(s, strm.total_in >> 16 & 255); + put_byte(s, strm.total_in >> 24 & 255); + } else { + putShortMSB(s, strm.adler >>> 16); + putShortMSB(s, strm.adler & 65535); + } + flush_pending(strm); + if (s.wrap > 0) { + s.wrap = -s.wrap; + } + return s.pending !== 0 ? Z_OK : Z_STREAM_END; + } + function deflateEnd(strm) { + var status2; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + status2 = strm.state.status; + if (status2 !== INIT_STATE && status2 !== EXTRA_STATE && status2 !== NAME_STATE && status2 !== COMMENT_STATE && status2 !== HCRC_STATE && status2 !== BUSY_STATE && status2 !== FINISH_STATE) { + return err(strm, Z_STREAM_ERROR); + } + strm.state = null; + return status2 === BUSY_STATE ? err(strm, Z_DATA_ERROR) : Z_OK; + } + function deflateSetDictionary(strm, dictionary) { + var dictLength = dictionary.length; + var s; + var str, n; + var wrap; + var avail; + var next; + var input; + var tmpDict; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + s = strm.state; + wrap = s.wrap; + if (wrap === 2 || wrap === 1 && s.status !== INIT_STATE || s.lookahead) { + return Z_STREAM_ERROR; + } + if (wrap === 1) { + strm.adler = adler32(strm.adler, dictionary, dictLength, 0); + } + s.wrap = 0; + if (dictLength >= s.w_size) { + if (wrap === 0) { + zero(s.head); + s.strstart = 0; + s.block_start = 0; + s.insert = 0; + } + tmpDict = new utils.Buf8(s.w_size); + utils.arraySet(tmpDict, dictionary, dictLength - s.w_size, s.w_size, 0); + dictionary = tmpDict; + dictLength = s.w_size; + } + avail = strm.avail_in; + next = strm.next_in; + input = strm.input; + strm.avail_in = dictLength; + strm.next_in = 0; + strm.input = dictionary; + fill_window(s); + while (s.lookahead >= MIN_MATCH) { + str = s.strstart; + n = s.lookahead - (MIN_MATCH - 1); + do { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask; + s.prev[str & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = str; + str++; + } while (--n); + s.strstart = str; + s.lookahead = MIN_MATCH - 1; + fill_window(s); + } + s.strstart += s.lookahead; + s.block_start = s.strstart; + s.insert = s.lookahead; + s.lookahead = 0; + s.match_length = s.prev_length = MIN_MATCH - 1; + s.match_available = 0; + strm.next_in = next; + strm.input = input; + strm.avail_in = avail; + s.wrap = wrap; + return Z_OK; + } + exports.deflateInit = deflateInit; + exports.deflateInit2 = deflateInit2; + exports.deflateReset = deflateReset; + exports.deflateResetKeep = deflateResetKeep; + exports.deflateSetHeader = deflateSetHeader; + exports.deflate = deflate2; + exports.deflateEnd = deflateEnd; + exports.deflateSetDictionary = deflateSetDictionary; + exports.deflateInfo = "pako deflate (from Nodeca project)"; + } +}); + +// node_modules/pako/lib/utils/strings.js +var require_strings = __commonJS({ + "node_modules/pako/lib/utils/strings.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var utils = require_common(); + var STR_APPLY_OK = true; + var STR_APPLY_UIA_OK = true; + try { + String.fromCharCode.apply(null, [0]); + } catch (__) { + STR_APPLY_OK = false; + } + try { + String.fromCharCode.apply(null, new Uint8Array(1)); + } catch (__) { + STR_APPLY_UIA_OK = false; + } + var _utf8len = new utils.Buf8(256); + for (q = 0; q < 256; q++) { + _utf8len[q] = q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1; + } + var q; + _utf8len[254] = _utf8len[254] = 1; + exports.string2buf = function(str) { + var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0; + for (m_pos = 0; m_pos < str_len; m_pos++) { + c = str.charCodeAt(m_pos); + if ((c & 64512) === 55296 && m_pos + 1 < str_len) { + c2 = str.charCodeAt(m_pos + 1); + if ((c2 & 64512) === 56320) { + c = 65536 + (c - 55296 << 10) + (c2 - 56320); + m_pos++; + } + } + buf_len += c < 128 ? 1 : c < 2048 ? 2 : c < 65536 ? 3 : 4; + } + buf = new utils.Buf8(buf_len); + for (i = 0, m_pos = 0; i < buf_len; m_pos++) { + c = str.charCodeAt(m_pos); + if ((c & 64512) === 55296 && m_pos + 1 < str_len) { + c2 = str.charCodeAt(m_pos + 1); + if ((c2 & 64512) === 56320) { + c = 65536 + (c - 55296 << 10) + (c2 - 56320); + m_pos++; + } + } + if (c < 128) { + buf[i++] = c; + } else if (c < 2048) { + buf[i++] = 192 | c >>> 6; + buf[i++] = 128 | c & 63; + } else if (c < 65536) { + buf[i++] = 224 | c >>> 12; + buf[i++] = 128 | c >>> 6 & 63; + buf[i++] = 128 | c & 63; + } else { + buf[i++] = 240 | c >>> 18; + buf[i++] = 128 | c >>> 12 & 63; + buf[i++] = 128 | c >>> 6 & 63; + buf[i++] = 128 | c & 63; + } + } + return buf; + }; + function buf2binstring(buf, len) { + if (len < 65534) { + if (buf.subarray && STR_APPLY_UIA_OK || !buf.subarray && STR_APPLY_OK) { + return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len)); + } + } + var result = ""; + for (var i = 0; i < len; i++) { + result += String.fromCharCode(buf[i]); + } + return result; + } + exports.buf2binstring = function(buf) { + return buf2binstring(buf, buf.length); + }; + exports.binstring2buf = function(str) { + var buf = new utils.Buf8(str.length); + for (var i = 0, len = buf.length; i < len; i++) { + buf[i] = str.charCodeAt(i); + } + return buf; + }; + exports.buf2string = function(buf, max) { + var i, out, c, c_len; + var len = max || buf.length; + var utf16buf = new Array(len * 2); + for (out = 0, i = 0; i < len; ) { + c = buf[i++]; + if (c < 128) { + utf16buf[out++] = c; + continue; + } + c_len = _utf8len[c]; + if (c_len > 4) { + utf16buf[out++] = 65533; + i += c_len - 1; + continue; + } + c &= c_len === 2 ? 31 : c_len === 3 ? 15 : 7; + while (c_len > 1 && i < len) { + c = c << 6 | buf[i++] & 63; + c_len--; + } + if (c_len > 1) { + utf16buf[out++] = 65533; + continue; + } + if (c < 65536) { + utf16buf[out++] = c; + } else { + c -= 65536; + utf16buf[out++] = 55296 | c >> 10 & 1023; + utf16buf[out++] = 56320 | c & 1023; + } + } + return buf2binstring(utf16buf, out); + }; + exports.utf8border = function(buf, max) { + var pos; + max = max || buf.length; + if (max > buf.length) { + max = buf.length; + } + pos = max - 1; + while (pos >= 0 && (buf[pos] & 192) === 128) { + pos--; + } + if (pos < 0) { + return max; + } + if (pos === 0) { + return max; + } + return pos + _utf8len[buf[pos]] > max ? pos : max; + }; + } +}); + +// node_modules/pako/lib/zlib/zstream.js +var require_zstream = __commonJS({ + "node_modules/pako/lib/zlib/zstream.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + function ZStream() { + this.input = null; + this.next_in = 0; + this.avail_in = 0; + this.total_in = 0; + this.output = null; + this.next_out = 0; + this.avail_out = 0; + this.total_out = 0; + this.msg = ""; + this.state = null; + this.data_type = 2; + this.adler = 0; + } + module2.exports = ZStream; + } +}); + +// node_modules/pako/lib/deflate.js +var require_deflate2 = __commonJS({ + "node_modules/pako/lib/deflate.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var zlib_deflate = require_deflate(); + var utils = require_common(); + var strings = require_strings(); + var msg = require_messages(); + var ZStream = require_zstream(); + var toString = Object.prototype.toString; + var Z_NO_FLUSH = 0; + var Z_FINISH = 4; + var Z_OK = 0; + var Z_STREAM_END = 1; + var Z_SYNC_FLUSH = 2; + var Z_DEFAULT_COMPRESSION = -1; + var Z_DEFAULT_STRATEGY = 0; + var Z_DEFLATED = 8; + function Deflate(options) { + if (!(this instanceof Deflate)) + return new Deflate(options); + this.options = utils.assign({ + level: Z_DEFAULT_COMPRESSION, + method: Z_DEFLATED, + chunkSize: 16384, + windowBits: 15, + memLevel: 8, + strategy: Z_DEFAULT_STRATEGY, + to: "" + }, options || {}); + var opt = this.options; + if (opt.raw && opt.windowBits > 0) { + opt.windowBits = -opt.windowBits; + } else if (opt.gzip && opt.windowBits > 0 && opt.windowBits < 16) { + opt.windowBits += 16; + } + this.err = 0; + this.msg = ""; + this.ended = false; + this.chunks = []; + this.strm = new ZStream(); + this.strm.avail_out = 0; + var status2 = zlib_deflate.deflateInit2(this.strm, opt.level, opt.method, opt.windowBits, opt.memLevel, opt.strategy); + if (status2 !== Z_OK) { + throw new Error(msg[status2]); + } + if (opt.header) { + zlib_deflate.deflateSetHeader(this.strm, opt.header); + } + if (opt.dictionary) { + var dict; + if (typeof opt.dictionary === "string") { + dict = strings.string2buf(opt.dictionary); + } else if (toString.call(opt.dictionary) === "[object ArrayBuffer]") { + dict = new Uint8Array(opt.dictionary); + } else { + dict = opt.dictionary; + } + status2 = zlib_deflate.deflateSetDictionary(this.strm, dict); + if (status2 !== Z_OK) { + throw new Error(msg[status2]); + } + this._dict_set = true; + } + } + Deflate.prototype.push = function(data, mode) { + var strm = this.strm; + var chunkSize = this.options.chunkSize; + var status2, _mode; + if (this.ended) { + return false; + } + _mode = mode === ~~mode ? mode : mode === true ? Z_FINISH : Z_NO_FLUSH; + if (typeof data === "string") { + strm.input = strings.string2buf(data); + } else if (toString.call(data) === "[object ArrayBuffer]") { + strm.input = new Uint8Array(data); + } else { + strm.input = data; + } + strm.next_in = 0; + strm.avail_in = strm.input.length; + do { + if (strm.avail_out === 0) { + strm.output = new utils.Buf8(chunkSize); + strm.next_out = 0; + strm.avail_out = chunkSize; + } + status2 = zlib_deflate.deflate(strm, _mode); + if (status2 !== Z_STREAM_END && status2 !== Z_OK) { + this.onEnd(status2); + this.ended = true; + return false; + } + if (strm.avail_out === 0 || strm.avail_in === 0 && (_mode === Z_FINISH || _mode === Z_SYNC_FLUSH)) { + if (this.options.to === "string") { + this.onData(strings.buf2binstring(utils.shrinkBuf(strm.output, strm.next_out))); + } else { + this.onData(utils.shrinkBuf(strm.output, strm.next_out)); + } + } + } while ((strm.avail_in > 0 || strm.avail_out === 0) && status2 !== Z_STREAM_END); + if (_mode === Z_FINISH) { + status2 = zlib_deflate.deflateEnd(this.strm); + this.onEnd(status2); + this.ended = true; + return status2 === Z_OK; + } + if (_mode === Z_SYNC_FLUSH) { + this.onEnd(Z_OK); + strm.avail_out = 0; + return true; + } + return true; + }; + Deflate.prototype.onData = function(chunk) { + this.chunks.push(chunk); + }; + Deflate.prototype.onEnd = function(status2) { + if (status2 === Z_OK) { + if (this.options.to === "string") { + this.result = this.chunks.join(""); + } else { + this.result = utils.flattenChunks(this.chunks); + } + } + this.chunks = []; + this.err = status2; + this.msg = this.strm.msg; + }; + function deflate2(input, options) { + var deflator = new Deflate(options); + deflator.push(input, true); + if (deflator.err) { + throw deflator.msg || msg[deflator.err]; + } + return deflator.result; + } + function deflateRaw(input, options) { + options = options || {}; + options.raw = true; + return deflate2(input, options); + } + function gzip(input, options) { + options = options || {}; + options.gzip = true; + return deflate2(input, options); + } + exports.Deflate = Deflate; + exports.deflate = deflate2; + exports.deflateRaw = deflateRaw; + exports.gzip = gzip; + } +}); + +// node_modules/pako/lib/zlib/inffast.js +var require_inffast = __commonJS({ + "node_modules/pako/lib/zlib/inffast.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + var BAD = 30; + var TYPE = 12; + module2.exports = function inflate_fast(strm, start) { + var state; + var _in; + var last2; + var _out; + var beg; + var end; + var dmax; + var wsize; + var whave; + var wnext; + var s_window; + var hold; + var bits; + var lcode; + var dcode; + var lmask; + var dmask; + var here; + var op; + var len; + var dist; + var from; + var from_source; + var input, output; + state = strm.state; + _in = strm.next_in; + input = strm.input; + last2 = _in + (strm.avail_in - 5); + _out = strm.next_out; + output = strm.output; + beg = _out - (start - strm.avail_out); + end = _out + (strm.avail_out - 257); + dmax = state.dmax; + wsize = state.wsize; + whave = state.whave; + wnext = state.wnext; + s_window = state.window; + hold = state.hold; + bits = state.bits; + lcode = state.lencode; + dcode = state.distcode; + lmask = (1 << state.lenbits) - 1; + dmask = (1 << state.distbits) - 1; + top: + do { + if (bits < 15) { + hold += input[_in++] << bits; + bits += 8; + hold += input[_in++] << bits; + bits += 8; + } + here = lcode[hold & lmask]; + dolen: + for (; ; ) { + op = here >>> 24; + hold >>>= op; + bits -= op; + op = here >>> 16 & 255; + if (op === 0) { + output[_out++] = here & 65535; + } else if (op & 16) { + len = here & 65535; + op &= 15; + if (op) { + if (bits < op) { + hold += input[_in++] << bits; + bits += 8; + } + len += hold & (1 << op) - 1; + hold >>>= op; + bits -= op; + } + if (bits < 15) { + hold += input[_in++] << bits; + bits += 8; + hold += input[_in++] << bits; + bits += 8; + } + here = dcode[hold & dmask]; + dodist: + for (; ; ) { + op = here >>> 24; + hold >>>= op; + bits -= op; + op = here >>> 16 & 255; + if (op & 16) { + dist = here & 65535; + op &= 15; + if (bits < op) { + hold += input[_in++] << bits; + bits += 8; + if (bits < op) { + hold += input[_in++] << bits; + bits += 8; + } + } + dist += hold & (1 << op) - 1; + if (dist > dmax) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break top; + } + hold >>>= op; + bits -= op; + op = _out - beg; + if (dist > op) { + op = dist - op; + if (op > whave) { + if (state.sane) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break top; + } + } + from = 0; + from_source = s_window; + if (wnext === 0) { + from += wsize - op; + if (op < len) { + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = _out - dist; + from_source = output; + } + } else if (wnext < op) { + from += wsize + wnext - op; + op -= wnext; + if (op < len) { + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = 0; + if (wnext < len) { + op = wnext; + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = _out - dist; + from_source = output; + } + } + } else { + from += wnext - op; + if (op < len) { + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = _out - dist; + from_source = output; + } + } + while (len > 2) { + output[_out++] = from_source[from++]; + output[_out++] = from_source[from++]; + output[_out++] = from_source[from++]; + len -= 3; + } + if (len) { + output[_out++] = from_source[from++]; + if (len > 1) { + output[_out++] = from_source[from++]; + } + } + } else { + from = _out - dist; + do { + output[_out++] = output[from++]; + output[_out++] = output[from++]; + output[_out++] = output[from++]; + len -= 3; + } while (len > 2); + if (len) { + output[_out++] = output[from++]; + if (len > 1) { + output[_out++] = output[from++]; + } + } + } + } else if ((op & 64) === 0) { + here = dcode[(here & 65535) + (hold & (1 << op) - 1)]; + continue dodist; + } else { + strm.msg = "invalid distance code"; + state.mode = BAD; + break top; + } + break; + } + } else if ((op & 64) === 0) { + here = lcode[(here & 65535) + (hold & (1 << op) - 1)]; + continue dolen; + } else if (op & 32) { + state.mode = TYPE; + break top; + } else { + strm.msg = "invalid literal/length code"; + state.mode = BAD; + break top; + } + break; + } + } while (_in < last2 && _out < end); + len = bits >> 3; + _in -= len; + bits -= len << 3; + hold &= (1 << bits) - 1; + strm.next_in = _in; + strm.next_out = _out; + strm.avail_in = _in < last2 ? 5 + (last2 - _in) : 5 - (_in - last2); + strm.avail_out = _out < end ? 257 + (end - _out) : 257 - (_out - end); + state.hold = hold; + state.bits = bits; + return; + }; + } +}); + +// node_modules/pako/lib/zlib/inftrees.js +var require_inftrees = __commonJS({ + "node_modules/pako/lib/zlib/inftrees.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + var utils = require_common(); + var MAXBITS = 15; + var ENOUGH_LENS = 852; + var ENOUGH_DISTS = 592; + var CODES = 0; + var LENS = 1; + var DISTS = 2; + var lbase = [ + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 13, + 15, + 17, + 19, + 23, + 27, + 31, + 35, + 43, + 51, + 59, + 67, + 83, + 99, + 115, + 131, + 163, + 195, + 227, + 258, + 0, + 0 + ]; + var lext = [ + 16, + 16, + 16, + 16, + 16, + 16, + 16, + 16, + 17, + 17, + 17, + 17, + 18, + 18, + 18, + 18, + 19, + 19, + 19, + 19, + 20, + 20, + 20, + 20, + 21, + 21, + 21, + 21, + 16, + 72, + 78 + ]; + var dbase = [ + 1, + 2, + 3, + 4, + 5, + 7, + 9, + 13, + 17, + 25, + 33, + 49, + 65, + 97, + 129, + 193, + 257, + 385, + 513, + 769, + 1025, + 1537, + 2049, + 3073, + 4097, + 6145, + 8193, + 12289, + 16385, + 24577, + 0, + 0 + ]; + var dext = [ + 16, + 16, + 16, + 16, + 17, + 17, + 18, + 18, + 19, + 19, + 20, + 20, + 21, + 21, + 22, + 22, + 23, + 23, + 24, + 24, + 25, + 25, + 26, + 26, + 27, + 27, + 28, + 28, + 29, + 29, + 64, + 64 + ]; + module2.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts) { + var bits = opts.bits; + var len = 0; + var sym = 0; + var min = 0, max = 0; + var root = 0; + var curr = 0; + var drop = 0; + var left = 0; + var used = 0; + var huff = 0; + var incr; + var fill; + var low; + var mask; + var next; + var base = null; + var base_index = 0; + var end; + var count = new utils.Buf16(MAXBITS + 1); + var offs = new utils.Buf16(MAXBITS + 1); + var extra = null; + var extra_index = 0; + var here_bits, here_op, here_val; + for (len = 0; len <= MAXBITS; len++) { + count[len] = 0; + } + for (sym = 0; sym < codes; sym++) { + count[lens[lens_index + sym]]++; + } + root = bits; + for (max = MAXBITS; max >= 1; max--) { + if (count[max] !== 0) { + break; + } + } + if (root > max) { + root = max; + } + if (max === 0) { + table[table_index++] = 1 << 24 | 64 << 16 | 0; + table[table_index++] = 1 << 24 | 64 << 16 | 0; + opts.bits = 1; + return 0; + } + for (min = 1; min < max; min++) { + if (count[min] !== 0) { + break; + } + } + if (root < min) { + root = min; + } + left = 1; + for (len = 1; len <= MAXBITS; len++) { + left <<= 1; + left -= count[len]; + if (left < 0) { + return -1; + } + } + if (left > 0 && (type === CODES || max !== 1)) { + return -1; + } + offs[1] = 0; + for (len = 1; len < MAXBITS; len++) { + offs[len + 1] = offs[len] + count[len]; + } + for (sym = 0; sym < codes; sym++) { + if (lens[lens_index + sym] !== 0) { + work[offs[lens[lens_index + sym]]++] = sym; + } + } + if (type === CODES) { + base = extra = work; + end = 19; + } else if (type === LENS) { + base = lbase; + base_index -= 257; + extra = lext; + extra_index -= 257; + end = 256; + } else { + base = dbase; + extra = dext; + end = -1; + } + huff = 0; + sym = 0; + len = min; + next = table_index; + curr = root; + drop = 0; + low = -1; + used = 1 << root; + mask = used - 1; + if (type === LENS && used > ENOUGH_LENS || type === DISTS && used > ENOUGH_DISTS) { + return 1; + } + for (; ; ) { + here_bits = len - drop; + if (work[sym] < end) { + here_op = 0; + here_val = work[sym]; + } else if (work[sym] > end) { + here_op = extra[extra_index + work[sym]]; + here_val = base[base_index + work[sym]]; + } else { + here_op = 32 + 64; + here_val = 0; + } + incr = 1 << len - drop; + fill = 1 << curr; + min = fill; + do { + fill -= incr; + table[next + (huff >> drop) + fill] = here_bits << 24 | here_op << 16 | here_val | 0; + } while (fill !== 0); + incr = 1 << len - 1; + while (huff & incr) { + incr >>= 1; + } + if (incr !== 0) { + huff &= incr - 1; + huff += incr; + } else { + huff = 0; + } + sym++; + if (--count[len] === 0) { + if (len === max) { + break; + } + len = lens[lens_index + work[sym]]; + } + if (len > root && (huff & mask) !== low) { + if (drop === 0) { + drop = root; + } + next += min; + curr = len - drop; + left = 1 << curr; + while (curr + drop < max) { + left -= count[curr + drop]; + if (left <= 0) { + break; + } + curr++; + left <<= 1; + } + used += 1 << curr; + if (type === LENS && used > ENOUGH_LENS || type === DISTS && used > ENOUGH_DISTS) { + return 1; + } + low = huff & mask; + table[low] = root << 24 | curr << 16 | next - table_index | 0; + } + } + if (huff !== 0) { + table[next + huff] = len - drop << 24 | 64 << 16 | 0; + } + opts.bits = root; + return 0; + }; + } +}); + +// node_modules/pako/lib/zlib/inflate.js +var require_inflate = __commonJS({ + "node_modules/pako/lib/zlib/inflate.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var utils = require_common(); + var adler32 = require_adler32(); + var crc322 = require_crc322(); + var inflate_fast = require_inffast(); + var inflate_table = require_inftrees(); + var CODES = 0; + var LENS = 1; + var DISTS = 2; + var Z_FINISH = 4; + var Z_BLOCK = 5; + var Z_TREES = 6; + var Z_OK = 0; + var Z_STREAM_END = 1; + var Z_NEED_DICT = 2; + var Z_STREAM_ERROR = -2; + var Z_DATA_ERROR = -3; + var Z_MEM_ERROR = -4; + var Z_BUF_ERROR = -5; + var Z_DEFLATED = 8; + var HEAD = 1; + var FLAGS = 2; + var TIME = 3; + var OS = 4; + var EXLEN = 5; + var EXTRA = 6; + var NAME = 7; + var COMMENT = 8; + var HCRC = 9; + var DICTID = 10; + var DICT = 11; + var TYPE = 12; + var TYPEDO = 13; + var STORED = 14; + var COPY_ = 15; + var COPY = 16; + var TABLE = 17; + var LENLENS = 18; + var CODELENS = 19; + var LEN_ = 20; + var LEN = 21; + var LENEXT = 22; + var DIST = 23; + var DISTEXT = 24; + var MATCH = 25; + var LIT = 26; + var CHECK = 27; + var LENGTH = 28; + var DONE = 29; + var BAD = 30; + var MEM = 31; + var SYNC = 32; + var ENOUGH_LENS = 852; + var ENOUGH_DISTS = 592; + var MAX_WBITS = 15; + var DEF_WBITS = MAX_WBITS; + function zswap32(q) { + return (q >>> 24 & 255) + (q >>> 8 & 65280) + ((q & 65280) << 8) + ((q & 255) << 24); + } + function InflateState() { + this.mode = 0; + this.last = false; + this.wrap = 0; + this.havedict = false; + this.flags = 0; + this.dmax = 0; + this.check = 0; + this.total = 0; + this.head = null; + this.wbits = 0; + this.wsize = 0; + this.whave = 0; + this.wnext = 0; + this.window = null; + this.hold = 0; + this.bits = 0; + this.length = 0; + this.offset = 0; + this.extra = 0; + this.lencode = null; + this.distcode = null; + this.lenbits = 0; + this.distbits = 0; + this.ncode = 0; + this.nlen = 0; + this.ndist = 0; + this.have = 0; + this.next = null; + this.lens = new utils.Buf16(320); + this.work = new utils.Buf16(288); + this.lendyn = null; + this.distdyn = null; + this.sane = 0; + this.back = 0; + this.was = 0; + } + function inflateResetKeep(strm) { + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + strm.total_in = strm.total_out = state.total = 0; + strm.msg = ""; + if (state.wrap) { + strm.adler = state.wrap & 1; + } + state.mode = HEAD; + state.last = 0; + state.havedict = 0; + state.dmax = 32768; + state.head = null; + state.hold = 0; + state.bits = 0; + state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS); + state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS); + state.sane = 1; + state.back = -1; + return Z_OK; + } + function inflateReset(strm) { + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + state.wsize = 0; + state.whave = 0; + state.wnext = 0; + return inflateResetKeep(strm); + } + function inflateReset2(strm, windowBits) { + var wrap; + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + if (windowBits < 0) { + wrap = 0; + windowBits = -windowBits; + } else { + wrap = (windowBits >> 4) + 1; + if (windowBits < 48) { + windowBits &= 15; + } + } + if (windowBits && (windowBits < 8 || windowBits > 15)) { + return Z_STREAM_ERROR; + } + if (state.window !== null && state.wbits !== windowBits) { + state.window = null; + } + state.wrap = wrap; + state.wbits = windowBits; + return inflateReset(strm); + } + function inflateInit2(strm, windowBits) { + var ret; + var state; + if (!strm) { + return Z_STREAM_ERROR; + } + state = new InflateState(); + strm.state = state; + state.window = null; + ret = inflateReset2(strm, windowBits); + if (ret !== Z_OK) { + strm.state = null; + } + return ret; + } + function inflateInit(strm) { + return inflateInit2(strm, DEF_WBITS); + } + var virgin = true; + var lenfix; + var distfix; + function fixedtables(state) { + if (virgin) { + var sym; + lenfix = new utils.Buf32(512); + distfix = new utils.Buf32(32); + sym = 0; + while (sym < 144) { + state.lens[sym++] = 8; + } + while (sym < 256) { + state.lens[sym++] = 9; + } + while (sym < 280) { + state.lens[sym++] = 7; + } + while (sym < 288) { + state.lens[sym++] = 8; + } + inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 }); + sym = 0; + while (sym < 32) { + state.lens[sym++] = 5; + } + inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 }); + virgin = false; + } + state.lencode = lenfix; + state.lenbits = 9; + state.distcode = distfix; + state.distbits = 5; + } + function updatewindow(strm, src, end, copy2) { + var dist; + var state = strm.state; + if (state.window === null) { + state.wsize = 1 << state.wbits; + state.wnext = 0; + state.whave = 0; + state.window = new utils.Buf8(state.wsize); + } + if (copy2 >= state.wsize) { + utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0); + state.wnext = 0; + state.whave = state.wsize; + } else { + dist = state.wsize - state.wnext; + if (dist > copy2) { + dist = copy2; + } + utils.arraySet(state.window, src, end - copy2, dist, state.wnext); + copy2 -= dist; + if (copy2) { + utils.arraySet(state.window, src, end - copy2, copy2, 0); + state.wnext = copy2; + state.whave = state.wsize; + } else { + state.wnext += dist; + if (state.wnext === state.wsize) { + state.wnext = 0; + } + if (state.whave < state.wsize) { + state.whave += dist; + } + } + } + return 0; + } + function inflate2(strm, flush2) { + var state; + var input, output; + var next; + var put; + var have, left; + var hold; + var bits; + var _in, _out; + var copy2; + var from; + var from_source; + var here = 0; + var here_bits, here_op, here_val; + var last_bits, last_op, last_val; + var len; + var ret; + var hbuf = new utils.Buf8(4); + var opts; + var n; + var order = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]; + if (!strm || !strm.state || !strm.output || !strm.input && strm.avail_in !== 0) { + return Z_STREAM_ERROR; + } + state = strm.state; + if (state.mode === TYPE) { + state.mode = TYPEDO; + } + put = strm.next_out; + output = strm.output; + left = strm.avail_out; + next = strm.next_in; + input = strm.input; + have = strm.avail_in; + hold = state.hold; + bits = state.bits; + _in = have; + _out = left; + ret = Z_OK; + inf_leave: + for (; ; ) { + switch (state.mode) { + case HEAD: + if (state.wrap === 0) { + state.mode = TYPEDO; + break; + } + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (state.wrap & 2 && hold === 35615) { + state.check = 0; + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + hold = 0; + bits = 0; + state.mode = FLAGS; + break; + } + state.flags = 0; + if (state.head) { + state.head.done = false; + } + if (!(state.wrap & 1) || (((hold & 255) << 8) + (hold >> 8)) % 31) { + strm.msg = "incorrect header check"; + state.mode = BAD; + break; + } + if ((hold & 15) !== Z_DEFLATED) { + strm.msg = "unknown compression method"; + state.mode = BAD; + break; + } + hold >>>= 4; + bits -= 4; + len = (hold & 15) + 8; + if (state.wbits === 0) { + state.wbits = len; + } else if (len > state.wbits) { + strm.msg = "invalid window size"; + state.mode = BAD; + break; + } + state.dmax = 1 << len; + strm.adler = state.check = 1; + state.mode = hold & 512 ? DICTID : TYPE; + hold = 0; + bits = 0; + break; + case FLAGS: + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.flags = hold; + if ((state.flags & 255) !== Z_DEFLATED) { + strm.msg = "unknown compression method"; + state.mode = BAD; + break; + } + if (state.flags & 57344) { + strm.msg = "unknown header flags set"; + state.mode = BAD; + break; + } + if (state.head) { + state.head.text = hold >> 8 & 1; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + } + hold = 0; + bits = 0; + state.mode = TIME; + case TIME: + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (state.head) { + state.head.time = hold; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + hbuf[2] = hold >>> 16 & 255; + hbuf[3] = hold >>> 24 & 255; + state.check = crc322(state.check, hbuf, 4, 0); + } + hold = 0; + bits = 0; + state.mode = OS; + case OS: + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (state.head) { + state.head.xflags = hold & 255; + state.head.os = hold >> 8; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + } + hold = 0; + bits = 0; + state.mode = EXLEN; + case EXLEN: + if (state.flags & 1024) { + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.length = hold; + if (state.head) { + state.head.extra_len = hold; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + } + hold = 0; + bits = 0; + } else if (state.head) { + state.head.extra = null; + } + state.mode = EXTRA; + case EXTRA: + if (state.flags & 1024) { + copy2 = state.length; + if (copy2 > have) { + copy2 = have; + } + if (copy2) { + if (state.head) { + len = state.head.extra_len - state.length; + if (!state.head.extra) { + state.head.extra = new Array(state.head.extra_len); + } + utils.arraySet(state.head.extra, input, next, copy2, len); + } + if (state.flags & 512) { + state.check = crc322(state.check, input, copy2, next); + } + have -= copy2; + next += copy2; + state.length -= copy2; + } + if (state.length) { + break inf_leave; + } + } + state.length = 0; + state.mode = NAME; + case NAME: + if (state.flags & 2048) { + if (have === 0) { + break inf_leave; + } + copy2 = 0; + do { + len = input[next + copy2++]; + if (state.head && len && state.length < 65536) { + state.head.name += String.fromCharCode(len); + } + } while (len && copy2 < have); + if (state.flags & 512) { + state.check = crc322(state.check, input, copy2, next); + } + have -= copy2; + next += copy2; + if (len) { + break inf_leave; + } + } else if (state.head) { + state.head.name = null; + } + state.length = 0; + state.mode = COMMENT; + case COMMENT: + if (state.flags & 4096) { + if (have === 0) { + break inf_leave; + } + copy2 = 0; + do { + len = input[next + copy2++]; + if (state.head && len && state.length < 65536) { + state.head.comment += String.fromCharCode(len); + } + } while (len && copy2 < have); + if (state.flags & 512) { + state.check = crc322(state.check, input, copy2, next); + } + have -= copy2; + next += copy2; + if (len) { + break inf_leave; + } + } else if (state.head) { + state.head.comment = null; + } + state.mode = HCRC; + case HCRC: + if (state.flags & 512) { + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (hold !== (state.check & 65535)) { + strm.msg = "header crc mismatch"; + state.mode = BAD; + break; + } + hold = 0; + bits = 0; + } + if (state.head) { + state.head.hcrc = state.flags >> 9 & 1; + state.head.done = true; + } + strm.adler = state.check = 0; + state.mode = TYPE; + break; + case DICTID: + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + strm.adler = state.check = zswap32(hold); + hold = 0; + bits = 0; + state.mode = DICT; + case DICT: + if (state.havedict === 0) { + strm.next_out = put; + strm.avail_out = left; + strm.next_in = next; + strm.avail_in = have; + state.hold = hold; + state.bits = bits; + return Z_NEED_DICT; + } + strm.adler = state.check = 1; + state.mode = TYPE; + case TYPE: + if (flush2 === Z_BLOCK || flush2 === Z_TREES) { + break inf_leave; + } + case TYPEDO: + if (state.last) { + hold >>>= bits & 7; + bits -= bits & 7; + state.mode = CHECK; + break; + } + while (bits < 3) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.last = hold & 1; + hold >>>= 1; + bits -= 1; + switch (hold & 3) { + case 0: + state.mode = STORED; + break; + case 1: + fixedtables(state); + state.mode = LEN_; + if (flush2 === Z_TREES) { + hold >>>= 2; + bits -= 2; + break inf_leave; + } + break; + case 2: + state.mode = TABLE; + break; + case 3: + strm.msg = "invalid block type"; + state.mode = BAD; + } + hold >>>= 2; + bits -= 2; + break; + case STORED: + hold >>>= bits & 7; + bits -= bits & 7; + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if ((hold & 65535) !== (hold >>> 16 ^ 65535)) { + strm.msg = "invalid stored block lengths"; + state.mode = BAD; + break; + } + state.length = hold & 65535; + hold = 0; + bits = 0; + state.mode = COPY_; + if (flush2 === Z_TREES) { + break inf_leave; + } + case COPY_: + state.mode = COPY; + case COPY: + copy2 = state.length; + if (copy2) { + if (copy2 > have) { + copy2 = have; + } + if (copy2 > left) { + copy2 = left; + } + if (copy2 === 0) { + break inf_leave; + } + utils.arraySet(output, input, next, copy2, put); + have -= copy2; + next += copy2; + left -= copy2; + put += copy2; + state.length -= copy2; + break; + } + state.mode = TYPE; + break; + case TABLE: + while (bits < 14) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.nlen = (hold & 31) + 257; + hold >>>= 5; + bits -= 5; + state.ndist = (hold & 31) + 1; + hold >>>= 5; + bits -= 5; + state.ncode = (hold & 15) + 4; + hold >>>= 4; + bits -= 4; + if (state.nlen > 286 || state.ndist > 30) { + strm.msg = "too many length or distance symbols"; + state.mode = BAD; + break; + } + state.have = 0; + state.mode = LENLENS; + case LENLENS: + while (state.have < state.ncode) { + while (bits < 3) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.lens[order[state.have++]] = hold & 7; + hold >>>= 3; + bits -= 3; + } + while (state.have < 19) { + state.lens[order[state.have++]] = 0; + } + state.lencode = state.lendyn; + state.lenbits = 7; + opts = { bits: state.lenbits }; + ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts); + state.lenbits = opts.bits; + if (ret) { + strm.msg = "invalid code lengths set"; + state.mode = BAD; + break; + } + state.have = 0; + state.mode = CODELENS; + case CODELENS: + while (state.have < state.nlen + state.ndist) { + for (; ; ) { + here = state.lencode[hold & (1 << state.lenbits) - 1]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (here_val < 16) { + hold >>>= here_bits; + bits -= here_bits; + state.lens[state.have++] = here_val; + } else { + if (here_val === 16) { + n = here_bits + 2; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= here_bits; + bits -= here_bits; + if (state.have === 0) { + strm.msg = "invalid bit length repeat"; + state.mode = BAD; + break; + } + len = state.lens[state.have - 1]; + copy2 = 3 + (hold & 3); + hold >>>= 2; + bits -= 2; + } else if (here_val === 17) { + n = here_bits + 3; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= here_bits; + bits -= here_bits; + len = 0; + copy2 = 3 + (hold & 7); + hold >>>= 3; + bits -= 3; + } else { + n = here_bits + 7; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= here_bits; + bits -= here_bits; + len = 0; + copy2 = 11 + (hold & 127); + hold >>>= 7; + bits -= 7; + } + if (state.have + copy2 > state.nlen + state.ndist) { + strm.msg = "invalid bit length repeat"; + state.mode = BAD; + break; + } + while (copy2--) { + state.lens[state.have++] = len; + } + } + } + if (state.mode === BAD) { + break; + } + if (state.lens[256] === 0) { + strm.msg = "invalid code -- missing end-of-block"; + state.mode = BAD; + break; + } + state.lenbits = 9; + opts = { bits: state.lenbits }; + ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts); + state.lenbits = opts.bits; + if (ret) { + strm.msg = "invalid literal/lengths set"; + state.mode = BAD; + break; + } + state.distbits = 6; + state.distcode = state.distdyn; + opts = { bits: state.distbits }; + ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts); + state.distbits = opts.bits; + if (ret) { + strm.msg = "invalid distances set"; + state.mode = BAD; + break; + } + state.mode = LEN_; + if (flush2 === Z_TREES) { + break inf_leave; + } + case LEN_: + state.mode = LEN; + case LEN: + if (have >= 6 && left >= 258) { + strm.next_out = put; + strm.avail_out = left; + strm.next_in = next; + strm.avail_in = have; + state.hold = hold; + state.bits = bits; + inflate_fast(strm, _out); + put = strm.next_out; + output = strm.output; + left = strm.avail_out; + next = strm.next_in; + input = strm.input; + have = strm.avail_in; + hold = state.hold; + bits = state.bits; + if (state.mode === TYPE) { + state.back = -1; + } + break; + } + state.back = 0; + for (; ; ) { + here = state.lencode[hold & (1 << state.lenbits) - 1]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (here_op && (here_op & 240) === 0) { + last_bits = here_bits; + last_op = here_op; + last_val = here_val; + for (; ; ) { + here = state.lencode[last_val + ((hold & (1 << last_bits + last_op) - 1) >> last_bits)]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (last_bits + here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= last_bits; + bits -= last_bits; + state.back += last_bits; + } + hold >>>= here_bits; + bits -= here_bits; + state.back += here_bits; + state.length = here_val; + if (here_op === 0) { + state.mode = LIT; + break; + } + if (here_op & 32) { + state.back = -1; + state.mode = TYPE; + break; + } + if (here_op & 64) { + strm.msg = "invalid literal/length code"; + state.mode = BAD; + break; + } + state.extra = here_op & 15; + state.mode = LENEXT; + case LENEXT: + if (state.extra) { + n = state.extra; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.length += hold & (1 << state.extra) - 1; + hold >>>= state.extra; + bits -= state.extra; + state.back += state.extra; + } + state.was = state.length; + state.mode = DIST; + case DIST: + for (; ; ) { + here = state.distcode[hold & (1 << state.distbits) - 1]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if ((here_op & 240) === 0) { + last_bits = here_bits; + last_op = here_op; + last_val = here_val; + for (; ; ) { + here = state.distcode[last_val + ((hold & (1 << last_bits + last_op) - 1) >> last_bits)]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (last_bits + here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= last_bits; + bits -= last_bits; + state.back += last_bits; + } + hold >>>= here_bits; + bits -= here_bits; + state.back += here_bits; + if (here_op & 64) { + strm.msg = "invalid distance code"; + state.mode = BAD; + break; + } + state.offset = here_val; + state.extra = here_op & 15; + state.mode = DISTEXT; + case DISTEXT: + if (state.extra) { + n = state.extra; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.offset += hold & (1 << state.extra) - 1; + hold >>>= state.extra; + bits -= state.extra; + state.back += state.extra; + } + if (state.offset > state.dmax) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break; + } + state.mode = MATCH; + case MATCH: + if (left === 0) { + break inf_leave; + } + copy2 = _out - left; + if (state.offset > copy2) { + copy2 = state.offset - copy2; + if (copy2 > state.whave) { + if (state.sane) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break; + } + } + if (copy2 > state.wnext) { + copy2 -= state.wnext; + from = state.wsize - copy2; + } else { + from = state.wnext - copy2; + } + if (copy2 > state.length) { + copy2 = state.length; + } + from_source = state.window; + } else { + from_source = output; + from = put - state.offset; + copy2 = state.length; + } + if (copy2 > left) { + copy2 = left; + } + left -= copy2; + state.length -= copy2; + do { + output[put++] = from_source[from++]; + } while (--copy2); + if (state.length === 0) { + state.mode = LEN; + } + break; + case LIT: + if (left === 0) { + break inf_leave; + } + output[put++] = state.length; + left--; + state.mode = LEN; + break; + case CHECK: + if (state.wrap) { + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold |= input[next++] << bits; + bits += 8; + } + _out -= left; + strm.total_out += _out; + state.total += _out; + if (_out) { + strm.adler = state.check = state.flags ? crc322(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out); + } + _out = left; + if ((state.flags ? hold : zswap32(hold)) !== state.check) { + strm.msg = "incorrect data check"; + state.mode = BAD; + break; + } + hold = 0; + bits = 0; + } + state.mode = LENGTH; + case LENGTH: + if (state.wrap && state.flags) { + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (hold !== (state.total & 4294967295)) { + strm.msg = "incorrect length check"; + state.mode = BAD; + break; + } + hold = 0; + bits = 0; + } + state.mode = DONE; + case DONE: + ret = Z_STREAM_END; + break inf_leave; + case BAD: + ret = Z_DATA_ERROR; + break inf_leave; + case MEM: + return Z_MEM_ERROR; + case SYNC: + default: + return Z_STREAM_ERROR; + } + } + strm.next_out = put; + strm.avail_out = left; + strm.next_in = next; + strm.avail_in = have; + state.hold = hold; + state.bits = bits; + if (state.wsize || _out !== strm.avail_out && state.mode < BAD && (state.mode < CHECK || flush2 !== Z_FINISH)) { + if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) { + state.mode = MEM; + return Z_MEM_ERROR; + } + } + _in -= strm.avail_in; + _out -= strm.avail_out; + strm.total_in += _in; + strm.total_out += _out; + state.total += _out; + if (state.wrap && _out) { + strm.adler = state.check = state.flags ? crc322(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out); + } + strm.data_type = state.bits + (state.last ? 64 : 0) + (state.mode === TYPE ? 128 : 0) + (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0); + if ((_in === 0 && _out === 0 || flush2 === Z_FINISH) && ret === Z_OK) { + ret = Z_BUF_ERROR; + } + return ret; + } + function inflateEnd(strm) { + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + var state = strm.state; + if (state.window) { + state.window = null; + } + strm.state = null; + return Z_OK; + } + function inflateGetHeader(strm, head) { + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + if ((state.wrap & 2) === 0) { + return Z_STREAM_ERROR; + } + state.head = head; + head.done = false; + return Z_OK; + } + function inflateSetDictionary(strm, dictionary) { + var dictLength = dictionary.length; + var state; + var dictid; + var ret; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + if (state.wrap !== 0 && state.mode !== DICT) { + return Z_STREAM_ERROR; + } + if (state.mode === DICT) { + dictid = 1; + dictid = adler32(dictid, dictionary, dictLength, 0); + if (dictid !== state.check) { + return Z_DATA_ERROR; + } + } + ret = updatewindow(strm, dictionary, dictLength, dictLength); + if (ret) { + state.mode = MEM; + return Z_MEM_ERROR; + } + state.havedict = 1; + return Z_OK; + } + exports.inflateReset = inflateReset; + exports.inflateReset2 = inflateReset2; + exports.inflateResetKeep = inflateResetKeep; + exports.inflateInit = inflateInit; + exports.inflateInit2 = inflateInit2; + exports.inflate = inflate2; + exports.inflateEnd = inflateEnd; + exports.inflateGetHeader = inflateGetHeader; + exports.inflateSetDictionary = inflateSetDictionary; + exports.inflateInfo = "pako inflate (from Nodeca project)"; + } +}); + +// node_modules/pako/lib/zlib/constants.js +var require_constants = __commonJS({ + "node_modules/pako/lib/zlib/constants.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + module2.exports = { + Z_NO_FLUSH: 0, + Z_PARTIAL_FLUSH: 1, + Z_SYNC_FLUSH: 2, + Z_FULL_FLUSH: 3, + Z_FINISH: 4, + Z_BLOCK: 5, + Z_TREES: 6, + Z_OK: 0, + Z_STREAM_END: 1, + Z_NEED_DICT: 2, + Z_ERRNO: -1, + Z_STREAM_ERROR: -2, + Z_DATA_ERROR: -3, + Z_BUF_ERROR: -5, + Z_NO_COMPRESSION: 0, + Z_BEST_SPEED: 1, + Z_BEST_COMPRESSION: 9, + Z_DEFAULT_COMPRESSION: -1, + Z_FILTERED: 1, + Z_HUFFMAN_ONLY: 2, + Z_RLE: 3, + Z_FIXED: 4, + Z_DEFAULT_STRATEGY: 0, + Z_BINARY: 0, + Z_TEXT: 1, + Z_UNKNOWN: 2, + Z_DEFLATED: 8 + }; + } +}); + +// node_modules/pako/lib/zlib/gzheader.js +var require_gzheader = __commonJS({ + "node_modules/pako/lib/zlib/gzheader.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + function GZheader() { + this.text = 0; + this.time = 0; + this.xflags = 0; + this.os = 0; + this.extra = null; + this.extra_len = 0; + this.name = ""; + this.comment = ""; + this.hcrc = 0; + this.done = false; + } + module2.exports = GZheader; + } +}); + +// node_modules/pako/lib/inflate.js +var require_inflate2 = __commonJS({ + "node_modules/pako/lib/inflate.js"(exports) { + init_polyfill_buffer(); + "use strict"; + var zlib_inflate = require_inflate(); + var utils = require_common(); + var strings = require_strings(); + var c = require_constants(); + var msg = require_messages(); + var ZStream = require_zstream(); + var GZheader = require_gzheader(); + var toString = Object.prototype.toString; + function Inflate(options) { + if (!(this instanceof Inflate)) + return new Inflate(options); + this.options = utils.assign({ + chunkSize: 16384, + windowBits: 0, + to: "" + }, options || {}); + var opt = this.options; + if (opt.raw && opt.windowBits >= 0 && opt.windowBits < 16) { + opt.windowBits = -opt.windowBits; + if (opt.windowBits === 0) { + opt.windowBits = -15; + } + } + if (opt.windowBits >= 0 && opt.windowBits < 16 && !(options && options.windowBits)) { + opt.windowBits += 32; + } + if (opt.windowBits > 15 && opt.windowBits < 48) { + if ((opt.windowBits & 15) === 0) { + opt.windowBits |= 15; + } + } + this.err = 0; + this.msg = ""; + this.ended = false; + this.chunks = []; + this.strm = new ZStream(); + this.strm.avail_out = 0; + var status2 = zlib_inflate.inflateInit2(this.strm, opt.windowBits); + if (status2 !== c.Z_OK) { + throw new Error(msg[status2]); + } + this.header = new GZheader(); + zlib_inflate.inflateGetHeader(this.strm, this.header); + if (opt.dictionary) { + if (typeof opt.dictionary === "string") { + opt.dictionary = strings.string2buf(opt.dictionary); + } else if (toString.call(opt.dictionary) === "[object ArrayBuffer]") { + opt.dictionary = new Uint8Array(opt.dictionary); + } + if (opt.raw) { + status2 = zlib_inflate.inflateSetDictionary(this.strm, opt.dictionary); + if (status2 !== c.Z_OK) { + throw new Error(msg[status2]); + } + } + } + } + Inflate.prototype.push = function(data, mode) { + var strm = this.strm; + var chunkSize = this.options.chunkSize; + var dictionary = this.options.dictionary; + var status2, _mode; + var next_out_utf8, tail, utf8str; + var allowBufError = false; + if (this.ended) { + return false; + } + _mode = mode === ~~mode ? mode : mode === true ? c.Z_FINISH : c.Z_NO_FLUSH; + if (typeof data === "string") { + strm.input = strings.binstring2buf(data); + } else if (toString.call(data) === "[object ArrayBuffer]") { + strm.input = new Uint8Array(data); + } else { + strm.input = data; + } + strm.next_in = 0; + strm.avail_in = strm.input.length; + do { + if (strm.avail_out === 0) { + strm.output = new utils.Buf8(chunkSize); + strm.next_out = 0; + strm.avail_out = chunkSize; + } + status2 = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); + if (status2 === c.Z_NEED_DICT && dictionary) { + status2 = zlib_inflate.inflateSetDictionary(this.strm, dictionary); + } + if (status2 === c.Z_BUF_ERROR && allowBufError === true) { + status2 = c.Z_OK; + allowBufError = false; + } + if (status2 !== c.Z_STREAM_END && status2 !== c.Z_OK) { + this.onEnd(status2); + this.ended = true; + return false; + } + if (strm.next_out) { + if (strm.avail_out === 0 || status2 === c.Z_STREAM_END || strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH)) { + if (this.options.to === "string") { + next_out_utf8 = strings.utf8border(strm.output, strm.next_out); + tail = strm.next_out - next_out_utf8; + utf8str = strings.buf2string(strm.output, next_out_utf8); + strm.next_out = tail; + strm.avail_out = chunkSize - tail; + if (tail) { + utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); + } + this.onData(utf8str); + } else { + this.onData(utils.shrinkBuf(strm.output, strm.next_out)); + } + } + } + if (strm.avail_in === 0 && strm.avail_out === 0) { + allowBufError = true; + } + } while ((strm.avail_in > 0 || strm.avail_out === 0) && status2 !== c.Z_STREAM_END); + if (status2 === c.Z_STREAM_END) { + _mode = c.Z_FINISH; + } + if (_mode === c.Z_FINISH) { + status2 = zlib_inflate.inflateEnd(this.strm); + this.onEnd(status2); + this.ended = true; + return status2 === c.Z_OK; + } + if (_mode === c.Z_SYNC_FLUSH) { + this.onEnd(c.Z_OK); + strm.avail_out = 0; + return true; + } + return true; + }; + Inflate.prototype.onData = function(chunk) { + this.chunks.push(chunk); + }; + Inflate.prototype.onEnd = function(status2) { + if (status2 === c.Z_OK) { + if (this.options.to === "string") { + this.result = this.chunks.join(""); + } else { + this.result = utils.flattenChunks(this.chunks); + } + } + this.chunks = []; + this.err = status2; + this.msg = this.strm.msg; + }; + function inflate2(input, options) { + var inflator = new Inflate(options); + inflator.push(input, true); + if (inflator.err) { + throw inflator.msg || msg[inflator.err]; + } + return inflator.result; + } + function inflateRaw(input, options) { + options = options || {}; + options.raw = true; + return inflate2(input, options); + } + exports.Inflate = Inflate; + exports.inflate = inflate2; + exports.inflateRaw = inflateRaw; + exports.ungzip = inflate2; + } +}); + +// node_modules/pako/index.js +var require_pako = __commonJS({ + "node_modules/pako/index.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + var assign2 = require_common().assign; + var deflate2 = require_deflate2(); + var inflate2 = require_inflate2(); + var constants = require_constants(); + var pako2 = {}; + assign2(pako2, deflate2, inflate2, constants); + module2.exports = pako2; + } +}); + +// node_modules/ignore/index.js +var require_ignore = __commonJS({ + "node_modules/ignore/index.js"(exports, module2) { + init_polyfill_buffer(); + function makeArray(subject) { + return Array.isArray(subject) ? subject : [subject]; + } + var EMPTY = ""; + var SPACE = " "; + var ESCAPE = "\\"; + var REGEX_TEST_BLANK_LINE = /^\s+$/; + var REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION = /^\\!/; + var REGEX_REPLACE_LEADING_EXCAPED_HASH = /^\\#/; + var REGEX_SPLITALL_CRLF = /\r?\n/g; + var REGEX_TEST_INVALID_PATH = /^\.*\/|^\.+$/; + var SLASH = "/"; + var KEY_IGNORE = typeof Symbol !== "undefined" ? Symbol.for("node-ignore") : "node-ignore"; + var define2 = (object, key2, value) => Object.defineProperty(object, key2, { value }); + var REGEX_REGEXP_RANGE = /([0-z])-([0-z])/g; + var RETURN_FALSE = () => false; + var sanitizeRange = (range) => range.replace(REGEX_REGEXP_RANGE, (match, from, to) => from.charCodeAt(0) <= to.charCodeAt(0) ? match : EMPTY); + var cleanRangeBackSlash = (slashes) => { + const { length } = slashes; + return slashes.slice(0, length - length % 2); + }; + var REPLACERS = [ + [ + /\\?\s+$/, + (match) => match.indexOf("\\") === 0 ? SPACE : EMPTY + ], + [ + /\\\s/g, + () => SPACE + ], + [ + /[\\$.|*+(){^]/g, + (match) => `\\${match}` + ], + [ + /(?!\\)\?/g, + () => "[^/]" + ], + [ + /^\//, + () => "^" + ], + [ + /\//g, + () => "\\/" + ], + [ + /^\^*\\\*\\\*\\\//, + () => "^(?:.*\\/)?" + ], + [ + /^(?=[^^])/, + function startingReplacer() { + return !/\/(?!$)/.test(this) ? "(?:^|\\/)" : "^"; + } + ], + [ + /\\\/\\\*\\\*(?=\\\/|$)/g, + (_, index2, str) => index2 + 6 < str.length ? "(?:\\/[^\\/]+)*" : "\\/.+" + ], + [ + /(^|[^\\]+)\\\*(?=.+)/g, + (_, p1) => `${p1}[^\\/]*` + ], + [ + /\\\\\\(?=[$.|*+(){^])/g, + () => ESCAPE + ], + [ + /\\\\/g, + () => ESCAPE + ], + [ + /(\\)?\[([^\]/]*?)(\\*)($|\])/g, + (match, leadEscape, range, endEscape, close) => leadEscape === ESCAPE ? `\\[${range}${cleanRangeBackSlash(endEscape)}${close}` : close === "]" ? endEscape.length % 2 === 0 ? `[${sanitizeRange(range)}${endEscape}]` : "[]" : "[]" + ], + [ + /(?:[^*])$/, + (match) => /\/$/.test(match) ? `${match}$` : `${match}(?=$|\\/$)` + ], + [ + /(\^|\\\/)?\\\*$/, + (_, p1) => { + const prefix = p1 ? `${p1}[^/]+` : "[^/]*"; + return `${prefix}(?=$|\\/$)`; + } + ] + ]; + var regexCache = Object.create(null); + var makeRegex = (pattern, ignoreCase) => { + let source = regexCache[pattern]; + if (!source) { + source = REPLACERS.reduce((prev, current) => prev.replace(current[0], current[1].bind(pattern)), pattern); + regexCache[pattern] = source; + } + return ignoreCase ? new RegExp(source, "i") : new RegExp(source); + }; + var isString = (subject) => typeof subject === "string"; + var checkPattern = (pattern) => pattern && isString(pattern) && !REGEX_TEST_BLANK_LINE.test(pattern) && pattern.indexOf("#") !== 0; + var splitPattern = (pattern) => pattern.split(REGEX_SPLITALL_CRLF); + var IgnoreRule = class { + constructor(origin, pattern, negative, regex2) { + this.origin = origin; + this.pattern = pattern; + this.negative = negative; + this.regex = regex2; + } + }; + var createRule = (pattern, ignoreCase) => { + const origin = pattern; + let negative = false; + if (pattern.indexOf("!") === 0) { + negative = true; + pattern = pattern.substr(1); + } + pattern = pattern.replace(REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION, "!").replace(REGEX_REPLACE_LEADING_EXCAPED_HASH, "#"); + const regex2 = makeRegex(pattern, ignoreCase); + return new IgnoreRule(origin, pattern, negative, regex2); + }; + var throwError = (message, Ctor) => { + throw new Ctor(message); + }; + var checkPath = (path2, originalPath, doThrow) => { + if (!isString(path2)) { + return doThrow(`path must be a string, but got \`${originalPath}\``, TypeError); + } + if (!path2) { + return doThrow(`path must not be empty`, TypeError); + } + if (checkPath.isNotRelative(path2)) { + const r = "`path.relative()`d"; + return doThrow(`path should be a ${r} string, but got "${originalPath}"`, RangeError); + } + return true; + }; + var isNotRelative = (path2) => REGEX_TEST_INVALID_PATH.test(path2); + checkPath.isNotRelative = isNotRelative; + checkPath.convert = (p) => p; + var Ignore = class { + constructor({ + ignorecase = true, + ignoreCase = ignorecase, + allowRelativePaths = false + } = {}) { + define2(this, KEY_IGNORE, true); + this._rules = []; + this._ignoreCase = ignoreCase; + this._allowRelativePaths = allowRelativePaths; + this._initCache(); + } + _initCache() { + this._ignoreCache = Object.create(null); + this._testCache = Object.create(null); + } + _addPattern(pattern) { + if (pattern && pattern[KEY_IGNORE]) { + this._rules = this._rules.concat(pattern._rules); + this._added = true; + return; + } + if (checkPattern(pattern)) { + const rule = createRule(pattern, this._ignoreCase); + this._added = true; + this._rules.push(rule); + } + } + add(pattern) { + this._added = false; + makeArray(isString(pattern) ? splitPattern(pattern) : pattern).forEach(this._addPattern, this); + if (this._added) { + this._initCache(); + } + return this; + } + addPattern(pattern) { + return this.add(pattern); + } + _testOne(path2, checkUnignored) { + let ignored = false; + let unignored = false; + this._rules.forEach((rule) => { + const { negative } = rule; + if (unignored === negative && ignored !== unignored || negative && !ignored && !unignored && !checkUnignored) { + return; + } + const matched = rule.regex.test(path2); + if (matched) { + ignored = !negative; + unignored = negative; + } + }); + return { + ignored, + unignored + }; + } + _test(originalPath, cache, checkUnignored, slices) { + const path2 = originalPath && checkPath.convert(originalPath); + checkPath(path2, originalPath, this._allowRelativePaths ? RETURN_FALSE : throwError); + return this._t(path2, cache, checkUnignored, slices); + } + _t(path2, cache, checkUnignored, slices) { + if (path2 in cache) { + return cache[path2]; + } + if (!slices) { + slices = path2.split(SLASH); + } + slices.pop(); + if (!slices.length) { + return cache[path2] = this._testOne(path2, checkUnignored); + } + const parent = this._t(slices.join(SLASH) + SLASH, cache, checkUnignored, slices); + return cache[path2] = parent.ignored ? parent : this._testOne(path2, checkUnignored); + } + ignores(path2) { + return this._test(path2, this._ignoreCache, false).ignored; + } + createFilter() { + return (path2) => !this.ignores(path2); + } + filter(paths) { + return makeArray(paths).filter(this.createFilter()); + } + test(path2) { + return this._test(path2, this._testCache, true); + } + }; + var factory = (options) => new Ignore(options); + var isPathValid = (path2) => checkPath(path2 && checkPath.convert(path2), path2, RETURN_FALSE); + factory.isPathValid = isPathValid; + factory.default = factory; + module2.exports = factory; + if (typeof process !== "undefined" && (process.env && process.env.IGNORE_TEST_WIN32 || process.platform === "win32")) { + const makePosix = (str) => /^\\\\\?\\/.test(str) || /["<>|\u0000-\u001F]+/u.test(str) ? str : str.replace(/\\/g, "/"); + checkPath.convert = makePosix; + const REGIX_IS_WINDOWS_PATH_ABSOLUTE = /^[a-z]:\//i; + checkPath.isNotRelative = (path2) => REGIX_IS_WINDOWS_PATH_ABSOLUTE.test(path2) || isNotRelative(path2); + } + } +}); + +// node_modules/pify/index.js +var require_pify = __commonJS({ + "node_modules/pify/index.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + var processFn = (fn, options) => function(...args) { + const P = options.promiseModule; + return new P((resolve, reject) => { + if (options.multiArgs) { + args.push((...result) => { + if (options.errorFirst) { + if (result[0]) { + reject(result); + } else { + result.shift(); + resolve(result); + } + } else { + resolve(result); + } + }); + } else if (options.errorFirst) { + args.push((error, result) => { + if (error) { + reject(error); + } else { + resolve(result); + } + }); + } else { + args.push(resolve); + } + fn.apply(this, args); + }); + }; + module2.exports = (input, options) => { + options = Object.assign({ + exclude: [/.+(Sync|Stream)$/], + errorFirst: true, + promiseModule: Promise + }, options); + const objType = typeof input; + if (!(input !== null && (objType === "object" || objType === "function"))) { + throw new TypeError(`Expected \`input\` to be a \`Function\` or \`Object\`, got \`${input === null ? "null" : objType}\``); + } + const filter = (key2) => { + const match = (pattern) => typeof pattern === "string" ? key2 === pattern : pattern.test(key2); + return options.include ? options.include.some(match) : !options.exclude.some(match); + }; + let ret; + if (objType === "function") { + ret = function(...args) { + return options.excludeMain ? input(...args) : processFn(input, options).apply(this, args); + }; + } else { + ret = Object.create(Object.getPrototypeOf(input)); + } + for (const key2 in input) { + const property = input[key2]; + ret[key2] = typeof property === "function" && filter(key2) ? processFn(property, options) : property; + } + return ret; + }; + } +}); + +// node_modules/clean-git-ref/lib/index.js +var require_lib2 = __commonJS({ + "node_modules/clean-git-ref/lib/index.js"(exports, module2) { + init_polyfill_buffer(); + "use strict"; + function escapeRegExp(string) { + return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); + } + function replaceAll(str, search, replacement) { + search = search instanceof RegExp ? search : new RegExp(escapeRegExp(search), "g"); + return str.replace(search, replacement); + } + var CleanGitRef = { + clean: function clean(value) { + if (typeof value !== "string") { + throw new Error("Expected a string, received: " + value); + } + value = replaceAll(value, "./", "/"); + value = replaceAll(value, "..", "."); + value = replaceAll(value, " ", "-"); + value = replaceAll(value, /^[~^:?*\\\-]/g, ""); + value = replaceAll(value, /[~^:?*\\]/g, "-"); + value = replaceAll(value, /[~^:?*\\\-]$/g, ""); + value = replaceAll(value, "@{", "-"); + value = replaceAll(value, /\.$/g, ""); + value = replaceAll(value, /\/$/g, ""); + value = replaceAll(value, /\.lock$/g, ""); + return value; + } + }; + module2.exports = CleanGitRef; + } +}); + +// node_modules/diff3/onp.js +var require_onp = __commonJS({ + "node_modules/diff3/onp.js"(exports, module2) { + init_polyfill_buffer(); + module2.exports = function(a_, b_) { + var a = a_, b = b_, m = a.length, n = b.length, reverse = false, ed = null, offset = m + 1, path2 = [], pathposi = [], ses = [], lcs = "", SES_DELETE = -1, SES_COMMON = 0, SES_ADD = 1; + var tmp1, tmp2; + var init3 = function() { + if (m >= n) { + tmp1 = a; + tmp2 = m; + a = b; + b = tmp1; + m = n; + n = tmp2; + reverse = true; + offset = m + 1; + } + }; + var P = function(x, y, k) { + return { + "x": x, + "y": y, + "k": k + }; + }; + var seselem = function(elem, t) { + return { + "elem": elem, + "t": t + }; + }; + var snake = function(k, p, pp) { + var r, x, y; + if (p > pp) { + r = path2[k - 1 + offset]; + } else { + r = path2[k + 1 + offset]; + } + y = Math.max(p, pp); + x = y - k; + while (x < m && y < n && a[x] === b[y]) { + ++x; + ++y; + } + path2[k + offset] = pathposi.length; + pathposi[pathposi.length] = new P(x, y, r); + return y; + }; + var recordseq = function(epc) { + var x_idx, y_idx, px_idx, py_idx, i; + x_idx = y_idx = 1; + px_idx = py_idx = 0; + for (i = epc.length - 1; i >= 0; --i) { + while (px_idx < epc[i].x || py_idx < epc[i].y) { + if (epc[i].y - epc[i].x > py_idx - px_idx) { + if (reverse) { + ses[ses.length] = new seselem(b[py_idx], SES_DELETE); + } else { + ses[ses.length] = new seselem(b[py_idx], SES_ADD); + } + ++y_idx; + ++py_idx; + } else if (epc[i].y - epc[i].x < py_idx - px_idx) { + if (reverse) { + ses[ses.length] = new seselem(a[px_idx], SES_ADD); + } else { + ses[ses.length] = new seselem(a[px_idx], SES_DELETE); + } + ++x_idx; + ++px_idx; + } else { + ses[ses.length] = new seselem(a[px_idx], SES_COMMON); + lcs += a[px_idx]; + ++x_idx; + ++y_idx; + ++px_idx; + ++py_idx; + } + } + } + }; + init3(); + return { + SES_DELETE: -1, + SES_COMMON: 0, + SES_ADD: 1, + editdistance: function() { + return ed; + }, + getlcs: function() { + return lcs; + }, + getses: function() { + return ses; + }, + compose: function() { + var delta, size, fp, p, r, epc, i, k; + delta = n - m; + size = m + n + 3; + fp = {}; + for (i = 0; i < size; ++i) { + fp[i] = -1; + path2[i] = -1; + } + p = -1; + do { + ++p; + for (k = -p; k <= delta - 1; ++k) { + fp[k + offset] = snake(k, fp[k - 1 + offset] + 1, fp[k + 1 + offset]); + } + for (k = delta + p; k >= delta + 1; --k) { + fp[k + offset] = snake(k, fp[k - 1 + offset] + 1, fp[k + 1 + offset]); + } + fp[delta + offset] = snake(delta, fp[delta - 1 + offset] + 1, fp[delta + 1 + offset]); + } while (fp[delta + offset] !== n); + ed = delta + 2 * p; + r = path2[delta + offset]; + epc = []; + while (r !== -1) { + epc[epc.length] = new P(pathposi[r].x, pathposi[r].y, null); + r = pathposi[r].k; + } + recordseq(epc); + } + }; + }; + } +}); + +// node_modules/diff3/diff3.js +var require_diff3 = __commonJS({ + "node_modules/diff3/diff3.js"(exports, module2) { + init_polyfill_buffer(); + var onp = require_onp(); + function longestCommonSubsequence(file1, file2) { + var diff2 = new onp(file1, file2); + diff2.compose(); + var ses = diff2.getses(); + var root; + var prev; + var file1RevIdx = file1.length - 1, file2RevIdx = file2.length - 1; + for (var i = ses.length - 1; i >= 0; --i) { + if (ses[i].t === diff2.SES_COMMON) { + if (prev) { + prev.chain = { + file1index: file1RevIdx, + file2index: file2RevIdx, + chain: null + }; + prev = prev.chain; + } else { + root = { + file1index: file1RevIdx, + file2index: file2RevIdx, + chain: null + }; + prev = root; + } + file1RevIdx--; + file2RevIdx--; + } else if (ses[i].t === diff2.SES_DELETE) { + file1RevIdx--; + } else if (ses[i].t === diff2.SES_ADD) { + file2RevIdx--; + } + } + var tail = { + file1index: -1, + file2index: -1, + chain: null + }; + if (!prev) { + return tail; + } + prev.chain = tail; + return root; + } + function diffIndices(file1, file2) { + var result = []; + var tail1 = file1.length; + var tail2 = file2.length; + for (var candidate = longestCommonSubsequence(file1, file2); candidate !== null; candidate = candidate.chain) { + var mismatchLength1 = tail1 - candidate.file1index - 1; + var mismatchLength2 = tail2 - candidate.file2index - 1; + tail1 = candidate.file1index; + tail2 = candidate.file2index; + if (mismatchLength1 || mismatchLength2) { + result.push({ + file1: [tail1 + 1, mismatchLength1], + file2: [tail2 + 1, mismatchLength2] + }); + } + } + result.reverse(); + return result; + } + function diff3MergeIndices(a, o, b) { + var i; + var m1 = diffIndices(o, a); + var m2 = diffIndices(o, b); + var hunks = []; + function addHunk(h, side2) { + hunks.push([h.file1[0], side2, h.file1[1], h.file2[0], h.file2[1]]); + } + for (i = 0; i < m1.length; i++) { + addHunk(m1[i], 0); + } + for (i = 0; i < m2.length; i++) { + addHunk(m2[i], 2); + } + hunks.sort(function(x, y) { + return x[0] - y[0]; + }); + var result = []; + var commonOffset = 0; + function copyCommon(targetOffset) { + if (targetOffset > commonOffset) { + result.push([1, commonOffset, targetOffset - commonOffset]); + commonOffset = targetOffset; + } + } + for (var hunkIndex = 0; hunkIndex < hunks.length; hunkIndex++) { + var firstHunkIndex = hunkIndex; + var hunk = hunks[hunkIndex]; + var regionLhs = hunk[0]; + var regionRhs = regionLhs + hunk[2]; + while (hunkIndex < hunks.length - 1) { + var maybeOverlapping = hunks[hunkIndex + 1]; + var maybeLhs = maybeOverlapping[0]; + if (maybeLhs > regionRhs) + break; + regionRhs = Math.max(regionRhs, maybeLhs + maybeOverlapping[2]); + hunkIndex++; + } + copyCommon(regionLhs); + if (firstHunkIndex == hunkIndex) { + if (hunk[4] > 0) { + result.push([hunk[1], hunk[3], hunk[4]]); + } + } else { + var regions = { + 0: [a.length, -1, o.length, -1], + 2: [b.length, -1, o.length, -1] + }; + for (i = firstHunkIndex; i <= hunkIndex; i++) { + hunk = hunks[i]; + var side = hunk[1]; + var r = regions[side]; + var oLhs = hunk[0]; + var oRhs = oLhs + hunk[2]; + var abLhs = hunk[3]; + var abRhs = abLhs + hunk[4]; + r[0] = Math.min(abLhs, r[0]); + r[1] = Math.max(abRhs, r[1]); + r[2] = Math.min(oLhs, r[2]); + r[3] = Math.max(oRhs, r[3]); + } + var aLhs = regions[0][0] + (regionLhs - regions[0][2]); + var aRhs = regions[0][1] + (regionRhs - regions[0][3]); + var bLhs = regions[2][0] + (regionLhs - regions[2][2]); + var bRhs = regions[2][1] + (regionRhs - regions[2][3]); + result.push([ + -1, + aLhs, + aRhs - aLhs, + regionLhs, + regionRhs - regionLhs, + bLhs, + bRhs - bLhs + ]); + } + commonOffset = regionRhs; + } + copyCommon(o.length); + return result; + } + function diff3Merge2(a, o, b) { + var result = []; + var files = [a, o, b]; + var indices = diff3MergeIndices(a, o, b); + var okLines = []; + function flushOk() { + if (okLines.length) { + result.push({ + ok: okLines + }); + } + okLines = []; + } + function pushOk(xs) { + for (var j = 0; j < xs.length; j++) { + okLines.push(xs[j]); + } + } + function isTrueConflict(rec) { + if (rec[2] != rec[6]) + return true; + var aoff = rec[1]; + var boff = rec[5]; + for (var j = 0; j < rec[2]; j++) { + if (a[j + aoff] != b[j + boff]) + return true; + } + return false; + } + for (var i = 0; i < indices.length; i++) { + var x = indices[i]; + var side = x[0]; + if (side == -1) { + if (!isTrueConflict(x)) { + pushOk(files[0].slice(x[1], x[1] + x[2])); + } else { + flushOk(); + result.push({ + conflict: { + a: a.slice(x[1], x[1] + x[2]), + aIndex: x[1], + o: o.slice(x[3], x[3] + x[4]), + oIndex: x[3], + b: b.slice(x[5], x[5] + x[6]), + bIndex: x[5] + } + }); + } + } else { + pushOk(files[side].slice(x[1], x[1] + x[2])); + } + } + flushOk(); + return result; + } + module2.exports = diff3Merge2; + } +}); // node_modules/ms/index.js var require_ms = __commonJS({ "node_modules/ms/index.js"(exports, module2) { + init_polyfill_buffer(); var s = 1e3; var m = s * 60; var h = m * 60; @@ -80,13 +7238,13 @@ var require_ms = __commonJS({ options = options || {}; var type = typeof val; if (type === "string" && val.length > 0) { - return parse(val); + return parse2(val); } else if (type === "number" && isFinite(val)) { return options.long ? fmtLong(val) : fmtShort(val); } throw new Error("val is not a non-empty string or a valid number. val=" + JSON.stringify(val)); }; - function parse(str) { + function parse2(str) { str = String(str); if (str.length > 100) { return; @@ -180,8 +7338,9 @@ var require_ms = __commonJS({ }); // node_modules/debug/src/common.js -var require_common = __commonJS({ +var require_common2 = __commonJS({ "node_modules/debug/src/common.js"(exports, module2) { + init_polyfill_buffer(); function setup(env) { createDebug.debug = createDebug; createDebug.default = createDebug; @@ -226,18 +7385,18 @@ var require_common = __commonJS({ if (typeof args[0] !== "string") { args.unshift("%O"); } - let index = 0; + let index2 = 0; args[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => { if (match === "%%") { return "%"; } - index++; + index2++; const formatter = createDebug.formatters[format]; if (typeof formatter === "function") { - const val = args[index]; + const val = args[index2]; match = formatter.call(self3, val); - args.splice(index, 1); - index--; + args.splice(index2, 1); + index2--; } return match; }); @@ -345,6 +7504,7 @@ var require_common = __commonJS({ // node_modules/debug/src/browser.js var require_browser = __commonJS({ "node_modules/debug/src/browser.js"(exports, module2) { + init_polyfill_buffer(); exports.formatArgs = formatArgs; exports.save = save; exports.load = load; @@ -453,15 +7613,15 @@ var require_browser = __commonJS({ } const c = "color: " + this.color; args.splice(1, 0, c, "color: inherit"); - let index = 0; + let index2 = 0; let lastC = 0; args[0].replace(/%[a-zA-Z%]/g, (match) => { if (match === "%%") { return; } - index++; + index2++; if (match === "%c") { - lastC = index; + lastC = index2; } }); args.splice(lastC, 0, c); @@ -495,7 +7655,7 @@ var require_browser = __commonJS({ } catch (error) { } } - module2.exports = require_common()(exports); + module2.exports = require_common2()(exports); var { formatters } = module2.exports; formatters.j = function(v) { try { @@ -507,334 +7667,38 @@ var require_browser = __commonJS({ } }); -// node_modules/has-flag/index.js -var require_has_flag = __commonJS({ - "node_modules/has-flag/index.js"(exports, module2) { - "use strict"; - module2.exports = (flag, argv = process.argv) => { - const prefix = flag.startsWith("-") ? "" : flag.length === 1 ? "-" : "--"; - const position = argv.indexOf(prefix + flag); - const terminatorPosition = argv.indexOf("--"); - return position !== -1 && (terminatorPosition === -1 || position < terminatorPosition); - }; - } -}); - -// node_modules/supports-color/index.js -var require_supports_color = __commonJS({ - "node_modules/supports-color/index.js"(exports, module2) { - "use strict"; - var os = require("os"); - var tty = require("tty"); - var hasFlag = require_has_flag(); - var { env } = process; - var forceColor; - if (hasFlag("no-color") || hasFlag("no-colors") || hasFlag("color=false") || hasFlag("color=never")) { - forceColor = 0; - } else if (hasFlag("color") || hasFlag("colors") || hasFlag("color=true") || hasFlag("color=always")) { - forceColor = 1; - } - if ("FORCE_COLOR" in env) { - if (env.FORCE_COLOR === "true") { - forceColor = 1; - } else if (env.FORCE_COLOR === "false") { - forceColor = 0; - } else { - forceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3); - } - } - function translateLevel(level) { - if (level === 0) { - return false; - } - return { - level, - hasBasic: true, - has256: level >= 2, - has16m: level >= 3 - }; - } - function supportsColor(haveStream, streamIsTTY) { - if (forceColor === 0) { - return 0; - } - if (hasFlag("color=16m") || hasFlag("color=full") || hasFlag("color=truecolor")) { - return 3; - } - if (hasFlag("color=256")) { - return 2; - } - if (haveStream && !streamIsTTY && forceColor === void 0) { - return 0; - } - const min = forceColor || 0; - if (env.TERM === "dumb") { - return min; - } - if (process.platform === "win32") { - const osRelease = os.release().split("."); - if (Number(osRelease[0]) >= 10 && Number(osRelease[2]) >= 10586) { - return Number(osRelease[2]) >= 14931 ? 3 : 2; - } - return 1; - } - if ("CI" in env) { - if (["TRAVIS", "CIRCLECI", "APPVEYOR", "GITLAB_CI", "GITHUB_ACTIONS", "BUILDKITE"].some((sign) => sign in env) || env.CI_NAME === "codeship") { - return 1; - } - return min; - } - if ("TEAMCITY_VERSION" in env) { - return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0; - } - if (env.COLORTERM === "truecolor") { - return 3; - } - if ("TERM_PROGRAM" in env) { - const version = parseInt((env.TERM_PROGRAM_VERSION || "").split(".")[0], 10); - switch (env.TERM_PROGRAM) { - case "iTerm.app": - return version >= 3 ? 3 : 2; - case "Apple_Terminal": - return 2; - } - } - if (/-256(color)?$/i.test(env.TERM)) { - return 2; - } - if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) { - return 1; - } - if ("COLORTERM" in env) { - return 1; - } - return min; - } - function getSupportLevel(stream) { - const level = supportsColor(stream, stream && stream.isTTY); - return translateLevel(level); - } - module2.exports = { - supportsColor: getSupportLevel, - stdout: translateLevel(supportsColor(true, tty.isatty(1))), - stderr: translateLevel(supportsColor(true, tty.isatty(2))) - }; - } -}); - -// node_modules/debug/src/node.js -var require_node = __commonJS({ - "node_modules/debug/src/node.js"(exports, module2) { - var tty = require("tty"); - var util = require("util"); - exports.init = init2; - exports.log = log; - exports.formatArgs = formatArgs; - exports.save = save; - exports.load = load; - exports.useColors = useColors; - exports.destroy = util.deprecate(() => { - }, "Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."); - exports.colors = [6, 2, 3, 4, 5, 1]; - try { - const supportsColor = require_supports_color(); - if (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) { - exports.colors = [ - 20, - 21, - 26, - 27, - 32, - 33, - 38, - 39, - 40, - 41, - 42, - 43, - 44, - 45, - 56, - 57, - 62, - 63, - 68, - 69, - 74, - 75, - 76, - 77, - 78, - 79, - 80, - 81, - 92, - 93, - 98, - 99, - 112, - 113, - 128, - 129, - 134, - 135, - 148, - 149, - 160, - 161, - 162, - 163, - 164, - 165, - 166, - 167, - 168, - 169, - 170, - 171, - 172, - 173, - 178, - 179, - 184, - 185, - 196, - 197, - 198, - 199, - 200, - 201, - 202, - 203, - 204, - 205, - 206, - 207, - 208, - 209, - 214, - 215, - 220, - 221 - ]; - } - } catch (error) { - } - exports.inspectOpts = Object.keys(process.env).filter((key2) => { - return /^debug_/i.test(key2); - }).reduce((obj, key2) => { - const prop = key2.substring(6).toLowerCase().replace(/_([a-z])/g, (_, k) => { - return k.toUpperCase(); - }); - let val = process.env[key2]; - if (/^(yes|on|true|enabled)$/i.test(val)) { - val = true; - } else if (/^(no|off|false|disabled)$/i.test(val)) { - val = false; - } else if (val === "null") { - val = null; - } else { - val = Number(val); - } - obj[prop] = val; - return obj; - }, {}); - function useColors() { - return "colors" in exports.inspectOpts ? Boolean(exports.inspectOpts.colors) : tty.isatty(process.stderr.fd); - } - function formatArgs(args) { - const { namespace: name, useColors: useColors2 } = this; - if (useColors2) { - const c = this.color; - const colorCode = "[3" + (c < 8 ? c : "8;5;" + c); - const prefix = ` ${colorCode};1m${name} `; - args[0] = prefix + args[0].split("\n").join("\n" + prefix); - args.push(colorCode + "m+" + module2.exports.humanize(this.diff) + ""); - } else { - args[0] = getDate() + name + " " + args[0]; - } - } - function getDate() { - if (exports.inspectOpts.hideDate) { - return ""; - } - return new Date().toISOString() + " "; - } - function log(...args) { - return process.stderr.write(util.format(...args) + "\n"); - } - function save(namespaces) { - if (namespaces) { - process.env.DEBUG = namespaces; - } else { - delete process.env.DEBUG; - } - } - function load() { - return process.env.DEBUG; - } - function init2(debug2) { - debug2.inspectOpts = {}; - const keys = Object.keys(exports.inspectOpts); - for (let i = 0; i < keys.length; i++) { - debug2.inspectOpts[keys[i]] = exports.inspectOpts[keys[i]]; - } - } - module2.exports = require_common()(exports); - var { formatters } = module2.exports; - formatters.o = function(v) { - this.inspectOpts.colors = this.useColors; - return util.inspect(v, this.inspectOpts).split("\n").map((str) => str.trim()).join(" "); - }; - formatters.O = function(v) { - this.inspectOpts.colors = this.useColors; - return util.inspect(v, this.inspectOpts); - }; - } -}); - -// node_modules/debug/src/index.js -var require_src = __commonJS({ - "node_modules/debug/src/index.js"(exports, module2) { - if (typeof process === "undefined" || process.type === "renderer" || process.browser === true || process.__nwjs) { - module2.exports = require_browser(); - } else { - module2.exports = require_node(); - } - } -}); - // node_modules/@kwsites/file-exists/dist/src/index.js -var require_src2 = __commonJS({ +var require_src = __commonJS({ "node_modules/@kwsites/file-exists/dist/src/index.js"(exports) { + init_polyfill_buffer(); "use strict"; - var __importDefault2 = exports && exports.__importDefault || function(mod) { + var __importDefault = exports && exports.__importDefault || function(mod) { return mod && mod.__esModule ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); var fs_1 = require("fs"); - var debug_1 = __importDefault2(require_src()); - var log = debug_1.default("@kwsites/file-exists"); + var debug_1 = __importDefault(require_browser()); + var log2 = debug_1.default("@kwsites/file-exists"); function check(path2, isFile, isDirectory) { - log(`checking %s`, path2); + log2(`checking %s`, path2); try { const stat = fs_1.statSync(path2); if (stat.isFile() && isFile) { - log(`[OK] path represents a file`); + log2(`[OK] path represents a file`); return true; } if (stat.isDirectory() && isDirectory) { - log(`[OK] path represents a directory`); + log2(`[OK] path represents a directory`); return true; } - log(`[FAIL] path represents something other than a file or directory`); + log2(`[FAIL] path represents something other than a file or directory`); return false; } catch (e) { if (e.code === "ENOENT") { - log(`[FAIL] path is not accessible: %o`, e); + log2(`[FAIL] path is not accessible: %o`, e); return false; } - log(`[FATAL] %o`, e); + log2(`[FATAL] %o`, e); throw e; } } @@ -851,6 +7715,7 @@ var require_src2 = __commonJS({ // node_modules/@kwsites/file-exists/dist/index.js var require_dist = __commonJS({ "node_modules/@kwsites/file-exists/dist/index.js"(exports) { + init_polyfill_buffer(); "use strict"; function __export3(m) { for (var p in m) @@ -858,20 +7723,21 @@ var require_dist = __commonJS({ exports[p] = m[p]; } Object.defineProperty(exports, "__esModule", { value: true }); - __export3(require_src2()); + __export3(require_src()); } }); // node_modules/@kwsites/promise-deferred/dist/index.js var require_dist2 = __commonJS({ "node_modules/@kwsites/promise-deferred/dist/index.js"(exports) { + init_polyfill_buffer(); "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.createDeferred = exports.deferred = void 0; function deferred2() { let done; let fail; - let status = "pending"; + let status2 = "pending"; const promise2 = new Promise((_done, _fail) => { done = _done; fail = _fail; @@ -879,22 +7745,22 @@ var require_dist2 = __commonJS({ return { promise: promise2, done(result) { - if (status === "pending") { - status = "resolved"; + if (status2 === "pending") { + status2 = "resolved"; done(result); } }, fail(error) { - if (status === "pending") { - status = "rejected"; + if (status2 === "pending") { + status2 = "rejected"; fail(error); } }, get fulfilled() { - return status !== "pending"; + return status2 !== "pending"; }, get status() { - return status; + return status2; } }; } @@ -904,2835 +7770,13 @@ var require_dist2 = __commonJS({ } }); -// node_modules/diff2html/lib/types.js -var require_types = __commonJS({ - "node_modules/diff2html/lib/types.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.DiffStyleType = exports.LineMatchingType = exports.OutputFormatType = exports.LineType = void 0; - var LineType; - (function(LineType2) { - LineType2["INSERT"] = "insert"; - LineType2["DELETE"] = "delete"; - LineType2["CONTEXT"] = "context"; - })(LineType = exports.LineType || (exports.LineType = {})); - exports.OutputFormatType = { - LINE_BY_LINE: "line-by-line", - SIDE_BY_SIDE: "side-by-side" - }; - exports.LineMatchingType = { - LINES: "lines", - WORDS: "words", - NONE: "none" - }; - exports.DiffStyleType = { - WORD: "word", - CHAR: "char" - }; - } -}); - -// node_modules/diff2html/lib/utils.js -var require_utils = __commonJS({ - "node_modules/diff2html/lib/utils.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.hashCode = exports.unifyPath = exports.escapeForRegExp = void 0; - var specials = [ - "-", - "[", - "]", - "/", - "{", - "}", - "(", - ")", - "*", - "+", - "?", - ".", - "\\", - "^", - "$", - "|" - ]; - var regex = RegExp("[" + specials.join("\\") + "]", "g"); - function escapeForRegExp(str) { - return str.replace(regex, "\\$&"); - } - exports.escapeForRegExp = escapeForRegExp; - function unifyPath(path2) { - return path2 ? path2.replace(/\\/g, "/") : path2; - } - exports.unifyPath = unifyPath; - function hashCode(text2) { - var i, chr, len; - var hash2 = 0; - for (i = 0, len = text2.length; i < len; i++) { - chr = text2.charCodeAt(i); - hash2 = (hash2 << 5) - hash2 + chr; - hash2 |= 0; - } - return hash2; - } - exports.hashCode = hashCode; - } -}); - -// node_modules/diff2html/lib/diff-parser.js -var require_diff_parser = __commonJS({ - "node_modules/diff2html/lib/diff-parser.js"(exports) { - "use strict"; - var __spreadArray2 = exports && exports.__spreadArray || function(to, from, pack) { - if (pack || arguments.length === 2) - for (var i = 0, l = from.length, ar; i < l; i++) { - if (ar || !(i in from)) { - if (!ar) - ar = Array.prototype.slice.call(from, 0, i); - ar[i] = from[i]; - } - } - return to.concat(ar || Array.prototype.slice.call(from)); - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.parse = void 0; - var types_1 = require_types(); - var utils_1 = require_utils(); - function getExtension(filename, language) { - var filenameParts = filename.split("."); - return filenameParts.length > 1 ? filenameParts[filenameParts.length - 1] : language; - } - function startsWithAny(str, prefixes) { - return prefixes.reduce(function(startsWith, prefix) { - return startsWith || str.startsWith(prefix); - }, false); - } - var baseDiffFilenamePrefixes = ["a/", "b/", "i/", "w/", "c/", "o/"]; - function getFilename(line, linePrefix, extraPrefix) { - var prefixes = extraPrefix !== void 0 ? __spreadArray2(__spreadArray2([], baseDiffFilenamePrefixes, true), [extraPrefix], false) : baseDiffFilenamePrefixes; - var FilenameRegExp = linePrefix ? new RegExp("^".concat((0, utils_1.escapeForRegExp)(linePrefix), ' "?(.+?)"?$')) : new RegExp('^"?(.+?)"?$'); - var _a2 = FilenameRegExp.exec(line) || [], _b = _a2[1], filename = _b === void 0 ? "" : _b; - var matchingPrefix = prefixes.find(function(p) { - return filename.indexOf(p) === 0; - }); - var fnameWithoutPrefix = matchingPrefix ? filename.slice(matchingPrefix.length) : filename; - return fnameWithoutPrefix.replace(/\s+\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}(?:\.\d+)? [+-]\d{4}.*$/, ""); - } - function getSrcFilename(line, srcPrefix) { - return getFilename(line, "---", srcPrefix); - } - function getDstFilename(line, dstPrefix) { - return getFilename(line, "+++", dstPrefix); - } - function parse(diffInput, config) { - if (config === void 0) { - config = {}; - } - var files = []; - var currentFile = null; - var currentBlock = null; - var oldLine = null; - var oldLine2 = null; - var newLine = null; - var possibleOldName = null; - var possibleNewName = null; - var oldFileNameHeader = "--- "; - var newFileNameHeader = "+++ "; - var hunkHeaderPrefix = "@@"; - var oldMode = /^old mode (\d{6})/; - var newMode = /^new mode (\d{6})/; - var deletedFileMode = /^deleted file mode (\d{6})/; - var newFileMode = /^new file mode (\d{6})/; - var copyFrom = /^copy from "?(.+)"?/; - var copyTo = /^copy to "?(.+)"?/; - var renameFrom = /^rename from "?(.+)"?/; - var renameTo = /^rename to "?(.+)"?/; - var similarityIndex = /^similarity index (\d+)%/; - var dissimilarityIndex = /^dissimilarity index (\d+)%/; - var index = /^index ([\da-z]+)\.\.([\da-z]+)\s*(\d{6})?/; - var binaryFiles = /^Binary files (.*) and (.*) differ/; - var binaryDiff = /^GIT binary patch/; - var combinedIndex = /^index ([\da-z]+),([\da-z]+)\.\.([\da-z]+)/; - var combinedMode = /^mode (\d{6}),(\d{6})\.\.(\d{6})/; - var combinedNewFile = /^new file mode (\d{6})/; - var combinedDeletedFile = /^deleted file mode (\d{6}),(\d{6})/; - var diffLines = diffInput.replace(/\\ No newline at end of file/g, "").replace(/\r\n?/g, "\n").split("\n"); - function saveBlock() { - if (currentBlock !== null && currentFile !== null) { - currentFile.blocks.push(currentBlock); - currentBlock = null; - } - } - function saveFile() { - if (currentFile !== null) { - if (!currentFile.oldName && possibleOldName !== null) { - currentFile.oldName = possibleOldName; - } - if (!currentFile.newName && possibleNewName !== null) { - currentFile.newName = possibleNewName; - } - if (currentFile.newName) { - files.push(currentFile); - currentFile = null; - } - } - possibleOldName = null; - possibleNewName = null; - } - function startFile() { - saveBlock(); - saveFile(); - currentFile = { - blocks: [], - deletedLines: 0, - addedLines: 0 - }; - } - function startBlock(line) { - saveBlock(); - var values; - if (currentFile !== null) { - if (values = /^@@ -(\d+)(?:,\d+)? \+(\d+)(?:,\d+)? @@.*/.exec(line)) { - currentFile.isCombined = false; - oldLine = parseInt(values[1], 10); - newLine = parseInt(values[2], 10); - } else if (values = /^@@@ -(\d+)(?:,\d+)? -(\d+)(?:,\d+)? \+(\d+)(?:,\d+)? @@@.*/.exec(line)) { - currentFile.isCombined = true; - oldLine = parseInt(values[1], 10); - oldLine2 = parseInt(values[2], 10); - newLine = parseInt(values[3], 10); - } else { - if (line.startsWith(hunkHeaderPrefix)) { - console.error("Failed to parse lines, starting in 0!"); - } - oldLine = 0; - newLine = 0; - currentFile.isCombined = false; - } - } - currentBlock = { - lines: [], - oldStartLine: oldLine, - oldStartLine2: oldLine2, - newStartLine: newLine, - header: line - }; - } - function createLine(line) { - if (currentFile === null || currentBlock === null || oldLine === null || newLine === null) - return; - var currentLine = { - content: line - }; - var addedPrefixes = currentFile.isCombined ? ["+ ", " +", "++"] : ["+"]; - var deletedPrefixes = currentFile.isCombined ? ["- ", " -", "--"] : ["-"]; - if (startsWithAny(line, addedPrefixes)) { - currentFile.addedLines++; - currentLine.type = types_1.LineType.INSERT; - currentLine.oldNumber = void 0; - currentLine.newNumber = newLine++; - } else if (startsWithAny(line, deletedPrefixes)) { - currentFile.deletedLines++; - currentLine.type = types_1.LineType.DELETE; - currentLine.oldNumber = oldLine++; - currentLine.newNumber = void 0; - } else { - currentLine.type = types_1.LineType.CONTEXT; - currentLine.oldNumber = oldLine++; - currentLine.newNumber = newLine++; - } - currentBlock.lines.push(currentLine); - } - function existHunkHeader(line, lineIdx) { - var idx = lineIdx; - while (idx < diffLines.length - 3) { - if (line.startsWith("diff")) { - return false; - } - if (diffLines[idx].startsWith(oldFileNameHeader) && diffLines[idx + 1].startsWith(newFileNameHeader) && diffLines[idx + 2].startsWith(hunkHeaderPrefix)) { - return true; - } - idx++; - } - return false; - } - diffLines.forEach(function(line, lineIndex) { - if (!line || line.startsWith("*")) { - return; - } - var values; - var prevLine = diffLines[lineIndex - 1]; - var nxtLine = diffLines[lineIndex + 1]; - var afterNxtLine = diffLines[lineIndex + 2]; - if (line.startsWith("diff")) { - startFile(); - var gitDiffStart = /^diff --git "?([a-ciow]\/.+)"? "?([a-ciow]\/.+)"?/; - if (values = gitDiffStart.exec(line)) { - possibleOldName = getFilename(values[1], void 0, config.dstPrefix); - possibleNewName = getFilename(values[2], void 0, config.srcPrefix); - } - if (currentFile === null) { - throw new Error("Where is my file !!!"); - } - currentFile.isGitDiff = true; - return; - } - if (!currentFile || !currentFile.isGitDiff && currentFile && line.startsWith(oldFileNameHeader) && nxtLine.startsWith(newFileNameHeader) && afterNxtLine.startsWith(hunkHeaderPrefix)) { - startFile(); - } - if (currentFile === null || currentFile === void 0 ? void 0 : currentFile.isTooBig) { - return; - } - if (currentFile && (typeof config.diffMaxChanges === "number" && currentFile.addedLines + currentFile.deletedLines > config.diffMaxChanges || typeof config.diffMaxLineLength === "number" && line.length > config.diffMaxLineLength)) { - currentFile.isTooBig = true; - currentFile.addedLines = 0; - currentFile.deletedLines = 0; - currentFile.blocks = []; - currentBlock = null; - var message = typeof config.diffTooBigMessage === "function" ? config.diffTooBigMessage(files.length) : "Diff too big to be displayed"; - startBlock(message); - return; - } - if (line.startsWith(oldFileNameHeader) && nxtLine.startsWith(newFileNameHeader) || line.startsWith(newFileNameHeader) && prevLine.startsWith(oldFileNameHeader)) { - if (currentFile && !currentFile.oldName && line.startsWith("--- ") && (values = getSrcFilename(line, config.srcPrefix))) { - currentFile.oldName = values; - currentFile.language = getExtension(currentFile.oldName, currentFile.language); - return; - } - if (currentFile && !currentFile.newName && line.startsWith("+++ ") && (values = getDstFilename(line, config.dstPrefix))) { - currentFile.newName = values; - currentFile.language = getExtension(currentFile.newName, currentFile.language); - return; - } - } - if (currentFile && (line.startsWith(hunkHeaderPrefix) || currentFile.isGitDiff && currentFile.oldName && currentFile.newName && !currentBlock)) { - startBlock(line); - return; - } - if (currentBlock && (line.startsWith("+") || line.startsWith("-") || line.startsWith(" "))) { - createLine(line); - return; - } - var doesNotExistHunkHeader = !existHunkHeader(line, lineIndex); - if (currentFile === null) { - throw new Error("Where is my file !!!"); - } - if (values = oldMode.exec(line)) { - currentFile.oldMode = values[1]; - } else if (values = newMode.exec(line)) { - currentFile.newMode = values[1]; - } else if (values = deletedFileMode.exec(line)) { - currentFile.deletedFileMode = values[1]; - currentFile.isDeleted = true; - } else if (values = newFileMode.exec(line)) { - currentFile.newFileMode = values[1]; - currentFile.isNew = true; - } else if (values = copyFrom.exec(line)) { - if (doesNotExistHunkHeader) { - currentFile.oldName = values[1]; - } - currentFile.isCopy = true; - } else if (values = copyTo.exec(line)) { - if (doesNotExistHunkHeader) { - currentFile.newName = values[1]; - } - currentFile.isCopy = true; - } else if (values = renameFrom.exec(line)) { - if (doesNotExistHunkHeader) { - currentFile.oldName = values[1]; - } - currentFile.isRename = true; - } else if (values = renameTo.exec(line)) { - if (doesNotExistHunkHeader) { - currentFile.newName = values[1]; - } - currentFile.isRename = true; - } else if (values = binaryFiles.exec(line)) { - currentFile.isBinary = true; - currentFile.oldName = getFilename(values[1], void 0, config.srcPrefix); - currentFile.newName = getFilename(values[2], void 0, config.dstPrefix); - startBlock("Binary file"); - } else if (binaryDiff.test(line)) { - currentFile.isBinary = true; - startBlock(line); - } else if (values = similarityIndex.exec(line)) { - currentFile.unchangedPercentage = parseInt(values[1], 10); - } else if (values = dissimilarityIndex.exec(line)) { - currentFile.changedPercentage = parseInt(values[1], 10); - } else if (values = index.exec(line)) { - currentFile.checksumBefore = values[1]; - currentFile.checksumAfter = values[2]; - values[3] && (currentFile.mode = values[3]); - } else if (values = combinedIndex.exec(line)) { - currentFile.checksumBefore = [values[2], values[3]]; - currentFile.checksumAfter = values[1]; - } else if (values = combinedMode.exec(line)) { - currentFile.oldMode = [values[2], values[3]]; - currentFile.newMode = values[1]; - } else if (values = combinedNewFile.exec(line)) { - currentFile.newFileMode = values[1]; - currentFile.isNew = true; - } else if (values = combinedDeletedFile.exec(line)) { - currentFile.deletedFileMode = values[1]; - currentFile.isDeleted = true; - } - }); - saveBlock(); - saveFile(); - return files; - } - exports.parse = parse; - } -}); - -// node_modules/diff/lib/diff/base.js -var require_base = __commonJS({ - "node_modules/diff/lib/diff/base.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports["default"] = Diff; - function Diff() { - } - Diff.prototype = { - diff: function diff(oldString, newString) { - var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; - var callback = options.callback; - if (typeof options === "function") { - callback = options; - options = {}; - } - this.options = options; - var self3 = this; - function done(value) { - if (callback) { - setTimeout(function() { - callback(void 0, value); - }, 0); - return true; - } else { - return value; - } - } - oldString = this.castInput(oldString); - newString = this.castInput(newString); - oldString = this.removeEmpty(this.tokenize(oldString)); - newString = this.removeEmpty(this.tokenize(newString)); - var newLen = newString.length, oldLen = oldString.length; - var editLength = 1; - var maxEditLength = newLen + oldLen; - if (options.maxEditLength) { - maxEditLength = Math.min(maxEditLength, options.maxEditLength); - } - var bestPath = [{ - newPos: -1, - components: [] - }]; - var oldPos = this.extractCommon(bestPath[0], newString, oldString, 0); - if (bestPath[0].newPos + 1 >= newLen && oldPos + 1 >= oldLen) { - return done([{ - value: this.join(newString), - count: newString.length - }]); - } - function execEditLength() { - for (var diagonalPath = -1 * editLength; diagonalPath <= editLength; diagonalPath += 2) { - var basePath = void 0; - var addPath = bestPath[diagonalPath - 1], removePath = bestPath[diagonalPath + 1], _oldPos = (removePath ? removePath.newPos : 0) - diagonalPath; - if (addPath) { - bestPath[diagonalPath - 1] = void 0; - } - var canAdd = addPath && addPath.newPos + 1 < newLen, canRemove = removePath && 0 <= _oldPos && _oldPos < oldLen; - if (!canAdd && !canRemove) { - bestPath[diagonalPath] = void 0; - continue; - } - if (!canAdd || canRemove && addPath.newPos < removePath.newPos) { - basePath = clonePath(removePath); - self3.pushComponent(basePath.components, void 0, true); - } else { - basePath = addPath; - basePath.newPos++; - self3.pushComponent(basePath.components, true, void 0); - } - _oldPos = self3.extractCommon(basePath, newString, oldString, diagonalPath); - if (basePath.newPos + 1 >= newLen && _oldPos + 1 >= oldLen) { - return done(buildValues(self3, basePath.components, newString, oldString, self3.useLongestToken)); - } else { - bestPath[diagonalPath] = basePath; - } - } - editLength++; - } - if (callback) { - (function exec() { - setTimeout(function() { - if (editLength > maxEditLength) { - return callback(); - } - if (!execEditLength()) { - exec(); - } - }, 0); - })(); - } else { - while (editLength <= maxEditLength) { - var ret = execEditLength(); - if (ret) { - return ret; - } - } - } - }, - pushComponent: function pushComponent(components, added, removed) { - var last2 = components[components.length - 1]; - if (last2 && last2.added === added && last2.removed === removed) { - components[components.length - 1] = { - count: last2.count + 1, - added, - removed - }; - } else { - components.push({ - count: 1, - added, - removed - }); - } - }, - extractCommon: function extractCommon(basePath, newString, oldString, diagonalPath) { - var newLen = newString.length, oldLen = oldString.length, newPos = basePath.newPos, oldPos = newPos - diagonalPath, commonCount = 0; - while (newPos + 1 < newLen && oldPos + 1 < oldLen && this.equals(newString[newPos + 1], oldString[oldPos + 1])) { - newPos++; - oldPos++; - commonCount++; - } - if (commonCount) { - basePath.components.push({ - count: commonCount - }); - } - basePath.newPos = newPos; - return oldPos; - }, - equals: function equals(left, right) { - if (this.options.comparator) { - return this.options.comparator(left, right); - } else { - return left === right || this.options.ignoreCase && left.toLowerCase() === right.toLowerCase(); - } - }, - removeEmpty: function removeEmpty(array) { - var ret = []; - for (var i = 0; i < array.length; i++) { - if (array[i]) { - ret.push(array[i]); - } - } - return ret; - }, - castInput: function castInput(value) { - return value; - }, - tokenize: function tokenize(value) { - return value.split(""); - }, - join: function join2(chars) { - return chars.join(""); - } - }; - function buildValues(diff, components, newString, oldString, useLongestToken) { - var componentPos = 0, componentLen = components.length, newPos = 0, oldPos = 0; - for (; componentPos < componentLen; componentPos++) { - var component = components[componentPos]; - if (!component.removed) { - if (!component.added && useLongestToken) { - var value = newString.slice(newPos, newPos + component.count); - value = value.map(function(value2, i) { - var oldValue = oldString[oldPos + i]; - return oldValue.length > value2.length ? oldValue : value2; - }); - component.value = diff.join(value); - } else { - component.value = diff.join(newString.slice(newPos, newPos + component.count)); - } - newPos += component.count; - if (!component.added) { - oldPos += component.count; - } - } else { - component.value = diff.join(oldString.slice(oldPos, oldPos + component.count)); - oldPos += component.count; - if (componentPos && components[componentPos - 1].added) { - var tmp = components[componentPos - 1]; - components[componentPos - 1] = components[componentPos]; - components[componentPos] = tmp; - } - } - } - var lastComponent = components[componentLen - 1]; - if (componentLen > 1 && typeof lastComponent.value === "string" && (lastComponent.added || lastComponent.removed) && diff.equals("", lastComponent.value)) { - components[componentLen - 2].value += lastComponent.value; - components.pop(); - } - return components; - } - function clonePath(path2) { - return { - newPos: path2.newPos, - components: path2.components.slice(0) - }; - } - } -}); - -// node_modules/diff/lib/diff/character.js -var require_character = __commonJS({ - "node_modules/diff/lib/diff/character.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffChars = diffChars; - exports.characterDiff = void 0; - var _base = _interopRequireDefault(require_base()); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - var characterDiff = new _base["default"](); - exports.characterDiff = characterDiff; - function diffChars(oldStr, newStr, options) { - return characterDiff.diff(oldStr, newStr, options); - } - } -}); - -// node_modules/diff/lib/util/params.js -var require_params = __commonJS({ - "node_modules/diff/lib/util/params.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.generateOptions = generateOptions; - function generateOptions(options, defaults) { - if (typeof options === "function") { - defaults.callback = options; - } else if (options) { - for (var name in options) { - if (options.hasOwnProperty(name)) { - defaults[name] = options[name]; - } - } - } - return defaults; - } - } -}); - -// node_modules/diff/lib/diff/word.js -var require_word = __commonJS({ - "node_modules/diff/lib/diff/word.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffWords = diffWords; - exports.diffWordsWithSpace = diffWordsWithSpace; - exports.wordDiff = void 0; - var _base = _interopRequireDefault(require_base()); - var _params = require_params(); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - var extendedWordChars = /^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/; - var reWhitespace = /\S/; - var wordDiff = new _base["default"](); - exports.wordDiff = wordDiff; - wordDiff.equals = function(left, right) { - if (this.options.ignoreCase) { - left = left.toLowerCase(); - right = right.toLowerCase(); - } - return left === right || this.options.ignoreWhitespace && !reWhitespace.test(left) && !reWhitespace.test(right); - }; - wordDiff.tokenize = function(value) { - var tokens = value.split(/([^\S\r\n]+|[()[\]{}'"\r\n]|\b)/); - for (var i = 0; i < tokens.length - 1; i++) { - if (!tokens[i + 1] && tokens[i + 2] && extendedWordChars.test(tokens[i]) && extendedWordChars.test(tokens[i + 2])) { - tokens[i] += tokens[i + 2]; - tokens.splice(i + 1, 2); - i--; - } - } - return tokens; - }; - function diffWords(oldStr, newStr, options) { - options = (0, _params.generateOptions)(options, { - ignoreWhitespace: true - }); - return wordDiff.diff(oldStr, newStr, options); - } - function diffWordsWithSpace(oldStr, newStr, options) { - return wordDiff.diff(oldStr, newStr, options); - } - } -}); - -// node_modules/diff/lib/diff/line.js -var require_line = __commonJS({ - "node_modules/diff/lib/diff/line.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffLines = diffLines; - exports.diffTrimmedLines = diffTrimmedLines; - exports.lineDiff = void 0; - var _base = _interopRequireDefault(require_base()); - var _params = require_params(); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - var lineDiff = new _base["default"](); - exports.lineDiff = lineDiff; - lineDiff.tokenize = function(value) { - var retLines = [], linesAndNewlines = value.split(/(\n|\r\n)/); - if (!linesAndNewlines[linesAndNewlines.length - 1]) { - linesAndNewlines.pop(); - } - for (var i = 0; i < linesAndNewlines.length; i++) { - var line = linesAndNewlines[i]; - if (i % 2 && !this.options.newlineIsToken) { - retLines[retLines.length - 1] += line; - } else { - if (this.options.ignoreWhitespace) { - line = line.trim(); - } - retLines.push(line); - } - } - return retLines; - }; - function diffLines(oldStr, newStr, callback) { - return lineDiff.diff(oldStr, newStr, callback); - } - function diffTrimmedLines(oldStr, newStr, callback) { - var options = (0, _params.generateOptions)(callback, { - ignoreWhitespace: true - }); - return lineDiff.diff(oldStr, newStr, options); - } - } -}); - -// node_modules/diff/lib/diff/sentence.js -var require_sentence = __commonJS({ - "node_modules/diff/lib/diff/sentence.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffSentences = diffSentences; - exports.sentenceDiff = void 0; - var _base = _interopRequireDefault(require_base()); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - var sentenceDiff = new _base["default"](); - exports.sentenceDiff = sentenceDiff; - sentenceDiff.tokenize = function(value) { - return value.split(/(\S.+?[.!?])(?=\s+|$)/); - }; - function diffSentences(oldStr, newStr, callback) { - return sentenceDiff.diff(oldStr, newStr, callback); - } - } -}); - -// node_modules/diff/lib/diff/css.js -var require_css = __commonJS({ - "node_modules/diff/lib/diff/css.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffCss = diffCss; - exports.cssDiff = void 0; - var _base = _interopRequireDefault(require_base()); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - var cssDiff = new _base["default"](); - exports.cssDiff = cssDiff; - cssDiff.tokenize = function(value) { - return value.split(/([{}:;,]|\s+)/); - }; - function diffCss(oldStr, newStr, callback) { - return cssDiff.diff(oldStr, newStr, callback); - } - } -}); - -// node_modules/diff/lib/diff/json.js -var require_json = __commonJS({ - "node_modules/diff/lib/diff/json.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffJson = diffJson; - exports.canonicalize = canonicalize; - exports.jsonDiff = void 0; - var _base = _interopRequireDefault(require_base()); - var _line = require_line(); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - function _typeof(obj) { - "@babel/helpers - typeof"; - if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { - _typeof = function _typeof2(obj2) { - return typeof obj2; - }; - } else { - _typeof = function _typeof2(obj2) { - return obj2 && typeof Symbol === "function" && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2; - }; - } - return _typeof(obj); - } - var objectPrototypeToString = Object.prototype.toString; - var jsonDiff = new _base["default"](); - exports.jsonDiff = jsonDiff; - jsonDiff.useLongestToken = true; - jsonDiff.tokenize = _line.lineDiff.tokenize; - jsonDiff.castInput = function(value) { - var _this$options = this.options, undefinedReplacement = _this$options.undefinedReplacement, _this$options$stringi = _this$options.stringifyReplacer, stringifyReplacer = _this$options$stringi === void 0 ? function(k, v) { - return typeof v === "undefined" ? undefinedReplacement : v; - } : _this$options$stringi; - return typeof value === "string" ? value : JSON.stringify(canonicalize(value, null, null, stringifyReplacer), stringifyReplacer, " "); - }; - jsonDiff.equals = function(left, right) { - return _base["default"].prototype.equals.call(jsonDiff, left.replace(/,([\r\n])/g, "$1"), right.replace(/,([\r\n])/g, "$1")); - }; - function diffJson(oldObj, newObj, options) { - return jsonDiff.diff(oldObj, newObj, options); - } - function canonicalize(obj, stack, replacementStack, replacer, key2) { - stack = stack || []; - replacementStack = replacementStack || []; - if (replacer) { - obj = replacer(key2, obj); - } - var i; - for (i = 0; i < stack.length; i += 1) { - if (stack[i] === obj) { - return replacementStack[i]; - } - } - var canonicalizedObj; - if (objectPrototypeToString.call(obj) === "[object Array]") { - stack.push(obj); - canonicalizedObj = new Array(obj.length); - replacementStack.push(canonicalizedObj); - for (i = 0; i < obj.length; i += 1) { - canonicalizedObj[i] = canonicalize(obj[i], stack, replacementStack, replacer, key2); - } - stack.pop(); - replacementStack.pop(); - return canonicalizedObj; - } - if (obj && obj.toJSON) { - obj = obj.toJSON(); - } - if (_typeof(obj) === "object" && obj !== null) { - stack.push(obj); - canonicalizedObj = {}; - replacementStack.push(canonicalizedObj); - var sortedKeys = [], _key; - for (_key in obj) { - if (obj.hasOwnProperty(_key)) { - sortedKeys.push(_key); - } - } - sortedKeys.sort(); - for (i = 0; i < sortedKeys.length; i += 1) { - _key = sortedKeys[i]; - canonicalizedObj[_key] = canonicalize(obj[_key], stack, replacementStack, replacer, _key); - } - stack.pop(); - replacementStack.pop(); - } else { - canonicalizedObj = obj; - } - return canonicalizedObj; - } - } -}); - -// node_modules/diff/lib/diff/array.js -var require_array = __commonJS({ - "node_modules/diff/lib/diff/array.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.diffArrays = diffArrays; - exports.arrayDiff = void 0; - var _base = _interopRequireDefault(require_base()); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - var arrayDiff = new _base["default"](); - exports.arrayDiff = arrayDiff; - arrayDiff.tokenize = function(value) { - return value.slice(); - }; - arrayDiff.join = arrayDiff.removeEmpty = function(value) { - return value; - }; - function diffArrays(oldArr, newArr, callback) { - return arrayDiff.diff(oldArr, newArr, callback); - } - } -}); - -// node_modules/diff/lib/patch/parse.js -var require_parse = __commonJS({ - "node_modules/diff/lib/patch/parse.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.parsePatch = parsePatch; - function parsePatch(uniDiff) { - var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; - var diffstr = uniDiff.split(/\r\n|[\n\v\f\r\x85]/), delimiters = uniDiff.match(/\r\n|[\n\v\f\r\x85]/g) || [], list = [], i = 0; - function parseIndex() { - var index = {}; - list.push(index); - while (i < diffstr.length) { - var line = diffstr[i]; - if (/^(\-\-\-|\+\+\+|@@)\s/.test(line)) { - break; - } - var header = /^(?:Index:|diff(?: -r \w+)+)\s+(.+?)\s*$/.exec(line); - if (header) { - index.index = header[1]; - } - i++; - } - parseFileHeader(index); - parseFileHeader(index); - index.hunks = []; - while (i < diffstr.length) { - var _line = diffstr[i]; - if (/^(Index:|diff|\-\-\-|\+\+\+)\s/.test(_line)) { - break; - } else if (/^@@/.test(_line)) { - index.hunks.push(parseHunk()); - } else if (_line && options.strict) { - throw new Error("Unknown line " + (i + 1) + " " + JSON.stringify(_line)); - } else { - i++; - } - } - } - function parseFileHeader(index) { - var fileHeader = /^(---|\+\+\+)\s+(.*)$/.exec(diffstr[i]); - if (fileHeader) { - var keyPrefix = fileHeader[1] === "---" ? "old" : "new"; - var data = fileHeader[2].split(" ", 2); - var fileName = data[0].replace(/\\\\/g, "\\"); - if (/^".*"$/.test(fileName)) { - fileName = fileName.substr(1, fileName.length - 2); - } - index[keyPrefix + "FileName"] = fileName; - index[keyPrefix + "Header"] = (data[1] || "").trim(); - i++; - } - } - function parseHunk() { - var chunkHeaderIndex = i, chunkHeaderLine = diffstr[i++], chunkHeader = chunkHeaderLine.split(/@@ -(\d+)(?:,(\d+))? \+(\d+)(?:,(\d+))? @@/); - var hunk = { - oldStart: +chunkHeader[1], - oldLines: typeof chunkHeader[2] === "undefined" ? 1 : +chunkHeader[2], - newStart: +chunkHeader[3], - newLines: typeof chunkHeader[4] === "undefined" ? 1 : +chunkHeader[4], - lines: [], - linedelimiters: [] - }; - if (hunk.oldLines === 0) { - hunk.oldStart += 1; - } - if (hunk.newLines === 0) { - hunk.newStart += 1; - } - var addCount = 0, removeCount = 0; - for (; i < diffstr.length; i++) { - if (diffstr[i].indexOf("--- ") === 0 && i + 2 < diffstr.length && diffstr[i + 1].indexOf("+++ ") === 0 && diffstr[i + 2].indexOf("@@") === 0) { - break; - } - var operation = diffstr[i].length == 0 && i != diffstr.length - 1 ? " " : diffstr[i][0]; - if (operation === "+" || operation === "-" || operation === " " || operation === "\\") { - hunk.lines.push(diffstr[i]); - hunk.linedelimiters.push(delimiters[i] || "\n"); - if (operation === "+") { - addCount++; - } else if (operation === "-") { - removeCount++; - } else if (operation === " ") { - addCount++; - removeCount++; - } - } else { - break; - } - } - if (!addCount && hunk.newLines === 1) { - hunk.newLines = 0; - } - if (!removeCount && hunk.oldLines === 1) { - hunk.oldLines = 0; - } - if (options.strict) { - if (addCount !== hunk.newLines) { - throw new Error("Added line count did not match for hunk at line " + (chunkHeaderIndex + 1)); - } - if (removeCount !== hunk.oldLines) { - throw new Error("Removed line count did not match for hunk at line " + (chunkHeaderIndex + 1)); - } - } - return hunk; - } - while (i < diffstr.length) { - parseIndex(); - } - return list; - } - } -}); - -// node_modules/diff/lib/util/distance-iterator.js -var require_distance_iterator = __commonJS({ - "node_modules/diff/lib/util/distance-iterator.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports["default"] = _default; - function _default(start, minLine, maxLine) { - var wantForward = true, backwardExhausted = false, forwardExhausted = false, localOffset = 1; - return function iterator() { - if (wantForward && !forwardExhausted) { - if (backwardExhausted) { - localOffset++; - } else { - wantForward = false; - } - if (start + localOffset <= maxLine) { - return localOffset; - } - forwardExhausted = true; - } - if (!backwardExhausted) { - if (!forwardExhausted) { - wantForward = true; - } - if (minLine <= start - localOffset) { - return -localOffset++; - } - backwardExhausted = true; - return iterator(); - } - }; - } - } -}); - -// node_modules/diff/lib/patch/apply.js -var require_apply = __commonJS({ - "node_modules/diff/lib/patch/apply.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.applyPatch = applyPatch; - exports.applyPatches = applyPatches; - var _parse = require_parse(); - var _distanceIterator = _interopRequireDefault(require_distance_iterator()); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - function applyPatch(source, uniDiff) { - var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; - if (typeof uniDiff === "string") { - uniDiff = (0, _parse.parsePatch)(uniDiff); - } - if (Array.isArray(uniDiff)) { - if (uniDiff.length > 1) { - throw new Error("applyPatch only works with a single input."); - } - uniDiff = uniDiff[0]; - } - var lines = source.split(/\r\n|[\n\v\f\r\x85]/), delimiters = source.match(/\r\n|[\n\v\f\r\x85]/g) || [], hunks = uniDiff.hunks, compareLine = options.compareLine || function(lineNumber, line2, operation2, patchContent) { - return line2 === patchContent; - }, errorCount = 0, fuzzFactor = options.fuzzFactor || 0, minLine = 0, offset = 0, removeEOFNL, addEOFNL; - function hunkFits(hunk2, toPos2) { - for (var j2 = 0; j2 < hunk2.lines.length; j2++) { - var line2 = hunk2.lines[j2], operation2 = line2.length > 0 ? line2[0] : " ", content2 = line2.length > 0 ? line2.substr(1) : line2; - if (operation2 === " " || operation2 === "-") { - if (!compareLine(toPos2 + 1, lines[toPos2], operation2, content2)) { - errorCount++; - if (errorCount > fuzzFactor) { - return false; - } - } - toPos2++; - } - } - return true; - } - for (var i = 0; i < hunks.length; i++) { - var hunk = hunks[i], maxLine = lines.length - hunk.oldLines, localOffset = 0, toPos = offset + hunk.oldStart - 1; - var iterator = (0, _distanceIterator["default"])(toPos, minLine, maxLine); - for (; localOffset !== void 0; localOffset = iterator()) { - if (hunkFits(hunk, toPos + localOffset)) { - hunk.offset = offset += localOffset; - break; - } - } - if (localOffset === void 0) { - return false; - } - minLine = hunk.offset + hunk.oldStart + hunk.oldLines; - } - var diffOffset = 0; - for (var _i = 0; _i < hunks.length; _i++) { - var _hunk = hunks[_i], _toPos = _hunk.oldStart + _hunk.offset + diffOffset - 1; - diffOffset += _hunk.newLines - _hunk.oldLines; - for (var j = 0; j < _hunk.lines.length; j++) { - var line = _hunk.lines[j], operation = line.length > 0 ? line[0] : " ", content = line.length > 0 ? line.substr(1) : line, delimiter = _hunk.linedelimiters[j]; - if (operation === " ") { - _toPos++; - } else if (operation === "-") { - lines.splice(_toPos, 1); - delimiters.splice(_toPos, 1); - } else if (operation === "+") { - lines.splice(_toPos, 0, content); - delimiters.splice(_toPos, 0, delimiter); - _toPos++; - } else if (operation === "\\") { - var previousOperation = _hunk.lines[j - 1] ? _hunk.lines[j - 1][0] : null; - if (previousOperation === "+") { - removeEOFNL = true; - } else if (previousOperation === "-") { - addEOFNL = true; - } - } - } - } - if (removeEOFNL) { - while (!lines[lines.length - 1]) { - lines.pop(); - delimiters.pop(); - } - } else if (addEOFNL) { - lines.push(""); - delimiters.push("\n"); - } - for (var _k = 0; _k < lines.length - 1; _k++) { - lines[_k] = lines[_k] + delimiters[_k]; - } - return lines.join(""); - } - function applyPatches(uniDiff, options) { - if (typeof uniDiff === "string") { - uniDiff = (0, _parse.parsePatch)(uniDiff); - } - var currentIndex = 0; - function processIndex() { - var index = uniDiff[currentIndex++]; - if (!index) { - return options.complete(); - } - options.loadFile(index, function(err, data) { - if (err) { - return options.complete(err); - } - var updatedContent = applyPatch(data, index, options); - options.patched(index, updatedContent, function(err2) { - if (err2) { - return options.complete(err2); - } - processIndex(); - }); - }); - } - processIndex(); - } - } -}); - -// node_modules/diff/lib/patch/create.js -var require_create = __commonJS({ - "node_modules/diff/lib/patch/create.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.structuredPatch = structuredPatch; - exports.formatPatch = formatPatch; - exports.createTwoFilesPatch = createTwoFilesPatch; - exports.createPatch = createPatch; - var _line = require_line(); - function _toConsumableArray(arr) { - return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); - } - function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); - } - function _unsupportedIterableToArray(o, minLen) { - if (!o) - return; - if (typeof o === "string") - return _arrayLikeToArray(o, minLen); - var n = Object.prototype.toString.call(o).slice(8, -1); - if (n === "Object" && o.constructor) - n = o.constructor.name; - if (n === "Map" || n === "Set") - return Array.from(o); - if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) - return _arrayLikeToArray(o, minLen); - } - function _iterableToArray(iter) { - if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) - return Array.from(iter); - } - function _arrayWithoutHoles(arr) { - if (Array.isArray(arr)) - return _arrayLikeToArray(arr); - } - function _arrayLikeToArray(arr, len) { - if (len == null || len > arr.length) - len = arr.length; - for (var i = 0, arr2 = new Array(len); i < len; i++) { - arr2[i] = arr[i]; - } - return arr2; - } - function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { - if (!options) { - options = {}; - } - if (typeof options.context === "undefined") { - options.context = 4; - } - var diff = (0, _line.diffLines)(oldStr, newStr, options); - if (!diff) { - return; - } - diff.push({ - value: "", - lines: [] - }); - function contextLines(lines) { - return lines.map(function(entry) { - return " " + entry; - }); - } - var hunks = []; - var oldRangeStart = 0, newRangeStart = 0, curRange = [], oldLine = 1, newLine = 1; - var _loop = function _loop2(i2) { - var current = diff[i2], lines = current.lines || current.value.replace(/\n$/, "").split("\n"); - current.lines = lines; - if (current.added || current.removed) { - var _curRange; - if (!oldRangeStart) { - var prev = diff[i2 - 1]; - oldRangeStart = oldLine; - newRangeStart = newLine; - if (prev) { - curRange = options.context > 0 ? contextLines(prev.lines.slice(-options.context)) : []; - oldRangeStart -= curRange.length; - newRangeStart -= curRange.length; - } - } - (_curRange = curRange).push.apply(_curRange, _toConsumableArray(lines.map(function(entry) { - return (current.added ? "+" : "-") + entry; - }))); - if (current.added) { - newLine += lines.length; - } else { - oldLine += lines.length; - } - } else { - if (oldRangeStart) { - if (lines.length <= options.context * 2 && i2 < diff.length - 2) { - var _curRange2; - (_curRange2 = curRange).push.apply(_curRange2, _toConsumableArray(contextLines(lines))); - } else { - var _curRange3; - var contextSize = Math.min(lines.length, options.context); - (_curRange3 = curRange).push.apply(_curRange3, _toConsumableArray(contextLines(lines.slice(0, contextSize)))); - var hunk = { - oldStart: oldRangeStart, - oldLines: oldLine - oldRangeStart + contextSize, - newStart: newRangeStart, - newLines: newLine - newRangeStart + contextSize, - lines: curRange - }; - if (i2 >= diff.length - 2 && lines.length <= options.context) { - var oldEOFNewline = /\n$/.test(oldStr); - var newEOFNewline = /\n$/.test(newStr); - var noNlBeforeAdds = lines.length == 0 && curRange.length > hunk.oldLines; - if (!oldEOFNewline && noNlBeforeAdds && oldStr.length > 0) { - curRange.splice(hunk.oldLines, 0, "\\ No newline at end of file"); - } - if (!oldEOFNewline && !noNlBeforeAdds || !newEOFNewline) { - curRange.push("\\ No newline at end of file"); - } - } - hunks.push(hunk); - oldRangeStart = 0; - newRangeStart = 0; - curRange = []; - } - } - oldLine += lines.length; - newLine += lines.length; - } - }; - for (var i = 0; i < diff.length; i++) { - _loop(i); - } - return { - oldFileName, - newFileName, - oldHeader, - newHeader, - hunks - }; - } - function formatPatch(diff) { - var ret = []; - if (diff.oldFileName == diff.newFileName) { - ret.push("Index: " + diff.oldFileName); - } - ret.push("==================================================================="); - ret.push("--- " + diff.oldFileName + (typeof diff.oldHeader === "undefined" ? "" : " " + diff.oldHeader)); - ret.push("+++ " + diff.newFileName + (typeof diff.newHeader === "undefined" ? "" : " " + diff.newHeader)); - for (var i = 0; i < diff.hunks.length; i++) { - var hunk = diff.hunks[i]; - if (hunk.oldLines === 0) { - hunk.oldStart -= 1; - } - if (hunk.newLines === 0) { - hunk.newStart -= 1; - } - ret.push("@@ -" + hunk.oldStart + "," + hunk.oldLines + " +" + hunk.newStart + "," + hunk.newLines + " @@"); - ret.push.apply(ret, hunk.lines); - } - return ret.join("\n") + "\n"; - } - function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { - return formatPatch(structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options)); - } - function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) { - return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options); - } - } -}); - -// node_modules/diff/lib/util/array.js -var require_array2 = __commonJS({ - "node_modules/diff/lib/util/array.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.arrayEqual = arrayEqual; - exports.arrayStartsWith = arrayStartsWith; - function arrayEqual(a, b) { - if (a.length !== b.length) { - return false; - } - return arrayStartsWith(a, b); - } - function arrayStartsWith(array, start) { - if (start.length > array.length) { - return false; - } - for (var i = 0; i < start.length; i++) { - if (start[i] !== array[i]) { - return false; - } - } - return true; - } - } -}); - -// node_modules/diff/lib/patch/merge.js -var require_merge = __commonJS({ - "node_modules/diff/lib/patch/merge.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.calcLineCount = calcLineCount; - exports.merge = merge; - var _create = require_create(); - var _parse = require_parse(); - var _array = require_array2(); - function _toConsumableArray(arr) { - return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); - } - function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); - } - function _unsupportedIterableToArray(o, minLen) { - if (!o) - return; - if (typeof o === "string") - return _arrayLikeToArray(o, minLen); - var n = Object.prototype.toString.call(o).slice(8, -1); - if (n === "Object" && o.constructor) - n = o.constructor.name; - if (n === "Map" || n === "Set") - return Array.from(o); - if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) - return _arrayLikeToArray(o, minLen); - } - function _iterableToArray(iter) { - if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) - return Array.from(iter); - } - function _arrayWithoutHoles(arr) { - if (Array.isArray(arr)) - return _arrayLikeToArray(arr); - } - function _arrayLikeToArray(arr, len) { - if (len == null || len > arr.length) - len = arr.length; - for (var i = 0, arr2 = new Array(len); i < len; i++) { - arr2[i] = arr[i]; - } - return arr2; - } - function calcLineCount(hunk) { - var _calcOldNewLineCount = calcOldNewLineCount(hunk.lines), oldLines = _calcOldNewLineCount.oldLines, newLines = _calcOldNewLineCount.newLines; - if (oldLines !== void 0) { - hunk.oldLines = oldLines; - } else { - delete hunk.oldLines; - } - if (newLines !== void 0) { - hunk.newLines = newLines; - } else { - delete hunk.newLines; - } - } - function merge(mine, theirs, base) { - mine = loadPatch(mine, base); - theirs = loadPatch(theirs, base); - var ret = {}; - if (mine.index || theirs.index) { - ret.index = mine.index || theirs.index; - } - if (mine.newFileName || theirs.newFileName) { - if (!fileNameChanged(mine)) { - ret.oldFileName = theirs.oldFileName || mine.oldFileName; - ret.newFileName = theirs.newFileName || mine.newFileName; - ret.oldHeader = theirs.oldHeader || mine.oldHeader; - ret.newHeader = theirs.newHeader || mine.newHeader; - } else if (!fileNameChanged(theirs)) { - ret.oldFileName = mine.oldFileName; - ret.newFileName = mine.newFileName; - ret.oldHeader = mine.oldHeader; - ret.newHeader = mine.newHeader; - } else { - ret.oldFileName = selectField(ret, mine.oldFileName, theirs.oldFileName); - ret.newFileName = selectField(ret, mine.newFileName, theirs.newFileName); - ret.oldHeader = selectField(ret, mine.oldHeader, theirs.oldHeader); - ret.newHeader = selectField(ret, mine.newHeader, theirs.newHeader); - } - } - ret.hunks = []; - var mineIndex = 0, theirsIndex = 0, mineOffset = 0, theirsOffset = 0; - while (mineIndex < mine.hunks.length || theirsIndex < theirs.hunks.length) { - var mineCurrent = mine.hunks[mineIndex] || { - oldStart: Infinity - }, theirsCurrent = theirs.hunks[theirsIndex] || { - oldStart: Infinity - }; - if (hunkBefore(mineCurrent, theirsCurrent)) { - ret.hunks.push(cloneHunk(mineCurrent, mineOffset)); - mineIndex++; - theirsOffset += mineCurrent.newLines - mineCurrent.oldLines; - } else if (hunkBefore(theirsCurrent, mineCurrent)) { - ret.hunks.push(cloneHunk(theirsCurrent, theirsOffset)); - theirsIndex++; - mineOffset += theirsCurrent.newLines - theirsCurrent.oldLines; - } else { - var mergedHunk = { - oldStart: Math.min(mineCurrent.oldStart, theirsCurrent.oldStart), - oldLines: 0, - newStart: Math.min(mineCurrent.newStart + mineOffset, theirsCurrent.oldStart + theirsOffset), - newLines: 0, - lines: [] - }; - mergeLines(mergedHunk, mineCurrent.oldStart, mineCurrent.lines, theirsCurrent.oldStart, theirsCurrent.lines); - theirsIndex++; - mineIndex++; - ret.hunks.push(mergedHunk); - } - } - return ret; - } - function loadPatch(param, base) { - if (typeof param === "string") { - if (/^@@/m.test(param) || /^Index:/m.test(param)) { - return (0, _parse.parsePatch)(param)[0]; - } - if (!base) { - throw new Error("Must provide a base reference or pass in a patch"); - } - return (0, _create.structuredPatch)(void 0, void 0, base, param); - } - return param; - } - function fileNameChanged(patch) { - return patch.newFileName && patch.newFileName !== patch.oldFileName; - } - function selectField(index, mine, theirs) { - if (mine === theirs) { - return mine; - } else { - index.conflict = true; - return { - mine, - theirs - }; - } - } - function hunkBefore(test, check) { - return test.oldStart < check.oldStart && test.oldStart + test.oldLines < check.oldStart; - } - function cloneHunk(hunk, offset) { - return { - oldStart: hunk.oldStart, - oldLines: hunk.oldLines, - newStart: hunk.newStart + offset, - newLines: hunk.newLines, - lines: hunk.lines - }; - } - function mergeLines(hunk, mineOffset, mineLines, theirOffset, theirLines) { - var mine = { - offset: mineOffset, - lines: mineLines, - index: 0 - }, their = { - offset: theirOffset, - lines: theirLines, - index: 0 - }; - insertLeading(hunk, mine, their); - insertLeading(hunk, their, mine); - while (mine.index < mine.lines.length && their.index < their.lines.length) { - var mineCurrent = mine.lines[mine.index], theirCurrent = their.lines[their.index]; - if ((mineCurrent[0] === "-" || mineCurrent[0] === "+") && (theirCurrent[0] === "-" || theirCurrent[0] === "+")) { - mutualChange(hunk, mine, their); - } else if (mineCurrent[0] === "+" && theirCurrent[0] === " ") { - var _hunk$lines; - (_hunk$lines = hunk.lines).push.apply(_hunk$lines, _toConsumableArray(collectChange(mine))); - } else if (theirCurrent[0] === "+" && mineCurrent[0] === " ") { - var _hunk$lines2; - (_hunk$lines2 = hunk.lines).push.apply(_hunk$lines2, _toConsumableArray(collectChange(their))); - } else if (mineCurrent[0] === "-" && theirCurrent[0] === " ") { - removal(hunk, mine, their); - } else if (theirCurrent[0] === "-" && mineCurrent[0] === " ") { - removal(hunk, their, mine, true); - } else if (mineCurrent === theirCurrent) { - hunk.lines.push(mineCurrent); - mine.index++; - their.index++; - } else { - conflict(hunk, collectChange(mine), collectChange(their)); - } - } - insertTrailing(hunk, mine); - insertTrailing(hunk, their); - calcLineCount(hunk); - } - function mutualChange(hunk, mine, their) { - var myChanges = collectChange(mine), theirChanges = collectChange(their); - if (allRemoves(myChanges) && allRemoves(theirChanges)) { - if ((0, _array.arrayStartsWith)(myChanges, theirChanges) && skipRemoveSuperset(their, myChanges, myChanges.length - theirChanges.length)) { - var _hunk$lines3; - (_hunk$lines3 = hunk.lines).push.apply(_hunk$lines3, _toConsumableArray(myChanges)); - return; - } else if ((0, _array.arrayStartsWith)(theirChanges, myChanges) && skipRemoveSuperset(mine, theirChanges, theirChanges.length - myChanges.length)) { - var _hunk$lines4; - (_hunk$lines4 = hunk.lines).push.apply(_hunk$lines4, _toConsumableArray(theirChanges)); - return; - } - } else if ((0, _array.arrayEqual)(myChanges, theirChanges)) { - var _hunk$lines5; - (_hunk$lines5 = hunk.lines).push.apply(_hunk$lines5, _toConsumableArray(myChanges)); - return; - } - conflict(hunk, myChanges, theirChanges); - } - function removal(hunk, mine, their, swap) { - var myChanges = collectChange(mine), theirChanges = collectContext(their, myChanges); - if (theirChanges.merged) { - var _hunk$lines6; - (_hunk$lines6 = hunk.lines).push.apply(_hunk$lines6, _toConsumableArray(theirChanges.merged)); - } else { - conflict(hunk, swap ? theirChanges : myChanges, swap ? myChanges : theirChanges); - } - } - function conflict(hunk, mine, their) { - hunk.conflict = true; - hunk.lines.push({ - conflict: true, - mine, - theirs: their - }); - } - function insertLeading(hunk, insert2, their) { - while (insert2.offset < their.offset && insert2.index < insert2.lines.length) { - var line = insert2.lines[insert2.index++]; - hunk.lines.push(line); - insert2.offset++; - } - } - function insertTrailing(hunk, insert2) { - while (insert2.index < insert2.lines.length) { - var line = insert2.lines[insert2.index++]; - hunk.lines.push(line); - } - } - function collectChange(state) { - var ret = [], operation = state.lines[state.index][0]; - while (state.index < state.lines.length) { - var line = state.lines[state.index]; - if (operation === "-" && line[0] === "+") { - operation = "+"; - } - if (operation === line[0]) { - ret.push(line); - state.index++; - } else { - break; - } - } - return ret; - } - function collectContext(state, matchChanges) { - var changes = [], merged = [], matchIndex = 0, contextChanges = false, conflicted = false; - while (matchIndex < matchChanges.length && state.index < state.lines.length) { - var change = state.lines[state.index], match = matchChanges[matchIndex]; - if (match[0] === "+") { - break; - } - contextChanges = contextChanges || change[0] !== " "; - merged.push(match); - matchIndex++; - if (change[0] === "+") { - conflicted = true; - while (change[0] === "+") { - changes.push(change); - change = state.lines[++state.index]; - } - } - if (match.substr(1) === change.substr(1)) { - changes.push(change); - state.index++; - } else { - conflicted = true; - } - } - if ((matchChanges[matchIndex] || "")[0] === "+" && contextChanges) { - conflicted = true; - } - if (conflicted) { - return changes; - } - while (matchIndex < matchChanges.length) { - merged.push(matchChanges[matchIndex++]); - } - return { - merged, - changes - }; - } - function allRemoves(changes) { - return changes.reduce(function(prev, change) { - return prev && change[0] === "-"; - }, true); - } - function skipRemoveSuperset(state, removeChanges, delta) { - for (var i = 0; i < delta; i++) { - var changeContent = removeChanges[removeChanges.length - delta + i].substr(1); - if (state.lines[state.index + i] !== " " + changeContent) { - return false; - } - } - state.index += delta; - return true; - } - function calcOldNewLineCount(lines) { - var oldLines = 0; - var newLines = 0; - lines.forEach(function(line) { - if (typeof line !== "string") { - var myCount = calcOldNewLineCount(line.mine); - var theirCount = calcOldNewLineCount(line.theirs); - if (oldLines !== void 0) { - if (myCount.oldLines === theirCount.oldLines) { - oldLines += myCount.oldLines; - } else { - oldLines = void 0; - } - } - if (newLines !== void 0) { - if (myCount.newLines === theirCount.newLines) { - newLines += myCount.newLines; - } else { - newLines = void 0; - } - } - } else { - if (newLines !== void 0 && (line[0] === "+" || line[0] === " ")) { - newLines++; - } - if (oldLines !== void 0 && (line[0] === "-" || line[0] === " ")) { - oldLines++; - } - } - }); - return { - oldLines, - newLines - }; - } - } -}); - -// node_modules/diff/lib/convert/dmp.js -var require_dmp = __commonJS({ - "node_modules/diff/lib/convert/dmp.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.convertChangesToDMP = convertChangesToDMP; - function convertChangesToDMP(changes) { - var ret = [], change, operation; - for (var i = 0; i < changes.length; i++) { - change = changes[i]; - if (change.added) { - operation = 1; - } else if (change.removed) { - operation = -1; - } else { - operation = 0; - } - ret.push([operation, change.value]); - } - return ret; - } - } -}); - -// node_modules/diff/lib/convert/xml.js -var require_xml = __commonJS({ - "node_modules/diff/lib/convert/xml.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.convertChangesToXML = convertChangesToXML; - function convertChangesToXML(changes) { - var ret = []; - for (var i = 0; i < changes.length; i++) { - var change = changes[i]; - if (change.added) { - ret.push(""); - } else if (change.removed) { - ret.push(""); - } - ret.push(escapeHTML(change.value)); - if (change.added) { - ret.push(""); - } else if (change.removed) { - ret.push(""); - } - } - return ret.join(""); - } - function escapeHTML(s) { - var n = s; - n = n.replace(/&/g, "&"); - n = n.replace(//g, ">"); - n = n.replace(/"/g, """); - return n; - } - } -}); - -// node_modules/diff/lib/index.js -var require_lib = __commonJS({ - "node_modules/diff/lib/index.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - Object.defineProperty(exports, "Diff", { - enumerable: true, - get: function get() { - return _base["default"]; - } - }); - Object.defineProperty(exports, "diffChars", { - enumerable: true, - get: function get() { - return _character.diffChars; - } - }); - Object.defineProperty(exports, "diffWords", { - enumerable: true, - get: function get() { - return _word.diffWords; - } - }); - Object.defineProperty(exports, "diffWordsWithSpace", { - enumerable: true, - get: function get() { - return _word.diffWordsWithSpace; - } - }); - Object.defineProperty(exports, "diffLines", { - enumerable: true, - get: function get() { - return _line.diffLines; - } - }); - Object.defineProperty(exports, "diffTrimmedLines", { - enumerable: true, - get: function get() { - return _line.diffTrimmedLines; - } - }); - Object.defineProperty(exports, "diffSentences", { - enumerable: true, - get: function get() { - return _sentence.diffSentences; - } - }); - Object.defineProperty(exports, "diffCss", { - enumerable: true, - get: function get() { - return _css.diffCss; - } - }); - Object.defineProperty(exports, "diffJson", { - enumerable: true, - get: function get() { - return _json.diffJson; - } - }); - Object.defineProperty(exports, "canonicalize", { - enumerable: true, - get: function get() { - return _json.canonicalize; - } - }); - Object.defineProperty(exports, "diffArrays", { - enumerable: true, - get: function get() { - return _array.diffArrays; - } - }); - Object.defineProperty(exports, "applyPatch", { - enumerable: true, - get: function get() { - return _apply.applyPatch; - } - }); - Object.defineProperty(exports, "applyPatches", { - enumerable: true, - get: function get() { - return _apply.applyPatches; - } - }); - Object.defineProperty(exports, "parsePatch", { - enumerable: true, - get: function get() { - return _parse.parsePatch; - } - }); - Object.defineProperty(exports, "merge", { - enumerable: true, - get: function get() { - return _merge.merge; - } - }); - Object.defineProperty(exports, "structuredPatch", { - enumerable: true, - get: function get() { - return _create.structuredPatch; - } - }); - Object.defineProperty(exports, "createTwoFilesPatch", { - enumerable: true, - get: function get() { - return _create.createTwoFilesPatch; - } - }); - Object.defineProperty(exports, "createPatch", { - enumerable: true, - get: function get() { - return _create.createPatch; - } - }); - Object.defineProperty(exports, "convertChangesToDMP", { - enumerable: true, - get: function get() { - return _dmp.convertChangesToDMP; - } - }); - Object.defineProperty(exports, "convertChangesToXML", { - enumerable: true, - get: function get() { - return _xml.convertChangesToXML; - } - }); - var _base = _interopRequireDefault(require_base()); - var _character = require_character(); - var _word = require_word(); - var _line = require_line(); - var _sentence = require_sentence(); - var _css = require_css(); - var _json = require_json(); - var _array = require_array(); - var _apply = require_apply(); - var _parse = require_parse(); - var _merge = require_merge(); - var _create = require_create(); - var _dmp = require_dmp(); - var _xml = require_xml(); - function _interopRequireDefault(obj) { - return obj && obj.__esModule ? obj : { "default": obj }; - } - } -}); - -// node_modules/diff2html/lib/rematch.js -var require_rematch = __commonJS({ - "node_modules/diff2html/lib/rematch.js"(exports) { - "use strict"; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.newMatcherFn = exports.newDistanceFn = exports.levenshtein = void 0; - function levenshtein(a, b) { - if (a.length === 0) { - return b.length; - } - if (b.length === 0) { - return a.length; - } - var matrix = []; - var i; - for (i = 0; i <= b.length; i++) { - matrix[i] = [i]; - } - var j; - for (j = 0; j <= a.length; j++) { - matrix[0][j] = j; - } - for (i = 1; i <= b.length; i++) { - for (j = 1; j <= a.length; j++) { - if (b.charAt(i - 1) === a.charAt(j - 1)) { - matrix[i][j] = matrix[i - 1][j - 1]; - } else { - matrix[i][j] = Math.min(matrix[i - 1][j - 1] + 1, Math.min(matrix[i][j - 1] + 1, matrix[i - 1][j] + 1)); - } - } - } - return matrix[b.length][a.length]; - } - exports.levenshtein = levenshtein; - function newDistanceFn(str) { - return function(x, y) { - var xValue = str(x).trim(); - var yValue = str(y).trim(); - var lev = levenshtein(xValue, yValue); - return lev / (xValue.length + yValue.length); - }; - } - exports.newDistanceFn = newDistanceFn; - function newMatcherFn(distance) { - function findBestMatch(a, b, cache) { - if (cache === void 0) { - cache = new Map(); - } - var bestMatchDist = Infinity; - var bestMatch; - for (var i = 0; i < a.length; ++i) { - for (var j = 0; j < b.length; ++j) { - var cacheKey = JSON.stringify([a[i], b[j]]); - var md = void 0; - if (!(cache.has(cacheKey) && (md = cache.get(cacheKey)))) { - md = distance(a[i], b[j]); - cache.set(cacheKey, md); - } - if (md < bestMatchDist) { - bestMatchDist = md; - bestMatch = { indexA: i, indexB: j, score: bestMatchDist }; - } - } - } - return bestMatch; - } - function group(a, b, level, cache) { - if (level === void 0) { - level = 0; - } - if (cache === void 0) { - cache = new Map(); - } - var bm = findBestMatch(a, b, cache); - if (!bm || a.length + b.length < 3) { - return [[a, b]]; - } - var a1 = a.slice(0, bm.indexA); - var b1 = b.slice(0, bm.indexB); - var aMatch = [a[bm.indexA]]; - var bMatch = [b[bm.indexB]]; - var tailA = bm.indexA + 1; - var tailB = bm.indexB + 1; - var a2 = a.slice(tailA); - var b2 = b.slice(tailB); - var group1 = group(a1, b1, level + 1, cache); - var groupMatch = group(aMatch, bMatch, level + 1, cache); - var group2 = group(a2, b2, level + 1, cache); - var result = groupMatch; - if (bm.indexA > 0 || bm.indexB > 0) { - result = group1.concat(result); - } - if (a.length > tailA || b.length > tailB) { - result = result.concat(group2); - } - return result; - } - return group; - } - exports.newMatcherFn = newMatcherFn; - } -}); - -// node_modules/diff2html/lib/render-utils.js -var require_render_utils = __commonJS({ - "node_modules/diff2html/lib/render-utils.js"(exports) { - "use strict"; - var __assign2 = exports && exports.__assign || function() { - __assign2 = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign2.apply(this, arguments); - }; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.diffHighlight = exports.getFileIcon = exports.getHtmlId = exports.filenameDiff = exports.deconstructLine = exports.escapeForHtml = exports.toCSSClass = exports.defaultRenderConfig = exports.CSSLineClass = void 0; - var jsDiff = __importStar2(require_lib()); - var utils_1 = require_utils(); - var rematch = __importStar2(require_rematch()); - var types_1 = require_types(); - exports.CSSLineClass = { - INSERTS: "d2h-ins", - DELETES: "d2h-del", - CONTEXT: "d2h-cntx", - INFO: "d2h-info", - INSERT_CHANGES: "d2h-ins d2h-change", - DELETE_CHANGES: "d2h-del d2h-change" - }; - exports.defaultRenderConfig = { - matching: types_1.LineMatchingType.NONE, - matchWordsThreshold: 0.25, - maxLineLengthHighlight: 1e4, - diffStyle: types_1.DiffStyleType.WORD - }; - var separator = "/"; - var distance = rematch.newDistanceFn(function(change) { - return change.value; - }); - var matcher = rematch.newMatcherFn(distance); - function isDevNullName(name) { - return name.indexOf("dev/null") !== -1; - } - function removeInsElements(line) { - return line.replace(/(]*>((.|\n)*?)<\/ins>)/g, ""); - } - function removeDelElements(line) { - return line.replace(/(]*>((.|\n)*?)<\/del>)/g, ""); - } - function toCSSClass(lineType) { - switch (lineType) { - case types_1.LineType.CONTEXT: - return exports.CSSLineClass.CONTEXT; - case types_1.LineType.INSERT: - return exports.CSSLineClass.INSERTS; - case types_1.LineType.DELETE: - return exports.CSSLineClass.DELETES; - } - } - exports.toCSSClass = toCSSClass; - function prefixLength(isCombined) { - return isCombined ? 2 : 1; - } - function escapeForHtml(str) { - return str.slice(0).replace(/&/g, "&").replace(//g, ">").replace(/"/g, """).replace(/'/g, "'").replace(/\//g, "/"); - } - exports.escapeForHtml = escapeForHtml; - function deconstructLine(line, isCombined, escape) { - if (escape === void 0) { - escape = true; - } - var indexToSplit = prefixLength(isCombined); - return { - prefix: line.substring(0, indexToSplit), - content: escape ? escapeForHtml(line.substring(indexToSplit)) : line.substring(indexToSplit) - }; - } - exports.deconstructLine = deconstructLine; - function filenameDiff(file) { - var oldFilename = (0, utils_1.unifyPath)(file.oldName); - var newFilename = (0, utils_1.unifyPath)(file.newName); - if (oldFilename !== newFilename && !isDevNullName(oldFilename) && !isDevNullName(newFilename)) { - var prefixPaths = []; - var suffixPaths = []; - var oldFilenameParts = oldFilename.split(separator); - var newFilenameParts = newFilename.split(separator); - var oldFilenamePartsSize = oldFilenameParts.length; - var newFilenamePartsSize = newFilenameParts.length; - var i = 0; - var j = oldFilenamePartsSize - 1; - var k = newFilenamePartsSize - 1; - while (i < j && i < k) { - if (oldFilenameParts[i] === newFilenameParts[i]) { - prefixPaths.push(newFilenameParts[i]); - i += 1; - } else { - break; - } - } - while (j > i && k > i) { - if (oldFilenameParts[j] === newFilenameParts[k]) { - suffixPaths.unshift(newFilenameParts[k]); - j -= 1; - k -= 1; - } else { - break; - } - } - var finalPrefix = prefixPaths.join(separator); - var finalSuffix = suffixPaths.join(separator); - var oldRemainingPath = oldFilenameParts.slice(i, j + 1).join(separator); - var newRemainingPath = newFilenameParts.slice(i, k + 1).join(separator); - if (finalPrefix.length && finalSuffix.length) { - return finalPrefix + separator + "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}" + separator + finalSuffix; - } else if (finalPrefix.length) { - return finalPrefix + separator + "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}"; - } else if (finalSuffix.length) { - return "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}" + separator + finalSuffix; - } - return oldFilename + " \u2192 " + newFilename; - } else if (!isDevNullName(newFilename)) { - return newFilename; - } else { - return oldFilename; - } - } - exports.filenameDiff = filenameDiff; - function getHtmlId(file) { - return "d2h-".concat((0, utils_1.hashCode)(filenameDiff(file)).toString().slice(-6)); - } - exports.getHtmlId = getHtmlId; - function getFileIcon(file) { - var templateName = "file-changed"; - if (file.isRename) { - templateName = "file-renamed"; - } else if (file.isCopy) { - templateName = "file-renamed"; - } else if (file.isNew) { - templateName = "file-added"; - } else if (file.isDeleted) { - templateName = "file-deleted"; - } else if (file.newName !== file.oldName) { - templateName = "file-renamed"; - } - return templateName; - } - exports.getFileIcon = getFileIcon; - function diffHighlight(diffLine1, diffLine2, isCombined, config) { - if (config === void 0) { - config = {}; - } - var _a2 = __assign2(__assign2({}, exports.defaultRenderConfig), config), matching = _a2.matching, maxLineLengthHighlight = _a2.maxLineLengthHighlight, matchWordsThreshold = _a2.matchWordsThreshold, diffStyle = _a2.diffStyle; - var line1 = deconstructLine(diffLine1, isCombined, false); - var line2 = deconstructLine(diffLine2, isCombined, false); - if (line1.content.length > maxLineLengthHighlight || line2.content.length > maxLineLengthHighlight) { - return { - oldLine: { - prefix: line1.prefix, - content: escapeForHtml(line1.content) - }, - newLine: { - prefix: line2.prefix, - content: escapeForHtml(line2.content) - } - }; - } - var diff = diffStyle === "char" ? jsDiff.diffChars(line1.content, line2.content) : jsDiff.diffWordsWithSpace(line1.content, line2.content); - var changedWords = []; - if (diffStyle === "word" && matching === "words") { - var removed = diff.filter(function(element2) { - return element2.removed; - }); - var added = diff.filter(function(element2) { - return element2.added; - }); - var chunks = matcher(added, removed); - chunks.forEach(function(chunk) { - if (chunk[0].length === 1 && chunk[1].length === 1) { - var dist = distance(chunk[0][0], chunk[1][0]); - if (dist < matchWordsThreshold) { - changedWords.push(chunk[0][0]); - changedWords.push(chunk[1][0]); - } - } - }); - } - var highlightedLine = diff.reduce(function(highlightedLine2, part) { - var elemType = part.added ? "ins" : part.removed ? "del" : null; - var addClass = changedWords.indexOf(part) > -1 ? ' class="d2h-change"' : ""; - var escapedValue = escapeForHtml(part.value); - return elemType !== null ? "".concat(highlightedLine2, "<").concat(elemType).concat(addClass, ">").concat(escapedValue, "") : "".concat(highlightedLine2).concat(escapedValue); - }, ""); - return { - oldLine: { - prefix: line1.prefix, - content: removeInsElements(highlightedLine) - }, - newLine: { - prefix: line2.prefix, - content: removeDelElements(highlightedLine) - } - }; - } - exports.diffHighlight = diffHighlight; - } -}); - -// node_modules/diff2html/lib/file-list-renderer.js -var require_file_list_renderer = __commonJS({ - "node_modules/diff2html/lib/file-list-renderer.js"(exports) { - "use strict"; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.render = void 0; - var renderUtils = __importStar2(require_render_utils()); - var baseTemplatesPath = "file-summary"; - var iconsBaseTemplatesPath = "icon"; - function render(diffFiles, hoganUtils) { - var files = diffFiles.map(function(file) { - return hoganUtils.render(baseTemplatesPath, "line", { - fileHtmlId: renderUtils.getHtmlId(file), - oldName: file.oldName, - newName: file.newName, - fileName: renderUtils.filenameDiff(file), - deletedLines: "-" + file.deletedLines, - addedLines: "+" + file.addedLines - }, { - fileIcon: hoganUtils.template(iconsBaseTemplatesPath, renderUtils.getFileIcon(file)) - }); - }).join("\n"); - return hoganUtils.render(baseTemplatesPath, "wrapper", { - filesNumber: diffFiles.length, - files - }); - } - exports.render = render; - } -}); - -// node_modules/diff2html/lib/line-by-line-renderer.js -var require_line_by_line_renderer = __commonJS({ - "node_modules/diff2html/lib/line-by-line-renderer.js"(exports) { - "use strict"; - var __assign2 = exports && exports.__assign || function() { - __assign2 = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign2.apply(this, arguments); - }; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.defaultLineByLineRendererConfig = void 0; - var Rematch = __importStar2(require_rematch()); - var renderUtils = __importStar2(require_render_utils()); - var types_1 = require_types(); - exports.defaultLineByLineRendererConfig = __assign2(__assign2({}, renderUtils.defaultRenderConfig), { renderNothingWhenEmpty: false, matchingMaxComparisons: 2500, maxLineSizeInBlockForComparison: 200 }); - var genericTemplatesPath = "generic"; - var baseTemplatesPath = "line-by-line"; - var iconsBaseTemplatesPath = "icon"; - var tagsBaseTemplatesPath = "tag"; - var LineByLineRenderer = function() { - function LineByLineRenderer2(hoganUtils, config) { - if (config === void 0) { - config = {}; - } - this.hoganUtils = hoganUtils; - this.config = __assign2(__assign2({}, exports.defaultLineByLineRendererConfig), config); - } - LineByLineRenderer2.prototype.render = function(diffFiles) { - var _this = this; - var diffsHtml = diffFiles.map(function(file) { - var diffs; - if (file.blocks.length) { - diffs = _this.generateFileHtml(file); - } else { - diffs = _this.generateEmptyDiff(); - } - return _this.makeFileDiffHtml(file, diffs); - }).join("\n"); - return this.hoganUtils.render(genericTemplatesPath, "wrapper", { content: diffsHtml }); - }; - LineByLineRenderer2.prototype.makeFileDiffHtml = function(file, diffs) { - if (this.config.renderNothingWhenEmpty && Array.isArray(file.blocks) && file.blocks.length === 0) - return ""; - var fileDiffTemplate = this.hoganUtils.template(baseTemplatesPath, "file-diff"); - var filePathTemplate = this.hoganUtils.template(genericTemplatesPath, "file-path"); - var fileIconTemplate = this.hoganUtils.template(iconsBaseTemplatesPath, "file"); - var fileTagTemplate = this.hoganUtils.template(tagsBaseTemplatesPath, renderUtils.getFileIcon(file)); - return fileDiffTemplate.render({ - file, - fileHtmlId: renderUtils.getHtmlId(file), - diffs, - filePath: filePathTemplate.render({ - fileDiffName: renderUtils.filenameDiff(file) - }, { - fileIcon: fileIconTemplate, - fileTag: fileTagTemplate - }) - }); - }; - LineByLineRenderer2.prototype.generateEmptyDiff = function() { - return this.hoganUtils.render(genericTemplatesPath, "empty-diff", { - contentClass: "d2h-code-line", - CSSLineClass: renderUtils.CSSLineClass - }); - }; - LineByLineRenderer2.prototype.generateFileHtml = function(file) { - var _this = this; - var matcher = Rematch.newMatcherFn(Rematch.newDistanceFn(function(e) { - return renderUtils.deconstructLine(e.content, file.isCombined).content; - })); - return file.blocks.map(function(block) { - var lines = _this.hoganUtils.render(genericTemplatesPath, "block-header", { - CSSLineClass: renderUtils.CSSLineClass, - blockHeader: file.isTooBig ? block.header : renderUtils.escapeForHtml(block.header), - lineClass: "d2h-code-linenumber", - contentClass: "d2h-code-line" - }); - _this.applyLineGroupping(block).forEach(function(_a2) { - var contextLines = _a2[0], oldLines = _a2[1], newLines = _a2[2]; - if (oldLines.length && newLines.length && !contextLines.length) { - _this.applyRematchMatching(oldLines, newLines, matcher).map(function(_a3) { - var oldLines2 = _a3[0], newLines2 = _a3[1]; - var _b2 = _this.processChangedLines(file.isCombined, oldLines2, newLines2), left2 = _b2.left, right2 = _b2.right; - lines += left2; - lines += right2; - }); - } else if (contextLines.length) { - contextLines.forEach(function(line) { - var _a3 = renderUtils.deconstructLine(line.content, file.isCombined), prefix = _a3.prefix, content = _a3.content; - lines += _this.generateSingleLineHtml({ - type: renderUtils.CSSLineClass.CONTEXT, - prefix, - content, - oldNumber: line.oldNumber, - newNumber: line.newNumber - }); - }); - } else if (oldLines.length || newLines.length) { - var _b = _this.processChangedLines(file.isCombined, oldLines, newLines), left = _b.left, right = _b.right; - lines += left; - lines += right; - } else { - console.error("Unknown state reached while processing groups of lines", contextLines, oldLines, newLines); - } - }); - return lines; - }).join("\n"); - }; - LineByLineRenderer2.prototype.applyLineGroupping = function(block) { - var blockLinesGroups = []; - var oldLines = []; - var newLines = []; - for (var i = 0; i < block.lines.length; i++) { - var diffLine = block.lines[i]; - if (diffLine.type !== types_1.LineType.INSERT && newLines.length || diffLine.type === types_1.LineType.CONTEXT && oldLines.length > 0) { - blockLinesGroups.push([[], oldLines, newLines]); - oldLines = []; - newLines = []; - } - if (diffLine.type === types_1.LineType.CONTEXT) { - blockLinesGroups.push([[diffLine], [], []]); - } else if (diffLine.type === types_1.LineType.INSERT && oldLines.length === 0) { - blockLinesGroups.push([[], [], [diffLine]]); - } else if (diffLine.type === types_1.LineType.INSERT && oldLines.length > 0) { - newLines.push(diffLine); - } else if (diffLine.type === types_1.LineType.DELETE) { - oldLines.push(diffLine); - } - } - if (oldLines.length || newLines.length) { - blockLinesGroups.push([[], oldLines, newLines]); - oldLines = []; - newLines = []; - } - return blockLinesGroups; - }; - LineByLineRenderer2.prototype.applyRematchMatching = function(oldLines, newLines, matcher) { - var comparisons = oldLines.length * newLines.length; - var maxLineSizeInBlock = Math.max.apply(null, [0].concat(oldLines.concat(newLines).map(function(elem) { - return elem.content.length; - }))); - var doMatching = comparisons < this.config.matchingMaxComparisons && maxLineSizeInBlock < this.config.maxLineSizeInBlockForComparison && (this.config.matching === "lines" || this.config.matching === "words"); - return doMatching ? matcher(oldLines, newLines) : [[oldLines, newLines]]; - }; - LineByLineRenderer2.prototype.processChangedLines = function(isCombined, oldLines, newLines) { - var fileHtml = { - right: "", - left: "" - }; - var maxLinesNumber = Math.max(oldLines.length, newLines.length); - for (var i = 0; i < maxLinesNumber; i++) { - var oldLine = oldLines[i]; - var newLine = newLines[i]; - var diff = oldLine !== void 0 && newLine !== void 0 ? renderUtils.diffHighlight(oldLine.content, newLine.content, isCombined, this.config) : void 0; - var preparedOldLine = oldLine !== void 0 && oldLine.oldNumber !== void 0 ? __assign2(__assign2({}, diff !== void 0 ? { - prefix: diff.oldLine.prefix, - content: diff.oldLine.content, - type: renderUtils.CSSLineClass.DELETE_CHANGES - } : __assign2(__assign2({}, renderUtils.deconstructLine(oldLine.content, isCombined)), { type: renderUtils.toCSSClass(oldLine.type) })), { oldNumber: oldLine.oldNumber, newNumber: oldLine.newNumber }) : void 0; - var preparedNewLine = newLine !== void 0 && newLine.newNumber !== void 0 ? __assign2(__assign2({}, diff !== void 0 ? { - prefix: diff.newLine.prefix, - content: diff.newLine.content, - type: renderUtils.CSSLineClass.INSERT_CHANGES - } : __assign2(__assign2({}, renderUtils.deconstructLine(newLine.content, isCombined)), { type: renderUtils.toCSSClass(newLine.type) })), { oldNumber: newLine.oldNumber, newNumber: newLine.newNumber }) : void 0; - var _a2 = this.generateLineHtml(preparedOldLine, preparedNewLine), left = _a2.left, right = _a2.right; - fileHtml.left += left; - fileHtml.right += right; - } - return fileHtml; - }; - LineByLineRenderer2.prototype.generateLineHtml = function(oldLine, newLine) { - return { - left: this.generateSingleLineHtml(oldLine), - right: this.generateSingleLineHtml(newLine) - }; - }; - LineByLineRenderer2.prototype.generateSingleLineHtml = function(line) { - if (line === void 0) - return ""; - var lineNumberHtml = this.hoganUtils.render(baseTemplatesPath, "numbers", { - oldNumber: line.oldNumber || "", - newNumber: line.newNumber || "" - }); - return this.hoganUtils.render(genericTemplatesPath, "line", { - type: line.type, - lineClass: "d2h-code-linenumber", - contentClass: "d2h-code-line", - prefix: line.prefix === " " ? " " : line.prefix, - content: line.content, - lineNumber: lineNumberHtml - }); - }; - return LineByLineRenderer2; - }(); - exports.default = LineByLineRenderer; - } -}); - -// node_modules/diff2html/lib/side-by-side-renderer.js -var require_side_by_side_renderer = __commonJS({ - "node_modules/diff2html/lib/side-by-side-renderer.js"(exports) { - "use strict"; - var __assign2 = exports && exports.__assign || function() { - __assign2 = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign2.apply(this, arguments); - }; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.defaultSideBySideRendererConfig = void 0; - var Rematch = __importStar2(require_rematch()); - var renderUtils = __importStar2(require_render_utils()); - var types_1 = require_types(); - exports.defaultSideBySideRendererConfig = __assign2(__assign2({}, renderUtils.defaultRenderConfig), { renderNothingWhenEmpty: false, matchingMaxComparisons: 2500, maxLineSizeInBlockForComparison: 200 }); - var genericTemplatesPath = "generic"; - var baseTemplatesPath = "side-by-side"; - var iconsBaseTemplatesPath = "icon"; - var tagsBaseTemplatesPath = "tag"; - var SideBySideRenderer = function() { - function SideBySideRenderer2(hoganUtils, config) { - if (config === void 0) { - config = {}; - } - this.hoganUtils = hoganUtils; - this.config = __assign2(__assign2({}, exports.defaultSideBySideRendererConfig), config); - } - SideBySideRenderer2.prototype.render = function(diffFiles) { - var _this = this; - var diffsHtml = diffFiles.map(function(file) { - var diffs; - if (file.blocks.length) { - diffs = _this.generateFileHtml(file); - } else { - diffs = _this.generateEmptyDiff(); - } - return _this.makeFileDiffHtml(file, diffs); - }).join("\n"); - return this.hoganUtils.render(genericTemplatesPath, "wrapper", { content: diffsHtml }); - }; - SideBySideRenderer2.prototype.makeFileDiffHtml = function(file, diffs) { - if (this.config.renderNothingWhenEmpty && Array.isArray(file.blocks) && file.blocks.length === 0) - return ""; - var fileDiffTemplate = this.hoganUtils.template(baseTemplatesPath, "file-diff"); - var filePathTemplate = this.hoganUtils.template(genericTemplatesPath, "file-path"); - var fileIconTemplate = this.hoganUtils.template(iconsBaseTemplatesPath, "file"); - var fileTagTemplate = this.hoganUtils.template(tagsBaseTemplatesPath, renderUtils.getFileIcon(file)); - return fileDiffTemplate.render({ - file, - fileHtmlId: renderUtils.getHtmlId(file), - diffs, - filePath: filePathTemplate.render({ - fileDiffName: renderUtils.filenameDiff(file) - }, { - fileIcon: fileIconTemplate, - fileTag: fileTagTemplate - }) - }); - }; - SideBySideRenderer2.prototype.generateEmptyDiff = function() { - return { - right: "", - left: this.hoganUtils.render(genericTemplatesPath, "empty-diff", { - contentClass: "d2h-code-side-line", - CSSLineClass: renderUtils.CSSLineClass - }) - }; - }; - SideBySideRenderer2.prototype.generateFileHtml = function(file) { - var _this = this; - var matcher = Rematch.newMatcherFn(Rematch.newDistanceFn(function(e) { - return renderUtils.deconstructLine(e.content, file.isCombined).content; - })); - return file.blocks.map(function(block) { - var fileHtml = { - left: _this.makeHeaderHtml(block.header, file), - right: _this.makeHeaderHtml("") - }; - _this.applyLineGroupping(block).forEach(function(_a2) { - var contextLines = _a2[0], oldLines = _a2[1], newLines = _a2[2]; - if (oldLines.length && newLines.length && !contextLines.length) { - _this.applyRematchMatching(oldLines, newLines, matcher).map(function(_a3) { - var oldLines2 = _a3[0], newLines2 = _a3[1]; - var _b2 = _this.processChangedLines(file.isCombined, oldLines2, newLines2), left2 = _b2.left, right2 = _b2.right; - fileHtml.left += left2; - fileHtml.right += right2; - }); - } else if (contextLines.length) { - contextLines.forEach(function(line) { - var _a3 = renderUtils.deconstructLine(line.content, file.isCombined), prefix = _a3.prefix, content = _a3.content; - var _b2 = _this.generateLineHtml({ - type: renderUtils.CSSLineClass.CONTEXT, - prefix, - content, - number: line.oldNumber - }, { - type: renderUtils.CSSLineClass.CONTEXT, - prefix, - content, - number: line.newNumber - }), left2 = _b2.left, right2 = _b2.right; - fileHtml.left += left2; - fileHtml.right += right2; - }); - } else if (oldLines.length || newLines.length) { - var _b = _this.processChangedLines(file.isCombined, oldLines, newLines), left = _b.left, right = _b.right; - fileHtml.left += left; - fileHtml.right += right; - } else { - console.error("Unknown state reached while processing groups of lines", contextLines, oldLines, newLines); - } - }); - return fileHtml; - }).reduce(function(accomulated, html2) { - return { left: accomulated.left + html2.left, right: accomulated.right + html2.right }; - }, { left: "", right: "" }); - }; - SideBySideRenderer2.prototype.applyLineGroupping = function(block) { - var blockLinesGroups = []; - var oldLines = []; - var newLines = []; - for (var i = 0; i < block.lines.length; i++) { - var diffLine = block.lines[i]; - if (diffLine.type !== types_1.LineType.INSERT && newLines.length || diffLine.type === types_1.LineType.CONTEXT && oldLines.length > 0) { - blockLinesGroups.push([[], oldLines, newLines]); - oldLines = []; - newLines = []; - } - if (diffLine.type === types_1.LineType.CONTEXT) { - blockLinesGroups.push([[diffLine], [], []]); - } else if (diffLine.type === types_1.LineType.INSERT && oldLines.length === 0) { - blockLinesGroups.push([[], [], [diffLine]]); - } else if (diffLine.type === types_1.LineType.INSERT && oldLines.length > 0) { - newLines.push(diffLine); - } else if (diffLine.type === types_1.LineType.DELETE) { - oldLines.push(diffLine); - } - } - if (oldLines.length || newLines.length) { - blockLinesGroups.push([[], oldLines, newLines]); - oldLines = []; - newLines = []; - } - return blockLinesGroups; - }; - SideBySideRenderer2.prototype.applyRematchMatching = function(oldLines, newLines, matcher) { - var comparisons = oldLines.length * newLines.length; - var maxLineSizeInBlock = Math.max.apply(null, [0].concat(oldLines.concat(newLines).map(function(elem) { - return elem.content.length; - }))); - var doMatching = comparisons < this.config.matchingMaxComparisons && maxLineSizeInBlock < this.config.maxLineSizeInBlockForComparison && (this.config.matching === "lines" || this.config.matching === "words"); - return doMatching ? matcher(oldLines, newLines) : [[oldLines, newLines]]; - }; - SideBySideRenderer2.prototype.makeHeaderHtml = function(blockHeader, file) { - return this.hoganUtils.render(genericTemplatesPath, "block-header", { - CSSLineClass: renderUtils.CSSLineClass, - blockHeader: (file === null || file === void 0 ? void 0 : file.isTooBig) ? blockHeader : renderUtils.escapeForHtml(blockHeader), - lineClass: "d2h-code-side-linenumber", - contentClass: "d2h-code-side-line" - }); - }; - SideBySideRenderer2.prototype.processChangedLines = function(isCombined, oldLines, newLines) { - var fileHtml = { - right: "", - left: "" - }; - var maxLinesNumber = Math.max(oldLines.length, newLines.length); - for (var i = 0; i < maxLinesNumber; i++) { - var oldLine = oldLines[i]; - var newLine = newLines[i]; - var diff = oldLine !== void 0 && newLine !== void 0 ? renderUtils.diffHighlight(oldLine.content, newLine.content, isCombined, this.config) : void 0; - var preparedOldLine = oldLine !== void 0 && oldLine.oldNumber !== void 0 ? __assign2(__assign2({}, diff !== void 0 ? { - prefix: diff.oldLine.prefix, - content: diff.oldLine.content, - type: renderUtils.CSSLineClass.DELETE_CHANGES - } : __assign2(__assign2({}, renderUtils.deconstructLine(oldLine.content, isCombined)), { type: renderUtils.toCSSClass(oldLine.type) })), { number: oldLine.oldNumber }) : void 0; - var preparedNewLine = newLine !== void 0 && newLine.newNumber !== void 0 ? __assign2(__assign2({}, diff !== void 0 ? { - prefix: diff.newLine.prefix, - content: diff.newLine.content, - type: renderUtils.CSSLineClass.INSERT_CHANGES - } : __assign2(__assign2({}, renderUtils.deconstructLine(newLine.content, isCombined)), { type: renderUtils.toCSSClass(newLine.type) })), { number: newLine.newNumber }) : void 0; - var _a2 = this.generateLineHtml(preparedOldLine, preparedNewLine), left = _a2.left, right = _a2.right; - fileHtml.left += left; - fileHtml.right += right; - } - return fileHtml; - }; - SideBySideRenderer2.prototype.generateLineHtml = function(oldLine, newLine) { - return { - left: this.generateSingleHtml(oldLine), - right: this.generateSingleHtml(newLine) - }; - }; - SideBySideRenderer2.prototype.generateSingleHtml = function(line) { - var lineClass = "d2h-code-side-linenumber"; - var contentClass = "d2h-code-side-line"; - return this.hoganUtils.render(genericTemplatesPath, "line", { - type: (line === null || line === void 0 ? void 0 : line.type) || "".concat(renderUtils.CSSLineClass.CONTEXT, " d2h-emptyplaceholder"), - lineClass: line !== void 0 ? lineClass : "".concat(lineClass, " d2h-code-side-emptyplaceholder"), - contentClass: line !== void 0 ? contentClass : "".concat(contentClass, " d2h-code-side-emptyplaceholder"), - prefix: (line === null || line === void 0 ? void 0 : line.prefix) === " " ? " " : line === null || line === void 0 ? void 0 : line.prefix, - content: line === null || line === void 0 ? void 0 : line.content, - lineNumber: line === null || line === void 0 ? void 0 : line.number - }); - }; - return SideBySideRenderer2; - }(); - exports.default = SideBySideRenderer; - } -}); - // node_modules/hogan.js/lib/compiler.js var require_compiler = __commonJS({ "node_modules/hogan.js/lib/compiler.js"(exports) { - (function(Hogan2) { + init_polyfill_buffer(); + (function(Hogan4) { var rIsWhitespace = /\S/, rQuot = /\"/g, rNewline = /\n/g, rCr = /\r/g, rSlash = /\\/g, rLineSep = /\u2028/, rParagraphSep = /\u2029/; - Hogan2.tags = { + Hogan4.tags = { "#": 1, "^": 2, "<": 3, @@ -3746,8 +7790,8 @@ var require_compiler = __commonJS({ "&": 11, "_t": 12 }; - Hogan2.scan = function scan(text2, delimiters) { - var len = text2.length, IN_TEXT = 0, IN_TAG_TYPE = 1, IN_TAG = 2, state = IN_TEXT, tagType = null, tag = null, buf = "", tokens = [], seenTag = false, i = 0, lineStart = 0, otag = "{{", ctag = "}}"; + Hogan4.scan = function scan(text2, delimiters) { + var len = text2.length, IN_TEXT = 0, IN_TAG_TYPE = 1, IN_TAG = 2, state = IN_TEXT, tagType = null, tag2 = null, buf = "", tokens = [], seenTag = false, i = 0, lineStart = 0, otag = "{{", ctag = "}}"; function addBuf() { if (buf.length > 0) { tokens.push({ tag: "_t", text: new String(buf) }); @@ -3757,7 +7801,7 @@ var require_compiler = __commonJS({ function lineIsWhitespace() { var isAllWhitespace = true; for (var j = lineStart; j < tokens.length; j++) { - isAllWhitespace = Hogan2.tags[tokens[j].tag] < Hogan2.tags["_v"] || tokens[j].tag == "_t" && tokens[j].text.match(rIsWhitespace) === null; + isAllWhitespace = Hogan4.tags[tokens[j].tag] < Hogan4.tags["_v"] || tokens[j].tag == "_t" && tokens[j].text.match(rIsWhitespace) === null; if (!isAllWhitespace) { return false; } @@ -3781,8 +7825,8 @@ var require_compiler = __commonJS({ seenTag = false; lineStart = tokens.length; } - function changeDelimiters(text3, index) { - var close = "=" + ctag, closeIndex = text3.indexOf(close, index), delimiters2 = trim(text3.substring(text3.indexOf("=", index) + 1, closeIndex)).split(" "); + function changeDelimiters(text3, index2) { + var close = "=" + ctag, closeIndex = text3.indexOf(close, index2), delimiters2 = trim(text3.substring(text3.indexOf("=", index2) + 1, closeIndex)).split(" "); otag = delimiters2[0]; ctag = delimiters2[delimiters2.length - 1]; return closeIndex + close.length - 1; @@ -3807,13 +7851,13 @@ var require_compiler = __commonJS({ } } else if (state == IN_TAG_TYPE) { i += otag.length - 1; - tag = Hogan2.tags[text2.charAt(i + 1)]; - tagType = tag ? text2.charAt(i + 1) : "_v"; + tag2 = Hogan4.tags[text2.charAt(i + 1)]; + tagType = tag2 ? text2.charAt(i + 1) : "_v"; if (tagType == "=") { i = changeDelimiters(text2, i); state = IN_TEXT; } else { - if (tag) { + if (tag2) { i++; } state = IN_TAG; @@ -3857,12 +7901,12 @@ var require_compiler = __commonJS({ } return s.replace(/^\s*|\s*$/g, ""); } - function tagChange(tag, text2, index) { - if (text2.charAt(index) != tag.charAt(0)) { + function tagChange(tag2, text2, index2) { + if (text2.charAt(index2) != tag2.charAt(0)) { return false; } - for (var i = 1, l = tag.length; i < l; i++) { - if (text2.charAt(index + i) != tag.charAt(i)) { + for (var i = 1, l = tag2.length; i < l; i++) { + if (text2.charAt(index2 + i) != tag2.charAt(i)) { return false; } } @@ -3877,7 +7921,7 @@ var require_compiler = __commonJS({ if (tail && tail.tag == "<" && !(token.tag in allowedInSuper)) { throw new Error("Illegal content in < super tag."); } - if (Hogan2.tags[token.tag] <= Hogan2.tags["$"] || isOpener(token, customTags)) { + if (Hogan4.tags[token.tag] <= Hogan4.tags["$"] || isOpener(token, customTags)) { stack.push(token); token.nodes = buildTree(tokens, token.tag, stack, customTags); } else if (token.tag == "/") { @@ -3929,29 +7973,29 @@ var require_compiler = __commonJS({ } return "partials: {" + partials.join(",") + "}, subs: " + stringifySubstitutions(codeObj.subs); } - Hogan2.stringify = function(codeObj, text2, options) { - return "{code: function (c,p,i) { " + Hogan2.wrapMain(codeObj.code) + " }," + stringifyPartials(codeObj) + "}"; + Hogan4.stringify = function(codeObj, text2, options) { + return "{code: function (c,p,i) { " + Hogan4.wrapMain(codeObj.code) + " }," + stringifyPartials(codeObj) + "}"; }; var serialNo = 0; - Hogan2.generate = function(tree, text2, options) { + Hogan4.generate = function(tree, text2, options) { serialNo = 0; var context = { code: "", subs: {}, partials: {} }; - Hogan2.walk(tree, context); + Hogan4.walk(tree, context); if (options.asString) { return this.stringify(context, text2, options); } return this.makeTemplate(context, text2, options); }; - Hogan2.wrapMain = function(code) { + Hogan4.wrapMain = function(code) { return 'var t=this;t.b(i=i||"");' + code + "return t.fl();"; }; - Hogan2.template = Hogan2.Template; - Hogan2.makeTemplate = function(codeObj, text2, options) { + Hogan4.template = Hogan4.Template; + Hogan4.makeTemplate = function(codeObj, text2, options) { var template = this.makePartials(codeObj); template.code = new Function("c", "p", "i", this.wrapMain(codeObj.code)); return new this.template(template, text2, this, options); }; - Hogan2.makePartials = function(codeObj) { + Hogan4.makePartials = function(codeObj) { var key2, template = { subs: {}, partials: codeObj.partials, name: codeObj.name }; for (key2 in template.partials) { template.partials[key2] = this.makePartials(template.partials[key2]); @@ -3974,28 +8018,28 @@ var require_compiler = __commonJS({ context.code += 't.b(t.rp("' + esc(sym) + '",c,p,"' + (node.indent || "") + '"));'; return sym; } - Hogan2.codegen = { + Hogan4.codegen = { "#": function(node, context) { context.code += "if(t.s(t." + chooseMethod(node.n) + '("' + esc(node.n) + '",c,p,1),c,p,0,' + node.i + "," + node.end + ',"' + node.otag + " " + node.ctag + '")){t.rs(c,p,function(c,p,t){'; - Hogan2.walk(node.nodes, context); + Hogan4.walk(node.nodes, context); context.code += "});c.pop();}"; }, "^": function(node, context) { context.code += "if(!t.s(t." + chooseMethod(node.n) + '("' + esc(node.n) + '",c,p,1),c,p,1,0,0,"")){'; - Hogan2.walk(node.nodes, context); + Hogan4.walk(node.nodes, context); context.code += "};"; }, ">": createPartial, "<": function(node, context) { var ctx = { partials: {}, code: "", subs: {}, inPartial: true }; - Hogan2.walk(node.nodes, ctx); + Hogan4.walk(node.nodes, ctx); var template = context.partials[createPartial(node, context)]; template.subs = ctx.subs; template.partials = ctx.partials; }, "$": function(node, context) { var ctx = { subs: {}, code: "", partials: context.partials, prefix: node.n }; - Hogan2.walk(node.nodes, ctx); + Hogan4.walk(node.nodes, ctx); context.subs[node.n] = ctx.code; if (!context.inPartial) { context.code += 't.sub("' + esc(node.n) + '",c,p,i);'; @@ -4019,25 +8063,25 @@ var require_compiler = __commonJS({ function write(s) { return "t.b(" + s + ");"; } - Hogan2.walk = function(nodelist, context) { + Hogan4.walk = function(nodelist, context) { var func; for (var i = 0, l = nodelist.length; i < l; i++) { - func = Hogan2.codegen[nodelist[i].tag]; + func = Hogan4.codegen[nodelist[i].tag]; func && func(nodelist[i], context); } return context; }; - Hogan2.parse = function(tokens, text2, options) { + Hogan4.parse = function(tokens, text2, options) { options = options || {}; return buildTree(tokens, "", [], options.sectionTags || []); }; - Hogan2.cache = {}; - Hogan2.cacheKey = function(text2, options) { + Hogan4.cache = {}; + Hogan4.cacheKey = function(text2, options) { return [text2, !!options.asString, !!options.disableLambda, options.delimiters, !!options.modelGet].join("||"); }; - Hogan2.compile = function(text2, options) { + Hogan4.compile = function(text2, options) { options = options || {}; - var key2 = Hogan2.cacheKey(text2, options); + var key2 = Hogan4.cacheKey(text2, options); var template = this.cache[key2]; if (template) { var partials = template.partials; @@ -4056,9 +8100,10 @@ var require_compiler = __commonJS({ // node_modules/hogan.js/lib/template.js var require_template = __commonJS({ "node_modules/hogan.js/lib/template.js"(exports) { - var Hogan2 = {}; - (function(Hogan3) { - Hogan3.Template = function(codeObj, text2, compiler, options) { + init_polyfill_buffer(); + var Hogan4 = {}; + (function(Hogan5) { + Hogan5.Template = function(codeObj, text2, compiler, options) { codeObj = codeObj || {}; this.r = codeObj.code || this.r; this.c = compiler; @@ -4068,17 +8113,17 @@ var require_template = __commonJS({ this.subs = codeObj.subs || {}; this.buf = ""; }; - Hogan3.Template.prototype = { - r: function(context, partials, indent) { + Hogan5.Template.prototype = { + r: function(context, partials, indent2) { return ""; }, v: hoganEscape, t: coerceToString, - render: function render(context, partials, indent) { - return this.ri([context], partials || {}, indent); + render: function render2(context, partials, indent2) { + return this.ri([context], partials || {}, indent2); }, - ri: function(context, partials, indent) { - return this.r(context, partials, indent); + ri: function(context, partials, indent2) { + return this.r(context, partials, indent2); }, ep: function(symbol, partials) { var partial = this.partials[symbol]; @@ -4109,12 +8154,12 @@ var require_template = __commonJS({ this.partials[symbol].instance = template; return template; }, - rp: function(symbol, context, partials, indent) { + rp: function(symbol, context, partials, indent2) { var partial = this.ep(symbol, partials); if (!partial) { return ""; } - return partial.ri(context, partials, indent); + return partial.ri(context, partials, indent2); }, rs: function(context, partials, section) { var tail = context[context.length - 1]; @@ -4226,11 +8271,11 @@ var require_template = __commonJS({ } return result; }, - sub: function(name, context, partials, indent) { + sub: function(name, context, partials, indent2) { var f = this.subs[name]; if (f) { this.activeSub = name; - f(context, partials, this, indent); + f(context, partials, this, indent2); this.activeSub = false; } } @@ -4292,1065 +8337,25 @@ var require_template = __commonJS({ var isArray = Array.isArray || function(a) { return Object.prototype.toString.call(a) === "[object Array]"; }; - })(typeof exports !== "undefined" ? exports : Hogan2); + })(typeof exports !== "undefined" ? exports : Hogan4); } }); // node_modules/hogan.js/lib/hogan.js var require_hogan = __commonJS({ "node_modules/hogan.js/lib/hogan.js"(exports, module2) { - var Hogan2 = require_compiler(); - Hogan2.Template = require_template().Template; - Hogan2.template = Hogan2.Template; - module2.exports = Hogan2; - } -}); - -// node_modules/diff2html/lib/diff2html-templates.js -var require_diff2html_templates = __commonJS({ - "node_modules/diff2html/lib/diff2html-templates.js"(exports) { - "use strict"; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.defaultTemplates = void 0; - var Hogan2 = __importStar2(require_hogan()); - exports.defaultTemplates = {}; - exports.defaultTemplates["file-summary-line"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('
  • '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(t.rp("'); - t.b(t.v(t.f("fileName", c, p, 0))); - t.b(""); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(' '); - t.b(t.v(t.f("addedLines", c, p, 0))); - t.b(""); - t.b("\n" + i); - t.b(' '); - t.b(t.v(t.f("deletedLines", c, p, 0))); - t.b(""); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b("
  • "); - return t.fl(); - }, partials: { "'); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(' Files changed ('); - t.b(t.v(t.f("filesNumber", c, p, 0))); - t.b(")"); - t.b("\n" + i); - t.b(' hide'); - t.b("\n" + i); - t.b(' show'); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b('
      '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.f("files", c, p, 0))); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b(""); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["generic-block-header"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b(""); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b('
    '); - t.b(t.t(t.f("blockHeader", c, p, 0))); - t.b("
    "); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b(""); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["generic-empty-diff"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b(""); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(" File without changes"); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b(""); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["generic-file-path"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b(''); - t.b("\n" + i); - t.b(t.rp("'); - t.b(t.v(t.f("fileDiffName", c, p, 0))); - t.b(""); - t.b("\n" + i); - t.b(t.rp(""); - t.b("\n" + i); - t.b('"); - return t.fl(); - }, partials: { ""); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.f("lineNumber", c, p, 0))); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - if (t.s(t.f("prefix", c, p, 1), c, p, 0, 162, 238, "{{ }}")) { - t.rs(c, p, function(c2, p2, t2) { - t2.b(' '); - t2.b(t2.t(t2.f("prefix", c2, p2, 0))); - t2.b(""); - t2.b("\n" + i); - }); - c.pop(); - } - if (!t.s(t.f("prefix", c, p, 1), c, p, 1, 0, 0, "")) { - t.b('  '); - t.b("\n" + i); - } - ; - if (t.s(t.f("content", c, p, 1), c, p, 0, 371, 445, "{{ }}")) { - t.rs(c, p, function(c2, p2, t2) { - t2.b(' '); - t2.b(t2.t(t2.f("content", c2, p2, 0))); - t2.b(""); - t2.b("\n" + i); - }); - c.pop(); - } - if (!t.s(t.f("content", c, p, 1), c, p, 1, 0, 0, "")) { - t.b('
    '); - t.b("\n" + i); - } - ; - t.b("
    "); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b(""); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["generic-wrapper"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('
    '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.f("content", c, p, 0))); - t.b("\n" + i); - t.b("
    "); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["icon-file-added"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('"); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["icon-file-changed"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('"); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["icon-file-deleted"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('"); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["icon-file-renamed"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('"); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["icon-file"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('"); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["line-by-line-file-diff"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('
    '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.f("filePath", c, p, 0))); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.f("diffs", c, p, 0))); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["line-by-line-numbers"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('
    '); - t.b(t.v(t.f("oldNumber", c, p, 0))); - t.b("
    "); - t.b("\n" + i); - t.b('
    '); - t.b(t.v(t.f("newNumber", c, p, 0))); - t.b("
    "); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["side-by-side-file-diff"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('
    '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.f("filePath", c, p, 0))); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.d("diffs.left", c, p, 0))); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b('
    '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(' '); - t.b("\n" + i); - t.b(" "); - t.b(t.t(t.d("diffs.right", c, p, 0))); - t.b("\n" + i); - t.b(" "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - t.b("\n" + i); - t.b("
    "); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["tag-file-added"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('ADDED'); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["tag-file-changed"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('CHANGED'); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["tag-file-deleted"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('DELETED'); - return t.fl(); - }, partials: {}, subs: {} }); - exports.defaultTemplates["tag-file-renamed"] = new Hogan2.Template({ code: function(c, p, i) { - var t = this; - t.b(i = i || ""); - t.b('RENAMED'); - return t.fl(); - }, partials: {}, subs: {} }); - } -}); - -// node_modules/diff2html/lib/hoganjs-utils.js -var require_hoganjs_utils = __commonJS({ - "node_modules/diff2html/lib/hoganjs-utils.js"(exports) { - "use strict"; - var __assign2 = exports && exports.__assign || function() { - __assign2 = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign2.apply(this, arguments); - }; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - var Hogan2 = __importStar2(require_hogan()); - var diff2html_templates_1 = require_diff2html_templates(); - var HoganJsUtils = function() { - function HoganJsUtils2(_a2) { - var _b = _a2.compiledTemplates, compiledTemplates = _b === void 0 ? {} : _b, _c = _a2.rawTemplates, rawTemplates = _c === void 0 ? {} : _c; - var compiledRawTemplates = Object.entries(rawTemplates).reduce(function(previousTemplates, _a3) { - var _b2; - var name = _a3[0], templateString = _a3[1]; - var compiledTemplate = Hogan2.compile(templateString, { asString: false }); - return __assign2(__assign2({}, previousTemplates), (_b2 = {}, _b2[name] = compiledTemplate, _b2)); - }, {}); - this.preCompiledTemplates = __assign2(__assign2(__assign2({}, diff2html_templates_1.defaultTemplates), compiledTemplates), compiledRawTemplates); - } - HoganJsUtils2.compile = function(templateString) { - return Hogan2.compile(templateString, { asString: false }); - }; - HoganJsUtils2.prototype.render = function(namespace, view, params, partials, indent) { - var templateKey = this.templateKey(namespace, view); - try { - var template = this.preCompiledTemplates[templateKey]; - return template.render(params, partials, indent); - } catch (e) { - throw new Error("Could not find template to render '".concat(templateKey, "'")); - } - }; - HoganJsUtils2.prototype.template = function(namespace, view) { - return this.preCompiledTemplates[this.templateKey(namespace, view)]; - }; - HoganJsUtils2.prototype.templateKey = function(namespace, view) { - return "".concat(namespace, "-").concat(view); - }; - return HoganJsUtils2; - }(); - exports.default = HoganJsUtils; - } -}); - -// node_modules/diff2html/lib/diff2html.js -var require_diff2html = __commonJS({ - "node_modules/diff2html/lib/diff2html.js"(exports) { - "use strict"; - var __assign2 = exports && exports.__assign || function() { - __assign2 = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign2.apply(this, arguments); - }; - var __createBinding2 = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }); - var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }); - var __importStar2 = exports && exports.__importStar || function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - var __importDefault2 = exports && exports.__importDefault || function(mod) { - return mod && mod.__esModule ? mod : { "default": mod }; - }; - Object.defineProperty(exports, "__esModule", { value: true }); - exports.html = exports.parse = exports.defaultDiff2HtmlConfig = void 0; - var DiffParser = __importStar2(require_diff_parser()); - var fileListPrinter = __importStar2(require_file_list_renderer()); - var line_by_line_renderer_1 = __importStar2(require_line_by_line_renderer()); - var side_by_side_renderer_1 = __importStar2(require_side_by_side_renderer()); - var types_1 = require_types(); - var hoganjs_utils_1 = __importDefault2(require_hoganjs_utils()); - exports.defaultDiff2HtmlConfig = __assign2(__assign2(__assign2({}, line_by_line_renderer_1.defaultLineByLineRendererConfig), side_by_side_renderer_1.defaultSideBySideRendererConfig), { outputFormat: types_1.OutputFormatType.LINE_BY_LINE, drawFileList: true }); - function parse(diffInput, configuration) { - if (configuration === void 0) { - configuration = {}; - } - return DiffParser.parse(diffInput, __assign2(__assign2({}, exports.defaultDiff2HtmlConfig), configuration)); - } - exports.parse = parse; - function html2(diffInput, configuration) { - if (configuration === void 0) { - configuration = {}; - } - var config = __assign2(__assign2({}, exports.defaultDiff2HtmlConfig), configuration); - var diffJson = typeof diffInput === "string" ? DiffParser.parse(diffInput, config) : diffInput; - var hoganUtils = new hoganjs_utils_1.default(config); - var fileList = config.drawFileList ? fileListPrinter.render(diffJson, hoganUtils) : ""; - var diffOutput = config.outputFormat === "side-by-side" ? new side_by_side_renderer_1.default(hoganUtils, config).render(diffJson) : new line_by_line_renderer_1.default(hoganUtils, config).render(diffJson); - return fileList + diffOutput; - } - exports.html = html2; - } -}); - -// node_modules/tslib/tslib.js -var require_tslib = __commonJS({ - "node_modules/tslib/tslib.js"(exports, module2) { - var __extends2; - var __assign2; - var __rest2; - var __decorate2; - var __param2; - var __metadata2; - var __awaiter2; - var __generator2; - var __exportStar2; - var __values2; - var __read2; - var __spread2; - var __spreadArrays2; - var __spreadArray2; - var __await2; - var __asyncGenerator2; - var __asyncDelegator2; - var __asyncValues2; - var __makeTemplateObject2; - var __importStar2; - var __importDefault2; - var __classPrivateFieldGet2; - var __classPrivateFieldSet2; - var __classPrivateFieldIn2; - var __createBinding2; - (function(factory) { - var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {}; - if (typeof define === "function" && define.amd) { - define("tslib", ["exports"], function(exports2) { - factory(createExporter(root, createExporter(exports2))); - }); - } else if (typeof module2 === "object" && typeof module2.exports === "object") { - factory(createExporter(root, createExporter(module2.exports))); - } else { - factory(createExporter(root)); - } - function createExporter(exports2, previous) { - if (exports2 !== root) { - if (typeof Object.create === "function") { - Object.defineProperty(exports2, "__esModule", { value: true }); - } else { - exports2.__esModule = true; - } - } - return function(id, v) { - return exports2[id] = previous ? previous(id, v) : v; - }; - } - })(function(exporter) { - var extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d, b) { - d.__proto__ = b; - } || function(d, b) { - for (var p in b) - if (Object.prototype.hasOwnProperty.call(b, p)) - d[p] = b[p]; - }; - __extends2 = function(d, b) { - if (typeof b !== "function" && b !== null) - throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); - extendStatics(d, b); - function __() { - this.constructor = d; - } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; - __assign2 = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - __rest2 = function(s, e) { - var t = {}; - for (var p in s) - if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) - t[p] = s[p]; - if (s != null && typeof Object.getOwnPropertySymbols === "function") - for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { - if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) - t[p[i]] = s[p[i]]; - } - return t; - }; - __decorate2 = function(decorators, target, key2, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key2) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") - r = Reflect.decorate(decorators, target, key2, desc); - else - for (var i = decorators.length - 1; i >= 0; i--) - if (d = decorators[i]) - r = (c < 3 ? d(r) : c > 3 ? d(target, key2, r) : d(target, key2)) || r; - return c > 3 && r && Object.defineProperty(target, key2, r), r; - }; - __param2 = function(paramIndex, decorator) { - return function(target, key2) { - decorator(target, key2, paramIndex); - }; - }; - __metadata2 = function(metadataKey, metadataValue) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") - return Reflect.metadata(metadataKey, metadataValue); - }; - __awaiter2 = function(thisArg, _arguments, P, generator) { - function adopt(value) { - return value instanceof P ? value : new P(function(resolve) { - resolve(value); - }); - } - return new (P || (P = Promise))(function(resolve, reject) { - function fulfilled(value) { - try { - step(generator.next(value)); - } catch (e) { - reject(e); - } - } - function rejected(value) { - try { - step(generator["throw"](value)); - } catch (e) { - reject(e); - } - } - function step(result) { - result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); - } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); - }; - __generator2 = function(thisArg, body) { - var _ = { label: 0, sent: function() { - if (t[0] & 1) - throw t[1]; - return t[1]; - }, trys: [], ops: [] }, f, y, t, g; - return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { - return this; - }), g; - function verb(n) { - return function(v) { - return step([n, v]); - }; - } - function step(op) { - if (f) - throw new TypeError("Generator is already executing."); - while (_) - try { - if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) - return t; - if (y = 0, t) - op = [op[0] & 2, t.value]; - switch (op[0]) { - case 0: - case 1: - t = op; - break; - case 4: - _.label++; - return { value: op[1], done: false }; - case 5: - _.label++; - y = op[1]; - op = [0]; - continue; - case 7: - op = _.ops.pop(); - _.trys.pop(); - continue; - default: - if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { - _ = 0; - continue; - } - if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) { - _.label = op[1]; - break; - } - if (op[0] === 6 && _.label < t[1]) { - _.label = t[1]; - t = op; - break; - } - if (t && _.label < t[2]) { - _.label = t[2]; - _.ops.push(op); - break; - } - if (t[2]) - _.ops.pop(); - _.trys.pop(); - continue; - } - op = body.call(thisArg, _); - } catch (e) { - op = [6, e]; - y = 0; - } finally { - f = t = 0; - } - if (op[0] & 5) - throw op[1]; - return { value: op[0] ? op[1] : void 0, done: true }; - } - }; - __exportStar2 = function(m, o) { - for (var p in m) - if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) - __createBinding2(o, m, p); - }; - __createBinding2 = Object.create ? function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { - return m[k]; - } }; - } - Object.defineProperty(o, k2, desc); - } : function(o, m, k, k2) { - if (k2 === void 0) - k2 = k; - o[k2] = m[k]; - }; - __values2 = function(o) { - var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; - if (m) - return m.call(o); - if (o && typeof o.length === "number") - return { - next: function() { - if (o && i >= o.length) - o = void 0; - return { value: o && o[i++], done: !o }; - } - }; - throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); - }; - __read2 = function(o, n) { - var m = typeof Symbol === "function" && o[Symbol.iterator]; - if (!m) - return o; - var i = m.call(o), r, ar = [], e; - try { - while ((n === void 0 || n-- > 0) && !(r = i.next()).done) - ar.push(r.value); - } catch (error) { - e = { error }; - } finally { - try { - if (r && !r.done && (m = i["return"])) - m.call(i); - } finally { - if (e) - throw e.error; - } - } - return ar; - }; - __spread2 = function() { - for (var ar = [], i = 0; i < arguments.length; i++) - ar = ar.concat(__read2(arguments[i])); - return ar; - }; - __spreadArrays2 = function() { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) - s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - }; - __spreadArray2 = function(to, from, pack) { - if (pack || arguments.length === 2) - for (var i = 0, l = from.length, ar; i < l; i++) { - if (ar || !(i in from)) { - if (!ar) - ar = Array.prototype.slice.call(from, 0, i); - ar[i] = from[i]; - } - } - return to.concat(ar || Array.prototype.slice.call(from)); - }; - __await2 = function(v) { - return this instanceof __await2 ? (this.v = v, this) : new __await2(v); - }; - __asyncGenerator2 = function(thisArg, _arguments, generator) { - if (!Symbol.asyncIterator) - throw new TypeError("Symbol.asyncIterator is not defined."); - var g = generator.apply(thisArg, _arguments || []), i, q = []; - return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function() { - return this; - }, i; - function verb(n) { - if (g[n]) - i[n] = function(v) { - return new Promise(function(a, b) { - q.push([n, v, a, b]) > 1 || resume(n, v); - }); - }; - } - function resume(n, v) { - try { - step(g[n](v)); - } catch (e) { - settle(q[0][3], e); - } - } - function step(r) { - r.value instanceof __await2 ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); - } - function fulfill(value) { - resume("next", value); - } - function reject(value) { - resume("throw", value); - } - function settle(f, v) { - if (f(v), q.shift(), q.length) - resume(q[0][0], q[0][1]); - } - }; - __asyncDelegator2 = function(o) { - var i, p; - return i = {}, verb("next"), verb("throw", function(e) { - throw e; - }), verb("return"), i[Symbol.iterator] = function() { - return this; - }, i; - function verb(n, f) { - i[n] = o[n] ? function(v) { - return (p = !p) ? { value: __await2(o[n](v)), done: n === "return" } : f ? f(v) : v; - } : f; - } - }; - __asyncValues2 = function(o) { - if (!Symbol.asyncIterator) - throw new TypeError("Symbol.asyncIterator is not defined."); - var m = o[Symbol.asyncIterator], i; - return m ? m.call(o) : (o = typeof __values2 === "function" ? __values2(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function() { - return this; - }, i); - function verb(n) { - i[n] = o[n] && function(v) { - return new Promise(function(resolve, reject) { - v = o[n](v), settle(resolve, reject, v.done, v.value); - }); - }; - } - function settle(resolve, reject, d, v) { - Promise.resolve(v).then(function(v2) { - resolve({ value: v2, done: d }); - }, reject); - } - }; - __makeTemplateObject2 = function(cooked, raw) { - if (Object.defineProperty) { - Object.defineProperty(cooked, "raw", { value: raw }); - } else { - cooked.raw = raw; - } - return cooked; - }; - var __setModuleDefault = Object.create ? function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - } : function(o, v) { - o["default"] = v; - }; - __importStar2 = function(mod) { - if (mod && mod.__esModule) - return mod; - var result = {}; - if (mod != null) { - for (var k in mod) - if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) - __createBinding2(result, mod, k); - } - __setModuleDefault(result, mod); - return result; - }; - __importDefault2 = function(mod) { - return mod && mod.__esModule ? mod : { "default": mod }; - }; - __classPrivateFieldGet2 = function(receiver, state, kind, f) { - if (kind === "a" && !f) - throw new TypeError("Private accessor was defined without a getter"); - if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) - throw new TypeError("Cannot read private member from an object whose class did not declare it"); - return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver); - }; - __classPrivateFieldSet2 = function(receiver, state, value, kind, f) { - if (kind === "m") - throw new TypeError("Private method is not writable"); - if (kind === "a" && !f) - throw new TypeError("Private accessor was defined without a setter"); - if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) - throw new TypeError("Cannot write private member to an object whose class did not declare it"); - return kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value), value; - }; - __classPrivateFieldIn2 = function(state, receiver) { - if (receiver === null || typeof receiver !== "object" && typeof receiver !== "function") - throw new TypeError("Cannot use 'in' operator on non-object"); - return typeof state === "function" ? receiver === state : state.has(receiver); - }; - exporter("__extends", __extends2); - exporter("__assign", __assign2); - exporter("__rest", __rest2); - exporter("__decorate", __decorate2); - exporter("__param", __param2); - exporter("__metadata", __metadata2); - exporter("__awaiter", __awaiter2); - exporter("__generator", __generator2); - exporter("__exportStar", __exportStar2); - exporter("__createBinding", __createBinding2); - exporter("__values", __values2); - exporter("__read", __read2); - exporter("__spread", __spread2); - exporter("__spreadArrays", __spreadArrays2); - exporter("__spreadArray", __spreadArray2); - exporter("__await", __await2); - exporter("__asyncGenerator", __asyncGenerator2); - exporter("__asyncDelegator", __asyncDelegator2); - exporter("__asyncValues", __asyncValues2); - exporter("__makeTemplateObject", __makeTemplateObject2); - exporter("__importStar", __importStar2); - exporter("__importDefault", __importDefault2); - exporter("__classPrivateFieldGet", __classPrivateFieldGet2); - exporter("__classPrivateFieldSet", __classPrivateFieldSet2); - exporter("__classPrivateFieldIn", __classPrivateFieldIn2); - }); + init_polyfill_buffer(); + var Hogan4 = require_compiler(); + Hogan4.Template = require_template().Template; + Hogan4.template = Hogan4.Template; + module2.exports = Hogan4; } }); // node_modules/feather-icons/dist/feather.js var require_feather = __commonJS({ "node_modules/feather-icons/dist/feather.js"(exports, module2) { + init_polyfill_buffer(); (function webpackUniversalModuleDefinition(root, factory) { if (typeof exports === "object" && typeof module2 === "object") module2.exports = factory(); @@ -5423,8 +8428,8 @@ var require_feather = __commonJS({ } } var hasOwn = {}.hasOwnProperty; - function _parseNumber(resultSet, num) { - resultSet[num] = true; + function _parseNumber(resultSet, num2) { + resultSet[num2] = true; } function _parseObject(resultSet, object) { for (var k in object) { @@ -5521,7 +8526,7 @@ var require_feather = __commonJS({ var argumentsLength = arguments.length; var mapfn = argumentsLength > 1 ? arguments[1] : void 0; var mapping = mapfn !== void 0; - var index = 0; + var index2 = 0; var iteratorMethod = getIteratorMethod(O); var length, result, step, iterator; if (mapping) @@ -5529,17 +8534,17 @@ var require_feather = __commonJS({ if (iteratorMethod != void 0 && !(C == Array && isArrayIteratorMethod(iteratorMethod))) { iterator = iteratorMethod.call(O); result = new C(); - for (; !(step = iterator.next()).done; index++) { - createProperty(result, index, mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index], true) : step.value); + for (; !(step = iterator.next()).done; index2++) { + createProperty(result, index2, mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index2], true) : step.value); } } else { length = toLength(O.length); result = new C(length); - for (; length > index; index++) { - createProperty(result, index, mapping ? mapfn(O[index], index) : O[index]); + for (; length > index2; index2++) { + createProperty(result, index2, mapping ? mapfn(O[index2], index2) : O[index2]); } } - result.length = index; + result.length = index2; return result; }; }, @@ -5551,19 +8556,19 @@ var require_feather = __commonJS({ return function($this, el, fromIndex) { var O = toIndexedObject($this); var length = toLength(O.length); - var index = toAbsoluteIndex(fromIndex, length); + var index2 = toAbsoluteIndex(fromIndex, length); var value; if (IS_INCLUDES && el != el) - while (length > index) { - value = O[index++]; + while (length > index2) { + value = O[index2++]; if (value != value) return true; } else - for (; length > index; index++) - if (IS_INCLUDES || index in O) { - if (O[index] === el) - return IS_INCLUDES || index || 0; + for (; length > index2; index2++) + if (IS_INCLUDES || index2 in O) { + if (O[index2] === el) + return IS_INCLUDES || index2 || 0; } return !IS_INCLUDES && -1; }; @@ -5672,8 +8677,8 @@ var require_feather = __commonJS({ } }; module3.exports = function(it) { - var O, tag, result; - return it === void 0 ? "Undefined" : it === null ? "Null" : typeof (tag = tryGet(O = Object(it), TO_STRING_TAG)) == "string" ? tag : CORRECT_ARGUMENTS ? classofRaw(O) : (result = classofRaw(O)) == "Object" && typeof O.callee == "function" ? "Arguments" : result; + var O, tag2, result; + return it === void 0 ? "Undefined" : it === null ? "Null" : typeof (tag2 = tryGet(O = Object(it), TO_STRING_TAG)) == "string" ? tag2 : CORRECT_ARGUMENTS ? classofRaw(O) : (result = classofRaw(O)) == "Object" && typeof O.callee == "function" ? "Arguments" : result; }; }, "./node_modules/core-js/internals/copy-constructor-properties.js": function(module3, exports2, __webpack_require__) { @@ -6321,8 +9326,8 @@ var require_feather = __commonJS({ var getOwnPropertyNamesModule = __webpack_require__("./node_modules/core-js/internals/object-get-own-property-names.js"); var getOwnPropertySymbolsModule = __webpack_require__("./node_modules/core-js/internals/object-get-own-property-symbols.js"); var anObject = __webpack_require__("./node_modules/core-js/internals/an-object.js"); - var Reflect2 = global2.Reflect; - module3.exports = Reflect2 && Reflect2.ownKeys || function ownKeys(it) { + var Reflect = global2.Reflect; + module3.exports = Reflect && Reflect.ownKeys || function ownKeys(it) { var keys = getOwnPropertyNamesModule.f(anObject(it)); var getOwnPropertySymbols = getOwnPropertySymbolsModule.f; return getOwnPropertySymbols ? keys.concat(getOwnPropertySymbols(it)) : keys; @@ -6443,8 +9448,8 @@ var require_feather = __commonJS({ var toInteger = __webpack_require__("./node_modules/core-js/internals/to-integer.js"); var max = Math.max; var min = Math.min; - module3.exports = function(index, length) { - var integer = toInteger(index); + module3.exports = function(index2, length) { + var integer = toInteger(index2); return integer < 0 ? max(integer + length, 0) : min(integer, length); }; }, @@ -6546,11 +9551,11 @@ var require_feather = __commonJS({ }, function next() { var state = getInternalState(this); var string = state.string; - var index = state.index; + var index2 = state.index; var point; - if (index >= string.length) + if (index2 >= string.length) return { value: void 0, done: true }; - point = codePointAt(string, index, true); + point = codePointAt(string, index2, true); state.index += point.length; return { value: point, done: false }; }); @@ -6773,9 +9778,8897 @@ var require_feather = __commonJS({ __export(exports, { default: () => ObsidianGit }); -var import_obsidian18 = __toModule(require("obsidian")); +init_polyfill_buffer(); + +// node_modules/isomorphic-git/index.js +init_polyfill_buffer(); +var import_async_lock = __toModule(require_async_lock()); +var import_sha1 = __toModule(require_sha1()); +var import_crc_32 = __toModule(require_crc32()); +var import_pako = __toModule(require_pako()); +var import_ignore = __toModule(require_ignore()); +var import_pify = __toModule(require_pify()); +var import_clean_git_ref = __toModule(require_lib2()); +var import_diff3 = __toModule(require_diff3()); +var BaseError = class extends Error { + constructor(message) { + super(message); + this.caller = ""; + } + toJSON() { + return { + code: this.code, + data: this.data, + caller: this.caller, + message: this.message, + stack: this.stack + }; + } + fromJSON(json) { + const e = new BaseError(json.message); + e.code = json.code; + e.data = json.data; + e.caller = json.caller; + e.stack = json.stack; + return e; + } + get isIsomorphicGitError() { + return true; + } +}; +var InternalError = class extends BaseError { + constructor(message) { + super(`An internal error caused this command to fail. Please file a bug report at https://github.com/isomorphic-git/isomorphic-git/issues with this error message: ${message}`); + this.code = this.name = InternalError.code; + this.data = { message }; + } +}; +InternalError.code = "InternalError"; +var UnsafeFilepathError = class extends BaseError { + constructor(filepath) { + super(`The filepath "${filepath}" contains unsafe character sequences`); + this.code = this.name = UnsafeFilepathError.code; + this.data = { filepath }; + } +}; +UnsafeFilepathError.code = "UnsafeFilepathError"; +var BufferCursor = class { + constructor(buffer2) { + this.buffer = buffer2; + this._start = 0; + } + eof() { + return this._start >= this.buffer.length; + } + tell() { + return this._start; + } + seek(n) { + this._start = n; + } + slice(n) { + const r = this.buffer.slice(this._start, this._start + n); + this._start += n; + return r; + } + toString(enc, length) { + const r = this.buffer.toString(enc, this._start, this._start + length); + this._start += length; + return r; + } + write(value, length, enc) { + const r = this.buffer.write(value, this._start, length, enc); + this._start += length; + return r; + } + copy(source, start, end) { + const r = source.copy(this.buffer, this._start, start, end); + this._start += r; + return r; + } + readUInt8() { + const r = this.buffer.readUInt8(this._start); + this._start += 1; + return r; + } + writeUInt8(value) { + const r = this.buffer.writeUInt8(value, this._start); + this._start += 1; + return r; + } + readUInt16BE() { + const r = this.buffer.readUInt16BE(this._start); + this._start += 2; + return r; + } + writeUInt16BE(value) { + const r = this.buffer.writeUInt16BE(value, this._start); + this._start += 2; + return r; + } + readUInt32BE() { + const r = this.buffer.readUInt32BE(this._start); + this._start += 4; + return r; + } + writeUInt32BE(value) { + const r = this.buffer.writeUInt32BE(value, this._start); + this._start += 4; + return r; + } +}; +function compareStrings(a, b) { + return -(a < b) || +(a > b); +} +function comparePath(a, b) { + return compareStrings(a.path, b.path); +} +function normalizeMode(mode) { + let type = mode > 0 ? mode >> 12 : 0; + if (type !== 4 && type !== 8 && type !== 10 && type !== 14) { + type = 8; + } + let permissions = mode & 511; + if (permissions & 73) { + permissions = 493; + } else { + permissions = 420; + } + if (type !== 8) + permissions = 0; + return (type << 12) + permissions; +} +var MAX_UINT32 = 2 ** 32; +function SecondsNanoseconds(givenSeconds, givenNanoseconds, milliseconds, date) { + if (givenSeconds !== void 0 && givenNanoseconds !== void 0) { + return [givenSeconds, givenNanoseconds]; + } + if (milliseconds === void 0) { + milliseconds = date.valueOf(); + } + const seconds = Math.floor(milliseconds / 1e3); + const nanoseconds = (milliseconds - seconds * 1e3) * 1e6; + return [seconds, nanoseconds]; +} +function normalizeStats(e) { + const [ctimeSeconds, ctimeNanoseconds] = SecondsNanoseconds(e.ctimeSeconds, e.ctimeNanoseconds, e.ctimeMs, e.ctime); + const [mtimeSeconds, mtimeNanoseconds] = SecondsNanoseconds(e.mtimeSeconds, e.mtimeNanoseconds, e.mtimeMs, e.mtime); + return { + ctimeSeconds: ctimeSeconds % MAX_UINT32, + ctimeNanoseconds: ctimeNanoseconds % MAX_UINT32, + mtimeSeconds: mtimeSeconds % MAX_UINT32, + mtimeNanoseconds: mtimeNanoseconds % MAX_UINT32, + dev: e.dev % MAX_UINT32, + ino: e.ino % MAX_UINT32, + mode: normalizeMode(e.mode % MAX_UINT32), + uid: e.uid % MAX_UINT32, + gid: e.gid % MAX_UINT32, + size: e.size > -1 ? e.size % MAX_UINT32 : 0 + }; +} +function toHex(buffer2) { + let hex = ""; + for (const byte of new Uint8Array(buffer2)) { + if (byte < 16) + hex += "0"; + hex += byte.toString(16); + } + return hex; +} +var supportsSubtleSHA1 = null; +async function shasum(buffer2) { + if (supportsSubtleSHA1 === null) { + supportsSubtleSHA1 = await testSubtleSHA1(); + } + return supportsSubtleSHA1 ? subtleSHA1(buffer2) : shasumSync(buffer2); +} +function shasumSync(buffer2) { + return new import_sha1.default().update(buffer2).digest("hex"); +} +async function subtleSHA1(buffer2) { + const hash2 = await crypto.subtle.digest("SHA-1", buffer2); + return toHex(hash2); +} +async function testSubtleSHA1() { + try { + const hash2 = await subtleSHA1(new Uint8Array([])); + if (hash2 === "da39a3ee5e6b4b0d3255bfef95601890afd80709") + return true; + } catch (_) { + } + return false; +} +function parseCacheEntryFlags(bits) { + return { + assumeValid: Boolean(bits & 32768), + extended: Boolean(bits & 16384), + stage: (bits & 12288) >> 12, + nameLength: bits & 4095 + }; +} +function renderCacheEntryFlags(entry) { + const flags = entry.flags; + flags.extended = false; + flags.nameLength = Math.min(Buffer2.from(entry.path).length, 4095); + return (flags.assumeValid ? 32768 : 0) + (flags.extended ? 16384 : 0) + ((flags.stage & 3) << 12) + (flags.nameLength & 4095); +} +var GitIndex = class { + constructor(entries) { + this._dirty = false; + this._entries = entries || new Map(); + } + static async from(buffer2) { + if (Buffer2.isBuffer(buffer2)) { + return GitIndex.fromBuffer(buffer2); + } else if (buffer2 === null) { + return new GitIndex(null); + } else { + throw new InternalError("invalid type passed to GitIndex.from"); + } + } + static async fromBuffer(buffer2) { + const shaComputed = await shasum(buffer2.slice(0, -20)); + const shaClaimed = buffer2.slice(-20).toString("hex"); + if (shaClaimed !== shaComputed) { + throw new InternalError(`Invalid checksum in GitIndex buffer: expected ${shaClaimed} but saw ${shaComputed}`); + } + const reader = new BufferCursor(buffer2); + const _entries = new Map(); + const magic = reader.toString("utf8", 4); + if (magic !== "DIRC") { + throw new InternalError(`Inavlid dircache magic file number: ${magic}`); + } + const version2 = reader.readUInt32BE(); + if (version2 !== 2) { + throw new InternalError(`Unsupported dircache version: ${version2}`); + } + const numEntries = reader.readUInt32BE(); + let i = 0; + while (!reader.eof() && i < numEntries) { + const entry = {}; + entry.ctimeSeconds = reader.readUInt32BE(); + entry.ctimeNanoseconds = reader.readUInt32BE(); + entry.mtimeSeconds = reader.readUInt32BE(); + entry.mtimeNanoseconds = reader.readUInt32BE(); + entry.dev = reader.readUInt32BE(); + entry.ino = reader.readUInt32BE(); + entry.mode = reader.readUInt32BE(); + entry.uid = reader.readUInt32BE(); + entry.gid = reader.readUInt32BE(); + entry.size = reader.readUInt32BE(); + entry.oid = reader.slice(20).toString("hex"); + const flags = reader.readUInt16BE(); + entry.flags = parseCacheEntryFlags(flags); + const pathlength = buffer2.indexOf(0, reader.tell() + 1) - reader.tell(); + if (pathlength < 1) { + throw new InternalError(`Got a path length of: ${pathlength}`); + } + entry.path = reader.toString("utf8", pathlength); + if (entry.path.includes("..\\") || entry.path.includes("../")) { + throw new UnsafeFilepathError(entry.path); + } + let padding = 8 - (reader.tell() - 12) % 8; + if (padding === 0) + padding = 8; + while (padding--) { + const tmp = reader.readUInt8(); + if (tmp !== 0) { + throw new InternalError(`Expected 1-8 null characters but got '${tmp}' after ${entry.path}`); + } else if (reader.eof()) { + throw new InternalError("Unexpected end of file"); + } + } + _entries.set(entry.path, entry); + i++; + } + return new GitIndex(_entries); + } + get entries() { + return [...this._entries.values()].sort(comparePath); + } + get entriesMap() { + return this._entries; + } + *[Symbol.iterator]() { + for (const entry of this.entries) { + yield entry; + } + } + insert({ filepath, stats, oid }) { + stats = normalizeStats(stats); + const bfilepath = Buffer2.from(filepath); + const entry = { + ctimeSeconds: stats.ctimeSeconds, + ctimeNanoseconds: stats.ctimeNanoseconds, + mtimeSeconds: stats.mtimeSeconds, + mtimeNanoseconds: stats.mtimeNanoseconds, + dev: stats.dev, + ino: stats.ino, + mode: stats.mode || 33188, + uid: stats.uid, + gid: stats.gid, + size: stats.size, + path: filepath, + oid, + flags: { + assumeValid: false, + extended: false, + stage: 0, + nameLength: bfilepath.length < 4095 ? bfilepath.length : 4095 + } + }; + this._entries.set(entry.path, entry); + this._dirty = true; + } + delete({ filepath }) { + if (this._entries.has(filepath)) { + this._entries.delete(filepath); + } else { + for (const key2 of this._entries.keys()) { + if (key2.startsWith(filepath + "/")) { + this._entries.delete(key2); + } + } + } + this._dirty = true; + } + clear() { + this._entries.clear(); + this._dirty = true; + } + has({ filepath }) { + return this._entries.has(filepath); + } + render() { + return this.entries.map((entry) => `${entry.mode.toString(8)} ${entry.oid} ${entry.path}`).join("\n"); + } + async toObject() { + const header = Buffer2.alloc(12); + const writer = new BufferCursor(header); + writer.write("DIRC", 4, "utf8"); + writer.writeUInt32BE(2); + writer.writeUInt32BE(this.entries.length); + const body = Buffer2.concat(this.entries.map((entry) => { + const bpath = Buffer2.from(entry.path); + const length = Math.ceil((62 + bpath.length + 1) / 8) * 8; + const written = Buffer2.alloc(length); + const writer2 = new BufferCursor(written); + const stat = normalizeStats(entry); + writer2.writeUInt32BE(stat.ctimeSeconds); + writer2.writeUInt32BE(stat.ctimeNanoseconds); + writer2.writeUInt32BE(stat.mtimeSeconds); + writer2.writeUInt32BE(stat.mtimeNanoseconds); + writer2.writeUInt32BE(stat.dev); + writer2.writeUInt32BE(stat.ino); + writer2.writeUInt32BE(stat.mode); + writer2.writeUInt32BE(stat.uid); + writer2.writeUInt32BE(stat.gid); + writer2.writeUInt32BE(stat.size); + writer2.write(entry.oid, 20, "hex"); + writer2.writeUInt16BE(renderCacheEntryFlags(entry)); + writer2.write(entry.path, bpath.length, "utf8"); + return written; + })); + const main = Buffer2.concat([header, body]); + const sum = await shasum(main); + return Buffer2.concat([main, Buffer2.from(sum, "hex")]); + } +}; +function compareStats(entry, stats) { + const e = normalizeStats(entry); + const s = normalizeStats(stats); + const staleness = e.mode !== s.mode || e.mtimeSeconds !== s.mtimeSeconds || e.ctimeSeconds !== s.ctimeSeconds || e.uid !== s.uid || e.gid !== s.gid || e.ino !== s.ino || e.size !== s.size; + return staleness; +} +var lock = null; +var IndexCache = Symbol("IndexCache"); +function createCache() { + return { + map: new Map(), + stats: new Map() + }; +} +async function updateCachedIndexFile(fs, filepath, cache) { + const stat = await fs.lstat(filepath); + const rawIndexFile = await fs.read(filepath); + const index2 = await GitIndex.from(rawIndexFile); + cache.map.set(filepath, index2); + cache.stats.set(filepath, stat); +} +async function isIndexStale(fs, filepath, cache) { + const savedStats = cache.stats.get(filepath); + if (savedStats === void 0) + return true; + const currStats = await fs.lstat(filepath); + if (savedStats === null) + return false; + if (currStats === null) + return false; + return compareStats(savedStats, currStats); +} +var GitIndexManager = class { + static async acquire({ fs, gitdir, cache }, closure) { + if (!cache[IndexCache]) + cache[IndexCache] = createCache(); + const filepath = `${gitdir}/index`; + if (lock === null) + lock = new import_async_lock.default({ maxPending: Infinity }); + let result; + await lock.acquire(filepath, async () => { + if (await isIndexStale(fs, filepath, cache[IndexCache])) { + await updateCachedIndexFile(fs, filepath, cache[IndexCache]); + } + const index2 = cache[IndexCache].map.get(filepath); + result = await closure(index2); + if (index2._dirty) { + const buffer2 = await index2.toObject(); + await fs.write(filepath, buffer2); + cache[IndexCache].stats.set(filepath, await fs.lstat(filepath)); + index2._dirty = false; + } + }); + return result; + } +}; +function basename(path2) { + const last2 = Math.max(path2.lastIndexOf("/"), path2.lastIndexOf("\\")); + if (last2 > -1) { + path2 = path2.slice(last2 + 1); + } + return path2; +} +function dirname(path2) { + const last2 = Math.max(path2.lastIndexOf("/"), path2.lastIndexOf("\\")); + if (last2 === -1) + return "."; + if (last2 === 0) + return "/"; + return path2.slice(0, last2); +} +function flatFileListToDirectoryStructure(files) { + const inodes = new Map(); + const mkdir = function(name) { + if (!inodes.has(name)) { + const dir = { + type: "tree", + fullpath: name, + basename: basename(name), + metadata: {}, + children: [] + }; + inodes.set(name, dir); + dir.parent = mkdir(dirname(name)); + if (dir.parent && dir.parent !== dir) + dir.parent.children.push(dir); + } + return inodes.get(name); + }; + const mkfile = function(name, metadata) { + if (!inodes.has(name)) { + const file = { + type: "blob", + fullpath: name, + basename: basename(name), + metadata, + parent: mkdir(dirname(name)), + children: [] + }; + if (file.parent) + file.parent.children.push(file); + inodes.set(name, file); + } + return inodes.get(name); + }; + mkdir("."); + for (const file of files) { + mkfile(file.path, file); + } + return inodes; +} +function mode2type(mode) { + switch (mode) { + case 16384: + return "tree"; + case 33188: + return "blob"; + case 33261: + return "blob"; + case 40960: + return "blob"; + case 57344: + return "commit"; + } + throw new InternalError(`Unexpected GitTree entry mode: ${mode.toString(8)}`); +} +var GitWalkerIndex = class { + constructor({ fs, gitdir, cache }) { + this.treePromise = GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + return flatFileListToDirectoryStructure(index2.entries); + }); + const walker = this; + this.ConstructEntry = class StageEntry { + constructor(fullpath) { + this._fullpath = fullpath; + this._type = false; + this._mode = false; + this._stat = false; + this._oid = false; + } + async type() { + return walker.type(this); + } + async mode() { + return walker.mode(this); + } + async stat() { + return walker.stat(this); + } + async content() { + return walker.content(this); + } + async oid() { + return walker.oid(this); + } + }; + } + async readdir(entry) { + const filepath = entry._fullpath; + const tree = await this.treePromise; + const inode = tree.get(filepath); + if (!inode) + return null; + if (inode.type === "blob") + return null; + if (inode.type !== "tree") { + throw new Error(`ENOTDIR: not a directory, scandir '${filepath}'`); + } + const names = inode.children.map((inode2) => inode2.fullpath); + names.sort(compareStrings); + return names; + } + async type(entry) { + if (entry._type === false) { + await entry.stat(); + } + return entry._type; + } + async mode(entry) { + if (entry._mode === false) { + await entry.stat(); + } + return entry._mode; + } + async stat(entry) { + if (entry._stat === false) { + const tree = await this.treePromise; + const inode = tree.get(entry._fullpath); + if (!inode) { + throw new Error(`ENOENT: no such file or directory, lstat '${entry._fullpath}'`); + } + const stats = inode.type === "tree" ? {} : normalizeStats(inode.metadata); + entry._type = inode.type === "tree" ? "tree" : mode2type(stats.mode); + entry._mode = stats.mode; + if (inode.type === "tree") { + entry._stat = void 0; + } else { + entry._stat = stats; + } + } + return entry._stat; + } + async content(_entry) { + } + async oid(entry) { + if (entry._oid === false) { + const tree = await this.treePromise; + const inode = tree.get(entry._fullpath); + entry._oid = inode.metadata.oid; + } + return entry._oid; + } +}; +var GitWalkSymbol = Symbol("GitWalkSymbol"); +function STAGE() { + const o = Object.create(null); + Object.defineProperty(o, GitWalkSymbol, { + value: function({ fs, gitdir, cache }) { + return new GitWalkerIndex({ fs, gitdir, cache }); + } + }); + Object.freeze(o); + return o; +} +var NotFoundError = class extends BaseError { + constructor(what) { + super(`Could not find ${what}.`); + this.code = this.name = NotFoundError.code; + this.data = { what }; + } +}; +NotFoundError.code = "NotFoundError"; +var ObjectTypeError = class extends BaseError { + constructor(oid, actual, expected, filepath) { + super(`Object ${oid} ${filepath ? `at ${filepath}` : ""}was anticipated to be a ${expected} but it is a ${actual}.`); + this.code = this.name = ObjectTypeError.code; + this.data = { oid, actual, expected, filepath }; + } +}; +ObjectTypeError.code = "ObjectTypeError"; +var InvalidOidError = class extends BaseError { + constructor(value) { + super(`Expected a 40-char hex object id but saw "${value}".`); + this.code = this.name = InvalidOidError.code; + this.data = { value }; + } +}; +InvalidOidError.code = "InvalidOidError"; +var NoRefspecError = class extends BaseError { + constructor(remote) { + super(`Could not find a fetch refspec for remote "${remote}". Make sure the config file has an entry like the following: +[remote "${remote}"] + fetch = +refs/heads/*:refs/remotes/origin/* +`); + this.code = this.name = NoRefspecError.code; + this.data = { remote }; + } +}; +NoRefspecError.code = "NoRefspecError"; +var GitPackedRefs = class { + constructor(text2) { + this.refs = new Map(); + this.parsedConfig = []; + if (text2) { + let key2 = null; + this.parsedConfig = text2.trim().split("\n").map((line) => { + if (/^\s*#/.test(line)) { + return { line, comment: true }; + } + const i = line.indexOf(" "); + if (line.startsWith("^")) { + const value = line.slice(1); + this.refs.set(key2 + "^{}", value); + return { line, ref: key2, peeled: value }; + } else { + const value = line.slice(0, i); + key2 = line.slice(i + 1); + this.refs.set(key2, value); + return { line, ref: key2, oid: value }; + } + }); + } + return this; + } + static from(text2) { + return new GitPackedRefs(text2); + } + delete(ref) { + this.parsedConfig = this.parsedConfig.filter((entry) => entry.ref !== ref); + this.refs.delete(ref); + } + toString() { + return this.parsedConfig.map(({ line }) => line).join("\n") + "\n"; + } +}; +var GitRefSpec = class { + constructor({ remotePath, localPath, force, matchPrefix }) { + Object.assign(this, { + remotePath, + localPath, + force, + matchPrefix + }); + } + static from(refspec) { + const [ + forceMatch, + remotePath, + remoteGlobMatch, + localPath, + localGlobMatch + ] = refspec.match(/^(\+?)(.*?)(\*?):(.*?)(\*?)$/).slice(1); + const force = forceMatch === "+"; + const remoteIsGlob = remoteGlobMatch === "*"; + const localIsGlob = localGlobMatch === "*"; + if (remoteIsGlob !== localIsGlob) { + throw new InternalError("Invalid refspec"); + } + return new GitRefSpec({ + remotePath, + localPath, + force, + matchPrefix: remoteIsGlob + }); + } + translate(remoteBranch) { + if (this.matchPrefix) { + if (remoteBranch.startsWith(this.remotePath)) { + return this.localPath + remoteBranch.replace(this.remotePath, ""); + } + } else { + if (remoteBranch === this.remotePath) + return this.localPath; + } + return null; + } + reverseTranslate(localBranch) { + if (this.matchPrefix) { + if (localBranch.startsWith(this.localPath)) { + return this.remotePath + localBranch.replace(this.localPath, ""); + } + } else { + if (localBranch === this.localPath) + return this.remotePath; + } + return null; + } +}; +var GitRefSpecSet = class { + constructor(rules = []) { + this.rules = rules; + } + static from(refspecs) { + const rules = []; + for (const refspec of refspecs) { + rules.push(GitRefSpec.from(refspec)); + } + return new GitRefSpecSet(rules); + } + add(refspec) { + const rule = GitRefSpec.from(refspec); + this.rules.push(rule); + } + translate(remoteRefs) { + const result = []; + for (const rule of this.rules) { + for (const remoteRef of remoteRefs) { + const localRef = rule.translate(remoteRef); + if (localRef) { + result.push([remoteRef, localRef]); + } + } + } + return result; + } + translateOne(remoteRef) { + let result = null; + for (const rule of this.rules) { + const localRef = rule.translate(remoteRef); + if (localRef) { + result = localRef; + } + } + return result; + } + localNamespaces() { + return this.rules.filter((rule) => rule.matchPrefix).map((rule) => rule.localPath.replace(/\/$/, "")); + } +}; +function compareRefNames(a, b) { + const _a2 = a.replace(/\^\{\}$/, ""); + const _b = b.replace(/\^\{\}$/, ""); + const tmp = -(_a2 < _b) || +(_a2 > _b); + if (tmp === 0) { + return a.endsWith("^{}") ? 1 : -1; + } + return tmp; +} +function normalizePath(path2) { + return path2.replace(/\/\.\//g, "/").replace(/\/{2,}/g, "/").replace(/^\/\.$/, "/").replace(/^\.\/$/, ".").replace(/^\.\//, "").replace(/\/\.$/, "").replace(/(.+)\/$/, "$1").replace(/^$/, "."); +} +function join(...parts) { + return normalizePath(parts.map(normalizePath).join("/")); +} +var num = (val) => { + val = val.toLowerCase(); + let n = parseInt(val); + if (val.endsWith("k")) + n *= 1024; + if (val.endsWith("m")) + n *= 1024 * 1024; + if (val.endsWith("g")) + n *= 1024 * 1024 * 1024; + return n; +}; +var bool = (val) => { + val = val.trim().toLowerCase(); + if (val === "true" || val === "yes" || val === "on") + return true; + if (val === "false" || val === "no" || val === "off") + return false; + throw Error(`Expected 'true', 'false', 'yes', 'no', 'on', or 'off', but got ${val}`); +}; +var schema = { + core: { + filemode: bool, + bare: bool, + logallrefupdates: bool, + symlinks: bool, + ignorecase: bool, + bigFileThreshold: num + } +}; +var SECTION_LINE_REGEX = /^\[([A-Za-z0-9-.]+)(?: "(.*)")?\]$/; +var SECTION_REGEX = /^[A-Za-z0-9-.]+$/; +var VARIABLE_LINE_REGEX = /^([A-Za-z][A-Za-z-]*)(?: *= *(.*))?$/; +var VARIABLE_NAME_REGEX = /^[A-Za-z][A-Za-z-]*$/; +var VARIABLE_VALUE_COMMENT_REGEX = /^(.*?)( *[#;].*)$/; +var extractSectionLine = (line) => { + const matches = SECTION_LINE_REGEX.exec(line); + if (matches != null) { + const [section, subsection] = matches.slice(1); + return [section, subsection]; + } + return null; +}; +var extractVariableLine = (line) => { + const matches = VARIABLE_LINE_REGEX.exec(line); + if (matches != null) { + const [name, rawValue = "true"] = matches.slice(1); + const valueWithoutComments = removeComments(rawValue); + const valueWithoutQuotes = removeQuotes(valueWithoutComments); + return [name, valueWithoutQuotes]; + } + return null; +}; +var removeComments = (rawValue) => { + const commentMatches = VARIABLE_VALUE_COMMENT_REGEX.exec(rawValue); + if (commentMatches == null) { + return rawValue; + } + const [valueWithoutComment, comment] = commentMatches.slice(1); + if (hasOddNumberOfQuotes(valueWithoutComment) && hasOddNumberOfQuotes(comment)) { + return `${valueWithoutComment}${comment}`; + } + return valueWithoutComment; +}; +var hasOddNumberOfQuotes = (text2) => { + const numberOfQuotes = (text2.match(/(?:^|[^\\])"/g) || []).length; + return numberOfQuotes % 2 !== 0; +}; +var removeQuotes = (text2) => { + return text2.split("").reduce((newText, c, idx, text3) => { + const isQuote = c === '"' && text3[idx - 1] !== "\\"; + const isEscapeForQuote = c === "\\" && text3[idx + 1] === '"'; + if (isQuote || isEscapeForQuote) { + return newText; + } + return newText + c; + }, ""); +}; +var lower = (text2) => { + return text2 != null ? text2.toLowerCase() : null; +}; +var getPath = (section, subsection, name) => { + return [lower(section), subsection, lower(name)].filter((a) => a != null).join("."); +}; +var normalizePath$1 = (path2) => { + const pathSegments = path2.split("."); + const section = pathSegments.shift(); + const name = pathSegments.pop(); + const subsection = pathSegments.length ? pathSegments.join(".") : void 0; + return { + section, + subsection, + name, + path: getPath(section, subsection, name), + sectionPath: getPath(section, subsection, null) + }; +}; +var findLastIndex = (array, callback) => { + return array.reduce((lastIndex, item, index2) => { + return callback(item) ? index2 : lastIndex; + }, -1); +}; +var GitConfig = class { + constructor(text2) { + let section = null; + let subsection = null; + this.parsedConfig = text2.split("\n").map((line) => { + let name = null; + let value = null; + const trimmedLine = line.trim(); + const extractedSection = extractSectionLine(trimmedLine); + const isSection = extractedSection != null; + if (isSection) { + ; + [section, subsection] = extractedSection; + } else { + const extractedVariable = extractVariableLine(trimmedLine); + const isVariable = extractedVariable != null; + if (isVariable) { + ; + [name, value] = extractedVariable; + } + } + const path2 = getPath(section, subsection, name); + return { line, isSection, section, subsection, name, value, path: path2 }; + }); + } + static from(text2) { + return new GitConfig(text2); + } + async get(path2, getall = false) { + const normalizedPath = normalizePath$1(path2).path; + const allValues = this.parsedConfig.filter((config) => config.path === normalizedPath).map(({ section, name, value }) => { + const fn = schema[section] && schema[section][name]; + return fn ? fn(value) : value; + }); + return getall ? allValues : allValues.pop(); + } + async getall(path2) { + return this.get(path2, true); + } + async getSubsections(section) { + return this.parsedConfig.filter((config) => config.section === section && config.isSection).map((config) => config.subsection); + } + async deleteSection(section, subsection) { + this.parsedConfig = this.parsedConfig.filter((config) => !(config.section === section && config.subsection === subsection)); + } + async append(path2, value) { + return this.set(path2, value, true); + } + async set(path2, value, append3 = false) { + const { + section, + subsection, + name, + path: normalizedPath, + sectionPath + } = normalizePath$1(path2); + const configIndex = findLastIndex(this.parsedConfig, (config) => config.path === normalizedPath); + if (value == null) { + if (configIndex !== -1) { + this.parsedConfig.splice(configIndex, 1); + } + } else { + if (configIndex !== -1) { + const config = this.parsedConfig[configIndex]; + const modifiedConfig = Object.assign({}, config, { + name, + value, + modified: true + }); + if (append3) { + this.parsedConfig.splice(configIndex + 1, 0, modifiedConfig); + } else { + this.parsedConfig[configIndex] = modifiedConfig; + } + } else { + const sectionIndex = this.parsedConfig.findIndex((config) => config.path === sectionPath); + const newConfig = { + section, + subsection, + name, + value, + modified: true, + path: normalizedPath + }; + if (SECTION_REGEX.test(section) && VARIABLE_NAME_REGEX.test(name)) { + if (sectionIndex >= 0) { + this.parsedConfig.splice(sectionIndex + 1, 0, newConfig); + } else { + const newSection = { + section, + subsection, + modified: true, + path: sectionPath + }; + this.parsedConfig.push(newSection, newConfig); + } + } + } + } + } + toString() { + return this.parsedConfig.map(({ line, section, subsection, name, value, modified: modified2 = false }) => { + if (!modified2) { + return line; + } + if (name != null && value != null) { + if (typeof value === "string" && /[#;]/.test(value)) { + return ` ${name} = "${value}"`; + } + return ` ${name} = ${value}`; + } + if (subsection != null) { + return `[${section} "${subsection}"]`; + } + return `[${section}]`; + }).join("\n"); + } +}; +var GitConfigManager = class { + static async get({ fs, gitdir }) { + const text2 = await fs.read(`${gitdir}/config`, { encoding: "utf8" }); + return GitConfig.from(text2); + } + static async save({ fs, gitdir, config }) { + await fs.write(`${gitdir}/config`, config.toString(), { + encoding: "utf8" + }); + } +}; +var refpaths = (ref) => [ + `${ref}`, + `refs/${ref}`, + `refs/tags/${ref}`, + `refs/heads/${ref}`, + `refs/remotes/${ref}`, + `refs/remotes/${ref}/HEAD` +]; +var GIT_FILES = ["config", "description", "index", "shallow", "commondir"]; +var GitRefManager = class { + static async updateRemoteRefs({ + fs, + gitdir, + remote, + refs, + symrefs, + tags, + refspecs = void 0, + prune = false, + pruneTags = false + }) { + for (const value of refs.values()) { + if (!value.match(/[0-9a-f]{40}/)) { + throw new InvalidOidError(value); + } + } + const config = await GitConfigManager.get({ fs, gitdir }); + if (!refspecs) { + refspecs = await config.getall(`remote.${remote}.fetch`); + if (refspecs.length === 0) { + throw new NoRefspecError(remote); + } + refspecs.unshift(`+HEAD:refs/remotes/${remote}/HEAD`); + } + const refspec = GitRefSpecSet.from(refspecs); + const actualRefsToWrite = new Map(); + if (pruneTags) { + const tags2 = await GitRefManager.listRefs({ + fs, + gitdir, + filepath: "refs/tags" + }); + await GitRefManager.deleteRefs({ + fs, + gitdir, + refs: tags2.map((tag2) => `refs/tags/${tag2}`) + }); + } + if (tags) { + for (const serverRef of refs.keys()) { + if (serverRef.startsWith("refs/tags") && !serverRef.endsWith("^{}")) { + if (!await GitRefManager.exists({ fs, gitdir, ref: serverRef })) { + const oid = refs.get(serverRef); + actualRefsToWrite.set(serverRef, oid); + } + } + } + } + const refTranslations = refspec.translate([...refs.keys()]); + for (const [serverRef, translatedRef] of refTranslations) { + const value = refs.get(serverRef); + actualRefsToWrite.set(translatedRef, value); + } + const symrefTranslations = refspec.translate([...symrefs.keys()]); + for (const [serverRef, translatedRef] of symrefTranslations) { + const value = symrefs.get(serverRef); + const symtarget = refspec.translateOne(value); + if (symtarget) { + actualRefsToWrite.set(translatedRef, `ref: ${symtarget}`); + } + } + const pruned = []; + if (prune) { + for (const filepath of refspec.localNamespaces()) { + const refs2 = (await GitRefManager.listRefs({ + fs, + gitdir, + filepath + })).map((file) => `${filepath}/${file}`); + for (const ref of refs2) { + if (!actualRefsToWrite.has(ref)) { + pruned.push(ref); + } + } + } + if (pruned.length > 0) { + await GitRefManager.deleteRefs({ fs, gitdir, refs: pruned }); + } + } + for (const [key2, value] of actualRefsToWrite) { + await fs.write(join(gitdir, key2), `${value.trim()} +`, "utf8"); + } + return { pruned }; + } + static async writeRef({ fs, gitdir, ref, value }) { + if (!value.match(/[0-9a-f]{40}/)) { + throw new InvalidOidError(value); + } + await fs.write(join(gitdir, ref), `${value.trim()} +`, "utf8"); + } + static async writeSymbolicRef({ fs, gitdir, ref, value }) { + await fs.write(join(gitdir, ref), `ref: ${value.trim()} +`, "utf8"); + } + static async deleteRef({ fs, gitdir, ref }) { + return GitRefManager.deleteRefs({ fs, gitdir, refs: [ref] }); + } + static async deleteRefs({ fs, gitdir, refs }) { + await Promise.all(refs.map((ref) => fs.rm(join(gitdir, ref)))); + let text2 = await fs.read(`${gitdir}/packed-refs`, { encoding: "utf8" }); + const packed = GitPackedRefs.from(text2); + const beforeSize = packed.refs.size; + for (const ref of refs) { + if (packed.refs.has(ref)) { + packed.delete(ref); + } + } + if (packed.refs.size < beforeSize) { + text2 = packed.toString(); + await fs.write(`${gitdir}/packed-refs`, text2, { encoding: "utf8" }); + } + } + static async resolve({ fs, gitdir, ref, depth = void 0 }) { + if (depth !== void 0) { + depth--; + if (depth === -1) { + return ref; + } + } + let sha; + if (ref.startsWith("ref: ")) { + ref = ref.slice("ref: ".length); + return GitRefManager.resolve({ fs, gitdir, ref, depth }); + } + if (ref.length === 40 && /[0-9a-f]{40}/.test(ref)) { + return ref; + } + const packedMap = await GitRefManager.packedRefs({ fs, gitdir }); + const allpaths = refpaths(ref).filter((p) => !GIT_FILES.includes(p)); + for (const ref2 of allpaths) { + sha = await fs.read(`${gitdir}/${ref2}`, { encoding: "utf8" }) || packedMap.get(ref2); + if (sha) { + return GitRefManager.resolve({ fs, gitdir, ref: sha.trim(), depth }); + } + } + throw new NotFoundError(ref); + } + static async exists({ fs, gitdir, ref }) { + try { + await GitRefManager.expand({ fs, gitdir, ref }); + return true; + } catch (err) { + return false; + } + } + static async expand({ fs, gitdir, ref }) { + if (ref.length === 40 && /[0-9a-f]{40}/.test(ref)) { + return ref; + } + const packedMap = await GitRefManager.packedRefs({ fs, gitdir }); + const allpaths = refpaths(ref); + for (const ref2 of allpaths) { + if (await fs.exists(`${gitdir}/${ref2}`)) + return ref2; + if (packedMap.has(ref2)) + return ref2; + } + throw new NotFoundError(ref); + } + static async expandAgainstMap({ ref, map }) { + const allpaths = refpaths(ref); + for (const ref2 of allpaths) { + if (await map.has(ref2)) + return ref2; + } + throw new NotFoundError(ref); + } + static resolveAgainstMap({ ref, fullref = ref, depth = void 0, map }) { + if (depth !== void 0) { + depth--; + if (depth === -1) { + return { fullref, oid: ref }; + } + } + if (ref.startsWith("ref: ")) { + ref = ref.slice("ref: ".length); + return GitRefManager.resolveAgainstMap({ ref, fullref, depth, map }); + } + if (ref.length === 40 && /[0-9a-f]{40}/.test(ref)) { + return { fullref, oid: ref }; + } + const allpaths = refpaths(ref); + for (const ref2 of allpaths) { + const sha = map.get(ref2); + if (sha) { + return GitRefManager.resolveAgainstMap({ + ref: sha.trim(), + fullref: ref2, + depth, + map + }); + } + } + throw new NotFoundError(ref); + } + static async packedRefs({ fs, gitdir }) { + const text2 = await fs.read(`${gitdir}/packed-refs`, { encoding: "utf8" }); + const packed = GitPackedRefs.from(text2); + return packed.refs; + } + static async listRefs({ fs, gitdir, filepath }) { + const packedMap = GitRefManager.packedRefs({ fs, gitdir }); + let files = null; + try { + files = await fs.readdirDeep(`${gitdir}/${filepath}`); + files = files.map((x) => x.replace(`${gitdir}/${filepath}/`, "")); + } catch (err) { + files = []; + } + for (let key2 of (await packedMap).keys()) { + if (key2.startsWith(filepath)) { + key2 = key2.replace(filepath + "/", ""); + if (!files.includes(key2)) { + files.push(key2); + } + } + } + files.sort(compareRefNames); + return files; + } + static async listBranches({ fs, gitdir, remote }) { + if (remote) { + return GitRefManager.listRefs({ + fs, + gitdir, + filepath: `refs/remotes/${remote}` + }); + } else { + return GitRefManager.listRefs({ fs, gitdir, filepath: `refs/heads` }); + } + } + static async listTags({ fs, gitdir }) { + const tags = await GitRefManager.listRefs({ + fs, + gitdir, + filepath: `refs/tags` + }); + return tags.filter((x) => !x.endsWith("^{}")); + } +}; +function compareTreeEntryPath(a, b) { + return compareStrings(appendSlashIfDir(a), appendSlashIfDir(b)); +} +function appendSlashIfDir(entry) { + return entry.mode === "040000" ? entry.path + "/" : entry.path; +} +function mode2type$1(mode) { + switch (mode) { + case "040000": + return "tree"; + case "100644": + return "blob"; + case "100755": + return "blob"; + case "120000": + return "blob"; + case "160000": + return "commit"; + } + throw new InternalError(`Unexpected GitTree entry mode: ${mode}`); +} +function parseBuffer(buffer2) { + const _entries = []; + let cursor = 0; + while (cursor < buffer2.length) { + const space2 = buffer2.indexOf(32, cursor); + if (space2 === -1) { + throw new InternalError(`GitTree: Error parsing buffer at byte location ${cursor}: Could not find the next space character.`); + } + const nullchar = buffer2.indexOf(0, cursor); + if (nullchar === -1) { + throw new InternalError(`GitTree: Error parsing buffer at byte location ${cursor}: Could not find the next null character.`); + } + let mode = buffer2.slice(cursor, space2).toString("utf8"); + if (mode === "40000") + mode = "040000"; + const type = mode2type$1(mode); + const path2 = buffer2.slice(space2 + 1, nullchar).toString("utf8"); + if (path2.includes("\\") || path2.includes("/")) { + throw new UnsafeFilepathError(path2); + } + const oid = buffer2.slice(nullchar + 1, nullchar + 21).toString("hex"); + cursor = nullchar + 21; + _entries.push({ mode, path: path2, oid, type }); + } + return _entries; +} +function limitModeToAllowed(mode) { + if (typeof mode === "number") { + mode = mode.toString(8); + } + if (mode.match(/^0?4.*/)) + return "040000"; + if (mode.match(/^1006.*/)) + return "100644"; + if (mode.match(/^1007.*/)) + return "100755"; + if (mode.match(/^120.*/)) + return "120000"; + if (mode.match(/^160.*/)) + return "160000"; + throw new InternalError(`Could not understand file mode: ${mode}`); +} +function nudgeIntoShape(entry) { + if (!entry.oid && entry.sha) { + entry.oid = entry.sha; + } + entry.mode = limitModeToAllowed(entry.mode); + if (!entry.type) { + entry.type = mode2type$1(entry.mode); + } + return entry; +} +var GitTree = class { + constructor(entries) { + if (Buffer2.isBuffer(entries)) { + this._entries = parseBuffer(entries); + } else if (Array.isArray(entries)) { + this._entries = entries.map(nudgeIntoShape); + } else { + throw new InternalError("invalid type passed to GitTree constructor"); + } + this._entries.sort(comparePath); + } + static from(tree) { + return new GitTree(tree); + } + render() { + return this._entries.map((entry) => `${entry.mode} ${entry.type} ${entry.oid} ${entry.path}`).join("\n"); + } + toObject() { + const entries = [...this._entries]; + entries.sort(compareTreeEntryPath); + return Buffer2.concat(entries.map((entry) => { + const mode = Buffer2.from(entry.mode.replace(/^0/, "")); + const space2 = Buffer2.from(" "); + const path2 = Buffer2.from(entry.path, "utf8"); + const nullchar = Buffer2.from([0]); + const oid = Buffer2.from(entry.oid, "hex"); + return Buffer2.concat([mode, space2, path2, nullchar, oid]); + })); + } + entries() { + return this._entries; + } + *[Symbol.iterator]() { + for (const entry of this._entries) { + yield entry; + } + } +}; +var GitObject = class { + static wrap({ type, object }) { + return Buffer2.concat([ + Buffer2.from(`${type} ${object.byteLength.toString()}\0`), + Buffer2.from(object) + ]); + } + static unwrap(buffer2) { + const s = buffer2.indexOf(32); + const i = buffer2.indexOf(0); + const type = buffer2.slice(0, s).toString("utf8"); + const length = buffer2.slice(s + 1, i).toString("utf8"); + const actualLength = buffer2.length - (i + 1); + if (parseInt(length) !== actualLength) { + throw new InternalError(`Length mismatch: expected ${length} bytes but got ${actualLength} instead.`); + } + return { + type, + object: Buffer2.from(buffer2.slice(i + 1)) + }; + } +}; +async function readObjectLoose({ fs, gitdir, oid }) { + const source = `objects/${oid.slice(0, 2)}/${oid.slice(2)}`; + const file = await fs.read(`${gitdir}/${source}`); + if (!file) { + return null; + } + return { object: file, format: "deflated", source }; +} +function applyDelta(delta, source) { + const reader = new BufferCursor(delta); + const sourceSize = readVarIntLE(reader); + if (sourceSize !== source.byteLength) { + throw new InternalError(`applyDelta expected source buffer to be ${sourceSize} bytes but the provided buffer was ${source.length} bytes`); + } + const targetSize = readVarIntLE(reader); + let target; + const firstOp = readOp(reader, source); + if (firstOp.byteLength === targetSize) { + target = firstOp; + } else { + target = Buffer2.alloc(targetSize); + const writer = new BufferCursor(target); + writer.copy(firstOp); + while (!reader.eof()) { + writer.copy(readOp(reader, source)); + } + const tell = writer.tell(); + if (targetSize !== tell) { + throw new InternalError(`applyDelta expected target buffer to be ${targetSize} bytes but the resulting buffer was ${tell} bytes`); + } + } + return target; +} +function readVarIntLE(reader) { + let result = 0; + let shift = 0; + let byte = null; + do { + byte = reader.readUInt8(); + result |= (byte & 127) << shift; + shift += 7; + } while (byte & 128); + return result; +} +function readCompactLE(reader, flags, size) { + let result = 0; + let shift = 0; + while (size--) { + if (flags & 1) { + result |= reader.readUInt8() << shift; + } + flags >>= 1; + shift += 8; + } + return result; +} +function readOp(reader, source) { + const byte = reader.readUInt8(); + const COPY = 128; + const OFFS = 15; + const SIZE = 112; + if (byte & COPY) { + const offset = readCompactLE(reader, byte & OFFS, 4); + let size = readCompactLE(reader, (byte & SIZE) >> 4, 3); + if (size === 0) + size = 65536; + return source.slice(offset, offset + size); + } else { + return reader.slice(byte); + } +} +function fromValue(value) { + let queue = [value]; + return { + next() { + return Promise.resolve({ done: queue.length === 0, value: queue.pop() }); + }, + return() { + queue = []; + return {}; + }, + [Symbol.asyncIterator]() { + return this; + } + }; +} +function getIterator(iterable) { + if (iterable[Symbol.asyncIterator]) { + return iterable[Symbol.asyncIterator](); + } + if (iterable[Symbol.iterator]) { + return iterable[Symbol.iterator](); + } + if (iterable.next) { + return iterable; + } + return fromValue(iterable); +} +var StreamReader = class { + constructor(stream) { + this.stream = getIterator(stream); + this.buffer = null; + this.cursor = 0; + this.undoCursor = 0; + this.started = false; + this._ended = false; + this._discardedBytes = 0; + } + eof() { + return this._ended && this.cursor === this.buffer.length; + } + tell() { + return this._discardedBytes + this.cursor; + } + async byte() { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor === this.buffer.length) { + await this._loadnext(); + if (this._ended) + return; + } + this._moveCursor(1); + return this.buffer[this.undoCursor]; + } + async chunk() { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor === this.buffer.length) { + await this._loadnext(); + if (this._ended) + return; + } + this._moveCursor(this.buffer.length); + return this.buffer.slice(this.undoCursor, this.cursor); + } + async read(n) { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor + n > this.buffer.length) { + this._trim(); + await this._accumulate(n); + } + this._moveCursor(n); + return this.buffer.slice(this.undoCursor, this.cursor); + } + async skip(n) { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor + n > this.buffer.length) { + this._trim(); + await this._accumulate(n); + } + this._moveCursor(n); + } + async undo() { + this.cursor = this.undoCursor; + } + async _next() { + this.started = true; + let { done, value } = await this.stream.next(); + if (done) { + this._ended = true; + } + if (value) { + value = Buffer2.from(value); + } + return value; + } + _trim() { + this.buffer = this.buffer.slice(this.undoCursor); + this.cursor -= this.undoCursor; + this._discardedBytes += this.undoCursor; + this.undoCursor = 0; + } + _moveCursor(n) { + this.undoCursor = this.cursor; + this.cursor += n; + if (this.cursor > this.buffer.length) { + this.cursor = this.buffer.length; + } + } + async _accumulate(n) { + if (this._ended) + return; + const buffers = [this.buffer]; + while (this.cursor + n > lengthBuffers(buffers)) { + const nextbuffer = await this._next(); + if (this._ended) + break; + buffers.push(nextbuffer); + } + this.buffer = Buffer2.concat(buffers); + } + async _loadnext() { + this._discardedBytes += this.buffer.length; + this.undoCursor = 0; + this.cursor = 0; + this.buffer = await this._next(); + } + async _init() { + this.buffer = await this._next(); + } +}; +function lengthBuffers(buffers) { + return buffers.reduce((acc, buffer2) => acc + buffer2.length, 0); +} +async function listpack(stream, onData) { + const reader = new StreamReader(stream); + let PACK = await reader.read(4); + PACK = PACK.toString("utf8"); + if (PACK !== "PACK") { + throw new InternalError(`Invalid PACK header '${PACK}'`); + } + let version2 = await reader.read(4); + version2 = version2.readUInt32BE(0); + if (version2 !== 2) { + throw new InternalError(`Invalid packfile version: ${version2}`); + } + let numObjects = await reader.read(4); + numObjects = numObjects.readUInt32BE(0); + if (numObjects < 1) + return; + while (!reader.eof() && numObjects--) { + const offset = reader.tell(); + const { type, length, ofs, reference } = await parseHeader(reader); + const inflator = new import_pako.default.Inflate(); + while (!inflator.result) { + const chunk = await reader.chunk(); + if (!chunk) + break; + inflator.push(chunk, false); + if (inflator.err) { + throw new InternalError(`Pako error: ${inflator.msg}`); + } + if (inflator.result) { + if (inflator.result.length !== length) { + throw new InternalError(`Inflated object size is different from that stated in packfile.`); + } + await reader.undo(); + await reader.read(chunk.length - inflator.strm.avail_in); + const end = reader.tell(); + await onData({ + data: inflator.result, + type, + num: numObjects, + offset, + end, + reference, + ofs + }); + } + } + } +} +async function parseHeader(reader) { + let byte = await reader.byte(); + const type = byte >> 4 & 7; + let length = byte & 15; + if (byte & 128) { + let shift = 4; + do { + byte = await reader.byte(); + length |= (byte & 127) << shift; + shift += 7; + } while (byte & 128); + } + let ofs; + let reference; + if (type === 6) { + let shift = 0; + ofs = 0; + const bytes = []; + do { + byte = await reader.byte(); + ofs |= (byte & 127) << shift; + shift += 7; + bytes.push(byte); + } while (byte & 128); + reference = Buffer2.from(bytes); + } + if (type === 7) { + const buf = await reader.read(20); + reference = buf; + } + return { type, length, ofs, reference }; +} +var supportsDecompressionStream = false; +async function inflate(buffer2) { + if (supportsDecompressionStream === null) { + supportsDecompressionStream = testDecompressionStream(); + } + return supportsDecompressionStream ? browserInflate(buffer2) : import_pako.default.inflate(buffer2); +} +async function browserInflate(buffer2) { + const ds = new DecompressionStream("deflate"); + const d = new Blob([buffer2]).stream().pipeThrough(ds); + return new Uint8Array(await new Response(d).arrayBuffer()); +} +function testDecompressionStream() { + try { + const ds = new DecompressionStream("deflate"); + if (ds) + return true; + } catch (_) { + } + return false; +} +function decodeVarInt(reader) { + const bytes = []; + let byte = 0; + let multibyte = 0; + do { + byte = reader.readUInt8(); + const lastSeven = byte & 127; + bytes.push(lastSeven); + multibyte = byte & 128; + } while (multibyte); + return bytes.reduce((a, b) => a + 1 << 7 | b, -1); +} +function otherVarIntDecode(reader, startWith) { + let result = startWith; + let shift = 4; + let byte = null; + do { + byte = reader.readUInt8(); + result |= (byte & 127) << shift; + shift += 7; + } while (byte & 128); + return result; +} +var GitPackIndex = class { + constructor(stuff) { + Object.assign(this, stuff); + this.offsetCache = {}; + } + static async fromIdx({ idx, getExternalRefDelta }) { + const reader = new BufferCursor(idx); + const magic = reader.slice(4).toString("hex"); + if (magic !== "ff744f63") { + return; + } + const version2 = reader.readUInt32BE(); + if (version2 !== 2) { + throw new InternalError(`Unable to read version ${version2} packfile IDX. (Only version 2 supported)`); + } + if (idx.byteLength > 2048 * 1024 * 1024) { + throw new InternalError(`To keep implementation simple, I haven't implemented the layer 5 feature needed to support packfiles > 2GB in size.`); + } + reader.seek(reader.tell() + 4 * 255); + const size = reader.readUInt32BE(); + const hashes = []; + for (let i = 0; i < size; i++) { + const hash2 = reader.slice(20).toString("hex"); + hashes[i] = hash2; + } + reader.seek(reader.tell() + 4 * size); + const offsets = new Map(); + for (let i = 0; i < size; i++) { + offsets.set(hashes[i], reader.readUInt32BE()); + } + const packfileSha = reader.slice(20).toString("hex"); + return new GitPackIndex({ + hashes, + crcs: {}, + offsets, + packfileSha, + getExternalRefDelta + }); + } + static async fromPack({ pack, getExternalRefDelta, onProgress }) { + const listpackTypes = { + 1: "commit", + 2: "tree", + 3: "blob", + 4: "tag", + 6: "ofs-delta", + 7: "ref-delta" + }; + const offsetToObject = {}; + const packfileSha = pack.slice(-20).toString("hex"); + const hashes = []; + const crcs = {}; + const offsets = new Map(); + let totalObjectCount = null; + let lastPercent = null; + await listpack([pack], async ({ data, type, reference, offset, num: num2 }) => { + if (totalObjectCount === null) + totalObjectCount = num2; + const percent = Math.floor((totalObjectCount - num2) * 100 / totalObjectCount); + if (percent !== lastPercent) { + if (onProgress) { + await onProgress({ + phase: "Receiving objects", + loaded: totalObjectCount - num2, + total: totalObjectCount + }); + } + } + lastPercent = percent; + type = listpackTypes[type]; + if (["commit", "tree", "blob", "tag"].includes(type)) { + offsetToObject[offset] = { + type, + offset + }; + } else if (type === "ofs-delta") { + offsetToObject[offset] = { + type, + offset + }; + } else if (type === "ref-delta") { + offsetToObject[offset] = { + type, + offset + }; + } + }); + const offsetArray = Object.keys(offsetToObject).map(Number); + for (const [i, start] of offsetArray.entries()) { + const end = i + 1 === offsetArray.length ? pack.byteLength - 20 : offsetArray[i + 1]; + const o = offsetToObject[start]; + const crc = import_crc_32.default.buf(pack.slice(start, end)) >>> 0; + o.end = end; + o.crc = crc; + } + const p = new GitPackIndex({ + pack: Promise.resolve(pack), + packfileSha, + crcs, + hashes, + offsets, + getExternalRefDelta + }); + lastPercent = null; + let count = 0; + const objectsByDepth = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]; + for (let offset in offsetToObject) { + offset = Number(offset); + const percent = Math.floor(count * 100 / totalObjectCount); + if (percent !== lastPercent) { + if (onProgress) { + await onProgress({ + phase: "Resolving deltas", + loaded: count, + total: totalObjectCount + }); + } + } + count++; + lastPercent = percent; + const o = offsetToObject[offset]; + if (o.oid) + continue; + try { + p.readDepth = 0; + p.externalReadDepth = 0; + const { type, object } = await p.readSlice({ start: offset }); + objectsByDepth[p.readDepth] += 1; + const oid = await shasum(GitObject.wrap({ type, object })); + o.oid = oid; + hashes.push(oid); + offsets.set(oid, offset); + crcs[oid] = o.crc; + } catch (err) { + continue; + } + } + hashes.sort(); + return p; + } + async toBuffer() { + const buffers = []; + const write = (str, encoding) => { + buffers.push(Buffer2.from(str, encoding)); + }; + write("ff744f63", "hex"); + write("00000002", "hex"); + const fanoutBuffer = new BufferCursor(Buffer2.alloc(256 * 4)); + for (let i = 0; i < 256; i++) { + let count = 0; + for (const hash2 of this.hashes) { + if (parseInt(hash2.slice(0, 2), 16) <= i) + count++; + } + fanoutBuffer.writeUInt32BE(count); + } + buffers.push(fanoutBuffer.buffer); + for (const hash2 of this.hashes) { + write(hash2, "hex"); + } + const crcsBuffer = new BufferCursor(Buffer2.alloc(this.hashes.length * 4)); + for (const hash2 of this.hashes) { + crcsBuffer.writeUInt32BE(this.crcs[hash2]); + } + buffers.push(crcsBuffer.buffer); + const offsetsBuffer = new BufferCursor(Buffer2.alloc(this.hashes.length * 4)); + for (const hash2 of this.hashes) { + offsetsBuffer.writeUInt32BE(this.offsets.get(hash2)); + } + buffers.push(offsetsBuffer.buffer); + write(this.packfileSha, "hex"); + const totalBuffer = Buffer2.concat(buffers); + const sha = await shasum(totalBuffer); + const shaBuffer = Buffer2.alloc(20); + shaBuffer.write(sha, "hex"); + return Buffer2.concat([totalBuffer, shaBuffer]); + } + async load({ pack }) { + this.pack = pack; + } + async unload() { + this.pack = null; + } + async read({ oid }) { + if (!this.offsets.get(oid)) { + if (this.getExternalRefDelta) { + this.externalReadDepth++; + return this.getExternalRefDelta(oid); + } else { + throw new InternalError(`Could not read object ${oid} from packfile`); + } + } + const start = this.offsets.get(oid); + return this.readSlice({ start }); + } + async readSlice({ start }) { + if (this.offsetCache[start]) { + return Object.assign({}, this.offsetCache[start]); + } + this.readDepth++; + const types2 = { + 16: "commit", + 32: "tree", + 48: "blob", + 64: "tag", + 96: "ofs_delta", + 112: "ref_delta" + }; + if (!this.pack) { + throw new InternalError("Tried to read from a GitPackIndex with no packfile loaded into memory"); + } + const raw = (await this.pack).slice(start); + const reader = new BufferCursor(raw); + const byte = reader.readUInt8(); + const btype = byte & 112; + let type = types2[btype]; + if (type === void 0) { + throw new InternalError("Unrecognized type: 0b" + btype.toString(2)); + } + const lastFour = byte & 15; + let length = lastFour; + const multibyte = byte & 128; + if (multibyte) { + length = otherVarIntDecode(reader, lastFour); + } + let base = null; + let object = null; + if (type === "ofs_delta") { + const offset = decodeVarInt(reader); + const baseOffset = start - offset; + ({ object: base, type } = await this.readSlice({ start: baseOffset })); + } + if (type === "ref_delta") { + const oid = reader.slice(20).toString("hex"); + ({ object: base, type } = await this.read({ oid })); + } + const buffer2 = raw.slice(reader.tell()); + object = Buffer2.from(await inflate(buffer2)); + if (object.byteLength !== length) { + throw new InternalError(`Packfile told us object would have length ${length} but it had length ${object.byteLength}`); + } + if (base) { + object = Buffer2.from(applyDelta(object, base)); + } + if (this.readDepth > 3) { + this.offsetCache[start] = { type, object }; + } + return { type, format: "content", object }; + } +}; +var PackfileCache = Symbol("PackfileCache"); +async function loadPackIndex({ + fs, + filename, + getExternalRefDelta, + emitter, + emitterPrefix +}) { + const idx = await fs.read(filename); + return GitPackIndex.fromIdx({ idx, getExternalRefDelta }); +} +function readPackIndex({ + fs, + cache, + filename, + getExternalRefDelta, + emitter, + emitterPrefix +}) { + if (!cache[PackfileCache]) + cache[PackfileCache] = new Map(); + let p = cache[PackfileCache].get(filename); + if (!p) { + p = loadPackIndex({ + fs, + filename, + getExternalRefDelta, + emitter, + emitterPrefix + }); + cache[PackfileCache].set(filename, p); + } + return p; +} +async function readObjectPacked({ + fs, + cache, + gitdir, + oid, + format = "content", + getExternalRefDelta +}) { + let list = await fs.readdir(join(gitdir, "objects/pack")); + list = list.filter((x) => x.endsWith(".idx")); + for (const filename of list) { + const indexFile = `${gitdir}/objects/pack/${filename}`; + const p = await readPackIndex({ + fs, + cache, + filename: indexFile, + getExternalRefDelta + }); + if (p.error) + throw new InternalError(p.error); + if (p.offsets.has(oid)) { + if (!p.pack) { + const packFile = indexFile.replace(/idx$/, "pack"); + p.pack = fs.read(packFile); + } + const result = await p.read({ oid, getExternalRefDelta }); + result.format = "content"; + result.source = `objects/pack/${filename.replace(/idx$/, "pack")}`; + return result; + } + } + return null; +} +async function _readObject({ + fs, + cache, + gitdir, + oid, + format = "content" +}) { + const getExternalRefDelta = (oid2) => _readObject({ fs, cache, gitdir, oid: oid2 }); + let result; + if (oid === "4b825dc642cb6eb9a060e54bf8d69288fbee4904") { + result = { format: "wrapped", object: Buffer2.from(`tree 0\0`) }; + } + if (!result) { + result = await readObjectLoose({ fs, gitdir, oid }); + } + if (!result) { + result = await readObjectPacked({ + fs, + cache, + gitdir, + oid, + getExternalRefDelta + }); + } + if (!result) { + throw new NotFoundError(oid); + } + if (format === "deflated") { + return result; + } + if (result.format === "deflated") { + result.object = Buffer2.from(await inflate(result.object)); + result.format = "wrapped"; + } + if (result.format === "wrapped") { + if (format === "wrapped" && result.format === "wrapped") { + return result; + } + const sha = await shasum(result.object); + if (sha !== oid) { + throw new InternalError(`SHA check failed! Expected ${oid}, computed ${sha}`); + } + const { object, type } = GitObject.unwrap(result.object); + result.type = type; + result.object = object; + result.format = "content"; + } + if (result.format === "content") { + if (format === "content") + return result; + return; + } + throw new InternalError(`invalid format "${result.format}"`); +} +var AlreadyExistsError = class extends BaseError { + constructor(noun, where, canForce = true) { + super(`Failed to create ${noun} at ${where} because it already exists.${canForce ? ` (Hint: use 'force: true' parameter to overwrite existing ${noun}.)` : ""}`); + this.code = this.name = AlreadyExistsError.code; + this.data = { noun, where, canForce }; + } +}; +AlreadyExistsError.code = "AlreadyExistsError"; +var AmbiguousError = class extends BaseError { + constructor(nouns, short, matches) { + super(`Found multiple ${nouns} matching "${short}" (${matches.join(", ")}). Use a longer abbreviation length to disambiguate them.`); + this.code = this.name = AmbiguousError.code; + this.data = { nouns, short, matches }; + } +}; +AmbiguousError.code = "AmbiguousError"; +var CheckoutConflictError = class extends BaseError { + constructor(filepaths) { + super(`Your local changes to the following files would be overwritten by checkout: ${filepaths.join(", ")}`); + this.code = this.name = CheckoutConflictError.code; + this.data = { filepaths }; + } +}; +CheckoutConflictError.code = "CheckoutConflictError"; +var CommitNotFetchedError = class extends BaseError { + constructor(ref, oid) { + super(`Failed to checkout "${ref}" because commit ${oid} is not available locally. Do a git fetch to make the branch available locally.`); + this.code = this.name = CommitNotFetchedError.code; + this.data = { ref, oid }; + } +}; +CommitNotFetchedError.code = "CommitNotFetchedError"; +var EmptyServerResponseError = class extends BaseError { + constructor() { + super(`Empty response from git server.`); + this.code = this.name = EmptyServerResponseError.code; + this.data = {}; + } +}; +EmptyServerResponseError.code = "EmptyServerResponseError"; +var FastForwardError = class extends BaseError { + constructor() { + super(`A simple fast-forward merge was not possible.`); + this.code = this.name = FastForwardError.code; + this.data = {}; + } +}; +FastForwardError.code = "FastForwardError"; +var GitPushError = class extends BaseError { + constructor(prettyDetails, result) { + super(`One or more branches were not updated: ${prettyDetails}`); + this.code = this.name = GitPushError.code; + this.data = { prettyDetails, result }; + } +}; +GitPushError.code = "GitPushError"; +var HttpError = class extends BaseError { + constructor(statusCode, statusMessage, response) { + super(`HTTP Error: ${statusCode} ${statusMessage}`); + this.code = this.name = HttpError.code; + this.data = { statusCode, statusMessage, response }; + } +}; +HttpError.code = "HttpError"; +var InvalidFilepathError = class extends BaseError { + constructor(reason) { + let message = "invalid filepath"; + if (reason === "leading-slash" || reason === "trailing-slash") { + message = `"filepath" parameter should not include leading or trailing directory separators because these can cause problems on some platforms.`; + } else if (reason === "directory") { + message = `"filepath" should not be a directory.`; + } + super(message); + this.code = this.name = InvalidFilepathError.code; + this.data = { reason }; + } +}; +InvalidFilepathError.code = "InvalidFilepathError"; +var InvalidRefNameError = class extends BaseError { + constructor(ref, suggestion) { + super(`"${ref}" would be an invalid git reference. (Hint: a valid alternative would be "${suggestion}".)`); + this.code = this.name = InvalidRefNameError.code; + this.data = { ref, suggestion }; + } +}; +InvalidRefNameError.code = "InvalidRefNameError"; +var MaxDepthError = class extends BaseError { + constructor(depth) { + super(`Maximum search depth of ${depth} exceeded.`); + this.code = this.name = MaxDepthError.code; + this.data = { depth }; + } +}; +MaxDepthError.code = "MaxDepthError"; +var MergeNotSupportedError = class extends BaseError { + constructor() { + super(`Merges with conflicts are not supported yet.`); + this.code = this.name = MergeNotSupportedError.code; + this.data = {}; + } +}; +MergeNotSupportedError.code = "MergeNotSupportedError"; +var MergeConflictError = class extends BaseError { + constructor(filepaths) { + super(`Automatic merge failed with one or more merge conflicts in the following files: ${filepaths.toString()}. Fix conflicts then commit the result.`); + this.code = this.name = MergeConflictError.code; + this.data = { filepaths }; + } +}; +MergeConflictError.code = "MergeConflictError"; +var MissingNameError = class extends BaseError { + constructor(role) { + super(`No name was provided for ${role} in the argument or in the .git/config file.`); + this.code = this.name = MissingNameError.code; + this.data = { role }; + } +}; +MissingNameError.code = "MissingNameError"; +var MissingParameterError = class extends BaseError { + constructor(parameter) { + super(`The function requires a "${parameter}" parameter but none was provided.`); + this.code = this.name = MissingParameterError.code; + this.data = { parameter }; + } +}; +MissingParameterError.code = "MissingParameterError"; +var MultipleGitError = class extends BaseError { + constructor(errors) { + super(`There are multiple errors that were thrown by the method. Please refer to the "errors" property to see more`); + this.code = this.name = MultipleGitError.code; + this.data = { errors }; + this.errors = errors; + } +}; +MultipleGitError.code = "MultipleGitError"; +var ParseError = class extends BaseError { + constructor(expected, actual) { + super(`Expected "${expected}" but received "${actual}".`); + this.code = this.name = ParseError.code; + this.data = { expected, actual }; + } +}; +ParseError.code = "ParseError"; +var PushRejectedError = class extends BaseError { + constructor(reason) { + let message = ""; + if (reason === "not-fast-forward") { + message = " because it was not a simple fast-forward"; + } else if (reason === "tag-exists") { + message = " because tag already exists"; + } + super(`Push rejected${message}. Use "force: true" to override.`); + this.code = this.name = PushRejectedError.code; + this.data = { reason }; + } +}; +PushRejectedError.code = "PushRejectedError"; +var RemoteCapabilityError = class extends BaseError { + constructor(capability, parameter) { + super(`Remote does not support the "${capability}" so the "${parameter}" parameter cannot be used.`); + this.code = this.name = RemoteCapabilityError.code; + this.data = { capability, parameter }; + } +}; +RemoteCapabilityError.code = "RemoteCapabilityError"; +var SmartHttpError = class extends BaseError { + constructor(preview, response) { + super(`Remote did not reply using the "smart" HTTP protocol. Expected "001e# service=git-upload-pack" but received: ${preview}`); + this.code = this.name = SmartHttpError.code; + this.data = { preview, response }; + } +}; +SmartHttpError.code = "SmartHttpError"; +var UnknownTransportError = class extends BaseError { + constructor(url, transport, suggestion) { + super(`Git remote "${url}" uses an unrecognized transport protocol: "${transport}"`); + this.code = this.name = UnknownTransportError.code; + this.data = { url, transport, suggestion }; + } +}; +UnknownTransportError.code = "UnknownTransportError"; +var UrlParseError = class extends BaseError { + constructor(url) { + super(`Cannot parse remote URL: "${url}"`); + this.code = this.name = UrlParseError.code; + this.data = { url }; + } +}; +UrlParseError.code = "UrlParseError"; +var UserCanceledError = class extends BaseError { + constructor() { + super(`The operation was canceled.`); + this.code = this.name = UserCanceledError.code; + this.data = {}; + } +}; +UserCanceledError.code = "UserCanceledError"; +var Errors = /* @__PURE__ */ Object.freeze({ + __proto__: null, + AlreadyExistsError, + AmbiguousError, + CheckoutConflictError, + CommitNotFetchedError, + EmptyServerResponseError, + FastForwardError, + GitPushError, + HttpError, + InternalError, + InvalidFilepathError, + InvalidOidError, + InvalidRefNameError, + MaxDepthError, + MergeNotSupportedError, + MergeConflictError, + MissingNameError, + MissingParameterError, + MultipleGitError, + NoRefspecError, + NotFoundError, + ObjectTypeError, + ParseError, + PushRejectedError, + RemoteCapabilityError, + SmartHttpError, + UnknownTransportError, + UnsafeFilepathError, + UrlParseError, + UserCanceledError +}); +function formatAuthor({ name, email, timestamp, timezoneOffset }) { + timezoneOffset = formatTimezoneOffset(timezoneOffset); + return `${name} <${email}> ${timestamp} ${timezoneOffset}`; +} +function formatTimezoneOffset(minutes) { + const sign = simpleSign(negateExceptForZero(minutes)); + minutes = Math.abs(minutes); + const hours = Math.floor(minutes / 60); + minutes -= hours * 60; + let strHours = String(hours); + let strMinutes = String(minutes); + if (strHours.length < 2) + strHours = "0" + strHours; + if (strMinutes.length < 2) + strMinutes = "0" + strMinutes; + return (sign === -1 ? "-" : "+") + strHours + strMinutes; +} +function simpleSign(n) { + return Math.sign(n) || (Object.is(n, -0) ? -1 : 1); +} +function negateExceptForZero(n) { + return n === 0 ? n : -n; +} +function normalizeNewlines(str) { + str = str.replace(/\r/g, ""); + str = str.replace(/^\n+/, ""); + str = str.replace(/\n+$/, "") + "\n"; + return str; +} +function parseAuthor(author) { + const [, name, email, timestamp, offset] = author.match(/^(.*) <(.*)> (.*) (.*)$/); + return { + name, + email, + timestamp: Number(timestamp), + timezoneOffset: parseTimezoneOffset(offset) + }; +} +function parseTimezoneOffset(offset) { + let [, sign, hours, minutes] = offset.match(/(\+|-)(\d\d)(\d\d)/); + minutes = (sign === "+" ? 1 : -1) * (Number(hours) * 60 + Number(minutes)); + return negateExceptForZero$1(minutes); +} +function negateExceptForZero$1(n) { + return n === 0 ? n : -n; +} +var GitAnnotatedTag = class { + constructor(tag2) { + if (typeof tag2 === "string") { + this._tag = tag2; + } else if (Buffer2.isBuffer(tag2)) { + this._tag = tag2.toString("utf8"); + } else if (typeof tag2 === "object") { + this._tag = GitAnnotatedTag.render(tag2); + } else { + throw new InternalError("invalid type passed to GitAnnotatedTag constructor"); + } + } + static from(tag2) { + return new GitAnnotatedTag(tag2); + } + static render(obj) { + return `object ${obj.object} +type ${obj.type} +tag ${obj.tag} +tagger ${formatAuthor(obj.tagger)} + +${obj.message} +${obj.gpgsig ? obj.gpgsig : ""}`; + } + justHeaders() { + return this._tag.slice(0, this._tag.indexOf("\n\n")); + } + message() { + const tag2 = this.withoutSignature(); + return tag2.slice(tag2.indexOf("\n\n") + 2); + } + parse() { + return Object.assign(this.headers(), { + message: this.message(), + gpgsig: this.gpgsig() + }); + } + render() { + return this._tag; + } + headers() { + const headers = this.justHeaders().split("\n"); + const hs = []; + for (const h of headers) { + if (h[0] === " ") { + hs[hs.length - 1] += "\n" + h.slice(1); + } else { + hs.push(h); + } + } + const obj = {}; + for (const h of hs) { + const key2 = h.slice(0, h.indexOf(" ")); + const value = h.slice(h.indexOf(" ") + 1); + if (Array.isArray(obj[key2])) { + obj[key2].push(value); + } else { + obj[key2] = value; + } + } + if (obj.tagger) { + obj.tagger = parseAuthor(obj.tagger); + } + if (obj.committer) { + obj.committer = parseAuthor(obj.committer); + } + return obj; + } + withoutSignature() { + const tag2 = normalizeNewlines(this._tag); + if (tag2.indexOf("\n-----BEGIN PGP SIGNATURE-----") === -1) + return tag2; + return tag2.slice(0, tag2.lastIndexOf("\n-----BEGIN PGP SIGNATURE-----")); + } + gpgsig() { + if (this._tag.indexOf("\n-----BEGIN PGP SIGNATURE-----") === -1) + return; + const signature = this._tag.slice(this._tag.indexOf("-----BEGIN PGP SIGNATURE-----"), this._tag.indexOf("-----END PGP SIGNATURE-----") + "-----END PGP SIGNATURE-----".length); + return normalizeNewlines(signature); + } + payload() { + return this.withoutSignature() + "\n"; + } + toObject() { + return Buffer2.from(this._tag, "utf8"); + } + static async sign(tag2, sign, secretKey) { + const payload = tag2.payload(); + let { signature } = await sign({ payload, secretKey }); + signature = normalizeNewlines(signature); + const signedTag = payload + signature; + return GitAnnotatedTag.from(signedTag); + } +}; +function indent(str) { + return str.trim().split("\n").map((x) => " " + x).join("\n") + "\n"; +} +function outdent(str) { + return str.split("\n").map((x) => x.replace(/^ /, "")).join("\n"); +} +var GitCommit = class { + constructor(commit2) { + if (typeof commit2 === "string") { + this._commit = commit2; + } else if (Buffer2.isBuffer(commit2)) { + this._commit = commit2.toString("utf8"); + } else if (typeof commit2 === "object") { + this._commit = GitCommit.render(commit2); + } else { + throw new InternalError("invalid type passed to GitCommit constructor"); + } + } + static fromPayloadSignature({ payload, signature }) { + const headers = GitCommit.justHeaders(payload); + const message = GitCommit.justMessage(payload); + const commit2 = normalizeNewlines(headers + "\ngpgsig" + indent(signature) + "\n" + message); + return new GitCommit(commit2); + } + static from(commit2) { + return new GitCommit(commit2); + } + toObject() { + return Buffer2.from(this._commit, "utf8"); + } + headers() { + return this.parseHeaders(); + } + message() { + return GitCommit.justMessage(this._commit); + } + parse() { + return Object.assign({ message: this.message() }, this.headers()); + } + static justMessage(commit2) { + return normalizeNewlines(commit2.slice(commit2.indexOf("\n\n") + 2)); + } + static justHeaders(commit2) { + return commit2.slice(0, commit2.indexOf("\n\n")); + } + parseHeaders() { + const headers = GitCommit.justHeaders(this._commit).split("\n"); + const hs = []; + for (const h of headers) { + if (h[0] === " ") { + hs[hs.length - 1] += "\n" + h.slice(1); + } else { + hs.push(h); + } + } + const obj = { + parent: [] + }; + for (const h of hs) { + const key2 = h.slice(0, h.indexOf(" ")); + const value = h.slice(h.indexOf(" ") + 1); + if (Array.isArray(obj[key2])) { + obj[key2].push(value); + } else { + obj[key2] = value; + } + } + if (obj.author) { + obj.author = parseAuthor(obj.author); + } + if (obj.committer) { + obj.committer = parseAuthor(obj.committer); + } + return obj; + } + static renderHeaders(obj) { + let headers = ""; + if (obj.tree) { + headers += `tree ${obj.tree} +`; + } else { + headers += `tree 4b825dc642cb6eb9a060e54bf8d69288fbee4904 +`; + } + if (obj.parent) { + if (obj.parent.length === void 0) { + throw new InternalError(`commit 'parent' property should be an array`); + } + for (const p of obj.parent) { + headers += `parent ${p} +`; + } + } + const author = obj.author; + headers += `author ${formatAuthor(author)} +`; + const committer = obj.committer || obj.author; + headers += `committer ${formatAuthor(committer)} +`; + if (obj.gpgsig) { + headers += "gpgsig" + indent(obj.gpgsig); + } + return headers; + } + static render(obj) { + return GitCommit.renderHeaders(obj) + "\n" + normalizeNewlines(obj.message); + } + render() { + return this._commit; + } + withoutSignature() { + const commit2 = normalizeNewlines(this._commit); + if (commit2.indexOf("\ngpgsig") === -1) + return commit2; + const headers = commit2.slice(0, commit2.indexOf("\ngpgsig")); + const message = commit2.slice(commit2.indexOf("-----END PGP SIGNATURE-----\n") + "-----END PGP SIGNATURE-----\n".length); + return normalizeNewlines(headers + "\n" + message); + } + isolateSignature() { + const signature = this._commit.slice(this._commit.indexOf("-----BEGIN PGP SIGNATURE-----"), this._commit.indexOf("-----END PGP SIGNATURE-----") + "-----END PGP SIGNATURE-----".length); + return outdent(signature); + } + static async sign(commit2, sign, secretKey) { + const payload = commit2.withoutSignature(); + const message = GitCommit.justMessage(commit2._commit); + let { signature } = await sign({ payload, secretKey }); + signature = normalizeNewlines(signature); + const headers = GitCommit.justHeaders(commit2._commit); + const signedCommit = headers + "\ngpgsig" + indent(signature) + "\n" + message; + return GitCommit.from(signedCommit); + } +}; +async function resolveTree({ fs, cache, gitdir, oid }) { + if (oid === "4b825dc642cb6eb9a060e54bf8d69288fbee4904") { + return { tree: GitTree.from([]), oid }; + } + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + oid = GitAnnotatedTag.from(object).parse().object; + return resolveTree({ fs, cache, gitdir, oid }); + } + if (type === "commit") { + oid = GitCommit.from(object).parse().tree; + return resolveTree({ fs, cache, gitdir, oid }); + } + if (type !== "tree") { + throw new ObjectTypeError(oid, type, "tree"); + } + return { tree: GitTree.from(object), oid }; +} +var GitWalkerRepo = class { + constructor({ fs, gitdir, ref, cache }) { + this.fs = fs; + this.cache = cache; + this.gitdir = gitdir; + this.mapPromise = (async () => { + const map = new Map(); + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref }); + } catch (e) { + if (e instanceof NotFoundError) { + oid = "4b825dc642cb6eb9a060e54bf8d69288fbee4904"; + } + } + const tree = await resolveTree({ fs, cache: this.cache, gitdir, oid }); + tree.type = "tree"; + tree.mode = "40000"; + map.set(".", tree); + return map; + })(); + const walker = this; + this.ConstructEntry = class TreeEntry { + constructor(fullpath) { + this._fullpath = fullpath; + this._type = false; + this._mode = false; + this._stat = false; + this._content = false; + this._oid = false; + } + async type() { + return walker.type(this); + } + async mode() { + return walker.mode(this); + } + async stat() { + return walker.stat(this); + } + async content() { + return walker.content(this); + } + async oid() { + return walker.oid(this); + } + }; + } + async readdir(entry) { + const filepath = entry._fullpath; + const { fs, cache, gitdir } = this; + const map = await this.mapPromise; + const obj = map.get(filepath); + if (!obj) + throw new Error(`No obj for ${filepath}`); + const oid = obj.oid; + if (!oid) + throw new Error(`No oid for obj ${JSON.stringify(obj)}`); + if (obj.type !== "tree") { + return null; + } + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type !== obj.type) { + throw new ObjectTypeError(oid, type, obj.type); + } + const tree = GitTree.from(object); + for (const entry2 of tree) { + map.set(join(filepath, entry2.path), entry2); + } + return tree.entries().map((entry2) => join(filepath, entry2.path)); + } + async type(entry) { + if (entry._type === false) { + const map = await this.mapPromise; + const { type } = map.get(entry._fullpath); + entry._type = type; + } + return entry._type; + } + async mode(entry) { + if (entry._mode === false) { + const map = await this.mapPromise; + const { mode } = map.get(entry._fullpath); + entry._mode = normalizeMode(parseInt(mode, 8)); + } + return entry._mode; + } + async stat(_entry) { + } + async content(entry) { + if (entry._content === false) { + const map = await this.mapPromise; + const { fs, cache, gitdir } = this; + const obj = map.get(entry._fullpath); + const oid = obj.oid; + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type !== "blob") { + entry._content = void 0; + } else { + entry._content = new Uint8Array(object); + } + } + return entry._content; + } + async oid(entry) { + if (entry._oid === false) { + const map = await this.mapPromise; + const obj = map.get(entry._fullpath); + entry._oid = obj.oid; + } + return entry._oid; + } +}; +function TREE({ ref = "HEAD" } = {}) { + const o = Object.create(null); + Object.defineProperty(o, GitWalkSymbol, { + value: function({ fs, gitdir, cache }) { + return new GitWalkerRepo({ fs, gitdir, ref, cache }); + } + }); + Object.freeze(o); + return o; +} +var GitWalkerFs = class { + constructor({ fs, dir, gitdir, cache }) { + this.fs = fs; + this.cache = cache; + this.dir = dir; + this.gitdir = gitdir; + const walker = this; + this.ConstructEntry = class WorkdirEntry { + constructor(fullpath) { + this._fullpath = fullpath; + this._type = false; + this._mode = false; + this._stat = false; + this._content = false; + this._oid = false; + } + async type() { + return walker.type(this); + } + async mode() { + return walker.mode(this); + } + async stat() { + return walker.stat(this); + } + async content() { + return walker.content(this); + } + async oid() { + return walker.oid(this); + } + }; + } + async readdir(entry) { + const filepath = entry._fullpath; + const { fs, dir } = this; + const names = await fs.readdir(join(dir, filepath)); + if (names === null) + return null; + return names.map((name) => join(filepath, name)); + } + async type(entry) { + if (entry._type === false) { + await entry.stat(); + } + return entry._type; + } + async mode(entry) { + if (entry._mode === false) { + await entry.stat(); + } + return entry._mode; + } + async stat(entry) { + if (entry._stat === false) { + const { fs, dir } = this; + let stat = await fs.lstat(`${dir}/${entry._fullpath}`); + if (!stat) { + throw new Error(`ENOENT: no such file or directory, lstat '${entry._fullpath}'`); + } + let type = stat.isDirectory() ? "tree" : "blob"; + if (type === "blob" && !stat.isFile() && !stat.isSymbolicLink()) { + type = "special"; + } + entry._type = type; + stat = normalizeStats(stat); + entry._mode = stat.mode; + if (stat.size === -1 && entry._actualSize) { + stat.size = entry._actualSize; + } + entry._stat = stat; + } + return entry._stat; + } + async content(entry) { + if (entry._content === false) { + const { fs, dir } = this; + if (await entry.type() === "tree") { + entry._content = void 0; + } else { + const content = await fs.read(`${dir}/${entry._fullpath}`); + entry._actualSize = content.length; + if (entry._stat && entry._stat.size === -1) { + entry._stat.size = entry._actualSize; + } + entry._content = new Uint8Array(content); + } + } + return entry._content; + } + async oid(entry) { + if (entry._oid === false) { + const { fs, gitdir, cache } = this; + let oid; + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + const stage = index2.entriesMap.get(entry._fullpath); + const stats = await entry.stat(); + if (!stage || compareStats(stats, stage)) { + const content = await entry.content(); + if (content === void 0) { + oid = void 0; + } else { + oid = await shasum(GitObject.wrap({ type: "blob", object: await entry.content() })); + if (stage && oid === stage.oid && stats.mode === stage.mode && compareStats(stats, stage)) { + index2.insert({ + filepath: entry._fullpath, + stats, + oid + }); + } + } + } else { + oid = stage.oid; + } + }); + entry._oid = oid; + } + return entry._oid; + } +}; +function WORKDIR() { + const o = Object.create(null); + Object.defineProperty(o, GitWalkSymbol, { + value: function({ fs, dir, gitdir, cache }) { + return new GitWalkerFs({ fs, dir, gitdir, cache }); + } + }); + Object.freeze(o); + return o; +} +var GitIgnoreManager = class { + static async isIgnored({ fs, dir, gitdir = join(dir, ".git"), filepath }) { + if (basename(filepath) === ".git") + return true; + if (filepath === ".") + return false; + let excludes = ""; + const excludesFile = join(gitdir, "info", "exclude"); + if (await fs.exists(excludesFile)) { + excludes = await fs.read(excludesFile, "utf8"); + } + const pairs = [ + { + gitignore: join(dir, ".gitignore"), + filepath + } + ]; + const pieces = filepath.split("/").filter(Boolean); + for (let i = 1; i < pieces.length; i++) { + const folder = pieces.slice(0, i).join("/"); + const file = pieces.slice(i).join("/"); + pairs.push({ + gitignore: join(dir, folder, ".gitignore"), + filepath: file + }); + } + let ignoredStatus = false; + for (const p of pairs) { + let file; + try { + file = await fs.read(p.gitignore, "utf8"); + } catch (err) { + if (err.code === "NOENT") + continue; + } + const ign = (0, import_ignore.default)().add(excludes); + ign.add(file); + const parentdir = dirname(p.filepath); + if (parentdir !== "." && ign.ignores(parentdir)) + return true; + if (ignoredStatus) { + ignoredStatus = !ign.test(p.filepath).unignored; + } else { + ignoredStatus = ign.test(p.filepath).ignored; + } + } + return ignoredStatus; + } +}; +async function rmRecursive(fs, filepath) { + const entries = await fs.readdir(filepath); + if (entries == null) { + await fs.rm(filepath); + } else if (entries.length) { + await Promise.all(entries.map((entry) => { + const subpath = join(filepath, entry); + return fs.lstat(subpath).then((stat) => { + if (!stat) + return; + return stat.isDirectory() ? rmRecursive(fs, subpath) : fs.rm(subpath); + }); + })).then(() => fs.rmdir(filepath)); + } else { + await fs.rmdir(filepath); + } +} +var FileSystem = class { + constructor(fs) { + if (typeof fs._original_unwrapped_fs !== "undefined") + return fs; + const promises = Object.getOwnPropertyDescriptor(fs, "promises"); + if (promises && promises.enumerable) { + this._readFile = fs.promises.readFile.bind(fs.promises); + this._writeFile = fs.promises.writeFile.bind(fs.promises); + this._mkdir = fs.promises.mkdir.bind(fs.promises); + if (fs.promises.rm) { + this._rm = fs.promises.rm.bind(fs.promises); + } else if (fs.promises.rmdir.length > 1) { + this._rm = fs.promises.rmdir.bind(fs.promises); + } else { + this._rm = rmRecursive.bind(null, this); + } + this._rmdir = fs.promises.rmdir.bind(fs.promises); + this._unlink = fs.promises.unlink.bind(fs.promises); + this._stat = fs.promises.stat.bind(fs.promises); + this._lstat = fs.promises.lstat.bind(fs.promises); + this._readdir = fs.promises.readdir.bind(fs.promises); + this._readlink = fs.promises.readlink.bind(fs.promises); + this._symlink = fs.promises.symlink.bind(fs.promises); + } else { + this._readFile = (0, import_pify.default)(fs.readFile.bind(fs)); + this._writeFile = (0, import_pify.default)(fs.writeFile.bind(fs)); + this._mkdir = (0, import_pify.default)(fs.mkdir.bind(fs)); + if (fs.rm) { + this._rm = (0, import_pify.default)(fs.rm.bind(fs)); + } else if (fs.rmdir.length > 2) { + this._rm = (0, import_pify.default)(fs.rmdir.bind(fs)); + } else { + this._rm = rmRecursive.bind(null, this); + } + this._rmdir = (0, import_pify.default)(fs.rmdir.bind(fs)); + this._unlink = (0, import_pify.default)(fs.unlink.bind(fs)); + this._stat = (0, import_pify.default)(fs.stat.bind(fs)); + this._lstat = (0, import_pify.default)(fs.lstat.bind(fs)); + this._readdir = (0, import_pify.default)(fs.readdir.bind(fs)); + this._readlink = (0, import_pify.default)(fs.readlink.bind(fs)); + this._symlink = (0, import_pify.default)(fs.symlink.bind(fs)); + } + this._original_unwrapped_fs = fs; + } + async exists(filepath, options = {}) { + try { + await this._stat(filepath); + return true; + } catch (err) { + if (err.code === "ENOENT" || err.code === "ENOTDIR") { + return false; + } else { + console.log('Unhandled error in "FileSystem.exists()" function', err); + throw err; + } + } + } + async read(filepath, options = {}) { + try { + let buffer2 = await this._readFile(filepath, options); + if (typeof buffer2 !== "string") { + buffer2 = Buffer2.from(buffer2); + } + return buffer2; + } catch (err) { + return null; + } + } + async write(filepath, contents, options = {}) { + try { + await this._writeFile(filepath, contents, options); + return; + } catch (err) { + await this.mkdir(dirname(filepath)); + await this._writeFile(filepath, contents, options); + } + } + async mkdir(filepath, _selfCall = false) { + try { + await this._mkdir(filepath); + return; + } catch (err) { + if (err === null) + return; + if (err.code === "EEXIST") + return; + if (_selfCall) + throw err; + if (err.code === "ENOENT") { + const parent = dirname(filepath); + if (parent === "." || parent === "/" || parent === filepath) + throw err; + await this.mkdir(parent); + await this.mkdir(filepath, true); + } + } + } + async rm(filepath) { + try { + await this._unlink(filepath); + } catch (err) { + if (err.code !== "ENOENT") + throw err; + } + } + async rmdir(filepath, opts) { + try { + if (opts && opts.recursive) { + await this._rm(filepath, opts); + } else { + await this._rmdir(filepath); + } + } catch (err) { + if (err.code !== "ENOENT") + throw err; + } + } + async readdir(filepath) { + try { + const names = await this._readdir(filepath); + names.sort(compareStrings); + return names; + } catch (err) { + if (err.code === "ENOTDIR") + return null; + return []; + } + } + async readdirDeep(dir) { + const subdirs = await this._readdir(dir); + const files = await Promise.all(subdirs.map(async (subdir) => { + const res = dir + "/" + subdir; + return (await this._stat(res)).isDirectory() ? this.readdirDeep(res) : res; + })); + return files.reduce((a, f) => a.concat(f), []); + } + async lstat(filename) { + try { + const stats = await this._lstat(filename); + return stats; + } catch (err) { + if (err.code === "ENOENT") { + return null; + } + throw err; + } + } + async readlink(filename, opts = { encoding: "buffer" }) { + try { + const link = await this._readlink(filename, opts); + return Buffer2.isBuffer(link) ? link : Buffer2.from(link); + } catch (err) { + if (err.code === "ENOENT") { + return null; + } + throw err; + } + } + async writelink(filename, buffer2) { + return this._symlink(buffer2.toString("utf8"), filename); + } +}; +async function writeObjectLoose({ fs, gitdir, object, format, oid }) { + if (format !== "deflated") { + throw new InternalError("GitObjectStoreLoose expects objects to write to be in deflated format"); + } + const source = `objects/${oid.slice(0, 2)}/${oid.slice(2)}`; + const filepath = `${gitdir}/${source}`; + if (!await fs.exists(filepath)) + await fs.write(filepath, object); +} +var supportsCompressionStream = null; +async function deflate(buffer2) { + if (supportsCompressionStream === null) { + supportsCompressionStream = testCompressionStream(); + } + return supportsCompressionStream ? browserDeflate(buffer2) : import_pako.default.deflate(buffer2); +} +async function browserDeflate(buffer2) { + const cs = new CompressionStream("deflate"); + const c = new Blob([buffer2]).stream().pipeThrough(cs); + return new Uint8Array(await new Response(c).arrayBuffer()); +} +function testCompressionStream() { + try { + const cs = new CompressionStream("deflate"); + new Blob([]).stream(); + if (cs) + return true; + } catch (_) { + } + return false; +} +async function _writeObject({ + fs, + gitdir, + type, + object, + format = "content", + oid = void 0, + dryRun = false +}) { + if (format !== "deflated") { + if (format !== "wrapped") { + object = GitObject.wrap({ type, object }); + } + oid = await shasum(object); + object = Buffer2.from(await deflate(object)); + } + if (!dryRun) { + await writeObjectLoose({ fs, gitdir, object, format: "deflated", oid }); + } + return oid; +} +function assertParameter(name, value) { + if (value === void 0) { + throw new MissingParameterError(name); + } +} +function posixifyPathBuffer(buffer2) { + let idx; + while (~(idx = buffer2.indexOf(92))) + buffer2[idx] = 47; + return buffer2; +} +async function add({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {}, + force = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + await GitIndexManager.acquire({ fs, gitdir, cache }, async (index2) => { + return addToIndex({ dir, gitdir, fs, filepath, index: index2, force }); + }); + } catch (err) { + err.caller = "git.add"; + throw err; + } +} +async function addToIndex({ dir, gitdir, fs, filepath, index: index2, force }) { + filepath = Array.isArray(filepath) ? filepath : [filepath]; + const promises = filepath.map(async (currentFilepath) => { + if (!force) { + const ignored = await GitIgnoreManager.isIgnored({ + fs, + dir, + gitdir, + filepath: currentFilepath + }); + if (ignored) + return; + } + const stats = await fs.lstat(join(dir, currentFilepath)); + if (!stats) + throw new NotFoundError(currentFilepath); + if (stats.isDirectory()) { + const children2 = await fs.readdir(join(dir, currentFilepath)); + const promises2 = children2.map((child) => addToIndex({ + dir, + gitdir, + fs, + filepath: [join(currentFilepath, child)], + index: index2, + force + })); + await Promise.all(promises2); + } else { + const object = stats.isSymbolicLink() ? await fs.readlink(join(dir, currentFilepath)).then(posixifyPathBuffer) : await fs.read(join(dir, currentFilepath)); + if (object === null) + throw new NotFoundError(currentFilepath); + const oid = await _writeObject({ fs, gitdir, type: "blob", object }); + index2.insert({ filepath: currentFilepath, stats, oid }); + } + }); + const settledPromises = await Promise.allSettled(promises); + const rejectedPromises = settledPromises.filter((settle) => settle.status === "rejected").map((settle) => settle.reason); + if (rejectedPromises.length > 1) { + throw new MultipleGitError(rejectedPromises); + } + if (rejectedPromises.length === 1) { + throw rejectedPromises[0]; + } + const fulfilledPromises = settledPromises.filter((settle) => settle.status === "fulfilled" && settle.value).map((settle) => settle.value); + return fulfilledPromises; +} +async function _commit({ + fs, + cache, + onSign, + gitdir, + message, + author, + committer, + signingKey, + dryRun = false, + noUpdateBranch = false, + ref, + parent, + tree +}) { + if (!ref) { + ref = await GitRefManager.resolve({ + fs, + gitdir, + ref: "HEAD", + depth: 2 + }); + } + return GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + const inodes = flatFileListToDirectoryStructure(index2.entries); + const inode = inodes.get("."); + if (!tree) { + tree = await constructTree({ fs, gitdir, inode, dryRun }); + } + if (!parent) { + try { + parent = [ + await GitRefManager.resolve({ + fs, + gitdir, + ref + }) + ]; + } catch (err) { + parent = []; + } + } else { + parent = await Promise.all(parent.map((p) => { + return GitRefManager.resolve({ fs, gitdir, ref: p }); + })); + } + let comm = GitCommit.from({ + tree, + parent, + author, + committer, + message + }); + if (signingKey) { + comm = await GitCommit.sign(comm, onSign, signingKey); + } + const oid = await _writeObject({ + fs, + gitdir, + type: "commit", + object: comm.toObject(), + dryRun + }); + if (!noUpdateBranch && !dryRun) { + await GitRefManager.writeRef({ + fs, + gitdir, + ref, + value: oid + }); + } + return oid; + }); +} +async function constructTree({ fs, gitdir, inode, dryRun }) { + const children2 = inode.children; + for (const inode2 of children2) { + if (inode2.type === "tree") { + inode2.metadata.mode = "040000"; + inode2.metadata.oid = await constructTree({ fs, gitdir, inode: inode2, dryRun }); + } + } + const entries = children2.map((inode2) => ({ + mode: inode2.metadata.mode, + path: inode2.basename, + oid: inode2.metadata.oid, + type: inode2.type + })); + const tree = GitTree.from(entries); + const oid = await _writeObject({ + fs, + gitdir, + type: "tree", + object: tree.toObject(), + dryRun + }); + return oid; +} +async function resolveFilepath({ fs, cache, gitdir, oid, filepath }) { + if (filepath.startsWith("/")) { + throw new InvalidFilepathError("leading-slash"); + } else if (filepath.endsWith("/")) { + throw new InvalidFilepathError("trailing-slash"); + } + const _oid = oid; + const result = await resolveTree({ fs, cache, gitdir, oid }); + const tree = result.tree; + if (filepath === "") { + oid = result.oid; + } else { + const pathArray = filepath.split("/"); + oid = await _resolveFilepath({ + fs, + cache, + gitdir, + tree, + pathArray, + oid: _oid, + filepath + }); + } + return oid; +} +async function _resolveFilepath({ + fs, + cache, + gitdir, + tree, + pathArray, + oid, + filepath +}) { + const name = pathArray.shift(); + for (const entry of tree) { + if (entry.path === name) { + if (pathArray.length === 0) { + return entry.oid; + } else { + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid: entry.oid + }); + if (type !== "tree") { + throw new ObjectTypeError(oid, type, "blob", filepath); + } + tree = GitTree.from(object); + return _resolveFilepath({ + fs, + cache, + gitdir, + tree, + pathArray, + oid, + filepath + }); + } + } + } + throw new NotFoundError(`file or directory found at "${oid}:${filepath}"`); +} +async function _readTree({ + fs, + cache, + gitdir, + oid, + filepath = void 0 +}) { + if (filepath !== void 0) { + oid = await resolveFilepath({ fs, cache, gitdir, oid, filepath }); + } + const { tree, oid: treeOid } = await resolveTree({ fs, cache, gitdir, oid }); + const result = { + oid: treeOid, + tree: tree.entries() + }; + return result; +} +async function _writeTree({ fs, gitdir, tree }) { + const object = GitTree.from(tree).toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "tree", + object, + format: "content" + }); + return oid; +} +async function _addNote({ + fs, + cache, + onSign, + gitdir, + ref, + oid, + note, + force, + author, + committer, + signingKey +}) { + let parent; + try { + parent = await GitRefManager.resolve({ gitdir, fs, ref }); + } catch (err) { + if (!(err instanceof NotFoundError)) { + throw err; + } + } + const result = await _readTree({ + fs, + cache, + gitdir, + oid: parent || "4b825dc642cb6eb9a060e54bf8d69288fbee4904" + }); + let tree = result.tree; + if (force) { + tree = tree.filter((entry) => entry.path !== oid); + } else { + for (const entry of tree) { + if (entry.path === oid) { + throw new AlreadyExistsError("note", oid); + } + } + } + if (typeof note === "string") { + note = Buffer2.from(note, "utf8"); + } + const noteOid = await _writeObject({ + fs, + gitdir, + type: "blob", + object: note, + format: "content" + }); + tree.push({ mode: "100644", path: oid, oid: noteOid, type: "blob" }); + const treeOid = await _writeTree({ + fs, + gitdir, + tree + }); + const commitOid = await _commit({ + fs, + cache, + onSign, + gitdir, + ref, + tree: treeOid, + parent: parent && [parent], + message: `Note added by 'isomorphic-git addNote' +`, + author, + committer, + signingKey + }); + return commitOid; +} +async function _getConfig({ fs, gitdir, path: path2 }) { + const config = await GitConfigManager.get({ fs, gitdir }); + return config.get(path2); +} +async function normalizeAuthorObject({ fs, gitdir, author = {} }) { + let { name, email, timestamp, timezoneOffset } = author; + name = name || await _getConfig({ fs, gitdir, path: "user.name" }); + email = email || await _getConfig({ fs, gitdir, path: "user.email" }) || ""; + if (name === void 0) { + return void 0; + } + timestamp = timestamp != null ? timestamp : Math.floor(Date.now() / 1e3); + timezoneOffset = timezoneOffset != null ? timezoneOffset : new Date(timestamp * 1e3).getTimezoneOffset(); + return { name, email, timestamp, timezoneOffset }; +} +async function normalizeCommitterObject({ + fs, + gitdir, + author, + committer +}) { + committer = Object.assign({}, committer || author); + if (author) { + committer.timestamp = committer.timestamp || author.timestamp; + committer.timezoneOffset = committer.timezoneOffset || author.timezoneOffset; + } + committer = await normalizeAuthorObject({ fs, gitdir, author: committer }); + return committer; +} +async function addNote({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + oid, + note, + force, + author: _author, + committer: _committer, + signingKey, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + assertParameter("note", note); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _addNote({ + fs: new FileSystem(fs), + cache, + onSign, + gitdir, + ref, + oid, + note, + force, + author, + committer, + signingKey + }); + } catch (err) { + err.caller = "git.addNote"; + throw err; + } +} +async function _addRemote({ fs, gitdir, remote, url, force }) { + if (remote !== import_clean_git_ref.default.clean(remote)) { + throw new InvalidRefNameError(remote, import_clean_git_ref.default.clean(remote)); + } + const config = await GitConfigManager.get({ fs, gitdir }); + if (!force) { + const remoteNames = await config.getSubsections("remote"); + if (remoteNames.includes(remote)) { + if (url !== await config.get(`remote.${remote}.url`)) { + throw new AlreadyExistsError("remote", remote); + } + } + } + await config.set(`remote.${remote}.url`, url); + await config.set(`remote.${remote}.fetch`, `+refs/heads/*:refs/remotes/${remote}/*`); + await GitConfigManager.save({ fs, gitdir, config }); +} +async function addRemote({ + fs, + dir, + gitdir = join(dir, ".git"), + remote, + url, + force = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("remote", remote); + assertParameter("url", url); + return await _addRemote({ + fs: new FileSystem(fs), + gitdir, + remote, + url, + force + }); + } catch (err) { + err.caller = "git.addRemote"; + throw err; + } +} +async function _annotatedTag({ + fs, + cache, + onSign, + gitdir, + ref, + tagger, + message = ref, + gpgsig, + object, + signingKey, + force = false +}) { + ref = ref.startsWith("refs/tags/") ? ref : `refs/tags/${ref}`; + if (!force && await GitRefManager.exists({ fs, gitdir, ref })) { + throw new AlreadyExistsError("tag", ref); + } + const oid = await GitRefManager.resolve({ + fs, + gitdir, + ref: object || "HEAD" + }); + const { type } = await _readObject({ fs, cache, gitdir, oid }); + let tagObject = GitAnnotatedTag.from({ + object: oid, + type, + tag: ref.replace("refs/tags/", ""), + tagger, + message, + gpgsig + }); + if (signingKey) { + tagObject = await GitAnnotatedTag.sign(tagObject, onSign, signingKey); + } + const value = await _writeObject({ + fs, + gitdir, + type: "tag", + object: tagObject.toObject() + }); + await GitRefManager.writeRef({ fs, gitdir, ref, value }); +} +async function annotatedTag({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ref, + tagger: _tagger, + message = ref, + gpgsig, + object, + signingKey, + force = false, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const tagger = await normalizeAuthorObject({ fs, gitdir, author: _tagger }); + if (!tagger) + throw new MissingNameError("tagger"); + return await _annotatedTag({ + fs, + cache, + onSign, + gitdir, + ref, + tagger, + message, + gpgsig, + object, + signingKey, + force + }); + } catch (err) { + err.caller = "git.annotatedTag"; + throw err; + } +} +async function _branch({ + fs, + gitdir, + ref, + object, + checkout: checkout2 = false, + force = false +}) { + if (ref !== import_clean_git_ref.default.clean(ref)) { + throw new InvalidRefNameError(ref, import_clean_git_ref.default.clean(ref)); + } + const fullref = `refs/heads/${ref}`; + if (!force) { + const exist = await GitRefManager.exists({ fs, gitdir, ref: fullref }); + if (exist) { + throw new AlreadyExistsError("branch", ref, false); + } + } + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref: object || "HEAD" }); + } catch (e) { + } + if (oid) { + await GitRefManager.writeRef({ fs, gitdir, ref: fullref, value: oid }); + } + if (checkout2) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref: "HEAD", + value: fullref + }); + } +} +async function branch({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + object, + checkout: checkout2 = false, + force = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await _branch({ + fs: new FileSystem(fs), + gitdir, + ref, + object, + checkout: checkout2, + force + }); + } catch (err) { + err.caller = "git.branch"; + throw err; + } +} +function arrayRange(start, end) { + const length = end - start; + return Array.from({ length }, (_, i) => start + i); +} +var flat = typeof Array.prototype.flat === "undefined" ? (entries) => entries.reduce((acc, x) => acc.concat(x), []) : (entries) => entries.flat(); +var RunningMinimum = class { + constructor() { + this.value = null; + } + consider(value) { + if (value === null || value === void 0) + return; + if (this.value === null) { + this.value = value; + } else if (value < this.value) { + this.value = value; + } + } + reset() { + this.value = null; + } +}; +function* unionOfIterators(sets) { + const min = new RunningMinimum(); + let minimum; + const heads = []; + const numsets = sets.length; + for (let i = 0; i < numsets; i++) { + heads[i] = sets[i].next().value; + if (heads[i] !== void 0) { + min.consider(heads[i]); + } + } + if (min.value === null) + return; + while (true) { + const result = []; + minimum = min.value; + min.reset(); + for (let i = 0; i < numsets; i++) { + if (heads[i] !== void 0 && heads[i] === minimum) { + result[i] = heads[i]; + heads[i] = sets[i].next().value; + } else { + result[i] = null; + } + if (heads[i] !== void 0) { + min.consider(heads[i]); + } + } + yield result; + if (min.value === null) + return; + } +} +async function _walk({ + fs, + cache, + dir, + gitdir, + trees, + map = async (_, entry) => entry, + reduce = async (parent, children2) => { + const flatten = flat(children2); + if (parent !== void 0) + flatten.unshift(parent); + return flatten; + }, + iterate = (walk2, children2) => Promise.all([...children2].map(walk2)) +}) { + const walkers = trees.map((proxy) => proxy[GitWalkSymbol]({ fs, dir, gitdir, cache })); + const root = new Array(walkers.length).fill("."); + const range = arrayRange(0, walkers.length); + const unionWalkerFromReaddir = async (entries) => { + range.map((i) => { + entries[i] = entries[i] && new walkers[i].ConstructEntry(entries[i]); + }); + const subdirs = await Promise.all(range.map((i) => entries[i] ? walkers[i].readdir(entries[i]) : [])); + const iterators = subdirs.map((array) => array === null ? [] : array).map((array) => array[Symbol.iterator]()); + return { + entries, + children: unionOfIterators(iterators) + }; + }; + const walk2 = async (root2) => { + const { entries, children: children2 } = await unionWalkerFromReaddir(root2); + const fullpath = entries.find((entry) => entry && entry._fullpath)._fullpath; + const parent = await map(fullpath, entries); + if (parent !== null) { + let walkedChildren = await iterate(walk2, children2); + walkedChildren = walkedChildren.filter((x) => x !== void 0); + return reduce(parent, walkedChildren); + } + }; + return walk2(root); +} +var worthWalking = (filepath, root) => { + if (filepath === "." || root == null || root.length === 0 || root === ".") { + return true; + } + if (root.length >= filepath.length) { + return root.startsWith(filepath); + } else { + return filepath.startsWith(root); + } +}; +async function _checkout({ + fs, + cache, + onProgress, + dir, + gitdir, + remote, + ref, + filepaths, + noCheckout, + noUpdateHead, + dryRun, + force, + track = true +}) { + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref }); + } catch (err) { + if (ref === "HEAD") + throw err; + const remoteRef = `${remote}/${ref}`; + oid = await GitRefManager.resolve({ + fs, + gitdir, + ref: remoteRef + }); + if (track) { + const config = await GitConfigManager.get({ fs, gitdir }); + await config.set(`branch.${ref}.remote`, remote); + await config.set(`branch.${ref}.merge`, `refs/heads/${ref}`); + await GitConfigManager.save({ fs, gitdir, config }); + } + await GitRefManager.writeRef({ + fs, + gitdir, + ref: `refs/heads/${ref}`, + value: oid + }); + } + if (!noCheckout) { + let ops; + try { + ops = await analyze({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + force, + filepaths + }); + } catch (err) { + if (err instanceof NotFoundError && err.data.what === oid) { + throw new CommitNotFetchedError(ref, oid); + } else { + throw err; + } + } + const conflicts2 = ops.filter(([method]) => method === "conflict").map(([method, fullpath]) => fullpath); + if (conflicts2.length > 0) { + throw new CheckoutConflictError(conflicts2); + } + const errors = ops.filter(([method]) => method === "error").map(([method, fullpath]) => fullpath); + if (errors.length > 0) { + throw new InternalError(errors.join(", ")); + } + if (dryRun) { + return; + } + let count = 0; + const total = ops.length; + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + await Promise.all(ops.filter(([method]) => method === "delete" || method === "delete-index").map(async function([method, fullpath]) { + const filepath = `${dir}/${fullpath}`; + if (method === "delete") { + await fs.rm(filepath); + } + index2.delete({ filepath: fullpath }); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + })); + }); + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + for (const [method, fullpath] of ops) { + if (method === "rmdir" || method === "rmdir-index") { + const filepath = `${dir}/${fullpath}`; + try { + if (method === "rmdir-index") { + index2.delete({ filepath: fullpath }); + } + await fs.rmdir(filepath); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + } catch (e) { + if (e.code === "ENOTEMPTY") { + console.log(`Did not delete ${fullpath} because directory is not empty`); + } else { + throw e; + } + } + } + } + }); + await Promise.all(ops.filter(([method]) => method === "mkdir" || method === "mkdir-index").map(async function([_, fullpath]) { + const filepath = `${dir}/${fullpath}`; + await fs.mkdir(filepath); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + })); + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + await Promise.all(ops.filter(([method]) => method === "create" || method === "create-index" || method === "update" || method === "mkdir-index").map(async function([method, fullpath, oid2, mode, chmod]) { + const filepath = `${dir}/${fullpath}`; + try { + if (method !== "create-index" && method !== "mkdir-index") { + const { object } = await _readObject({ fs, cache, gitdir, oid: oid2 }); + if (chmod) { + await fs.rm(filepath); + } + if (mode === 33188) { + await fs.write(filepath, object); + } else if (mode === 33261) { + await fs.write(filepath, object, { mode: 511 }); + } else if (mode === 40960) { + await fs.writelink(filepath, object); + } else { + throw new InternalError(`Invalid mode 0o${mode.toString(8)} detected in blob ${oid2}`); + } + } + const stats = await fs.lstat(filepath); + if (mode === 33261) { + stats.mode = 493; + } + if (method === "mkdir-index") { + stats.mode = 57344; + } + index2.insert({ + filepath: fullpath, + stats, + oid: oid2 + }); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + } catch (e) { + console.log(e); + } + })); + }); + } + if (!noUpdateHead) { + const fullRef = await GitRefManager.expand({ fs, gitdir, ref }); + if (fullRef.startsWith("refs/heads")) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref: "HEAD", + value: fullRef + }); + } else { + await GitRefManager.writeRef({ fs, gitdir, ref: "HEAD", value: oid }); + } + } +} +async function analyze({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + force, + filepaths +}) { + let count = 0; + return _walk({ + fs, + cache, + dir, + gitdir, + trees: [TREE({ ref }), WORKDIR(), STAGE()], + map: async function(fullpath, [commit2, workdir, stage]) { + if (fullpath === ".") + return; + if (filepaths && !filepaths.some((base) => worthWalking(fullpath, base))) { + return null; + } + if (onProgress) { + await onProgress({ phase: "Analyzing workdir", loaded: ++count }); + } + const key2 = [!!stage, !!commit2, !!workdir].map(Number).join(""); + switch (key2) { + case "000": + return; + case "001": + if (force && filepaths && filepaths.includes(fullpath)) { + return ["delete", fullpath]; + } + return; + case "010": { + switch (await commit2.type()) { + case "tree": { + return ["mkdir", fullpath]; + } + case "blob": { + return [ + "create", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + case "commit": { + return [ + "mkdir-index", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + default: { + return [ + "error", + `new entry Unhandled type ${await commit2.type()}` + ]; + } + } + } + case "011": { + switch (`${await commit2.type()}-${await workdir.type()}`) { + case "tree-tree": { + return; + } + case "tree-blob": + case "blob-tree": { + return ["conflict", fullpath]; + } + case "blob-blob": { + if (await commit2.oid() !== await workdir.oid()) { + if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + await commit2.mode() !== await workdir.mode() + ]; + } else { + return ["conflict", fullpath]; + } + } else { + if (await commit2.mode() !== await workdir.mode()) { + if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + true + ]; + } else { + return ["conflict", fullpath]; + } + } else { + return [ + "create-index", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + } + } + case "commit-tree": { + return; + } + case "commit-blob": { + return ["conflict", fullpath]; + } + default: { + return ["error", `new entry Unhandled type ${commit2.type}`]; + } + } + } + case "100": { + return ["delete-index", fullpath]; + } + case "101": { + switch (await stage.type()) { + case "tree": { + return ["rmdir", fullpath]; + } + case "blob": { + if (await stage.oid() !== await workdir.oid()) { + if (force) { + return ["delete", fullpath]; + } else { + return ["conflict", fullpath]; + } + } else { + return ["delete", fullpath]; + } + } + case "commit": { + return ["rmdir-index", fullpath]; + } + default: { + return [ + "error", + `delete entry Unhandled type ${await stage.type()}` + ]; + } + } + } + case "110": + case "111": { + switch (`${await stage.type()}-${await commit2.type()}`) { + case "tree-tree": { + return; + } + case "blob-blob": { + if (await stage.oid() === await commit2.oid() && await stage.mode() === await commit2.mode() && !force) { + return; + } + if (workdir) { + if (await workdir.oid() !== await stage.oid() && await workdir.oid() !== await commit2.oid()) { + if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + await commit2.mode() !== await workdir.mode() + ]; + } else { + return ["conflict", fullpath]; + } + } + } else if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + await commit2.mode() !== await stage.mode() + ]; + } + if (await commit2.mode() !== await stage.mode()) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + true + ]; + } + if (await commit2.oid() !== await stage.oid()) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + false + ]; + } else { + return; + } + } + case "tree-blob": { + return ["update-dir-to-blob", fullpath, await commit2.oid()]; + } + case "blob-tree": { + return ["update-blob-to-tree", fullpath]; + } + case "commit-commit": { + return [ + "mkdir-index", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + default: { + return [ + "error", + `update entry Unhandled type ${await stage.type()}-${await commit2.type()}` + ]; + } + } + } + } + }, + reduce: async function(parent, children2) { + children2 = flat(children2); + if (!parent) { + return children2; + } else if (parent && parent[0] === "rmdir") { + children2.push(parent); + return children2; + } else { + children2.unshift(parent); + return children2; + } + } + }); +} +async function checkout({ + fs, + onProgress, + dir, + gitdir = join(dir, ".git"), + remote = "origin", + ref: _ref, + filepaths, + noCheckout = false, + noUpdateHead = _ref === void 0, + dryRun = false, + force = false, + track = true, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + const ref = _ref || "HEAD"; + return await _checkout({ + fs: new FileSystem(fs), + cache, + onProgress, + dir, + gitdir, + remote, + ref, + filepaths, + noCheckout, + noUpdateHead, + dryRun, + force, + track + }); + } catch (err) { + err.caller = "git.checkout"; + throw err; + } +} +var abbreviateRx = new RegExp("^refs/(heads/|tags/|remotes/)?(.*)"); +function abbreviateRef(ref) { + const match = abbreviateRx.exec(ref); + if (match) { + if (match[1] === "remotes/" && ref.endsWith("/HEAD")) { + return match[2].slice(0, -5); + } else { + return match[2]; + } + } + return ref; +} +async function _currentBranch({ + fs, + gitdir, + fullname = false, + test = false +}) { + const ref = await GitRefManager.resolve({ + fs, + gitdir, + ref: "HEAD", + depth: 2 + }); + if (test) { + try { + await GitRefManager.resolve({ fs, gitdir, ref }); + } catch (_) { + return; + } + } + if (!ref.startsWith("refs/")) + return; + return fullname ? ref : abbreviateRef(ref); +} +function translateSSHtoHTTP(url) { + url = url.replace(/^git@([^:]+):/, "https://$1/"); + url = url.replace(/^ssh:\/\//, "https://"); + return url; +} +function calculateBasicAuthHeader({ username = "", password = "" }) { + return `Basic ${Buffer2.from(`${username}:${password}`).toString("base64")}`; +} +async function forAwait(iterable, cb) { + const iter = getIterator(iterable); + while (true) { + const { value, done } = await iter.next(); + if (value) + await cb(value); + if (done) + break; + } + if (iter.return) + iter.return(); +} +async function collect(iterable) { + let size = 0; + const buffers = []; + await forAwait(iterable, (value) => { + buffers.push(value); + size += value.byteLength; + }); + const result = new Uint8Array(size); + let nextIndex = 0; + for (const buffer2 of buffers) { + result.set(buffer2, nextIndex); + nextIndex += buffer2.byteLength; + } + return result; +} +function extractAuthFromUrl(url) { + let userpass = url.match(/^https?:\/\/([^/]+)@/); + if (userpass == null) + return { url, auth: {} }; + userpass = userpass[1]; + const [username, password] = userpass.split(":"); + url = url.replace(`${userpass}@`, ""); + return { url, auth: { username, password } }; +} +function padHex(b, n) { + const s = n.toString(16); + return "0".repeat(b - s.length) + s; +} +var GitPktLine = class { + static flush() { + return Buffer2.from("0000", "utf8"); + } + static delim() { + return Buffer2.from("0001", "utf8"); + } + static encode(line) { + if (typeof line === "string") { + line = Buffer2.from(line); + } + const length = line.length + 4; + const hexlength = padHex(4, length); + return Buffer2.concat([Buffer2.from(hexlength, "utf8"), line]); + } + static streamReader(stream) { + const reader = new StreamReader(stream); + return async function read() { + try { + let length = await reader.read(4); + if (length == null) + return true; + length = parseInt(length.toString("utf8"), 16); + if (length === 0) + return null; + if (length === 1) + return null; + const buffer2 = await reader.read(length - 4); + if (buffer2 == null) + return true; + return buffer2; + } catch (err) { + console.log("error", err); + return true; + } + }; + } +}; +async function parseCapabilitiesV2(read) { + const capabilities2 = {}; + let line; + while (true) { + line = await read(); + if (line === true) + break; + if (line === null) + continue; + line = line.toString("utf8").replace(/\n$/, ""); + const i = line.indexOf("="); + if (i > -1) { + const key2 = line.slice(0, i); + const value = line.slice(i + 1); + capabilities2[key2] = value; + } else { + capabilities2[line] = true; + } + } + return { protocolVersion: 2, capabilities2 }; +} +async function parseRefsAdResponse(stream, { service }) { + const capabilities = new Set(); + const refs = new Map(); + const symrefs = new Map(); + const read = GitPktLine.streamReader(stream); + let lineOne = await read(); + while (lineOne === null) + lineOne = await read(); + if (lineOne === true) + throw new EmptyServerResponseError(); + if (lineOne.includes("version 2")) { + return parseCapabilitiesV2(read); + } + if (lineOne.toString("utf8").replace(/\n$/, "") !== `# service=${service}`) { + throw new ParseError(`# service=${service}\\n`, lineOne.toString("utf8")); + } + let lineTwo = await read(); + while (lineTwo === null) + lineTwo = await read(); + if (lineTwo === true) + return { capabilities, refs, symrefs }; + lineTwo = lineTwo.toString("utf8"); + if (lineTwo.includes("version 2")) { + return parseCapabilitiesV2(read); + } + const [firstRef, capabilitiesLine] = splitAndAssert(lineTwo, "\0", "\\x00"); + capabilitiesLine.split(" ").map((x) => capabilities.add(x)); + const [ref, name] = splitAndAssert(firstRef, " ", " "); + refs.set(name, ref); + while (true) { + const line = await read(); + if (line === true) + break; + if (line !== null) { + const [ref2, name2] = splitAndAssert(line.toString("utf8"), " ", " "); + refs.set(name2, ref2); + } + } + for (const cap of capabilities) { + if (cap.startsWith("symref=")) { + const m = cap.match(/symref=([^:]+):(.*)/); + if (m.length === 3) { + symrefs.set(m[1], m[2]); + } + } + } + return { protocolVersion: 1, capabilities, refs, symrefs }; +} +function splitAndAssert(line, sep2, expected) { + const split = line.trim().split(sep2); + if (split.length !== 2) { + throw new ParseError(`Two strings separated by '${expected}'`, line.toString("utf8")); + } + return split; +} +var corsProxify = (corsProxy, url) => corsProxy.endsWith("?") ? `${corsProxy}${url}` : `${corsProxy}/${url.replace(/^https?:\/\//, "")}`; +var updateHeaders = (headers, auth) => { + if (auth.username || auth.password) { + headers.Authorization = calculateBasicAuthHeader(auth); + } + if (auth.headers) { + Object.assign(headers, auth.headers); + } +}; +var stringifyBody = async (res) => { + try { + const data = Buffer2.from(await collect(res.body)); + const response = data.toString("utf8"); + const preview = response.length < 256 ? response : response.slice(0, 256) + "..."; + return { preview, response, data }; + } catch (e) { + return {}; + } +}; +var GitRemoteHTTP = class { + static async capabilities() { + return ["discover", "connect"]; + } + static async discover({ + http, + onProgress, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service, + url: _origUrl, + headers, + protocolVersion + }) { + let { url, auth } = extractAuthFromUrl(_origUrl); + const proxifiedURL = corsProxy ? corsProxify(corsProxy, url) : url; + if (auth.username || auth.password) { + headers.Authorization = calculateBasicAuthHeader(auth); + } + if (protocolVersion === 2) { + headers["Git-Protocol"] = "version=2"; + } + let res; + let tryAgain; + let providedAuthBefore = false; + do { + res = await http.request({ + onProgress, + method: "GET", + url: `${proxifiedURL}/info/refs?service=${service}`, + headers + }); + tryAgain = false; + if (res.statusCode === 401 || res.statusCode === 203) { + const getAuth = providedAuthBefore ? onAuthFailure : onAuth; + if (getAuth) { + auth = await getAuth(url, { + ...auth, + headers: { ...headers } + }); + if (auth && auth.cancel) { + throw new UserCanceledError(); + } else if (auth) { + updateHeaders(headers, auth); + providedAuthBefore = true; + tryAgain = true; + } + } + } else if (res.statusCode === 200 && providedAuthBefore && onAuthSuccess) { + await onAuthSuccess(url, auth); + } + } while (tryAgain); + if (res.statusCode !== 200) { + const { response } = await stringifyBody(res); + throw new HttpError(res.statusCode, res.statusMessage, response); + } + if (res.headers["content-type"] === `application/x-${service}-advertisement`) { + const remoteHTTP = await parseRefsAdResponse(res.body, { service }); + remoteHTTP.auth = auth; + return remoteHTTP; + } else { + const { preview, response, data } = await stringifyBody(res); + try { + const remoteHTTP = await parseRefsAdResponse([data], { service }); + remoteHTTP.auth = auth; + return remoteHTTP; + } catch (e) { + throw new SmartHttpError(preview, response); + } + } + } + static async connect({ + http, + onProgress, + corsProxy, + service, + url, + auth, + body, + headers + }) { + const urlAuth = extractAuthFromUrl(url); + if (urlAuth) + url = urlAuth.url; + if (corsProxy) + url = corsProxify(corsProxy, url); + headers["content-type"] = `application/x-${service}-request`; + headers.accept = `application/x-${service}-result`; + updateHeaders(headers, auth); + const res = await http.request({ + onProgress, + method: "POST", + url: `${url}/${service}`, + body, + headers + }); + if (res.statusCode !== 200) { + const { response } = stringifyBody(res); + throw new HttpError(res.statusCode, res.statusMessage, response); + } + return res; + } +}; +function parseRemoteUrl({ url }) { + if (url.startsWith("git@")) { + return { + transport: "ssh", + address: url + }; + } + const matches = url.match(/(\w+)(:\/\/|::)(.*)/); + if (matches === null) + return; + if (matches[2] === "://") { + return { + transport: matches[1], + address: matches[0] + }; + } + if (matches[2] === "::") { + return { + transport: matches[1], + address: matches[3] + }; + } +} +var GitRemoteManager = class { + static getRemoteHelperFor({ url }) { + const remoteHelpers = new Map(); + remoteHelpers.set("http", GitRemoteHTTP); + remoteHelpers.set("https", GitRemoteHTTP); + const parts = parseRemoteUrl({ url }); + if (!parts) { + throw new UrlParseError(url); + } + if (remoteHelpers.has(parts.transport)) { + return remoteHelpers.get(parts.transport); + } + throw new UnknownTransportError(url, parts.transport, parts.transport === "ssh" ? translateSSHtoHTTP(url) : void 0); + } +}; +var lock$1 = null; +var GitShallowManager = class { + static async read({ fs, gitdir }) { + if (lock$1 === null) + lock$1 = new import_async_lock.default(); + const filepath = join(gitdir, "shallow"); + const oids = new Set(); + await lock$1.acquire(filepath, async function() { + const text2 = await fs.read(filepath, { encoding: "utf8" }); + if (text2 === null) + return oids; + if (text2.trim() === "") + return oids; + text2.trim().split("\n").map((oid) => oids.add(oid)); + }); + return oids; + } + static async write({ fs, gitdir, oids }) { + if (lock$1 === null) + lock$1 = new import_async_lock.default(); + const filepath = join(gitdir, "shallow"); + if (oids.size > 0) { + const text2 = [...oids].join("\n") + "\n"; + await lock$1.acquire(filepath, async function() { + await fs.write(filepath, text2, { + encoding: "utf8" + }); + }); + } else { + await lock$1.acquire(filepath, async function() { + await fs.rm(filepath); + }); + } + } +}; +async function hasObjectLoose({ fs, gitdir, oid }) { + const source = `objects/${oid.slice(0, 2)}/${oid.slice(2)}`; + return fs.exists(`${gitdir}/${source}`); +} +async function hasObjectPacked({ + fs, + cache, + gitdir, + oid, + getExternalRefDelta +}) { + let list = await fs.readdir(join(gitdir, "objects/pack")); + list = list.filter((x) => x.endsWith(".idx")); + for (const filename of list) { + const indexFile = `${gitdir}/objects/pack/${filename}`; + const p = await readPackIndex({ + fs, + cache, + filename: indexFile, + getExternalRefDelta + }); + if (p.error) + throw new InternalError(p.error); + if (p.offsets.has(oid)) { + return true; + } + } + return false; +} +async function hasObject({ + fs, + cache, + gitdir, + oid, + format = "content" +}) { + const getExternalRefDelta = (oid2) => _readObject({ fs, cache, gitdir, oid: oid2 }); + let result = await hasObjectLoose({ fs, gitdir, oid }); + if (!result) { + result = await hasObjectPacked({ + fs, + cache, + gitdir, + oid, + getExternalRefDelta + }); + } + return result; +} +function emptyPackfile(pack) { + const pheader = "5041434b"; + const version2 = "00000002"; + const obCount = "00000000"; + const header = pheader + version2 + obCount; + return pack.slice(0, 12).toString("hex") === header; +} +function filterCapabilities(server, client) { + const serverNames = server.map((cap) => cap.split("=", 1)[0]); + return client.filter((cap) => { + const name = cap.split("=", 1)[0]; + return serverNames.includes(name); + }); +} +var pkg = { + name: "isomorphic-git", + version: "1.21.0", + agent: "git/isomorphic-git@1.21.0" +}; +var FIFO = class { + constructor() { + this._queue = []; + } + write(chunk) { + if (this._ended) { + throw Error("You cannot write to a FIFO that has already been ended!"); + } + if (this._waiting) { + const resolve = this._waiting; + this._waiting = null; + resolve({ value: chunk }); + } else { + this._queue.push(chunk); + } + } + end() { + this._ended = true; + if (this._waiting) { + const resolve = this._waiting; + this._waiting = null; + resolve({ done: true }); + } + } + destroy(err) { + this._ended = true; + this.error = err; + } + async next() { + if (this._queue.length > 0) { + return { value: this._queue.shift() }; + } + if (this._ended) { + return { done: true }; + } + if (this._waiting) { + throw Error("You cannot call read until the previous call to read has returned!"); + } + return new Promise((resolve) => { + this._waiting = resolve; + }); + } +}; +function findSplit(str) { + const r = str.indexOf("\r"); + const n = str.indexOf("\n"); + if (r === -1 && n === -1) + return -1; + if (r === -1) + return n + 1; + if (n === -1) + return r + 1; + if (n === r + 1) + return n + 1; + return Math.min(r, n) + 1; +} +function splitLines(input) { + const output = new FIFO(); + let tmp = ""; + (async () => { + await forAwait(input, (chunk) => { + chunk = chunk.toString("utf8"); + tmp += chunk; + while (true) { + const i = findSplit(tmp); + if (i === -1) + break; + output.write(tmp.slice(0, i)); + tmp = tmp.slice(i); + } + }); + if (tmp.length > 0) { + output.write(tmp); + } + output.end(); + })(); + return output; +} +var GitSideBand = class { + static demux(input) { + const read = GitPktLine.streamReader(input); + const packetlines = new FIFO(); + const packfile = new FIFO(); + const progress = new FIFO(); + const nextBit = async function() { + const line = await read(); + if (line === null) + return nextBit(); + if (line === true) { + packetlines.end(); + progress.end(); + packfile.end(); + return; + } + switch (line[0]) { + case 1: { + packfile.write(line.slice(1)); + break; + } + case 2: { + progress.write(line.slice(1)); + break; + } + case 3: { + const error = line.slice(1); + progress.write(error); + packfile.destroy(new Error(error.toString("utf8"))); + return; + } + default: { + packetlines.write(line.slice(0)); + } + } + nextBit(); + }; + nextBit(); + return { + packetlines, + packfile, + progress + }; + } +}; +async function parseUploadPackResponse(stream) { + const { packetlines, packfile, progress } = GitSideBand.demux(stream); + const shallows = []; + const unshallows = []; + const acks = []; + let nak = false; + let done = false; + return new Promise((resolve, reject) => { + forAwait(packetlines, (data) => { + const line = data.toString("utf8").trim(); + if (line.startsWith("shallow")) { + const oid = line.slice(-41).trim(); + if (oid.length !== 40) { + reject(new InvalidOidError(oid)); + } + shallows.push(oid); + } else if (line.startsWith("unshallow")) { + const oid = line.slice(-41).trim(); + if (oid.length !== 40) { + reject(new InvalidOidError(oid)); + } + unshallows.push(oid); + } else if (line.startsWith("ACK")) { + const [, oid, status2] = line.split(" "); + acks.push({ oid, status: status2 }); + if (!status2) + done = true; + } else if (line.startsWith("NAK")) { + nak = true; + done = true; + } + if (done) { + resolve({ shallows, unshallows, acks, nak, packfile, progress }); + } + }); + }); +} +function writeUploadPackRequest({ + capabilities = [], + wants = [], + haves = [], + shallows = [], + depth = null, + since = null, + exclude = [] +}) { + const packstream = []; + wants = [...new Set(wants)]; + let firstLineCapabilities = ` ${capabilities.join(" ")}`; + for (const oid of wants) { + packstream.push(GitPktLine.encode(`want ${oid}${firstLineCapabilities} +`)); + firstLineCapabilities = ""; + } + for (const oid of shallows) { + packstream.push(GitPktLine.encode(`shallow ${oid} +`)); + } + if (depth !== null) { + packstream.push(GitPktLine.encode(`deepen ${depth} +`)); + } + if (since !== null) { + packstream.push(GitPktLine.encode(`deepen-since ${Math.floor(since.valueOf() / 1e3)} +`)); + } + for (const oid of exclude) { + packstream.push(GitPktLine.encode(`deepen-not ${oid} +`)); + } + packstream.push(GitPktLine.flush()); + for (const oid of haves) { + packstream.push(GitPktLine.encode(`have ${oid} +`)); + } + packstream.push(GitPktLine.encode(`done +`)); + return packstream; +} +async function _fetch({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref: _ref, + remoteRef: _remoteRef, + remote: _remote, + url: _url, + corsProxy, + depth = null, + since = null, + exclude = [], + relative = false, + tags = false, + singleBranch = false, + headers = {}, + prune = false, + pruneTags = false +}) { + const ref = _ref || await _currentBranch({ fs, gitdir, test: true }); + const config = await GitConfigManager.get({ fs, gitdir }); + const remote = _remote || ref && await config.get(`branch.${ref}.remote`) || "origin"; + const url = _url || await config.get(`remote.${remote}.url`); + if (typeof url === "undefined") { + throw new MissingParameterError("remote OR url"); + } + const remoteRef = _remoteRef || ref && await config.get(`branch.${ref}.merge`) || _ref || "HEAD"; + if (corsProxy === void 0) { + corsProxy = await config.get("http.corsProxy"); + } + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const remoteHTTP = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: "git-upload-pack", + url, + headers, + protocolVersion: 1 + }); + const auth = remoteHTTP.auth; + const remoteRefs = remoteHTTP.refs; + if (remoteRefs.size === 0) { + return { + defaultBranch: null, + fetchHead: null, + fetchHeadDescription: null + }; + } + if (depth !== null && !remoteHTTP.capabilities.has("shallow")) { + throw new RemoteCapabilityError("shallow", "depth"); + } + if (since !== null && !remoteHTTP.capabilities.has("deepen-since")) { + throw new RemoteCapabilityError("deepen-since", "since"); + } + if (exclude.length > 0 && !remoteHTTP.capabilities.has("deepen-not")) { + throw new RemoteCapabilityError("deepen-not", "exclude"); + } + if (relative === true && !remoteHTTP.capabilities.has("deepen-relative")) { + throw new RemoteCapabilityError("deepen-relative", "relative"); + } + const { oid, fullref } = GitRefManager.resolveAgainstMap({ + ref: remoteRef, + map: remoteRefs + }); + for (const remoteRef2 of remoteRefs.keys()) { + if (remoteRef2 === fullref || remoteRef2 === "HEAD" || remoteRef2.startsWith("refs/heads/") || tags && remoteRef2.startsWith("refs/tags/")) { + continue; + } + remoteRefs.delete(remoteRef2); + } + const capabilities = filterCapabilities([...remoteHTTP.capabilities], [ + "multi_ack_detailed", + "no-done", + "side-band-64k", + "ofs-delta", + `agent=${pkg.agent}` + ]); + if (relative) + capabilities.push("deepen-relative"); + const wants = singleBranch ? [oid] : remoteRefs.values(); + const haveRefs = singleBranch ? [ref] : await GitRefManager.listRefs({ + fs, + gitdir, + filepath: `refs` + }); + let haves = []; + for (let ref2 of haveRefs) { + try { + ref2 = await GitRefManager.expand({ fs, gitdir, ref: ref2 }); + const oid2 = await GitRefManager.resolve({ fs, gitdir, ref: ref2 }); + if (await hasObject({ fs, cache, gitdir, oid: oid2 })) { + haves.push(oid2); + } + } catch (err) { + } + } + haves = [...new Set(haves)]; + const oids = await GitShallowManager.read({ fs, gitdir }); + const shallows = remoteHTTP.capabilities.has("shallow") ? [...oids] : []; + const packstream = writeUploadPackRequest({ + capabilities, + wants, + haves, + shallows, + depth, + since, + exclude + }); + const packbuffer = Buffer2.from(await collect(packstream)); + const raw = await GitRemoteHTTP2.connect({ + http, + onProgress, + corsProxy, + service: "git-upload-pack", + url, + auth, + body: [packbuffer], + headers + }); + const response = await parseUploadPackResponse(raw.body); + if (raw.headers) { + response.headers = raw.headers; + } + for (const oid2 of response.shallows) { + if (!oids.has(oid2)) { + try { + const { object } = await _readObject({ fs, cache, gitdir, oid: oid2 }); + const commit2 = new GitCommit(object); + const hasParents = await Promise.all(commit2.headers().parent.map((oid3) => hasObject({ fs, cache, gitdir, oid: oid3 }))); + const haveAllParents = hasParents.length === 0 || hasParents.every((has) => has); + if (!haveAllParents) { + oids.add(oid2); + } + } catch (err) { + oids.add(oid2); + } + } + } + for (const oid2 of response.unshallows) { + oids.delete(oid2); + } + await GitShallowManager.write({ fs, gitdir, oids }); + if (singleBranch) { + const refs = new Map([[fullref, oid]]); + const symrefs = new Map(); + let bail = 10; + let key2 = fullref; + while (bail--) { + const value = remoteHTTP.symrefs.get(key2); + if (value === void 0) + break; + symrefs.set(key2, value); + key2 = value; + } + const realRef = remoteRefs.get(key2); + if (realRef) { + refs.set(key2, realRef); + } + const { pruned } = await GitRefManager.updateRemoteRefs({ + fs, + gitdir, + remote, + refs, + symrefs, + tags, + prune + }); + if (prune) { + response.pruned = pruned; + } + } else { + const { pruned } = await GitRefManager.updateRemoteRefs({ + fs, + gitdir, + remote, + refs: remoteRefs, + symrefs: remoteHTTP.symrefs, + tags, + prune, + pruneTags + }); + if (prune) { + response.pruned = pruned; + } + } + response.HEAD = remoteHTTP.symrefs.get("HEAD"); + if (response.HEAD === void 0) { + const { oid: oid2 } = GitRefManager.resolveAgainstMap({ + ref: "HEAD", + map: remoteRefs + }); + for (const [key2, value] of remoteRefs.entries()) { + if (key2 !== "HEAD" && value === oid2) { + response.HEAD = key2; + break; + } + } + } + const noun = fullref.startsWith("refs/tags") ? "tag" : "branch"; + response.FETCH_HEAD = { + oid, + description: `${noun} '${abbreviateRef(fullref)}' of ${url}` + }; + if (onProgress || onMessage) { + const lines = splitLines(response.progress); + forAwait(lines, async (line) => { + if (onMessage) + await onMessage(line); + if (onProgress) { + const matches = line.match(/([^:]*).*\((\d+?)\/(\d+?)\)/); + if (matches) { + await onProgress({ + phase: matches[1].trim(), + loaded: parseInt(matches[2], 10), + total: parseInt(matches[3], 10) + }); + } + } + }); + } + const packfile = Buffer2.from(await collect(response.packfile)); + const packfileSha = packfile.slice(-20).toString("hex"); + const res = { + defaultBranch: response.HEAD, + fetchHead: response.FETCH_HEAD.oid, + fetchHeadDescription: response.FETCH_HEAD.description + }; + if (response.headers) { + res.headers = response.headers; + } + if (prune) { + res.pruned = response.pruned; + } + if (packfileSha !== "" && !emptyPackfile(packfile)) { + res.packfile = `objects/pack/pack-${packfileSha}.pack`; + const fullpath = join(gitdir, res.packfile); + await fs.write(fullpath, packfile); + const getExternalRefDelta = (oid2) => _readObject({ fs, cache, gitdir, oid: oid2 }); + const idx = await GitPackIndex.fromPack({ + pack: packfile, + getExternalRefDelta, + onProgress + }); + await fs.write(fullpath.replace(/\.pack$/, ".idx"), await idx.toBuffer()); + } + return res; +} +async function _init({ + fs, + bare = false, + dir, + gitdir = bare ? dir : join(dir, ".git"), + defaultBranch = "master" +}) { + if (await fs.exists(gitdir + "/config")) + return; + let folders = [ + "hooks", + "info", + "objects/info", + "objects/pack", + "refs/heads", + "refs/tags" + ]; + folders = folders.map((dir2) => gitdir + "/" + dir2); + for (const folder of folders) { + await fs.mkdir(folder); + } + await fs.write(gitdir + "/config", `[core] + repositoryformatversion = 0 + filemode = false + bare = ${bare} +` + (bare ? "" : " logallrefupdates = true\n") + " symlinks = false\n ignorecase = true\n"); + await fs.write(gitdir + "/HEAD", `ref: refs/heads/${defaultBranch} +`); +} +async function _clone({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + url, + corsProxy, + ref, + remote, + depth, + since, + exclude, + relative, + singleBranch, + noCheckout, + noTags, + headers +}) { + try { + await _init({ fs, gitdir }); + await _addRemote({ fs, gitdir, remote, url, force: false }); + if (corsProxy) { + const config = await GitConfigManager.get({ fs, gitdir }); + await config.set(`http.corsProxy`, corsProxy); + await GitConfigManager.save({ fs, gitdir, config }); + } + const { defaultBranch, fetchHead } = await _fetch({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref, + remote, + corsProxy, + depth, + since, + exclude, + relative, + singleBranch, + headers, + tags: !noTags + }); + if (fetchHead === null) + return; + ref = ref || defaultBranch; + ref = ref.replace("refs/heads/", ""); + await _checkout({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + remote, + noCheckout + }); + } catch (err) { + await fs.rmdir(gitdir, { recursive: true, maxRetries: 10 }).catch(() => void 0); + throw err; + } +} +async function clone({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + url, + corsProxy = void 0, + ref = void 0, + remote = "origin", + depth = void 0, + since = void 0, + exclude = [], + relative = false, + singleBranch = false, + noCheckout = false, + noTags = false, + headers = {}, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + if (!noCheckout) { + assertParameter("dir", dir); + } + assertParameter("url", url); + return await _clone({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + url, + corsProxy, + ref, + remote, + depth, + since, + exclude, + relative, + singleBranch, + noCheckout, + noTags, + headers + }); + } catch (err) { + err.caller = "git.clone"; + throw err; + } +} +async function commit({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + message, + author: _author, + committer: _committer, + signingKey, + dryRun = false, + noUpdateBranch = false, + ref, + parent, + tree, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("message", message); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _commit({ + fs, + cache, + onSign, + gitdir, + message, + author, + committer, + signingKey, + dryRun, + noUpdateBranch, + ref, + parent, + tree + }); + } catch (err) { + err.caller = "git.commit"; + throw err; + } +} +async function currentBranch({ + fs, + dir, + gitdir = join(dir, ".git"), + fullname = false, + test = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return await _currentBranch({ + fs: new FileSystem(fs), + gitdir, + fullname, + test + }); + } catch (err) { + err.caller = "git.currentBranch"; + throw err; + } +} +async function _deleteBranch({ fs, gitdir, ref }) { + const exist = await GitRefManager.exists({ fs, gitdir, ref }); + if (!exist) { + throw new NotFoundError(ref); + } + const fullRef = await GitRefManager.expand({ fs, gitdir, ref }); + const currentRef = await _currentBranch({ fs, gitdir, fullname: true }); + if (fullRef === currentRef) { + const value = await GitRefManager.resolve({ fs, gitdir, ref: fullRef }); + await GitRefManager.writeRef({ fs, gitdir, ref: "HEAD", value }); + } + await GitRefManager.deleteRef({ fs, gitdir, ref: fullRef }); +} +async function deleteBranch({ + fs, + dir, + gitdir = join(dir, ".git"), + ref +}) { + try { + assertParameter("fs", fs); + assertParameter("ref", ref); + return await _deleteBranch({ + fs: new FileSystem(fs), + gitdir, + ref + }); + } catch (err) { + err.caller = "git.deleteBranch"; + throw err; + } +} +async function deleteRef({ fs, dir, gitdir = join(dir, ".git"), ref }) { + try { + assertParameter("fs", fs); + assertParameter("ref", ref); + await GitRefManager.deleteRef({ fs: new FileSystem(fs), gitdir, ref }); + } catch (err) { + err.caller = "git.deleteRef"; + throw err; + } +} +async function _deleteRemote({ fs, gitdir, remote }) { + const config = await GitConfigManager.get({ fs, gitdir }); + await config.deleteSection("remote", remote); + await GitConfigManager.save({ fs, gitdir, config }); +} +async function deleteRemote({ + fs, + dir, + gitdir = join(dir, ".git"), + remote +}) { + try { + assertParameter("fs", fs); + assertParameter("remote", remote); + return await _deleteRemote({ + fs: new FileSystem(fs), + gitdir, + remote + }); + } catch (err) { + err.caller = "git.deleteRemote"; + throw err; + } +} +async function _deleteTag({ fs, gitdir, ref }) { + ref = ref.startsWith("refs/tags/") ? ref : `refs/tags/${ref}`; + await GitRefManager.deleteRef({ fs, gitdir, ref }); +} +async function deleteTag({ fs, dir, gitdir = join(dir, ".git"), ref }) { + try { + assertParameter("fs", fs); + assertParameter("ref", ref); + return await _deleteTag({ + fs: new FileSystem(fs), + gitdir, + ref + }); + } catch (err) { + err.caller = "git.deleteTag"; + throw err; + } +} +async function expandOidLoose({ fs, gitdir, oid: short }) { + const prefix = short.slice(0, 2); + const objectsSuffixes = await fs.readdir(`${gitdir}/objects/${prefix}`); + return objectsSuffixes.map((suffix) => `${prefix}${suffix}`).filter((_oid) => _oid.startsWith(short)); +} +async function expandOidPacked({ + fs, + cache, + gitdir, + oid: short, + getExternalRefDelta +}) { + const results = []; + let list = await fs.readdir(join(gitdir, "objects/pack")); + list = list.filter((x) => x.endsWith(".idx")); + for (const filename of list) { + const indexFile = `${gitdir}/objects/pack/${filename}`; + const p = await readPackIndex({ + fs, + cache, + filename: indexFile, + getExternalRefDelta + }); + if (p.error) + throw new InternalError(p.error); + for (const oid of p.offsets.keys()) { + if (oid.startsWith(short)) + results.push(oid); + } + } + return results; +} +async function _expandOid({ fs, cache, gitdir, oid: short }) { + const getExternalRefDelta = (oid) => _readObject({ fs, cache, gitdir, oid }); + const results1 = await expandOidLoose({ fs, gitdir, oid: short }); + const results2 = await expandOidPacked({ + fs, + cache, + gitdir, + oid: short, + getExternalRefDelta + }); + const results = results1.concat(results2); + if (results.length === 1) { + return results[0]; + } + if (results.length > 1) { + throw new AmbiguousError("oids", short, results); + } + throw new NotFoundError(`an object matching "${short}"`); +} +async function expandOid({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _expandOid({ + fs: new FileSystem(fs), + cache, + gitdir, + oid + }); + } catch (err) { + err.caller = "git.expandOid"; + throw err; + } +} +async function expandRef({ fs, dir, gitdir = join(dir, ".git"), ref }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await GitRefManager.expand({ + fs: new FileSystem(fs), + gitdir, + ref + }); + } catch (err) { + err.caller = "git.expandRef"; + throw err; + } +} +async function _findMergeBase({ fs, cache, gitdir, oids }) { + const visits = {}; + const passes = oids.length; + let heads = oids.map((oid, index2) => ({ index: index2, oid })); + while (heads.length) { + const result = new Set(); + for (const { oid, index: index2 } of heads) { + if (!visits[oid]) + visits[oid] = new Set(); + visits[oid].add(index2); + if (visits[oid].size === passes) { + result.add(oid); + } + } + if (result.size > 0) { + return [...result]; + } + const newheads = new Map(); + for (const { oid, index: index2 } of heads) { + try { + const { object } = await _readObject({ fs, cache, gitdir, oid }); + const commit2 = GitCommit.from(object); + const { parent } = commit2.parseHeaders(); + for (const oid2 of parent) { + if (!visits[oid2] || !visits[oid2].has(index2)) { + newheads.set(oid2 + ":" + index2, { oid: oid2, index: index2 }); + } + } + } catch (err) { + } + } + heads = Array.from(newheads.values()); + } + return []; +} +var LINEBREAKS = /^.*(\r?\n|$)/gm; +function mergeFile({ branches, contents }) { + const ourName = branches[1]; + const theirName = branches[2]; + const baseContent = contents[0]; + const ourContent = contents[1]; + const theirContent = contents[2]; + const ours = ourContent.match(LINEBREAKS); + const base = baseContent.match(LINEBREAKS); + const theirs = theirContent.match(LINEBREAKS); + const result = (0, import_diff3.default)(ours, base, theirs); + const markerSize = 7; + let mergedText = ""; + let cleanMerge = true; + for (const item of result) { + if (item.ok) { + mergedText += item.ok.join(""); + } + if (item.conflict) { + cleanMerge = false; + mergedText += `${"<".repeat(markerSize)} ${ourName} +`; + mergedText += item.conflict.a.join(""); + mergedText += `${"=".repeat(markerSize)} +`; + mergedText += item.conflict.b.join(""); + mergedText += `${">".repeat(markerSize)} ${theirName} +`; + } + } + return { cleanMerge, mergedText }; +} +async function mergeTree({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + ourOid, + baseOid, + theirOid, + ourName = "ours", + baseName = "base", + theirName = "theirs", + dryRun = false, + abortOnConflict = true, + mergeDriver +}) { + const ourTree = TREE({ ref: ourOid }); + const baseTree = TREE({ ref: baseOid }); + const theirTree = TREE({ ref: theirOid }); + const unmergedFiles = []; + let cleanMerge = true; + const results = await _walk({ + fs, + cache, + dir, + gitdir, + trees: [ourTree, baseTree, theirTree], + map: async function(filepath, [ours, base, theirs]) { + const path2 = basename(filepath); + const ourChange = await modified(ours, base); + const theirChange = await modified(theirs, base); + switch (`${ourChange}-${theirChange}`) { + case "false-false": { + return { + mode: await base.mode(), + path: path2, + oid: await base.oid(), + type: await base.type() + }; + } + case "false-true": { + return theirs ? { + mode: await theirs.mode(), + path: path2, + oid: await theirs.oid(), + type: await theirs.type() + } : void 0; + } + case "true-false": { + return ours ? { + mode: await ours.mode(), + path: path2, + oid: await ours.oid(), + type: await ours.type() + } : void 0; + } + case "true-true": { + if (ours && base && theirs && await ours.type() === "blob" && await base.type() === "blob" && await theirs.type() === "blob") { + return mergeBlobs({ + fs, + gitdir, + path: path2, + ours, + base, + theirs, + ourName, + baseName, + theirName, + mergeDriver + }).then((r) => { + cleanMerge = cleanMerge && r.cleanMerge; + unmergedFiles.push(filepath); + return r.mergeResult; + }); + } + throw new MergeNotSupportedError(); + } + } + }, + reduce: async (parent, children2) => { + const entries = children2.filter(Boolean); + if (!parent) + return; + if (parent && parent.type === "tree" && entries.length === 0) + return; + if (entries.length > 0) { + const tree = new GitTree(entries); + const object = tree.toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "tree", + object, + dryRun + }); + parent.oid = oid; + } + return parent; + } + }); + if (!cleanMerge) { + if (dir && !abortOnConflict) { + await _walk({ + fs, + cache, + dir, + gitdir, + trees: [TREE({ ref: results.oid })], + map: async function(filepath, [entry]) { + const path2 = `${dir}/${filepath}`; + if (await entry.type() === "blob") { + const mode = await entry.mode(); + const content = new TextDecoder().decode(await entry.content()); + await fs.write(path2, content, { mode }); + } + return true; + } + }); + } + throw new MergeConflictError(unmergedFiles); + } + return results.oid; +} +async function modified(entry, base) { + if (!entry && !base) + return false; + if (entry && !base) + return true; + if (!entry && base) + return true; + if (await entry.type() === "tree" && await base.type() === "tree") { + return false; + } + if (await entry.type() === await base.type() && await entry.mode() === await base.mode() && await entry.oid() === await base.oid()) { + return false; + } + return true; +} +async function mergeBlobs({ + fs, + gitdir, + path: path2, + ours, + base, + theirs, + ourName, + theirName, + baseName, + dryRun, + mergeDriver = mergeFile +}) { + const type = "blob"; + const mode = await base.mode() === await ours.mode() ? await theirs.mode() : await ours.mode(); + if (await ours.oid() === await theirs.oid()) { + return { + cleanMerge: true, + mergeResult: { mode, path: path2, oid: await ours.oid(), type } + }; + } + if (await ours.oid() === await base.oid()) { + return { + cleanMerge: true, + mergeResult: { mode, path: path2, oid: await theirs.oid(), type } + }; + } + if (await theirs.oid() === await base.oid()) { + return { + cleanMerge: true, + mergeResult: { mode, path: path2, oid: await ours.oid(), type } + }; + } + const ourContent = Buffer2.from(await ours.content()).toString("utf8"); + const baseContent = Buffer2.from(await base.content()).toString("utf8"); + const theirContent = Buffer2.from(await theirs.content()).toString("utf8"); + const { mergedText, cleanMerge } = await mergeDriver({ + branches: [baseName, ourName, theirName], + contents: [baseContent, ourContent, theirContent], + path: path2 + }); + const oid = await _writeObject({ + fs, + gitdir, + type: "blob", + object: Buffer2.from(mergedText, "utf8"), + dryRun + }); + return { cleanMerge, mergeResult: { mode, path: path2, oid, type } }; +} +async function _merge({ + fs, + cache, + dir, + gitdir, + ours, + theirs, + fastForward: fastForward2 = true, + fastForwardOnly = false, + dryRun = false, + noUpdateBranch = false, + abortOnConflict = true, + message, + author, + committer, + signingKey, + onSign, + mergeDriver +}) { + if (ours === void 0) { + ours = await _currentBranch({ fs, gitdir, fullname: true }); + } + ours = await GitRefManager.expand({ + fs, + gitdir, + ref: ours + }); + theirs = await GitRefManager.expand({ + fs, + gitdir, + ref: theirs + }); + const ourOid = await GitRefManager.resolve({ + fs, + gitdir, + ref: ours + }); + const theirOid = await GitRefManager.resolve({ + fs, + gitdir, + ref: theirs + }); + const baseOids = await _findMergeBase({ + fs, + cache, + gitdir, + oids: [ourOid, theirOid] + }); + if (baseOids.length !== 1) { + throw new MergeNotSupportedError(); + } + const baseOid = baseOids[0]; + if (baseOid === theirOid) { + return { + oid: ourOid, + alreadyMerged: true + }; + } + if (fastForward2 && baseOid === ourOid) { + if (!dryRun && !noUpdateBranch) { + await GitRefManager.writeRef({ fs, gitdir, ref: ours, value: theirOid }); + } + return { + oid: theirOid, + fastForward: true + }; + } else { + if (fastForwardOnly) { + throw new FastForwardError(); + } + const tree = await mergeTree({ + fs, + cache, + dir, + gitdir, + ourOid, + theirOid, + baseOid, + ourName: abbreviateRef(ours), + baseName: "base", + theirName: abbreviateRef(theirs), + dryRun, + abortOnConflict, + mergeDriver + }); + if (!message) { + message = `Merge branch '${abbreviateRef(theirs)}' into ${abbreviateRef(ours)}`; + } + const oid = await _commit({ + fs, + cache, + gitdir, + message, + ref: ours, + tree, + parent: [ourOid, theirOid], + author, + committer, + signingKey, + onSign, + dryRun, + noUpdateBranch + }); + return { + oid, + tree, + mergeCommit: true + }; + } +} +async function _pull({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + ref, + url, + remote, + remoteRef, + prune, + pruneTags, + fastForward: fastForward2, + fastForwardOnly, + corsProxy, + singleBranch, + headers, + author, + committer, + signingKey +}) { + try { + if (!ref) { + const head = await _currentBranch({ fs, gitdir }); + if (!head) { + throw new MissingParameterError("ref"); + } + ref = head; + } + const { fetchHead, fetchHeadDescription } = await _fetch({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + corsProxy, + ref, + url, + remote, + remoteRef, + singleBranch, + headers, + prune, + pruneTags + }); + await _merge({ + fs, + cache, + gitdir, + ours: ref, + theirs: fetchHead, + fastForward: fastForward2, + fastForwardOnly, + message: `Merge ${fetchHeadDescription}`, + author, + committer, + signingKey, + dryRun: false, + noUpdateBranch: false + }); + await _checkout({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + remote, + noCheckout: false + }); + } catch (err) { + err.caller = "git.pull"; + throw err; + } +} +async function fastForward({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + url, + remote, + remoteRef, + corsProxy, + singleBranch, + headers = {}, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + const thisWillNotBeUsed = { + name: "", + email: "", + timestamp: Date.now(), + timezoneOffset: 0 + }; + return await _pull({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + ref, + url, + remote, + remoteRef, + fastForwardOnly: true, + corsProxy, + singleBranch, + headers, + author: thisWillNotBeUsed, + committer: thisWillNotBeUsed + }); + } catch (err) { + err.caller = "git.fastForward"; + throw err; + } +} +async function fetch({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + remote, + remoteRef, + url, + corsProxy, + depth = null, + since = null, + exclude = [], + relative = false, + tags = false, + singleBranch = false, + headers = {}, + prune = false, + pruneTags = false, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + return await _fetch({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref, + remote, + remoteRef, + url, + corsProxy, + depth, + since, + exclude, + relative, + tags, + singleBranch, + headers, + prune, + pruneTags + }); + } catch (err) { + err.caller = "git.fetch"; + throw err; + } +} +async function findMergeBase({ + fs, + dir, + gitdir = join(dir, ".git"), + oids, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oids", oids); + return await _findMergeBase({ + fs: new FileSystem(fs), + cache, + gitdir, + oids + }); + } catch (err) { + err.caller = "git.findMergeBase"; + throw err; + } +} +async function _findRoot({ fs, filepath }) { + if (await fs.exists(join(filepath, ".git"))) { + return filepath; + } else { + const parent = dirname(filepath); + if (parent === filepath) { + throw new NotFoundError(`git root for ${filepath}`); + } + return _findRoot({ fs, filepath: parent }); + } +} +async function findRoot({ fs, filepath }) { + try { + assertParameter("fs", fs); + assertParameter("filepath", filepath); + return await _findRoot({ fs: new FileSystem(fs), filepath }); + } catch (err) { + err.caller = "git.findRoot"; + throw err; + } +} +async function getConfig({ fs, dir, gitdir = join(dir, ".git"), path: path2 }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("path", path2); + return await _getConfig({ + fs: new FileSystem(fs), + gitdir, + path: path2 + }); + } catch (err) { + err.caller = "git.getConfig"; + throw err; + } +} +async function _getConfigAll({ fs, gitdir, path: path2 }) { + const config = await GitConfigManager.get({ fs, gitdir }); + return config.getall(path2); +} +async function getConfigAll({ + fs, + dir, + gitdir = join(dir, ".git"), + path: path2 +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("path", path2); + return await _getConfigAll({ + fs: new FileSystem(fs), + gitdir, + path: path2 + }); + } catch (err) { + err.caller = "git.getConfigAll"; + throw err; + } +} +async function getRemoteInfo({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + url, + headers = {}, + forPush = false +}) { + try { + assertParameter("http", http); + assertParameter("url", url); + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const remote = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + headers, + protocolVersion: 1 + }); + const result = { + capabilities: [...remote.capabilities] + }; + for (const [ref, oid] of remote.refs) { + const parts = ref.split("/"); + const last2 = parts.pop(); + let o = result; + for (const part of parts) { + o[part] = o[part] || {}; + o = o[part]; + } + o[last2] = oid; + } + for (const [symref, ref] of remote.symrefs) { + const parts = symref.split("/"); + const last2 = parts.pop(); + let o = result; + for (const part of parts) { + o[part] = o[part] || {}; + o = o[part]; + } + o[last2] = ref; + } + return result; + } catch (err) { + err.caller = "git.getRemoteInfo"; + throw err; + } +} +function formatInfoRefs(remote, prefix, symrefs, peelTags) { + const refs = []; + for (const [key2, value] of remote.refs) { + if (prefix && !key2.startsWith(prefix)) + continue; + if (key2.endsWith("^{}")) { + if (peelTags) { + const _key = key2.replace("^{}", ""); + const last2 = refs[refs.length - 1]; + const r = last2.ref === _key ? last2 : refs.find((x) => x.ref === _key); + if (r === void 0) { + throw new Error("I did not expect this to happen"); + } + r.peeled = value; + } + continue; + } + const ref = { ref: key2, oid: value }; + if (symrefs) { + if (remote.symrefs.has(key2)) { + ref.target = remote.symrefs.get(key2); + } + } + refs.push(ref); + } + return refs; +} +async function getRemoteInfo2({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + url, + headers = {}, + forPush = false, + protocolVersion = 2 +}) { + try { + assertParameter("http", http); + assertParameter("url", url); + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const remote = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + headers, + protocolVersion + }); + if (remote.protocolVersion === 2) { + return { + protocolVersion: remote.protocolVersion, + capabilities: remote.capabilities2 + }; + } + const capabilities = {}; + for (const cap of remote.capabilities) { + const [key2, value] = cap.split("="); + if (value) { + capabilities[key2] = value; + } else { + capabilities[key2] = true; + } + } + return { + protocolVersion: 1, + capabilities, + refs: formatInfoRefs(remote, void 0, true, true) + }; + } catch (err) { + err.caller = "git.getRemoteInfo2"; + throw err; + } +} +async function hashObject({ + type, + object, + format = "content", + oid = void 0 +}) { + if (format !== "deflated") { + if (format !== "wrapped") { + object = GitObject.wrap({ type, object }); + } + oid = await shasum(object); + } + return { oid, object }; +} +async function hashBlob({ object }) { + try { + assertParameter("object", object); + if (typeof object === "string") { + object = Buffer2.from(object, "utf8"); + } else { + object = Buffer2.from(object); + } + const type = "blob"; + const { oid, object: _object } = await hashObject({ + type: "blob", + format: "content", + object + }); + return { oid, type, object: new Uint8Array(_object), format: "wrapped" }; + } catch (err) { + err.caller = "git.hashBlob"; + throw err; + } +} +async function _indexPack({ + fs, + cache, + onProgress, + dir, + gitdir, + filepath +}) { + try { + filepath = join(dir, filepath); + const pack = await fs.read(filepath); + const getExternalRefDelta = (oid) => _readObject({ fs, cache, gitdir, oid }); + const idx = await GitPackIndex.fromPack({ + pack, + getExternalRefDelta, + onProgress + }); + await fs.write(filepath.replace(/\.pack$/, ".idx"), await idx.toBuffer()); + return { + oids: [...idx.hashes] + }; + } catch (err) { + err.caller = "git.indexPack"; + throw err; + } +} +async function indexPack({ + fs, + onProgress, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("dir", dir); + assertParameter("gitdir", dir); + assertParameter("filepath", filepath); + return await _indexPack({ + fs: new FileSystem(fs), + cache, + onProgress, + dir, + gitdir, + filepath + }); + } catch (err) { + err.caller = "git.indexPack"; + throw err; + } +} +async function init({ + fs, + bare = false, + dir, + gitdir = bare ? dir : join(dir, ".git"), + defaultBranch = "master" +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + if (!bare) { + assertParameter("dir", dir); + } + return await _init({ + fs: new FileSystem(fs), + bare, + dir, + gitdir, + defaultBranch + }); + } catch (err) { + err.caller = "git.init"; + throw err; + } +} +async function _isDescendent({ + fs, + cache, + gitdir, + oid, + ancestor, + depth +}) { + const shallows = await GitShallowManager.read({ fs, gitdir }); + if (!oid) { + throw new MissingParameterError("oid"); + } + if (!ancestor) { + throw new MissingParameterError("ancestor"); + } + if (oid === ancestor) + return false; + const queue = [oid]; + const visited = new Set(); + let searchdepth = 0; + while (queue.length) { + if (searchdepth++ === depth) { + throw new MaxDepthError(depth); + } + const oid2 = queue.shift(); + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid: oid2 + }); + if (type !== "commit") { + throw new ObjectTypeError(oid2, type, "commit"); + } + const commit2 = GitCommit.from(object).parse(); + for (const parent of commit2.parent) { + if (parent === ancestor) + return true; + } + if (!shallows.has(oid2)) { + for (const parent of commit2.parent) { + if (!visited.has(parent)) { + queue.push(parent); + visited.add(parent); + } + } + } + } + return false; +} +async function isDescendent({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + ancestor, + depth = -1, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + assertParameter("ancestor", ancestor); + return await _isDescendent({ + fs: new FileSystem(fs), + cache, + gitdir, + oid, + ancestor, + depth + }); + } catch (err) { + err.caller = "git.isDescendent"; + throw err; + } +} +async function isIgnored({ + fs, + dir, + gitdir = join(dir, ".git"), + filepath +}) { + try { + assertParameter("fs", fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + return GitIgnoreManager.isIgnored({ + fs: new FileSystem(fs), + dir, + gitdir, + filepath + }); + } catch (err) { + err.caller = "git.isIgnored"; + throw err; + } +} +async function listBranches({ + fs, + dir, + gitdir = join(dir, ".git"), + remote +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return GitRefManager.listBranches({ + fs: new FileSystem(fs), + gitdir, + remote + }); + } catch (err) { + err.caller = "git.listBranches"; + throw err; + } +} +async function _listFiles({ fs, gitdir, ref, cache }) { + if (ref) { + const oid = await GitRefManager.resolve({ gitdir, fs, ref }); + const filenames = []; + await accumulateFilesFromOid({ + fs, + cache, + gitdir, + oid, + filenames, + prefix: "" + }); + return filenames; + } else { + return GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + return index2.entries.map((x) => x.path); + }); + } +} +async function accumulateFilesFromOid({ + fs, + cache, + gitdir, + oid, + filenames, + prefix +}) { + const { tree } = await _readTree({ fs, cache, gitdir, oid }); + for (const entry of tree) { + if (entry.type === "tree") { + await accumulateFilesFromOid({ + fs, + cache, + gitdir, + oid: entry.oid, + filenames, + prefix: join(prefix, entry.path) + }); + } else { + filenames.push(join(prefix, entry.path)); + } + } +} +async function listFiles({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return await _listFiles({ + fs: new FileSystem(fs), + cache, + gitdir, + ref + }); + } catch (err) { + err.caller = "git.listFiles"; + throw err; + } +} +async function _listNotes({ fs, cache, gitdir, ref }) { + let parent; + try { + parent = await GitRefManager.resolve({ gitdir, fs, ref }); + } catch (err) { + if (err instanceof NotFoundError) { + return []; + } + } + const result = await _readTree({ + fs, + cache, + gitdir, + oid: parent + }); + const notes = result.tree.map((entry) => ({ + target: entry.path, + note: entry.oid + })); + return notes; +} +async function listNotes({ + fs, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await _listNotes({ + fs: new FileSystem(fs), + cache, + gitdir, + ref + }); + } catch (err) { + err.caller = "git.listNotes"; + throw err; + } +} +async function _listRemotes({ fs, gitdir }) { + const config = await GitConfigManager.get({ fs, gitdir }); + const remoteNames = await config.getSubsections("remote"); + const remotes = Promise.all(remoteNames.map(async (remote) => { + const url = await config.get(`remote.${remote}.url`); + return { remote, url }; + })); + return remotes; +} +async function listRemotes({ fs, dir, gitdir = join(dir, ".git") }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return await _listRemotes({ + fs: new FileSystem(fs), + gitdir + }); + } catch (err) { + err.caller = "git.listRemotes"; + throw err; + } +} +async function parseListRefsResponse(stream) { + const read = GitPktLine.streamReader(stream); + const refs = []; + let line; + while (true) { + line = await read(); + if (line === true) + break; + if (line === null) + continue; + line = line.toString("utf8").replace(/\n$/, ""); + const [oid, ref, ...attrs] = line.split(" "); + const r = { ref, oid }; + for (const attr2 of attrs) { + const [name, value] = attr2.split(":"); + if (name === "symref-target") { + r.target = value; + } else if (name === "peeled") { + r.peeled = value; + } + } + refs.push(r); + } + return refs; +} +async function writeListRefsRequest({ prefix, symrefs, peelTags }) { + const packstream = []; + packstream.push(GitPktLine.encode("command=ls-refs\n")); + packstream.push(GitPktLine.encode(`agent=${pkg.agent} +`)); + if (peelTags || symrefs || prefix) { + packstream.push(GitPktLine.delim()); + } + if (peelTags) + packstream.push(GitPktLine.encode("peel")); + if (symrefs) + packstream.push(GitPktLine.encode("symrefs")); + if (prefix) + packstream.push(GitPktLine.encode(`ref-prefix ${prefix}`)); + packstream.push(GitPktLine.flush()); + return packstream; +} +async function listServerRefs({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + url, + headers = {}, + forPush = false, + protocolVersion = 2, + prefix, + symrefs, + peelTags +}) { + try { + assertParameter("http", http); + assertParameter("url", url); + const remote = await GitRemoteHTTP.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + headers, + protocolVersion + }); + if (remote.protocolVersion === 1) { + return formatInfoRefs(remote, prefix, symrefs, peelTags); + } + const body = await writeListRefsRequest({ prefix, symrefs, peelTags }); + const res = await GitRemoteHTTP.connect({ + http, + auth: remote.auth, + headers, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + body + }); + return parseListRefsResponse(res.body); + } catch (err) { + err.caller = "git.listServerRefs"; + throw err; + } +} +async function listTags({ fs, dir, gitdir = join(dir, ".git") }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return GitRefManager.listTags({ fs: new FileSystem(fs), gitdir }); + } catch (err) { + err.caller = "git.listTags"; + throw err; + } +} +async function resolveCommit({ fs, cache, gitdir, oid }) { + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + oid = GitAnnotatedTag.from(object).parse().object; + return resolveCommit({ fs, cache, gitdir, oid }); + } + if (type !== "commit") { + throw new ObjectTypeError(oid, type, "commit"); + } + return { commit: GitCommit.from(object), oid }; +} +async function _readCommit({ fs, cache, gitdir, oid }) { + const { commit: commit2, oid: commitOid } = await resolveCommit({ + fs, + cache, + gitdir, + oid + }); + const result = { + oid: commitOid, + commit: commit2.parse(), + payload: commit2.withoutSignature() + }; + return result; +} +function compareAge(a, b) { + return a.committer.timestamp - b.committer.timestamp; +} +var EMPTY_OID = "e69de29bb2d1d6434b8b29ae775ad8c2e48c5391"; +async function resolveFileIdInTree({ fs, cache, gitdir, oid, fileId }) { + if (fileId === EMPTY_OID) + return; + const _oid = oid; + let filepath; + const result = await resolveTree({ fs, cache, gitdir, oid }); + const tree = result.tree; + if (fileId === result.oid) { + filepath = result.path; + } else { + filepath = await _resolveFileId({ + fs, + cache, + gitdir, + tree, + fileId, + oid: _oid + }); + if (Array.isArray(filepath)) { + if (filepath.length === 0) + filepath = void 0; + else if (filepath.length === 1) + filepath = filepath[0]; + } + } + return filepath; +} +async function _resolveFileId({ + fs, + cache, + gitdir, + tree, + fileId, + oid, + filepaths = [], + parentPath = "" +}) { + const walks = tree.entries().map(function(entry) { + let result; + if (entry.oid === fileId) { + result = join(parentPath, entry.path); + filepaths.push(result); + } else if (entry.type === "tree") { + result = _readObject({ + fs, + cache, + gitdir, + oid: entry.oid + }).then(function({ object }) { + return _resolveFileId({ + fs, + cache, + gitdir, + tree: GitTree.from(object), + fileId, + oid, + filepaths, + parentPath: join(parentPath, entry.path) + }); + }); + } + return result; + }); + await Promise.all(walks); + return filepaths; +} +async function _log({ + fs, + cache, + gitdir, + filepath, + ref, + depth, + since, + force, + follow +}) { + const sinceTimestamp = typeof since === "undefined" ? void 0 : Math.floor(since.valueOf() / 1e3); + const commits = []; + const shallowCommits = await GitShallowManager.read({ fs, gitdir }); + const oid = await GitRefManager.resolve({ fs, gitdir, ref }); + const tips = [await _readCommit({ fs, cache, gitdir, oid })]; + let lastFileOid; + let lastCommit; + let isOk; + function endCommit(commit2) { + if (isOk && filepath) + commits.push(commit2); + } + while (tips.length > 0) { + const commit2 = tips.pop(); + if (sinceTimestamp !== void 0 && commit2.commit.committer.timestamp <= sinceTimestamp) { + break; + } + if (filepath) { + let vFileOid; + try { + vFileOid = await resolveFilepath({ + fs, + cache, + gitdir, + oid: commit2.commit.tree, + filepath + }); + if (lastCommit && lastFileOid !== vFileOid) { + commits.push(lastCommit); + } + lastFileOid = vFileOid; + lastCommit = commit2; + isOk = true; + } catch (e) { + if (e instanceof NotFoundError) { + let found = follow && lastFileOid; + if (found) { + found = await resolveFileIdInTree({ + fs, + cache, + gitdir, + oid: commit2.commit.tree, + fileId: lastFileOid + }); + if (found) { + if (Array.isArray(found)) { + if (lastCommit) { + const lastFound = await resolveFileIdInTree({ + fs, + cache, + gitdir, + oid: lastCommit.commit.tree, + fileId: lastFileOid + }); + if (Array.isArray(lastFound)) { + found = found.filter((p) => lastFound.indexOf(p) === -1); + if (found.length === 1) { + found = found[0]; + filepath = found; + if (lastCommit) + commits.push(lastCommit); + } else { + found = false; + if (lastCommit) + commits.push(lastCommit); + break; + } + } + } + } else { + filepath = found; + if (lastCommit) + commits.push(lastCommit); + } + } + } + if (!found) { + if (isOk && lastFileOid) { + commits.push(lastCommit); + if (!force) + break; + } + if (!force && !follow) + throw e; + } + lastCommit = commit2; + isOk = false; + } else + throw e; + } + } else { + commits.push(commit2); + } + if (depth !== void 0 && commits.length === depth) { + endCommit(commit2); + break; + } + if (!shallowCommits.has(commit2.oid)) { + for (const oid2 of commit2.commit.parent) { + const commit3 = await _readCommit({ fs, cache, gitdir, oid: oid2 }); + if (!tips.map((commit4) => commit4.oid).includes(commit3.oid)) { + tips.push(commit3); + } + } + } + if (tips.length === 0) { + endCommit(commit2); + } + tips.sort((a, b) => compareAge(a.commit, b.commit)); + } + return commits; +} +async function log({ + fs, + dir, + gitdir = join(dir, ".git"), + filepath, + ref = "HEAD", + depth, + since, + force, + follow, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await _log({ + fs: new FileSystem(fs), + cache, + gitdir, + filepath, + ref, + depth, + since, + force, + follow + }); + } catch (err) { + err.caller = "git.log"; + throw err; + } +} +async function merge({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ours, + theirs, + fastForward: fastForward2 = true, + fastForwardOnly = false, + dryRun = false, + noUpdateBranch = false, + abortOnConflict = true, + message, + author: _author, + committer: _committer, + signingKey, + cache = {}, + mergeDriver +}) { + try { + assertParameter("fs", _fs); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author && (!fastForwardOnly || !fastForward2)) { + throw new MissingNameError("author"); + } + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer && (!fastForwardOnly || !fastForward2)) { + throw new MissingNameError("committer"); + } + return await _merge({ + fs, + cache, + dir, + gitdir, + ours, + theirs, + fastForward: fastForward2, + fastForwardOnly, + dryRun, + noUpdateBranch, + abortOnConflict, + message, + author, + committer, + signingKey, + onSign, + mergeDriver + }); + } catch (err) { + err.caller = "git.merge"; + throw err; + } +} +var types = { + commit: 16, + tree: 32, + blob: 48, + tag: 64, + ofs_delta: 96, + ref_delta: 112 +}; +async function _pack({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + oids +}) { + const hash2 = new import_sha1.default(); + const outputStream = []; + function write(chunk, enc) { + const buff = Buffer2.from(chunk, enc); + outputStream.push(buff); + hash2.update(buff); + } + async function writeObject2({ stype, object }) { + const type = types[stype]; + let length = object.length; + let multibyte = length > 15 ? 128 : 0; + const lastFour = length & 15; + length = length >>> 4; + let byte = (multibyte | type | lastFour).toString(16); + write(byte, "hex"); + while (multibyte) { + multibyte = length > 127 ? 128 : 0; + byte = multibyte | length & 127; + write(padHex(2, byte), "hex"); + length = length >>> 7; + } + write(Buffer2.from(await deflate(object))); + } + write("PACK"); + write("00000002", "hex"); + write(padHex(8, oids.length), "hex"); + for (const oid of oids) { + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + await writeObject2({ write, object, stype: type }); + } + const digest = hash2.digest(); + outputStream.push(digest); + return outputStream; +} +async function _packObjects({ fs, cache, gitdir, oids, write }) { + const buffers = await _pack({ fs, cache, gitdir, oids }); + const packfile = Buffer2.from(await collect(buffers)); + const packfileSha = packfile.slice(-20).toString("hex"); + const filename = `pack-${packfileSha}.pack`; + if (write) { + await fs.write(join(gitdir, `objects/pack/${filename}`), packfile); + return { filename }; + } + return { + filename, + packfile: new Uint8Array(packfile) + }; +} +async function packObjects({ + fs, + dir, + gitdir = join(dir, ".git"), + oids, + write = false, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oids", oids); + return await _packObjects({ + fs: new FileSystem(fs), + cache, + gitdir, + oids, + write + }); + } catch (err) { + err.caller = "git.packObjects"; + throw err; + } +} +async function pull({ + fs: _fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + url, + remote, + remoteRef, + prune = false, + pruneTags = false, + fastForward: fastForward2 = true, + fastForwardOnly = false, + corsProxy, + singleBranch, + headers = {}, + author: _author, + committer: _committer, + signingKey, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _pull({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + ref, + url, + remote, + remoteRef, + fastForward: fastForward2, + fastForwardOnly, + corsProxy, + singleBranch, + headers, + author, + committer, + signingKey, + prune, + pruneTags + }); + } catch (err) { + err.caller = "git.pull"; + throw err; + } +} +async function listCommitsAndTags({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + start, + finish +}) { + const shallows = await GitShallowManager.read({ fs, gitdir }); + const startingSet = new Set(); + const finishingSet = new Set(); + for (const ref of start) { + startingSet.add(await GitRefManager.resolve({ fs, gitdir, ref })); + } + for (const ref of finish) { + try { + const oid = await GitRefManager.resolve({ fs, gitdir, ref }); + finishingSet.add(oid); + } catch (err) { + } + } + const visited = new Set(); + async function walk2(oid) { + visited.add(oid); + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + const tag2 = GitAnnotatedTag.from(object); + const commit2 = tag2.headers().object; + return walk2(commit2); + } + if (type !== "commit") { + throw new ObjectTypeError(oid, type, "commit"); + } + if (!shallows.has(oid)) { + const commit2 = GitCommit.from(object); + const parents = commit2.headers().parent; + for (oid of parents) { + if (!finishingSet.has(oid) && !visited.has(oid)) { + await walk2(oid); + } + } + } + } + for (const oid of startingSet) { + await walk2(oid); + } + return visited; +} +async function listObjects({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + oids +}) { + const visited = new Set(); + async function walk2(oid) { + if (visited.has(oid)) + return; + visited.add(oid); + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + const tag2 = GitAnnotatedTag.from(object); + const obj = tag2.headers().object; + await walk2(obj); + } else if (type === "commit") { + const commit2 = GitCommit.from(object); + const tree = commit2.headers().tree; + await walk2(tree); + } else if (type === "tree") { + const tree = GitTree.from(object); + for (const entry of tree) { + if (entry.type === "blob") { + visited.add(entry.oid); + } + if (entry.type === "tree") { + await walk2(entry.oid); + } + } + } + } + for (const oid of oids) { + await walk2(oid); + } + return visited; +} +async function parseReceivePackResponse(packfile) { + const result = {}; + let response = ""; + const read = GitPktLine.streamReader(packfile); + let line = await read(); + while (line !== true) { + if (line !== null) + response += line.toString("utf8") + "\n"; + line = await read(); + } + const lines = response.toString("utf8").split("\n"); + line = lines.shift(); + if (!line.startsWith("unpack ")) { + throw new ParseError('unpack ok" or "unpack [error message]', line); + } + result.ok = line === "unpack ok"; + if (!result.ok) { + result.error = line.slice("unpack ".length); + } + result.refs = {}; + for (const line2 of lines) { + if (line2.trim() === "") + continue; + const status2 = line2.slice(0, 2); + const refAndMessage = line2.slice(3); + let space2 = refAndMessage.indexOf(" "); + if (space2 === -1) + space2 = refAndMessage.length; + const ref = refAndMessage.slice(0, space2); + const error = refAndMessage.slice(space2 + 1); + result.refs[ref] = { + ok: status2 === "ok", + error + }; + } + return result; +} +async function writeReceivePackRequest({ + capabilities = [], + triplets = [] +}) { + const packstream = []; + let capsFirstLine = `\0 ${capabilities.join(" ")}`; + for (const trip of triplets) { + packstream.push(GitPktLine.encode(`${trip.oldoid} ${trip.oid} ${trip.fullRef}${capsFirstLine} +`)); + capsFirstLine = ""; + } + packstream.push(GitPktLine.flush()); + return packstream; +} +async function _push({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref: _ref, + remoteRef: _remoteRef, + remote, + url: _url, + force = false, + delete: _delete = false, + corsProxy, + headers = {} +}) { + const ref = _ref || await _currentBranch({ fs, gitdir }); + if (typeof ref === "undefined") { + throw new MissingParameterError("ref"); + } + const config = await GitConfigManager.get({ fs, gitdir }); + remote = remote || await config.get(`branch.${ref}.pushRemote`) || await config.get("remote.pushDefault") || await config.get(`branch.${ref}.remote`) || "origin"; + const url = _url || await config.get(`remote.${remote}.pushurl`) || await config.get(`remote.${remote}.url`); + if (typeof url === "undefined") { + throw new MissingParameterError("remote OR url"); + } + const remoteRef = _remoteRef || await config.get(`branch.${ref}.merge`); + if (typeof url === "undefined") { + throw new MissingParameterError("remoteRef"); + } + if (corsProxy === void 0) { + corsProxy = await config.get("http.corsProxy"); + } + const fullRef = await GitRefManager.expand({ fs, gitdir, ref }); + const oid = _delete ? "0000000000000000000000000000000000000000" : await GitRefManager.resolve({ fs, gitdir, ref: fullRef }); + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const httpRemote = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: "git-receive-pack", + url, + headers, + protocolVersion: 1 + }); + const auth = httpRemote.auth; + let fullRemoteRef; + if (!remoteRef) { + fullRemoteRef = fullRef; + } else { + try { + fullRemoteRef = await GitRefManager.expandAgainstMap({ + ref: remoteRef, + map: httpRemote.refs + }); + } catch (err) { + if (err instanceof NotFoundError) { + fullRemoteRef = remoteRef.startsWith("refs/") ? remoteRef : `refs/heads/${remoteRef}`; + } else { + throw err; + } + } + } + const oldoid = httpRemote.refs.get(fullRemoteRef) || "0000000000000000000000000000000000000000"; + const thinPack = !httpRemote.capabilities.has("no-thin"); + let objects = new Set(); + if (!_delete) { + const finish = [...httpRemote.refs.values()]; + let skipObjects = new Set(); + if (oldoid !== "0000000000000000000000000000000000000000") { + const mergebase = await _findMergeBase({ + fs, + cache, + gitdir, + oids: [oid, oldoid] + }); + for (const oid2 of mergebase) + finish.push(oid2); + if (thinPack) { + skipObjects = await listObjects({ fs, cache, gitdir, oids: mergebase }); + } + } + if (!finish.includes(oid)) { + const commits = await listCommitsAndTags({ + fs, + cache, + gitdir, + start: [oid], + finish + }); + objects = await listObjects({ fs, cache, gitdir, oids: commits }); + } + if (thinPack) { + try { + const ref2 = await GitRefManager.resolve({ + fs, + gitdir, + ref: `refs/remotes/${remote}/HEAD`, + depth: 2 + }); + const { oid: oid2 } = await GitRefManager.resolveAgainstMap({ + ref: ref2.replace(`refs/remotes/${remote}/`, ""), + fullref: ref2, + map: httpRemote.refs + }); + const oids = [oid2]; + for (const oid3 of await listObjects({ fs, cache, gitdir, oids })) { + skipObjects.add(oid3); + } + } catch (e) { + } + for (const oid2 of skipObjects) { + objects.delete(oid2); + } + } + if (oid === oldoid) + force = true; + if (!force) { + if (fullRef.startsWith("refs/tags") && oldoid !== "0000000000000000000000000000000000000000") { + throw new PushRejectedError("tag-exists"); + } + if (oid !== "0000000000000000000000000000000000000000" && oldoid !== "0000000000000000000000000000000000000000" && !await _isDescendent({ + fs, + cache, + gitdir, + oid, + ancestor: oldoid, + depth: -1 + })) { + throw new PushRejectedError("not-fast-forward"); + } + } + } + const capabilities = filterCapabilities([...httpRemote.capabilities], ["report-status", "side-band-64k", `agent=${pkg.agent}`]); + const packstream1 = await writeReceivePackRequest({ + capabilities, + triplets: [{ oldoid, oid, fullRef: fullRemoteRef }] + }); + const packstream2 = _delete ? [] : await _pack({ + fs, + cache, + gitdir, + oids: [...objects] + }); + const res = await GitRemoteHTTP2.connect({ + http, + onProgress, + corsProxy, + service: "git-receive-pack", + url, + auth, + headers, + body: [...packstream1, ...packstream2] + }); + const { packfile, progress } = await GitSideBand.demux(res.body); + if (onMessage) { + const lines = splitLines(progress); + forAwait(lines, async (line) => { + await onMessage(line); + }); + } + const result = await parseReceivePackResponse(packfile); + if (res.headers) { + result.headers = res.headers; + } + if (remote && result.ok && result.refs[fullRemoteRef].ok) { + const ref2 = `refs/remotes/${remote}/${fullRemoteRef.replace("refs/heads", "")}`; + if (_delete) { + await GitRefManager.deleteRef({ fs, gitdir, ref: ref2 }); + } else { + await GitRefManager.writeRef({ fs, gitdir, ref: ref2, value: oid }); + } + } + if (result.ok && Object.values(result.refs).every((result2) => result2.ok)) { + return result; + } else { + const prettyDetails = Object.entries(result.refs).filter(([k, v]) => !v.ok).map(([k, v]) => ` + - ${k}: ${v.error}`).join(""); + throw new GitPushError(prettyDetails, result); + } +} +async function push({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + remoteRef, + remote = "origin", + url, + force = false, + delete: _delete = false, + corsProxy, + headers = {}, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + return await _push({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref, + remoteRef, + remote, + url, + force, + delete: _delete, + corsProxy, + headers + }); + } catch (err) { + err.caller = "git.push"; + throw err; + } +} +async function resolveBlob({ fs, cache, gitdir, oid }) { + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + oid = GitAnnotatedTag.from(object).parse().object; + return resolveBlob({ fs, cache, gitdir, oid }); + } + if (type !== "blob") { + throw new ObjectTypeError(oid, type, "blob"); + } + return { oid, blob: new Uint8Array(object) }; +} +async function _readBlob({ + fs, + cache, + gitdir, + oid, + filepath = void 0 +}) { + if (filepath !== void 0) { + oid = await resolveFilepath({ fs, cache, gitdir, oid, filepath }); + } + const blob = await resolveBlob({ + fs, + cache, + gitdir, + oid + }); + return blob; +} +async function readBlob({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + filepath, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readBlob({ + fs: new FileSystem(fs), + cache, + gitdir, + oid, + filepath + }); + } catch (err) { + err.caller = "git.readBlob"; + throw err; + } +} +async function readCommit({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readCommit({ + fs: new FileSystem(fs), + cache, + gitdir, + oid + }); + } catch (err) { + err.caller = "git.readCommit"; + throw err; + } +} +async function _readNote({ + fs, + cache, + gitdir, + ref = "refs/notes/commits", + oid +}) { + const parent = await GitRefManager.resolve({ gitdir, fs, ref }); + const { blob } = await _readBlob({ + fs, + cache, + gitdir, + oid: parent, + filepath: oid + }); + return blob; +} +async function readNote({ + fs, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + assertParameter("oid", oid); + return await _readNote({ + fs: new FileSystem(fs), + cache, + gitdir, + ref, + oid + }); + } catch (err) { + err.caller = "git.readNote"; + throw err; + } +} +async function readObject({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + oid, + format = "parsed", + filepath = void 0, + encoding = void 0, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + const fs = new FileSystem(_fs); + if (filepath !== void 0) { + oid = await resolveFilepath({ + fs, + cache, + gitdir, + oid, + filepath + }); + } + const _format = format === "parsed" ? "content" : format; + const result = await _readObject({ + fs, + cache, + gitdir, + oid, + format: _format + }); + result.oid = oid; + if (format === "parsed") { + result.format = "parsed"; + switch (result.type) { + case "commit": + result.object = GitCommit.from(result.object).parse(); + break; + case "tree": + result.object = GitTree.from(result.object).entries(); + break; + case "blob": + if (encoding) { + result.object = result.object.toString(encoding); + } else { + result.object = new Uint8Array(result.object); + result.format = "content"; + } + break; + case "tag": + result.object = GitAnnotatedTag.from(result.object).parse(); + break; + default: + throw new ObjectTypeError(result.oid, result.type, "blob|commit|tag|tree"); + } + } else if (result.format === "deflated" || result.format === "wrapped") { + result.type = result.format; + } + return result; + } catch (err) { + err.caller = "git.readObject"; + throw err; + } +} +async function _readTag({ fs, cache, gitdir, oid }) { + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid, + format: "content" + }); + if (type !== "tag") { + throw new ObjectTypeError(oid, type, "tag"); + } + const tag2 = GitAnnotatedTag.from(object); + const result = { + oid, + tag: tag2.parse(), + payload: tag2.payload() + }; + return result; +} +async function readTag({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readTag({ + fs: new FileSystem(fs), + cache, + gitdir, + oid + }); + } catch (err) { + err.caller = "git.readTag"; + throw err; + } +} +async function readTree({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + filepath = void 0, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readTree({ + fs: new FileSystem(fs), + cache, + gitdir, + oid, + filepath + }); + } catch (err) { + err.caller = "git.readTree"; + throw err; + } +} +async function remove({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + await GitIndexManager.acquire({ fs: new FileSystem(_fs), gitdir, cache }, async function(index2) { + index2.delete({ filepath }); + }); + } catch (err) { + err.caller = "git.remove"; + throw err; + } +} +async function _removeNote({ + fs, + cache, + onSign, + gitdir, + ref = "refs/notes/commits", + oid, + author, + committer, + signingKey +}) { + let parent; + try { + parent = await GitRefManager.resolve({ gitdir, fs, ref }); + } catch (err) { + if (!(err instanceof NotFoundError)) { + throw err; + } + } + const result = await _readTree({ + fs, + gitdir, + oid: parent || "4b825dc642cb6eb9a060e54bf8d69288fbee4904" + }); + let tree = result.tree; + tree = tree.filter((entry) => entry.path !== oid); + const treeOid = await _writeTree({ + fs, + gitdir, + tree + }); + const commitOid = await _commit({ + fs, + cache, + onSign, + gitdir, + ref, + tree: treeOid, + parent: parent && [parent], + message: `Note removed by 'isomorphic-git removeNote' +`, + author, + committer, + signingKey + }); + return commitOid; +} +async function removeNote({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + oid, + author: _author, + committer: _committer, + signingKey, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _removeNote({ + fs, + cache, + onSign, + gitdir, + ref, + oid, + author, + committer, + signingKey + }); + } catch (err) { + err.caller = "git.removeNote"; + throw err; + } +} +async function _renameBranch({ + fs, + gitdir, + oldref, + ref, + checkout: checkout2 = false +}) { + if (ref !== import_clean_git_ref.default.clean(ref)) { + throw new InvalidRefNameError(ref, import_clean_git_ref.default.clean(ref)); + } + if (oldref !== import_clean_git_ref.default.clean(oldref)) { + throw new InvalidRefNameError(oldref, import_clean_git_ref.default.clean(oldref)); + } + const fulloldref = `refs/heads/${oldref}`; + const fullnewref = `refs/heads/${ref}`; + const newexist = await GitRefManager.exists({ fs, gitdir, ref: fullnewref }); + if (newexist) { + throw new AlreadyExistsError("branch", ref, false); + } + const value = await GitRefManager.resolve({ + fs, + gitdir, + ref: fulloldref, + depth: 1 + }); + await GitRefManager.writeRef({ fs, gitdir, ref: fullnewref, value }); + await GitRefManager.deleteRef({ fs, gitdir, ref: fulloldref }); + if (checkout2) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref: "HEAD", + value: fullnewref + }); + } +} +async function renameBranch({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + oldref, + checkout: checkout2 = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + assertParameter("oldref", oldref); + return await _renameBranch({ + fs: new FileSystem(fs), + gitdir, + ref, + oldref, + checkout: checkout2 + }); + } catch (err) { + err.caller = "git.renameBranch"; + throw err; + } +} +async function hashObject$1({ gitdir, type, object }) { + return shasum(GitObject.wrap({ type, object })); +} +async function resetIndex({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + ref, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + let oid; + let workdirOid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref: ref || "HEAD" }); + } catch (e) { + if (ref) { + throw e; + } + } + if (oid) { + try { + oid = await resolveFilepath({ + fs, + cache, + gitdir, + oid, + filepath + }); + } catch (e) { + oid = null; + } + } + let stats = { + ctime: new Date(0), + mtime: new Date(0), + dev: 0, + ino: 0, + mode: 0, + uid: 0, + gid: 0, + size: 0 + }; + const object = dir && await fs.read(join(dir, filepath)); + if (object) { + workdirOid = await hashObject$1({ + gitdir, + type: "blob", + object + }); + if (oid === workdirOid) { + stats = await fs.lstat(join(dir, filepath)); + } + } + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + index2.delete({ filepath }); + if (oid) { + index2.insert({ filepath, stats, oid }); + } + }); + } catch (err) { + err.caller = "git.reset"; + throw err; + } +} +async function resolveRef({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + depth +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + const oid = await GitRefManager.resolve({ + fs: new FileSystem(fs), + gitdir, + ref, + depth + }); + return oid; + } catch (err) { + err.caller = "git.resolveRef"; + throw err; + } +} +async function setConfig({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + path: path2, + value, + append: append3 = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("path", path2); + const fs = new FileSystem(_fs); + const config = await GitConfigManager.get({ fs, gitdir }); + if (append3) { + await config.append(path2, value); + } else { + await config.set(path2, value); + } + await GitConfigManager.save({ fs, gitdir, config }); + } catch (err) { + err.caller = "git.setConfig"; + throw err; + } +} +async function status({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + const ignored = await GitIgnoreManager.isIgnored({ + fs, + gitdir, + dir, + filepath + }); + if (ignored) { + return "ignored"; + } + const headTree = await getHeadTree({ fs, cache, gitdir }); + const treeOid = await getOidAtPath({ + fs, + cache, + gitdir, + tree: headTree, + path: filepath + }); + const indexEntry = await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + for (const entry of index2) { + if (entry.path === filepath) + return entry; + } + return null; + }); + const stats = await fs.lstat(join(dir, filepath)); + const H = treeOid !== null; + const I = indexEntry !== null; + const W = stats !== null; + const getWorkdirOid = async () => { + if (I && !compareStats(indexEntry, stats)) { + return indexEntry.oid; + } else { + const object = await fs.read(join(dir, filepath)); + const workdirOid = await hashObject$1({ + gitdir, + type: "blob", + object + }); + if (I && indexEntry.oid === workdirOid) { + if (stats.size !== -1) { + GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + index2.insert({ filepath, stats, oid: workdirOid }); + }); + } + } + return workdirOid; + } + }; + if (!H && !W && !I) + return "absent"; + if (!H && !W && I) + return "*absent"; + if (!H && W && !I) + return "*added"; + if (!H && W && I) { + const workdirOid = await getWorkdirOid(); + return workdirOid === indexEntry.oid ? "added" : "*added"; + } + if (H && !W && !I) + return "deleted"; + if (H && !W && I) { + return treeOid === indexEntry.oid ? "*deleted" : "*deleted"; + } + if (H && W && !I) { + const workdirOid = await getWorkdirOid(); + return workdirOid === treeOid ? "*undeleted" : "*undeletemodified"; + } + if (H && W && I) { + const workdirOid = await getWorkdirOid(); + if (workdirOid === treeOid) { + return workdirOid === indexEntry.oid ? "unmodified" : "*unmodified"; + } else { + return workdirOid === indexEntry.oid ? "modified" : "*modified"; + } + } + } catch (err) { + err.caller = "git.status"; + throw err; + } +} +async function getOidAtPath({ fs, cache, gitdir, tree, path: path2 }) { + if (typeof path2 === "string") + path2 = path2.split("/"); + const dirname2 = path2.shift(); + for (const entry of tree) { + if (entry.path === dirname2) { + if (path2.length === 0) { + return entry.oid; + } + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid: entry.oid + }); + if (type === "tree") { + const tree2 = GitTree.from(object); + return getOidAtPath({ fs, cache, gitdir, tree: tree2, path: path2 }); + } + if (type === "blob") { + throw new ObjectTypeError(entry.oid, type, "blob", path2.join("/")); + } + } + } + return null; +} +async function getHeadTree({ fs, cache, gitdir }) { + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref: "HEAD" }); + } catch (e) { + if (e instanceof NotFoundError) { + return []; + } + } + const { tree } = await _readTree({ fs, cache, gitdir, oid }); + return tree; +} +async function statusMatrix({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + ref = "HEAD", + filepaths = ["."], + filter, + cache = {}, + ignored: shouldIgnore = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + const fs = new FileSystem(_fs); + return await _walk({ + fs, + cache, + dir, + gitdir, + trees: [TREE({ ref }), WORKDIR(), STAGE()], + map: async function(filepath, [head, workdir, stage]) { + if (!head && !stage && workdir) { + if (!shouldIgnore) { + const isIgnored2 = await GitIgnoreManager.isIgnored({ + fs, + dir, + filepath + }); + if (isIgnored2) { + return null; + } + } + } + if (!filepaths.some((base) => worthWalking(filepath, base))) { + return null; + } + if (filter) { + if (!filter(filepath)) + return; + } + const [headType, workdirType, stageType] = await Promise.all([ + head && head.type(), + workdir && workdir.type(), + stage && stage.type() + ]); + const isBlob = [headType, workdirType, stageType].includes("blob"); + if ((headType === "tree" || headType === "special") && !isBlob) + return; + if (headType === "commit") + return null; + if ((workdirType === "tree" || workdirType === "special") && !isBlob) + return; + if (stageType === "commit") + return null; + if ((stageType === "tree" || stageType === "special") && !isBlob) + return; + const headOid = headType === "blob" ? await head.oid() : void 0; + const stageOid = stageType === "blob" ? await stage.oid() : void 0; + let workdirOid; + if (headType !== "blob" && workdirType === "blob" && stageType !== "blob") { + workdirOid = "42"; + } else if (workdirType === "blob") { + workdirOid = await workdir.oid(); + } + const entry = [void 0, headOid, workdirOid, stageOid]; + const result = entry.map((value) => entry.indexOf(value)); + result.shift(); + return [filepath, ...result]; + } + }); + } catch (err) { + err.caller = "git.statusMatrix"; + throw err; + } +} +async function tag({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + ref, + object, + force = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + const fs = new FileSystem(_fs); + if (ref === void 0) { + throw new MissingParameterError("ref"); + } + ref = ref.startsWith("refs/tags/") ? ref : `refs/tags/${ref}`; + const value = await GitRefManager.resolve({ + fs, + gitdir, + ref: object || "HEAD" + }); + if (!force && await GitRefManager.exists({ fs, gitdir, ref })) { + throw new AlreadyExistsError("tag", ref); + } + await GitRefManager.writeRef({ fs, gitdir, ref, value }); + } catch (err) { + err.caller = "git.tag"; + throw err; + } +} +async function updateIndex({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + cache = {}, + filepath, + oid, + mode, + add: add2, + remove: remove3, + force +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + if (remove3) { + return await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + let fileStats2; + if (!force) { + fileStats2 = await fs.lstat(join(dir, filepath)); + if (fileStats2) { + if (fileStats2.isDirectory()) { + throw new InvalidFilepathError("directory"); + } + return; + } + } + if (index2.has({ filepath })) { + index2.delete({ + filepath + }); + } + }); + } + let fileStats; + if (!oid) { + fileStats = await fs.lstat(join(dir, filepath)); + if (!fileStats) { + throw new NotFoundError(`file at "${filepath}" on disk and "remove" not set`); + } + if (fileStats.isDirectory()) { + throw new InvalidFilepathError("directory"); + } + } + return await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + if (!add2 && !index2.has({ filepath })) { + throw new NotFoundError(`file at "${filepath}" in index and "add" not set`); + } + let stats = { + ctime: new Date(0), + mtime: new Date(0), + dev: 0, + ino: 0, + mode, + uid: 0, + gid: 0, + size: 0 + }; + if (!oid) { + stats = fileStats; + const object = stats.isSymbolicLink() ? await fs.readlink(join(dir, filepath)) : await fs.read(join(dir, filepath)); + oid = await _writeObject({ + fs, + gitdir, + type: "blob", + format: "content", + object + }); + } + index2.insert({ + filepath, + oid, + stats + }); + return oid; + }); + } catch (err) { + err.caller = "git.updateIndex"; + throw err; + } +} +function version() { + try { + return pkg.version; + } catch (err) { + err.caller = "git.version"; + throw err; + } +} +async function walk({ + fs, + dir, + gitdir = join(dir, ".git"), + trees, + map, + reduce, + iterate, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("trees", trees); + return await _walk({ + fs: new FileSystem(fs), + cache, + dir, + gitdir, + trees, + map, + reduce, + iterate + }); + } catch (err) { + err.caller = "git.walk"; + throw err; + } +} +async function writeBlob({ fs, dir, gitdir = join(dir, ".git"), blob }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("blob", blob); + return await _writeObject({ + fs: new FileSystem(fs), + gitdir, + type: "blob", + object: blob, + format: "content" + }); + } catch (err) { + err.caller = "git.writeBlob"; + throw err; + } +} +async function _writeCommit({ fs, gitdir, commit: commit2 }) { + const object = GitCommit.from(commit2).toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "commit", + object, + format: "content" + }); + return oid; +} +async function writeCommit({ + fs, + dir, + gitdir = join(dir, ".git"), + commit: commit2 +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("commit", commit2); + return await _writeCommit({ + fs: new FileSystem(fs), + gitdir, + commit: commit2 + }); + } catch (err) { + err.caller = "git.writeCommit"; + throw err; + } +} +async function writeObject({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + type, + object, + format = "parsed", + oid, + encoding = void 0 +}) { + try { + const fs = new FileSystem(_fs); + if (format === "parsed") { + switch (type) { + case "commit": + object = GitCommit.from(object).toObject(); + break; + case "tree": + object = GitTree.from(object).toObject(); + break; + case "blob": + object = Buffer2.from(object, encoding); + break; + case "tag": + object = GitAnnotatedTag.from(object).toObject(); + break; + default: + throw new ObjectTypeError(oid || "", type, "blob|commit|tag|tree"); + } + format = "content"; + } + oid = await _writeObject({ + fs, + gitdir, + type, + object, + oid, + format + }); + return oid; + } catch (err) { + err.caller = "git.writeObject"; + throw err; + } +} +async function writeRef({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + ref, + value, + force = false, + symbolic = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + assertParameter("value", value); + const fs = new FileSystem(_fs); + if (ref !== import_clean_git_ref.default.clean(ref)) { + throw new InvalidRefNameError(ref, import_clean_git_ref.default.clean(ref)); + } + if (!force && await GitRefManager.exists({ fs, gitdir, ref })) { + throw new AlreadyExistsError("ref", ref); + } + if (symbolic) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref, + value + }); + } else { + value = await GitRefManager.resolve({ + fs, + gitdir, + ref: value + }); + await GitRefManager.writeRef({ + fs, + gitdir, + ref, + value + }); + } + } catch (err) { + err.caller = "git.writeRef"; + throw err; + } +} +async function _writeTag({ fs, gitdir, tag: tag2 }) { + const object = GitAnnotatedTag.from(tag2).toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "tag", + object, + format: "content" + }); + return oid; +} +async function writeTag({ fs, dir, gitdir = join(dir, ".git"), tag: tag2 }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("tag", tag2); + return await _writeTag({ + fs: new FileSystem(fs), + gitdir, + tag: tag2 + }); + } catch (err) { + err.caller = "git.writeTag"; + throw err; + } +} +async function writeTree({ fs, dir, gitdir = join(dir, ".git"), tree }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("tree", tree); + return await _writeTree({ + fs: new FileSystem(fs), + gitdir, + tree + }); + } catch (err) { + err.caller = "git.writeTree"; + throw err; + } +} +var index = { + Errors, + STAGE, + TREE, + WORKDIR, + add, + addNote, + addRemote, + annotatedTag, + branch, + checkout, + clone, + commit, + getConfig, + getConfigAll, + setConfig, + currentBranch, + deleteBranch, + deleteRef, + deleteRemote, + deleteTag, + expandOid, + expandRef, + fastForward, + fetch, + findMergeBase, + findRoot, + getRemoteInfo, + getRemoteInfo2, + hashBlob, + indexPack, + init, + isDescendent, + isIgnored, + listBranches, + listFiles, + listNotes, + listRemotes, + listServerRefs, + listTags, + log, + merge, + packObjects, + pull, + push, + readBlob, + readCommit, + readNote, + readObject, + readTag, + readTree, + remove, + removeNote, + renameBranch, + resetIndex, + updateIndex, + resolveRef, + status, + statusMatrix, + tag, + version, + walk, + writeBlob, + writeCommit, + writeObject, + writeRef, + writeTag, + writeTree +}; +var isomorphic_git_default = index; + +// src/main.ts +var import_obsidian23 = __toModule(require("obsidian")); // src/promiseQueue.ts +init_polyfill_buffer(); var PromiseQueue = class { constructor() { this.tasks = []; @@ -6786,22 +18679,516 @@ var PromiseQueue = class { this.handleTask(); } } - handleTask() { - return __async(this, null, function* () { - if (this.tasks.length > 0) { - this.tasks[0]().finally(() => { - this.tasks.shift(); - this.handleTask(); - }); - } - }); + async handleTask() { + if (this.tasks.length > 0) { + this.tasks[0]().finally(() => { + this.tasks.shift(); + this.handleTask(); + }); + } } }; // src/settings.ts -var import_obsidian2 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian7 = __toModule(require("obsidian")); + +// src/isomorphicGit.ts +init_polyfill_buffer(); + +// node_modules/diff/lib/index.mjs +init_polyfill_buffer(); +function Diff() { +} +Diff.prototype = { + diff: function diff(oldString, newString) { + var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; + var callback = options.callback; + if (typeof options === "function") { + callback = options; + options = {}; + } + this.options = options; + var self3 = this; + function done(value) { + if (callback) { + setTimeout(function() { + callback(void 0, value); + }, 0); + return true; + } else { + return value; + } + } + oldString = this.castInput(oldString); + newString = this.castInput(newString); + oldString = this.removeEmpty(this.tokenize(oldString)); + newString = this.removeEmpty(this.tokenize(newString)); + var newLen = newString.length, oldLen = oldString.length; + var editLength = 1; + var maxEditLength = newLen + oldLen; + if (options.maxEditLength) { + maxEditLength = Math.min(maxEditLength, options.maxEditLength); + } + var bestPath = [{ + newPos: -1, + components: [] + }]; + var oldPos = this.extractCommon(bestPath[0], newString, oldString, 0); + if (bestPath[0].newPos + 1 >= newLen && oldPos + 1 >= oldLen) { + return done([{ + value: this.join(newString), + count: newString.length + }]); + } + function execEditLength() { + for (var diagonalPath = -1 * editLength; diagonalPath <= editLength; diagonalPath += 2) { + var basePath = void 0; + var addPath = bestPath[diagonalPath - 1], removePath = bestPath[diagonalPath + 1], _oldPos = (removePath ? removePath.newPos : 0) - diagonalPath; + if (addPath) { + bestPath[diagonalPath - 1] = void 0; + } + var canAdd = addPath && addPath.newPos + 1 < newLen, canRemove = removePath && 0 <= _oldPos && _oldPos < oldLen; + if (!canAdd && !canRemove) { + bestPath[diagonalPath] = void 0; + continue; + } + if (!canAdd || canRemove && addPath.newPos < removePath.newPos) { + basePath = clonePath(removePath); + self3.pushComponent(basePath.components, void 0, true); + } else { + basePath = addPath; + basePath.newPos++; + self3.pushComponent(basePath.components, true, void 0); + } + _oldPos = self3.extractCommon(basePath, newString, oldString, diagonalPath); + if (basePath.newPos + 1 >= newLen && _oldPos + 1 >= oldLen) { + return done(buildValues(self3, basePath.components, newString, oldString, self3.useLongestToken)); + } else { + bestPath[diagonalPath] = basePath; + } + } + editLength++; + } + if (callback) { + (function exec() { + setTimeout(function() { + if (editLength > maxEditLength) { + return callback(); + } + if (!execEditLength()) { + exec(); + } + }, 0); + })(); + } else { + while (editLength <= maxEditLength) { + var ret = execEditLength(); + if (ret) { + return ret; + } + } + } + }, + pushComponent: function pushComponent(components, added, removed) { + var last2 = components[components.length - 1]; + if (last2 && last2.added === added && last2.removed === removed) { + components[components.length - 1] = { + count: last2.count + 1, + added, + removed + }; + } else { + components.push({ + count: 1, + added, + removed + }); + } + }, + extractCommon: function extractCommon(basePath, newString, oldString, diagonalPath) { + var newLen = newString.length, oldLen = oldString.length, newPos = basePath.newPos, oldPos = newPos - diagonalPath, commonCount = 0; + while (newPos + 1 < newLen && oldPos + 1 < oldLen && this.equals(newString[newPos + 1], oldString[oldPos + 1])) { + newPos++; + oldPos++; + commonCount++; + } + if (commonCount) { + basePath.components.push({ + count: commonCount + }); + } + basePath.newPos = newPos; + return oldPos; + }, + equals: function equals(left, right) { + if (this.options.comparator) { + return this.options.comparator(left, right); + } else { + return left === right || this.options.ignoreCase && left.toLowerCase() === right.toLowerCase(); + } + }, + removeEmpty: function removeEmpty(array) { + var ret = []; + for (var i = 0; i < array.length; i++) { + if (array[i]) { + ret.push(array[i]); + } + } + return ret; + }, + castInput: function castInput(value) { + return value; + }, + tokenize: function tokenize(value) { + return value.split(""); + }, + join: function join2(chars) { + return chars.join(""); + } +}; +function buildValues(diff2, components, newString, oldString, useLongestToken) { + var componentPos = 0, componentLen = components.length, newPos = 0, oldPos = 0; + for (; componentPos < componentLen; componentPos++) { + var component = components[componentPos]; + if (!component.removed) { + if (!component.added && useLongestToken) { + var value = newString.slice(newPos, newPos + component.count); + value = value.map(function(value2, i) { + var oldValue = oldString[oldPos + i]; + return oldValue.length > value2.length ? oldValue : value2; + }); + component.value = diff2.join(value); + } else { + component.value = diff2.join(newString.slice(newPos, newPos + component.count)); + } + newPos += component.count; + if (!component.added) { + oldPos += component.count; + } + } else { + component.value = diff2.join(oldString.slice(oldPos, oldPos + component.count)); + oldPos += component.count; + if (componentPos && components[componentPos - 1].added) { + var tmp = components[componentPos - 1]; + components[componentPos - 1] = components[componentPos]; + components[componentPos] = tmp; + } + } + } + var lastComponent = components[componentLen - 1]; + if (componentLen > 1 && typeof lastComponent.value === "string" && (lastComponent.added || lastComponent.removed) && diff2.equals("", lastComponent.value)) { + components[componentLen - 2].value += lastComponent.value; + components.pop(); + } + return components; +} +function clonePath(path2) { + return { + newPos: path2.newPos, + components: path2.components.slice(0) + }; +} +var characterDiff = new Diff(); +function diffChars(oldStr, newStr, options) { + return characterDiff.diff(oldStr, newStr, options); +} +var extendedWordChars = /^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/; +var reWhitespace = /\S/; +var wordDiff = new Diff(); +wordDiff.equals = function(left, right) { + if (this.options.ignoreCase) { + left = left.toLowerCase(); + right = right.toLowerCase(); + } + return left === right || this.options.ignoreWhitespace && !reWhitespace.test(left) && !reWhitespace.test(right); +}; +wordDiff.tokenize = function(value) { + var tokens = value.split(/([^\S\r\n]+|[()[\]{}'"\r\n]|\b)/); + for (var i = 0; i < tokens.length - 1; i++) { + if (!tokens[i + 1] && tokens[i + 2] && extendedWordChars.test(tokens[i]) && extendedWordChars.test(tokens[i + 2])) { + tokens[i] += tokens[i + 2]; + tokens.splice(i + 1, 2); + i--; + } + } + return tokens; +}; +function diffWordsWithSpace(oldStr, newStr, options) { + return wordDiff.diff(oldStr, newStr, options); +} +var lineDiff = new Diff(); +lineDiff.tokenize = function(value) { + var retLines = [], linesAndNewlines = value.split(/(\n|\r\n)/); + if (!linesAndNewlines[linesAndNewlines.length - 1]) { + linesAndNewlines.pop(); + } + for (var i = 0; i < linesAndNewlines.length; i++) { + var line = linesAndNewlines[i]; + if (i % 2 && !this.options.newlineIsToken) { + retLines[retLines.length - 1] += line; + } else { + if (this.options.ignoreWhitespace) { + line = line.trim(); + } + retLines.push(line); + } + } + return retLines; +}; +function diffLines(oldStr, newStr, callback) { + return lineDiff.diff(oldStr, newStr, callback); +} +var sentenceDiff = new Diff(); +sentenceDiff.tokenize = function(value) { + return value.split(/(\S.+?[.!?])(?=\s+|$)/); +}; +var cssDiff = new Diff(); +cssDiff.tokenize = function(value) { + return value.split(/([{}:;,]|\s+)/); +}; +function _typeof(obj) { + "@babel/helpers - typeof"; + if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { + _typeof = function(obj2) { + return typeof obj2; + }; + } else { + _typeof = function(obj2) { + return obj2 && typeof Symbol === "function" && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2; + }; + } + return _typeof(obj); +} +function _toConsumableArray(arr) { + return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); +} +function _arrayWithoutHoles(arr) { + if (Array.isArray(arr)) + return _arrayLikeToArray(arr); +} +function _iterableToArray(iter) { + if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) + return Array.from(iter); +} +function _unsupportedIterableToArray(o, minLen) { + if (!o) + return; + if (typeof o === "string") + return _arrayLikeToArray(o, minLen); + var n = Object.prototype.toString.call(o).slice(8, -1); + if (n === "Object" && o.constructor) + n = o.constructor.name; + if (n === "Map" || n === "Set") + return Array.from(o); + if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) + return _arrayLikeToArray(o, minLen); +} +function _arrayLikeToArray(arr, len) { + if (len == null || len > arr.length) + len = arr.length; + for (var i = 0, arr2 = new Array(len); i < len; i++) + arr2[i] = arr[i]; + return arr2; +} +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} +var objectPrototypeToString = Object.prototype.toString; +var jsonDiff = new Diff(); +jsonDiff.useLongestToken = true; +jsonDiff.tokenize = lineDiff.tokenize; +jsonDiff.castInput = function(value) { + var _this$options = this.options, undefinedReplacement = _this$options.undefinedReplacement, _this$options$stringi = _this$options.stringifyReplacer, stringifyReplacer = _this$options$stringi === void 0 ? function(k, v) { + return typeof v === "undefined" ? undefinedReplacement : v; + } : _this$options$stringi; + return typeof value === "string" ? value : JSON.stringify(canonicalize(value, null, null, stringifyReplacer), stringifyReplacer, " "); +}; +jsonDiff.equals = function(left, right) { + return Diff.prototype.equals.call(jsonDiff, left.replace(/,([\r\n])/g, "$1"), right.replace(/,([\r\n])/g, "$1")); +}; +function canonicalize(obj, stack, replacementStack, replacer, key2) { + stack = stack || []; + replacementStack = replacementStack || []; + if (replacer) { + obj = replacer(key2, obj); + } + var i; + for (i = 0; i < stack.length; i += 1) { + if (stack[i] === obj) { + return replacementStack[i]; + } + } + var canonicalizedObj; + if (objectPrototypeToString.call(obj) === "[object Array]") { + stack.push(obj); + canonicalizedObj = new Array(obj.length); + replacementStack.push(canonicalizedObj); + for (i = 0; i < obj.length; i += 1) { + canonicalizedObj[i] = canonicalize(obj[i], stack, replacementStack, replacer, key2); + } + stack.pop(); + replacementStack.pop(); + return canonicalizedObj; + } + if (obj && obj.toJSON) { + obj = obj.toJSON(); + } + if (_typeof(obj) === "object" && obj !== null) { + stack.push(obj); + canonicalizedObj = {}; + replacementStack.push(canonicalizedObj); + var sortedKeys = [], _key; + for (_key in obj) { + if (obj.hasOwnProperty(_key)) { + sortedKeys.push(_key); + } + } + sortedKeys.sort(); + for (i = 0; i < sortedKeys.length; i += 1) { + _key = sortedKeys[i]; + canonicalizedObj[_key] = canonicalize(obj[_key], stack, replacementStack, replacer, _key); + } + stack.pop(); + replacementStack.pop(); + } else { + canonicalizedObj = obj; + } + return canonicalizedObj; +} +var arrayDiff = new Diff(); +arrayDiff.tokenize = function(value) { + return value.slice(); +}; +arrayDiff.join = arrayDiff.removeEmpty = function(value) { + return value; +}; +function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { + if (!options) { + options = {}; + } + if (typeof options.context === "undefined") { + options.context = 4; + } + var diff2 = diffLines(oldStr, newStr, options); + if (!diff2) { + return; + } + diff2.push({ + value: "", + lines: [] + }); + function contextLines(lines) { + return lines.map(function(entry) { + return " " + entry; + }); + } + var hunks = []; + var oldRangeStart = 0, newRangeStart = 0, curRange = [], oldLine = 1, newLine = 1; + var _loop = function _loop2(i2) { + var current = diff2[i2], lines = current.lines || current.value.replace(/\n$/, "").split("\n"); + current.lines = lines; + if (current.added || current.removed) { + var _curRange; + if (!oldRangeStart) { + var prev = diff2[i2 - 1]; + oldRangeStart = oldLine; + newRangeStart = newLine; + if (prev) { + curRange = options.context > 0 ? contextLines(prev.lines.slice(-options.context)) : []; + oldRangeStart -= curRange.length; + newRangeStart -= curRange.length; + } + } + (_curRange = curRange).push.apply(_curRange, _toConsumableArray(lines.map(function(entry) { + return (current.added ? "+" : "-") + entry; + }))); + if (current.added) { + newLine += lines.length; + } else { + oldLine += lines.length; + } + } else { + if (oldRangeStart) { + if (lines.length <= options.context * 2 && i2 < diff2.length - 2) { + var _curRange2; + (_curRange2 = curRange).push.apply(_curRange2, _toConsumableArray(contextLines(lines))); + } else { + var _curRange3; + var contextSize = Math.min(lines.length, options.context); + (_curRange3 = curRange).push.apply(_curRange3, _toConsumableArray(contextLines(lines.slice(0, contextSize)))); + var hunk = { + oldStart: oldRangeStart, + oldLines: oldLine - oldRangeStart + contextSize, + newStart: newRangeStart, + newLines: newLine - newRangeStart + contextSize, + lines: curRange + }; + if (i2 >= diff2.length - 2 && lines.length <= options.context) { + var oldEOFNewline = /\n$/.test(oldStr); + var newEOFNewline = /\n$/.test(newStr); + var noNlBeforeAdds = lines.length == 0 && curRange.length > hunk.oldLines; + if (!oldEOFNewline && noNlBeforeAdds && oldStr.length > 0) { + curRange.splice(hunk.oldLines, 0, "\\ No newline at end of file"); + } + if (!oldEOFNewline && !noNlBeforeAdds || !newEOFNewline) { + curRange.push("\\ No newline at end of file"); + } + } + hunks.push(hunk); + oldRangeStart = 0; + newRangeStart = 0; + curRange = []; + } + } + oldLine += lines.length; + newLine += lines.length; + } + }; + for (var i = 0; i < diff2.length; i++) { + _loop(i); + } + return { + oldFileName, + newFileName, + oldHeader, + newHeader, + hunks + }; +} +function formatPatch(diff2) { + var ret = []; + if (diff2.oldFileName == diff2.newFileName) { + ret.push("Index: " + diff2.oldFileName); + } + ret.push("==================================================================="); + ret.push("--- " + diff2.oldFileName + (typeof diff2.oldHeader === "undefined" ? "" : " " + diff2.oldHeader)); + ret.push("+++ " + diff2.newFileName + (typeof diff2.newHeader === "undefined" ? "" : " " + diff2.newHeader)); + for (var i = 0; i < diff2.hunks.length; i++) { + var hunk = diff2.hunks[i]; + if (hunk.oldLines === 0) { + hunk.oldStart -= 1; + } + if (hunk.newLines === 0) { + hunk.newStart -= 1; + } + ret.push("@@ -" + hunk.oldStart + "," + hunk.oldLines + " +" + hunk.newStart + "," + hunk.newLines + " @@"); + ret.push.apply(ret, hunk.lines); + } + return ret.join("\n") + "\n"; +} +function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { + return formatPatch(structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options)); +} +function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) { + return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options); +} + +// src/isomorphicGit.ts +var import_obsidian5 = __toModule(require("obsidian")); // src/gitManager.ts +init_polyfill_buffer(); var GitManager = class { constructor(plugin) { this.plugin = plugin; @@ -6817,8 +19204,8 @@ var GitManager = class { getPath(path2, relativeToVault) { return relativeToVault && this.plugin.settings.basePath.length > 0 ? path2.substring(this.plugin.settings.basePath.length + 1) : path2; } - getTreeStructure(children2, beginLength = 0) { - let list = []; + _getTreeStructure(children2, beginLength = 0) { + const list = []; children2 = [...children2]; while (children2.length > 0) { const first2 = children2.first(); @@ -6831,93 +19218,1071 @@ var GitManager = class { childrenWithSameTitle.forEach((item) => children2.remove(item)); list.push({ title, - children: this.getTreeStructure(childrenWithSameTitle, (beginLength > 0 ? beginLength + title.length : title.length) + 1) + path: first2.path.substring(0, restPath.indexOf("/") + beginLength), + children: this._getTreeStructure(childrenWithSameTitle, (beginLength > 0 ? beginLength + title.length : title.length) + 1) }); } else { - list.push({ title: restPath, statusResult: first2 }); + list.push({ title: restPath, statusResult: first2, path: first2.path }); children2.remove(first2); } } return list; } - formatCommitMessage(template) { - return __async(this, null, function* () { - let status; - if (template.includes("{{numFiles}}")) { - status = yield this.status(); - let numFiles = status.staged.length; - template = template.replace("{{numFiles}}", String(numFiles)); + simplify(tree) { + var _a2, _b, _c, _d; + for (const node of tree) { + const singleChild = ((_a2 = node.children) == null ? void 0 : _a2.length) == 1; + const singleChildIsDir = ((_c = (_b = node.children) == null ? void 0 : _b.first()) == null ? void 0 : _c.statusResult) == void 0; + if (node.children != void 0 && singleChild && singleChildIsDir) { + node.title += "/" + node.children.first().title; + node.path = node.children.first().path; + node.children = node.children.first().children; + } else if (node.children != void 0) { + this.simplify(node.children); } - if (template.includes("{{hostname}}")) { - const hostname = this.plugin.localStorage.getHostname() || ""; - template = template.replace("{{hostname}}", hostname); - } - if (template.includes("{{files}}")) { - status = status != null ? status : yield this.status(); - let changeset = {}; - status.staged.forEach((value) => { - if (value.index in changeset) { - changeset[value.index].push(value.path); - } else { - changeset[value.index] = [value.path]; - } - }); - let chunks = []; - for (let [action, files2] of Object.entries(changeset)) { - chunks.push(action + " " + files2.join(" ")); + (_d = node.children) == null ? void 0 : _d.sort((a, b) => { + const dirCompare = (b.statusResult == void 0 ? 1 : 0) - (a.statusResult == void 0 ? 1 : 0); + if (dirCompare != 0) { + return dirCompare; + } else { + return a.title.localeCompare(b.title); } - let files = chunks.join(", "); - template = template.replace("{{files}}", files); + }); + } + return tree.sort((a, b) => { + const dirCompare = (b.statusResult == void 0 ? 1 : 0) - (a.statusResult == void 0 ? 1 : 0); + if (dirCompare != 0) { + return dirCompare; + } else { + return a.title.localeCompare(b.title); } - let moment = window.moment; - template = template.replace("{{date}}", moment().format(this.plugin.settings.commitDateFormat)); - if (this.plugin.settings.listChangedFilesInMessageBody) { - template = template + "\n\nAffected files:\n" + (status != null ? status : yield this.status()).staged.map((e) => e.path).join("\n"); - } - return template; }); } + getTreeStructure(children2) { + const tree = this._getTreeStructure(children2); + const res = this.simplify(tree); + return res; + } + async formatCommitMessage(template) { + let status2; + if (template.includes("{{numFiles}}")) { + status2 = await this.status(); + const numFiles = status2.staged.length; + template = template.replace("{{numFiles}}", String(numFiles)); + } + if (template.includes("{{hostname}}")) { + const hostname = this.plugin.localStorage.getHostname() || ""; + template = template.replace("{{hostname}}", hostname); + } + if (template.includes("{{files}}")) { + status2 = status2 != null ? status2 : await this.status(); + const changeset = {}; + status2.staged.forEach((value) => { + if (value.index in changeset) { + changeset[value.index].push(value.path); + } else { + changeset[value.index] = [value.path]; + } + }); + const chunks = []; + for (const [action, files2] of Object.entries(changeset)) { + chunks.push(action + " " + files2.join(" ")); + } + const files = chunks.join(", "); + template = template.replace("{{files}}", files); + } + const moment = window.moment; + template = template.replace("{{date}}", moment().format(this.plugin.settings.commitDateFormat)); + if (this.plugin.settings.listChangedFilesInMessageBody) { + template = template + "\n\nAffected files:\n" + (status2 != null ? status2 : await this.status()).staged.map((e) => e.path).join("\n"); + } + return template; + } }; -// src/isomorphicGit.ts -var IsomorphicGit = class extends GitManager { +// src/myAdapter.ts +init_polyfill_buffer(); +var import_obsidian2 = __toModule(require("obsidian")); +var MyAdapter = class { + constructor(vault, plugin) { + this.plugin = plugin; + this.promises = {}; + this.adapter = vault.adapter; + this.vault = vault; + this.promises.readFile = this.readFile.bind(this); + this.promises.writeFile = this.writeFile.bind(this); + this.promises.readdir = this.readdir.bind(this); + this.promises.mkdir = this.mkdir.bind(this); + this.promises.rmdir = this.rmdir.bind(this); + this.promises.stat = this.stat.bind(this); + this.promises.unlink = this.unlink.bind(this); + this.promises.lstat = this.lstat.bind(this); + this.promises.readlink = this.readlink.bind(this); + this.promises.symlink = this.symlink.bind(this); + } + async readFile(path2, opts) { + var _a2; + this.maybeLog("Read: " + path2 + JSON.stringify(opts)); + if (opts == "utf8" || opts.encoding == "utf8") { + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian2.TFile) { + this.maybeLog("Reuse"); + return this.vault.read(file); + } else { + return this.adapter.read(path2); + } + } else { + if (path2.endsWith(".git/index")) { + return (_a2 = this.index) != null ? _a2 : this.adapter.readBinary(path2); + } + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian2.TFile) { + this.maybeLog("Reuse"); + return this.vault.readBinary(file); + } else { + return this.adapter.readBinary(path2); + } + } + } + async writeFile(path2, data) { + this.maybeLog("Write: " + path2); + if (typeof data === "string") { + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian2.TFile) { + return this.vault.modify(file, data); + } else { + return this.adapter.write(path2, data); + } + } else { + if (path2.endsWith(".git/index")) { + this.index = data; + this.indexmtime = Date.now(); + } else { + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian2.TFile) { + return this.vault.modifyBinary(file, data); + } else { + return this.adapter.writeBinary(path2, data); + } + } + } + } + async readdir(path2) { + if (path2 === ".") + path2 = "/"; + const res = await this.adapter.list(path2); + const all = [...res.files, ...res.folders]; + let formattedAll; + if (path2 !== "/") { + formattedAll = all.map((e) => (0, import_obsidian2.normalizePath)(e.substring(path2.length))); + } else { + formattedAll = all; + } + return formattedAll; + } + async mkdir(path2) { + return this.adapter.mkdir(path2); + } + async rmdir(path2, opts) { + var _a2, _b; + return this.adapter.rmdir(path2, (_b = (_a2 = opts == null ? void 0 : opts.options) == null ? void 0 : _a2.recursive) != null ? _b : false); + } + async stat(path2) { + if (path2.endsWith(".git/index")) { + if (this.index !== void 0 && this.indexctime != void 0 && this.indexmtime != void 0) { + return { + isFile: () => true, + isDirectory: () => false, + isSymbolicLink: () => false, + size: this.index.length, + type: "file", + ctimeMs: this.indexctime, + mtimeMs: this.indexmtime + }; + } else { + const stat = await this.adapter.stat(path2); + if (stat == void 0) { + throw { "code": "ENOENT" }; + } + this.indexctime = stat.ctime; + this.indexmtime = stat.mtime; + return { + ctimeMs: stat.ctime, + mtimeMs: stat.mtime, + size: stat.size, + type: "file", + isFile: () => true, + isDirectory: () => false, + isSymbolicLink: () => false + }; + } + } + if (path2 === ".") + path2 = "/"; + const file = this.vault.getAbstractFileByPath(path2); + this.maybeLog("Stat: " + path2); + if (file instanceof import_obsidian2.TFile) { + this.maybeLog("Reuse stat"); + return { + ctimeMs: file.stat.ctime, + mtimeMs: file.stat.mtime, + size: file.stat.size, + type: "file", + isFile: () => true, + isDirectory: () => false, + isSymbolicLink: () => false + }; + } else { + const stat = await this.adapter.stat(path2); + if (stat) { + return { + ctimeMs: stat.ctime, + mtimeMs: stat.mtime, + size: stat.size, + type: stat.type === "folder" ? "directory" : stat.type, + isFile: () => stat.type === "file", + isDirectory: () => stat.type === "folder", + isSymbolicLink: () => false + }; + } else { + throw { "code": "ENOENT" }; + } + } + } + async unlink(path2) { + return this.adapter.remove(path2); + } + async lstat(path2) { + return this.stat(path2); + } + async readlink(path2) { + throw new Error(`readlink of (${path2}) is not implemented.`); + } + async symlink(path2) { + throw new Error(`symlink of (${path2}) is not implemented.`); + } + async saveAndClear() { + if (this.index !== void 0) { + await this.adapter.writeBinary(this.plugin.gitManager.getVaultPath(".git/index"), this.index, { + ctime: this.indexctime, + mtime: this.indexmtime + }); + } + this.index = void 0; + this.indexctime = void 0; + this.indexmtime = void 0; + } + maybeLog(text2) { + } }; +// src/types.ts +init_polyfill_buffer(); +var PluginState; +(function(PluginState2) { + PluginState2[PluginState2["idle"] = 0] = "idle"; + PluginState2[PluginState2["status"] = 1] = "status"; + PluginState2[PluginState2["pull"] = 2] = "pull"; + PluginState2[PluginState2["add"] = 3] = "add"; + PluginState2[PluginState2["commit"] = 4] = "commit"; + PluginState2[PluginState2["push"] = 5] = "push"; + PluginState2[PluginState2["conflicted"] = 6] = "conflicted"; +})(PluginState || (PluginState = {})); +var FileType; +(function(FileType2) { + FileType2[FileType2["staged"] = 0] = "staged"; + FileType2[FileType2["changed"] = 1] = "changed"; + FileType2[FileType2["pulled"] = 2] = "pulled"; +})(FileType || (FileType = {})); + +// src/ui/modals/generalModal.ts +init_polyfill_buffer(); +var import_obsidian3 = __toModule(require("obsidian")); +var generalModalConfigDefaults = { + options: [], + placeholder: "", + allowEmpty: false, + onlySelection: false, + initialValue: void 0 +}; +var GeneralModal = class extends import_obsidian3.SuggestModal { + constructor(config) { + super(app); + this.config = { ...generalModalConfigDefaults, ...config }; + this.setPlaceholder(this.config.placeholder); + } + open() { + super.open(); + if (this.config.initialValue != void 0) { + this.inputEl.value = this.config.initialValue; + this.inputEl.dispatchEvent(new Event("input")); + } + return new Promise((resolve) => { + this.resolve = resolve; + }); + } + selectSuggestion(value, evt) { + if (this.resolve) { + let res; + if (this.config.allowEmpty && value === " ") + res = ""; + else if (value === "...") + res = void 0; + else + res = value; + this.resolve(res); + } + super.selectSuggestion(value, evt); + } + onClose() { + if (this.resolve) + this.resolve(void 0); + } + getSuggestions(query) { + if (this.config.onlySelection) { + return this.config.options; + } else if (this.config.allowEmpty) { + return [query.length > 0 ? query : " ", ...this.config.options]; + } else { + return [query.length > 0 ? query : "...", ...this.config.options]; + } + } + renderSuggestion(value, el) { + el.setText(value); + } + onChooseSuggestion(item, evt) { + } +}; + +// src/utils.ts +init_polyfill_buffer(); +var import_obsidian4 = __toModule(require("obsidian")); +var worthWalking2 = (filepath, root) => { + if (filepath === "." || root == null || root.length === 0 || root === ".") { + return true; + } + if (root.length >= filepath.length) { + return root.startsWith(filepath); + } else { + return filepath.startsWith(root); + } +}; +function getNewLeaf(event) { + let leaf; + if (event) { + if (event.button === 0 || event.button === 1) { + const type = import_obsidian4.Keymap.isModEvent(event); + leaf = app.workspace.getLeaf(type); + } + } else { + leaf = app.workspace.getLeaf(false); + } + return leaf; +} + +// src/isomorphicGit.ts +var IsomorphicGit = class extends GitManager { + constructor(plugin) { + super(plugin); + this.FILE = 0; + this.HEAD = 1; + this.WORKDIR = 2; + this.STAGE = 3; + this.status_mapping = { + "000": " ", + "003": "AD", + "020": "??", + "022": "A ", + "023": "AM", + "100": "D ", + "101": " D", + "103": "MD", + "110": "DA", + "111": " ", + "120": "DA", + "121": " M", + "122": "M ", + "123": "MM" + }; + this.noticeLength = 999999; + this.fs = new MyAdapter(this.app.vault, this.plugin); + } + getRepo() { + return { + fs: this.fs, + dir: this.plugin.settings.basePath, + onAuth: () => { + var _a2; + return { + username: this.plugin.settings.username, + password: (_a2 = this.plugin.localStorage.getPassword()) != null ? _a2 : void 0 + }; + }, + onAuthFailure: async () => { + new import_obsidian5.Notice("Authentication failed. Please try with different credentials"); + const username = await new GeneralModal({ placeholder: "Specify your username" }).open(); + if (username) { + const password = await new GeneralModal({ placeholder: "Specify your password/personal access token" }).open(); + if (password) { + this.plugin.settings.username = username; + await this.plugin.saveSettings(); + this.plugin.localStorage.setPassword(password); + return { + username, + password + }; + } + } + return { cancel: true }; + }, + http: { + async request({ + url, + method, + headers, + body + }) { + if (body) { + body = await collect2(body); + body = body.buffer; + } + const res = await (0, import_obsidian5.requestUrl)({ url, method, headers, body, throw: false }); + return { + url, + method, + headers: res.headers, + body: [new Uint8Array(res.arrayBuffer)], + statusCode: res.status, + statusMessage: res.status.toString() + }; + } + } + }; + } + async wrapFS(call) { + try { + const res = await call; + await this.fs.saveAndClear(); + return res; + } catch (error) { + await this.fs.saveAndClear(); + throw error; + } + } + async status() { + const notice = new import_obsidian5.Notice("Getting status...", this.noticeLength); + try { + this.plugin.setState(PluginState.status); + const status2 = (await this.wrapFS(isomorphic_git_default.statusMatrix({ ...this.getRepo() }))).map((row) => this.getFileStatusResult(row)); + const changed = status2.filter((fileStatus) => fileStatus.working_dir !== " "); + const staged = status2.filter((fileStatus) => fileStatus.index !== " " && fileStatus.index !== "U"); + const conflicted = []; + notice.hide(); + return { changed, staged, conflicted }; + } catch (error) { + notice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async commitAll({ message, status: status2, unstagedFiles }) { + try { + await this.stageAll({ status: status2, unstagedFiles }); + return this.commit(message); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async commit(message) { + try { + this.plugin.setState(PluginState.commit); + const formatMessage = await this.formatCommitMessage(message); + const hadConflict = this.plugin.localStorage.getConflict() === "true"; + let parent = void 0; + if (hadConflict) { + const branchInfo = await this.branchInfo(); + parent = [branchInfo.current, branchInfo.tracking]; + } + await this.wrapFS(isomorphic_git_default.commit({ + ...this.getRepo(), + message: formatMessage, + parent + })); + this.plugin.localStorage.setConflict("false"); + return; + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async stage(filepath, relativeToVault) { + const gitPath = this.getPath(filepath, relativeToVault); + let vaultPath; + if (relativeToVault) { + vaultPath = filepath; + } else { + vaultPath = this.getVaultPath(filepath); + } + try { + this.plugin.setState(PluginState.add); + if (await this.app.vault.adapter.exists(vaultPath)) { + await this.wrapFS(isomorphic_git_default.add({ ...this.getRepo(), filepath: gitPath })); + } else { + await this.wrapFS(isomorphic_git_default.remove({ ...this.getRepo(), filepath: gitPath })); + } + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async stageAll({ dir, status: status2, unstagedFiles }) { + try { + if (status2) { + await Promise.all(status2.changed.map((file) => file.working_dir !== "D" ? this.wrapFS(isomorphic_git_default.add({ ...this.getRepo(), filepath: file.path })) : isomorphic_git_default.remove({ ...this.getRepo(), filepath: file.path }))); + } else { + const filesToStage = unstagedFiles != null ? unstagedFiles : await this.getUnstagedFiles(dir != null ? dir : "."); + await Promise.all(filesToStage.map(({ filepath, deleted }) => deleted ? isomorphic_git_default.remove({ ...this.getRepo(), filepath }) : this.wrapFS(isomorphic_git_default.add({ ...this.getRepo(), filepath })))); + } + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async unstage(filepath, relativeToVault) { + try { + this.plugin.setState(PluginState.add); + filepath = this.getPath(filepath, relativeToVault); + await this.wrapFS(isomorphic_git_default.resetIndex({ ...this.getRepo(), filepath })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async unstageAll({ dir, status: status2 }) { + try { + let staged; + if (status2) { + staged = status2.staged.map((file) => file.path); + } else { + const res = await this.getStagedFiles(dir != null ? dir : "."); + staged = res.map(({ filepath }) => filepath); + } + await Promise.all(staged.map((file) => this.unstage(file, false))); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async discard(filepath) { + try { + this.plugin.setState(PluginState.add); + await this.wrapFS(isomorphic_git_default.checkout({ ...this.getRepo(), filepaths: [filepath], force: true })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + getProgressText(action, event) { + let out = `${action} progress:`; + if (event.phase) { + out = `${out} ${event.phase}:`; + } + if (event.loaded) { + out = `${out} ${event.loaded}`; + if (event.total) { + out = `${out} of ${event.total}`; + } + } + return out; + } + resolveRef(ref) { + return this.wrapFS(isomorphic_git_default.resolveRef({ ...this.getRepo(), ref })); + } + async pull() { + const progressNotice = new import_obsidian5.Notice("Initializing pull", this.noticeLength); + try { + this.plugin.setState(PluginState.pull); + const localCommit = await this.resolveRef("HEAD"); + await this.fetch(); + const branchInfo = await this.branchInfo(); + await this.wrapFS(isomorphic_git_default.merge({ + ...this.getRepo(), + ours: branchInfo.current, + theirs: branchInfo.tracking, + abortOnConflict: false + })); + await this.wrapFS(isomorphic_git_default.checkout({ + ...this.getRepo(), + ref: branchInfo.current, + onProgress: (progress) => { + progressNotice.noticeEl.innerText = this.getProgressText("Checkout", progress); + }, + remote: branchInfo.remote + })); + progressNotice.hide(); + const upstreamCommit = await this.resolveRef("HEAD"); + this.plugin.lastUpdate = Date.now(); + const changedFiles = await this.getFileChangesCount(localCommit, upstreamCommit); + new import_obsidian5.Notice("Finished pull"); + return changedFiles.map((file) => ({ + path: file.path, + working_dir: "P", + index: "P", + vault_path: this.getVaultPath(file.path) + })); + } catch (error) { + progressNotice.hide(); + if (error instanceof Errors.MergeConflictError) { + this.plugin.handleConflict(error.data.filepaths.map((file) => this.getVaultPath(file))); + } + this.plugin.displayError(error); + throw error; + } + } + async push() { + if (!await this.canPush()) { + return 0; + } + const progressNotice = new import_obsidian5.Notice("Initializing push", this.noticeLength); + try { + this.plugin.setState(PluginState.status); + const status2 = await this.branchInfo(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const numChangedFiles = (await this.getFileChangesCount(currentBranch2, trackingBranch)).length; + this.plugin.setState(PluginState.push); + await this.wrapFS(isomorphic_git_default.push({ + ...this.getRepo(), + onProgress: (progress) => { + progressNotice.noticeEl.innerText = this.getProgressText("Pushing", progress); + } + })); + progressNotice.hide(); + return numChangedFiles; + } catch (error) { + progressNotice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async canPush() { + const status2 = await this.branchInfo(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const current = await this.resolveRef(currentBranch2); + const tracking = await this.resolveRef(trackingBranch); + return current != tracking; + } + async checkRequirements() { + const headExists = await this.plugin.app.vault.adapter.exists(`${this.getRepo().dir}/.git/HEAD`); + return headExists ? "valid" : "missing-repo"; + } + async branchInfo() { + var _a2, _b; + try { + const current = await isomorphic_git_default.currentBranch(this.getRepo()) || ""; + const branches = await isomorphic_git_default.listBranches(this.getRepo()); + const remote = (_a2 = await this.getConfig(`branch.${current}.remote`)) != null ? _a2 : "origin"; + const trackingBranch = (_b = await this.getConfig(`branch.${current}.merge`)) == null ? void 0 : _b.split("refs/heads")[1]; + const tracking = trackingBranch ? remote + trackingBranch : void 0; + return { + current, + tracking, + branches, + remote + }; + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async getCurrentRemote() { + var _a2; + const current = await isomorphic_git_default.currentBranch(this.getRepo()) || ""; + const remote = (_a2 = await this.getConfig(`branch.${current}.remote`)) != null ? _a2 : "origin"; + return remote; + } + async checkout(branch2) { + try { + return this.wrapFS(isomorphic_git_default.checkout({ + ...this.getRepo(), + ref: branch2 + })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async createBranch(branch2) { + try { + await this.wrapFS(isomorphic_git_default.branch({ ...this.getRepo(), ref: branch2, checkout: true })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async deleteBranch(branch2) { + try { + await this.wrapFS(isomorphic_git_default.deleteBranch({ ...this.getRepo(), ref: branch2 })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async branchIsMerged(branch2) { + return true; + } + async init() { + try { + await this.wrapFS(isomorphic_git_default.init(this.getRepo())); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async clone(url, dir) { + const progressNotice = new import_obsidian5.Notice("Initializing clone", this.noticeLength); + try { + await this.wrapFS(isomorphic_git_default.clone({ + ...this.getRepo(), + dir, + url, + onProgress: (progress) => { + progressNotice.noticeEl.innerText = this.getProgressText("Cloning", progress); + } + })); + progressNotice.hide(); + } catch (error) { + progressNotice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async setConfig(path2, value) { + try { + return this.wrapFS(isomorphic_git_default.setConfig({ + ...this.getRepo(), + path: path2, + value + })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async getConfig(path2) { + try { + return this.wrapFS(isomorphic_git_default.getConfig({ + ...this.getRepo(), + path: path2 + })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async fetch(remote) { + const progressNotice = new import_obsidian5.Notice("Initializing fetch", this.noticeLength); + try { + const args = { + ...this.getRepo(), + onProgress: (progress) => { + progressNotice.noticeEl.innerText = this.getProgressText("Fetching", progress); + }, + remote: remote != null ? remote : await this.getCurrentRemote() + }; + await this.wrapFS(isomorphic_git_default.fetch(args)); + progressNotice.hide(); + } catch (error) { + this.plugin.displayError(error); + progressNotice.hide(); + throw error; + } + } + async setRemote(name, url) { + try { + await this.wrapFS(isomorphic_git_default.addRemote({ ...this.getRepo(), remote: name, url })); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async getRemoteBranches(remote) { + let remoteBranches = []; + remoteBranches.push(...await this.wrapFS(isomorphic_git_default.listBranches({ ...this.getRepo(), remote }))); + remoteBranches.remove("HEAD"); + remoteBranches = remoteBranches.map((e) => `${remote}/${e}`); + return remoteBranches; + } + async getRemotes() { + return (await this.wrapFS(isomorphic_git_default.listRemotes({ ...this.getRepo() }))).map((remoteUrl) => remoteUrl.remote); + } + async removeRemote(remoteName) { + await this.wrapFS(isomorphic_git_default.deleteRemote({ ...this.getRepo(), remote: remoteName })); + } + async getRemoteUrl(remote) { + return (await this.wrapFS(isomorphic_git_default.listRemotes({ ...this.getRepo() }))).filter((item) => item.remote == remote)[0].url; + } + updateBasePath(basePath) { + this.getRepo().dir = basePath; + } + async updateUpstreamBranch(remoteBranch) { + const [remote, branch2] = remoteBranch.split("/"); + const branchInfo = await this.branchInfo(); + await this.setConfig(`branch.${branchInfo.current}.merge`, `refs/heads/${branch2}`); + await this.setConfig(`branch.${branch2}.remote`, remote); + } + updateGitPath(gitPath) { + return; + } + async getFileChangesCount(commitHash1, commitHash2) { + return this.walkDifference({ walkers: [isomorphic_git_default.TREE({ ref: commitHash1 }), isomorphic_git_default.TREE({ ref: commitHash2 })] }); + } + async walkDifference({ walkers, dir: base }) { + const res = await this.wrapFS(isomorphic_git_default.walk({ + ...this.getRepo(), + trees: walkers, + map: async function(filepath, [A, B]) { + if (!worthWalking2(filepath, base)) { + return null; + } + if (await (A == null ? void 0 : A.type()) === "tree" || await (B == null ? void 0 : B.type()) === "tree") { + return; + } + const Aoid = await (A == null ? void 0 : A.oid()); + const Boid = await (B == null ? void 0 : B.oid()); + let type = "equal"; + if (Aoid !== Boid) { + type = "modify"; + } + if (Aoid === void 0) { + type = "add"; + } + if (Boid === void 0) { + type = "remove"; + } + if (Aoid === void 0 && Boid === void 0) { + console.log("Something weird happened:"); + console.log(A); + console.log(B); + } + if (type === "equal") { + return; + } + return { + path: filepath, + type + }; + } + })); + return res; + } + async getStagedFiles(dir = ".") { + const res = await this.walkDifference({ + walkers: [isomorphic_git_default.TREE({ ref: "HEAD" }), isomorphic_git_default.STAGE()], + dir + }); + return res.map((file) => { + return { + vault_path: this.getVaultPath(file.path), + filepath: file.path + }; + }); + } + async getUnstagedFiles(base = ".") { + const notice = new import_obsidian5.Notice("Getting status...", this.noticeLength); + try { + const repo = this.getRepo(); + const res = await this.wrapFS(isomorphic_git_default.walk({ + ...repo, + trees: [isomorphic_git_default.WORKDIR(), isomorphic_git_default.STAGE()], + map: async function(filepath, [workdir, stage]) { + if (!stage && workdir) { + const isIgnored2 = await isomorphic_git_default.isIgnored({ + ...repo, + filepath + }); + if (isIgnored2) { + return null; + } + } + if (!worthWalking2(filepath, base)) { + return null; + } + const [workdirType, stageType] = await Promise.all([ + workdir && workdir.type(), + stage && stage.type() + ]); + const isBlob = [workdirType, stageType].includes("blob"); + if ((workdirType === "tree" || workdirType === "special") && !isBlob) + return; + if (stageType === "commit") + return null; + if ((stageType === "tree" || stageType === "special") && !isBlob) + return; + const stageOid = stageType === "blob" ? await stage.oid() : void 0; + let workdirOid; + if (workdirType === "blob" && stageType !== "blob") { + workdirOid = "42"; + } else if (workdirType === "blob") { + workdirOid = await workdir.oid(); + } + if (!workdirOid) { + return { + filepath, + deleted: true + }; + } + if (workdirOid !== stageOid) { + return { + filepath, + deleted: false + }; + } + return null; + } + })); + notice.hide(); + return res; + } catch (error) { + notice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async getDiffString(filePath, stagedChanges = false) { + const map = async (file, [A]) => { + if (filePath == file) { + const oid = await A.oid(); + const contents = await isomorphic_git_default.readBlob({ ...this.getRepo(), oid }); + return contents.blob; + } + }; + const stagedBlob = (await isomorphic_git_default.walk({ + ...this.getRepo(), + trees: [isomorphic_git_default.STAGE()], + map + })).first(); + const stagedContent = new TextDecoder().decode(stagedBlob); + if (stagedChanges) { + const headBlob = await readBlob({ ...this.getRepo(), filepath: filePath, oid: await this.resolveRef("HEAD") }); + const headContent = new TextDecoder().decode(headBlob.blob); + const diff2 = createPatch(filePath, headContent, stagedContent); + return diff2; + } else { + let workdirContent; + if (await app.vault.adapter.exists(filePath)) { + workdirContent = await app.vault.adapter.read(filePath); + } else { + workdirContent = ""; + } + const diff2 = createPatch(filePath, stagedContent, workdirContent); + return diff2; + } + } + getFileStatusResult(row) { + const status2 = this.status_mapping[`${row[this.HEAD]}${row[this.WORKDIR]}${row[this.STAGE]}`]; + return { + index: status2[0] == "?" ? "U" : status2[0], + working_dir: status2[1] == "?" ? "U" : status2[1], + path: row[this.FILE], + vault_path: this.getVaultPath(row[this.FILE]) + }; + } +}; +function fromValue2(value) { + let queue = [value]; + return { + next() { + return Promise.resolve({ done: queue.length === 0, value: queue.pop() }); + }, + return() { + queue = []; + return {}; + }, + [Symbol.asyncIterator]() { + return this; + } + }; +} +function getIterator2(iterable) { + if (iterable[Symbol.asyncIterator]) { + return iterable[Symbol.asyncIterator](); + } + if (iterable[Symbol.iterator]) { + return iterable[Symbol.iterator](); + } + if (iterable.next) { + return iterable; + } + return fromValue2(iterable); +} +async function forAwait2(iterable, cb) { + const iter = getIterator2(iterable); + while (true) { + const { value, done } = await iter.next(); + if (value) + await cb(value); + if (done) + break; + } + if (iter.return) + iter.return(); +} +async function collect2(iterable) { + let size = 0; + const buffers = []; + await forAwait2(iterable, (value) => { + buffers.push(value); + size += value.byteLength; + }); + const result = new Uint8Array(size); + let nextIndex = 0; + for (const buffer2 of buffers) { + result.set(buffer2, nextIndex); + nextIndex += buffer2.byteLength; + } + return result; +} + // src/simpleGit.ts +init_polyfill_buffer(); var import_child_process2 = __toModule(require("child_process")); -var import_obsidian = __toModule(require("obsidian")); +var import_obsidian6 = __toModule(require("obsidian")); var path = __toModule(require("path")); var import_path = __toModule(require("path")); // node_modules/simple-git/dist/esm/index.js +init_polyfill_buffer(); var import_file_exists = __toModule(require_dist()); -var import_debug = __toModule(require_src()); +var import_debug = __toModule(require_browser()); var import_child_process = __toModule(require("child_process")); var import_promise_deferred = __toModule(require_dist2()); var import_promise_deferred2 = __toModule(require_dist2()); var __defProp2 = Object.defineProperty; -var __defProps2 = Object.defineProperties; +var __defProps = Object.defineProperties; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; -var __getOwnPropDescs2 = Object.getOwnPropertyDescriptors; +var __getOwnPropDescs = Object.getOwnPropertyDescriptors; var __getOwnPropNames2 = Object.getOwnPropertyNames; -var __getOwnPropSymbols2 = Object.getOwnPropertySymbols; +var __getOwnPropSymbols = Object.getOwnPropertySymbols; var __hasOwnProp2 = Object.prototype.hasOwnProperty; -var __propIsEnum2 = Object.prototype.propertyIsEnumerable; -var __defNormalProp2 = (obj, key2, value) => key2 in obj ? __defProp2(obj, key2, { enumerable: true, configurable: true, writable: true, value }) : obj[key2] = value; -var __spreadValues2 = (a, b) => { +var __propIsEnum = Object.prototype.propertyIsEnumerable; +var __defNormalProp = (obj, key2, value) => key2 in obj ? __defProp2(obj, key2, { enumerable: true, configurable: true, writable: true, value }) : obj[key2] = value; +var __spreadValues = (a, b) => { for (var prop in b || (b = {})) if (__hasOwnProp2.call(b, prop)) - __defNormalProp2(a, prop, b[prop]); - if (__getOwnPropSymbols2) - for (var prop of __getOwnPropSymbols2(b)) { - if (__propIsEnum2.call(b, prop)) - __defNormalProp2(a, prop, b[prop]); + __defNormalProp(a, prop, b[prop]); + if (__getOwnPropSymbols) + for (var prop of __getOwnPropSymbols(b)) { + if (__propIsEnum.call(b, prop)) + __defNormalProp(a, prop, b[prop]); } return a; }; -var __spreadProps2 = (a, b) => __defProps2(a, __getOwnPropDescs2(b)); +var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); var __markAsModule2 = (target) => __defProp2(target, "__esModule", { value: true }); -var __esm = (fn, res) => function __init() { +var __esm2 = (fn, res) => function __init() { return fn && (res = (0, fn[__getOwnPropNames2(fn)[0]])(fn = 0)), res; }; var __commonJS2 = (cb, mod) => function __require() { @@ -6940,7 +20305,7 @@ var __toCommonJS = /* @__PURE__ */ ((cache) => { return cache && cache.get(module2) || (temp = __reExport2(__markAsModule2({}), module2, 1), cache && cache.set(module2, temp), temp); }; })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0); -var __async2 = (__this, __arguments, generator) => { +var __async = (__this, __arguments, generator) => { return new Promise((resolve, reject) => { var fulfilled = (value) => { try { @@ -6961,7 +20326,7 @@ var __async2 = (__this, __arguments, generator) => { }); }; var GitError; -var init_git_error = __esm({ +var init_git_error = __esm2({ "src/lib/errors/git-error.ts"() { GitError = class extends Error { constructor(task, message) { @@ -6973,7 +20338,7 @@ var init_git_error = __esm({ } }); var GitResponseError; -var init_git_response_error = __esm({ +var init_git_response_error = __esm2({ "src/lib/errors/git-response-error.ts"() { init_git_error(); GitResponseError = class extends GitError { @@ -6985,7 +20350,7 @@ var init_git_response_error = __esm({ } }); var TaskConfigurationError; -var init_task_configuration_error = __esm({ +var init_task_configuration_error = __esm2({ "src/lib/errors/task-configuration-error.ts"() { init_git_error(); TaskConfigurationError = class extends GitError { @@ -7002,11 +20367,11 @@ function isUserFunction(source) { return typeof source === "function" && source !== NOOP; } function splitOn(input, char) { - const index = input.indexOf(char); - if (index <= 0) { + const index2 = input.indexOf(char); + if (index2 <= 0) { return [input, ""]; } - return [input.substr(0, index), input.substr(index + 1)]; + return [input.substr(0, index2), input.substr(index2 + 1)]; } function first(input, offset = 0) { return isArrayLike(input) && input.length > offset ? input[offset] : void 0; @@ -7019,8 +20384,8 @@ function last(input, offset = 0) { function isArrayLike(input) { return !!(input && typeof input.length === "number"); } -function toLinesWithContent(input = "", trimmed2 = true, separator = "\n") { - return input.split(separator).reduce((output, line) => { +function toLinesWithContent(input = "", trimmed2 = true, separator2 = "\n") { + return input.split(separator2).reduce((output, line) => { const lineContent = trimmed2 ? line.trim() : line; if (lineContent) { output.push(lineContent); @@ -7050,11 +20415,11 @@ function including(target, item) { } return target; } -function remove(target, item) { +function remove2(target, item) { if (Array.isArray(target)) { - const index = target.indexOf(item); - if (index >= 0) { - target.splice(index, 1); + const index2 = target.indexOf(item); + if (index2 >= 0) { + target.splice(index2, 1); } } else { target.delete(item); @@ -7071,8 +20436,8 @@ function asNumber(source, onNaN = 0) { if (source == null) { return onNaN; } - const num = parseInt(source, 10); - return isNaN(num) ? onNaN : num; + const num2 = parseInt(source, 10); + return isNaN(num2) ? onNaN : num2; } function prefixedArray(input, prefix) { const output = []; @@ -7082,7 +20447,7 @@ function prefixedArray(input, prefix) { return output; } function bufferToString(input) { - return (Array.isArray(input) ? Buffer.concat(input) : input).toString("utf-8"); + return (Array.isArray(input) ? Buffer2.concat(input) : input).toString("utf-8"); } function pick(source, properties) { return Object.assign({}, ...properties.map((property) => property in source ? { [property]: source[property] } : {})); @@ -7093,7 +20458,7 @@ function delay(duration = 0) { var NULL; var NOOP; var objectToString; -var init_util = __esm({ +var init_util = __esm2({ "src/lib/utils/util.ts"() { NULL = "\0"; NOOP = () => { @@ -7121,7 +20486,7 @@ var filterString; var filterStringArray; var filterStringOrStringArray; var filterHasLength; -var init_argument_filters = __esm({ +var init_argument_filters = __esm2({ "src/lib/utils/argument-filters.ts"() { init_util(); filterArray = (input) => { @@ -7145,18 +20510,19 @@ var init_argument_filters = __esm({ } }); var ExitCodes; -var init_exit_codes = __esm({ +var init_exit_codes = __esm2({ "src/lib/utils/exit-codes.ts"() { ExitCodes = /* @__PURE__ */ ((ExitCodes2) => { ExitCodes2[ExitCodes2["SUCCESS"] = 0] = "SUCCESS"; ExitCodes2[ExitCodes2["ERROR"] = 1] = "ERROR"; + ExitCodes2[ExitCodes2["NOT_FOUND"] = -2] = "NOT_FOUND"; ExitCodes2[ExitCodes2["UNCLEAN"] = 128] = "UNCLEAN"; return ExitCodes2; })(ExitCodes || {}); } }); var GitOutputStreams; -var init_git_output_streams = __esm({ +var init_git_output_streams = __esm2({ "src/lib/utils/git-output-streams.ts"() { GitOutputStreams = class { constructor(stdOut, stdErr) { @@ -7171,14 +20537,14 @@ var init_git_output_streams = __esm({ }); var LineParser; var RemoteLineParser; -var init_line_parser = __esm({ +var init_line_parser = __esm2({ "src/lib/utils/line-parser.ts"() { LineParser = class { constructor(regExp, useMatches) { this.matches = []; this.parse = (line, target) => { this.resetMatches(); - if (!this._regExp.every((reg, index) => this.addMatch(reg, index, line(index)))) { + if (!this._regExp.every((reg, index2) => this.addMatch(reg, index2, line(index2)))) { return false; } return this.useMatches(target, this.prepareMatches()) !== false; @@ -7197,10 +20563,10 @@ var init_line_parser = __esm({ prepareMatches() { return this.matches; } - addMatch(reg, index, line) { + addMatch(reg, index2, line) { const matched = line && reg.exec(line); if (matched) { - this.pushMatch(index, matched); + this.pushMatch(index2, matched); } return !!matched; } @@ -7209,12 +20575,12 @@ var init_line_parser = __esm({ } }; RemoteLineParser = class extends LineParser { - addMatch(reg, index, line) { - return /^remote:\s/.test(String(line)) && super.addMatch(reg, index, line); + addMatch(reg, index2, line) { + return /^remote:\s/.test(String(line)) && super.addMatch(reg, index2, line); } - pushMatch(index, matched) { - if (index > 0 || matched.length > 1) { - super.pushMatch(index, matched); + pushMatch(index2, matched) { + if (index2 > 0 || matched.length > 1) { + super.pushMatch(index2, matched); } } }; @@ -7222,13 +20588,13 @@ var init_line_parser = __esm({ }); function createInstanceConfig(...options) { const baseDir = process.cwd(); - const config = Object.assign(__spreadValues2({ baseDir }, defaultOptions), ...options.filter((o) => typeof o === "object" && o)); + const config = Object.assign(__spreadValues({ baseDir }, defaultOptions), ...options.filter((o) => typeof o === "object" && o)); config.baseDir = config.baseDir || baseDir; config.trimmed = config.trimmed === true; return config; } var defaultOptions; -var init_simple_git_options = __esm({ +var init_simple_git_options = __esm2({ "src/lib/utils/simple-git-options.ts"() { defaultOptions = { binary: "git", @@ -7277,7 +20643,7 @@ function trailingFunctionArgument(args, includeNoop = true) { const callback = asFunction(last(args)); return includeNoop || isUserFunction(callback) ? callback : void 0; } -var init_task_options = __esm({ +var init_task_options = __esm2({ "src/lib/utils/task-options.ts"() { init_argument_filters(); init_util(); @@ -7286,7 +20652,7 @@ var init_task_options = __esm({ function callTaskParser(parser3, streams) { return parser3(streams.stdOut, streams.stdErr); } -function parseStringResponse(result, parsers11, texts, trim = true) { +function parseStringResponse(result, parsers12, texts, trim = true) { asArray(texts).forEach((text2) => { for (let lines = toLinesWithContent(text2, trim), i = 0, max = lines.length; i < max; i++) { const line = (offset = 0) => { @@ -7295,12 +20661,12 @@ function parseStringResponse(result, parsers11, texts, trim = true) { } return lines[i + offset]; }; - parsers11.some(({ parse }) => parse(line, result)); + parsers12.some(({ parse: parse2 }) => parse2(line, result)); } }); return result; } -var init_task_parser = __esm({ +var init_task_parser = __esm2({ "src/lib/utils/task-parser.ts"() { init_util(); } @@ -7343,13 +20709,13 @@ __export2(utils_exports, { parseStringResponse: () => parseStringResponse, pick: () => pick, prefixedArray: () => prefixedArray, - remove: () => remove, + remove: () => remove2, splitOn: () => splitOn, toLinesWithContent: () => toLinesWithContent, trailingFunctionArgument: () => trailingFunctionArgument, trailingOptionsArgument: () => trailingOptionsArgument }); -var init_utils = __esm({ +var init_utils = __esm2({ "src/lib/utils/index.ts"() { init_argument_filters(); init_exit_codes(); @@ -7409,7 +20775,7 @@ function isNotRepoMessage(error) { var CheckRepoActions; var onError; var parser; -var init_check_is_repo = __esm({ +var init_check_is_repo = __esm2({ "src/lib/tasks/check-is-repo.ts"() { init_utils(); CheckRepoActions = /* @__PURE__ */ ((CheckRepoActions2) => { @@ -7420,7 +20786,7 @@ var init_check_is_repo = __esm({ })(CheckRepoActions || {}); onError = ({ exitCode }, error, done, fail) => { if (exitCode === 128 && isNotRepoMessage(error)) { - return done(Buffer.from("false")); + return done(Buffer2.from("false")); } fail(error); }; @@ -7443,7 +20809,7 @@ var CleanResponse; var removalRegexp; var dryRunRemovalRegexp; var isFolderRegexp; -var init_CleanSummary = __esm({ +var init_CleanSummary = __esm2({ "src/lib/responses/CleanSummary.ts"() { init_utils(); CleanResponse = class { @@ -7498,8 +20864,8 @@ function straightThroughBufferTask(commands) { return { commands, format: "buffer", - parser(buffer) { - return buffer; + parser(buffer2) { + return buffer2; } }; } @@ -7510,7 +20876,7 @@ function isEmptyTask(task) { return task.format === "empty" || !task.commands.length; } var EMPTY_COMMANDS; -var init_task = __esm({ +var init_task = __esm2({ "src/lib/tasks/task.ts"() { init_task_configuration_error(); EMPTY_COMMANDS = []; @@ -7588,7 +20954,7 @@ var CONFIG_ERROR_MODE_REQUIRED; var CONFIG_ERROR_UNKNOWN_OPTION; var CleanOptions; var CleanOptionValues; -var init_clean = __esm({ +var init_clean = __esm2({ "src/lib/tasks/clean.ts"() { init_CleanSummary(); init_utils(); @@ -7659,7 +21025,7 @@ function* configParser(text2, requestedKey = null) { } } var ConfigList; -var init_ConfigList = __esm({ +var init_ConfigList = __esm2({ "src/lib/responses/ConfigList.ts"() { init_utils(); ConfigList = class { @@ -7757,7 +21123,7 @@ function config_default() { }; } var GitConfigScope; -var init_config = __esm({ +var init_config = __esm2({ "src/lib/tasks/config.ts"() { init_ConfigList(); init_utils(); @@ -7818,7 +21184,7 @@ var disallowedOptions; var Query; var _a; var GrepQuery; -var init_grep = __esm({ +var init_grep = __esm2({ "src/lib/tasks/grep.ts"() { init_utils(); init_task(); @@ -7874,7 +21240,7 @@ function isValidResetMode(mode) { } var ResetMode; var ResetModes; -var init_reset = __esm({ +var init_reset = __esm2({ "src/lib/tasks/reset.ts"() { init_task(); ResetMode = /* @__PURE__ */ ((ResetMode2) => { @@ -7936,12 +21302,12 @@ function createLogger(label, verbose, initialStep, infoDebugger = createLog()) { }); } } -var init_git_logger = __esm({ +var init_git_logger = __esm2({ "src/lib/git-logger.ts"() { init_utils(); import_debug.default.formatters.L = (value) => String(filterHasLength(value) ? value.length : "-"); import_debug.default.formatters.B = (value) => { - if (Buffer.isBuffer(value)) { + if (Buffer2.isBuffer(value)) { return value.toString("utf8"); } return objectToString(value); @@ -7950,7 +21316,7 @@ var init_git_logger = __esm({ }); var _TasksPendingQueue; var TasksPendingQueue; -var init_tasks_pending_queue = __esm({ +var init_tasks_pending_queue = __esm2({ "src/lib/runners/tasks-pending-queue.ts"() { init_git_error(); init_git_logger(); @@ -8022,18 +21388,18 @@ function pluginContext(task, commands) { function onErrorReceived(target, logger) { return (err) => { logger(`[ERROR] child process exception %o`, err); - target.push(Buffer.from(String(err.stack), "ascii")); + target.push(Buffer2.from(String(err.stack), "ascii")); }; } function onDataReceived(target, name, logger, output) { - return (buffer) => { - logger(`%s received %L bytes`, name, buffer); - output(`%B`, buffer); - target.push(buffer); + return (buffer2) => { + logger(`%s received %L bytes`, name, buffer2); + output(`%B`, buffer2); + target.push(buffer2); }; } var GitExecutorChain; -var init_git_executor_chain = __esm({ +var init_git_executor_chain = __esm2({ "src/lib/runners/git-executor-chain.ts"() { init_git_error(); init_task(); @@ -8070,7 +21436,7 @@ var init_git_executor_chain = __esm({ return this._chain = this._chain.then(() => this.attemptTask(task)); } attemptTask(task) { - return __async2(this, null, function* () { + return __async(this, null, function* () { const onScheduleComplete = yield this._scheduler.next(); const onQueueComplete = () => this._queue.complete(task); try { @@ -8091,7 +21457,7 @@ var init_git_executor_chain = __esm({ return gitError; } attemptRemoteTask(task, logger) { - return __async2(this, null, function* () { + return __async(this, null, function* () { const args = this._plugins.exec("spawn.args", [...task.commands], pluginContext(task, task.commands)); const raw = yield this.gitResponse(task, this.binary, args, this.outputHandler, logger.step("SPAWN")); const outputStreams = yield this.handleTaskData(task, args, raw, logger.step("HANDLE")); @@ -8103,7 +21469,7 @@ var init_git_executor_chain = __esm({ }); } attemptEmptyTask(task, logger) { - return __async2(this, null, function* () { + return __async(this, null, function* () { logger(`empty task bypassing child process to call to task's parser`); return task.parser(this); }); @@ -8112,13 +21478,13 @@ var init_git_executor_chain = __esm({ const { exitCode, rejection, stdOut, stdErr } = result; return new Promise((done, fail) => { logger(`Preparing to handle process response exitCode=%d stdOut=`, exitCode); - const { error } = this._plugins.exec("task.error", { error: rejection }, __spreadValues2(__spreadValues2({}, pluginContext(task, args)), result)); + const { error } = this._plugins.exec("task.error", { error: rejection }, __spreadValues(__spreadValues({}, pluginContext(task, args)), result)); if (error && task.onError) { logger.info(`exitCode=%s handling with custom error handler`); return task.onError(result, error, (newStdOut) => { logger.info(`custom error handler treated as success`); logger(`custom error returned a %s`, objectToString(newStdOut)); - done(new GitOutputStreams(Array.isArray(newStdOut) ? Buffer.concat(newStdOut) : newStdOut, Buffer.concat(stdErr))); + done(new GitOutputStreams(Array.isArray(newStdOut) ? Buffer2.concat(newStdOut) : newStdOut, Buffer2.concat(stdErr))); }, fail); } if (error) { @@ -8126,11 +21492,11 @@ var init_git_executor_chain = __esm({ return fail(error); } logger.info(`retrieving task output complete`); - done(new GitOutputStreams(Buffer.concat(stdOut), Buffer.concat(stdErr))); + done(new GitOutputStreams(Buffer2.concat(stdOut), Buffer2.concat(stdErr))); }); } gitResponse(task, command, args, outputHandler, logger) { - return __async2(this, null, function* () { + return __async(this, null, function* () { const outputLogger = logger.sibling("output"); const spawnOptions = this._plugins.exec("spawn.options", { cwd: this.cwd, @@ -8140,9 +21506,22 @@ var init_git_executor_chain = __esm({ return new Promise((done) => { const stdOut = []; const stdErr = []; - let rejection; logger.info(`%s %o`, command, args); logger("%O", spawnOptions); + let rejection = this._beforeSpawn(task, args); + if (rejection) { + return done({ + stdOut, + stdErr, + exitCode: 9901, + rejection + }); + } + this._plugins.exec("spawn.before", void 0, __spreadProps(__spreadValues({}, pluginContext(task, args)), { + kill(reason) { + rejection = reason || rejection; + } + })); const spawned = (0, import_child_process.spawn)(command, args, spawnOptions); spawned.stdout.on("data", onDataReceived(stdOut, "stdOut", logger, outputLogger.step("stdOut"))); spawned.stderr.on("data", onDataReceived(stdErr, "stdErr", logger, outputLogger.step("stdErr"))); @@ -8151,7 +21530,7 @@ var init_git_executor_chain = __esm({ logger(`Passing child process stdOut/stdErr to custom outputHandler`); outputHandler(command, spawned.stdout, spawned.stderr, [...args]); } - this._plugins.exec("spawn.after", void 0, __spreadProps2(__spreadValues2({}, pluginContext(task, args)), { + this._plugins.exec("spawn.after", void 0, __spreadProps(__spreadValues({}, pluginContext(task, args)), { spawned, close(exitCode, reason) { done({ @@ -8172,6 +21551,15 @@ var init_git_executor_chain = __esm({ }); }); } + _beforeSpawn(task, args) { + let rejection; + this._plugins.exec("spawn.before", void 0, __spreadProps(__spreadValues({}, pluginContext(task, args)), { + kill(reason) { + rejection = reason || rejection; + } + })); + return rejection; + } }; } }); @@ -8180,7 +21568,7 @@ __export2(git_executor_exports, { GitExecutor: () => GitExecutor }); var GitExecutor; -var init_git_executor = __esm({ +var init_git_executor = __esm2({ "src/lib/runners/git-executor.ts"() { init_git_executor_chain(); GitExecutor = class { @@ -8212,9 +21600,9 @@ function taskCallback(task, response, callback = NOOP) { response.then(onSuccess, onError2); } function addDeprecationNoticeToError(err) { - let log = (name) => { + let log2 = (name) => { console.warn(`simple-git deprecation notice: accessing GitResponseError.${name} should be GitResponseError.git.${name}, this will no longer be available in version 3`); - log = NOOP; + log2 = NOOP; }; return Object.create(err, Object.getOwnPropertyNames(err.git).reduce(descriptorReducer, {})); function descriptorReducer(all, name) { @@ -8225,14 +21613,14 @@ function addDeprecationNoticeToError(err) { enumerable: false, configurable: false, get() { - log(name); + log2(name); return err.git[name]; } }; return all; } } -var init_task_callback = __esm({ +var init_task_callback = __esm2({ "src/lib/task-callback.ts"() { init_git_response_error(); init_utils(); @@ -8246,7 +21634,7 @@ function changeWorkingDirectoryTask(directory, root) { return (root || instance6).cwd = directory; }); } -var init_change_working_directory = __esm({ +var init_change_working_directory = __esm2({ "src/lib/tasks/change-working-directory.ts"() { init_utils(); init_task(); @@ -8267,13 +21655,13 @@ function parseCommitResult(stdOut) { return parseStringResponse(result, parsers, stdOut); } var parsers; -var init_parse_commit = __esm({ +var init_parse_commit = __esm2({ "src/lib/parsers/parse-commit.ts"() { init_utils(); parsers = [ - new LineParser(/^\[([^\s]+)( \([^)]+\))? ([^\]]+)/, (result, [branch, root, commit]) => { - result.branch = branch; - result.commit = commit; + new LineParser(/^\[([^\s]+)( \([^)]+\))? ([^\]]+)/, (result, [branch2, root, commit2]) => { + result.branch = branch2; + result.commit = commit2; result.root = !!root; }), new LineParser(/\s*Author:\s(.+)/i, (result, [author]) => { @@ -8336,7 +21724,7 @@ function commit_default() { return !filterStringOrStringArray(message) && configurationErrorTask(`git.commit: requires the commit message to be supplied as a string/string[]`); } } -var init_commit = __esm({ +var init_commit = __esm2({ "src/lib/tasks/commit.ts"() { init_parse_commit(); init_utils(); @@ -8350,7 +21738,7 @@ function hashObjectTask(filePath, write) { } return straightThroughStringTask(commands, true); } -var init_hash_object = __esm({ +var init_hash_object = __esm2({ "src/lib/tasks/hash-object.ts"() { init_task(); } @@ -8378,7 +21766,7 @@ function parseInit(bare, path2, text2) { var InitSummary; var initResponseRegex; var reInitResponseRegex; -var init_InitSummary = __esm({ +var init_InitSummary = __esm2({ "src/lib/responses/InitSummary.ts"() { InitSummary = class { constructor(bare, path2, existing, gitDir) { @@ -8409,7 +21797,7 @@ function initTask(bare = false, path2, customArgs) { }; } var bareCommand; -var init_init = __esm({ +var init_init = __esm2({ "src/lib/tasks/init.ts"() { init_InitSummary(); bareCommand = "--bare"; @@ -8428,13 +21816,13 @@ function isLogFormat(customArg) { return logFormatRegex.test(customArg); } var logFormatRegex; -var init_log_format = __esm({ +var init_log_format = __esm2({ "src/lib/args/log-format.ts"() { logFormatRegex = /^--(stat|numstat|name-only|name-status)(=|$)/; } }); var DiffSummary; -var init_DiffSummary = __esm({ +var init_DiffSummary = __esm2({ "src/lib/responses/DiffSummary.ts"() { DiffSummary = class { constructor() { @@ -8455,7 +21843,7 @@ var numStatParser; var nameOnlyParser; var nameStatusParser; var diffSummaryParsers; -var init_parse_diff_summary = __esm({ +var init_parse_diff_summary = __esm2({ "src/lib/parsers/parse-diff-summary.ts"() { init_log_format(); init_DiffSummary(); @@ -8545,8 +21933,8 @@ var init_parse_diff_summary = __esm({ } }); function lineBuilder(tokens, fields) { - return fields.reduce((line, field, index) => { - line[field] = tokens[index] || ""; + return fields.reduce((line, field, index2) => { + line[field] = tokens[index2] || ""; return line; }, /* @__PURE__ */ Object.create({ diff: null })); } @@ -8572,7 +21960,7 @@ var START_BOUNDARY; var COMMIT_BOUNDARY; var SPLITTER; var defaultFieldNames; -var init_parse_list_log_summary = __esm({ +var init_parse_list_log_summary = __esm2({ "src/lib/parsers/parse-list-log-summary.ts"() { init_utils(); init_parse_diff_summary(); @@ -8611,7 +21999,7 @@ function validateLogFormatConfig(customArgs) { return configurationErrorTask(`Summary flag ${flags} parsing is not compatible with null termination option '-z'`); } } -var init_diff = __esm({ +var init_diff = __esm2({ "src/lib/tasks/diff.ts"() { init_log_format(); init_parse_diff_summary(); @@ -8695,7 +22083,7 @@ function log_default() { } } var excludeOptions; -var init_log = __esm({ +var init_log = __esm2({ "src/lib/tasks/log.ts"() { init_log_format(); init_parse_list_log_summary(); @@ -8722,7 +22110,7 @@ var init_log = __esm({ }); var MergeSummaryConflict; var MergeSummaryDetail; -var init_MergeSummary = __esm({ +var init_MergeSummary = __esm2({ "src/lib/responses/MergeSummary.ts"() { MergeSummaryConflict = class { constructor(reason, file = null, meta) { @@ -8757,7 +22145,7 @@ var init_MergeSummary = __esm({ }); var PullSummary; var PullFailedSummary; -var init_PullSummary = __esm({ +var init_PullSummary = __esm2({ "src/lib/responses/PullSummary.ts"() { PullSummary = class { constructor() { @@ -8814,7 +22202,7 @@ function asObjectCount(source) { }; } var remoteMessagesObjectParsers; -var init_parse_remote_objects = __esm({ +var init_parse_remote_objects = __esm2({ "src/lib/parsers/parse-remote-objects.ts"() { init_utils(); remoteMessagesObjectParsers = [ @@ -8842,7 +22230,7 @@ function parseRemoteMessages(_stdOut, stdErr) { } var parsers2; var RemoteMessageSummary; -var init_parse_remote_messages = __esm({ +var init_parse_remote_messages = __esm2({ "src/lib/parsers/parse-remote-messages.ts"() { init_utils(); init_parse_remote_objects(); @@ -8881,7 +22269,7 @@ var parsers3; var errorParsers; var parsePullDetail; var parsePullResult; -var init_parse_pull = __esm({ +var init_parse_pull = __esm2({ "src/lib/parsers/parse-pull.ts"() { init_PullSummary(); init_utils(); @@ -8934,7 +22322,7 @@ var init_parse_pull = __esm({ var parsers4; var parseMergeResult; var parseMergeDetail; -var init_parse_merge = __esm({ +var init_parse_merge = __esm2({ "src/lib/parsers/parse-merge.ts"() { init_MergeSummary(); init_utils(); @@ -8946,8 +22334,8 @@ var init_parse_merge = __esm({ new LineParser(/^CONFLICT\s+\((.+)\): Merge conflict in (.+)$/, (summary, [reason, file]) => { summary.conflicts.push(new MergeSummaryConflict(reason, file)); }), - new LineParser(/^CONFLICT\s+\((.+\/delete)\): (.+) deleted in (.+) and/, (summary, [reason, file, deleteRef]) => { - summary.conflicts.push(new MergeSummaryConflict(reason, file, { deleteRef })); + new LineParser(/^CONFLICT\s+\((.+\/delete)\): (.+) deleted in (.+) and/, (summary, [reason, file, deleteRef2]) => { + summary.conflicts.push(new MergeSummaryConflict(reason, file, { deleteRef: deleteRef2 })); }), new LineParser(/^CONFLICT\s+\((.+)\):/, (summary, [reason]) => { summary.conflicts.push(new MergeSummaryConflict(reason, null)); @@ -8972,29 +22360,29 @@ function mergeTask(customArgs) { commands: ["merge", ...customArgs], format: "utf-8", parser(stdOut, stdErr) { - const merge = parseMergeResult(stdOut, stdErr); - if (merge.failed) { - throw new GitResponseError(merge); + const merge2 = parseMergeResult(stdOut, stdErr); + if (merge2.failed) { + throw new GitResponseError(merge2); } - return merge; + return merge2; } }; } -var init_merge = __esm({ +var init_merge = __esm2({ "src/lib/tasks/merge.ts"() { init_git_response_error(); init_parse_merge(); init_task(); } }); -function pushResultPushedItem(local, remote, status) { - const deleted = status.includes("deleted"); - const tag = status.includes("tag") || /^refs\/tags/.test(local); - const alreadyUpdated = !status.includes("new"); +function pushResultPushedItem(local, remote, status2) { + const deleted = status2.includes("deleted"); + const tag2 = status2.includes("tag") || /^refs\/tags/.test(local); + const alreadyUpdated = !status2.includes("new"); return { deleted, - tag, - branch: !tag, + tag: tag2, + branch: !tag2, new: !alreadyUpdated, alreadyUpdated, local, @@ -9004,7 +22392,7 @@ function pushResultPushedItem(local, remote, status) { var parsers5; var parsePushResult; var parsePushDetail; -var init_parse_push = __esm({ +var init_parse_push = __esm2({ "src/lib/parsers/parse-push.ts"() { init_utils(); init_parse_remote_messages(); @@ -9013,7 +22401,7 @@ var init_parse_push = __esm({ result.repo = repo; }), new LineParser(/^updating local tracking ref '(.+)'/, (result, [local]) => { - result.ref = __spreadProps2(__spreadValues2({}, result.ref || {}), { + result.ref = __spreadProps(__spreadValues({}, result.ref || {}), { local }); }), @@ -9021,7 +22409,7 @@ var init_parse_push = __esm({ result.pushed.push(pushResultPushedItem(local, remote, type)); }), new LineParser(/^Branch '([^']+)' set up to track remote branch '([^']+)' from '([^']+)'/, (result, [local, remote, remoteName]) => { - result.branch = __spreadProps2(__spreadValues2({}, result.branch || {}), { + result.branch = __spreadProps(__spreadValues({}, result.branch || {}), { local, remote, remoteName @@ -9043,7 +22431,7 @@ var init_parse_push = __esm({ parsePushResult = (stdOut, stdErr) => { const pushDetail = parsePushDetail(stdOut, stdErr); const responseDetail = parseRemoteMessages(stdOut, stdErr); - return __spreadValues2(__spreadValues2({}, pushDetail), responseDetail); + return __spreadValues(__spreadValues({}, pushDetail), responseDetail); }; parsePushDetail = (stdOut, stdErr) => { return parseStringResponse({ pushed: [] }, parsers5, [stdOut, stdErr]); @@ -9067,7 +22455,7 @@ function pushTask(ref = {}, customArgs) { if (ref.remote) { commands.splice(1, 0, ref.remote); } - remove(commands, "-v"); + remove2(commands, "-v"); append(commands, "--verbose"); append(commands, "--porcelain"); return { @@ -9076,7 +22464,7 @@ function pushTask(ref = {}, customArgs) { parser: parsePushResult }; } -var init_push = __esm({ +var init_push = __esm2({ "src/lib/tasks/push.ts"() { init_parse_push(); init_utils(); @@ -9084,15 +22472,15 @@ var init_push = __esm({ }); var fromPathRegex; var FileStatusSummary; -var init_FileStatusSummary = __esm({ +var init_FileStatusSummary = __esm2({ "src/lib/responses/FileStatusSummary.ts"() { fromPathRegex = /^(.+) -> (.+)$/; FileStatusSummary = class { - constructor(path2, index, working_dir) { + constructor(path2, index2, working_dir) { this.path = path2; - this.index = index; + this.index = index2; this.working_dir = working_dir; - if (index + working_dir === "R") { + if (index2 + working_dir === "R") { const detail = fromPathRegex.exec(path2) || [null, path2, path2]; this.from = detail[1] || ""; this.path = detail[2] || ""; @@ -9124,21 +22512,21 @@ function splitLine(result, lineStr) { default: return; } - function data(index, workingDir, path2) { - const raw = `${index}${workingDir}`; + function data(index2, workingDir, path2) { + const raw = `${index2}${workingDir}`; const handler = parsers6.get(raw); if (handler) { handler(result, path2); } if (raw !== "##" && raw !== "!!") { - result.files.push(new FileStatusSummary(path2.replace(/\0.+$/, ""), index, workingDir)); + result.files.push(new FileStatusSummary(path2.replace(/\0.+$/, ""), index2, workingDir)); } } } var StatusSummary; var parsers6; var parseStatusSummary; -var init_StatusSummary = __esm({ +var init_StatusSummary = __esm2({ "src/lib/responses/StatusSummary.ts"() { init_utils(); init_FileStatusSummary(); @@ -9212,7 +22600,7 @@ var init_StatusSummary = __esm({ ]); parseStatusSummary = function(text2) { const lines = text2.split(NULL); - const status = new StatusSummary(); + const status2 = new StatusSummary(); for (let i = 0, l = lines.length; i < l; ) { let line = lines[i++].trim(); if (!line) { @@ -9221,9 +22609,9 @@ var init_StatusSummary = __esm({ if (line.charAt(0) === "R") { line += NULL + (lines[i++] || ""); } - splitLine(status, line); + splitLine(status2, line); } - return status; + return status2; }; } }); @@ -9245,18 +22633,75 @@ function statusTask(customArgs) { }; } var ignoredOptions; -var init_status = __esm({ +var init_status = __esm2({ "src/lib/tasks/status.ts"() { init_StatusSummary(); ignoredOptions = ["--null", "-z"]; } }); +function versionResponse(major = 0, minor = 0, patch = 0, agent = "", installed = true) { + return Object.defineProperty({ + major, + minor, + patch, + agent, + installed + }, "toString", { + value() { + return `${this.major}.${this.minor}.${this.patch}`; + }, + configurable: false, + enumerable: false + }); +} +function notInstalledResponse() { + return versionResponse(0, 0, 0, "", false); +} +function version_default() { + return { + version() { + return this._runTask({ + commands: ["--version"], + format: "utf-8", + parser: versionParser, + onError(result, error, done, fail) { + if (result.exitCode === -2) { + return done(Buffer2.from(NOT_INSTALLED)); + } + fail(error); + } + }); + } + }; +} +function versionParser(stdOut) { + if (stdOut === NOT_INSTALLED) { + return notInstalledResponse(); + } + return parseStringResponse(versionResponse(0, 0, 0, stdOut), parsers7, stdOut); +} +var NOT_INSTALLED; +var parsers7; +var init_version = __esm2({ + "src/lib/tasks/version.ts"() { + init_utils(); + NOT_INSTALLED = "installed=false"; + parsers7 = [ + new LineParser(/version (\d+)\.(\d+)\.(\d+)(?:\s*\((.+)\))?/, (result, [major, minor, patch, agent = ""]) => { + Object.assign(result, versionResponse(asNumber(major), asNumber(minor), asNumber(patch), agent)); + }), + new LineParser(/version (\d+)\.(\d+)\.(\D+)(.+)?$/, (result, [major, minor, patch, agent = ""]) => { + Object.assign(result, versionResponse(asNumber(major), asNumber(minor), patch, agent)); + }) + ]; + } +}); var simple_git_api_exports = {}; __export2(simple_git_api_exports, { SimpleGitApi: () => SimpleGitApi }); var SimpleGitApi; -var init_simple_git_api = __esm({ +var init_simple_git_api = __esm2({ "src/lib/simple-git-api.ts"() { init_task_callback(); init_change_working_directory(); @@ -9270,6 +22715,7 @@ var init_simple_git_api = __esm({ init_push(); init_status(); init_task(); + init_version(); init_utils(); SimpleGitApi = class { constructor(_executor) { @@ -9309,11 +22755,11 @@ var init_simple_git_api = __esm({ merge() { return this._runTask(mergeTask(getTrailingOptions(arguments)), trailingFunctionArgument(arguments)); } - mergeFromTo(remote, branch) { - if (!(filterString(remote) && filterString(branch))) { + mergeFromTo(remote, branch2) { + if (!(filterString(remote) && filterString(branch2))) { return this._runTask(configurationErrorTask(`Git.mergeFromTo requires that the 'remote' and 'branch' arguments are supplied as strings`)); } - return this._runTask(mergeTask([remote, branch, ...getTrailingOptions(arguments)]), trailingFunctionArgument(arguments, false)); + return this._runTask(mergeTask([remote, branch2, ...getTrailingOptions(arguments)]), trailingFunctionArgument(arguments, false)); } outputHandler(handler) { this._executor.outputHandler = handler; @@ -9333,7 +22779,7 @@ var init_simple_git_api = __esm({ return this._runTask(statusTask(getTrailingOptions(arguments)), trailingFunctionArgument(arguments)); } }; - Object.assign(SimpleGitApi.prototype, commit_default(), config_default(), grep_default(), log_default()); + Object.assign(SimpleGitApi.prototype, commit_default(), config_default(), grep_default(), log_default(), version_default()); } }); var scheduler_exports = {}; @@ -9342,7 +22788,7 @@ __export2(scheduler_exports, { }); var createScheduledTask; var Scheduler; -var init_scheduler = __esm({ +var init_scheduler = __esm2({ "src/lib/runners/scheduler.ts"() { init_utils(); init_git_logger(); @@ -9375,7 +22821,7 @@ var init_scheduler = __esm({ this.logger(`Attempting id=%s`, task.id); task.done(() => { this.logger(`Completing id=`, task.id); - remove(this.running, task); + remove2(this.running, task); this.schedule(); }); } @@ -9395,27 +22841,27 @@ __export2(apply_patch_exports, { function applyPatchTask(patches, customArgs) { return straightThroughStringTask(["apply", ...customArgs, ...patches]); } -var init_apply_patch = __esm({ +var init_apply_patch = __esm2({ "src/lib/tasks/apply-patch.ts"() { init_task(); } }); -function branchDeletionSuccess(branch, hash2) { +function branchDeletionSuccess(branch2, hash2) { return { - branch, + branch: branch2, hash: hash2, success: true }; } -function branchDeletionFailure(branch) { +function branchDeletionFailure(branch2) { return { - branch, + branch: branch2, hash: null, success: false }; } var BranchDeletionBatch; -var init_BranchDeleteSummary = __esm({ +var init_BranchDeleteSummary = __esm2({ "src/lib/responses/BranchDeleteSummary.ts"() { BranchDeletionBatch = class { constructor() { @@ -9434,34 +22880,34 @@ function hasBranchDeletionError(data, processExitCode) { } var deleteSuccessRegex; var deleteErrorRegex; -var parsers7; +var parsers8; var parseBranchDeletions; -var init_parse_branch_delete = __esm({ +var init_parse_branch_delete = __esm2({ "src/lib/parsers/parse-branch-delete.ts"() { init_BranchDeleteSummary(); init_utils(); deleteSuccessRegex = /(\S+)\s+\(\S+\s([^)]+)\)/; deleteErrorRegex = /^error[^']+'([^']+)'/m; - parsers7 = [ - new LineParser(deleteSuccessRegex, (result, [branch, hash2]) => { - const deletion = branchDeletionSuccess(branch, hash2); + parsers8 = [ + new LineParser(deleteSuccessRegex, (result, [branch2, hash2]) => { + const deletion = branchDeletionSuccess(branch2, hash2); result.all.push(deletion); - result.branches[branch] = deletion; + result.branches[branch2] = deletion; }), - new LineParser(deleteErrorRegex, (result, [branch]) => { - const deletion = branchDeletionFailure(branch); + new LineParser(deleteErrorRegex, (result, [branch2]) => { + const deletion = branchDeletionFailure(branch2); result.errors.push(deletion); result.all.push(deletion); - result.branches[branch] = deletion; + result.branches[branch2] = deletion; }) ]; parseBranchDeletions = (stdOut, stdErr) => { - return parseStringResponse(new BranchDeletionBatch(), parsers7, [stdOut, stdErr]); + return parseStringResponse(new BranchDeletionBatch(), parsers8, [stdOut, stdErr]); }; } }); var BranchSummaryResult; -var init_BranchSummary = __esm({ +var init_BranchSummary = __esm2({ "src/lib/responses/BranchSummary.ts"() { BranchSummaryResult = class { constructor() { @@ -9470,17 +22916,17 @@ var init_BranchSummary = __esm({ this.current = ""; this.detached = false; } - push(status, detached, name, commit, label) { - if (status === "*") { + push(status2, detached, name, commit2, label) { + if (status2 === "*") { this.detached = detached; this.current = name; } this.all.push(name); this.branches[name] = { - current: status === "*", - linkedWorkTree: status === "+", + current: status2 === "*", + linkedWorkTree: status2 === "+", name, - commit, + commit: commit2, label }; } @@ -9491,19 +22937,19 @@ function branchStatus(input) { return input ? input.charAt(0) : ""; } function parseBranchSummary(stdOut) { - return parseStringResponse(new BranchSummaryResult(), parsers8, stdOut); + return parseStringResponse(new BranchSummaryResult(), parsers9, stdOut); } -var parsers8; -var init_parse_branch = __esm({ +var parsers9; +var init_parse_branch = __esm2({ "src/lib/parsers/parse-branch.ts"() { init_BranchSummary(); init_utils(); - parsers8 = [ - new LineParser(/^([*+]\s)?\((?:HEAD )?detached (?:from|at) (\S+)\)\s+([a-z0-9]+)\s(.*)$/, (result, [current, name, commit, label]) => { - result.push(branchStatus(current), true, name, commit, label); + parsers9 = [ + new LineParser(/^([*+]\s)?\((?:HEAD )?detached (?:from|at) (\S+)\)\s+([a-z0-9]+)\s(.*)$/, (result, [current, name, commit2, label]) => { + result.push(branchStatus(current), true, name, commit2, label); }), - new LineParser(/^([*+]\s)?(\S+)\s+([a-z0-9]+)\s?(.*)$/s, (result, [current, name, commit, label]) => { - result.push(branchStatus(current), false, name, commit, label); + new LineParser(/^([*+]\s)?(\S+)\s+([a-z0-9]+)\s?(.*)$/s, (result, [current, name, commit2, label]) => { + result.push(branchStatus(current), false, name, commit2, label); }) ]; } @@ -9563,12 +23009,12 @@ function deleteBranchesTask(branches, forceDelete = false) { } }; } -function deleteBranchTask(branch, forceDelete = false) { +function deleteBranchTask(branch2, forceDelete = false) { const task = { format: "utf-8", - commands: ["branch", "-v", forceDelete ? "-D" : "-d", branch], + commands: ["branch", "-v", forceDelete ? "-D" : "-d", branch2], parser(stdOut, stdErr) { - return parseBranchDeletions(stdOut, stdErr).branches[branch]; + return parseBranchDeletions(stdOut, stdErr).branches[branch2]; }, onError({ exitCode, stdErr, stdOut }, error, _, fail) { if (!hasBranchDeletionError(String(error), exitCode)) { @@ -9579,7 +23025,7 @@ function deleteBranchTask(branch, forceDelete = false) { }; return task; } -var init_branch = __esm({ +var init_branch = __esm2({ "src/lib/tasks/branch.ts"() { init_git_response_error(); init_parse_branch_delete(); @@ -9588,7 +23034,7 @@ var init_branch = __esm({ } }); var parseCheckIgnore; -var init_CheckIgnore = __esm({ +var init_CheckIgnore = __esm2({ "src/lib/responses/CheckIgnore.ts"() { parseCheckIgnore = (text2) => { return text2.split(/\n/g).map((line) => line.trim()).filter((file) => !!file); @@ -9606,7 +23052,7 @@ function checkIgnoreTask(paths) { parser: parseCheckIgnore }; } -var init_check_ignore = __esm({ +var init_check_ignore = __esm2({ "src/lib/tasks/check-ignore.ts"() { init_CheckIgnore(); } @@ -9633,7 +23079,7 @@ function cloneMirrorTask(repo, directory, customArgs) { append(customArgs, "--mirror"); return cloneTask(repo, directory, customArgs); } -var init_clone = __esm({ +var init_clone = __esm2({ "src/lib/tasks/clone.ts"() { init_task(); init_utils(); @@ -9648,13 +23094,13 @@ function parseFetchResult(stdOut, stdErr) { updated: [], deleted: [] }; - return parseStringResponse(result, parsers9, [stdOut, stdErr]); + return parseStringResponse(result, parsers10, [stdOut, stdErr]); } -var parsers9; -var init_parse_fetch = __esm({ +var parsers10; +var init_parse_fetch = __esm2({ "src/lib/parsers/parse-fetch.ts"() { init_utils(); - parsers9 = [ + parsers10 = [ new LineParser(/From (.+)$/, (result, [remote]) => { result.remote = remote; }), @@ -9693,10 +23139,10 @@ __export2(fetch_exports, { function disallowedCommand2(command) { return /^--upload-pack(=|$)/.test(command); } -function fetchTask(remote, branch, customArgs) { +function fetchTask(remote, branch2, customArgs) { const commands = ["fetch", ...customArgs]; - if (remote && branch) { - commands.push(remote, branch); + if (remote && branch2) { + commands.push(remote, branch2); } const banned = commands.find(disallowedCommand2); if (banned) { @@ -9708,20 +23154,20 @@ function fetchTask(remote, branch, customArgs) { parser: parseFetchResult }; } -var init_fetch = __esm({ +var init_fetch = __esm2({ "src/lib/tasks/fetch.ts"() { init_parse_fetch(); init_task(); } }); function parseMoveResult(stdOut) { - return parseStringResponse({ moves: [] }, parsers10, stdOut); + return parseStringResponse({ moves: [] }, parsers11, stdOut); } -var parsers10; -var init_parse_move = __esm({ +var parsers11; +var init_parse_move = __esm2({ "src/lib/parsers/parse-move.ts"() { init_utils(); - parsers10 = [ + parsers11 = [ new LineParser(/^Renaming (.+) to (.+)$/, (result, [from, to]) => { result.moves.push({ from, to }); }) @@ -9739,7 +23185,7 @@ function moveTask(from, to) { parser: parseMoveResult }; } -var init_move = __esm({ +var init_move = __esm2({ "src/lib/tasks/move.ts"() { init_parse_move(); init_utils(); @@ -9749,10 +23195,10 @@ var pull_exports = {}; __export2(pull_exports, { pullTask: () => pullTask }); -function pullTask(remote, branch, customArgs) { +function pullTask(remote, branch2, customArgs) { const commands = ["pull", ...customArgs]; - if (remote && branch) { - commands.splice(1, 0, remote, branch); + if (remote && branch2) { + commands.splice(1, 0, remote, branch2); } return { commands, @@ -9769,7 +23215,7 @@ function pullTask(remote, branch, customArgs) { } }; } -var init_pull = __esm({ +var init_pull = __esm2({ "src/lib/tasks/pull.ts"() { init_git_response_error(); init_parse_pull(); @@ -9799,7 +23245,7 @@ function parseGetRemotesVerbose(text2) { function forEach(text2, handler) { forEachLineWithContent(text2, (line) => handler(line.split(/\s+/))); } -var init_GetRemoteSummary = __esm({ +var init_GetRemoteSummary = __esm2({ "src/lib/responses/GetRemoteSummary.ts"() { init_utils(); } @@ -9843,7 +23289,7 @@ function remoteTask(customArgs = []) { function removeRemoteTask(remoteName) { return straightThroughStringTask(["remote", "remove", remoteName]); } -var init_remote = __esm({ +var init_remote = __esm2({ "src/lib/tasks/remote.ts"() { init_GetRemoteSummary(); init_task(); @@ -9863,7 +23309,7 @@ function stashListTask(opt = {}, customArgs) { parser: parser3 }; } -var init_stash_list = __esm({ +var init_stash_list = __esm2({ "src/lib/tasks/stash-list.ts"() { init_log_format(); init_parse_list_log_summary(); @@ -9894,7 +23340,7 @@ function subModuleTask(customArgs) { function updateSubModuleTask(customArgs) { return subModuleTask(["update", ...customArgs]); } -var init_sub_module = __esm({ +var init_sub_module = __esm2({ "src/lib/tasks/sub-module.ts"() { init_task(); } @@ -9921,7 +23367,7 @@ function toNumber(input) { } var TagList; var parseTagList; -var init_TagList = __esm({ +var init_TagList = __esm2({ "src/lib/responses/TagList.ts"() { TagList = class { constructor(all, latest) { @@ -9939,15 +23385,15 @@ var init_TagList = __esm({ return singleSorted(toNumber(partsA[0]), toNumber(partsB[0])); } for (let i = 0, l = Math.max(partsA.length, partsB.length); i < l; i++) { - const diff = sorted(toNumber(partsA[i]), toNumber(partsB[i])); - if (diff) { - return diff; + const diff2 = sorted(toNumber(partsA[i]), toNumber(partsB[i])); + if (diff2) { + return diff2; } } return 0; }); } - const latest = customSort ? tags[0] : [...tags].reverse().find((tag) => tag.indexOf(".") >= 0); + const latest = customSort ? tags[0] : [...tags].reverse().find((tag2) => tag2.indexOf(".") >= 0); return new TagList(tags, latest); }; } @@ -9986,7 +23432,7 @@ function addAnnotatedTagTask(name, tagMessage) { } }; } -var init_tag = __esm({ +var init_tag = __esm2({ "src/lib/tasks/tag.ts"() { init_TagList(); } @@ -10085,11 +23531,11 @@ var require_git = __commonJS2({ }); }); }; - Git2.prototype.pull = function(remote, branch, options, then) { - return this._runTask(pullTask2(filterType2(remote, filterString2), filterType2(branch, filterString2), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + Git2.prototype.pull = function(remote, branch2, options, then) { + return this._runTask(pullTask2(filterType2(remote, filterString2), filterType2(branch2, filterString2), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); }; - Git2.prototype.fetch = function(remote, branch) { - return this._runTask(fetchTask2(filterType2(remote, filterString2), filterType2(branch, filterString2), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + Git2.prototype.fetch = function(remote, branch2) { + return this._runTask(fetchTask2(filterType2(remote, filterString2), filterType2(branch2, filterString2), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); }; Git2.prototype.silent = function(silence) { console.warn("simple-git deprecation notice: git.silent: logging should be configured using the `debug` library / `DEBUG` environment variable, this will be an error in version 3"); @@ -10104,12 +23550,12 @@ var require_git = __commonJS2({ Git2.prototype.reset = function(mode) { return this._runTask(resetTask2(getResetMode2(mode), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); }; - Git2.prototype.revert = function(commit) { + Git2.prototype.revert = function(commit2) { const next = trailingFunctionArgument2(arguments); - if (typeof commit !== "string") { + if (typeof commit2 !== "string") { return this._runTask(configurationErrorTask2("Commit must be a string"), next); } - return this._runTask(straightThroughStringTask2(["revert", ...getTrailingOptions2(arguments, 0, true), commit]), next); + return this._runTask(straightThroughStringTask2(["revert", ...getTrailingOptions2(arguments, 0, true), commit2]), next); }; Git2.prototype.addTag = function(name) { const task = typeof name === "string" ? addTagTask2(name) : configurationErrorTask2("Git.addTag requires a tag name"); @@ -10294,6 +23740,30 @@ init_clean(); init_config(); init_grep(); init_reset(); +function abortPlugin(signal) { + if (!signal) { + return; + } + const onSpawnAfter = { + type: "spawn.after", + action(_data, context) { + function kill() { + context.kill(new GitPluginError(void 0, "abort", "Abort signal received")); + } + signal.addEventListener("abort", kill); + context.spawned.on("close", () => signal.removeEventListener("abort", kill)); + } + }; + const onSpawnBefore = { + type: "spawn.before", + action(_data, context) { + if (signal.aborted) { + context.kill(new GitPluginError(void 0, "abort", "Abort already signaled")); + } + } + }; + return [onSpawnBefore, onSpawnAfter]; +} init_utils(); function commandConfigPrefixingPlugin(configuration) { const prefix = prefixedArray(configuration, "-c"); @@ -10348,7 +23818,7 @@ function completionDetectionPlugin({ return { type: "spawn.after", action(_0, _1) { - return __async2(this, arguments, function* (_data, { spawned, close }) { + return __async(this, arguments, function* (_data, { spawned, close }) { var _a2, _b; const events = createEvents(); let deferClose = true; @@ -10376,7 +23846,7 @@ function isTaskError(result) { return !!(result.exitCode && result.stdErr.length); } function getErrorMessage(result) { - return Buffer.concat([...result.stdOut, ...result.stdErr]); + return Buffer2.concat([...result.stdOut, ...result.stdErr]); } function errorDetectionHandler(overwrite = false, isError = isTaskError, errorMessage = getErrorMessage) { return (error, result) => { @@ -10395,7 +23865,7 @@ function errorDetectionPlugin(config) { stdOut: context.stdOut, exitCode: context.exitCode }); - if (Buffer.isBuffer(error)) { + if (Buffer2.isBuffer(error)) { return { error: new GitError(void 0, error.toString("utf-8")) }; } return { @@ -10473,7 +23943,7 @@ function spawnOptionsPlugin(spawnOptions) { return { type: "spawn.options", action(data) { - return __spreadValues2(__spreadValues2({}, options), data); + return __spreadValues(__spreadValues({}, options), data); } }; } @@ -10523,6 +23993,7 @@ function gitInstanceFactory(baseDir, options) { plugins.add(commandConfigPrefixingPlugin(config.config)); } plugins.add(completionDetectionPlugin(config.completion)); + config.abort && plugins.add(abortPlugin(config.abort)); config.progress && plugins.add(progressMonitorPlugin(config.progress)); config.timeout && plugins.add(timeoutPlugin(config.timeout)); config.spawnOptions && plugins.add(spawnOptionsPlugin(config.spawnOptions)); @@ -10533,84 +24004,57 @@ function gitInstanceFactory(baseDir, options) { init_git_response_error(); var esm_default = gitInstanceFactory; -// src/types.ts -var PluginState; -(function(PluginState2) { - PluginState2[PluginState2["idle"] = 0] = "idle"; - PluginState2[PluginState2["status"] = 1] = "status"; - PluginState2[PluginState2["pull"] = 2] = "pull"; - PluginState2[PluginState2["add"] = 3] = "add"; - PluginState2[PluginState2["commit"] = 4] = "commit"; - PluginState2[PluginState2["push"] = 5] = "push"; - PluginState2[PluginState2["conflicted"] = 6] = "conflicted"; -})(PluginState || (PluginState = {})); -var FileType; -(function(FileType2) { - FileType2[FileType2["staged"] = 0] = "staged"; - FileType2[FileType2["changed"] = 1] = "changed"; - FileType2[FileType2["pulled"] = 2] = "pulled"; -})(FileType || (FileType = {})); - // src/simpleGit.ts var SimpleGit = class extends GitManager { constructor(plugin) { super(plugin); } - setGitInstance(ignoreError = false) { - return __async(this, null, function* () { - if (this.isGitInstalled()) { - const adapter = this.app.vault.adapter; - const path2 = adapter.getBasePath(); - let basePath = path2; - if (this.plugin.settings.basePath) { - const exists2 = yield adapter.exists((0, import_obsidian.normalizePath)(this.plugin.settings.basePath)); - if (exists2) { - basePath = path2 + import_path.sep + this.plugin.settings.basePath; - } else if (!ignoreError) { - new import_obsidian.Notice("ObsidianGit: Base path does not exist"); - } + async setGitInstance(ignoreError = false) { + if (this.isGitInstalled()) { + const adapter = this.app.vault.adapter; + const path2 = adapter.getBasePath(); + let basePath = path2; + if (this.plugin.settings.basePath) { + const exists2 = await adapter.exists((0, import_obsidian6.normalizePath)(this.plugin.settings.basePath)); + if (exists2) { + basePath = path2 + import_path.sep + this.plugin.settings.basePath; + } else if (!ignoreError) { + new import_obsidian6.Notice("ObsidianGit: Base path does not exist"); } - this.git = esm_default({ - baseDir: basePath, - binary: this.plugin.localStorage.getGitPath() || void 0, - config: ["core.quotepath=off"] - }); - this.git.cwd(yield this.git.revparse("--show-toplevel")); } - }); + this.git = esm_default({ + baseDir: basePath, + binary: this.plugin.localStorage.getGitPath() || void 0, + config: ["core.quotepath=off"] + }); + this.git.cwd(await this.git.revparse("--show-toplevel")); + } } - status() { - return __async(this, null, function* () { - this.plugin.setState(PluginState.status); - const status = yield this.git.status((err) => this.onError(err)); - this.plugin.setState(PluginState.idle); - return { - changed: status.files.filter((e) => e.working_dir !== " ").map((e) => { - const res = this.formatPath(e); - return { - path: res.path, - from: res.from, - working_dir: e.working_dir === "?" ? "U" : e.working_dir, - vault_path: this.getVaultPath(res.path) - }; - }), - staged: status.files.filter((e) => e.index !== " " && e.index != "?").map((e) => { - const res = this.formatPath(e, e.index === "R"); - return { - path: res.path, - from: res.from, - index: e.index, - vault_path: this.getVaultPath(res.path) - }; - }), - conflicted: status.conflicted.map((e) => this.formatPath({ - path: e, - from: void 0, - index: void 0, - working_dir: void 0 - }).path) - }; - }); + async status() { + this.plugin.setState(PluginState.status); + const status2 = await this.git.status((err) => this.onError(err)); + this.plugin.setState(PluginState.idle); + return { + changed: status2.files.filter((e) => e.working_dir !== " ").map((e) => { + const res = this.formatPath(e); + return { + path: res.path, + from: res.from, + working_dir: e.working_dir === "?" ? "U" : e.working_dir, + vault_path: this.getVaultPath(res.path) + }; + }), + staged: status2.files.filter((e) => e.index !== " " && e.index != "?").map((e) => { + const res = this.formatPath(e, e.index === "R"); + return { + path: res.path, + from: res.from, + index: e.index, + vault_path: this.getVaultPath(res.path) + }; + }), + conflicted: status2.conflicted.map((path2) => this.formatPath({ path: path2 }).path) + }; } formatPath(path2, renamed = false) { function format(path3) { @@ -10633,286 +24077,244 @@ var SimpleGit = class extends GitManager { }; } } - commitAll(_0) { - return __async(this, arguments, function* ({ message }) { - if (this.plugin.settings.updateSubmodules) { - this.plugin.setState(PluginState.commit); - yield new Promise((resolve, reject) => __async(this, null, function* () { - this.git.outputHandler((cmd, stdout, stderr, args) => __async(this, null, function* () { - if (!(args.contains("submodule") && args.contains("foreach"))) - return; - let body = ""; - let root = this.app.vault.adapter.getBasePath() + (this.plugin.settings.basePath ? "/" + this.plugin.settings.basePath : ""); - stdout.on("data", (chunk) => { - body += chunk.toString("utf8"); - }); - stdout.on("end", () => __async(this, null, function* () { - let submods = body.split("\n"); - submods = submods.map((i) => { - let submod = i.match(/'([^']*)'/); - if (submod != void 0) { - return root + "/" + submod[1] + import_path.sep; - } - }); - submods.reverse(); - for (const item of submods) { - if (item != void 0) { - yield this.git.cwd({ path: item, root: false }).add("-A", (err) => this.onError(err)); - yield this.git.cwd({ path: item, root: false }).commit(yield this.formatCommitMessage(message), (err) => this.onError(err)); - } - } - resolve(); - })); - })); - yield this.git.subModule(["foreach", "--recursive", ""]); - this.git.outputHandler(() => { - }); - })); - } - this.plugin.setState(PluginState.add); - yield this.git.add("-A", (err) => this.onError(err)); + async commitAll({ message }) { + if (this.plugin.settings.updateSubmodules) { this.plugin.setState(PluginState.commit); - return (yield this.git.commit(yield this.formatCommitMessage(message), (err) => this.onError(err))).summary.changes; - }); - } - commit(message) { - return __async(this, null, function* () { - this.plugin.setState(PluginState.commit); - const res = (yield this.git.commit(yield this.formatCommitMessage(message), (err) => this.onError(err))).summary.changes; - this.plugin.setState(PluginState.idle); - return res; - }); - } - stage(path2, relativeToVault) { - return __async(this, null, function* () { - this.plugin.setState(PluginState.add); - path2 = this.getPath(path2, relativeToVault); - yield this.git.add(["--", path2], (err) => this.onError(err)); - this.plugin.setState(PluginState.idle); - }); - } - stageAll(_0) { - return __async(this, arguments, function* ({ dir }) { - this.plugin.setState(PluginState.add); - yield this.git.add(dir != null ? dir : "-A", (err) => this.onError(err)); - this.plugin.setState(PluginState.idle); - }); - } - unstageAll() { - return __async(this, null, function* () { - this.plugin.setState(PluginState.add); - yield this.git.reset([], (err) => this.onError(err)); - this.plugin.setState(PluginState.idle); - }); - } - unstage(path2, relativeToVault) { - return __async(this, null, function* () { - this.plugin.setState(PluginState.add); - path2 = this.getPath(path2, relativeToVault); - yield this.git.reset(["--", path2], (err) => this.onError(err)); - this.plugin.setState(PluginState.idle); - }); - } - discard(filepath) { - return __async(this, null, function* () { - this.plugin.setState(PluginState.add); - yield this.git.checkout(["--", filepath], (err) => this.onError(err)); - this.plugin.setState(PluginState.idle); - }); - } - pull() { - return __async(this, null, function* () { - this.plugin.setState(PluginState.pull); - if (this.plugin.settings.updateSubmodules) - yield this.git.subModule(["update", "--remote", "--merge", "--recursive"], (err) => this.onError(err)); - const branchInfo = yield this.branchInfo(); - const localCommit = yield this.git.revparse([branchInfo.current], (err) => this.onError(err)); - yield this.git.fetch((err) => this.onError(err)); - const upstreamCommit = yield this.git.revparse([branchInfo.tracking], (err) => this.onError(err)); - if (localCommit !== upstreamCommit) { - if (this.plugin.settings.syncMethod === "merge" || this.plugin.settings.syncMethod === "rebase") { - try { - switch (this.plugin.settings.syncMethod) { - case "merge": - yield this.git.merge([branchInfo.tracking]); - break; - case "rebase": - yield this.git.rebase([branchInfo.tracking]); - } - } catch (err) { - this.plugin.displayError(`Pull failed (${this.plugin.settings.syncMethod}): ${err.message}`); + await new Promise(async (resolve, reject) => { + this.git.outputHandler(async (cmd, stdout, stderr, args) => { + if (!(args.contains("submodule") && args.contains("foreach"))) return; - } - } else if (this.plugin.settings.syncMethod === "reset") { - try { - yield this.git.raw(["update-ref", `refs/heads/${branchInfo.current}`, upstreamCommit], (err) => this.onError(err)); - yield this.unstageAll(); - } catch (err) { - this.plugin.displayError(`Sync failed (${this.plugin.settings.syncMethod}): ${err.message}`); - } - } - const afterMergeCommit = yield this.git.revparse([branchInfo.current], (err) => this.onError(err)); - const filesChanged = yield this.git.diff([`${localCommit}..${afterMergeCommit}`, "--name-only"]); - return filesChanged.split(/\r\n|\r|\n/).filter((value) => value.length > 0).map((e) => { - return { - path: e, - working_dir: "P", - vault_path: this.getVaultPath(e) - }; + let body = ""; + const root = this.app.vault.adapter.getBasePath() + (this.plugin.settings.basePath ? "/" + this.plugin.settings.basePath : ""); + stdout.on("data", (chunk) => { + body += chunk.toString("utf8"); + }); + stdout.on("end", async () => { + const submods = body.split("\n"); + const strippedSubmods = submods.map((i) => { + const submod = i.match(/'([^']*)'/); + if (submod != void 0) { + return root + "/" + submod[1] + import_path.sep; + } + }); + strippedSubmods.reverse(); + for (const item of strippedSubmods) { + if (item != void 0) { + await this.git.cwd({ path: item, root: false }).add("-A", (err) => this.onError(err)); + await this.git.cwd({ path: item, root: false }).commit(await this.formatCommitMessage(message), (err) => this.onError(err)); + } + } + resolve(); + }); }); - } else { - return []; - } - }); + await this.git.subModule(["foreach", "--recursive", ""]); + this.git.outputHandler(() => { + }); + }); + } + this.plugin.setState(PluginState.add); + await this.git.add("-A", (err) => this.onError(err)); + this.plugin.setState(PluginState.commit); + return (await this.git.commit(await this.formatCommitMessage(message), (err) => this.onError(err))).summary.changes; } - push() { - return __async(this, null, function* () { - this.plugin.setState(PluginState.status); - const status = yield this.git.status(); - const trackingBranch = status.tracking; - const currentBranch = status.current; - const remoteChangedFiles = (yield this.git.diffSummary([currentBranch, trackingBranch], (err) => this.onError(err))).changed; - this.plugin.setState(PluginState.push); - if (this.plugin.settings.updateSubmodules) { - yield this.git.env(__spreadProps(__spreadValues({}, process.env), { "OBSIDIAN_GIT": 1 })).subModule(["foreach", "--recursive", `tracking=$(git for-each-ref --format='%(upstream:short)' "$(git symbolic-ref -q HEAD)"); echo $tracking; if [ ! -z "$(git diff --shortstat $tracking)" ]; then git push; fi`], (err) => this.onError(err)); - } - yield this.git.env(__spreadProps(__spreadValues({}, process.env), { "OBSIDIAN_GIT": 1 })).push((err) => this.onError(err)); - return remoteChangedFiles; - }); + async commit(message) { + this.plugin.setState(PluginState.commit); + const res = (await this.git.commit(await this.formatCommitMessage(message), (err) => this.onError(err))).summary.changes; + this.plugin.setState(PluginState.idle); + return res; } - canPush() { - return __async(this, null, function* () { - if (this.plugin.settings.updateSubmodules === true) { - return true; - } - const status = yield this.git.status((err) => this.onError(err)); - const trackingBranch = status.tracking; - const currentBranch = status.current; - const remoteChangedFiles = (yield this.git.diffSummary([currentBranch, trackingBranch])).changed; - return remoteChangedFiles !== 0; - }); + async stage(path2, relativeToVault) { + this.plugin.setState(PluginState.add); + path2 = this.getPath(path2, relativeToVault); + await this.git.add(["--", path2], (err) => this.onError(err)); + this.plugin.setState(PluginState.idle); } - checkRequirements() { - return __async(this, null, function* () { - if (!this.isGitInstalled()) { - return "missing-git"; - } - if (!(yield this.git.checkIsRepo())) { - return "missing-repo"; - } - return "valid"; - }); + async stageAll({ dir }) { + this.plugin.setState(PluginState.add); + await this.git.add(dir != null ? dir : "-A", (err) => this.onError(err)); + this.plugin.setState(PluginState.idle); } - branchInfo() { - return __async(this, null, function* () { - const status = yield this.git.status((err) => this.onError(err)); - const branches = yield this.git.branch(["--no-color"], (err) => this.onError(err)); - return { - current: status.current, - tracking: status.tracking, - branches: branches.all - }; - }); + async unstageAll() { + this.plugin.setState(PluginState.add); + await this.git.reset([], (err) => this.onError(err)); + this.plugin.setState(PluginState.idle); } - getRemoteUrl(remote) { - return __async(this, null, function* () { - return (yield this.git.remote(["get-url", remote], (err, url) => this.onError(err))) || void 0; - }); + async unstage(path2, relativeToVault) { + this.plugin.setState(PluginState.add); + path2 = this.getPath(path2, relativeToVault); + await this.git.reset(["--", path2], (err) => this.onError(err)); + this.plugin.setState(PluginState.idle); } - log(file, relativeToVault = true) { - return __async(this, null, function* () { - const path2 = this.getPath(file, relativeToVault); - const res = yield this.git.log({ file: path2 }, (err) => this.onError(err)); - return res.all; - }); + async discard(filepath) { + this.plugin.setState(PluginState.add); + await this.git.checkout(["--", filepath], (err) => this.onError(err)); + this.plugin.setState(PluginState.idle); } - show(commitHash, file, relativeToVault = true) { - return __async(this, null, function* () { - const path2 = this.getPath(file, relativeToVault); - return this.git.show([commitHash + ":" + path2], (err) => this.onError(err)); - }); - } - checkout(branch) { - return __async(this, null, function* () { - yield this.git.checkout(branch, (err) => this.onError(err)); - }); - } - init() { - return __async(this, null, function* () { - yield this.git.init(false, (err) => this.onError(err)); - }); - } - clone(url, dir) { - return __async(this, null, function* () { - yield this.git.clone(url, path.join(this.app.vault.adapter.getBasePath(), dir), [], (err) => this.onError(err)); - }); - } - setConfig(path2, value) { - return __async(this, null, function* () { - yield this.git.addConfig(path2, value, (err) => this.onError(err)); - }); - } - getConfig(path2) { - return __async(this, null, function* () { - const config = yield this.git.listConfig((err) => this.onError(err)); - return config.all[path2]; - }); - } - fetch(remote) { - return __async(this, null, function* () { - yield this.git.fetch(remote != void 0 ? [remote] : [], (err) => this.onError(err)); - }); - } - setRemote(name, url) { - return __async(this, null, function* () { - if ((yield this.getRemotes()).includes(name)) - yield this.git.remote(["set-url", name, url], (err) => this.onError(err)); - else { - yield this.git.remote(["add", name, url], (err) => this.onError(err)); - } - }); - } - getRemoteBranches(remote) { - return __async(this, null, function* () { - const res = yield this.git.branch(["-r", "--list", `${remote}*`], (err) => this.onError(err)); - console.log(remote); - console.log(res); - const list = []; - for (var item in res.branches) { - list.push(res.branches[item].name); - } - return list; - }); - } - getRemotes() { - return __async(this, null, function* () { - const res = yield this.git.remote([], (err) => this.onError(err)); - if (res) { - return res.trim().split("\n"); - } else { - return []; - } - }); - } - removeRemote(remoteName) { - return __async(this, null, function* () { - yield this.git.removeRemote(remoteName); - }); - } - updateUpstreamBranch(remoteBranch) { - return __async(this, null, function* () { - try { - yield this.git.branch(["--set-upstream-to", remoteBranch]); - } catch (e) { - console.error(e); + async pull() { + this.plugin.setState(PluginState.pull); + if (this.plugin.settings.updateSubmodules) + await this.git.subModule(["update", "--remote", "--merge", "--recursive"], (err) => this.onError(err)); + const branchInfo = await this.branchInfo(); + const localCommit = await this.git.revparse([branchInfo.current], (err) => this.onError(err)); + await this.git.fetch((err) => this.onError(err)); + const upstreamCommit = await this.git.revparse([branchInfo.tracking], (err) => this.onError(err)); + if (localCommit !== upstreamCommit) { + if (this.plugin.settings.syncMethod === "merge" || this.plugin.settings.syncMethod === "rebase") { try { - yield this.git.branch(["--set-upstream", remoteBranch]); - } catch (e2) { - console.error(e2); - yield this.git.push(["--set-upstream", ...remoteBranch.split("/")], (err) => this.onError(err)); + switch (this.plugin.settings.syncMethod) { + case "merge": + await this.git.merge([branchInfo.tracking]); + break; + case "rebase": + await this.git.rebase([branchInfo.tracking]); + } + } catch (err) { + this.plugin.displayError(`Pull failed (${this.plugin.settings.syncMethod}): ${err.message}`); + return; + } + } else if (this.plugin.settings.syncMethod === "reset") { + try { + await this.git.raw(["update-ref", `refs/heads/${branchInfo.current}`, upstreamCommit], (err) => this.onError(err)); + await this.unstageAll(); + } catch (err) { + this.plugin.displayError(`Sync failed (${this.plugin.settings.syncMethod}): ${err.message}`); } } - }); + const afterMergeCommit = await this.git.revparse([branchInfo.current], (err) => this.onError(err)); + const filesChanged = await this.git.diff([`${localCommit}..${afterMergeCommit}`, "--name-only"]); + return filesChanged.split(/\r\n|\r|\n/).filter((value) => value.length > 0).map((e) => { + return { + path: e, + working_dir: "P", + vault_path: this.getVaultPath(e) + }; + }); + } else { + return []; + } + } + async push() { + this.plugin.setState(PluginState.status); + const status2 = await this.git.status(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const remoteChangedFiles = (await this.git.diffSummary([currentBranch2, trackingBranch, "--"], (err) => this.onError(err))).changed; + this.plugin.setState(PluginState.push); + if (this.plugin.settings.updateSubmodules) { + await this.git.env({ ...process.env, "OBSIDIAN_GIT": 1 }).subModule(["foreach", "--recursive", `tracking=$(git for-each-ref --format='%(upstream:short)' "$(git symbolic-ref -q HEAD)"); echo $tracking; if [ ! -z "$(git diff --shortstat $tracking)" ]; then git push; fi`], (err) => this.onError(err)); + } + await this.git.env({ ...process.env, "OBSIDIAN_GIT": 1 }).push((err) => this.onError(err)); + return remoteChangedFiles; + } + async canPush() { + if (this.plugin.settings.updateSubmodules === true) { + return true; + } + const status2 = await this.git.status((err) => this.onError(err)); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const remoteChangedFiles = (await this.git.diffSummary([currentBranch2, trackingBranch, "--"])).changed; + return remoteChangedFiles !== 0; + } + async checkRequirements() { + if (!this.isGitInstalled()) { + return "missing-git"; + } + if (!await this.git.checkIsRepo()) { + return "missing-repo"; + } + return "valid"; + } + async branchInfo() { + const status2 = await this.git.status((err) => this.onError(err)); + const branches = await this.git.branch(["--no-color"], (err) => this.onError(err)); + return { + current: status2.current || void 0, + tracking: status2.tracking || void 0, + branches: branches.all + }; + } + async getRemoteUrl(remote) { + return await this.git.remote(["get-url", remote], (err, url) => this.onError(err)) || void 0; + } + async log(file, relativeToVault = true) { + const path2 = this.getPath(file, relativeToVault); + const res = await this.git.log({ file: path2 }, (err) => this.onError(err)); + return res.all; + } + async show(commitHash, file, relativeToVault = true) { + const path2 = this.getPath(file, relativeToVault); + return this.git.show([commitHash + ":" + path2], (err) => this.onError(err)); + } + async checkout(branch2) { + await this.git.checkout(branch2, (err) => this.onError(err)); + } + async createBranch(branch2) { + await this.git.checkout(["-b", branch2], (err) => this.onError(err)); + } + async deleteBranch(branch2, force) { + await this.git.branch([force ? "-D" : "-d", branch2], (err) => this.onError(err)); + } + async branchIsMerged(branch2) { + const notMergedBranches = await this.git.branch(["--no-merged"], (err) => this.onError(err)); + return !notMergedBranches.all.contains(branch2); + } + async init() { + await this.git.init(false, (err) => this.onError(err)); + } + async clone(url, dir) { + await this.git.clone(url, path.join(this.app.vault.adapter.getBasePath(), dir), [], (err) => this.onError(err)); + } + async setConfig(path2, value) { + await this.git.addConfig(path2, value, (err) => this.onError(err)); + } + async getConfig(path2) { + const config = await this.git.listConfig((err) => this.onError(err)); + return config.all[path2]; + } + async fetch(remote) { + await this.git.fetch(remote != void 0 ? [remote] : [], (err) => this.onError(err)); + } + async setRemote(name, url) { + if ((await this.getRemotes()).includes(name)) + await this.git.remote(["set-url", name, url], (err) => this.onError(err)); + else { + await this.git.remote(["add", name, url], (err) => this.onError(err)); + } + } + async getRemoteBranches(remote) { + const res = await this.git.branch(["-r", "--list", `${remote}*`], (err) => this.onError(err)); + console.log(remote); + console.log(res); + const list = []; + for (const item in res.branches) { + list.push(res.branches[item].name); + } + return list; + } + async getRemotes() { + const res = await this.git.remote([], (err) => this.onError(err)); + if (res) { + return res.trim().split("\n"); + } else { + return []; + } + } + async removeRemote(remoteName) { + await this.git.removeRemote(remoteName); + } + async updateUpstreamBranch(remoteBranch) { + try { + await this.git.branch(["--set-upstream-to", remoteBranch]); + } catch (e) { + console.error(e); + try { + await this.git.branch(["--set-upstream", remoteBranch]); + } catch (e2) { + console.error(e2); + await this.git.push(["--set-upstream", ...remoteBranch.split("/")], (err) => this.onError(err)); + } + } } updateGitPath(gitPath) { this.setGitInstance(); @@ -10920,18 +24322,14 @@ var SimpleGit = class extends GitManager { updateBasePath(basePath) { this.setGitInstance(true); } - getDiffString(filePath, stagedChanges = false) { - return __async(this, null, function* () { - if (stagedChanges) - return yield this.git.diff(["--cached", "--", filePath]); - else - return yield this.git.diff(["--", filePath]); - }); + async getDiffString(filePath, stagedChanges = false) { + if (stagedChanges) + return await this.git.diff(["--cached", "--", filePath]); + else + return await this.git.diff(["--", filePath]); } - diff(file, commit1, commit2) { - return __async(this, null, function* () { - return yield this.git.diff([`${commit1}..${commit2}`, "--", file]); - }); + async diff(file, commit1, commit2) { + return await this.git.diff([`${commit1}..${commit2}`, "--", file]); } isGitInstalled() { const command = (0, import_child_process2.spawnSync)(this.plugin.localStorage.getGitPath() || "git", ["--version"], { @@ -10945,7 +24343,7 @@ var SimpleGit = class extends GitManager { } onError(error) { if (error) { - let networkFailure = error.message.contains("Could not resolve host") || error.message.match(/ssh: connect to host .*? port .*?: Operation timed out/); + const networkFailure = error.message.contains("Could not resolve host") || error.message.match(/ssh: connect to host .*? port .*?: Operation timed out/); if (!networkFailure) { this.plugin.displayError(error.message); this.plugin.setState(PluginState.idle); @@ -10961,9 +24359,9 @@ var SimpleGit = class extends GitManager { }; // src/settings.ts -var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { +var ObsidianGitSettingsTab = class extends import_obsidian7.PluginSettingTab { display() { - let { containerEl } = this; + const { containerEl } = this; const plugin = this.plugin; const commitOrBackup = plugin.settings.differentIntervalCommitAndPush ? "commit" : "backup"; const gitReady = plugin.gitReady; @@ -10975,7 +24373,7 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { if (gitReady) { containerEl.createEl("br"); containerEl.createEl("h3", { text: "Automatic" }); - new import_obsidian2.Setting(containerEl).setName("Split automatic commit and push").setDesc("Enable to use separate timer for commit and push").addToggle((toggle) => toggle.setValue(plugin.settings.differentIntervalCommitAndPush).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Split automatic commit and push").setDesc("Enable to use separate timer for commit and push").addToggle((toggle) => toggle.setValue(plugin.settings.differentIntervalCommitAndPush).onChange((value) => { plugin.settings.differentIntervalCommitAndPush = value; plugin.saveSettings(); plugin.clearAutoBackup(); @@ -10988,22 +24386,22 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { } this.display(); })); - new import_obsidian2.Setting(containerEl).setName(`Vault ${commitOrBackup} interval (minutes)`).setDesc(`${plugin.settings.differentIntervalCommitAndPush ? "Commit" : "Commit and push"} changes every X minutes. Set to 0 (default) to disable. (See below setting for further configuration!)`).addText((text2) => text2.setValue(String(plugin.settings.autoSaveInterval)).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName(`Vault ${commitOrBackup} interval (minutes)`).setDesc(`${plugin.settings.differentIntervalCommitAndPush ? "Commit" : "Commit and push"} changes every X minutes. Set to 0 (default) to disable. (See below setting for further configuration!)`).addText((text2) => text2.setValue(String(plugin.settings.autoSaveInterval)).onChange((value) => { if (!isNaN(Number(value))) { plugin.settings.autoSaveInterval = Number(value); plugin.saveSettings(); if (plugin.settings.autoSaveInterval > 0) { plugin.clearAutoBackup(); plugin.startAutoBackup(plugin.settings.autoSaveInterval); - new import_obsidian2.Notice(`Automatic ${commitOrBackup} enabled! Every ${plugin.settings.autoSaveInterval} minutes.`); + new import_obsidian7.Notice(`Automatic ${commitOrBackup} enabled! Every ${plugin.settings.autoSaveInterval} minutes.`); } else if (plugin.settings.autoSaveInterval <= 0) { - plugin.clearAutoBackup() && new import_obsidian2.Notice(`Automatic ${commitOrBackup} disabled!`); + plugin.clearAutoBackup() && new import_obsidian7.Notice(`Automatic ${commitOrBackup} disabled!`); } } else { - new import_obsidian2.Notice("Please specify a valid number."); + new import_obsidian7.Notice("Please specify a valid number."); } })); - new import_obsidian2.Setting(containerEl).setName(`If turned on, do auto ${commitOrBackup} every X minutes after last change. Prevents auto ${commitOrBackup} while editing a file. If turned off, do auto ${commitOrBackup} every X minutes. It's independent from last change.`).addToggle((toggle) => toggle.setValue(plugin.settings.autoBackupAfterFileChange).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName(`If turned on, do auto ${commitOrBackup} every X minutes after last change. Prevents auto ${commitOrBackup} while editing a file. If turned off, do auto ${commitOrBackup} every X minutes. It's independent from last change.`).addToggle((toggle) => toggle.setValue(plugin.settings.autoBackupAfterFileChange).onChange((value) => { plugin.settings.autoBackupAfterFileChange = value; plugin.saveSettings(); plugin.clearAutoBackup(); @@ -11012,70 +24410,73 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { } })); if (plugin.settings.differentIntervalCommitAndPush) { - new import_obsidian2.Setting(containerEl).setName(`Vault push interval (minutes)`).setDesc("Push changes every X minutes. Set to 0 (default) to disable.").addText((text2) => text2.setValue(String(plugin.settings.autoPushInterval)).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName(`Vault push interval (minutes)`).setDesc("Push changes every X minutes. Set to 0 (default) to disable.").addText((text2) => text2.setValue(String(plugin.settings.autoPushInterval)).onChange((value) => { if (!isNaN(Number(value))) { plugin.settings.autoPushInterval = Number(value); plugin.saveSettings(); if (plugin.settings.autoPushInterval > 0) { plugin.clearAutoPush(); plugin.startAutoPush(plugin.settings.autoPushInterval); - new import_obsidian2.Notice(`Automatic push enabled! Every ${plugin.settings.autoPushInterval} minutes.`); + new import_obsidian7.Notice(`Automatic push enabled! Every ${plugin.settings.autoPushInterval} minutes.`); } else if (plugin.settings.autoPushInterval <= 0) { - plugin.clearAutoPush() && new import_obsidian2.Notice("Automatic push disabled!"); + plugin.clearAutoPush() && new import_obsidian7.Notice("Automatic push disabled!"); } } else { - new import_obsidian2.Notice("Please specify a valid number."); + new import_obsidian7.Notice("Please specify a valid number."); } })); } - new import_obsidian2.Setting(containerEl).setName("Auto pull interval (minutes)").setDesc("Pull changes every X minutes. Set to 0 (default) to disable.").addText((text2) => text2.setValue(String(plugin.settings.autoPullInterval)).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Auto pull interval (minutes)").setDesc("Pull changes every X minutes. Set to 0 (default) to disable.").addText((text2) => text2.setValue(String(plugin.settings.autoPullInterval)).onChange((value) => { if (!isNaN(Number(value))) { plugin.settings.autoPullInterval = Number(value); plugin.saveSettings(); if (plugin.settings.autoPullInterval > 0) { plugin.clearAutoPull(); plugin.startAutoPull(plugin.settings.autoPullInterval); - new import_obsidian2.Notice(`Automatic pull enabled! Every ${plugin.settings.autoPullInterval} minutes.`); + new import_obsidian7.Notice(`Automatic pull enabled! Every ${plugin.settings.autoPullInterval} minutes.`); } else if (plugin.settings.autoPullInterval <= 0) { - plugin.clearAutoPull() && new import_obsidian2.Notice("Automatic pull disabled!"); + plugin.clearAutoPull() && new import_obsidian7.Notice("Automatic pull disabled!"); } } else { - new import_obsidian2.Notice("Please specify a valid number."); + new import_obsidian7.Notice("Please specify a valid number."); } })); - new import_obsidian2.Setting(containerEl).setName("Commit message on manual backup/commit").setDesc("Available placeholders: {{date}} (see below), {{hostname}} (see below) and {{numFiles}} (number of changed files in the commit)").addText((text2) => text2.setPlaceholder("vault backup: {{date}}").setValue(plugin.settings.commitMessage ? plugin.settings.commitMessage : "").onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Commit message on manual backup/commit").setDesc("Available placeholders: {{date}} (see below), {{hostname}} (see below) and {{numFiles}} (number of changed files in the commit)").addText((text2) => text2.setPlaceholder("vault backup: {{date}}").setValue(plugin.settings.commitMessage ? plugin.settings.commitMessage : "").onChange((value) => { plugin.settings.commitMessage = value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Specify custom commit message on auto backup").setDesc("You will get a pop up to specify your message").addToggle((toggle) => toggle.setValue(plugin.settings.customMessageOnAutoBackup).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Specify custom commit message on auto backup").setDesc("You will get a pop up to specify your message").addToggle((toggle) => toggle.setValue(plugin.settings.customMessageOnAutoBackup).onChange((value) => { plugin.settings.customMessageOnAutoBackup = value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Commit message on auto backup/commit").setDesc("Available placeholders: {{date}} (see below), {{hostname}} (see below) and {{numFiles}} (number of changed files in the commit)").addText((text2) => text2.setPlaceholder("vault backup: {{date}}").setValue(plugin.settings.autoCommitMessage).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Commit message on auto backup/commit").setDesc("Available placeholders: {{date}} (see below), {{hostname}} (see below) and {{numFiles}} (number of changed files in the commit)").addText((text2) => text2.setPlaceholder("vault backup: {{date}}").setValue(plugin.settings.autoCommitMessage).onChange((value) => { plugin.settings.autoCommitMessage = value; plugin.saveSettings(); })); containerEl.createEl("br"); containerEl.createEl("h3", { text: "Commit message" }); - new import_obsidian2.Setting(containerEl).setName("{{date}} placeholder format").setDesc('Specify custom date format. E.g. "YYYY-MM-DD HH:mm:ss"').addText((text2) => text2.setPlaceholder(plugin.settings.commitDateFormat).setValue(plugin.settings.commitDateFormat).onChange((value) => __async(this, null, function* () { + new import_obsidian7.Setting(containerEl).setName("{{date}} placeholder format").setDesc('Specify custom date format. E.g. "YYYY-MM-DD HH:mm:ss"').addText((text2) => text2.setPlaceholder(plugin.settings.commitDateFormat).setValue(plugin.settings.commitDateFormat).onChange(async (value) => { plugin.settings.commitDateFormat = value; - yield plugin.saveSettings(); - }))); - new import_obsidian2.Setting(containerEl).setName("{{hostname}} placeholder replacement").setDesc("Specify custom hostname for every device.").addText((text2) => text2.setValue(plugin.localStorage.getHostname()).onChange((value) => __async(this, null, function* () { - plugin.localStorage.setHostname(value); - }))); - new import_obsidian2.Setting(containerEl).setName("Preview commit message").addButton((button) => button.setButtonText("Preview").onClick(() => __async(this, null, function* () { - let commitMessagePreview = yield plugin.gitManager.formatCommitMessage(plugin.settings.commitMessage); - new import_obsidian2.Notice(`${commitMessagePreview}`); - }))); - new import_obsidian2.Setting(containerEl).setName("List filenames affected by commit in the commit body").addToggle((toggle) => toggle.setValue(plugin.settings.listChangedFilesInMessageBody).onChange((value) => { + await plugin.saveSettings(); + })); + new import_obsidian7.Setting(containerEl).setName("{{hostname}} placeholder replacement").setDesc("Specify custom hostname for every device.").addText((text2) => { + var _a2; + return text2.setValue((_a2 = plugin.localStorage.getHostname()) != null ? _a2 : "").onChange(async (value) => { + plugin.localStorage.setHostname(value); + }); + }); + new import_obsidian7.Setting(containerEl).setName("Preview commit message").addButton((button) => button.setButtonText("Preview").onClick(async () => { + const commitMessagePreview = await plugin.gitManager.formatCommitMessage(plugin.settings.commitMessage); + new import_obsidian7.Notice(`${commitMessagePreview}`); + })); + new import_obsidian7.Setting(containerEl).setName("List filenames affected by commit in the commit body").addToggle((toggle) => toggle.setValue(plugin.settings.listChangedFilesInMessageBody).onChange((value) => { plugin.settings.listChangedFilesInMessageBody = value; plugin.saveSettings(); })); containerEl.createEl("br"); containerEl.createEl("h3", { text: "Backup" }); if (plugin.gitManager instanceof SimpleGit) - new import_obsidian2.Setting(containerEl).setName("Sync Method").setDesc("Selects the method used for handling new changes found in your remote git repository.").addDropdown((dropdown) => { + new import_obsidian7.Setting(containerEl).setName("Sync Method").setDesc("Selects the method used for handling new changes found in your remote git repository.").addDropdown((dropdown) => { const options = { "merge": "Merge", "rebase": "Rebase", @@ -11083,64 +24484,62 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { }; dropdown.addOptions(options); dropdown.setValue(plugin.settings.syncMethod); - dropdown.onChange((option) => __async(this, null, function* () { + dropdown.onChange(async (option) => { plugin.settings.syncMethod = option; plugin.saveSettings(); - })); + }); }); - new import_obsidian2.Setting(containerEl).setName("Pull updates on startup").setDesc("Automatically pull updates when Obsidian starts").addToggle((toggle) => toggle.setValue(plugin.settings.autoPullOnBoot).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Pull updates on startup").setDesc("Automatically pull updates when Obsidian starts").addToggle((toggle) => toggle.setValue(plugin.settings.autoPullOnBoot).onChange((value) => { plugin.settings.autoPullOnBoot = value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Push on backup").setDesc("Disable to only commit changes").addToggle((toggle) => toggle.setValue(!plugin.settings.disablePush).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Push on backup").setDesc("Disable to only commit changes").addToggle((toggle) => toggle.setValue(!plugin.settings.disablePush).onChange((value) => { plugin.settings.disablePush = !value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Pull changes before push").setDesc("Commit -> pull -> push (Only if pushing is enabled)").addToggle((toggle) => toggle.setValue(plugin.settings.pullBeforePush).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Pull changes before push").setDesc("Commit -> pull -> push (Only if pushing is enabled)").addToggle((toggle) => toggle.setValue(plugin.settings.pullBeforePush).onChange((value) => { plugin.settings.pullBeforePush = value; plugin.saveSettings(); })); } containerEl.createEl("br"); containerEl.createEl("h3", { text: "Miscellaneous" }); - if (gitReady) - new import_obsidian2.Setting(containerEl).setName("Current branch").setDesc("Switch to a different branch").addDropdown((dropdown) => __async(this, null, function* () { - const branchInfo = yield plugin.gitManager.branchInfo(); - for (const branch of branchInfo.branches) { - dropdown.addOption(branch, branch); - } - dropdown.setValue(branchInfo.current); - dropdown.onChange((option) => __async(this, null, function* () { - yield plugin.gitManager.checkout(option); - new import_obsidian2.Notice(`Checked out to ${option}`); - })); - })); - new import_obsidian2.Setting(containerEl).setName("Automatically refresh Source Control View on file changes").setDesc("On slower machines this may cause lags. If so, just disable this option").addToggle((toggle) => toggle.setValue(plugin.settings.refreshSourceControl).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Automatically refresh Source Control View on file changes").setDesc("On slower machines this may cause lags. If so, just disable this option").addToggle((toggle) => toggle.setValue(plugin.settings.refreshSourceControl).onChange((value) => { plugin.settings.refreshSourceControl = value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Disable notifications").setDesc("Disable notifications for git operations to minimize distraction (refer to status bar for updates). Errors are still shown as notifications even if you enable this setting").addToggle((toggle) => toggle.setValue(plugin.settings.disablePopups).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Source Control View refresh interval").setDesc("Milliseconds to wait after file change before refreshing the Source Control View").addText((toggle) => toggle.setValue(plugin.settings.refreshSourceControlTimer.toString()).setPlaceholder("7000").onChange((value) => { + plugin.settings.refreshSourceControlTimer = Math.max(parseInt(value), 500); + plugin.saveSettings(); + plugin.setRefreshDebouncer(); + })); + new import_obsidian7.Setting(containerEl).setName("Disable notifications").setDesc("Disable notifications for git operations to minimize distraction (refer to status bar for updates). Errors are still shown as notifications even if you enable this setting").addToggle((toggle) => toggle.setValue(plugin.settings.disablePopups).onChange((value) => { plugin.settings.disablePopups = value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Show status bar").setDesc("Obsidian must be restarted for the changes to take affect").addToggle((toggle) => toggle.setValue(plugin.settings.showStatusBar).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Show status bar").setDesc("Obsidian must be restarted for the changes to take affect").addToggle((toggle) => toggle.setValue(plugin.settings.showStatusBar).onChange((value) => { plugin.settings.showStatusBar = value; plugin.saveSettings(); })); - new import_obsidian2.Setting(containerEl).setName("Show changes files count in status bar").addToggle((toggle) => toggle.setValue(plugin.settings.changedFilesInStatusBar).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Show branch status bar").setDesc("Obsidian must be restarted for the changes to take affect").addToggle((toggle) => toggle.setValue(plugin.settings.showBranchStatusBar).onChange((value) => { + plugin.settings.showBranchStatusBar = value; + plugin.saveSettings(); + })); + new import_obsidian7.Setting(containerEl).setName("Show changes files count in status bar").addToggle((toggle) => toggle.setValue(plugin.settings.changedFilesInStatusBar).onChange((value) => { plugin.settings.changedFilesInStatusBar = value; plugin.saveSettings(); })); containerEl.createEl("br"); containerEl.createEl("h3", { text: "Advanced" }); if (plugin.gitManager instanceof SimpleGit) - new import_obsidian2.Setting(containerEl).setName("Update submodules").setDesc('"Create backup" and "pull" takes care of submodules. Missing features: Conflicted files, count of pulled/pushed/committed files. Tracking branch needs to be set for each submodule').addToggle((toggle) => toggle.setValue(plugin.settings.updateSubmodules).onChange((value) => { + new import_obsidian7.Setting(containerEl).setName("Update submodules").setDesc('"Create backup" and "pull" takes care of submodules. Missing features: Conflicted files, count of pulled/pushed/committed files. Tracking branch needs to be set for each submodule').addToggle((toggle) => toggle.setValue(plugin.settings.updateSubmodules).onChange((value) => { plugin.settings.updateSubmodules = value; plugin.saveSettings(); })); if (plugin.gitManager instanceof SimpleGit) - new import_obsidian2.Setting(containerEl).setName("Custom Git binary path").addText((cb) => { - cb.setValue(plugin.localStorage.getGitPath()); + new import_obsidian7.Setting(containerEl).setName("Custom Git binary path").addText((cb) => { + var _a2; + cb.setValue((_a2 = plugin.localStorage.getGitPath()) != null ? _a2 : ""); cb.setPlaceholder("git"); cb.onChange((value) => { plugin.localStorage.setGitPath(value); @@ -11148,7 +24547,7 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { }); }); if (plugin.gitManager instanceof IsomorphicGit) - new import_obsidian2.Setting(containerEl).setName("Username on your git server. E.g. your username on GitHub").addText((cb) => { + new import_obsidian7.Setting(containerEl).setName("Username on your git server. E.g. your username on GitHub").addText((cb) => { cb.setValue(plugin.settings.username); cb.onChange((value) => { plugin.settings.username = value; @@ -11156,7 +24555,7 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { }); }); if (plugin.gitManager instanceof IsomorphicGit) - new import_obsidian2.Setting(containerEl).setName("Password/Personal access token").setDesc("Type in your password and press on the button to set it. You won't be able to see it again.").addText((cb) => { + new import_obsidian7.Setting(containerEl).setName("Password/Personal access token").setDesc("Type in your password. You won't be able to see it again.").addText((cb) => { cb.inputEl.autocapitalize = "off"; cb.inputEl.autocomplete = "off"; cb.inputEl.spellcheck = false; @@ -11165,20 +24564,20 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { }); }); if (gitReady) - new import_obsidian2.Setting(containerEl).setName("Author name for commit").addText((cb) => __async(this, null, function* () { - cb.setValue(yield plugin.gitManager.getConfig("user.name")); + new import_obsidian7.Setting(containerEl).setName("Author name for commit").addText(async (cb) => { + cb.setValue(await plugin.gitManager.getConfig("user.name")); cb.onChange((value) => { plugin.gitManager.setConfig("user.name", value); }); - })); + }); if (gitReady) - new import_obsidian2.Setting(containerEl).setName("Author email for commit").addText((cb) => __async(this, null, function* () { - cb.setValue(yield plugin.gitManager.getConfig("user.email")); + new import_obsidian7.Setting(containerEl).setName("Author email for commit").addText(async (cb) => { + cb.setValue(await plugin.gitManager.getConfig("user.email")); cb.onChange((value) => { plugin.gitManager.setConfig("user.email", value); }); - })); - new import_obsidian2.Setting(containerEl).setName("Custom base path (Git repository path)").setDesc(` + }); + new import_obsidian7.Setting(containerEl).setName("Custom base path (Git repository path)").setDesc(` Sets the relative path to the vault from which the Git binary should be executed. Mostly used to set the path to the Git repository, which is only required if the Git repository is below the vault root directory. Use "\\" instead of "/" on Windows. `).addText((cb) => { @@ -11190,7 +24589,16 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { plugin.gitManager.updateBasePath(value || ""); }); }); - new import_obsidian2.Setting(containerEl).setName("Donate").setDesc("If you like this Plugin, consider donating to support continued development.").addButton((bt) => { + new import_obsidian7.Setting(containerEl).setName("Disable on this device").addToggle((toggle) => toggle.setValue(plugin.localStorage.getPluginDisabled()).onChange((value) => { + plugin.localStorage.setPluginDisabled(value); + if (value) { + plugin.unloadPlugin(); + } else { + plugin.loadPlugin(); + } + new import_obsidian7.Notice("Obsidian must be restarted for the changes to take affect"); + })); + new import_obsidian7.Setting(containerEl).setName("Donate").setDesc("If you like this Plugin, consider donating to support continued development.").addButton((bt) => { bt.buttonEl.outerHTML = "Buy Me a Coffee at ko-fi.com"; }); const info = containerEl.createDiv(); @@ -11199,7 +24607,7 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { const keys = containerEl.createDiv(); keys.setAttr("align", "center"); keys.addClass("obsidian-git-shortcuts"); - if (import_obsidian2.Platform.isMacOS === true) { + if (import_obsidian7.Platform.isMacOS === true) { keys.createEl("kbd", { text: "CMD (\u2318) + OPTION (\u2325) + I" }); } else { keys.createEl("kbd", { text: "CTRL + SHIFT + I" }); @@ -11208,7 +24616,8 @@ var ObsidianGitSettingsTab = class extends import_obsidian2.PluginSettingTab { }; // src/statusBar.ts -var import_obsidian3 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian8 = __toModule(require("obsidian")); var StatusBar = class { constructor(statusBarEl, plugin) { this.statusBarEl = statusBarEl; @@ -11256,37 +24665,37 @@ var StatusBar = class { break; case PluginState.status: this.statusBarEl.ariaLabel = "Checking repository status..."; - (0, import_obsidian3.setIcon)(this.iconEl, "refresh-cw"); + (0, import_obsidian8.setIcon)(this.iconEl, "refresh-cw"); this.statusBarEl.addClass(this.base + "status"); break; case PluginState.add: this.statusBarEl.ariaLabel = "Adding files..."; - (0, import_obsidian3.setIcon)(this.iconEl, "refresh-w"); + (0, import_obsidian8.setIcon)(this.iconEl, "refresh-w"); this.statusBarEl.addClass(this.base + "add"); break; case PluginState.commit: this.statusBarEl.ariaLabel = "Committing changes..."; - (0, import_obsidian3.setIcon)(this.iconEl, "git-commit"); + (0, import_obsidian8.setIcon)(this.iconEl, "git-commit"); this.statusBarEl.addClass(this.base + "commit"); break; case PluginState.push: this.statusBarEl.ariaLabel = "Pushing changes..."; - (0, import_obsidian3.setIcon)(this.iconEl, "upload"); + (0, import_obsidian8.setIcon)(this.iconEl, "upload"); this.statusBarEl.addClass(this.base + "push"); break; case PluginState.pull: this.statusBarEl.ariaLabel = "Pulling changes..."; - (0, import_obsidian3.setIcon)(this.iconEl, "download"); + (0, import_obsidian8.setIcon)(this.iconEl, "download"); this.statusBarEl.addClass(this.base + "pull"); break; case PluginState.conflicted: this.statusBarEl.ariaLabel = "You have conflict files..."; - (0, import_obsidian3.setIcon)(this.iconEl, "alert-circle"); + (0, import_obsidian8.setIcon)(this.iconEl, "alert-circle"); this.statusBarEl.addClass(this.base + "conflict"); break; default: this.statusBarEl.ariaLabel = "Failed on initialization!"; - (0, import_obsidian3.setIcon)(this.iconEl, "alert-triangle"); + (0, import_obsidian8.setIcon)(this.iconEl, "alert-triangle"); this.statusBarEl.addClass(this.base + "failed-init"); break; } @@ -11300,9 +24709,9 @@ var StatusBar = class { this.statusBarEl.ariaLabel = this.plugin.offlineMode ? "Git is offline" : "Git is ready"; } if (this.plugin.offlineMode) { - (0, import_obsidian3.setIcon)(this.iconEl, "globe"); + (0, import_obsidian8.setIcon)(this.iconEl, "globe"); } else { - (0, import_obsidian3.setIcon)(this.iconEl, "check"); + (0, import_obsidian8.setIcon)(this.iconEl, "check"); } if (this.plugin.settings.changedFilesInStatusBar && this.plugin.cachedStatus) { this.textEl.setText(this.plugin.cachedStatus.changed.length.toString()); @@ -11312,8 +24721,9 @@ var StatusBar = class { }; // src/ui/modals/changedFilesModal.ts -var import_obsidian4 = __toModule(require("obsidian")); -var ChangedFilesModal = class extends import_obsidian4.FuzzySuggestModal { +init_polyfill_buffer(); +var import_obsidian9 = __toModule(require("obsidian")); +var ChangedFilesModal = class extends import_obsidian9.FuzzySuggestModal { constructor(plugin, changedFiles) { super(plugin.app); this.plugin = plugin; @@ -11328,12 +24738,12 @@ var ChangedFilesModal = class extends import_obsidian4.FuzzySuggestModal { return `Untracked | ${item.vault_path}`; } let working_dir = ""; - let index = ""; + let index2 = ""; if (item.working_dir != " ") working_dir = `Working dir: ${item.working_dir} `; if (item.index != " ") - index = `Index: ${item.index}`; - return `${working_dir}${index} | ${item.vault_path}`; + index2 = `Index: ${item.index}`; + return `${working_dir}${index2} | ${item.vault_path}`; } onChooseItem(item, _) { if (this.plugin.app.metadataCache.getFirstLinkpathDest(item.vault_path, "") == null) { @@ -11345,8 +24755,9 @@ var ChangedFilesModal = class extends import_obsidian4.FuzzySuggestModal { }; // src/ui/modals/customMessageModal.ts -var import_obsidian5 = __toModule(require("obsidian")); -var CustomMessageModal = class extends import_obsidian5.SuggestModal { +init_polyfill_buffer(); +var import_obsidian10 = __toModule(require("obsidian")); +var CustomMessageModal = class extends import_obsidian10.SuggestModal { constructor(plugin, fromAutoBackup) { super(plugin.app); this.fromAutoBackup = fromAutoBackup; @@ -11383,7 +24794,8 @@ var CustomMessageModal = class extends import_obsidian5.SuggestModal { }; // src/constants.ts -var import_obsidian6 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian11 = __toModule(require("obsidian")); var DEFAULT_SETTINGS = { commitMessage: "vault backup: {{date}}", autoCommitMessage: void 0, @@ -11402,11 +24814,14 @@ var DEFAULT_SETTINGS = { customMessageOnAutoBackup: false, autoBackupAfterFileChange: false, treeStructure: false, - refreshSourceControl: import_obsidian6.Platform.isDesktopApp, + refreshSourceControl: import_obsidian11.Platform.isDesktopApp, basePath: "", differentIntervalCommitAndPush: false, changedFilesInStatusBar: false, - username: "" + username: "", + showedMobileNotice: false, + refreshSourceControlTimer: 7e3, + showBranchStatusBar: true }; var GIT_VIEW_CONFIG = { type: "git-view", @@ -11420,111 +24835,1679 @@ var DIFF_VIEW_CONFIG = { }; // src/localStorageSettings.ts +init_polyfill_buffer(); var LocalStorageSettings = class { constructor(plugin) { this.plugin = plugin; - this.prefix = this.plugin.manifest.id; + this.prefix = this.plugin.manifest.id + ":"; + } + migrate() { + const keys = ["password", "hostname", "conflict", "lastAutoPull", "lastAutoBackup", "lastAutoPush", "gitPath", "pluginDisabled"]; + for (const key2 of keys) { + const old = localStorage.getItem(this.prefix + key2); + if (app.loadLocalStorage(this.prefix + key2) == null && old != null) { + if (old != null) { + app.saveLocalStorage(this.prefix + key2, old); + localStorage.removeItem(this.prefix + key2); + } + } + } } getPassword() { - return localStorage.getItem(this.prefix + ":password"); + return app.loadLocalStorage(this.prefix + "password"); } setPassword(value) { - return localStorage.setItem(this.prefix + ":password", value); + return app.saveLocalStorage(this.prefix + "password", value); } getHostname() { - return localStorage.getItem(this.prefix + ":hostname"); + return app.loadLocalStorage(this.prefix + "hostname"); } setHostname(value) { - return localStorage.setItem(this.prefix + ":hostname", value); + return app.saveLocalStorage(this.prefix + "hostname", value); } getConflict() { - return localStorage.getItem(this.prefix + ":conflict"); + return app.loadLocalStorage(this.prefix + "conflict"); } setConflict(value) { - return localStorage.setItem(this.prefix + ":conflict", value); + return app.saveLocalStorage(this.prefix + "conflict", value); } getLastAutoPull() { - return localStorage.getItem(this.prefix + ":lastAutoPull"); + return app.loadLocalStorage(this.prefix + "lastAutoPull"); } setLastAutoPull(value) { - return localStorage.setItem(this.prefix + ":lastAutoPull", value); + return app.saveLocalStorage(this.prefix + "lastAutoPull", value); } getLastAutoBackup() { - return localStorage.getItem(this.prefix + ":lastAutoBackup"); + return app.loadLocalStorage(this.prefix + "lastAutoBackup"); } setLastAutoBackup(value) { - return localStorage.setItem(this.prefix + ":lastAutoBackup", value); + return app.saveLocalStorage(this.prefix + "lastAutoBackup", value); } getLastAutoPush() { - return localStorage.getItem(this.prefix + ":lastAutoPush"); + return app.loadLocalStorage(this.prefix + "lastAutoPush"); } setLastAutoPush(value) { - return localStorage.setItem(this.prefix + ":lastAutoPush", value); + return app.saveLocalStorage(this.prefix + "lastAutoPush", value); } getGitPath() { - return localStorage.getItem(this.prefix + ":gitPath"); + return app.loadLocalStorage(this.prefix + "gitPath"); } setGitPath(value) { - return localStorage.setItem(this.prefix + ":gitPath", value); + return app.saveLocalStorage(this.prefix + "gitPath", value); + } + getPluginDisabled() { + return app.loadLocalStorage(this.prefix + "pluginDisabled") == "true"; + } + setPluginDisabled(value) { + return app.saveLocalStorage(this.prefix + "pluginDisabled", `${value}`); } }; // src/openInGitHub.ts -var import_obsidian7 = __toModule(require("obsidian")); -function openLineInGitHub(editor, file, manager) { - return __async(this, null, function* () { - const { isGitHub, branch, repo, user } = yield getData(manager); - if (isGitHub) { - const path2 = manager.getPath(file.path, true); - const from = editor.getCursor("from").line + 1; - const to = editor.getCursor("to").line + 1; - if (from === to) { - window.open(`https://github.com/${user}/${repo}/blob/${branch}/${path2}?plain=1#L${from}`); - } else { - window.open(`https://github.com/${user}/${repo}/blob/${branch}/${path2}?plain=1#L${from}-L${to}`); - } - } else { - new import_obsidian7.Notice("It seems like you are not using GitHub"); - } - }); -} -function openHistoryInGitHub(file, manager) { - return __async(this, null, function* () { - const { isGitHub, branch, repo, user } = yield getData(manager); +init_polyfill_buffer(); +var import_obsidian12 = __toModule(require("obsidian")); +async function openLineInGitHub(editor, file, manager) { + const { isGitHub, branch: branch2, repo, user } = await getData(manager); + if (isGitHub) { const path2 = manager.getPath(file.path, true); - if (isGitHub) { - window.open(`https://github.com/${user}/${repo}/commits/${branch}/${path2}`); + const from = editor.getCursor("from").line + 1; + const to = editor.getCursor("to").line + 1; + if (from === to) { + window.open(`https://github.com/${user}/${repo}/blob/${branch2}/${path2}?plain=1#L${from}`); } else { - new import_obsidian7.Notice("It seems like you are not using GitHub"); + window.open(`https://github.com/${user}/${repo}/blob/${branch2}/${path2}?plain=1#L${from}-L${to}`); } - }); + } else { + new import_obsidian12.Notice("It seems like you are not using GitHub"); + } } -function getData(manager) { - return __async(this, null, function* () { - const branchInfo = yield manager.branchInfo(); - const remoteBranch = branchInfo.tracking; - const branch = branchInfo.current; - const remote = remoteBranch.substring(0, remoteBranch.indexOf("/")); - const remoteUrl = yield manager.getConfig(`remote.${remote}.url`); - const [isGitHub, httpsUser, httpsRepo, sshUser, sshRepo] = remoteUrl.match(/(?:^https:\/\/github\.com\/(.*)\/(.*)\.git$)|(?:^git@github\.com:(.*)\/(.*)\.git$)/); - return { - isGitHub: !!isGitHub, - repo: httpsRepo || sshRepo, - user: httpsUser || sshUser, - branch - }; - }); +async function openHistoryInGitHub(file, manager) { + const { isGitHub, branch: branch2, repo, user } = await getData(manager); + const path2 = manager.getPath(file.path, true); + if (isGitHub) { + window.open(`https://github.com/${user}/${repo}/commits/${branch2}/${path2}`); + } else { + new import_obsidian12.Notice("It seems like you are not using GitHub"); + } +} +async function getData(manager) { + const branchInfo = await manager.branchInfo(); + const remoteBranch = branchInfo.tracking; + const branch2 = branchInfo.current; + const remote = remoteBranch.substring(0, remoteBranch.indexOf("/")); + const remoteUrl = await manager.getConfig(`remote.${remote}.url`); + const [isGitHub, httpsUser, httpsRepo, sshUser, sshRepo] = remoteUrl.match(/(?:^https:\/\/github\.com\/(.*)\/(.*)\.git$)|(?:^git@github\.com:(.*)\/(.*)\.git$)/); + return { + isGitHub: !!isGitHub, + repo: httpsRepo || sshRepo, + user: httpsUser || sshUser, + branch: branch2 + }; } // src/ui/diff/diffView.ts -var import_diff2html = __toModule(require_diff2html()); -var import_obsidian8 = __toModule(require("obsidian")); -var DiffView = class extends import_obsidian8.ItemView { +init_polyfill_buffer(); + +// node_modules/diff2html/lib-esm/diff2html.js +init_polyfill_buffer(); + +// node_modules/diff2html/lib-esm/diff-parser.js +init_polyfill_buffer(); + +// node_modules/diff2html/lib-esm/types.js +init_polyfill_buffer(); +var LineType; +(function(LineType2) { + LineType2["INSERT"] = "insert"; + LineType2["DELETE"] = "delete"; + LineType2["CONTEXT"] = "context"; +})(LineType || (LineType = {})); +var OutputFormatType = { + LINE_BY_LINE: "line-by-line", + SIDE_BY_SIDE: "side-by-side" +}; +var LineMatchingType = { + LINES: "lines", + WORDS: "words", + NONE: "none" +}; +var DiffStyleType = { + WORD: "word", + CHAR: "char" +}; + +// node_modules/diff2html/lib-esm/utils.js +init_polyfill_buffer(); +var specials = [ + "-", + "[", + "]", + "/", + "{", + "}", + "(", + ")", + "*", + "+", + "?", + ".", + "\\", + "^", + "$", + "|" +]; +var regex = RegExp("[" + specials.join("\\") + "]", "g"); +function escapeForRegExp(str) { + return str.replace(regex, "\\$&"); +} +function unifyPath(path2) { + return path2 ? path2.replace(/\\/g, "/") : path2; +} +function hashCode(text2) { + var i, chr, len; + var hash2 = 0; + for (i = 0, len = text2.length; i < len; i++) { + chr = text2.charCodeAt(i); + hash2 = (hash2 << 5) - hash2 + chr; + hash2 |= 0; + } + return hash2; +} + +// node_modules/diff2html/lib-esm/diff-parser.js +var __spreadArray = function(to, from, pack) { + if (pack || arguments.length === 2) + for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) + ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +function getExtension(filename, language) { + var filenameParts = filename.split("."); + return filenameParts.length > 1 ? filenameParts[filenameParts.length - 1] : language; +} +function startsWithAny(str, prefixes) { + return prefixes.reduce(function(startsWith, prefix) { + return startsWith || str.startsWith(prefix); + }, false); +} +var baseDiffFilenamePrefixes = ["a/", "b/", "i/", "w/", "c/", "o/"]; +function getFilename(line, linePrefix, extraPrefix) { + var prefixes = extraPrefix !== void 0 ? __spreadArray(__spreadArray([], baseDiffFilenamePrefixes, true), [extraPrefix], false) : baseDiffFilenamePrefixes; + var FilenameRegExp = linePrefix ? new RegExp("^".concat(escapeForRegExp(linePrefix), ' "?(.+?)"?$')) : new RegExp('^"?(.+?)"?$'); + var _a2 = FilenameRegExp.exec(line) || [], _b = _a2[1], filename = _b === void 0 ? "" : _b; + var matchingPrefix = prefixes.find(function(p) { + return filename.indexOf(p) === 0; + }); + var fnameWithoutPrefix = matchingPrefix ? filename.slice(matchingPrefix.length) : filename; + return fnameWithoutPrefix.replace(/\s+\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}(?:\.\d+)? [+-]\d{4}.*$/, ""); +} +function getSrcFilename(line, srcPrefix) { + return getFilename(line, "---", srcPrefix); +} +function getDstFilename(line, dstPrefix) { + return getFilename(line, "+++", dstPrefix); +} +function parse(diffInput, config) { + if (config === void 0) { + config = {}; + } + var files = []; + var currentFile = null; + var currentBlock = null; + var oldLine = null; + var oldLine2 = null; + var newLine = null; + var possibleOldName = null; + var possibleNewName = null; + var oldFileNameHeader = "--- "; + var newFileNameHeader = "+++ "; + var hunkHeaderPrefix = "@@"; + var oldMode = /^old mode (\d{6})/; + var newMode = /^new mode (\d{6})/; + var deletedFileMode = /^deleted file mode (\d{6})/; + var newFileMode = /^new file mode (\d{6})/; + var copyFrom = /^copy from "?(.+)"?/; + var copyTo = /^copy to "?(.+)"?/; + var renameFrom = /^rename from "?(.+)"?/; + var renameTo = /^rename to "?(.+)"?/; + var similarityIndex = /^similarity index (\d+)%/; + var dissimilarityIndex = /^dissimilarity index (\d+)%/; + var index2 = /^index ([\da-z]+)\.\.([\da-z]+)\s*(\d{6})?/; + var binaryFiles = /^Binary files (.*) and (.*) differ/; + var binaryDiff = /^GIT binary patch/; + var combinedIndex = /^index ([\da-z]+),([\da-z]+)\.\.([\da-z]+)/; + var combinedMode = /^mode (\d{6}),(\d{6})\.\.(\d{6})/; + var combinedNewFile = /^new file mode (\d{6})/; + var combinedDeletedFile = /^deleted file mode (\d{6}),(\d{6})/; + var diffLines2 = diffInput.replace(/\\ No newline at end of file/g, "").replace(/\r\n?/g, "\n").split("\n"); + function saveBlock() { + if (currentBlock !== null && currentFile !== null) { + currentFile.blocks.push(currentBlock); + currentBlock = null; + } + } + function saveFile() { + if (currentFile !== null) { + if (!currentFile.oldName && possibleOldName !== null) { + currentFile.oldName = possibleOldName; + } + if (!currentFile.newName && possibleNewName !== null) { + currentFile.newName = possibleNewName; + } + if (currentFile.newName) { + files.push(currentFile); + currentFile = null; + } + } + possibleOldName = null; + possibleNewName = null; + } + function startFile() { + saveBlock(); + saveFile(); + currentFile = { + blocks: [], + deletedLines: 0, + addedLines: 0 + }; + } + function startBlock(line) { + saveBlock(); + var values; + if (currentFile !== null) { + if (values = /^@@ -(\d+)(?:,\d+)? \+(\d+)(?:,\d+)? @@.*/.exec(line)) { + currentFile.isCombined = false; + oldLine = parseInt(values[1], 10); + newLine = parseInt(values[2], 10); + } else if (values = /^@@@ -(\d+)(?:,\d+)? -(\d+)(?:,\d+)? \+(\d+)(?:,\d+)? @@@.*/.exec(line)) { + currentFile.isCombined = true; + oldLine = parseInt(values[1], 10); + oldLine2 = parseInt(values[2], 10); + newLine = parseInt(values[3], 10); + } else { + if (line.startsWith(hunkHeaderPrefix)) { + console.error("Failed to parse lines, starting in 0!"); + } + oldLine = 0; + newLine = 0; + currentFile.isCombined = false; + } + } + currentBlock = { + lines: [], + oldStartLine: oldLine, + oldStartLine2: oldLine2, + newStartLine: newLine, + header: line + }; + } + function createLine(line) { + if (currentFile === null || currentBlock === null || oldLine === null || newLine === null) + return; + var currentLine = { + content: line + }; + var addedPrefixes = currentFile.isCombined ? ["+ ", " +", "++"] : ["+"]; + var deletedPrefixes = currentFile.isCombined ? ["- ", " -", "--"] : ["-"]; + if (startsWithAny(line, addedPrefixes)) { + currentFile.addedLines++; + currentLine.type = LineType.INSERT; + currentLine.oldNumber = void 0; + currentLine.newNumber = newLine++; + } else if (startsWithAny(line, deletedPrefixes)) { + currentFile.deletedLines++; + currentLine.type = LineType.DELETE; + currentLine.oldNumber = oldLine++; + currentLine.newNumber = void 0; + } else { + currentLine.type = LineType.CONTEXT; + currentLine.oldNumber = oldLine++; + currentLine.newNumber = newLine++; + } + currentBlock.lines.push(currentLine); + } + function existHunkHeader(line, lineIdx) { + var idx = lineIdx; + while (idx < diffLines2.length - 3) { + if (line.startsWith("diff")) { + return false; + } + if (diffLines2[idx].startsWith(oldFileNameHeader) && diffLines2[idx + 1].startsWith(newFileNameHeader) && diffLines2[idx + 2].startsWith(hunkHeaderPrefix)) { + return true; + } + idx++; + } + return false; + } + diffLines2.forEach(function(line, lineIndex) { + if (!line || line.startsWith("*")) { + return; + } + var values; + var prevLine = diffLines2[lineIndex - 1]; + var nxtLine = diffLines2[lineIndex + 1]; + var afterNxtLine = diffLines2[lineIndex + 2]; + if (line.startsWith("diff")) { + startFile(); + var gitDiffStart = /^diff --git "?([a-ciow]\/.+)"? "?([a-ciow]\/.+)"?/; + if (values = gitDiffStart.exec(line)) { + possibleOldName = getFilename(values[1], void 0, config.dstPrefix); + possibleNewName = getFilename(values[2], void 0, config.srcPrefix); + } + if (currentFile === null) { + throw new Error("Where is my file !!!"); + } + currentFile.isGitDiff = true; + return; + } + if (!currentFile || !currentFile.isGitDiff && currentFile && line.startsWith(oldFileNameHeader) && nxtLine.startsWith(newFileNameHeader) && afterNxtLine.startsWith(hunkHeaderPrefix)) { + startFile(); + } + if (currentFile === null || currentFile === void 0 ? void 0 : currentFile.isTooBig) { + return; + } + if (currentFile && (typeof config.diffMaxChanges === "number" && currentFile.addedLines + currentFile.deletedLines > config.diffMaxChanges || typeof config.diffMaxLineLength === "number" && line.length > config.diffMaxLineLength)) { + currentFile.isTooBig = true; + currentFile.addedLines = 0; + currentFile.deletedLines = 0; + currentFile.blocks = []; + currentBlock = null; + var message = typeof config.diffTooBigMessage === "function" ? config.diffTooBigMessage(files.length) : "Diff too big to be displayed"; + startBlock(message); + return; + } + if (line.startsWith(oldFileNameHeader) && nxtLine.startsWith(newFileNameHeader) || line.startsWith(newFileNameHeader) && prevLine.startsWith(oldFileNameHeader)) { + if (currentFile && !currentFile.oldName && line.startsWith("--- ") && (values = getSrcFilename(line, config.srcPrefix))) { + currentFile.oldName = values; + currentFile.language = getExtension(currentFile.oldName, currentFile.language); + return; + } + if (currentFile && !currentFile.newName && line.startsWith("+++ ") && (values = getDstFilename(line, config.dstPrefix))) { + currentFile.newName = values; + currentFile.language = getExtension(currentFile.newName, currentFile.language); + return; + } + } + if (currentFile && (line.startsWith(hunkHeaderPrefix) || currentFile.isGitDiff && currentFile.oldName && currentFile.newName && !currentBlock)) { + startBlock(line); + return; + } + if (currentBlock && (line.startsWith("+") || line.startsWith("-") || line.startsWith(" "))) { + createLine(line); + return; + } + var doesNotExistHunkHeader = !existHunkHeader(line, lineIndex); + if (currentFile === null) { + throw new Error("Where is my file !!!"); + } + if (values = oldMode.exec(line)) { + currentFile.oldMode = values[1]; + } else if (values = newMode.exec(line)) { + currentFile.newMode = values[1]; + } else if (values = deletedFileMode.exec(line)) { + currentFile.deletedFileMode = values[1]; + currentFile.isDeleted = true; + } else if (values = newFileMode.exec(line)) { + currentFile.newFileMode = values[1]; + currentFile.isNew = true; + } else if (values = copyFrom.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.oldName = values[1]; + } + currentFile.isCopy = true; + } else if (values = copyTo.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.newName = values[1]; + } + currentFile.isCopy = true; + } else if (values = renameFrom.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.oldName = values[1]; + } + currentFile.isRename = true; + } else if (values = renameTo.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.newName = values[1]; + } + currentFile.isRename = true; + } else if (values = binaryFiles.exec(line)) { + currentFile.isBinary = true; + currentFile.oldName = getFilename(values[1], void 0, config.srcPrefix); + currentFile.newName = getFilename(values[2], void 0, config.dstPrefix); + startBlock("Binary file"); + } else if (binaryDiff.test(line)) { + currentFile.isBinary = true; + startBlock(line); + } else if (values = similarityIndex.exec(line)) { + currentFile.unchangedPercentage = parseInt(values[1], 10); + } else if (values = dissimilarityIndex.exec(line)) { + currentFile.changedPercentage = parseInt(values[1], 10); + } else if (values = index2.exec(line)) { + currentFile.checksumBefore = values[1]; + currentFile.checksumAfter = values[2]; + values[3] && (currentFile.mode = values[3]); + } else if (values = combinedIndex.exec(line)) { + currentFile.checksumBefore = [values[2], values[3]]; + currentFile.checksumAfter = values[1]; + } else if (values = combinedMode.exec(line)) { + currentFile.oldMode = [values[2], values[3]]; + currentFile.newMode = values[1]; + } else if (values = combinedNewFile.exec(line)) { + currentFile.newFileMode = values[1]; + currentFile.isNew = true; + } else if (values = combinedDeletedFile.exec(line)) { + currentFile.deletedFileMode = values[1]; + currentFile.isDeleted = true; + } + }); + saveBlock(); + saveFile(); + return files; +} + +// node_modules/diff2html/lib-esm/file-list-renderer.js +init_polyfill_buffer(); + +// node_modules/diff2html/lib-esm/render-utils.js +init_polyfill_buffer(); + +// node_modules/diff2html/lib-esm/rematch.js +init_polyfill_buffer(); +function levenshtein(a, b) { + if (a.length === 0) { + return b.length; + } + if (b.length === 0) { + return a.length; + } + var matrix = []; + var i; + for (i = 0; i <= b.length; i++) { + matrix[i] = [i]; + } + var j; + for (j = 0; j <= a.length; j++) { + matrix[0][j] = j; + } + for (i = 1; i <= b.length; i++) { + for (j = 1; j <= a.length; j++) { + if (b.charAt(i - 1) === a.charAt(j - 1)) { + matrix[i][j] = matrix[i - 1][j - 1]; + } else { + matrix[i][j] = Math.min(matrix[i - 1][j - 1] + 1, Math.min(matrix[i][j - 1] + 1, matrix[i - 1][j] + 1)); + } + } + } + return matrix[b.length][a.length]; +} +function newDistanceFn(str) { + return function(x, y) { + var xValue = str(x).trim(); + var yValue = str(y).trim(); + var lev = levenshtein(xValue, yValue); + return lev / (xValue.length + yValue.length); + }; +} +function newMatcherFn(distance2) { + function findBestMatch(a, b, cache) { + if (cache === void 0) { + cache = new Map(); + } + var bestMatchDist = Infinity; + var bestMatch; + for (var i = 0; i < a.length; ++i) { + for (var j = 0; j < b.length; ++j) { + var cacheKey = JSON.stringify([a[i], b[j]]); + var md = void 0; + if (!(cache.has(cacheKey) && (md = cache.get(cacheKey)))) { + md = distance2(a[i], b[j]); + cache.set(cacheKey, md); + } + if (md < bestMatchDist) { + bestMatchDist = md; + bestMatch = { indexA: i, indexB: j, score: bestMatchDist }; + } + } + } + return bestMatch; + } + function group(a, b, level, cache) { + if (level === void 0) { + level = 0; + } + if (cache === void 0) { + cache = new Map(); + } + var bm = findBestMatch(a, b, cache); + if (!bm || a.length + b.length < 3) { + return [[a, b]]; + } + var a1 = a.slice(0, bm.indexA); + var b1 = b.slice(0, bm.indexB); + var aMatch = [a[bm.indexA]]; + var bMatch = [b[bm.indexB]]; + var tailA = bm.indexA + 1; + var tailB = bm.indexB + 1; + var a2 = a.slice(tailA); + var b2 = b.slice(tailB); + var group1 = group(a1, b1, level + 1, cache); + var groupMatch = group(aMatch, bMatch, level + 1, cache); + var group2 = group(a2, b2, level + 1, cache); + var result = groupMatch; + if (bm.indexA > 0 || bm.indexB > 0) { + result = group1.concat(result); + } + if (a.length > tailA || b.length > tailB) { + result = result.concat(group2); + } + return result; + } + return group; +} + +// node_modules/diff2html/lib-esm/render-utils.js +var __assign = function() { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) + if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var CSSLineClass = { + INSERTS: "d2h-ins", + DELETES: "d2h-del", + CONTEXT: "d2h-cntx", + INFO: "d2h-info", + INSERT_CHANGES: "d2h-ins d2h-change", + DELETE_CHANGES: "d2h-del d2h-change" +}; +var defaultRenderConfig = { + matching: LineMatchingType.NONE, + matchWordsThreshold: 0.25, + maxLineLengthHighlight: 1e4, + diffStyle: DiffStyleType.WORD +}; +var separator = "/"; +var distance = newDistanceFn(function(change) { + return change.value; +}); +var matcher = newMatcherFn(distance); +function isDevNullName(name) { + return name.indexOf("dev/null") !== -1; +} +function removeInsElements(line) { + return line.replace(/(]*>((.|\n)*?)<\/ins>)/g, ""); +} +function removeDelElements(line) { + return line.replace(/(]*>((.|\n)*?)<\/del>)/g, ""); +} +function toCSSClass(lineType) { + switch (lineType) { + case LineType.CONTEXT: + return CSSLineClass.CONTEXT; + case LineType.INSERT: + return CSSLineClass.INSERTS; + case LineType.DELETE: + return CSSLineClass.DELETES; + } +} +function prefixLength(isCombined) { + return isCombined ? 2 : 1; +} +function escapeForHtml(str) { + return str.slice(0).replace(/&/g, "&").replace(//g, ">").replace(/"/g, """).replace(/'/g, "'").replace(/\//g, "/"); +} +function deconstructLine(line, isCombined, escape) { + if (escape === void 0) { + escape = true; + } + var indexToSplit = prefixLength(isCombined); + return { + prefix: line.substring(0, indexToSplit), + content: escape ? escapeForHtml(line.substring(indexToSplit)) : line.substring(indexToSplit) + }; +} +function filenameDiff(file) { + var oldFilename = unifyPath(file.oldName); + var newFilename = unifyPath(file.newName); + if (oldFilename !== newFilename && !isDevNullName(oldFilename) && !isDevNullName(newFilename)) { + var prefixPaths = []; + var suffixPaths = []; + var oldFilenameParts = oldFilename.split(separator); + var newFilenameParts = newFilename.split(separator); + var oldFilenamePartsSize = oldFilenameParts.length; + var newFilenamePartsSize = newFilenameParts.length; + var i = 0; + var j = oldFilenamePartsSize - 1; + var k = newFilenamePartsSize - 1; + while (i < j && i < k) { + if (oldFilenameParts[i] === newFilenameParts[i]) { + prefixPaths.push(newFilenameParts[i]); + i += 1; + } else { + break; + } + } + while (j > i && k > i) { + if (oldFilenameParts[j] === newFilenameParts[k]) { + suffixPaths.unshift(newFilenameParts[k]); + j -= 1; + k -= 1; + } else { + break; + } + } + var finalPrefix = prefixPaths.join(separator); + var finalSuffix = suffixPaths.join(separator); + var oldRemainingPath = oldFilenameParts.slice(i, j + 1).join(separator); + var newRemainingPath = newFilenameParts.slice(i, k + 1).join(separator); + if (finalPrefix.length && finalSuffix.length) { + return finalPrefix + separator + "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}" + separator + finalSuffix; + } else if (finalPrefix.length) { + return finalPrefix + separator + "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}"; + } else if (finalSuffix.length) { + return "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}" + separator + finalSuffix; + } + return oldFilename + " \u2192 " + newFilename; + } else if (!isDevNullName(newFilename)) { + return newFilename; + } else { + return oldFilename; + } +} +function getHtmlId(file) { + return "d2h-".concat(hashCode(filenameDiff(file)).toString().slice(-6)); +} +function getFileIcon(file) { + var templateName = "file-changed"; + if (file.isRename) { + templateName = "file-renamed"; + } else if (file.isCopy) { + templateName = "file-renamed"; + } else if (file.isNew) { + templateName = "file-added"; + } else if (file.isDeleted) { + templateName = "file-deleted"; + } else if (file.newName !== file.oldName) { + templateName = "file-renamed"; + } + return templateName; +} +function diffHighlight(diffLine1, diffLine2, isCombined, config) { + if (config === void 0) { + config = {}; + } + var _a2 = __assign(__assign({}, defaultRenderConfig), config), matching = _a2.matching, maxLineLengthHighlight = _a2.maxLineLengthHighlight, matchWordsThreshold = _a2.matchWordsThreshold, diffStyle = _a2.diffStyle; + var line1 = deconstructLine(diffLine1, isCombined, false); + var line2 = deconstructLine(diffLine2, isCombined, false); + if (line1.content.length > maxLineLengthHighlight || line2.content.length > maxLineLengthHighlight) { + return { + oldLine: { + prefix: line1.prefix, + content: escapeForHtml(line1.content) + }, + newLine: { + prefix: line2.prefix, + content: escapeForHtml(line2.content) + } + }; + } + var diff2 = diffStyle === "char" ? diffChars(line1.content, line2.content) : diffWordsWithSpace(line1.content, line2.content); + var changedWords = []; + if (diffStyle === "word" && matching === "words") { + var removed = diff2.filter(function(element2) { + return element2.removed; + }); + var added = diff2.filter(function(element2) { + return element2.added; + }); + var chunks = matcher(added, removed); + chunks.forEach(function(chunk) { + if (chunk[0].length === 1 && chunk[1].length === 1) { + var dist = distance(chunk[0][0], chunk[1][0]); + if (dist < matchWordsThreshold) { + changedWords.push(chunk[0][0]); + changedWords.push(chunk[1][0]); + } + } + }); + } + var highlightedLine = diff2.reduce(function(highlightedLine2, part) { + var elemType = part.added ? "ins" : part.removed ? "del" : null; + var addClass = changedWords.indexOf(part) > -1 ? ' class="d2h-change"' : ""; + var escapedValue = escapeForHtml(part.value); + return elemType !== null ? "".concat(highlightedLine2, "<").concat(elemType).concat(addClass, ">").concat(escapedValue, "") : "".concat(highlightedLine2).concat(escapedValue); + }, ""); + return { + oldLine: { + prefix: line1.prefix, + content: removeInsElements(highlightedLine) + }, + newLine: { + prefix: line2.prefix, + content: removeDelElements(highlightedLine) + } + }; +} + +// node_modules/diff2html/lib-esm/file-list-renderer.js +var baseTemplatesPath = "file-summary"; +var iconsBaseTemplatesPath = "icon"; +function render(diffFiles, hoganUtils) { + var files = diffFiles.map(function(file) { + return hoganUtils.render(baseTemplatesPath, "line", { + fileHtmlId: getHtmlId(file), + oldName: file.oldName, + newName: file.newName, + fileName: filenameDiff(file), + deletedLines: "-" + file.deletedLines, + addedLines: "+" + file.addedLines + }, { + fileIcon: hoganUtils.template(iconsBaseTemplatesPath, getFileIcon(file)) + }); + }).join("\n"); + return hoganUtils.render(baseTemplatesPath, "wrapper", { + filesNumber: diffFiles.length, + files + }); +} + +// node_modules/diff2html/lib-esm/line-by-line-renderer.js +init_polyfill_buffer(); +var __assign2 = function() { + __assign2 = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) + if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign2.apply(this, arguments); +}; +var defaultLineByLineRendererConfig = __assign2(__assign2({}, defaultRenderConfig), { renderNothingWhenEmpty: false, matchingMaxComparisons: 2500, maxLineSizeInBlockForComparison: 200 }); +var genericTemplatesPath = "generic"; +var baseTemplatesPath2 = "line-by-line"; +var iconsBaseTemplatesPath2 = "icon"; +var tagsBaseTemplatesPath = "tag"; +var LineByLineRenderer = function() { + function LineByLineRenderer2(hoganUtils, config) { + if (config === void 0) { + config = {}; + } + this.hoganUtils = hoganUtils; + this.config = __assign2(__assign2({}, defaultLineByLineRendererConfig), config); + } + LineByLineRenderer2.prototype.render = function(diffFiles) { + var _this = this; + var diffsHtml = diffFiles.map(function(file) { + var diffs; + if (file.blocks.length) { + diffs = _this.generateFileHtml(file); + } else { + diffs = _this.generateEmptyDiff(); + } + return _this.makeFileDiffHtml(file, diffs); + }).join("\n"); + return this.hoganUtils.render(genericTemplatesPath, "wrapper", { content: diffsHtml }); + }; + LineByLineRenderer2.prototype.makeFileDiffHtml = function(file, diffs) { + if (this.config.renderNothingWhenEmpty && Array.isArray(file.blocks) && file.blocks.length === 0) + return ""; + var fileDiffTemplate = this.hoganUtils.template(baseTemplatesPath2, "file-diff"); + var filePathTemplate = this.hoganUtils.template(genericTemplatesPath, "file-path"); + var fileIconTemplate = this.hoganUtils.template(iconsBaseTemplatesPath2, "file"); + var fileTagTemplate = this.hoganUtils.template(tagsBaseTemplatesPath, getFileIcon(file)); + return fileDiffTemplate.render({ + file, + fileHtmlId: getHtmlId(file), + diffs, + filePath: filePathTemplate.render({ + fileDiffName: filenameDiff(file) + }, { + fileIcon: fileIconTemplate, + fileTag: fileTagTemplate + }) + }); + }; + LineByLineRenderer2.prototype.generateEmptyDiff = function() { + return this.hoganUtils.render(genericTemplatesPath, "empty-diff", { + contentClass: "d2h-code-line", + CSSLineClass + }); + }; + LineByLineRenderer2.prototype.generateFileHtml = function(file) { + var _this = this; + var matcher2 = newMatcherFn(newDistanceFn(function(e) { + return deconstructLine(e.content, file.isCombined).content; + })); + return file.blocks.map(function(block) { + var lines = _this.hoganUtils.render(genericTemplatesPath, "block-header", { + CSSLineClass, + blockHeader: file.isTooBig ? block.header : escapeForHtml(block.header), + lineClass: "d2h-code-linenumber", + contentClass: "d2h-code-line" + }); + _this.applyLineGroupping(block).forEach(function(_a2) { + var contextLines = _a2[0], oldLines = _a2[1], newLines = _a2[2]; + if (oldLines.length && newLines.length && !contextLines.length) { + _this.applyRematchMatching(oldLines, newLines, matcher2).map(function(_a3) { + var oldLines2 = _a3[0], newLines2 = _a3[1]; + var _b2 = _this.processChangedLines(file.isCombined, oldLines2, newLines2), left2 = _b2.left, right2 = _b2.right; + lines += left2; + lines += right2; + }); + } else if (contextLines.length) { + contextLines.forEach(function(line) { + var _a3 = deconstructLine(line.content, file.isCombined), prefix = _a3.prefix, content = _a3.content; + lines += _this.generateSingleLineHtml({ + type: CSSLineClass.CONTEXT, + prefix, + content, + oldNumber: line.oldNumber, + newNumber: line.newNumber + }); + }); + } else if (oldLines.length || newLines.length) { + var _b = _this.processChangedLines(file.isCombined, oldLines, newLines), left = _b.left, right = _b.right; + lines += left; + lines += right; + } else { + console.error("Unknown state reached while processing groups of lines", contextLines, oldLines, newLines); + } + }); + return lines; + }).join("\n"); + }; + LineByLineRenderer2.prototype.applyLineGroupping = function(block) { + var blockLinesGroups = []; + var oldLines = []; + var newLines = []; + for (var i = 0; i < block.lines.length; i++) { + var diffLine = block.lines[i]; + if (diffLine.type !== LineType.INSERT && newLines.length || diffLine.type === LineType.CONTEXT && oldLines.length > 0) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + if (diffLine.type === LineType.CONTEXT) { + blockLinesGroups.push([[diffLine], [], []]); + } else if (diffLine.type === LineType.INSERT && oldLines.length === 0) { + blockLinesGroups.push([[], [], [diffLine]]); + } else if (diffLine.type === LineType.INSERT && oldLines.length > 0) { + newLines.push(diffLine); + } else if (diffLine.type === LineType.DELETE) { + oldLines.push(diffLine); + } + } + if (oldLines.length || newLines.length) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + return blockLinesGroups; + }; + LineByLineRenderer2.prototype.applyRematchMatching = function(oldLines, newLines, matcher2) { + var comparisons = oldLines.length * newLines.length; + var maxLineSizeInBlock = Math.max.apply(null, [0].concat(oldLines.concat(newLines).map(function(elem) { + return elem.content.length; + }))); + var doMatching = comparisons < this.config.matchingMaxComparisons && maxLineSizeInBlock < this.config.maxLineSizeInBlockForComparison && (this.config.matching === "lines" || this.config.matching === "words"); + return doMatching ? matcher2(oldLines, newLines) : [[oldLines, newLines]]; + }; + LineByLineRenderer2.prototype.processChangedLines = function(isCombined, oldLines, newLines) { + var fileHtml = { + right: "", + left: "" + }; + var maxLinesNumber = Math.max(oldLines.length, newLines.length); + for (var i = 0; i < maxLinesNumber; i++) { + var oldLine = oldLines[i]; + var newLine = newLines[i]; + var diff2 = oldLine !== void 0 && newLine !== void 0 ? diffHighlight(oldLine.content, newLine.content, isCombined, this.config) : void 0; + var preparedOldLine = oldLine !== void 0 && oldLine.oldNumber !== void 0 ? __assign2(__assign2({}, diff2 !== void 0 ? { + prefix: diff2.oldLine.prefix, + content: diff2.oldLine.content, + type: CSSLineClass.DELETE_CHANGES + } : __assign2(__assign2({}, deconstructLine(oldLine.content, isCombined)), { type: toCSSClass(oldLine.type) })), { oldNumber: oldLine.oldNumber, newNumber: oldLine.newNumber }) : void 0; + var preparedNewLine = newLine !== void 0 && newLine.newNumber !== void 0 ? __assign2(__assign2({}, diff2 !== void 0 ? { + prefix: diff2.newLine.prefix, + content: diff2.newLine.content, + type: CSSLineClass.INSERT_CHANGES + } : __assign2(__assign2({}, deconstructLine(newLine.content, isCombined)), { type: toCSSClass(newLine.type) })), { oldNumber: newLine.oldNumber, newNumber: newLine.newNumber }) : void 0; + var _a2 = this.generateLineHtml(preparedOldLine, preparedNewLine), left = _a2.left, right = _a2.right; + fileHtml.left += left; + fileHtml.right += right; + } + return fileHtml; + }; + LineByLineRenderer2.prototype.generateLineHtml = function(oldLine, newLine) { + return { + left: this.generateSingleLineHtml(oldLine), + right: this.generateSingleLineHtml(newLine) + }; + }; + LineByLineRenderer2.prototype.generateSingleLineHtml = function(line) { + if (line === void 0) + return ""; + var lineNumberHtml = this.hoganUtils.render(baseTemplatesPath2, "numbers", { + oldNumber: line.oldNumber || "", + newNumber: line.newNumber || "" + }); + return this.hoganUtils.render(genericTemplatesPath, "line", { + type: line.type, + lineClass: "d2h-code-linenumber", + contentClass: "d2h-code-line", + prefix: line.prefix === " " ? " " : line.prefix, + content: line.content, + lineNumber: lineNumberHtml + }); + }; + return LineByLineRenderer2; +}(); +var line_by_line_renderer_default = LineByLineRenderer; + +// node_modules/diff2html/lib-esm/side-by-side-renderer.js +init_polyfill_buffer(); +var __assign3 = function() { + __assign3 = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) + if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign3.apply(this, arguments); +}; +var defaultSideBySideRendererConfig = __assign3(__assign3({}, defaultRenderConfig), { renderNothingWhenEmpty: false, matchingMaxComparisons: 2500, maxLineSizeInBlockForComparison: 200 }); +var genericTemplatesPath2 = "generic"; +var baseTemplatesPath3 = "side-by-side"; +var iconsBaseTemplatesPath3 = "icon"; +var tagsBaseTemplatesPath2 = "tag"; +var SideBySideRenderer = function() { + function SideBySideRenderer2(hoganUtils, config) { + if (config === void 0) { + config = {}; + } + this.hoganUtils = hoganUtils; + this.config = __assign3(__assign3({}, defaultSideBySideRendererConfig), config); + } + SideBySideRenderer2.prototype.render = function(diffFiles) { + var _this = this; + var diffsHtml = diffFiles.map(function(file) { + var diffs; + if (file.blocks.length) { + diffs = _this.generateFileHtml(file); + } else { + diffs = _this.generateEmptyDiff(); + } + return _this.makeFileDiffHtml(file, diffs); + }).join("\n"); + return this.hoganUtils.render(genericTemplatesPath2, "wrapper", { content: diffsHtml }); + }; + SideBySideRenderer2.prototype.makeFileDiffHtml = function(file, diffs) { + if (this.config.renderNothingWhenEmpty && Array.isArray(file.blocks) && file.blocks.length === 0) + return ""; + var fileDiffTemplate = this.hoganUtils.template(baseTemplatesPath3, "file-diff"); + var filePathTemplate = this.hoganUtils.template(genericTemplatesPath2, "file-path"); + var fileIconTemplate = this.hoganUtils.template(iconsBaseTemplatesPath3, "file"); + var fileTagTemplate = this.hoganUtils.template(tagsBaseTemplatesPath2, getFileIcon(file)); + return fileDiffTemplate.render({ + file, + fileHtmlId: getHtmlId(file), + diffs, + filePath: filePathTemplate.render({ + fileDiffName: filenameDiff(file) + }, { + fileIcon: fileIconTemplate, + fileTag: fileTagTemplate + }) + }); + }; + SideBySideRenderer2.prototype.generateEmptyDiff = function() { + return { + right: "", + left: this.hoganUtils.render(genericTemplatesPath2, "empty-diff", { + contentClass: "d2h-code-side-line", + CSSLineClass + }) + }; + }; + SideBySideRenderer2.prototype.generateFileHtml = function(file) { + var _this = this; + var matcher2 = newMatcherFn(newDistanceFn(function(e) { + return deconstructLine(e.content, file.isCombined).content; + })); + return file.blocks.map(function(block) { + var fileHtml = { + left: _this.makeHeaderHtml(block.header, file), + right: _this.makeHeaderHtml("") + }; + _this.applyLineGroupping(block).forEach(function(_a2) { + var contextLines = _a2[0], oldLines = _a2[1], newLines = _a2[2]; + if (oldLines.length && newLines.length && !contextLines.length) { + _this.applyRematchMatching(oldLines, newLines, matcher2).map(function(_a3) { + var oldLines2 = _a3[0], newLines2 = _a3[1]; + var _b2 = _this.processChangedLines(file.isCombined, oldLines2, newLines2), left2 = _b2.left, right2 = _b2.right; + fileHtml.left += left2; + fileHtml.right += right2; + }); + } else if (contextLines.length) { + contextLines.forEach(function(line) { + var _a3 = deconstructLine(line.content, file.isCombined), prefix = _a3.prefix, content = _a3.content; + var _b2 = _this.generateLineHtml({ + type: CSSLineClass.CONTEXT, + prefix, + content, + number: line.oldNumber + }, { + type: CSSLineClass.CONTEXT, + prefix, + content, + number: line.newNumber + }), left2 = _b2.left, right2 = _b2.right; + fileHtml.left += left2; + fileHtml.right += right2; + }); + } else if (oldLines.length || newLines.length) { + var _b = _this.processChangedLines(file.isCombined, oldLines, newLines), left = _b.left, right = _b.right; + fileHtml.left += left; + fileHtml.right += right; + } else { + console.error("Unknown state reached while processing groups of lines", contextLines, oldLines, newLines); + } + }); + return fileHtml; + }).reduce(function(accomulated, html2) { + return { left: accomulated.left + html2.left, right: accomulated.right + html2.right }; + }, { left: "", right: "" }); + }; + SideBySideRenderer2.prototype.applyLineGroupping = function(block) { + var blockLinesGroups = []; + var oldLines = []; + var newLines = []; + for (var i = 0; i < block.lines.length; i++) { + var diffLine = block.lines[i]; + if (diffLine.type !== LineType.INSERT && newLines.length || diffLine.type === LineType.CONTEXT && oldLines.length > 0) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + if (diffLine.type === LineType.CONTEXT) { + blockLinesGroups.push([[diffLine], [], []]); + } else if (diffLine.type === LineType.INSERT && oldLines.length === 0) { + blockLinesGroups.push([[], [], [diffLine]]); + } else if (diffLine.type === LineType.INSERT && oldLines.length > 0) { + newLines.push(diffLine); + } else if (diffLine.type === LineType.DELETE) { + oldLines.push(diffLine); + } + } + if (oldLines.length || newLines.length) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + return blockLinesGroups; + }; + SideBySideRenderer2.prototype.applyRematchMatching = function(oldLines, newLines, matcher2) { + var comparisons = oldLines.length * newLines.length; + var maxLineSizeInBlock = Math.max.apply(null, [0].concat(oldLines.concat(newLines).map(function(elem) { + return elem.content.length; + }))); + var doMatching = comparisons < this.config.matchingMaxComparisons && maxLineSizeInBlock < this.config.maxLineSizeInBlockForComparison && (this.config.matching === "lines" || this.config.matching === "words"); + return doMatching ? matcher2(oldLines, newLines) : [[oldLines, newLines]]; + }; + SideBySideRenderer2.prototype.makeHeaderHtml = function(blockHeader, file) { + return this.hoganUtils.render(genericTemplatesPath2, "block-header", { + CSSLineClass, + blockHeader: (file === null || file === void 0 ? void 0 : file.isTooBig) ? blockHeader : escapeForHtml(blockHeader), + lineClass: "d2h-code-side-linenumber", + contentClass: "d2h-code-side-line" + }); + }; + SideBySideRenderer2.prototype.processChangedLines = function(isCombined, oldLines, newLines) { + var fileHtml = { + right: "", + left: "" + }; + var maxLinesNumber = Math.max(oldLines.length, newLines.length); + for (var i = 0; i < maxLinesNumber; i++) { + var oldLine = oldLines[i]; + var newLine = newLines[i]; + var diff2 = oldLine !== void 0 && newLine !== void 0 ? diffHighlight(oldLine.content, newLine.content, isCombined, this.config) : void 0; + var preparedOldLine = oldLine !== void 0 && oldLine.oldNumber !== void 0 ? __assign3(__assign3({}, diff2 !== void 0 ? { + prefix: diff2.oldLine.prefix, + content: diff2.oldLine.content, + type: CSSLineClass.DELETE_CHANGES + } : __assign3(__assign3({}, deconstructLine(oldLine.content, isCombined)), { type: toCSSClass(oldLine.type) })), { number: oldLine.oldNumber }) : void 0; + var preparedNewLine = newLine !== void 0 && newLine.newNumber !== void 0 ? __assign3(__assign3({}, diff2 !== void 0 ? { + prefix: diff2.newLine.prefix, + content: diff2.newLine.content, + type: CSSLineClass.INSERT_CHANGES + } : __assign3(__assign3({}, deconstructLine(newLine.content, isCombined)), { type: toCSSClass(newLine.type) })), { number: newLine.newNumber }) : void 0; + var _a2 = this.generateLineHtml(preparedOldLine, preparedNewLine), left = _a2.left, right = _a2.right; + fileHtml.left += left; + fileHtml.right += right; + } + return fileHtml; + }; + SideBySideRenderer2.prototype.generateLineHtml = function(oldLine, newLine) { + return { + left: this.generateSingleHtml(oldLine), + right: this.generateSingleHtml(newLine) + }; + }; + SideBySideRenderer2.prototype.generateSingleHtml = function(line) { + var lineClass = "d2h-code-side-linenumber"; + var contentClass = "d2h-code-side-line"; + return this.hoganUtils.render(genericTemplatesPath2, "line", { + type: (line === null || line === void 0 ? void 0 : line.type) || "".concat(CSSLineClass.CONTEXT, " d2h-emptyplaceholder"), + lineClass: line !== void 0 ? lineClass : "".concat(lineClass, " d2h-code-side-emptyplaceholder"), + contentClass: line !== void 0 ? contentClass : "".concat(contentClass, " d2h-code-side-emptyplaceholder"), + prefix: (line === null || line === void 0 ? void 0 : line.prefix) === " " ? " " : line === null || line === void 0 ? void 0 : line.prefix, + content: line === null || line === void 0 ? void 0 : line.content, + lineNumber: line === null || line === void 0 ? void 0 : line.number + }); + }; + return SideBySideRenderer2; +}(); +var side_by_side_renderer_default = SideBySideRenderer; + +// node_modules/diff2html/lib-esm/hoganjs-utils.js +init_polyfill_buffer(); +var Hogan3 = __toModule(require_hogan()); + +// node_modules/diff2html/lib-esm/diff2html-templates.js +init_polyfill_buffer(); +var Hogan2 = __toModule(require_hogan()); +var defaultTemplates = {}; +defaultTemplates["file-summary-line"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
  • '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(t.rp("'); + t.b(t.v(t.f("fileName", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b(t.v(t.f("addedLines", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b(t.v(t.f("deletedLines", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
  • "); + return t.fl(); +}, partials: { "'); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' Files changed ('); + t.b(t.v(t.f("filesNumber", c, p, 0))); + t.b(")"); + t.b("\n" + i); + t.b(' hide'); + t.b("\n" + i); + t.b(' show'); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
      '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("files", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-block-header"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b('
    '); + t.b(t.t(t.f("blockHeader", c, p, 0))); + t.b("
    "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-empty-diff"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(" File without changes"); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-file-path"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b(''); + t.b("\n" + i); + t.b(t.rp("'); + t.b(t.v(t.f("fileDiffName", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(t.rp(""); + t.b("\n" + i); + t.b('"); + return t.fl(); +}, partials: { ""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("lineNumber", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + if (t.s(t.f("prefix", c, p, 1), c, p, 0, 162, 238, "{{ }}")) { + t.rs(c, p, function(c2, p2, t2) { + t2.b(' '); + t2.b(t2.t(t2.f("prefix", c2, p2, 0))); + t2.b(""); + t2.b("\n" + i); + }); + c.pop(); + } + if (!t.s(t.f("prefix", c, p, 1), c, p, 1, 0, 0, "")) { + t.b('  '); + t.b("\n" + i); + } + ; + if (t.s(t.f("content", c, p, 1), c, p, 0, 371, 445, "{{ }}")) { + t.rs(c, p, function(c2, p2, t2) { + t2.b(' '); + t2.b(t2.t(t2.f("content", c2, p2, 0))); + t2.b(""); + t2.b("\n" + i); + }); + c.pop(); + } + if (!t.s(t.f("content", c, p, 1), c, p, 1, 0, 0, "")) { + t.b('
    '); + t.b("\n" + i); + } + ; + t.b("
    "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-wrapper"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("content", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-added"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-changed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-deleted"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-renamed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["line-by-line-file-diff"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("filePath", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("diffs", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["line-by-line-numbers"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b(t.v(t.f("oldNumber", c, p, 0))); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b(t.v(t.f("newNumber", c, p, 0))); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["side-by-side-file-diff"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("filePath", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.d("diffs.left", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.d("diffs.right", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-added"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('ADDED'); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-changed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('CHANGED'); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-deleted"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('DELETED'); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-renamed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('RENAMED'); + return t.fl(); +}, partials: {}, subs: {} }); + +// node_modules/diff2html/lib-esm/hoganjs-utils.js +var __assign4 = function() { + __assign4 = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) + if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign4.apply(this, arguments); +}; +var HoganJsUtils = function() { + function HoganJsUtils2(_a2) { + var _b = _a2.compiledTemplates, compiledTemplates = _b === void 0 ? {} : _b, _c = _a2.rawTemplates, rawTemplates = _c === void 0 ? {} : _c; + var compiledRawTemplates = Object.entries(rawTemplates).reduce(function(previousTemplates, _a3) { + var _b2; + var name = _a3[0], templateString = _a3[1]; + var compiledTemplate = Hogan3.compile(templateString, { asString: false }); + return __assign4(__assign4({}, previousTemplates), (_b2 = {}, _b2[name] = compiledTemplate, _b2)); + }, {}); + this.preCompiledTemplates = __assign4(__assign4(__assign4({}, defaultTemplates), compiledTemplates), compiledRawTemplates); + } + HoganJsUtils2.compile = function(templateString) { + return Hogan3.compile(templateString, { asString: false }); + }; + HoganJsUtils2.prototype.render = function(namespace, view, params, partials, indent2) { + var templateKey = this.templateKey(namespace, view); + try { + var template = this.preCompiledTemplates[templateKey]; + return template.render(params, partials, indent2); + } catch (e) { + throw new Error("Could not find template to render '".concat(templateKey, "'")); + } + }; + HoganJsUtils2.prototype.template = function(namespace, view) { + return this.preCompiledTemplates[this.templateKey(namespace, view)]; + }; + HoganJsUtils2.prototype.templateKey = function(namespace, view) { + return "".concat(namespace, "-").concat(view); + }; + return HoganJsUtils2; +}(); +var hoganjs_utils_default = HoganJsUtils; + +// node_modules/diff2html/lib-esm/diff2html.js +var __assign5 = function() { + __assign5 = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) + if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign5.apply(this, arguments); +}; +var defaultDiff2HtmlConfig = __assign5(__assign5(__assign5({}, defaultLineByLineRendererConfig), defaultSideBySideRendererConfig), { outputFormat: OutputFormatType.LINE_BY_LINE, drawFileList: true }); +function html(diffInput, configuration) { + if (configuration === void 0) { + configuration = {}; + } + var config = __assign5(__assign5({}, defaultDiff2HtmlConfig), configuration); + var diffJson = typeof diffInput === "string" ? parse(diffInput, config) : diffInput; + var hoganUtils = new hoganjs_utils_default(config); + var fileList = config.drawFileList ? render(diffJson, hoganUtils) : ""; + var diffOutput = config.outputFormat === "side-by-side" ? new side_by_side_renderer_default(hoganUtils, config).render(diffJson) : new line_by_line_renderer_default(hoganUtils, config).render(diffJson); + return fileList + diffOutput; +} + +// src/ui/diff/diffView.ts +var import_obsidian13 = __toModule(require("obsidian")); +var DiffView = class extends import_obsidian13.ItemView { constructor(leaf, plugin) { super(leaf); this.plugin = plugin; this.gettingDiff = false; this.parser = new DOMParser(); + this.navigation = true; addEventListener("git-refresh", this.refresh.bind(this)); } getViewType() { @@ -11536,12 +26519,10 @@ var DiffView = class extends import_obsidian8.ItemView { getIcon() { return DIFF_VIEW_CONFIG.icon; } - setState(state, result) { - return __async(this, null, function* () { - this.state = state; - yield this.refresh(); - return; - }); + async setState(state, result) { + this.state = state; + await this.refresh(); + return; } getState() { return this.state; @@ -11554,38 +26535,43 @@ var DiffView = class extends import_obsidian8.ItemView { this.refresh(); return super.onOpen(); } - refresh() { - return __async(this, null, function* () { - var _a2; - if (((_a2 = this.state) == null ? void 0 : _a2.file) && !this.gettingDiff && this.plugin.gitManager) { - this.gettingDiff = true; - let diff = yield this.plugin.gitManager.getDiffString(this.state.file, this.state.staged); - this.contentEl.empty(); - if (!diff) { - const content = yield this.app.vault.adapter.read(this.plugin.gitManager.getVaultPath(this.state.file)); - const header = `--- /dev/null + async refresh() { + var _a2; + if (((_a2 = this.state) == null ? void 0 : _a2.file) && !this.gettingDiff && this.plugin.gitManager) { + this.gettingDiff = true; + let diff2 = await this.plugin.gitManager.getDiffString(this.state.file, this.state.staged); + this.contentEl.empty(); + if (!diff2) { + const content = await this.app.vault.adapter.read(this.plugin.gitManager.getVaultPath(this.state.file)); + const header = `--- /dev/null +++ ${this.state.file} @@ -0,0 +1,${content.split("\n").length} @@`; - diff = [...header.split("\n"), ...content.split("\n").map((line) => `+${line}`)].join("\n"); - } - const diffEl = this.parser.parseFromString((0, import_diff2html.html)(diff), "text/html").querySelector(".d2h-file-diff"); - this.contentEl.append(diffEl); - this.gettingDiff = false; + diff2 = [...header.split("\n"), ...content.split("\n").map((line) => `+${line}`)].join("\n"); } - }); + const diffEl = this.parser.parseFromString(html(diff2), "text/html").querySelector(".d2h-file-diff"); + this.contentEl.append(diffEl); + this.gettingDiff = false; + } } }; -// src/ui/modals/generalModal.ts -var import_obsidian9 = __toModule(require("obsidian")); -var GeneralModal = class extends import_obsidian9.SuggestModal { - constructor(app2, options, placeholder, allowEmpty = false, onlySelection = false) { - super(app2); - this.options = options; - this.allowEmpty = allowEmpty; - this.onlySelection = onlySelection; - this.resolve = null; - this.setPlaceholder(placeholder); +// src/ui/modals/branchModal.ts +init_polyfill_buffer(); +var import_obsidian14 = __toModule(require("obsidian")); +var BranchModal = class extends import_obsidian14.FuzzySuggestModal { + constructor(branches) { + super(app); + this.branches = branches; + this.setPlaceholder("Select branch to checkout"); + } + getItems() { + return this.branches; + } + getItemText(item) { + return item; + } + onChooseItem(item, evt) { + this.resolve(item); } open() { super.open(); @@ -11593,42 +26579,17 @@ var GeneralModal = class extends import_obsidian9.SuggestModal { this.resolve = resolve; }); } - selectSuggestion(value, evt) { - if (this.resolve) { - let res; - if (this.allowEmpty && value === " ") - res = ""; - else if (value === "...") - res = void 0; - else - res = value; - this.resolve(res); - } - super.selectSuggestion(value, evt); - } - onClose() { + async onClose() { + await new Promise((resolve) => setTimeout(resolve, 10)); if (this.resolve) this.resolve(void 0); } - getSuggestions(query) { - if (this.onlySelection) { - return this.options; - } else if (this.allowEmpty) { - return [query.length > 0 ? query : " ", ...this.options]; - } else { - return [query.length > 0 ? query : "...", ...this.options]; - } - } - renderSuggestion(value, el) { - el.innerText = value; - } - onChooseSuggestion(item, _) { - } }; // src/ui/modals/ignoreModal.ts -var import_obsidian10 = __toModule(require("obsidian")); -var IgnoreModal = class extends import_obsidian10.Modal { +init_polyfill_buffer(); +var import_obsidian15 = __toModule(require("obsidian")); +var IgnoreModal = class extends import_obsidian15.Modal { constructor(app2, content) { super(app2); this.content = content; @@ -11641,7 +26602,7 @@ var IgnoreModal = class extends import_obsidian10.Modal { }); } onOpen() { - let { contentEl, titleEl } = this; + const { contentEl, titleEl } = this; titleEl.setText("Edit .gitignore"); const div = contentEl.createDiv(); const text2 = div.createEl("textarea", { @@ -11652,22 +26613,27 @@ var IgnoreModal = class extends import_obsidian10.Modal { div.createEl("button", { cls: ["mod-cta", "obsidian-git-center-button"], text: "Save" - }).addEventListener("click", () => __async(this, null, function* () { + }).addEventListener("click", async () => { this.resolve(text2.value); this.close(); - })); + }); } onClose() { - let { contentEl } = this; + const { contentEl } = this; this.resolve(void 0); contentEl.empty(); } }; // src/ui/sidebar/sidebarView.ts -var import_obsidian17 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian22 = __toModule(require("obsidian")); + +// src/ui/sidebar/gitView.svelte +init_polyfill_buffer(); // node_modules/svelte/internal/index.mjs +init_polyfill_buffer(); function noop() { } var identity = (x) => x; @@ -11751,6 +26717,7 @@ function append_empty_stylesheet(node) { } function append_stylesheet(node, style) { append2(node.head || node, style); + return style.sheet; } function insert(target, node, anchor) { target.insertBefore(node, anchor || null); @@ -11803,6 +26770,13 @@ function set_data(text2, data) { function set_input_value(input, value) { input.value = value == null ? "" : value; } +function set_style(node, key2, value, important) { + if (value === null) { + node.style.removeProperty(key2); + } else { + node.style.setProperty(key2, value, important ? "important" : ""); + } +} function toggle_class(element2, name, toggle) { element2.classList[toggle ? "add" : "remove"](name); } @@ -11863,11 +26837,9 @@ function clear_rules() { if (active) return; managed_styles.forEach((info) => { - const { stylesheet } = info; - let i = stylesheet.cssRules.length; - while (i--) - stylesheet.deleteRule(i); - info.rules = {}; + const { ownerNode } = info.stylesheet; + if (ownerNode) + detach(ownerNode); }); managed_styles.clear(); }); @@ -12010,7 +26982,7 @@ function create_bidirectional_transition(node, fn, params, intro) { if (animation_name) delete_rule(node, animation_name); } - function init2(program, duration) { + function init3(program, duration) { const d = program.b - t; duration *= Math.abs(d); return { @@ -12042,11 +27014,11 @@ function create_bidirectional_transition(node, fn, params, intro) { } if (b) tick2(0, 1); - running_program = init2(program, duration); + running_program = init3(program, duration); add_render_callback(() => dispatch(node, b, "start")); loop((now2) => { if (pending_program && now2 > pending_program.start) { - running_program = init2(pending_program, duration); + running_program = init3(pending_program, duration); pending_program = null; dispatch(node, running_program.b, "start"); if (css) { @@ -12108,7 +27080,9 @@ var boolean_attributes = new Set([ "disabled", "formnovalidate", "hidden", + "inert", "ismap", + "itemscope", "loop", "multiple", "muted", @@ -12125,13 +27099,13 @@ function create_component(block) { block && block.c(); } function mount_component(component, target, anchor, customElement) { - const { fragment, on_mount, on_destroy, after_update } = component.$$; + const { fragment, after_update } = component.$$; fragment && fragment.m(target, anchor); if (!customElement) { add_render_callback(() => { - const new_on_destroy = on_mount.map(run).filter(is_function); - if (on_destroy) { - on_destroy.push(...new_on_destroy); + const new_on_destroy = component.$$.on_mount.map(run).filter(is_function); + if (component.$$.on_destroy) { + component.$$.on_destroy.push(...new_on_destroy); } else { run_all(new_on_destroy); } @@ -12157,12 +27131,12 @@ function make_dirty(component, i) { } component.$$.dirty[i / 31 | 0] |= 1 << i % 31; } -function init(component, options, instance6, create_fragment6, not_equal, props, append_styles2, dirty = [-1]) { +function init2(component, options, instance6, create_fragment6, not_equal, props, append_styles2, dirty = [-1]) { const parent_component = current_component; set_current_component(component); const $$ = component.$$ = { fragment: null, - ctx: null, + ctx: [], props, update: noop, not_equal, @@ -12179,19 +27153,19 @@ function init(component, options, instance6, create_fragment6, not_equal, props, root: options.target || parent_component.$$.root }; append_styles2 && append_styles2($$.root); - let ready2 = false; + let ready = false; $$.ctx = instance6 ? instance6(component, options.props || {}, (i, ret, ...rest) => { const value = rest.length ? rest[0] : ret; if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) { if (!$$.skip_bound && $$.bound[i]) $$.bound[i](value); - if (ready2) + if (ready) make_dirty(component, i); } return ret; }) : []; $$.update(); - ready2 = true; + ready = true; run_all($$.before_update); $$.fragment = create_fragment6 ? create_fragment6($$.ctx) : false; if (options.target) { @@ -12236,12 +27210,15 @@ if (typeof HTMLElement === "function") { this.$destroy = noop; } $on(type, callback) { + if (!is_function(callback)) { + return noop; + } const callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []); callbacks.push(callback); return () => { - const index = callbacks.indexOf(callback); - if (index !== -1) - callbacks.splice(index, 1); + const index2 = callbacks.indexOf(callback); + if (index2 !== -1) + callbacks.splice(index2, 1); }; } $set($$props) { @@ -12259,12 +27236,15 @@ var SvelteComponent = class { this.$destroy = noop; } $on(type, callback) { + if (!is_function(callback)) { + return noop; + } const callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []); callbacks.push(callback); return () => { - const index = callbacks.indexOf(callback); - if (index !== -1) - callbacks.splice(index, 1); + const index2 = callbacks.indexOf(callback); + if (index2 !== -1) + callbacks.splice(index2, 1); }; } $set($$props) { @@ -12276,40 +27256,17 @@ var SvelteComponent = class { } }; -// node_modules/tslib/modules/index.js -var import_tslib = __toModule(require_tslib()); -var { - __extends, - __assign, - __rest, - __decorate, - __param, - __metadata, - __awaiter, - __generator, - __exportStar, - __createBinding, - __values, - __read, - __spread, - __spreadArrays, - __spreadArray, - __await, - __asyncGenerator, - __asyncDelegator, - __asyncValues, - __makeTemplateObject, - __importStar, - __importDefault, - __classPrivateFieldGet, - __classPrivateFieldSet, - __classPrivateFieldIn -} = import_tslib.default; - // src/ui/sidebar/gitView.svelte -var import_obsidian16 = __toModule(require("obsidian")); +var import_obsidian21 = __toModule(require("obsidian")); + +// node_modules/svelte/index.mjs +init_polyfill_buffer(); + +// node_modules/svelte/transition/index.mjs +init_polyfill_buffer(); // node_modules/svelte/easing/index.mjs +init_polyfill_buffer(); function cubicOut(t) { const f = t - 1; return f * f * f + 1; @@ -12335,11 +27292,16 @@ function slide(node, { delay: delay2 = 0, duration = 400, easing = cubicOut } = } // src/ui/sidebar/components/fileComponent.svelte -var import_obsidian13 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian18 = __toModule(require("obsidian")); + +// node_modules/obsidian-community-lib/dist/index.js +init_polyfill_buffer(); // node_modules/obsidian-community-lib/dist/utils.js +init_polyfill_buffer(); var feather = __toModule(require_feather()); -var import_obsidian11 = __toModule(require("obsidian")); +var import_obsidian16 = __toModule(require("obsidian")); function hoverPreview(event, view, to) { const targetEl = event.target; app.workspace.trigger("hover-link", { @@ -12350,47 +27312,11 @@ function hoverPreview(event, view, to) { linktext: to }); } -function createNewMDNote(newName, currFilePath = "") { - return __async(this, null, function* () { - const newFileFolder = app.fileManager.getNewFileParent(currFilePath).path; - const newFilePath = (0, import_obsidian11.normalizePath)(`${newFileFolder}${newFileFolder === "/" ? "" : "/"}${addMD(newName)}`); - return yield app.vault.create(newFilePath, ""); - }); -} -var addMD = (noteName) => { - return noteName.match(/\.MD$|\.md$/m) ? noteName : noteName + ".md"; -}; -function openOrSwitch(_0, _1) { - return __async(this, arguments, function* (dest, event, options = { createNewFile: true }) { - const { workspace } = app; - let destFile = app.metadataCache.getFirstLinkpathDest(dest, ""); - if (!destFile && options.createNewFile) { - destFile = yield createNewMDNote(dest); - } else if (!destFile && !options.createNewFile) - return; - const leavesWithDestAlreadyOpen = []; - workspace.iterateAllLeaves((leaf) => { - var _a2; - if (leaf.view instanceof import_obsidian11.MarkdownView) { - const file = (_a2 = leaf.view) === null || _a2 === void 0 ? void 0 : _a2.file; - if (file && file.basename + "." + file.extension === dest) { - leavesWithDestAlreadyOpen.push(leaf); - } - } - }); - if (leavesWithDestAlreadyOpen.length > 0) { - workspace.setActiveLeaf(leavesWithDestAlreadyOpen[0]); - } else { - const mode = app.vault.getConfig("defaultViewMode"); - const leaf = event.ctrlKey || event.getModifierState("Meta") ? workspace.splitActiveLeaf() : workspace.getUnpinnedLeaf(); - yield leaf.openFile(destFile, { active: true, mode }); - } - }); -} // src/ui/modals/discardModal.ts -var import_obsidian12 = __toModule(require("obsidian")); -var DiscardModal = class extends import_obsidian12.Modal { +init_polyfill_buffer(); +var import_obsidian17 = __toModule(require("obsidian")); +var DiscardModal = class extends import_obsidian17.Modal { constructor(app2, deletion, filename) { super(app2); this.deletion = deletion; @@ -12404,7 +27330,7 @@ var DiscardModal = class extends import_obsidian12.Modal { }); } onOpen() { - let { contentEl, titleEl } = this; + const { contentEl, titleEl } = this; titleEl.setText(`${this.deletion ? "Delete" : "Discard"} this file?`); contentEl.createEl("h4").setText(`Do you really want to ${this.deletion ? "delete" : "discard the changes of"} "${this.filename}"`); const div = contentEl.createDiv(); @@ -12417,21 +27343,21 @@ var DiscardModal = class extends import_obsidian12.Modal { div.createEl("button", { cls: "mod-cta", text: "Confirm" - }).addEventListener("click", () => __async(this, null, function* () { + }).addEventListener("click", async () => { if (this.resolve) this.resolve(true); this.close(); - })); + }); } onClose() { - let { contentEl } = this; + const { contentEl } = this; contentEl.empty(); } }; // src/ui/sidebar/components/fileComponent.svelte function add_css(target) { - append_styles(target, "svelte-1furf50", "main.svelte-1furf50.svelte-1furf50.svelte-1furf50{cursor:pointer;background-color:var(--background-secondary);border-radius:4px;width:98%;display:flex;justify-content:space-between;font-size:0.8rem;margin-bottom:2px}main.svelte-1furf50 .path.svelte-1furf50.svelte-1furf50{color:var(--text-muted);white-space:nowrap;max-width:75%;overflow:hidden;text-overflow:ellipsis}main.svelte-1furf50:hover .path.svelte-1furf50.svelte-1furf50{color:var(--text-normal);transition:all 200ms}main.svelte-1furf50 .tools.svelte-1furf50.svelte-1furf50{display:flex;align-items:center}main.svelte-1furf50 .tools .type.svelte-1furf50.svelte-1furf50{height:16px;width:16px;margin:0;display:flex;align-items:center;justify-content:center}main.svelte-1furf50 .tools .type[data-type=M].svelte-1furf50.svelte-1furf50{color:orange}main.svelte-1furf50 .tools .type[data-type=D].svelte-1furf50.svelte-1furf50{color:red}main.svelte-1furf50 .tools .buttons.svelte-1furf50.svelte-1furf50{display:flex}main.svelte-1furf50 .tools .buttons.svelte-1furf50>.svelte-1furf50{color:var(--text-faint);height:16px;width:16px;margin:0;transition:all 0.2s;border-radius:2px;margin-right:1px}main.svelte-1furf50 .tools .buttons.svelte-1furf50>.svelte-1furf50:hover{color:var(--text-normal);background-color:var(--interactive-accent)}"); + append_styles(target, "svelte-1o25zf2", "main.svelte-1o25zf2 .nav-file-title-content.svelte-1o25zf2.svelte-1o25zf2{display:flex;align-items:center}main.svelte-1o25zf2 .tools.svelte-1o25zf2.svelte-1o25zf2{display:flex;margin-left:auto}main.svelte-1o25zf2 .tools .type.svelte-1o25zf2.svelte-1o25zf2{padding-left:var(--size-2-1);display:flex;align-items:center;justify-content:center}main.svelte-1o25zf2 .tools .type[data-type=M].svelte-1o25zf2.svelte-1o25zf2{color:orange}main.svelte-1o25zf2 .tools .type[data-type=D].svelte-1o25zf2.svelte-1o25zf2{color:red}main.svelte-1o25zf2 .tools .buttons.svelte-1o25zf2.svelte-1o25zf2{display:flex}main.svelte-1o25zf2 .tools .buttons.svelte-1o25zf2>.svelte-1o25zf2{padding:0 0;height:auto}"); } function create_if_block(ctx) { let div; @@ -12442,13 +27368,16 @@ function create_if_block(ctx) { div = element("div"); attr(div, "data-icon", "go-to-file"); attr(div, "aria-label", "Open File"); - attr(div, "class", "svelte-1furf50"); + attr(div, "class", "clickable-icon svelte-1o25zf2"); }, m(target, anchor) { insert(target, div, anchor); - ctx[12](div); + ctx[11](div); if (!mounted) { - dispose = listen(div, "click", ctx[5]); + dispose = [ + listen(div, "auxclick", ctx[5]), + listen(div, "click", ctx[5]) + ]; mounted = true; } }, @@ -12456,105 +27385,108 @@ function create_if_block(ctx) { d(detaching) { if (detaching) detach(div); - ctx[12](null); + ctx[11](null); mounted = false; - dispose(); + run_all(dispose); } }; } function create_fragment(ctx) { + var _a2; let main; - let span0; - let t0_value = ctx[0].vault_path.split("/").last().replace(".md", "") + ""; + let div6; + let div0; + let t0_value = ((_a2 = ctx[0].vault_path.split("/").last()) == null ? void 0 : _a2.replace(".md", "")) + ""; let t0; - let span0_aria_label_value; let t1; + let div5; let div3; - let div2; let show_if = ctx[1].app.vault.getAbstractFileByPath(ctx[0].vault_path); let t2; - let div0; - let t3; let div1; + let t3; + let div2; let t4; - let span1; + let div4; let t5_value = ctx[0].working_dir + ""; let t5; - let span1_data_type_value; + let div4_data_type_value; + let div6_aria_label_value; let mounted; let dispose; let if_block = show_if && create_if_block(ctx); return { c() { main = element("main"); - span0 = element("span"); + div6 = element("div"); + div0 = element("div"); t0 = text(t0_value); t1 = space(); + div5 = element("div"); div3 = element("div"); - div2 = element("div"); if (if_block) if_block.c(); t2 = space(); - div0 = element("div"); - t3 = space(); div1 = element("div"); + t3 = space(); + div2 = element("div"); t4 = space(); - span1 = element("span"); + div4 = element("div"); t5 = text(t5_value); - attr(span0, "class", "path svelte-1furf50"); - attr(span0, "aria-label-position", ctx[3]); - attr(span0, "aria-label", span0_aria_label_value = ctx[0].vault_path.split("/").last() != ctx[0].vault_path ? ctx[0].vault_path : ""); - attr(div0, "data-icon", "skip-back"); - attr(div0, "aria-label", "Discard"); - attr(div0, "class", "svelte-1furf50"); - attr(div1, "data-icon", "plus"); - attr(div1, "aria-label", "Stage"); - attr(div1, "class", "svelte-1furf50"); - attr(div2, "class", "buttons svelte-1furf50"); - attr(span1, "class", "type svelte-1furf50"); - attr(span1, "data-type", span1_data_type_value = ctx[0].working_dir); - attr(div3, "class", "tools svelte-1furf50"); - attr(main, "class", "svelte-1furf50"); + attr(div0, "class", "nav-file-title-content svelte-1o25zf2"); + attr(div1, "data-icon", "skip-back"); + attr(div1, "aria-label", "Discard"); + attr(div1, "class", "clickable-icon svelte-1o25zf2"); + attr(div2, "data-icon", "plus"); + attr(div2, "aria-label", "Stage"); + attr(div2, "class", "clickable-icon svelte-1o25zf2"); + attr(div3, "class", "buttons svelte-1o25zf2"); + attr(div4, "class", "type svelte-1o25zf2"); + attr(div4, "data-type", div4_data_type_value = ctx[0].working_dir); + attr(div5, "class", "tools svelte-1o25zf2"); + attr(div6, "class", "nav-file-title"); + attr(div6, "aria-label-position", ctx[3]); + attr(div6, "aria-label", div6_aria_label_value = ctx[0].vault_path.split("/").last() != ctx[0].vault_path ? ctx[0].vault_path : ""); + attr(main, "class", "nav-file svelte-1o25zf2"); }, m(target, anchor) { insert(target, main, anchor); - append2(main, span0); - append2(span0, t0); - append2(main, t1); - append2(main, div3); - append2(div3, div2); + append2(main, div6); + append2(div6, div0); + append2(div0, t0); + append2(div6, t1); + append2(div6, div5); + append2(div5, div3); if (if_block) - if_block.m(div2, null); - append2(div2, t2); - append2(div2, div0); - ctx[13](div0); - append2(div2, t3); - append2(div2, div1); - ctx[14](div1); - append2(div3, t4); - append2(div3, span1); - append2(span1, t5); + if_block.m(div3, null); + append2(div3, t2); + append2(div3, div1); + ctx[12](div1); + append2(div3, t3); + append2(div3, div2); + ctx[13](div2); + append2(div5, t4); + append2(div5, div4); + append2(div4, t5); if (!mounted) { dispose = [ - listen(span0, "click", self2(ctx[7])), - listen(div0, "click", ctx[8]), - listen(div1, "click", ctx[6]), + listen(div0, "click", ctx[7]), + listen(div0, "auxclick", ctx[7]), + listen(div1, "click", ctx[8]), + listen(div2, "click", ctx[6]), + listen(div6, "click", self2(ctx[7])), + listen(div6, "auxclick", self2(ctx[7])), listen(main, "mouseover", ctx[4]), listen(main, "click", self2(ctx[7])), - listen(main, "focus", ctx[11]) + listen(main, "focus", ctx[10]) ]; mounted = true; } }, p(ctx2, [dirty]) { - if (dirty & 1 && t0_value !== (t0_value = ctx2[0].vault_path.split("/").last().replace(".md", "") + "")) + var _a3; + if (dirty & 1 && t0_value !== (t0_value = ((_a3 = ctx2[0].vault_path.split("/").last()) == null ? void 0 : _a3.replace(".md", "")) + "")) set_data(t0, t0_value); - if (dirty & 8) { - attr(span0, "aria-label-position", ctx2[3]); - } - if (dirty & 1 && span0_aria_label_value !== (span0_aria_label_value = ctx2[0].vault_path.split("/").last() != ctx2[0].vault_path ? ctx2[0].vault_path : "")) { - attr(span0, "aria-label", span0_aria_label_value); - } if (dirty & 3) show_if = ctx2[1].app.vault.getAbstractFileByPath(ctx2[0].vault_path); if (show_if) { @@ -12563,7 +27495,7 @@ function create_fragment(ctx) { } else { if_block = create_if_block(ctx2); if_block.c(); - if_block.m(div2, t2); + if_block.m(div3, t2); } } else if (if_block) { if_block.d(1); @@ -12571,8 +27503,14 @@ function create_fragment(ctx) { } if (dirty & 1 && t5_value !== (t5_value = ctx2[0].working_dir + "")) set_data(t5, t5_value); - if (dirty & 1 && span1_data_type_value !== (span1_data_type_value = ctx2[0].working_dir)) { - attr(span1, "data-type", span1_data_type_value); + if (dirty & 1 && div4_data_type_value !== (div4_data_type_value = ctx2[0].working_dir)) { + attr(div4, "data-type", div4_data_type_value); + } + if (dirty & 8) { + attr(div6, "aria-label-position", ctx2[3]); + } + if (dirty & 1 && div6_aria_label_value !== (div6_aria_label_value = ctx2[0].vault_path.split("/").last() != ctx2[0].vault_path ? ctx2[0].vault_path : "")) { + attr(div6, "aria-label", div6_aria_label_value); } }, i: noop, @@ -12582,8 +27520,8 @@ function create_fragment(ctx) { detach(main); if (if_block) if_block.d(); + ctx[12](null); ctx[13](null); - ctx[14](null); mounted = false; run_all(dispose); } @@ -12594,17 +27532,19 @@ function instance($$self, $$props, $$invalidate) { let { change } = $$props; let { view } = $$props; let { manager } = $$props; - let { workspace } = $$props; let buttons = []; - window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian13.setIcon)(b, b.getAttr("data-icon"), 16)), 0); + window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian18.setIcon)(b, b.getAttr("data-icon"))), 0); function hover(event) { if (!change.path.startsWith(view.app.vault.configDir) || !change.path.startsWith(".")) { hoverPreview(event, view, change.vault_path.split("/").last().replace(".md", "")); } } function open(event) { - if (!(change.path.startsWith(view.app.vault.configDir) || change.path.startsWith(".") || change.working_dir === "D")) { - openOrSwitch(change.vault_path, event); + var _a2; + const file = view.app.vault.getAbstractFileByPath(change.vault_path); + console.log(event); + if (file instanceof import_obsidian18.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); } } function stage() { @@ -12613,19 +27553,12 @@ function instance($$self, $$props, $$invalidate) { }); } function showDiff(event) { - const leaf = workspace.getMostRecentLeaf(workspace.rootSplit); - if (leaf && !leaf.getViewState().pinned && !(event.ctrlKey || event.getModifierState("Meta"))) { - leaf.setViewState({ - type: DIFF_VIEW_CONFIG.type, - state: { file: change.path, staged: false } - }); - } else { - workspace.createLeafInParent(workspace.rootSplit, 0).setViewState({ - type: DIFF_VIEW_CONFIG.type, - active: true, - state: { file: change.path, staged: false } - }); - } + var _a2; + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.setViewState({ + type: DIFF_VIEW_CONFIG.type, + active: true, + state: { file: change.path, staged: false } + }); } function discard() { const deleteFile = change.working_dir == "U"; @@ -12652,13 +27585,13 @@ function instance($$self, $$props, $$invalidate) { $$invalidate(2, buttons); }); } - function div0_binding($$value) { + function div1_binding($$value) { binding_callbacks[$$value ? "unshift" : "push"](() => { buttons[0] = $$value; $$invalidate(2, buttons); }); } - function div1_binding($$value) { + function div2_binding($$value) { binding_callbacks[$$value ? "unshift" : "push"](() => { buttons[2] = $$value; $$invalidate(2, buttons); @@ -12671,8 +27604,6 @@ function instance($$self, $$props, $$invalidate) { $$invalidate(1, view = $$props2.view); if ("manager" in $$props2) $$invalidate(9, manager = $$props2.manager); - if ("workspace" in $$props2) - $$invalidate(10, workspace = $$props2.workspace); }; $$self.$$.update = () => { if ($$self.$$.dirty & 2) { @@ -12691,93 +27622,93 @@ function instance($$self, $$props, $$invalidate) { showDiff, discard, manager, - workspace, focus_handler, div_binding, - div0_binding, - div1_binding + div1_binding, + div2_binding ]; } var FileComponent = class extends SvelteComponent { constructor(options) { super(); - init(this, options, instance, create_fragment, safe_not_equal, { - change: 0, - view: 1, - manager: 9, - workspace: 10 - }, add_css); + init2(this, options, instance, create_fragment, safe_not_equal, { change: 0, view: 1, manager: 9 }, add_css); } }; var fileComponent_default = FileComponent; // src/ui/sidebar/components/pulledFileComponent.svelte -var import_obsidian14 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian19 = __toModule(require("obsidian")); function add_css2(target) { - append_styles(target, "svelte-1pr4yz5", "main.svelte-1pr4yz5.svelte-1pr4yz5{cursor:pointer;background-color:var(--background-secondary);border-radius:4px;width:98%;display:flex;justify-content:space-between;font-size:0.8rem;margin-bottom:2px}main.svelte-1pr4yz5 .path.svelte-1pr4yz5{color:var(--text-muted);white-space:nowrap;max-width:75%;overflow:hidden;text-overflow:ellipsis}main.svelte-1pr4yz5:hover .path.svelte-1pr4yz5{color:var(--text-normal);transition:all 200ms}main.svelte-1pr4yz5 .tools.svelte-1pr4yz5{display:flex;align-items:center}main.svelte-1pr4yz5 .tools .type.svelte-1pr4yz5{height:16px;width:16px;margin:0;display:flex;align-items:center;justify-content:center}main.svelte-1pr4yz5 .tools .type[data-type=M].svelte-1pr4yz5{color:orange}main.svelte-1pr4yz5 .tools .type[data-type=D].svelte-1pr4yz5{color:red}"); + append_styles(target, "svelte-sajhpp", "main.svelte-sajhpp .nav-file-title-content.svelte-sajhpp{display:flex;align-items:center}main.svelte-sajhpp .tools.svelte-sajhpp{display:flex;margin-left:auto}main.svelte-sajhpp .tools .type.svelte-sajhpp{padding-left:var(--size-2-1);display:flex;align-items:center;justify-content:center}main.svelte-sajhpp .tools .type[data-type=M].svelte-sajhpp{color:orange}main.svelte-sajhpp .tools .type[data-type=D].svelte-sajhpp{color:red}"); } function create_fragment2(ctx) { + var _a2; let main; - let span0; - let t0_value = ctx[0].vault_path.split("/").last().replace(".md", "") + ""; + let div2; + let div0; + let t0_value = ((_a2 = ctx[0].vault_path.split("/").last()) == null ? void 0 : _a2.replace(".md", "")) + ""; let t0; - let span0_aria_label_value; let t1; - let div; - let span1; + let div1; + let span; let t2_value = ctx[0].working_dir + ""; let t2; - let span1_data_type_value; + let span_data_type_value; + let div2_aria_label_value; let mounted; let dispose; return { c() { main = element("main"); - span0 = element("span"); + div2 = element("div"); + div0 = element("div"); t0 = text(t0_value); t1 = space(); - div = element("div"); - span1 = element("span"); + div1 = element("div"); + span = element("span"); t2 = text(t2_value); - attr(span0, "class", "path svelte-1pr4yz5"); - attr(span0, "aria-label-position", ctx[1]); - attr(span0, "aria-label", span0_aria_label_value = ctx[0].vault_path.split("/").last() != ctx[0].vault_path ? ctx[0].vault_path : ""); - attr(span1, "class", "type svelte-1pr4yz5"); - attr(span1, "data-type", span1_data_type_value = ctx[0].working_dir); - attr(div, "class", "tools svelte-1pr4yz5"); - attr(main, "class", "svelte-1pr4yz5"); + attr(div0, "class", "nav-file-title-content svelte-sajhpp"); + attr(span, "class", "type svelte-sajhpp"); + attr(span, "data-type", span_data_type_value = ctx[0].working_dir); + attr(div1, "class", "tools svelte-sajhpp"); + attr(div2, "class", "nav-file-title"); + attr(div2, "aria-label-position", ctx[1]); + attr(div2, "aria-label", div2_aria_label_value = ctx[0].vault_path.split("/").last() != ctx[0].vault_path ? ctx[0].vault_path : ""); + attr(main, "class", "nav-file svelte-sajhpp"); }, m(target, anchor) { insert(target, main, anchor); - append2(main, span0); - append2(span0, t0); - append2(main, t1); - append2(main, div); - append2(div, span1); - append2(span1, t2); + append2(main, div2); + append2(div2, div0); + append2(div0, t0); + append2(div2, t1); + append2(div2, div1); + append2(div1, span); + append2(span, t2); if (!mounted) { dispose = [ - listen(span0, "click", self2(ctx[3])), listen(main, "mouseover", ctx[2]), - listen(main, "click", self2(ctx[3])), + listen(main, "click", ctx[3]), listen(main, "focus", ctx[5]) ]; mounted = true; } }, p(ctx2, [dirty]) { - if (dirty & 1 && t0_value !== (t0_value = ctx2[0].vault_path.split("/").last().replace(".md", "") + "")) + var _a3; + if (dirty & 1 && t0_value !== (t0_value = ((_a3 = ctx2[0].vault_path.split("/").last()) == null ? void 0 : _a3.replace(".md", "")) + "")) set_data(t0, t0_value); - if (dirty & 2) { - attr(span0, "aria-label-position", ctx2[1]); - } - if (dirty & 1 && span0_aria_label_value !== (span0_aria_label_value = ctx2[0].vault_path.split("/").last() != ctx2[0].vault_path ? ctx2[0].vault_path : "")) { - attr(span0, "aria-label", span0_aria_label_value); - } if (dirty & 1 && t2_value !== (t2_value = ctx2[0].working_dir + "")) set_data(t2, t2_value); - if (dirty & 1 && span1_data_type_value !== (span1_data_type_value = ctx2[0].working_dir)) { - attr(span1, "data-type", span1_data_type_value); + if (dirty & 1 && span_data_type_value !== (span_data_type_value = ctx2[0].working_dir)) { + attr(span, "data-type", span_data_type_value); + } + if (dirty & 2) { + attr(div2, "aria-label-position", ctx2[1]); + } + if (dirty & 1 && div2_aria_label_value !== (div2_aria_label_value = ctx2[0].vault_path.split("/").last() != ctx2[0].vault_path ? ctx2[0].vault_path : "")) { + attr(div2, "aria-label", div2_aria_label_value); } }, i: noop, @@ -12800,8 +27731,10 @@ function instance2($$self, $$props, $$invalidate) { } } function open(event) { - if (!(change.path.startsWith(view.app.vault.configDir) || change.path.startsWith(".") || change.working_dir === "D")) { - openOrSwitch(change.vault_path, event); + var _a2; + const file = view.app.vault.getAbstractFileByPath(change.vault_path); + if (file instanceof import_obsidian19.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); } } function focus_handler(event) { @@ -12824,15 +27757,16 @@ function instance2($$self, $$props, $$invalidate) { var PulledFileComponent = class extends SvelteComponent { constructor(options) { super(); - init(this, options, instance2, create_fragment2, safe_not_equal, { change: 0, view: 4 }, add_css2); + init2(this, options, instance2, create_fragment2, safe_not_equal, { change: 0, view: 4 }, add_css2); } }; var pulledFileComponent_default = PulledFileComponent; // src/ui/sidebar/components/stagedFileComponent.svelte -var import_obsidian15 = __toModule(require("obsidian")); +init_polyfill_buffer(); +var import_obsidian20 = __toModule(require("obsidian")); function add_css3(target) { - append_styles(target, "svelte-15heedx", "main.svelte-15heedx.svelte-15heedx.svelte-15heedx{cursor:pointer;background-color:var(--background-secondary);border-radius:4px;width:98%;display:flex;justify-content:space-between;font-size:0.8rem;margin-bottom:2px}main.svelte-15heedx .path.svelte-15heedx.svelte-15heedx{color:var(--text-muted);white-space:nowrap;max-width:75%;overflow:hidden;text-overflow:ellipsis}main.svelte-15heedx:hover .path.svelte-15heedx.svelte-15heedx{color:var(--text-normal);transition:all 200ms}main.svelte-15heedx .tools.svelte-15heedx.svelte-15heedx{display:flex;align-items:center}main.svelte-15heedx .tools .type.svelte-15heedx.svelte-15heedx{height:16px;width:16px;margin:0;display:flex;align-items:center;justify-content:center}main.svelte-15heedx .tools .type[data-type=M].svelte-15heedx.svelte-15heedx{color:orange}main.svelte-15heedx .tools .type[data-type=D].svelte-15heedx.svelte-15heedx{color:red}main.svelte-15heedx .tools .type[data-type=A].svelte-15heedx.svelte-15heedx{color:yellowgreen}main.svelte-15heedx .tools .type[data-type=R].svelte-15heedx.svelte-15heedx{color:violet}main.svelte-15heedx .tools .buttons.svelte-15heedx.svelte-15heedx{display:flex}main.svelte-15heedx .tools .buttons.svelte-15heedx>.svelte-15heedx{color:var(--text-faint);height:16px;width:16px;margin:0;transition:all 0.2s;border-radius:2px;margin-right:1px}main.svelte-15heedx .tools .buttons.svelte-15heedx>.svelte-15heedx:hover{color:var(--text-normal);background-color:var(--interactive-accent)}"); + append_styles(target, "svelte-1o25zf2", "main.svelte-1o25zf2 .nav-file-title-content.svelte-1o25zf2.svelte-1o25zf2{display:flex;align-items:center}main.svelte-1o25zf2 .tools.svelte-1o25zf2.svelte-1o25zf2{display:flex;margin-left:auto}main.svelte-1o25zf2 .tools .type.svelte-1o25zf2.svelte-1o25zf2{padding-left:var(--size-2-1);display:flex;align-items:center;justify-content:center}main.svelte-1o25zf2 .tools .type[data-type=M].svelte-1o25zf2.svelte-1o25zf2{color:orange}main.svelte-1o25zf2 .tools .type[data-type=D].svelte-1o25zf2.svelte-1o25zf2{color:red}main.svelte-1o25zf2 .tools .buttons.svelte-1o25zf2.svelte-1o25zf2{display:flex}main.svelte-1o25zf2 .tools .buttons.svelte-1o25zf2>.svelte-1o25zf2{padding:0 0;height:auto}"); } function create_if_block2(ctx) { let div; @@ -12843,7 +27777,7 @@ function create_if_block2(ctx) { div = element("div"); attr(div, "data-icon", "go-to-file"); attr(div, "aria-label", "Open File"); - attr(div, "class", "svelte-15heedx"); + attr(div, "class", "clickable-icon svelte-1o25zf2"); }, m(target, anchor) { insert(target, div, anchor); @@ -12864,71 +27798,78 @@ function create_if_block2(ctx) { }; } function create_fragment3(ctx) { + var _a2; let main; - let span0; - let t0_value = ctx[3].split("/").last().replace(".md", "") + ""; + let div5; + let div0; + let t0_value = ((_a2 = ctx[3].split("/").last()) == null ? void 0 : _a2.replace(".md", "")) + ""; let t0; - let span0_aria_label_value; let t1; + let div4; let div2; - let div1; let show_if = ctx[1].app.vault.getAbstractFileByPath(ctx[3]); let t2; - let div0; + let div1; let t3; - let span1; + let div3; let t4_value = ctx[0].index + ""; let t4; - let span1_data_type_value; + let div3_data_type_value; + let div5_aria_label_value; let mounted; let dispose; let if_block = show_if && create_if_block2(ctx); return { c() { main = element("main"); - span0 = element("span"); + div5 = element("div"); + div0 = element("div"); t0 = text(t0_value); t1 = space(); + div4 = element("div"); div2 = element("div"); - div1 = element("div"); if (if_block) if_block.c(); t2 = space(); - div0 = element("div"); + div1 = element("div"); t3 = space(); - span1 = element("span"); + div3 = element("div"); t4 = text(t4_value); - attr(span0, "class", "path svelte-15heedx"); - attr(span0, "aria-label-position", ctx[4]); - attr(span0, "aria-label", span0_aria_label_value = ctx[3].split("/").last() != ctx[3] ? ctx[3] : ""); - attr(div0, "data-icon", "minus"); - attr(div0, "aria-label", "Unstage"); - attr(div0, "class", "svelte-15heedx"); - attr(div1, "class", "buttons svelte-15heedx"); - attr(span1, "class", "type svelte-15heedx"); - attr(span1, "data-type", span1_data_type_value = ctx[0].index); - attr(div2, "class", "tools svelte-15heedx"); - attr(main, "class", "svelte-15heedx"); + attr(div0, "class", "nav-file-title-content svelte-1o25zf2"); + attr(div1, "data-icon", "minus"); + attr(div1, "aria-label", "Unstage"); + attr(div1, "class", "clickable-icon svelte-1o25zf2"); + attr(div2, "class", "buttons svelte-1o25zf2"); + attr(div3, "class", "type svelte-1o25zf2"); + attr(div3, "data-type", div3_data_type_value = ctx[0].index); + attr(div4, "class", "tools svelte-1o25zf2"); + attr(div5, "class", "nav-file-title"); + attr(div5, "aria-label-position", ctx[4]); + attr(div5, "aria-label", div5_aria_label_value = ctx[3].split("/").last() != ctx[3] ? ctx[3] : ""); + attr(main, "class", "nav-file svelte-1o25zf2"); }, m(target, anchor) { insert(target, main, anchor); - append2(main, span0); - append2(span0, t0); - append2(main, t1); - append2(main, div2); - append2(div2, div1); + append2(main, div5); + append2(div5, div0); + append2(div0, t0); + append2(div5, t1); + append2(div5, div4); + append2(div4, div2); if (if_block) - if_block.m(div1, null); - append2(div1, t2); - append2(div1, div0); - ctx[12](div0); - append2(div2, t3); - append2(div2, span1); - append2(span1, t4); + if_block.m(div2, null); + append2(div2, t2); + append2(div2, div1); + ctx[12](div1); + append2(div4, t3); + append2(div4, div3); + append2(div3, t4); if (!mounted) { dispose = [ - listen(span0, "click", ctx[7]), - listen(div0, "click", ctx[8]), + listen(div0, "click", ctx[7]), + listen(div0, "auxclick", ctx[7]), + listen(div1, "click", ctx[8]), + listen(div5, "click", self2(ctx[7])), listen(main, "mouseover", ctx[5]), listen(main, "focus", ctx[10]), listen(main, "click", self2(ctx[7])) @@ -12937,14 +27878,9 @@ function create_fragment3(ctx) { } }, p(ctx2, [dirty]) { - if (dirty & 8 && t0_value !== (t0_value = ctx2[3].split("/").last().replace(".md", "") + "")) + var _a3; + if (dirty & 8 && t0_value !== (t0_value = ((_a3 = ctx2[3].split("/").last()) == null ? void 0 : _a3.replace(".md", "")) + "")) set_data(t0, t0_value); - if (dirty & 16) { - attr(span0, "aria-label-position", ctx2[4]); - } - if (dirty & 8 && span0_aria_label_value !== (span0_aria_label_value = ctx2[3].split("/").last() != ctx2[3] ? ctx2[3] : "")) { - attr(span0, "aria-label", span0_aria_label_value); - } if (dirty & 10) show_if = ctx2[1].app.vault.getAbstractFileByPath(ctx2[3]); if (show_if) { @@ -12953,7 +27889,7 @@ function create_fragment3(ctx) { } else { if_block = create_if_block2(ctx2); if_block.c(); - if_block.m(div1, t2); + if_block.m(div2, t2); } } else if (if_block) { if_block.d(1); @@ -12961,8 +27897,14 @@ function create_fragment3(ctx) { } if (dirty & 1 && t4_value !== (t4_value = ctx2[0].index + "")) set_data(t4, t4_value); - if (dirty & 1 && span1_data_type_value !== (span1_data_type_value = ctx2[0].index)) { - attr(span1, "data-type", span1_data_type_value); + if (dirty & 1 && div3_data_type_value !== (div3_data_type_value = ctx2[0].index)) { + attr(div3, "data-type", div3_data_type_value); + } + if (dirty & 16) { + attr(div5, "aria-label-position", ctx2[4]); + } + if (dirty & 8 && div5_aria_label_value !== (div5_aria_label_value = ctx2[3].split("/").last() != ctx2[3] ? ctx2[3] : "")) { + attr(div5, "aria-label", div5_aria_label_value); } }, i: noop, @@ -12985,33 +27927,26 @@ function instance3($$self, $$props, $$invalidate) { let { view } = $$props; let { manager } = $$props; let buttons = []; - window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian15.setIcon)(b, b.getAttr("data-icon"), 16)), 0); + window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian20.setIcon)(b, b.getAttr("data-icon"), 16)), 0); function hover(event) { if (!change.path.startsWith(view.app.vault.configDir) || !change.path.startsWith(".")) { hoverPreview(event, view, formattedPath.split("/").last().replace(".md", "")); } } function open(event) { - if (!(change.path.startsWith(view.app.vault.configDir) || change.path.startsWith(".") || change.index === "D")) { - openOrSwitch(formattedPath, event); + var _a2; + const file = view.app.vault.getAbstractFileByPath(change.vault_path); + if (file instanceof import_obsidian20.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); } } function showDiff(event) { - const workspace = view.app.workspace; - const leaf = workspace.getMostRecentLeaf(workspace.rootSplit); - if (leaf && !leaf.getViewState().pinned && !(event.ctrlKey || event.getModifierState("Meta"))) { - leaf.setViewState({ - type: DIFF_VIEW_CONFIG.type, - state: { file: change.path, staged: true } - }); - workspace.setActiveLeaf(leaf, true, true); - } else { - workspace.createLeafInParent(workspace.rootSplit, 0).setViewState({ - type: DIFF_VIEW_CONFIG.type, - active: true, - state: { file: change.path, staged: true } - }); - } + var _a2; + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.setViewState({ + type: DIFF_VIEW_CONFIG.type, + active: true, + state: { file: change.path, staged: true } + }); } function unstage() { manager.unstage(change.path, false).finally(() => { @@ -13027,7 +27962,7 @@ function instance3($$self, $$props, $$invalidate) { $$invalidate(2, buttons); }); } - function div0_binding($$value) { + function div1_binding($$value) { binding_callbacks[$$value ? "unshift" : "push"](() => { buttons[0] = $$value; $$invalidate(2, buttons); @@ -13064,128 +27999,165 @@ function instance3($$self, $$props, $$invalidate) { manager, focus_handler, div_binding, - div0_binding + div1_binding ]; } var StagedFileComponent = class extends SvelteComponent { constructor(options) { super(); - init(this, options, instance3, create_fragment3, safe_not_equal, { change: 0, view: 1, manager: 9 }, add_css3); + init2(this, options, instance3, create_fragment3, safe_not_equal, { change: 0, view: 1, manager: 9 }, add_css3); } }; var stagedFileComponent_default = StagedFileComponent; // src/ui/sidebar/components/treeComponent.svelte +init_polyfill_buffer(); function add_css4(target) { - append_styles(target, "svelte-pgmdei", '@charset "UTF-8";main.svelte-pgmdei.svelte-pgmdei:not(.topLevel){margin-left:5px}.opener.svelte-pgmdei.svelte-pgmdei{display:flex;justify-content:space-between;align-items:center;padding:0 4px}.opener.svelte-pgmdei .collapse-icon.svelte-pgmdei::after{content:"\xA0"}.opener.svelte-pgmdei div.svelte-pgmdei{display:flex}.opener.svelte-pgmdei svg.svelte-pgmdei{transform:rotate(-90deg)}.opener.open.svelte-pgmdei svg.svelte-pgmdei{transform:rotate(0)}.opener.svelte-pgmdei span.svelte-pgmdei{font-size:0.8rem}.file-view.svelte-pgmdei.svelte-pgmdei{margin-left:5px}'); + append_styles(target, "svelte-148wteu", "main.svelte-148wteu .nav-folder-title-content.svelte-148wteu.svelte-148wteu{display:flex;align-items:center}main.svelte-148wteu .tools.svelte-148wteu.svelte-148wteu{display:flex;margin-left:auto}main.svelte-148wteu .tools .buttons.svelte-148wteu.svelte-148wteu{display:flex}main.svelte-148wteu .tools .buttons.svelte-148wteu>.svelte-148wteu{padding:0 0;height:auto}"); } function get_each_context(ctx, list, i) { const child_ctx = ctx.slice(); - child_ctx[7] = list[i]; + child_ctx[14] = list[i]; return child_ctx; } function create_else_block(ctx) { - let div2; - let div1; + let div5; + let div4; let div0; let t0; - let span; - let t1_value = ctx[7].title + ""; + let div1; + let t1_value = ctx[14].title + ""; let t1; let t2; - let if_block_anchor; + let div3; + let div2; + let t3; + let t4; let current; let mounted; let dispose; function click_handler() { - return ctx[6](ctx[7]); + return ctx[9](ctx[14]); } - let if_block = !ctx[5][ctx[7].title] && create_if_block_4(ctx); + function click_handler_1() { + return ctx[10](ctx[14]); + } + function select_block_type_2(ctx2, dirty) { + if (ctx2[3] == FileType.staged) + return create_if_block_5; + return create_else_block_1; + } + let current_block_type = select_block_type_2(ctx, -1); + let if_block0 = current_block_type(ctx); + function click_handler_4() { + return ctx[13](ctx[14]); + } + let if_block1 = !ctx[5][ctx[14].title] && create_if_block_4(ctx); return { c() { - div2 = element("div"); - div1 = element("div"); + div5 = element("div"); + div4 = element("div"); div0 = element("div"); - div0.innerHTML = ``; + div0.innerHTML = ``; t0 = space(); - span = element("span"); + div1 = element("div"); t1 = text(t1_value); t2 = space(); - if (if_block) - if_block.c(); - if_block_anchor = empty(); - attr(div0, "class", "tree-item-icon collapse-icon svelte-pgmdei"); - attr(div0, "style", ""); - attr(span, "class", "svelte-pgmdei"); - attr(div1, "class", "svelte-pgmdei"); - attr(div2, "class", "opener tree-item-self is-clickable svelte-pgmdei"); - toggle_class(div2, "open", !ctx[5][ctx[7].title]); + div3 = element("div"); + div2 = element("div"); + if_block0.c(); + t3 = space(); + if (if_block1) + if_block1.c(); + t4 = space(); + attr(div0, "class", "nav-folder-collapse-indicator collapse-icon"); + attr(div1, "class", "nav-folder-title-content svelte-148wteu"); + attr(div2, "class", "buttons svelte-148wteu"); + attr(div3, "class", "tools svelte-148wteu"); + attr(div4, "class", "nav-folder-title"); + attr(div5, "class", "nav-folder"); + toggle_class(div5, "is-collapsed", ctx[5][ctx[14].title]); }, m(target, anchor) { - insert(target, div2, anchor); - append2(div2, div1); - append2(div1, div0); - append2(div1, t0); - append2(div1, span); - append2(span, t1); - insert(target, t2, anchor); - if (if_block) - if_block.m(target, anchor); - insert(target, if_block_anchor, anchor); + insert(target, div5, anchor); + append2(div5, div4); + append2(div4, div0); + append2(div4, t0); + append2(div4, div1); + append2(div1, t1); + append2(div4, t2); + append2(div4, div3); + append2(div3, div2); + if_block0.m(div2, null); + append2(div5, t3); + if (if_block1) + if_block1.m(div5, null); + append2(div5, t4); current = true; if (!mounted) { - dispose = listen(div2, "click", click_handler); + dispose = [ + listen(div0, "click", click_handler), + listen(div1, "click", click_handler_1), + listen(div4, "click", self2(click_handler_4)) + ]; mounted = true; } }, p(new_ctx, dirty) { ctx = new_ctx; - if ((!current || dirty & 1) && t1_value !== (t1_value = ctx[7].title + "")) + if ((!current || dirty & 1) && t1_value !== (t1_value = ctx[14].title + "")) set_data(t1, t1_value); - if (dirty & 33) { - toggle_class(div2, "open", !ctx[5][ctx[7].title]); + if (current_block_type === (current_block_type = select_block_type_2(ctx, dirty)) && if_block0) { + if_block0.p(ctx, dirty); + } else { + if_block0.d(1); + if_block0 = current_block_type(ctx); + if (if_block0) { + if_block0.c(); + if_block0.m(div2, null); + } } - if (!ctx[5][ctx[7].title]) { - if (if_block) { - if_block.p(ctx, dirty); + if (!ctx[5][ctx[14].title]) { + if (if_block1) { + if_block1.p(ctx, dirty); if (dirty & 33) { - transition_in(if_block, 1); + transition_in(if_block1, 1); } } else { - if_block = create_if_block_4(ctx); - if_block.c(); - transition_in(if_block, 1); - if_block.m(if_block_anchor.parentNode, if_block_anchor); + if_block1 = create_if_block_4(ctx); + if_block1.c(); + transition_in(if_block1, 1); + if_block1.m(div5, t4); } - } else if (if_block) { + } else if (if_block1) { group_outros(); - transition_out(if_block, 1, 1, () => { - if_block = null; + transition_out(if_block1, 1, 1, () => { + if_block1 = null; }); check_outros(); } + if (!current || dirty & 33) { + toggle_class(div5, "is-collapsed", ctx[5][ctx[14].title]); + } }, i(local) { if (current) return; - transition_in(if_block); + transition_in(if_block1); current = true; }, o(local) { - transition_out(if_block); + transition_out(if_block1); current = false; }, d(detaching) { if (detaching) - detach(div2); - if (detaching) - detach(t2); - if (if_block) - if_block.d(detaching); - if (detaching) - detach(if_block_anchor); + detach(div5); + if_block0.d(); + if (if_block1) + if_block1.d(); mounted = false; - dispose(); + run_all(dispose); } }; } @@ -13215,7 +28187,6 @@ function create_if_block3(ctx) { if (if_block) if_block.c(); t = space(); - attr(div, "class", "file-view svelte-pgmdei"); }, m(target, anchor) { insert(target, div, anchor); @@ -13274,15 +28245,80 @@ function create_if_block3(ctx) { } }; } +function create_else_block_1(ctx) { + let div; + let mounted; + let dispose; + function click_handler_3() { + return ctx[12](ctx[14]); + } + return { + c() { + div = element("div"); + div.innerHTML = ``; + attr(div, "data-icon", "plus"); + attr(div, "aria-label", "Stage"); + attr(div, "class", "clickable-icon svelte-148wteu"); + }, + m(target, anchor) { + insert(target, div, anchor); + if (!mounted) { + dispose = listen(div, "click", click_handler_3); + mounted = true; + } + }, + p(new_ctx, dirty) { + ctx = new_ctx; + }, + d(detaching) { + if (detaching) + detach(div); + mounted = false; + dispose(); + } + }; +} +function create_if_block_5(ctx) { + let div; + let mounted; + let dispose; + function click_handler_2() { + return ctx[11](ctx[14]); + } + return { + c() { + div = element("div"); + div.innerHTML = ``; + attr(div, "data-icon", "minus"); + attr(div, "aria-label", "Unstage"); + attr(div, "class", "clickable-icon svelte-148wteu"); + }, + m(target, anchor) { + insert(target, div, anchor); + if (!mounted) { + dispose = listen(div, "click", click_handler_2); + mounted = true; + } + }, + p(new_ctx, dirty) { + ctx = new_ctx; + }, + d(detaching) { + if (detaching) + detach(div); + mounted = false; + dispose(); + } + }; +} function create_if_block_4(ctx) { let div; let treecomponent; - let t; let div_transition; let current; treecomponent = new TreeComponent({ props: { - hierarchy: ctx[7], + hierarchy: ctx[14], plugin: ctx[1], view: ctx[2], fileType: ctx[3] @@ -13292,19 +28328,17 @@ function create_if_block_4(ctx) { c() { div = element("div"); create_component(treecomponent.$$.fragment); - t = space(); - attr(div, "class", "file-view svelte-pgmdei"); + attr(div, "class", "nav-folder-children"); }, m(target, anchor) { insert(target, div, anchor); mount_component(treecomponent, div, null); - append2(div, t); current = true; }, p(ctx2, dirty) { const treecomponent_changes = {}; if (dirty & 1) - treecomponent_changes.hierarchy = ctx2[7]; + treecomponent_changes.hierarchy = ctx2[14]; if (dirty & 2) treecomponent_changes.plugin = ctx2[1]; if (dirty & 4) @@ -13320,7 +28354,7 @@ function create_if_block_4(ctx) { if (local) { add_render_callback(() => { if (!div_transition) - div_transition = create_bidirectional_transition(div, slide, { duration: 75 }, true); + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); div_transition.run(1); }); } @@ -13330,7 +28364,7 @@ function create_if_block_4(ctx) { transition_out(treecomponent.$$.fragment, local); if (local) { if (!div_transition) - div_transition = create_bidirectional_transition(div, slide, { duration: 75 }, false); + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); div_transition.run(0); } current = false; @@ -13349,7 +28383,7 @@ function create_if_block_3(ctx) { let current; pulledfilecomponent = new pulledFileComponent_default({ props: { - change: ctx[7].statusResult, + change: ctx[14].statusResult, view: ctx[2] } }); @@ -13364,7 +28398,7 @@ function create_if_block_3(ctx) { p(ctx2, dirty) { const pulledfilecomponent_changes = {}; if (dirty & 1) - pulledfilecomponent_changes.change = ctx2[7].statusResult; + pulledfilecomponent_changes.change = ctx2[14].statusResult; if (dirty & 4) pulledfilecomponent_changes.view = ctx2[2]; pulledfilecomponent.$set(pulledfilecomponent_changes); @@ -13389,10 +28423,9 @@ function create_if_block_2(ctx) { let current; filecomponent = new fileComponent_default({ props: { - change: ctx[7].statusResult, + change: ctx[14].statusResult, manager: ctx[1].gitManager, - view: ctx[2], - workspace: ctx[1].app.workspace + view: ctx[2] } }); return { @@ -13406,13 +28439,11 @@ function create_if_block_2(ctx) { p(ctx2, dirty) { const filecomponent_changes = {}; if (dirty & 1) - filecomponent_changes.change = ctx2[7].statusResult; + filecomponent_changes.change = ctx2[14].statusResult; if (dirty & 2) filecomponent_changes.manager = ctx2[1].gitManager; if (dirty & 4) filecomponent_changes.view = ctx2[2]; - if (dirty & 2) - filecomponent_changes.workspace = ctx2[1].app.workspace; filecomponent.$set(filecomponent_changes); }, i(local) { @@ -13435,7 +28466,7 @@ function create_if_block_1(ctx) { let current; stagedfilecomponent = new stagedFileComponent_default({ props: { - change: ctx[7].statusResult, + change: ctx[14].statusResult, manager: ctx[1].gitManager, view: ctx[2] } @@ -13451,7 +28482,7 @@ function create_if_block_1(ctx) { p(ctx2, dirty) { const stagedfilecomponent_changes = {}; if (dirty & 1) - stagedfilecomponent_changes.change = ctx2[7].statusResult; + stagedfilecomponent_changes.change = ctx2[14].statusResult; if (dirty & 2) stagedfilecomponent_changes.manager = ctx2[1].gitManager; if (dirty & 4) @@ -13481,7 +28512,7 @@ function create_each_block(ctx) { const if_block_creators = [create_if_block3, create_else_block]; const if_blocks = []; function select_block_type(ctx2, dirty) { - if (ctx2[7].statusResult) + if (ctx2[14].statusResult) return 0; return 1; } @@ -13553,7 +28584,7 @@ function create_fragment4(ctx) { for (let i = 0; i < each_blocks.length; i += 1) { each_blocks[i].c(); } - attr(main, "class", "svelte-pgmdei"); + attr(main, "class", "svelte-148wteu"); toggle_class(main, "topLevel", ctx[4]); }, m(target, anchor) { @@ -13564,7 +28595,7 @@ function create_fragment4(ctx) { current = true; }, p(ctx2, [dirty]) { - if (dirty & 47) { + if (dirty & 495) { each_value = ctx2[0].children; let i; for (i = 0; i < each_value.length; i += 1) { @@ -13585,7 +28616,7 @@ function create_fragment4(ctx) { } check_outros(); } - if (dirty & 16) { + if (!current || dirty & 16) { toggle_class(main, "topLevel", ctx2[4]); } }, @@ -13618,9 +28649,24 @@ function instance4($$self, $$props, $$invalidate) { let { fileType } = $$props; let { topLevel = false } = $$props; const closed = {}; - const click_handler = (entity) => { - $$invalidate(5, closed[entity.title] = !closed[entity.title], closed); - }; + function stage(path2) { + plugin.gitManager.stageAll({ dir: path2 }).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + function unstage(path2) { + plugin.gitManager.unstageAll({ dir: path2 }).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + function fold(item) { + $$invalidate(5, closed[item.title] = !closed[item.title], closed); + } + const click_handler = (entity) => fold(entity); + const click_handler_1 = (entity) => fold(entity); + const click_handler_2 = (entity) => unstage(entity.title); + const click_handler_3 = (entity) => stage(entity.path); + const click_handler_4 = (entity) => fold(entity); $$self.$$set = ($$props2) => { if ("hierarchy" in $$props2) $$invalidate(0, hierarchy = $$props2.hierarchy); @@ -13633,12 +28679,27 @@ function instance4($$self, $$props, $$invalidate) { if ("topLevel" in $$props2) $$invalidate(4, topLevel = $$props2.topLevel); }; - return [hierarchy, plugin, view, fileType, topLevel, closed, click_handler]; + return [ + hierarchy, + plugin, + view, + fileType, + topLevel, + closed, + stage, + unstage, + fold, + click_handler, + click_handler_1, + click_handler_2, + click_handler_3, + click_handler_4 + ]; } var TreeComponent = class extends SvelteComponent { constructor(options) { super(); - init(this, options, instance4, create_fragment4, safe_not_equal, { + init2(this, options, instance4, create_fragment4, safe_not_equal, { hierarchy: 0, plugin: 1, view: 2, @@ -13651,7 +28712,7 @@ var treeComponent_default = TreeComponent; // src/ui/sidebar/gitView.svelte function add_css5(target) { - append_styles(target, "svelte-1f0ksxd", '@charset "UTF-8";.commit-msg.svelte-1f0ksxd.svelte-1f0ksxd{width:100%;min-height:1.9em;height:1.9em;resize:vertical;padding:2px 5px;background-color:var(--background-modifier-form-field)}.search-input-container.svelte-1f0ksxd.svelte-1f0ksxd{width:100%}.file-view.svelte-1f0ksxd.svelte-1f0ksxd{margin-left:5px}.opener.svelte-1f0ksxd.svelte-1f0ksxd{display:flex;justify-content:space-between;align-items:center;padding:0 4px}.opener.svelte-1f0ksxd .collapse-icon.svelte-1f0ksxd::after{content:"\xA0"}.opener.svelte-1f0ksxd div.svelte-1f0ksxd{display:flex}.opener.svelte-1f0ksxd svg.svelte-1f0ksxd{transform:rotate(-90deg)}.opener.open.svelte-1f0ksxd svg.svelte-1f0ksxd{transform:rotate(0)}.git-view-body.svelte-1f0ksxd.svelte-1f0ksxd{overflow-y:auto;padding-left:10px}main.svelte-1f0ksxd.svelte-1f0ksxd{display:flex;flex-direction:column;height:100%;overflow-y:hidden}.nav-buttons-container.svelte-1f0ksxd.svelte-1f0ksxd{justify-content:space-between}.group.svelte-1f0ksxd.svelte-1f0ksxd{display:flex}'); + append_styles(target, "svelte-1u4uc91", `.commit-msg-input.svelte-1u4uc91{width:100%;min-height:33px;height:30px;resize:vertical;padding:7px 5px;background-color:var(--background-modifier-form-field)}.git-commit-msg.svelte-1u4uc91{position:relative;padding:0;width:calc(100% - var(--size-4-8));margin:4px auto}.git-commit-msg-clear-button.svelte-1u4uc91{position:absolute;background:transparent;border-radius:50%;color:var(--search-clear-button-color);cursor:var(--cursor);top:0px;right:2px;bottom:0px;line-height:0;height:var(--input-height);width:28px;margin:auto;padding:0 0;text-align:center;display:flex;justify-content:center;align-items:center;transition:color 0.15s ease-in-out}.git-commit-msg-clear-button.svelte-1u4uc91:after{content:"";height:var(--search-clear-button-size);width:var(--search-clear-button-size);display:block;background-color:currentColor;-webkit-mask-image:url("data:image/svg+xml,");-webkit-mask-repeat:no-repeat}.tree-item-flair.svelte-1u4uc91{margin-left:auto;align-items:center}`); } function get_each_context2(ctx, list, i) { const child_ctx = ctx.slice(); @@ -13676,7 +28737,7 @@ function create_if_block_8(ctx) { return { c() { div = element("div"); - attr(div, "class", "search-input-clear-button"); + attr(div, "class", "git-commit-msg-clear-button svelte-1u4uc91"); attr(div, "aria-label", div_aria_label_value = "Clear"); }, m(target, anchor) { @@ -13696,25 +28757,30 @@ function create_if_block_8(ctx) { }; } function create_if_block4(ctx) { + let div9; + let div8; let div3; let div2; + let div0; + let t0; let div1; let t2; - let span1; + let span0; let t3_value = ctx[5].staged.length + ""; let t3; let t4; let t5; let div7; let div6; + let div4; + let t6; let div5; let t8; - let span3; + let span1; let t9_value = ctx[5].changed.length + ""; let t9; let t10; let t11; - let if_block2_anchor; let current; let mounted; let dispose; @@ -13723,13 +28789,17 @@ function create_if_block4(ctx) { let if_block2 = ctx[6].length > 0 && create_if_block_12(ctx); return { c() { + div9 = element("div"); + div8 = element("div"); div3 = element("div"); div2 = element("div"); + div0 = element("div"); + div0.innerHTML = ``; + t0 = space(); div1 = element("div"); - div1.innerHTML = `
    - Staged Changes`; + div1.textContent = "Staged Changes"; t2 = space(); - span1 = element("span"); + span0 = element("span"); t3 = text(t3_value); t4 = space(); if (if_block0) @@ -13737,11 +28807,13 @@ function create_if_block4(ctx) { t5 = space(); div7 = element("div"); div6 = element("div"); + div4 = element("div"); + div4.innerHTML = ``; + t6 = space(); div5 = element("div"); - div5.innerHTML = `
    - Changes`; + div5.textContent = "Changes"; t8 = space(); - span3 = element("span"); + span1 = element("span"); t9 = text(t9_value); t10 = space(); if (if_block1) @@ -13749,42 +28821,50 @@ function create_if_block4(ctx) { t11 = space(); if (if_block2) if_block2.c(); - if_block2_anchor = empty(); - attr(div1, "class", "svelte-1f0ksxd"); - attr(span1, "class", "tree-item-flair"); - attr(div2, "class", "opener tree-item-self is-clickable svelte-1f0ksxd"); - toggle_class(div2, "open", ctx[13]); - attr(div3, "class", "staged"); - attr(div5, "class", "svelte-1f0ksxd"); - attr(span3, "class", "tree-item-flair"); - attr(div6, "class", "opener tree-item-self is-clickable svelte-1f0ksxd"); - toggle_class(div6, "open", ctx[12]); - attr(div7, "class", "changes"); + attr(div0, "class", "nav-folder-collapse-indicator collapse-icon"); + attr(div1, "class", "nav-folder-title-content"); + attr(span0, "class", "tree-item-flair svelte-1u4uc91"); + attr(div2, "class", "nav-folder-title"); + attr(div3, "class", "staged nav-folder"); + toggle_class(div3, "is-collapsed", !ctx[13]); + attr(div4, "class", "nav-folder-collapse-indicator collapse-icon"); + attr(div5, "class", "nav-folder-title-content"); + attr(span1, "class", "tree-item-flair svelte-1u4uc91"); + attr(div6, "class", "nav-folder-title"); + attr(div7, "class", "changes nav-folder"); + toggle_class(div7, "is-collapsed", !ctx[12]); + attr(div8, "class", "nav-folder-children"); + attr(div9, "class", "nav-folder mod-root"); }, m(target, anchor) { - insert(target, div3, anchor); + insert(target, div9, anchor); + append2(div9, div8); + append2(div8, div3); append2(div3, div2); + append2(div2, div0); + append2(div2, t0); append2(div2, div1); append2(div2, t2); - append2(div2, span1); - append2(span1, t3); + append2(div2, span0); + append2(span0, t3); append2(div3, t4); if (if_block0) if_block0.m(div3, null); - insert(target, t5, anchor); - insert(target, div7, anchor); + append2(div8, t5); + append2(div8, div7); append2(div7, div6); + append2(div6, div4); + append2(div6, t6); append2(div6, div5); append2(div6, t8); - append2(div6, span3); - append2(span3, t9); + append2(div6, span1); + append2(span1, t9); append2(div7, t10); if (if_block1) if_block1.m(div7, null); - insert(target, t11, anchor); + append2(div8, t11); if (if_block2) - if_block2.m(target, anchor); - insert(target, if_block2_anchor, anchor); + if_block2.m(div8, null); current = true; if (!mounted) { dispose = [ @@ -13797,9 +28877,6 @@ function create_if_block4(ctx) { p(ctx2, dirty) { if ((!current || dirty[0] & 32) && t3_value !== (t3_value = ctx2[5].staged.length + "")) set_data(t3, t3_value); - if (dirty[0] & 8192) { - toggle_class(div2, "open", ctx2[13]); - } if (ctx2[13]) { if (if_block0) { if_block0.p(ctx2, dirty); @@ -13819,11 +28896,11 @@ function create_if_block4(ctx) { }); check_outros(); } + if (!current || dirty[0] & 8192) { + toggle_class(div3, "is-collapsed", !ctx2[13]); + } if ((!current || dirty[0] & 32) && t9_value !== (t9_value = ctx2[5].changed.length + "")) set_data(t9, t9_value); - if (dirty[0] & 4096) { - toggle_class(div6, "open", ctx2[12]); - } if (ctx2[12]) { if (if_block1) { if_block1.p(ctx2, dirty); @@ -13843,6 +28920,9 @@ function create_if_block4(ctx) { }); check_outros(); } + if (!current || dirty[0] & 4096) { + toggle_class(div7, "is-collapsed", !ctx2[12]); + } if (ctx2[6].length > 0) { if (if_block2) { if_block2.p(ctx2, dirty); @@ -13853,7 +28933,7 @@ function create_if_block4(ctx) { if_block2 = create_if_block_12(ctx2); if_block2.c(); transition_in(if_block2, 1); - if_block2.m(if_block2_anchor.parentNode, if_block2_anchor); + if_block2.m(div8, null); } } else if (if_block2) { group_outros(); @@ -13879,21 +28959,13 @@ function create_if_block4(ctx) { }, d(detaching) { if (detaching) - detach(div3); + detach(div9); if (if_block0) if_block0.d(); - if (detaching) - detach(t5); - if (detaching) - detach(div7); if (if_block1) if_block1.d(); - if (detaching) - detach(t11); if (if_block2) - if_block2.d(detaching); - if (detaching) - detach(if_block2_anchor); + if_block2.d(); mounted = false; run_all(dispose); } @@ -13918,7 +28990,7 @@ function create_if_block_6(ctx) { c() { div = element("div"); if_block.c(); - attr(div, "class", "file-view svelte-1f0ksxd"); + attr(div, "class", "nav-folder-children"); }, m(target, anchor) { insert(target, div, anchor); @@ -14142,7 +29214,7 @@ function create_if_block_42(ctx) { let if_block; let div_transition; let current; - const if_block_creators = [create_if_block_5, create_else_block_1]; + const if_block_creators = [create_if_block_52, create_else_block_12]; const if_blocks = []; function select_block_type_1(ctx2, dirty) { if (ctx2[2]) @@ -14155,7 +29227,7 @@ function create_if_block_42(ctx) { c() { div = element("div"); if_block.c(); - attr(div, "class", "file-view svelte-1f0ksxd"); + attr(div, "class", "nav-folder-children"); }, m(target, anchor) { insert(target, div, anchor); @@ -14215,7 +29287,7 @@ function create_if_block_42(ctx) { } }; } -function create_else_block_1(ctx) { +function create_else_block_12(ctx) { let each_1_anchor; let current; let each_value_1 = ctx[5].changed; @@ -14285,7 +29357,7 @@ function create_else_block_1(ctx) { } }; } -function create_if_block_5(ctx) { +function create_if_block_52(ctx) { let treecomponent; let current; treecomponent = new treeComponent_default({ @@ -14337,8 +29409,7 @@ function create_each_block_1(ctx) { props: { change: ctx[34], view: ctx[1], - manager: ctx[0].gitManager, - workspace: ctx[0].app.workspace + manager: ctx[0].gitManager } }); filecomponent.$on("git-refresh", triggerRefresh); @@ -14358,8 +29429,6 @@ function create_each_block_1(ctx) { filecomponent_changes.view = ctx2[1]; if (dirty[0] & 1) filecomponent_changes.manager = ctx2[0].gitManager; - if (dirty[0] & 1) - filecomponent_changes.workspace = ctx2[0].app.workspace; filecomponent.$set(filecomponent_changes); }, i(local) { @@ -14380,9 +29449,11 @@ function create_each_block_1(ctx) { function create_if_block_12(ctx) { let div3; let div2; + let div0; + let t0; let div1; let t2; - let span1; + let span; let t3_value = ctx[6].length + ""; let t3; let t4; @@ -14394,28 +29465,33 @@ function create_if_block_12(ctx) { c() { div3 = element("div"); div2 = element("div"); + div0 = element("div"); + div0.innerHTML = ``; + t0 = space(); div1 = element("div"); - div1.innerHTML = `
    - Recently Pulled Changes`; + div1.textContent = "Recently Pulled Files"; t2 = space(); - span1 = element("span"); + span = element("span"); t3 = text(t3_value); t4 = space(); if (if_block) if_block.c(); - attr(div1, "class", "svelte-1f0ksxd"); - attr(span1, "class", "tree-item-flair"); - attr(div2, "class", "opener tree-item-self is-clickable svelte-1f0ksxd"); - toggle_class(div2, "open", ctx[14]); - attr(div3, "class", "pulled"); + attr(div0, "class", "nav-folder-collapse-indicator collapse-icon"); + attr(div1, "class", "nav-folder-title-content"); + attr(span, "class", "tree-item-flair svelte-1u4uc91"); + attr(div2, "class", "nav-folder-title"); + attr(div3, "class", "pulled nav-folder"); + toggle_class(div3, "is-collapsed", !ctx[14]); }, m(target, anchor) { insert(target, div3, anchor); append2(div3, div2); + append2(div2, div0); + append2(div2, t0); append2(div2, div1); append2(div2, t2); - append2(div2, span1); - append2(span1, t3); + append2(div2, span); + append2(span, t3); append2(div3, t4); if (if_block) if_block.m(div3, null); @@ -14428,9 +29504,6 @@ function create_if_block_12(ctx) { p(ctx2, dirty) { if ((!current || dirty[0] & 64) && t3_value !== (t3_value = ctx2[6].length + "")) set_data(t3, t3_value); - if (dirty[0] & 16384) { - toggle_class(div2, "open", ctx2[14]); - } if (ctx2[14]) { if (if_block) { if_block.p(ctx2, dirty); @@ -14450,6 +29523,9 @@ function create_if_block_12(ctx) { }); check_outros(); } + if (!current || dirty[0] & 16384) { + toggle_class(div3, "is-collapsed", !ctx2[14]); + } }, i(local) { if (current) @@ -14490,7 +29566,7 @@ function create_if_block_22(ctx) { c() { div = element("div"); if_block.c(); - attr(div, "class", "file-view svelte-1f0ksxd"); + attr(div, "class", "nav-folder-children"); }, m(target, anchor) { insert(target, div, anchor); @@ -14708,8 +29784,8 @@ function create_each_block2(ctx) { } function create_fragment5(ctx) { let main; - let div9; - let div6; + let div8; + let div7; let div0; let t0; let div1; @@ -14722,9 +29798,9 @@ function create_fragment5(ctx) { let t4; let div5; let t5; - let div7; + let div6; let t6; - let div8; + let div9; let textarea; let t7; let t8; @@ -14733,12 +29809,12 @@ function create_fragment5(ctx) { let mounted; let dispose; let if_block0 = ctx[7] && create_if_block_8(ctx); - let if_block1 = ctx[5] && create_if_block4(ctx); + let if_block1 = ctx[5] && ctx[10] && ctx[9] && create_if_block4(ctx); return { c() { main = element("main"); - div9 = element("div"); - div6 = element("div"); + div8 = element("div"); + div7 = element("div"); div0 = element("div"); t0 = space(); div1 = element("div"); @@ -14751,9 +29827,9 @@ function create_fragment5(ctx) { t4 = space(); div5 = element("div"); t5 = space(); - div7 = element("div"); + div6 = element("div"); t6 = space(); - div8 = element("div"); + div9 = element("div"); textarea = element("textarea"); t7 = space(); if (if_block0) @@ -14764,73 +29840,73 @@ function create_fragment5(ctx) { if_block1.c(); attr(div0, "id", "commit-btn"); attr(div0, "data-icon", "check"); - attr(div0, "class", "nav-action-button"); + attr(div0, "class", "clickable-icon nav-action-button"); attr(div0, "aria-label", "Commit"); attr(div1, "id", "stage-all"); - attr(div1, "class", "nav-action-button"); + attr(div1, "class", "clickable-icon nav-action-button"); attr(div1, "data-icon", "plus-circle"); attr(div1, "aria-label", "Stage all"); attr(div2, "id", "unstage-all"); - attr(div2, "class", "nav-action-button"); + attr(div2, "class", "clickable-icon nav-action-button"); attr(div2, "data-icon", "minus-circle"); attr(div2, "aria-label", "Unstage all"); attr(div3, "id", "push"); - attr(div3, "class", "nav-action-button"); + attr(div3, "class", "clickable-icon nav-action-button"); attr(div3, "data-icon", "upload"); attr(div3, "aria-label", "Push"); attr(div4, "id", "pull"); - attr(div4, "class", "nav-action-button"); + attr(div4, "class", "clickable-icon nav-action-button"); attr(div4, "data-icon", "download"); attr(div4, "aria-label", "Pull"); attr(div5, "id", "layoutChange"); - attr(div5, "class", "nav-action-button"); + attr(div5, "class", "clickable-icon nav-action-button"); attr(div5, "aria-label", "Change Layout"); - attr(div6, "class", "group svelte-1f0ksxd"); - attr(div7, "id", "refresh"); - attr(div7, "class", "nav-action-button"); - attr(div7, "data-icon", "refresh-cw"); - attr(div7, "aria-label", "Refresh"); - toggle_class(div7, "loading", ctx[4]); - attr(textarea, "class", "commit-msg svelte-1f0ksxd"); + attr(div6, "id", "refresh"); + attr(div6, "class", "clickable-icon nav-action-button"); + attr(div6, "data-icon", "refresh-cw"); + attr(div6, "aria-label", "Refresh"); + toggle_class(div6, "loading", ctx[4]); + attr(div7, "class", "nav-buttons-container"); + attr(div8, "class", "nav-header"); + attr(textarea, "class", "commit-msg-input svelte-1u4uc91"); attr(textarea, "type", "text"); attr(textarea, "spellcheck", "true"); attr(textarea, "placeholder", "Commit Message"); - attr(div8, "class", "search-input-container svelte-1f0ksxd"); - attr(div9, "class", "nav-buttons-container svelte-1f0ksxd"); - attr(div10, "class", "git-view-body svelte-1f0ksxd"); - attr(main, "class", "svelte-1f0ksxd"); + attr(div9, "class", "git-commit-msg svelte-1u4uc91"); + attr(div10, "class", "nav-files-container"); + set_style(div10, "position", "relative"); }, m(target, anchor) { insert(target, main, anchor); - append2(main, div9); - append2(div9, div6); - append2(div6, div0); + append2(main, div8); + append2(div8, div7); + append2(div7, div0); ctx[20](div0); - append2(div6, t0); - append2(div6, div1); + append2(div7, t0); + append2(div7, div1); ctx[21](div1); - append2(div6, t1); - append2(div6, div2); + append2(div7, t1); + append2(div7, div2); ctx[22](div2); - append2(div6, t2); - append2(div6, div3); + append2(div7, t2); + append2(div7, div3); ctx[23](div3); - append2(div6, t3); - append2(div6, div4); + append2(div7, t3); + append2(div7, div4); ctx[24](div4); - append2(div6, t4); - append2(div6, div5); + append2(div7, t4); + append2(div7, div5); ctx[25](div5); - append2(div9, t5); - append2(div9, div7); - ctx[27](div7); - append2(div9, t6); - append2(div9, div8); - append2(div8, textarea); + append2(div7, t5); + append2(div7, div6); + ctx[27](div6); + append2(main, t6); + append2(main, div9); + append2(div9, textarea); set_input_value(textarea, ctx[7]); - append2(div8, t7); + append2(div9, t7); if (if_block0) - if_block0.m(div8, null); + if_block0.m(div9, null); append2(main, t8); append2(main, div10); if (if_block1) @@ -14844,15 +29920,15 @@ function create_fragment5(ctx) { listen(div3, "click", ctx[18]), listen(div4, "click", ctx[19]), listen(div5, "click", ctx[26]), - listen(div7, "click", triggerRefresh), + listen(div6, "click", triggerRefresh), listen(textarea, "input", ctx[28]) ]; mounted = true; } }, p(ctx2, dirty) { - if (dirty[0] & 16) { - toggle_class(div7, "loading", ctx2[4]); + if (!current || dirty[0] & 16) { + toggle_class(div6, "loading", ctx2[4]); } if (dirty[0] & 128) { set_input_value(textarea, ctx2[7]); @@ -14863,16 +29939,16 @@ function create_fragment5(ctx) { } else { if_block0 = create_if_block_8(ctx2); if_block0.c(); - if_block0.m(div8, null); + if_block0.m(div9, null); } } else if (if_block0) { if_block0.d(1); if_block0 = null; } - if (ctx2[5]) { + if (ctx2[5] && ctx2[10] && ctx2[9]) { if (if_block1) { if_block1.p(ctx2, dirty); - if (dirty[0] & 32) { + if (dirty[0] & 1568) { transition_in(if_block1, 1); } } else { @@ -14925,7 +30001,7 @@ function instance5($$self, $$props, $$invalidate) { let { plugin } = $$props; let { view } = $$props; let loading; - let status; + let status2; let lastPulledFiles = []; let commitMessage = plugin.settings.commitMessage; let buttons = []; @@ -14940,17 +30016,17 @@ function instance5($$self, $$props, $$invalidate) { addEventListener("git-view-refresh", refresh); plugin.app.workspace.onLayoutReady(() => { window.setTimeout(() => { - buttons.forEach((btn) => (0, import_obsidian16.setIcon)(btn, btn.getAttr("data-icon"), 16)); - (0, import_obsidian16.setIcon)(layoutBtn, showTree ? "list" : "folder", 16); + buttons.forEach((btn) => (0, import_obsidian21.setIcon)(btn, btn.getAttr("data-icon"), 16)); + (0, import_obsidian21.setIcon)(layoutBtn, showTree ? "list" : "folder", 16); }, 0); }); onDestroy(() => { removeEventListener("git-view-refresh", refresh); }); - function commit() { - return __awaiter(this, void 0, void 0, function* () { - $$invalidate(4, loading = true); - if (yield plugin.hasTooBigFiles(status.staged)) { + async function commit2() { + $$invalidate(4, loading = true); + if (status2) { + if (await plugin.hasTooBigFiles(status2.staged)) { plugin.setState(PluginState.idle); return false; } @@ -14959,60 +30035,64 @@ function instance5($$self, $$props, $$invalidate) { $$invalidate(7, commitMessage = ""); } }).finally(triggerRefresh); - }); + } } - function refresh() { - return __awaiter(this, void 0, void 0, function* () { - if (!plugin.gitReady) { - $$invalidate(5, status = void 0); - return; - } - $$invalidate(5, status = plugin.cachedStatus); - if (plugin.lastPulledFiles && plugin.lastPulledFiles != lastPulledFiles) { - $$invalidate(6, lastPulledFiles = plugin.lastPulledFiles); - $$invalidate(11, lastPulledFilesHierarchy = { - title: "", - children: plugin.gitManager.getTreeStructure(lastPulledFiles) - }); - } - if (status) { - if (status.changed.length + status.staged.length > 500) { - $$invalidate(5, status = void 0); - if (!plugin.loading) { - plugin.displayError("Too many changes to display"); - } - } else { - $$invalidate(9, changeHierarchy = { - title: "", - children: plugin.gitManager.getTreeStructure(status.changed) - }); - $$invalidate(10, stagedHierarchy = { - title: "", - children: plugin.gitManager.getTreeStructure(status.staged) - }); + async function refresh() { + if (!plugin.gitReady) { + $$invalidate(5, status2 = void 0); + return; + } + $$invalidate(5, status2 = plugin.cachedStatus); + if (plugin.lastPulledFiles && plugin.lastPulledFiles != lastPulledFiles) { + $$invalidate(6, lastPulledFiles = plugin.lastPulledFiles); + $$invalidate(11, lastPulledFilesHierarchy = { + title: "", + path: "", + children: plugin.gitManager.getTreeStructure(lastPulledFiles) + }); + } + if (status2) { + const sort = (a, b) => { + return a.vault_path.split("/").last().localeCompare(b.vault_path.split("/").last()); + }; + status2.changed.sort(sort); + status2.staged.sort(sort); + if (status2.changed.length + status2.staged.length > 500) { + $$invalidate(5, status2 = void 0); + if (!plugin.loading) { + plugin.displayError("Too many changes to display"); } } else { - $$invalidate(9, changeHierarchy = void 0); - $$invalidate(10, stagedHierarchy = void 0); + $$invalidate(9, changeHierarchy = { + title: "", + path: "", + children: plugin.gitManager.getTreeStructure(status2.changed) + }); + $$invalidate(10, stagedHierarchy = { + title: "", + path: "", + children: plugin.gitManager.getTreeStructure(status2.staged) + }); } - $$invalidate(4, loading = plugin.loading); - }); + } else { + $$invalidate(9, changeHierarchy = void 0); + $$invalidate(10, stagedHierarchy = void 0); + } + $$invalidate(4, loading = plugin.loading); } function stageAll() { $$invalidate(4, loading = true); - plugin.gitManager.stageAll({ status }).finally(triggerRefresh); + plugin.gitManager.stageAll({ status: status2 }).finally(triggerRefresh); } function unstageAll() { $$invalidate(4, loading = true); - plugin.gitManager.unstageAll({ status }).finally(triggerRefresh); + plugin.gitManager.unstageAll({ status: status2 }).finally(triggerRefresh); } - function push() { + function push2() { $$invalidate(4, loading = true); - if (ready) { - plugin.push().finally(triggerRefresh); - } + plugin.push().finally(triggerRefresh); } - function pull() { + function pull2() { $$invalidate(4, loading = true); plugin.pullChangesFromRemote().finally(triggerRefresh); } @@ -15057,7 +30137,7 @@ function instance5($$self, $$props, $$invalidate) { $$invalidate(0, plugin.settings.treeStructure = showTree, plugin); plugin.saveSettings(); }; - function div7_binding($$value) { + function div6_binding($$value) { binding_callbacks[$$value ? "unshift" : "push"](() => { buttons[6] = $$value; $$invalidate(8, buttons); @@ -15082,7 +30162,7 @@ function instance5($$self, $$props, $$invalidate) { $: { if (layoutBtn) { layoutBtn.empty(); - (0, import_obsidian16.setIcon)(layoutBtn, showTree ? "list" : "folder", 16); + (0, import_obsidian21.setIcon)(layoutBtn, showTree ? "list" : "folder", 16); } } } @@ -15093,7 +30173,7 @@ function instance5($$self, $$props, $$invalidate) { showTree, layoutBtn, loading, - status, + status2, lastPulledFiles, commitMessage, buttons, @@ -15103,11 +30183,11 @@ function instance5($$self, $$props, $$invalidate) { changesOpen, stagedOpen, lastPulledFilesOpen, - commit, + commit2, stageAll, unstageAll, - push, - pull, + push2, + pull2, div0_binding, div1_binding, div2_binding, @@ -15115,7 +30195,7 @@ function instance5($$self, $$props, $$invalidate) { div4_binding, div5_binding, click_handler, - div7_binding, + div6_binding, textarea_input_handler, click_handler_1, click_handler_2, @@ -15126,13 +30206,13 @@ function instance5($$self, $$props, $$invalidate) { var GitView = class extends SvelteComponent { constructor(options) { super(); - init(this, options, instance5, create_fragment5, safe_not_equal, { plugin: 0, view: 1 }, add_css5, [-1, -1]); + init2(this, options, instance5, create_fragment5, safe_not_equal, { plugin: 0, view: 1 }, add_css5, [-1, -1]); } }; var gitView_default = GitView; // src/ui/sidebar/sidebarView.ts -var GitView2 = class extends import_obsidian17.ItemView { +var GitView2 = class extends import_obsidian22.ItemView { constructor(leaf, plugin) { super(leaf); this.plugin = plugin; @@ -15162,8 +30242,33 @@ var GitView2 = class extends import_obsidian17.ItemView { } }; +// src/ui/statusBar/branchStatusBar.ts +init_polyfill_buffer(); +var BranchStatusBar = class { + constructor(statusBarEl, plugin) { + this.statusBarEl = statusBarEl; + this.plugin = plugin; + this.statusBarEl.addClass("mod-clickable"); + this.statusBarEl.onClickEvent((e) => { + this.plugin.switchBranch(); + }); + } + async display() { + if (this.plugin.gitReady) { + const branchInfo = await this.plugin.gitManager.branchInfo(); + if (branchInfo.current != void 0) { + this.statusBarEl.setText(branchInfo.current); + } else { + this.statusBarEl.empty(); + } + } else { + this.statusBarEl.empty(); + } + } +}; + // src/main.ts -var ObsidianGit = class extends import_obsidian18.Plugin { +var ObsidianGit = class extends import_obsidian23.Plugin { constructor() { super(...arguments); this.gitReady = false; @@ -15171,252 +30276,305 @@ var ObsidianGit = class extends import_obsidian18.Plugin { this.conflictOutputFile = "conflict-files-obsidian-git.md"; this.offlineMode = false; this.loading = false; - this.debRefresh = (0, import_obsidian18.debounce)(() => { - if (this.settings.refreshSourceControl) { - this.refresh(); - } - }, 7e3, true); } setState(state) { var _a2; this.state = state; (_a2 = this.statusBar) == null ? void 0 : _a2.display(); } - updateCachedStatus() { - return __async(this, null, function* () { - this.cachedStatus = yield this.gitManager.status(); - return this.cachedStatus; - }); + async updateCachedStatus() { + this.cachedStatus = await this.gitManager.status(); + return this.cachedStatus; } - refresh() { - return __async(this, null, function* () { - const gitView = this.app.workspace.getLeavesOfType(GIT_VIEW_CONFIG.type); - if (this.settings.changedFilesInStatusBar || gitView.length > 0) { - this.loading = true; - dispatchEvent(new CustomEvent("git-view-refresh")); - yield this.updateCachedStatus(); - this.loading = false; - dispatchEvent(new CustomEvent("git-view-refresh")); + async refresh() { + const gitView = this.app.workspace.getLeavesOfType(GIT_VIEW_CONFIG.type); + if (this.settings.changedFilesInStatusBar || gitView.length > 0) { + this.loading = true; + dispatchEvent(new CustomEvent("git-view-refresh")); + await this.updateCachedStatus(); + this.loading = false; + dispatchEvent(new CustomEvent("git-view-refresh")); + } + } + async onload() { + console.log("loading " + this.manifest.name + " plugin"); + this.localStorage = new LocalStorageSettings(this); + this.localStorage.migrate(); + await this.loadSettings(); + this.migrateSettings(); + this.addSettingTab(new ObsidianGitSettingsTab(this.app, this)); + if (!this.localStorage.getPluginDisabled()) { + this.loadPlugin(); + } + } + async loadPlugin() { + addEventListener("git-refresh", this.refresh.bind(this)); + this.registerView(GIT_VIEW_CONFIG.type, (leaf) => { + return new GitView2(leaf, this); + }); + this.registerView(DIFF_VIEW_CONFIG.type, (leaf) => { + return new DiffView(leaf, this); + }); + this.app.workspace.registerHoverLinkSource(GIT_VIEW_CONFIG.type, { + display: "Git View", + defaultMod: true + }); + this.setRefreshDebouncer(); + this.addCommand({ + id: "edit-gitignore", + name: "Edit .gitignore", + callback: async () => { + const content = await this.app.vault.adapter.read(this.gitManager.getVaultPath(".gitignore")); + const modal = new IgnoreModal(this.app, content); + const res = await modal.open(); + if (res !== void 0) { + await this.app.vault.adapter.write(this.gitManager.getVaultPath(".gitignore"), res); + this.refresh(); + } } }); - } - onload() { - return __async(this, null, function* () { - console.log("loading " + this.manifest.name + " plugin"); - this.localStorage = new LocalStorageSettings(this); - yield this.loadSettings(); - this.migrateSettings(); - addEventListener("git-refresh", this.refresh.bind(this)); - this.registerView(GIT_VIEW_CONFIG.type, (leaf) => { - return new GitView2(leaf, this); - }); - this.registerView(DIFF_VIEW_CONFIG.type, (leaf) => { - return new DiffView(leaf, this); - }); - this.app.workspace.registerHoverLinkSource(GIT_VIEW_CONFIG.type, { - display: "Git View", - defaultMod: true - }); - this.addSettingTab(new ObsidianGitSettingsTab(this.app, this)); - this.addCommand({ - id: "edit-gitignore", - name: "Edit .gitignore", - callback: () => __async(this, null, function* () { - const content = yield this.app.vault.adapter.read(this.gitManager.getVaultPath(".gitignore")); - const modal = new IgnoreModal(this.app, content); - const res = yield modal.open(); - if (res !== void 0) { - yield this.app.vault.adapter.write(this.gitManager.getVaultPath(".gitignore"), res); + this.addCommand({ + id: "open-git-view", + name: "Open source control view", + callback: async () => { + const leafs = this.app.workspace.getLeavesOfType(GIT_VIEW_CONFIG.type); + let leaf; + if (leafs.length === 0) { + leaf = this.app.workspace.getRightLeaf(false); + await leaf.setViewState({ + type: GIT_VIEW_CONFIG.type + }); + } else { + leaf = leafs.first(); + } + this.app.workspace.revealLeaf(leaf); + dispatchEvent(new CustomEvent("git-refresh")); + } + }); + this.addCommand({ + id: "open-diff-view", + name: "Open diff view", + checkCallback: (checking) => { + var _a2; + const file = this.app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + (_a2 = getNewLeaf()) == null ? void 0 : _a2.setViewState({ type: DIFF_VIEW_CONFIG.type, state: { staged: false, file: file.path } }); + } + } + }); + this.addCommand({ + id: "view-file-on-github", + name: "Open file on GitHub", + editorCallback: (editor, { file }) => openLineInGitHub(editor, file, this.gitManager) + }); + this.addCommand({ + id: "view-history-on-github", + name: "Open file history on GitHub", + editorCallback: (_, { file }) => openHistoryInGitHub(file, this.gitManager) + }); + this.addCommand({ + id: "pull", + name: "Pull", + callback: () => this.promiseQueue.addTask(() => this.pullChangesFromRemote()) + }); + this.addCommand({ + id: "add-to-gitignore", + name: "Add file to gitignore", + checkCallback: (checking) => { + const file = app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + app.vault.adapter.append(this.gitManager.getVaultPath(".gitignore"), "\n" + this.gitManager.getPath(file.path, true)).then(() => { this.refresh(); - } - }) - }); - this.addCommand({ - id: "open-git-view", - name: "Open source control view", - callback: () => __async(this, null, function* () { - if (this.app.workspace.getLeavesOfType(GIT_VIEW_CONFIG.type).length === 0) { - yield this.app.workspace.getRightLeaf(false).setViewState({ - type: GIT_VIEW_CONFIG.type - }); - } - this.app.workspace.revealLeaf(this.app.workspace.getLeavesOfType(GIT_VIEW_CONFIG.type).first()); - dispatchEvent(new CustomEvent("git-refresh")); - }) - }); - this.addCommand({ - id: "open-diff-view", - name: "Open diff view", - editorCallback: (editor, view) => __async(this, null, function* () { - this.app.workspace.createLeafBySplit(view.leaf).setViewState({ type: DIFF_VIEW_CONFIG.type, state: { staged: false, file: view.file.path } }); - }) - }); - this.addCommand({ - id: "view-file-on-github", - name: "Open file on GitHub", - editorCallback: (editor, { file }) => openLineInGitHub(editor, file, this.gitManager) - }); - this.addCommand({ - id: "view-history-on-github", - name: "Open file history on GitHub", - editorCallback: (_, { file }) => openHistoryInGitHub(file, this.gitManager) - }); - this.addCommand({ - id: "pull", - name: "Pull", - callback: () => this.promiseQueue.addTask(() => this.pullChangesFromRemote()) - }); - this.addCommand({ - id: "add-to-gitignore", - name: "Add file to gitignore", - checkCallback: (checking) => { - const file = app.workspace.getActiveFile(); - if (checking) { - return file !== void 0; - } else { - app.vault.adapter.append(this.gitManager.getVaultPath(".gitignore"), "\n" + this.gitManager.getPath(file.path, true)).then(() => { - this.refresh(); - }); - } + }); } - }); - this.addCommand({ - id: "push", - name: "Create backup", - callback: () => this.promiseQueue.addTask(() => this.createBackup(false)) - }); - this.addCommand({ - id: "backup-and-close", - name: "Create backup and close", - callback: () => this.promiseQueue.addTask(() => __async(this, null, function* () { - yield this.createBackup(false); - window.close(); - })) - }); - this.addCommand({ - id: "commit-push-specified-message", - name: "Create backup with specific message", - callback: () => this.promiseQueue.addTask(() => this.createBackup(false, true)) - }); - this.addCommand({ - id: "commit", - name: "Commit all changes", - callback: () => this.promiseQueue.addTask(() => this.commit(false)) - }); - this.addCommand({ - id: "commit-specified-message", - name: "Commit all changes with specific message", - callback: () => this.promiseQueue.addTask(() => this.commit(false, true)) - }); - this.addCommand({ - id: "commit-staged", - name: "Commit staged", - callback: () => this.promiseQueue.addTask(() => this.commit(false, false, true)) - }); - this.addCommand({ - id: "commit-staged-specified-message", - name: "Commit staged with specific message", - callback: () => this.promiseQueue.addTask(() => this.commit(false, true, true)) - }); - this.addCommand({ - id: "push2", - name: "Push", - callback: () => this.promiseQueue.addTask(() => this.push()) - }); - this.addCommand({ - id: "stage-current-file", - name: "Stage current file", - checkCallback: (checking) => { - if (checking) { - return this.app.workspace.getActiveFile() !== null; - } else { - this.promiseQueue.addTask(() => this.stageCurrentFile()); - } - } - }); - this.addCommand({ - id: "unstage-current-file", - name: "Unstage current file", - checkCallback: (checking) => { - if (checking) { - return this.app.workspace.getActiveFile() !== null; - } else { - this.promiseQueue.addTask(() => this.unstageCurrentFile()); - } - } - }); - this.addCommand({ - id: "edit-remotes", - name: "Edit remotes", - callback: () => __async(this, null, function* () { - return this.editRemotes(); - }) - }); - this.addCommand({ - id: "remove-remote", - name: "Remove remote", - callback: () => __async(this, null, function* () { - return this.removeRemote(); - }) - }); - this.addCommand({ - id: "delete-repo", - name: "CAUTION: Delete repository", - callback: () => __async(this, null, function* () { - const repoExists = yield this.app.vault.adapter.exists(`${this.settings.basePath}/.git`); - if (repoExists) { - const modal = new GeneralModal(this.app, ["NO", "YES"], "Do you really want to delete the repository (.git directory)? This action cannot be undone.", false, true); - const shouldDelete = (yield modal.open()) === "YES"; - if (shouldDelete) { - yield this.app.vault.adapter.rmdir(`${this.settings.basePath}/.git`, true); - new import_obsidian18.Notice("Successfully deleted repository. Reloading plugin..."); - this.unloadPlugin(); - this.init(); - } - } else { - new import_obsidian18.Notice("No repository found"); - } - }) - }); - this.addCommand({ - id: "init-repo", - name: "Initialize a new repo", - callback: () => __async(this, null, function* () { - return this.createNewRepo(); - }) - }); - this.addCommand({ - id: "clone-repo", - name: "Clone an existing remote repo", - callback: () => __async(this, null, function* () { - return this.cloneNewRepo(); - }) - }); - this.addCommand({ - id: "list-changed-files", - name: "List changed files", - callback: () => __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return; - const status = yield this.gitManager.status(); - this.setState(PluginState.idle); - if (status.changed.length + status.staged.length > 500) { - this.displayError("Too many changes to display"); - return; - } - new ChangedFilesModal(this, status.changed).open(); - }) - }); - this.registerEvent(this.app.workspace.on("file-menu", (menu, file, source) => { - this.handleFileMenu(menu, file, source); - })); - if (this.settings.showStatusBar) { - let statusBarEl = this.addStatusBarItem(); - this.statusBar = new StatusBar(statusBarEl, this); - this.registerInterval(window.setInterval(() => this.statusBar.display(), 1e3)); } - this.app.workspace.onLayoutReady(() => this.init()); }); + this.addCommand({ + id: "push", + name: "Create backup", + callback: () => this.promiseQueue.addTask(() => this.createBackup(false)) + }); + this.addCommand({ + id: "backup-and-close", + name: "Create backup and close", + callback: () => this.promiseQueue.addTask(async () => { + await this.createBackup(false); + window.close(); + }) + }); + this.addCommand({ + id: "commit-push-specified-message", + name: "Create backup with specific message", + callback: () => this.promiseQueue.addTask(() => this.createBackup(false, true)) + }); + this.addCommand({ + id: "commit", + name: "Commit all changes", + callback: () => this.promiseQueue.addTask(() => this.commit(false)) + }); + this.addCommand({ + id: "commit-specified-message", + name: "Commit all changes with specific message", + callback: () => this.promiseQueue.addTask(() => this.commit(false, true)) + }); + this.addCommand({ + id: "commit-staged", + name: "Commit staged", + callback: () => this.promiseQueue.addTask(() => this.commit(false, false, true)) + }); + this.addCommand({ + id: "commit-staged-specified-message", + name: "Commit staged with specific message", + callback: () => this.promiseQueue.addTask(() => this.commit(false, true, true)) + }); + this.addCommand({ + id: "push2", + name: "Push", + callback: () => this.promiseQueue.addTask(() => this.push()) + }); + this.addCommand({ + id: "stage-current-file", + name: "Stage current file", + checkCallback: (checking) => { + const file = this.app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + this.promiseQueue.addTask(() => this.stageFile(file)); + } + } + }); + this.addCommand({ + id: "unstage-current-file", + name: "Unstage current file", + checkCallback: (checking) => { + const file = this.app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + this.promiseQueue.addTask(() => this.unstageFile(file)); + } + } + }); + this.addCommand({ + id: "edit-remotes", + name: "Edit remotes", + callback: async () => this.editRemotes() + }); + this.addCommand({ + id: "remove-remote", + name: "Remove remote", + callback: async () => this.removeRemote() + }); + this.addCommand({ + id: "delete-repo", + name: "CAUTION: Delete repository", + callback: async () => { + const repoExists = await this.app.vault.adapter.exists(`${this.settings.basePath}/.git`); + if (repoExists) { + const modal = new GeneralModal({ options: ["NO", "YES"], placeholder: "Do you really want to delete the repository (.git directory)? This action cannot be undone.", onlySelection: true }); + const shouldDelete = await modal.open() === "YES"; + if (shouldDelete) { + await this.app.vault.adapter.rmdir(`${this.settings.basePath}/.git`, true); + new import_obsidian23.Notice("Successfully deleted repository. Reloading plugin..."); + this.unloadPlugin(); + this.init(); + } + } else { + new import_obsidian23.Notice("No repository found"); + } + } + }); + this.addCommand({ + id: "init-repo", + name: "Initialize a new repo", + callback: async () => this.createNewRepo() + }); + this.addCommand({ + id: "clone-repo", + name: "Clone an existing remote repo", + callback: async () => this.cloneNewRepo() + }); + this.addCommand({ + id: "list-changed-files", + name: "List changed files", + callback: async () => { + if (!await this.isAllInitialized()) + return; + const status2 = await this.gitManager.status(); + this.setState(PluginState.idle); + if (status2.changed.length + status2.staged.length > 500) { + this.displayError("Too many changes to display"); + return; + } + new ChangedFilesModal(this, status2.changed).open(); + } + }); + this.addCommand({ + id: "switch-branch", + name: "Switch branch", + callback: () => { + this.switchBranch(); + } + }); + this.addCommand({ + id: "create-branch", + name: "Create new branch", + callback: () => { + this.createBranch(); + } + }); + this.addCommand({ + id: "delete-branch", + name: "Delete branch", + callback: () => { + this.deleteBranch(); + } + }); + this.registerEvent(this.app.workspace.on("file-menu", (menu, file, source) => { + this.handleFileMenu(menu, file, source); + })); + if (this.settings.showStatusBar) { + const statusBarEl = this.addStatusBarItem(); + this.statusBar = new StatusBar(statusBarEl, this); + this.registerInterval(window.setInterval(() => { + var _a2; + return (_a2 = this.statusBar) == null ? void 0 : _a2.display(); + }, 1e3)); + } + if (import_obsidian23.Platform.isDesktop && this.settings.showBranchStatusBar) { + const branchStatusBarEl = this.addStatusBarItem(); + this.branchBar = new BranchStatusBar(branchStatusBarEl, this); + this.registerInterval(window.setInterval(() => { + var _a2; + return (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + }, 6e4)); + } + this.app.workspace.onLayoutReady(() => this.init()); + } + setRefreshDebouncer() { + var _a2; + (_a2 = this.debRefresh) == null ? void 0 : _a2.cancel(); + this.debRefresh = (0, import_obsidian23.debounce)(() => { + if (this.settings.refreshSourceControl) { + this.refresh(); + } + }, this.settings.refreshSourceControlTimer, true); + } + async showNotices() { + const length = 1e4; + if (this.manifest.id === "obsidian-git" && import_obsidian23.Platform.isDesktopApp && !this.settings.showedMobileNotice) { + new import_obsidian23.Notice("Obsidian Git is now available on mobile! Please read the plugin's README for more information.", length); + this.settings.showedMobileNotice = true; + await this.saveSettings(); + } + if (this.manifest.id === "obsidian-git-isomorphic") { + new import_obsidian23.Notice("Obsidian Git Mobile is now deprecated. Please uninstall it and install Obsidian Git instead.", length); + } } handleFileMenu(menu, file, source) { if (source !== "file-explorer-context-menu") { @@ -15429,43 +30587,43 @@ var ObsidianGit = class extends import_obsidian18.Plugin { return; menu.addItem((item) => { item.setTitle(`Git: Stage`).setIcon("plus-circle").setSection("action").onClick((_) => { - this.promiseQueue.addTask(() => __async(this, null, function* () { - if (file instanceof import_obsidian18.TFile) { - yield this.gitManager.stage(file.path, true); + this.promiseQueue.addTask(async () => { + if (file instanceof import_obsidian23.TFile) { + await this.gitManager.stage(file.path, true); } else { - yield this.gitManager.stageAll({ dir: this.gitManager.getPath(file.path, true) }); + await this.gitManager.stageAll({ dir: this.gitManager.getPath(file.path, true) }); } this.displayMessage(`Staged ${file.path}`); - })); + }); }); }); menu.addItem((item) => { item.setTitle(`Git: Unstage`).setIcon("minus-circle").setSection("action").onClick((_) => { - this.promiseQueue.addTask(() => __async(this, null, function* () { - if (file instanceof import_obsidian18.TFile) { - yield this.gitManager.unstage(file.path, true); + this.promiseQueue.addTask(async () => { + if (file instanceof import_obsidian23.TFile) { + await this.gitManager.unstage(file.path, true); } else { - yield this.gitManager.unstageAll({ dir: this.gitManager.getPath(file.path, true) }); + await this.gitManager.unstageAll({ dir: this.gitManager.getPath(file.path, true) }); } this.displayMessage(`Unstaged ${file.path}`); - })); + }); }); }); } - migrateSettings() { + async migrateSettings() { if (this.settings.mergeOnPull != void 0) { this.settings.syncMethod = this.settings.mergeOnPull ? "merge" : "rebase"; this.settings.mergeOnPull = void 0; - return this.saveSettings(); + await this.saveSettings(); } if (this.settings.autoCommitMessage === void 0) { this.settings.autoCommitMessage = this.settings.commitMessage; - this.saveSettings(); + await this.saveSettings(); } if (this.settings.gitPath != void 0) { this.localStorage.setGitPath(this.settings.gitPath); this.settings.gitPath = void 0; - this.saveSettings(); + await this.saveSettings(); } } unloadPlugin() { @@ -15481,399 +30639,423 @@ var ObsidianGit = class extends import_obsidian18.Plugin { this.app.metadataCache.offref(this.renameEvent); this.debRefresh.cancel(); } - onunload() { - return __async(this, null, function* () { - this.app.workspace.unregisterHoverLinkSource(GIT_VIEW_CONFIG.type); - this.app.workspace.detachLeavesOfType(GIT_VIEW_CONFIG.type); - this.app.workspace.detachLeavesOfType(DIFF_VIEW_CONFIG.type); - this.unloadPlugin(); - console.log("unloading " + this.manifest.name + " plugin"); - }); + async onunload() { + this.app.workspace.unregisterHoverLinkSource(GIT_VIEW_CONFIG.type); + this.unloadPlugin(); + console.log("unloading " + this.manifest.name + " plugin"); } - loadSettings() { - return __async(this, null, function* () { - this.settings = Object.assign({}, DEFAULT_SETTINGS, yield this.loadData()); - }); + async loadSettings() { + let data = await this.loadData(); + if (data == void 0) { + data = { showedMobileNotice: true }; + } + this.settings = Object.assign({}, DEFAULT_SETTINGS, data); } - saveSettings() { - return __async(this, null, function* () { - yield this.saveData(this.settings); - }); + async saveSettings() { + await this.saveData(this.settings); } - saveLastAuto(date, mode) { - return __async(this, null, function* () { - if (mode === "backup") { - this.localStorage.setLastAutoBackup(date.toString()); - } else if (mode === "pull") { - this.localStorage.setLastAutoPull(date.toString()); - } else if (mode === "push") { - this.localStorage.setLastAutoPush(date.toString()); - } - }); + async saveLastAuto(date, mode) { + if (mode === "backup") { + this.localStorage.setLastAutoBackup(date.toString()); + } else if (mode === "pull") { + this.localStorage.setLastAutoPull(date.toString()); + } else if (mode === "push") { + this.localStorage.setLastAutoPush(date.toString()); + } } - loadLastAuto() { - return __async(this, null, function* () { - var _a2, _b, _c; - return { - "backup": new Date((_a2 = this.localStorage.getLastAutoBackup()) != null ? _a2 : ""), - "pull": new Date((_b = this.localStorage.getLastAutoPull()) != null ? _b : ""), - "push": new Date((_c = this.localStorage.getLastAutoPush()) != null ? _c : "") - }; - }); + async loadLastAuto() { + var _a2, _b, _c; + return { + "backup": new Date((_a2 = this.localStorage.getLastAutoBackup()) != null ? _a2 : ""), + "pull": new Date((_b = this.localStorage.getLastAutoPull()) != null ? _b : ""), + "push": new Date((_c = this.localStorage.getLastAutoPush()) != null ? _c : "") + }; } - init() { - return __async(this, null, function* () { - try { - if (true) { - this.gitManager = new SimpleGit(this); - yield this.gitManager.setGitInstance(); - } else { - this.gitManager = new IsomorphicGit(this); - } - const result = yield this.gitManager.checkRequirements(); - switch (result) { - case "missing-git": - this.displayError("Cannot run git command"); - break; - case "missing-repo": - new import_obsidian18.Notice("Can't find a valid git repository. Please create one via the given command or clone an existing repo."); - break; - case "valid": - this.gitReady = true; - this.setState(PluginState.idle); - this.modifyEvent = this.app.vault.on("modify", () => { - this.debRefresh(); - }); - this.deleteEvent = this.app.vault.on("delete", () => { - this.debRefresh(); - }); - this.createEvent = this.app.vault.on("create", () => { - this.debRefresh(); - }); - this.renameEvent = this.app.vault.on("rename", () => { - this.debRefresh(); - }); - this.registerEvent(this.modifyEvent); - this.registerEvent(this.deleteEvent); - this.registerEvent(this.createEvent); - this.registerEvent(this.renameEvent); - dispatchEvent(new CustomEvent("git-refresh")); - if (this.settings.autoPullOnBoot) { - this.promiseQueue.addTask(() => this.pullChangesFromRemote()); - } - const lastAutos = yield this.loadLastAuto(); - if (this.settings.autoSaveInterval > 0) { - const now2 = new Date(); - const diff = this.settings.autoSaveInterval - Math.round((now2.getTime() - lastAutos.backup.getTime()) / 1e3 / 60); - this.startAutoBackup(diff <= 0 ? 0 : diff); - } - if (this.settings.differentIntervalCommitAndPush && this.settings.autoPushInterval > 0) { - const now2 = new Date(); - const diff = this.settings.autoPushInterval - Math.round((now2.getTime() - lastAutos.push.getTime()) / 1e3 / 60); - this.startAutoPush(diff <= 0 ? 0 : diff); - } - if (this.settings.autoPullInterval > 0) { - const now2 = new Date(); - const diff = this.settings.autoPullInterval - Math.round((now2.getTime() - lastAutos.pull.getTime()) / 1e3 / 60); - this.startAutoPull(diff <= 0 ? 0 : diff); - } - break; - default: - console.log("Something weird happened. The 'checkRequirements' result is " + result); - } - } catch (error) { - this.displayError(error); - console.error(error); - } - }); - } - createNewRepo() { - return __async(this, null, function* () { - yield this.gitManager.init(); - new import_obsidian18.Notice("Initialized new repo"); - yield this.init(); - }); - } - cloneNewRepo() { - return __async(this, null, function* () { - const modal = new GeneralModal(this.app, [], "Enter remote URL"); - const url = yield modal.open(); - if (url) { - const confirmOption = "Vault Root"; - let dir = yield new GeneralModal(this.app, [confirmOption], "Enter directory for clone. It needs to be empty or not existent.", this.gitManager instanceof IsomorphicGit).open(); - if (dir !== void 0) { - if (dir === confirmOption) { - dir = "."; - } - dir = (0, import_obsidian18.normalizePath)(dir); - if (dir === "/") { - dir = "."; - } - if (dir === ".") { - const modal2 = new GeneralModal(this.app, ["NO", "YES"], `Does your remote repo contain a ${app.vault.configDir} directory at the root?`, false, true); - const containsConflictDir = yield modal2.open(); - if (containsConflictDir === void 0) { - new import_obsidian18.Notice("Aborted clone"); - return; - } else if (containsConflictDir === "YES") { - const confirmOption2 = "DELETE ALL YOUR LOCAL CONFIG AND PLUGINS"; - const modal3 = new GeneralModal(this.app, ["Abort clone", confirmOption2], `To avoid conflicts, the local ${app.vault.configDir} directory needs to be deleted.`, false, true); - const shouldDelete = (yield modal3.open()) === confirmOption2; - if (shouldDelete) { - yield this.app.vault.adapter.rmdir(app.vault.configDir, true); - } else { - new import_obsidian18.Notice("Aborted clone"); - return; - } - } - } - new import_obsidian18.Notice(`Cloning new repo into "${dir}"`); - yield this.gitManager.clone(url, dir); - new import_obsidian18.Notice("Cloned new repo."); - new import_obsidian18.Notice("Please restart Obsidian"); - if (dir && dir !== ".") { - this.settings.basePath = dir; - this.saveSettings(); - } - } - } - }); - } - isAllInitialized() { - return __async(this, null, function* () { - if (!this.gitReady) { - yield this.init(); - } - return this.gitReady; - }); - } - pullChangesFromRemote() { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return; - const filesUpdated = yield this.pull(); - if (!filesUpdated) { - this.displayMessage("Everything is up-to-date"); - } - if (this.gitManager instanceof SimpleGit) { - const status = yield this.gitManager.status(); - if (status.conflicted.length > 0) { - this.displayError(`You have ${status.conflicted.length} conflict ${status.conflicted.length > 1 ? "files" : "file"}`); - this.handleConflict(status.conflicted); - } - } - dispatchEvent(new CustomEvent("git-refresh")); - this.lastUpdate = Date.now(); - this.setState(PluginState.idle); - }); - } - createBackup(fromAutoBackup, requestCustomMessage = false) { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return; - if (!(yield this.commit(fromAutoBackup, requestCustomMessage))) - return; - if (!this.settings.disablePush) { - if (yield this.gitManager.canPush()) { - if (this.settings.pullBeforePush) { - yield this.pull(); - } - yield this.push(); - } else { - this.displayMessage("No changes to push"); - } - } - this.setState(PluginState.idle); - }); - } - commit(fromAutoBackup, requestCustomMessage = false, onlyStaged = false) { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return false; - const hadConflict = this.localStorage.getConflict() === "true"; - let changedFiles; - let status; - let unstagedFiles; - if (this.gitManager instanceof SimpleGit) { - const file = this.app.vault.getAbstractFileByPath(this.conflictOutputFile); - yield this.app.vault.delete(file); - status = yield this.updateCachedStatus(); - if (fromAutoBackup && status.conflicted.length > 0) { - this.displayError(`Did not commit, because you have ${status.conflicted.length} conflict ${status.conflicted.length > 1 ? "files" : "file"}. Please resolve them and commit per command.`); - this.handleConflict(status.conflicted); - return; - } - changedFiles = [...status.changed, ...status.staged]; - } else if (fromAutoBackup && hadConflict) { - this.setState(PluginState.conflicted); - this.displayError(`Did not commit, because you have conflict files. Please resolve them and commit per command.`); - return; - } else if (hadConflict) { - const file = this.app.vault.getAbstractFileByPath(this.conflictOutputFile); - yield this.app.vault.delete(file); - status = yield this.updateCachedStatus(); - changedFiles = [...status.changed, ...status.staged]; + async init() { + var _a2; + this.showNotices(); + try { + if (import_obsidian23.Platform.isDesktopApp) { + this.gitManager = new SimpleGit(this); + await this.gitManager.setGitInstance(); } else { - if (onlyStaged) { - changedFiles = yield this.gitManager.getStagedFiles(); - } else { - unstagedFiles = yield this.gitManager.getUnstagedFiles(); - changedFiles = unstagedFiles.map(({ filepath }) => ({ vault_path: this.gitManager.getVaultPath(filepath) })); - } + this.gitManager = new IsomorphicGit(this); } - if (yield this.hasTooBigFiles(changedFiles)) { - this.setState(PluginState.idle); - return false; - } - if (changedFiles.length !== 0 || hadConflict) { - let commitMessage = fromAutoBackup ? this.settings.autoCommitMessage : this.settings.commitMessage; - if (fromAutoBackup && this.settings.customMessageOnAutoBackup || requestCustomMessage) { - if (!this.settings.disablePopups && fromAutoBackup) { - new import_obsidian18.Notice("Auto backup: Please enter a custom commit message. Leave empty to abort"); - } - const tempMessage = yield new CustomMessageModal(this, true).open(); - if (tempMessage != void 0 && tempMessage != "" && tempMessage != "...") { - commitMessage = tempMessage; - } else { - this.setState(PluginState.idle); - return false; - } - } - let committedFiles; - if (onlyStaged) { - committedFiles = yield this.gitManager.commit(commitMessage); - } else { - committedFiles = yield this.gitManager.commitAll({ message: commitMessage, status, unstagedFiles }); - } - let roughly = false; - if (committedFiles === void 0) { - roughly = true; - committedFiles = changedFiles.length; - } - this.displayMessage(`Committed${roughly ? " approx." : ""} ${committedFiles} ${committedFiles > 1 ? "files" : "file"}`); - } else { - this.displayMessage("No changes to commit"); - } - dispatchEvent(new CustomEvent("git-refresh")); - this.setState(PluginState.idle); - return true; - }); - } - hasTooBigFiles(files) { - return __async(this, null, function* () { - var _a2; - const branchInfo = yield this.gitManager.branchInfo(); - const remote = (_a2 = branchInfo.tracking) == null ? void 0 : _a2.split("/")[0]; - if (remote) { - const remoteUrl = yield this.gitManager.getRemoteUrl(remote); - if (remoteUrl.includes("github.com")) { - const tooBigFiles = files.filter((f) => { - const file = this.app.vault.getAbstractFileByPath(f.vault_path); - if (file instanceof import_obsidian18.TFile) { - return file.stat.size >= 1e8; - } - return false; + const result = await this.gitManager.checkRequirements(); + switch (result) { + case "missing-git": + this.displayError("Cannot run git command"); + break; + case "missing-repo": + new import_obsidian23.Notice("Can't find a valid git repository. Please create one via the given command or clone an existing repo."); + break; + case "valid": + this.gitReady = true; + this.setState(PluginState.idle); + this.modifyEvent = this.app.vault.on("modify", () => { + this.debRefresh(); }); - if (tooBigFiles.length > 0) { - this.displayError(`Did not commit, because following files are too big: ${tooBigFiles.map((e) => e.vault_path)}. Please remove them.`); - return true; + this.deleteEvent = this.app.vault.on("delete", () => { + this.debRefresh(); + }); + this.createEvent = this.app.vault.on("create", () => { + this.debRefresh(); + }); + this.renameEvent = this.app.vault.on("rename", () => { + this.debRefresh(); + }); + this.registerEvent(this.modifyEvent); + this.registerEvent(this.deleteEvent); + this.registerEvent(this.createEvent); + this.registerEvent(this.renameEvent); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + dispatchEvent(new CustomEvent("git-refresh")); + if (this.settings.autoPullOnBoot) { + this.promiseQueue.addTask(() => this.pullChangesFromRemote()); + } + const lastAutos = await this.loadLastAuto(); + if (this.settings.autoSaveInterval > 0) { + const now2 = new Date(); + const diff2 = this.settings.autoSaveInterval - Math.round((now2.getTime() - lastAutos.backup.getTime()) / 1e3 / 60); + this.startAutoBackup(diff2 <= 0 ? 0 : diff2); + } + if (this.settings.differentIntervalCommitAndPush && this.settings.autoPushInterval > 0) { + const now2 = new Date(); + const diff2 = this.settings.autoPushInterval - Math.round((now2.getTime() - lastAutos.push.getTime()) / 1e3 / 60); + this.startAutoPush(diff2 <= 0 ? 0 : diff2); + } + if (this.settings.autoPullInterval > 0) { + const now2 = new Date(); + const diff2 = this.settings.autoPullInterval - Math.round((now2.getTime() - lastAutos.pull.getTime()) / 1e3 / 60); + this.startAutoPull(diff2 <= 0 ? 0 : diff2); + } + break; + default: + console.log("Something weird happened. The 'checkRequirements' result is " + result); + } + } catch (error) { + this.displayError(error); + console.error(error); + } + } + async createNewRepo() { + await this.gitManager.init(); + new import_obsidian23.Notice("Initialized new repo"); + await this.init(); + } + async cloneNewRepo() { + const modal = new GeneralModal({ placeholder: "Enter remote URL" }); + const url = await modal.open(); + if (url) { + const confirmOption = "Vault Root"; + let dir = await new GeneralModal({ + options: [confirmOption], + placeholder: "Enter directory for clone. It needs to be empty or not existent.", + allowEmpty: this.gitManager instanceof IsomorphicGit + }).open(); + if (dir !== void 0) { + if (dir === confirmOption) { + dir = "."; + } + dir = (0, import_obsidian23.normalizePath)(dir); + if (dir === "/") { + dir = "."; + } + if (dir === ".") { + const modal2 = new GeneralModal({ options: ["NO", "YES"], placeholder: `Does your remote repo contain a ${app.vault.configDir} directory at the root?`, onlySelection: true }); + const containsConflictDir = await modal2.open(); + if (containsConflictDir === void 0) { + new import_obsidian23.Notice("Aborted clone"); + return; + } else if (containsConflictDir === "YES") { + const confirmOption2 = "DELETE ALL YOUR LOCAL CONFIG AND PLUGINS"; + const modal3 = new GeneralModal({ options: ["Abort clone", confirmOption2], placeholder: `To avoid conflicts, the local ${app.vault.configDir} directory needs to be deleted.`, onlySelection: true }); + const shouldDelete = await modal3.open() === confirmOption2; + if (shouldDelete) { + await this.app.vault.adapter.rmdir(app.vault.configDir, true); + } else { + new import_obsidian23.Notice("Aborted clone"); + return; + } } } - } - return false; - }); - } - push() { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return false; - if (!(yield this.remotesAreSet())) { - return false; - } - const file = this.app.vault.getAbstractFileByPath(this.conflictOutputFile); - const hadConflict = this.localStorage.getConflict() === "true"; - if (this.gitManager instanceof SimpleGit && file) - yield this.app.vault.delete(file); - let status; - if (this.gitManager instanceof SimpleGit && (status = yield this.updateCachedStatus()).conflicted.length > 0) { - this.displayError(`Cannot push. You have ${status.conflicted.length} conflict ${status.conflicted.length > 1 ? "files" : "file"}`); - this.handleConflict(status.conflicted); - return false; - } else if (this.gitManager instanceof IsomorphicGit && hadConflict) { - this.displayError(`Cannot push. You have conflict files`); - this.setState(PluginState.conflicted); - return false; - } - { - console.log("Pushing...."); - const pushedFiles = yield this.gitManager.push(); - console.log("Pushed!", pushedFiles); - this.lastUpdate = Date.now(); - if (pushedFiles > 0) { - this.displayMessage(`Pushed ${pushedFiles} ${pushedFiles > 1 ? "files" : "file"} to remote`); - } else { - this.displayMessage(`No changes to push`); + new import_obsidian23.Notice(`Cloning new repo into "${dir}"`); + await this.gitManager.clone(url, dir); + new import_obsidian23.Notice("Cloned new repo."); + new import_obsidian23.Notice("Please restart Obsidian"); + if (dir && dir !== ".") { + this.settings.basePath = dir; + this.saveSettings(); } - this.offlineMode = false; - this.setState(PluginState.idle); - return true; } - }); + } } - pull() { - return __async(this, null, function* () { - if (!(yield this.remotesAreSet())) { + async isAllInitialized() { + if (!this.gitReady) { + await this.init(); + } + return this.gitReady; + } + async pullChangesFromRemote() { + if (!await this.isAllInitialized()) + return; + const filesUpdated = await this.pull(); + if (!filesUpdated) { + this.displayMessage("Everything is up-to-date"); + } + if (this.gitManager instanceof SimpleGit) { + const status2 = await this.gitManager.status(); + if (status2.conflicted.length > 0) { + this.displayError(`You have ${status2.conflicted.length} conflict ${status2.conflicted.length > 1 ? "files" : "file"}`); + this.handleConflict(status2.conflicted); + } + } + dispatchEvent(new CustomEvent("git-refresh")); + this.lastUpdate = Date.now(); + this.setState(PluginState.idle); + } + async createBackup(fromAutoBackup, requestCustomMessage = false) { + if (!await this.isAllInitialized()) + return; + if (this.settings.syncMethod == "reset" && this.settings.pullBeforePush) { + await this.pull(); + } + if (!await this.commit(fromAutoBackup, requestCustomMessage)) + return; + if (!this.settings.disablePush) { + if (await this.gitManager.canPush()) { + if (this.settings.syncMethod != "reset" && this.settings.pullBeforePush) { + await this.pull(); + } + await this.push(); + } else { + this.displayMessage("No changes to push"); + } + } + this.setState(PluginState.idle); + } + async commit(fromAutoBackup, requestCustomMessage = false, onlyStaged = false) { + if (!await this.isAllInitialized()) + return false; + const hadConflict = this.localStorage.getConflict() === "true"; + let changedFiles; + let status2; + let unstagedFiles; + if (this.gitManager instanceof SimpleGit) { + const file = this.app.vault.getAbstractFileByPath(this.conflictOutputFile); + if (file != null) + await this.app.vault.delete(file); + status2 = await this.updateCachedStatus(); + if (fromAutoBackup && status2.conflicted.length > 0) { + this.displayError(`Did not commit, because you have ${status2.conflicted.length} conflict ${status2.conflicted.length > 1 ? "files" : "file"}. Please resolve them and commit per command.`); + this.handleConflict(status2.conflicted); return false; } - const pulledFiles = yield this.gitManager.pull(); - this.offlineMode = false; - if (pulledFiles.length > 0) { - this.displayMessage(`Pulled ${pulledFiles.length} ${pulledFiles.length > 1 ? "files" : "file"} from remote`); - this.lastPulledFiles = pulledFiles; + changedFiles = [...status2.changed, ...status2.staged]; + } else if (fromAutoBackup && hadConflict) { + this.setState(PluginState.conflicted); + this.displayError(`Did not commit, because you have conflict files. Please resolve them and commit per command.`); + return false; + } else if (hadConflict) { + const file = this.app.vault.getAbstractFileByPath(this.conflictOutputFile); + if (file != null) + await this.app.vault.delete(file); + status2 = await this.updateCachedStatus(); + changedFiles = [...status2.changed, ...status2.staged]; + } else { + if (onlyStaged) { + changedFiles = await this.gitManager.getStagedFiles(); + } else { + unstagedFiles = await this.gitManager.getUnstagedFiles(); + changedFiles = unstagedFiles.map(({ filepath }) => ({ vault_path: this.gitManager.getVaultPath(filepath) })); } - return pulledFiles.length != 0; - }); - } - stageCurrentFile() { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return false; - const file = this.app.workspace.getActiveFile(); - yield this.gitManager.stage(file.path, true); - this.displayMessage(`Staged ${file.path}`); - dispatchEvent(new CustomEvent("git-refresh")); + } + if (await this.hasTooBigFiles(changedFiles)) { this.setState(PluginState.idle); - return true; - }); - } - unstageCurrentFile() { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return false; - const file = this.app.workspace.getActiveFile(); - yield this.gitManager.unstage(file.path, true); - this.displayMessage(`Unstaged ${file.path}`); - dispatchEvent(new CustomEvent("git-refresh")); - this.setState(PluginState.idle); - return true; - }); - } - remotesAreSet() { - return __async(this, null, function* () { - if (!(yield this.gitManager.branchInfo()).tracking) { - new import_obsidian18.Notice("No upstream branch is set. Please select one."); - const remoteBranch = yield this.selectRemoteBranch(); - if (remoteBranch == void 0) { - this.displayError("Aborted. No upstream-branch is set!", 1e4); + return false; + } + if (changedFiles.length !== 0 || hadConflict) { + let commitMessage = fromAutoBackup ? this.settings.autoCommitMessage : this.settings.commitMessage; + if (fromAutoBackup && this.settings.customMessageOnAutoBackup || requestCustomMessage) { + if (!this.settings.disablePopups && fromAutoBackup) { + new import_obsidian23.Notice("Auto backup: Please enter a custom commit message. Leave empty to abort"); + } + const tempMessage = await new CustomMessageModal(this, true).open(); + if (tempMessage != void 0 && tempMessage != "" && tempMessage != "...") { + commitMessage = tempMessage; + } else { this.setState(PluginState.idle); return false; - } else { - yield this.gitManager.updateUpstreamBranch(remoteBranch); + } + } + let committedFiles; + if (onlyStaged) { + committedFiles = await this.gitManager.commit(commitMessage); + } else { + committedFiles = await this.gitManager.commitAll({ message: commitMessage, status: status2, unstagedFiles }); + } + let roughly = false; + if (committedFiles === void 0) { + roughly = true; + committedFiles = changedFiles.length; + } + this.displayMessage(`Committed${roughly ? " approx." : ""} ${committedFiles} ${committedFiles > 1 ? "files" : "file"}`); + } else { + this.displayMessage("No changes to commit"); + } + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(PluginState.idle); + return true; + } + async hasTooBigFiles(files) { + var _a2; + const branchInfo = await this.gitManager.branchInfo(); + const remote = (_a2 = branchInfo.tracking) == null ? void 0 : _a2.split("/")[0]; + if (remote) { + const remoteUrl = await this.gitManager.getRemoteUrl(remote); + if (remoteUrl == null ? void 0 : remoteUrl.includes("github.com")) { + const tooBigFiles = files.filter((f) => { + const file = this.app.vault.getAbstractFileByPath(f.vault_path); + if (file instanceof import_obsidian23.TFile) { + return file.stat.size >= 1e8; + } + return false; + }); + if (tooBigFiles.length > 0) { + this.displayError(`Did not commit, because following files are too big: ${tooBigFiles.map((e) => e.vault_path)}. Please remove them.`); return true; } } + } + return false; + } + async push() { + if (!await this.isAllInitialized()) + return false; + if (!await this.remotesAreSet()) { + return false; + } + const file = this.app.vault.getAbstractFileByPath(this.conflictOutputFile); + const hadConflict = this.localStorage.getConflict() === "true"; + if (this.gitManager instanceof SimpleGit && file) + await this.app.vault.delete(file); + let status2; + if (this.gitManager instanceof SimpleGit && (status2 = await this.updateCachedStatus()).conflicted.length > 0) { + this.displayError(`Cannot push. You have ${status2.conflicted.length} conflict ${status2.conflicted.length > 1 ? "files" : "file"}`); + this.handleConflict(status2.conflicted); + return false; + } else if (this.gitManager instanceof IsomorphicGit && hadConflict) { + this.displayError(`Cannot push. You have conflict files`); + this.setState(PluginState.conflicted); + return false; + } + { + console.log("Pushing...."); + const pushedFiles = await this.gitManager.push(); + console.log("Pushed!", pushedFiles); + this.lastUpdate = Date.now(); + if (pushedFiles > 0) { + this.displayMessage(`Pushed ${pushedFiles} ${pushedFiles > 1 ? "files" : "file"} to remote`); + } else { + this.displayMessage(`No changes to push`); + } + this.offlineMode = false; + this.setState(PluginState.idle); return true; - }); + } + } + async pull() { + if (!await this.remotesAreSet()) { + return false; + } + const pulledFiles = await this.gitManager.pull() || []; + this.offlineMode = false; + if (pulledFiles.length > 0) { + this.displayMessage(`Pulled ${pulledFiles.length} ${pulledFiles.length > 1 ? "files" : "file"} from remote`); + this.lastPulledFiles = pulledFiles; + } + return pulledFiles.length != 0; + } + async stageFile(file) { + if (!await this.isAllInitialized()) + return false; + await this.gitManager.stage(file.path, true); + this.displayMessage(`Staged ${file.path}`); + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(PluginState.idle); + return true; + } + async unstageFile(file) { + if (!await this.isAllInitialized()) + return false; + await this.gitManager.unstage(file.path, true); + this.displayMessage(`Unstaged ${file.path}`); + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(PluginState.idle); + return true; + } + async switchBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const branchInfo = await this.gitManager.branchInfo(); + const selectedBranch = await new BranchModal(branchInfo.branches).open(); + if (selectedBranch != void 0) { + await this.gitManager.checkout(selectedBranch); + this.displayMessage(`Switched to ${selectedBranch}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return selectedBranch; + } + } + async createBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const newBranch = await new GeneralModal({ placeholder: "Create new branch" }).open(); + if (newBranch != void 0) { + await this.gitManager.createBranch(newBranch); + this.displayMessage(`Created new branch ${newBranch}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return newBranch; + } + } + async deleteBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const branchInfo = await this.gitManager.branchInfo(); + if (branchInfo.current) + branchInfo.branches.remove(branchInfo.current); + const branch2 = await new GeneralModal({ options: branchInfo.branches, placeholder: "Delete branch", onlySelection: true }).open(); + if (branch2 != void 0) { + let force = false; + if (!await this.gitManager.branchIsMerged(branch2)) { + const forceAnswer = await new GeneralModal({ options: ["YES", "NO"], placeholder: "This branch isn't merged into HEAD. Force delete?", onlySelection: true }).open(); + if (forceAnswer !== "YES") { + return; + } + force = forceAnswer === "YES"; + } + await this.gitManager.deleteBranch(branch2, force); + this.displayMessage(`Deleted branch ${branch2}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return branch2; + } + } + async remotesAreSet() { + if (!(await this.gitManager.branchInfo()).tracking) { + new import_obsidian23.Notice("No upstream branch is set. Please select one."); + const remoteBranch = await this.selectRemoteBranch(); + if (remoteBranch == void 0) { + this.displayError("Aborted. No upstream-branch is set!", 1e4); + this.setState(PluginState.idle); + return false; + } else { + await this.gitManager.updateUpstreamBranch(remoteBranch); + return true; + } + } + return true; } startAutoBackup(minutes) { const time = (minutes != null ? minutes : this.settings.autoSaveInterval) * 6e4; @@ -15882,7 +31064,7 @@ var ObsidianGit = class extends import_obsidian18.Plugin { this.doAutoBackup(); } else { this.onFileModifyEventRef = this.app.vault.on("modify", () => this.autoBackupDebouncer()); - this.autoBackupDebouncer = (0, import_obsidian18.debounce)(() => this.doAutoBackup(), time, true); + this.autoBackupDebouncer = (0, import_obsidian23.debounce)(() => this.doAutoBackup(), time, true); } } else { this.timeoutIDBackup = window.setTimeout(() => this.doAutoBackup(), time); @@ -15948,118 +31130,120 @@ var ObsidianGit = class extends import_obsidian18.Plugin { } return false; } - handleConflict(conflicted) { - return __async(this, null, function* () { - this.setState(PluginState.conflicted); - this.localStorage.setConflict("true"); - let lines; - if (conflicted !== void 0) { - lines = [ - "# Conflict files", - "Please resolve them and commit per command (This file will be deleted before the commit).", - ...conflicted.map((e) => { - const file = this.app.vault.getAbstractFileByPath(e); - if (file instanceof import_obsidian18.TFile) { - const link = this.app.metadataCache.fileToLinktext(file, "/"); - return `- [[${link}]]`; - } else { - return `- Not a file: ${e}`; - } - }) - ]; - } - this.writeAndOpenFile(lines == null ? void 0 : lines.join("\n")); - }); + async handleConflict(conflicted) { + this.setState(PluginState.conflicted); + this.localStorage.setConflict("true"); + let lines; + if (conflicted !== void 0) { + lines = [ + "# Conflict files", + "Please resolve them and commit per command (This file will be deleted before the commit).", + ...conflicted.map((e) => { + const file = this.app.vault.getAbstractFileByPath(e); + if (file instanceof import_obsidian23.TFile) { + const link = this.app.metadataCache.fileToLinktext(file, "/"); + return `- [[${link}]]`; + } else { + return `- Not a file: ${e}`; + } + }) + ]; + } + this.writeAndOpenFile(lines == null ? void 0 : lines.join("\n")); } - editRemotes() { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return; - const remotes = yield this.gitManager.getRemotes(); - const nameModal = new GeneralModal(this.app, remotes, "Select or create a new remote by typing its name and selecting it"); - const remoteName = yield nameModal.open(); - if (remoteName) { - const urlModal = new GeneralModal(this.app, [], "Enter the remote URL"); - const remoteURL = yield urlModal.open(); - if (remoteURL) { - yield this.gitManager.setRemote(remoteName, remoteURL); - return remoteName; - } - } + async editRemotes() { + if (!await this.isAllInitialized()) + return; + const remotes = await this.gitManager.getRemotes(); + const nameModal = new GeneralModal({ + options: remotes, + placeholder: "Select or create a new remote by typing its name and selecting it" }); + const remoteName = await nameModal.open(); + if (remoteName) { + const oldUrl = await this.gitManager.getRemoteUrl(remoteName); + const urlModal = new GeneralModal({ initialValue: oldUrl }); + const remoteURL = await urlModal.open(); + if (remoteURL) { + await this.gitManager.setRemote(remoteName, remoteURL); + return remoteName; + } + } } - selectRemoteBranch() { - return __async(this, null, function* () { - let remotes = yield this.gitManager.getRemotes(); - let selectedRemote; - if (remotes.length === 0) { - selectedRemote = yield this.editRemotes(); - if (selectedRemote == void 0) { - remotes = yield this.gitManager.getRemotes(); - } + async selectRemoteBranch() { + let remotes = await this.gitManager.getRemotes(); + let selectedRemote; + if (remotes.length === 0) { + selectedRemote = await this.editRemotes(); + if (selectedRemote == void 0) { + remotes = await this.gitManager.getRemotes(); } - const nameModal = new GeneralModal(this.app, remotes, "Select or create a new remote by typing its name and selecting it"); - const remoteName = selectedRemote != null ? selectedRemote : yield nameModal.open(); - if (remoteName) { - this.displayMessage("Fetching remote branches"); - yield this.gitManager.fetch(remoteName); - const branches = yield this.gitManager.getRemoteBranches(remoteName); - const branchModal = new GeneralModal(this.app, branches, "Select or create a new remote branch by typing its name and selecting it"); - return yield branchModal.open(); - } - }); + } + const nameModal = new GeneralModal({ options: remotes, placeholder: "Select or create a new remote by typing its name and selecting it" }); + const remoteName = selectedRemote != null ? selectedRemote : await nameModal.open(); + if (remoteName) { + this.displayMessage("Fetching remote branches"); + await this.gitManager.fetch(remoteName); + const branches = await this.gitManager.getRemoteBranches(remoteName); + const branchModal = new GeneralModal({ options: branches, placeholder: "Select or create a new remote branch by typing its name and selecting it" }); + return await branchModal.open(); + } } - removeRemote() { - return __async(this, null, function* () { - if (!(yield this.isAllInitialized())) - return; - const remotes = yield this.gitManager.getRemotes(); - const nameModal = new GeneralModal(this.app, remotes, "Select a remote"); - const remoteName = yield nameModal.open(); - if (remoteName) { - this.gitManager.removeRemote(remoteName); - } - }); + async removeRemote() { + if (!await this.isAllInitialized()) + return; + const remotes = await this.gitManager.getRemotes(); + const nameModal = new GeneralModal({ options: remotes, placeholder: "Select a remote" }); + const remoteName = await nameModal.open(); + if (remoteName) { + this.gitManager.removeRemote(remoteName); + } } - writeAndOpenFile(text2) { - return __async(this, null, function* () { - if (text2 !== void 0) { - yield this.app.vault.adapter.write(this.conflictOutputFile, text2); - } - let fileIsAlreadyOpened = false; - this.app.workspace.iterateAllLeaves((leaf) => { - if (leaf.getDisplayText() != "" && this.conflictOutputFile.startsWith(leaf.getDisplayText())) { - fileIsAlreadyOpened = true; - } - }); - if (!fileIsAlreadyOpened) { - this.app.workspace.openLinkText(this.conflictOutputFile, "/", true); + async writeAndOpenFile(text2) { + if (text2 !== void 0) { + await this.app.vault.adapter.write(this.conflictOutputFile, text2); + } + let fileIsAlreadyOpened = false; + this.app.workspace.iterateAllLeaves((leaf) => { + if (leaf.getDisplayText() != "" && this.conflictOutputFile.startsWith(leaf.getDisplayText())) { + fileIsAlreadyOpened = true; } }); + if (!fileIsAlreadyOpened) { + this.app.workspace.openLinkText(this.conflictOutputFile, "/", true); + } } displayMessage(message, timeout = 4 * 1e3) { var _a2; (_a2 = this.statusBar) == null ? void 0 : _a2.displayMessage(message.toLowerCase(), timeout); if (!this.settings.disablePopups) { - new import_obsidian18.Notice(message, 5 * 1e3); + new import_obsidian23.Notice(message, 5 * 1e3); } console.log(`git obsidian message: ${message}`); } displayError(message, timeout = 10 * 1e3) { var _a2; + if (message instanceof Errors.UserCanceledError) { + new import_obsidian23.Notice("Aborted"); + return; + } message = message.toString(); - new import_obsidian18.Notice(message, timeout); + new import_obsidian23.Notice(message, timeout); console.log(`git obsidian error: ${message}`); (_a2 = this.statusBar) == null ? void 0 : _a2.displayMessage(message.toLowerCase(), timeout); } }; -// Annotate the CommonJS export names for ESM import in node: -0 && (module.exports = {}); /*! Copyright (c) 2016 Jed Watson. Licensed under the MIT License (MIT), see http://jedwatson.github.io/classnames */ +/*! + * The buffer module from node.js, for the browser. + * + * @author Feross Aboukhadijeh + * @license MIT + */ /*! ***************************************************************************** Copyright (c) Microsoft Corporation. @@ -16074,3 +31258,6 @@ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ***************************************************************************** */ +/*! crc32.js (C) 2014-present SheetJS -- http://sheetjs.com */ +/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */ +/*! safe-buffer. MIT License. Feross Aboukhadijeh */ diff --git a/.obsidian/plugins/obsidian-git/manifest.json b/.obsidian/plugins/obsidian-git/manifest.json index accbcaa..b3c5c93 100644 --- a/.obsidian/plugins/obsidian-git/manifest.json +++ b/.obsidian/plugins/obsidian-git/manifest.json @@ -1,8 +1,8 @@ { "id": "obsidian-git", "name": "Obsidian Git", - "description": "Backup your vault with git.", - "isDesktopOnly": true, + "description": "Backup your vault with Git.", + "isDesktopOnly": false, "js": "main.js", - "version": "1.31.0" + "version": "2.6.0" } diff --git a/.obsidian/plugins/obsidian-git/styles.css b/.obsidian/plugins/obsidian-git/styles.css index e283d44..a7ccdfd 100644 --- a/.obsidian/plugins/obsidian-git/styles.css +++ b/.obsidian/plugins/obsidian-git/styles.css @@ -1,465 +1,473 @@ @keyframes loading { - 0% { - transform: rotate(0deg); - } + 0% { + transform: rotate(0deg); + } - 100% { - transform: rotate(360deg); - } + 100% { + transform: rotate(360deg); + } +} + +.workspace-leaf-content[data-type='git-view'] .view-content { + padding: 0; } .loading>svg { - animation: 2s linear infinite loading; - transform-origin: 50% 50%; - display: inline-block; + animation: 2s linear infinite loading; + transform-origin: 50% 50%; + display: inline-block; } .obsidian-git-center { - margin: auto; - width: 50%; + margin: auto; + width: 50%; } .obsidian-git-textarea { - display: block; - margin-left: auto; - margin-right: auto; + display: block; + margin-left: auto; + margin-right: auto; } .obsidian-git-center-button { - display: block; - margin: 20px auto; + display: block; + margin: 20px auto; } .tooltip.mod-left { - overflow-wrap: break-word; + overflow-wrap: break-word; } .tooltip.mod-right { - overflow-wrap: break-word; + overflow-wrap: break-word; } .obsidian-git-shortcuts { - margin: 10px; + margin: 10px; } .diff-err { - height: 100%; - display: flex; - justify-content: center; - flex-direction: column; - align-items: center; + height: 100%; + display: flex; + justify-content: center; + flex-direction: column; + align-items: center; } .diff-err-sign { - font-size: 2em; + font-size: 2em; } .workspace-leaf-content[data-type="diff-view"] .d2h-d-none { - display: none; + display: none; } .workspace-leaf-content[data-type="diff-view"] .d2h-wrapper { - text-align: left; + text-align: left; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-header { - background-color: var(--background-primary); - border-bottom: 1px solid var(--interactive-accent); - font-family: var(--font-monospace); - height: 35px; - padding: 5px 10px; + background-color: var(--background-primary); + border-bottom: 1px solid var(--interactive-accent); + font-family: var(--font-monospace); + height: 35px; + padding: 5px 10px; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-header, .workspace-leaf-content[data-type="diff-view"] .d2h-file-stats { - display: -webkit-box; - display: -ms-flexbox; - display: flex; + display: -webkit-box; + display: -ms-flexbox; + display: flex; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-stats { - font-size: 14px; - margin-left: auto; + font-size: 14px; + margin-left: auto; } .workspace-leaf-content[data-type="diff-view"] .d2h-lines-added { - border: 1px solid #b4e2b4; - border-radius: 5px 0 0 5px; - color: #399839; - padding: 2px; - text-align: right; - vertical-align: middle; + border: 1px solid #b4e2b4; + border-radius: 5px 0 0 5px; + color: #399839; + padding: 2px; + text-align: right; + vertical-align: middle; } .workspace-leaf-content[data-type="diff-view"] .d2h-lines-deleted { - border: 1px solid #e9aeae; - border-radius: 0 5px 5px 0; - color: #c33; - margin-left: 1px; - padding: 2px; - text-align: left; - vertical-align: middle; + border: 1px solid #e9aeae; + border-radius: 0 5px 5px 0; + color: #c33; + margin-left: 1px; + padding: 2px; + text-align: left; + vertical-align: middle; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-name-wrapper { - -webkit-box-align: center; - -ms-flex-align: center; - align-items: center; - display: -webkit-box; - display: -ms-flexbox; - display: flex; - font-size: 15px; - width: 100%; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + font-size: 15px; + width: 100%; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-name { - overflow-x: hidden; - text-overflow: ellipsis; - white-space: nowrap; + overflow-x: hidden; + text-overflow: ellipsis; + white-space: nowrap; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-wrapper { - border: 1px solid var(--background-modifier-border); - border-radius: 3px; - margin-bottom: 1em; + border: 1px solid var(--background-modifier-border); + border-radius: 3px; + margin-bottom: 1em; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-collapse { - -webkit-box-pack: end; - -ms-flex-pack: end; - -webkit-box-align: center; - -ms-flex-align: center; - align-items: center; - border: 1px solid var(--background-modifier-border); - border-radius: 3px; - cursor: pointer; - display: none; - font-size: 12px; - justify-content: flex-end; - padding: 4px 8px; + -webkit-box-pack: end; + -ms-flex-pack: end; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + border: 1px solid var(--background-modifier-border); + border-radius: 3px; + cursor: pointer; + display: none; + font-size: 12px; + justify-content: flex-end; + padding: 4px 8px; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-collapse.d2h-selected { - background-color: #c8e1ff; + background-color: #c8e1ff; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-collapse-input { - margin: 0 4px 0 0; + margin: 0 4px 0 0; } .workspace-leaf-content[data-type="diff-view"] .d2h-diff-table { - border-collapse: collapse; - font-family: Menlo, Consolas, monospace; - font-size: 13px; - width: 100%; + border-collapse: collapse; + font-family: Menlo, Consolas, monospace; + font-size: 13px; + width: 100%; } .workspace-leaf-content[data-type="diff-view"] .d2h-files-diff { - width: 100%; + width: 100%; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff { - overflow-y: hidden; + overflow-y: hidden; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-side-diff { - display: inline-block; - margin-bottom: -8px; - margin-right: -4px; - overflow-x: scroll; - overflow-y: hidden; - width: 50%; + display: inline-block; + margin-bottom: -8px; + margin-right: -4px; + overflow-x: scroll; + overflow-y: hidden; + width: 50%; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-line { - padding: 0 8em; + padding: 0 8em; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-line, .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line { - display: inline-block; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - white-space: nowrap; - width: 100%; + display: inline-block; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + white-space: nowrap; + width: 100%; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line { - padding: 0 4.5em; + padding: 0 4.5em; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-line-ctn { - word-wrap: normal; - background: none; - display: inline-block; - padding: 0; - -webkit-user-select: text; - -moz-user-select: text; - -ms-user-select: text; - user-select: text; - vertical-align: middle; - white-space: pre; - width: 100%; + word-wrap: normal; + background: none; + display: inline-block; + padding: 0; + -webkit-user-select: text; + -moz-user-select: text; + -ms-user-select: text; + user-select: text; + vertical-align: middle; + white-space: pre; + width: 100%; } .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-line del, .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line del { - background-color: #ffb6ba; + background-color: #ffb6ba; } .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-line del, .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line del { - background-color: #8d232881; + background-color: #8d232881; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-line del, .workspace-leaf-content[data-type="diff-view"] .d2h-code-line ins, .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line del, .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line ins { - border-radius: 0.2em; - display: inline-block; - margin-top: -1px; - text-decoration: none; - vertical-align: middle; + border-radius: 0.2em; + display: inline-block; + margin-top: -1px; + text-decoration: none; + vertical-align: middle; } .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-line ins, .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line ins { - background-color: #97f295; - text-align: left; + background-color: #97f295; + text-align: left; } .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-line ins, .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line ins { - background-color: #1d921996; - text-align: left; + background-color: #1d921996; + text-align: left; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-line-prefix { - word-wrap: normal; - background: none; - display: inline; - padding: 0; - white-space: pre; + word-wrap: normal; + background: none; + display: inline; + padding: 0; + white-space: pre; } .workspace-leaf-content[data-type="diff-view"] .line-num1 { - float: left; + float: left; } .workspace-leaf-content[data-type="diff-view"] .line-num1, .workspace-leaf-content[data-type="diff-view"] .line-num2 { - -webkit-box-sizing: border-box; - box-sizing: border-box; - overflow: hidden; - padding: 0 0.5em; - text-overflow: ellipsis; - width: 3.5em; + -webkit-box-sizing: border-box; + box-sizing: border-box; + overflow: hidden; + padding: 0 0.5em; + text-overflow: ellipsis; + width: 3.5em; } .workspace-leaf-content[data-type="diff-view"] .line-num2 { - float: right; + float: right; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber { - background-color: var(--background-primary); - border: solid var(--background-modifier-border); - border-width: 0 1px; - -webkit-box-sizing: border-box; - box-sizing: border-box; - color: var(--text-muted); - cursor: pointer; - display: inline-block; - position: absolute; - text-align: right; - width: 7.5em; + background-color: var(--background-primary); + border: solid var(--background-modifier-border); + border-width: 0 1px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: var(--text-muted); + cursor: pointer; + display: inline-block; + position: absolute; + text-align: right; + width: 7.5em; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber:after { - content: "\200b"; + content: "\200b"; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber { - background-color: var(--background-primary); - border: solid var(--background-modifier-border); - border-width: 0 1px; - -webkit-box-sizing: border-box; - box-sizing: border-box; - color: var(--text-muted); - cursor: pointer; - display: inline-block; - overflow: hidden; - padding: 0 0.5em; - position: absolute; - text-align: right; - text-overflow: ellipsis; - width: 4em; + background-color: var(--background-primary); + border: solid var(--background-modifier-border); + border-width: 0 1px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: var(--text-muted); + cursor: pointer; + display: inline-block; + overflow: hidden; + padding: 0 0.5em; + position: absolute; + text-align: right; + text-overflow: ellipsis; + width: 4em; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-diff-tbody tr { + position: relative; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber:after { - content: "\200b"; + content: "\200b"; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-emptyplaceholder, .workspace-leaf-content[data-type="diff-view"] .d2h-emptyplaceholder { - background-color: var(--background-primary); - border-color: var(--background-modifier-border); + background-color: var(--background-primary); + border-color: var(--background-modifier-border); } .workspace-leaf-content[data-type="diff-view"] .d2h-code-line-prefix, .workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber, .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber, .workspace-leaf-content[data-type="diff-view"] .d2h-emptyplaceholder { - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } .workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber, .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber { - direction: rtl; + direction: rtl; } .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-del { - background-color: #fee8e9; - border-color: #e9aeae; + background-color: #fee8e9; + border-color: #e9aeae; } .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-ins { - background-color: #dfd; - border-color: #b4e2b4; + background-color: #dfd; + border-color: #b4e2b4; } .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-del { - background-color: #521b1d83; - border-color: #691d1d73; + background-color: #521b1d83; + border-color: #691d1d73; } .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-ins { - background-color: rgba(30, 71, 30, 0.5); - border-color: #13501381; + background-color: rgba(30, 71, 30, 0.5); + border-color: #13501381; } .workspace-leaf-content[data-type="diff-view"] .d2h-info { - background-color: var(--background-primary); - border-color: var(--background-modifier-border); - color: var(--text-normal); + background-color: var(--background-primary); + border-color: var(--background-modifier-border); + color: var(--text-normal); } .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-del.d2h-change { - background-color: #fdf2d0; + background-color: #fdf2d0; } .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-del.d2h-change { - background-color: #55492480; + background-color: #55492480; } .theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-ins.d2h-change { - background-color: #ded; + background-color: #ded; } .theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-ins.d2h-change { - background-color: rgba(37, 78, 37, 0.418); + background-color: rgba(37, 78, 37, 0.418); } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list-wrapper { - margin-bottom: 10px; + margin-bottom: 10px; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list-wrapper a { - color: #3572b0; - text-decoration: none; + color: #3572b0; + text-decoration: none; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list-wrapper a:visited { - color: #3572b0; + color: #3572b0; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list-header { - text-align: left; + text-align: left; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list-title { - font-weight: 700; + font-weight: 700; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list-line { - display: -webkit-box; - display: -ms-flexbox; - display: flex; - text-align: left; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + text-align: left; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list { - display: block; - list-style: none; - margin: 0; - padding: 0; + display: block; + list-style: none; + margin: 0; + padding: 0; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list>li { - border-bottom: 1px solid var(--background-modifier-border); - margin: 0; - padding: 5px 10px; + border-bottom: 1px solid var(--background-modifier-border); + margin: 0; + padding: 5px 10px; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-list>li:last-child { - border-bottom: none; + border-bottom: none; } .workspace-leaf-content[data-type="diff-view"] .d2h-file-switch { - cursor: pointer; - display: none; - font-size: 10px; + cursor: pointer; + display: none; + font-size: 10px; } .workspace-leaf-content[data-type="diff-view"] .d2h-icon { - fill: currentColor; - margin-right: 10px; - vertical-align: middle; + fill: currentColor; + margin-right: 10px; + vertical-align: middle; } .workspace-leaf-content[data-type="diff-view"] .d2h-deleted { - color: #c33; + color: #c33; } .workspace-leaf-content[data-type="diff-view"] .d2h-added { - color: #399839; + color: #399839; } .workspace-leaf-content[data-type="diff-view"] .d2h-changed { - color: #d0b44c; + color: #d0b44c; } .workspace-leaf-content[data-type="diff-view"] .d2h-moved { - color: #3572b0; + color: #3572b0; } .workspace-leaf-content[data-type="diff-view"] .d2h-tag { - background-color: var(--background-primary); - display: -webkit-box; - display: -ms-flexbox; - display: flex; - font-size: 10px; - margin-left: 5px; - padding: 0 2px; + background-color: var(--background-primary); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + font-size: 10px; + margin-left: 5px; + padding: 0 2px; } .workspace-leaf-content[data-type="diff-view"] .d2h-deleted-tag { - border: 2px solid #c33; + border: 2px solid #c33; } .workspace-leaf-content[data-type="diff-view"] .d2h-added-tag { - border: 1px solid #399839; + border: 1px solid #399839; } .workspace-leaf-content[data-type="diff-view"] .d2h-changed-tag { - border: 1px solid #d0b44c; + border: 1px solid #d0b44c; } .workspace-leaf-content[data-type="diff-view"] .d2h-moved-tag { - border: 1px solid #3572b0; + border: 1px solid #3572b0; } \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-style-settings/data.json b/.obsidian/plugins/obsidian-style-settings/data.json index cb2487c..bd29c0b 100644 --- a/.obsidian/plugins/obsidian-style-settings/data.json +++ b/.obsidian/plugins/obsidian-style-settings/data.json @@ -3,11 +3,7 @@ "obsidian-prism-theme@@light-accent-color-preset": "pt-accent-color-green-lt", "obsidian-prism-theme@@color-schemes-dt": "pt-color-scheme-indigo-dt", "obsidian-prism-theme@@pt-disable-blur": true, - "obsidian-prism-theme@@pt-disable-animations": true, - "obsidian-prism-theme@@pt-disable-custom-icons": false, - "obsidian-prism-theme@@pt-hide-view-header": false, "obsidian-prism-theme@@accent-style-dt": "pt-accent-style-borderandfilled-dt", "obsidian-prism-theme@@accent-style-lt": "pt-accent-style-borderandfilled-lt", - "obsidian-prism-theme@@background-type-lt": "pt-background-default-lt", "obsidian-prism-theme@@light-mark-highlight-style": "pt-highlight-style-filled-lt" } \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-style-settings/main.js b/.obsidian/plugins/obsidian-style-settings/main.js index 907ea2c..e784b94 100644 --- a/.obsidian/plugins/obsidian-style-settings/main.js +++ b/.obsidian/plugins/obsidian-style-settings/main.js @@ -3861,7 +3861,14 @@ const tr = {}; const uk = {}; -const zh = {}; +const zh = { + "Default:": "默认:", + "Error:": "错误:", + "missing default light value, or value is not in a valid color format": "缺少默认的浅色模式色值,或该色值没有采用一个有效的颜色格式", + "missing default dark value, or value is not in a valid color format": "缺少默认的深色模式色值,或该色值没有采用一个有效的颜色格式", + "missing default value, or value is not in a valid color format": "缺少默认色值,或该色值没有采用一个有效的颜色格式", + "missing default value": "缺少默认色值", +}; const zhTw = {}; diff --git a/.obsidian/plugins/obsidian-style-settings/manifest.json b/.obsidian/plugins/obsidian-style-settings/manifest.json index b495407..1107ae3 100644 --- a/.obsidian/plugins/obsidian-style-settings/manifest.json +++ b/.obsidian/plugins/obsidian-style-settings/manifest.json @@ -1,7 +1,7 @@ { "id": "obsidian-style-settings", "name": "Style Settings", - "version": "0.4.11", + "version": "0.4.12", "minAppVersion": "0.11.5", "description": "Offers controls for adjusting theme, plugin, and snippet CSS variables.", "author": "mgmeyers", diff --git a/.obsidian/themes/Prism/manifest.json b/.obsidian/themes/Prism/manifest.json new file mode 100644 index 0000000..2452c59 --- /dev/null +++ b/.obsidian/themes/Prism/manifest.json @@ -0,0 +1,7 @@ +{ + "name": "Prism", + "version": "3.0.0-beta.9", + "minAppVersion": "0.16.0", + "author": "Damian Korcz", + "authorUrl": "https://github.com/damiankorcz" +} \ No newline at end of file diff --git a/.obsidian/themes/Prism/theme.css b/.obsidian/themes/Prism/theme.css new file mode 100644 index 0000000..f5aec14 --- /dev/null +++ b/.obsidian/themes/Prism/theme.css @@ -0,0 +1,6630 @@ +/*! + Prism Theme for Obsidian.md (Version: v3.0.0) Beta 9 + > A Comprehensive, Highly-Customisable and Elegant Light/Dark Theme for Obsidian.md + + Source: https://github.com/damiankorcz/Obsidian-Prism + Support the development: https://www.buymeacoffee.com/DamianKorcz + Forum Thread: https://forum.obsidian.md/t/theme-prism/36493 + + Distributed under the MIT License. See https://github.com/damiankorcz/Obsidian-Prism/blob/main/LICENSE for more information. + Copyright (c) 2022 Damian Korcz +*/ +@font-face { + font-family: "Source Sans 3"; + font-style: normal; + font-weight: 200 900; + font-stretch: normal; + src: url(data:application/octet-stream;base64,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); +} +@font-face { + font-family: "Source Sans 3"; + font-style: italic; + font-weight: 200 900; + font-stretch: normal; + src: url(data:application/octet-stream;base64,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); +} +@font-face { + font-family: "JetBrains Mono"; + font-style: normal; + font-weight: 100 800; + src: url(data:application/octet-stream;base64,AAEAAAAVAQAABABQRFNJRwAAAAEAA4NgAAAACEdERUYPbKaXAAHL4AAAAtFHUE9TGGo6AAABzrQAACJ8R1NVQrc8lvcAAfEwAABblkhWQVIFXwAzAAJMyAAAADZPUy8yEhQLhAAAAdgAAABgU1RBVBOw1okAAk0AAAAA+GF2YXIK0yABAAJN+AAAACpjbWFwatR7iAAAF3QAADp8ZnZhcosVeawAAk4kAAAAdGdhc3AAAAAQAAHL2AAAAAhnbHlmH3IJOAAAXJgAASwYZ3Zhci2l5sQAAk6YAAE0yGhlYWQVW/RJAAABXAAAADZoaGVh/+8GHQAAAZQAAAAkaG10eNDOL0UAAAI4AAAVPGxvY2Gwg/rQAABR+AAACqBtYXhwBccCbgAAAbgAAAAgbmFtZYkhUdsAAYiwAAAJyXBvc3TtVOXvAAGSfAAAOVpwcmVwaAaMhQAAUfAAAAAHAAEAAAACPfRCd0eiXw889QADA+gAAAAA3Sm1EQAAAADdKb2R+Tn+cAK3BGAAAAAGAAIAAAAAAAAAAQAAA/z+1AAAAlj5Of+hArcAAQAAAAAAAAAAAAAAAAAABU8AAQAABU8BuABuALQABgABAAAAAAAAAAAAAAAAAAMAAQAEAlgBkAAFAAACigJYAAAASwKKAlgAAAFeADIBQAAAAgAACQAAAAAAAKAEAv8SAPn7AgAAKAAAAABKQgAAAMAAAP//A/z+1AAAA/wBLCAAAZ/f1wAAAiYC2gAAACAABgJYAFoCWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYAB4CWAAeAlgAXQJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFwCWAAKAlgAXAJYAAoCWABkAlgAZAJYAGQCWABkAlgAZAJYAGQCWABkAlgAZAJYAGQCWABkAlgAZAJYAGQCWABkAlgAZAJYAGQCWABkAlgAZAJYAEYCWABkAlgAXwJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABdAlgACgJYAF0CWABpAlgAaQJYAGkCWABpAlgAaQJYAGkCWABpAlgAaQJYAGkCWABpAlgAaQJYAGkCWAAtAlgALQJYAFwCWABcAlgAggJYAHUCWACCAlgAggJYAIICWAAUAlgATAJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWAAjAlgAIwJYAFgCWAAoAlgAXAJYAFoCWABQAlgAXAJYAFwCWABcAlgAXAJYAEgCWABIAlgASAJYAEgCWABIAlgASAJYAFwCWABaAlgANwJYADcCWAA3AlgANwJYADcCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAMgJYABkCWAAZAlgAGQJYABkCWAAZAlgAKAJYACMCWAAjAlgAIwJYACMCWAAjAlgAIwJYACMCWAAjAlgAIwJYAFUCWABVAlgAVQJYAFUCWABBAlgAQQJYAEECWABBAlgAQQJYAEECWABBAlgAQQJYAEECWABBAlgAQQJYAEECWABBAlgAQQJYAEECWABBAlgAQQJYAEECWABBAlgAQQJYAEECWABBAlgAQQJYACMCWAAjAlgAXAJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABGAlgAPwJYAFoCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAWAJYAFUCWABaAlgAPAJYAFgCWABYAlgAWAJYAFgCWABYAlgAWAJYAFgCWABcAlgAAAJY/+ECWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAEYCWABGAlgARgJYAF8CWABfAlgAXwJYAB4CWAAeAlgAMgJYAB4CWAAeAlgACgJYAB4CWAA8AlgAXAJYAFwCWP/2AlgAXAJYAFwCWABeAlgAXAJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAVQJYAFUCWABYAlgAIwJYACMCWABVAlgAIwJYAF0CWABXAlgAWAJYAG0CWABtAlgAbQJYACMCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABcAlgApQJYADcCWAA3AlgANwJYADcCWAA3AlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAWgJYAFoCWABaAlgAMgJYACMCWAAjAlgAIwJYACMCWAAjAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYADICWAAyAlgAMgJYAFoCWABaAlgAWgJYAFoCWABcAlgArwJYALkCWAAyAlgAXgJYAF0CWACCAlgAggJYAIICWAAZAlgAZAJYAGQCWAAMAlgANgJYAFoCWABaAlgAXAJYAFwCWAAUAlgATAJYAF0CWABYAlgAXgJYAFwCWABYAlgANwJYADICWAAyAlgANgJYACgCWABLAlgAXgJYAEACWABAAlgAXgJYAF4CWP/7AlgAQQJY//sCWAA1AlgASAJYAFoCWABUAlgAaQJYAGkCWAAtAlgAAAJYADwCWAA4AlgAAAJYAB4CWABRAlgAWQJYACMCWAAjAlgAQQJYAF8CWABUAlgAWgJYAEECWABXAlgAXAJYAIICWACCAlgAggJYAB4CWABVAlgAVQJYABICWABBAlgAXAJYAFwCWABfAlgAXwJYABkCWABMAlgAXAJYAFUCWABcAlgAXQJYAFUCWAA3AlgAMgJYADICWAA2AlgAMgJYAE4CWABcAlgAPAJYADwCWABcAlgAYgJYAAACWABBAlgABQJYAD4CWABaAlgAUwJYAFQCWABVAlgAVQJYAEYCWAAAAlgAPAJYAEECWAAAAlgANwJYAFwCWABbAlgAPAJYADwCWABJAlgAZAJYAFUCWABaAlgAMgJYAF0CWACCAlgAMgJYAGQCWABVAlgAXQJYAFgCWABpAlgAXAJYADICWABMAlgAWgJYAFACWABYAlgAXgJYAFwCWABLAlgANwJYACMCWAA2AlgAKAJYADYCWAAyAlgACgJY/40CWP+NAlj/jQJY/7ACWP+DAlj/sAJYAGkCWAAjAlgAXAJYAFoCWABcAlgAPAJYAFoCWABQAlgARAJYAFwCWABYAlgANwJYAF8CWAAyAlgAXQJYADICWABVAlgAVQJYABkCWABeAlgAVQJYAFUCWAA8AlgAWgJYADcCWAAoAlgANgJYADcCWAA3AlgANwJYADcCWABaAlgAWgJYAFoCWABVAlgANwJYAFoCWABQAlgAXAJYAFwCWAA2AlgADwJYAFoCWABaAlgAaQJYAEQCWABbAlgAUAJYAFoCWABIAlgARgJYAEYCWABVAlgAQAJYAFACWABCAlgAQAJYAFgCWACRAlgAmwJYAJcCWACIAlgAkgJYAIkCWACRAlgAmwJYAJYCWACSAlgAkQJYAJsCWACXAlgAiAJYAJICWACJAlgAkQJYAJsCWACWAlgAkgJYAFoCWAAeAlgAHgJYABoCWABMAlgA2QJYAKUCWADZAlgAqgJYADwCWADhAlgA4QJYAIICWABuAlgA2QJYALQCWAAjAlgAzQJYAJYCWAAjAlgA2QJY//YCWABLAlgASwJY/+wCWADZAAD/GQAA/3gCWAC5AlgAcwJYAEsCWABfAlgAzQJYAJYCWABuAlgAlgJYAGkCWACTAlgAzQJYAM0CWACWAlgAlgJYAKACWABzAlgAjAJYAIwCWABQAlgAAAJYAIwCWAA8AlgApQJYAFUCWABLAlgAVQJYAOYCWADDAlgAHgJYAB4CWACTAlgAkwJYAA8CWACWAlgA9gJY/jQCWPvcAlj7pgJY/lwCWP39Alj7pQJY/f0CWPulAlj+EQJY/kMCWP67Alj+jgJY/j4CWP7TAlj8jwJY/HACWP6BAlj+XAJY/tECWPzJAlj8RAJY/rMCWPwsAlj+UgJY/oECWP6BAlj+ogJY/JoCWP7FAlj9+AJY+6UCWP4sAlj+kAJY/lwCWPv6Alj+UgJY+5sCWP3FAlj9ywJY/csCWP3LAlj9ywJY/csCWP3LAlj9ywJY/ekCWPuRAlj5OQJY/csCWP3LAlj7cwJY/fMCWPubAlj+EQJY+6ACWP4WAlj+PgJY+/oCWPwTAlj8IgJY/eQCWAB9AlgAZAJYAKACWABzAlgALgJYAGkCWADZAlgAqgJYAAACWAAAAlgAAAJYAAACWAAAAAAAAAJYAF0CWABVAlgAKwJYAEgCWABaAlgAEwJYAAACWAAeAlgASwJYAC0CWAAjAlgARgJYANkCWAAAAlgAmwJYAEYCWAAoAlgA/wJYABsCWAD/AlgAWgJYAIwCWAAjAlj/9gJYACMCWADmAlgAeAJYAFUCWAAAAlgAUAJYAFACWAD/AlgALQJYAP8CWAD/AlgA/wJYAP8CWABBAlj/9gJYABQCWABGAlj/9gJYACsCWABGAlgAIwJYAEYCWAAjAlgAIwJYAFUCWABVAlgAVQJYAFUCWABVAlgAIwJYAB4CWABBAlgAjAJYAGkCWABkAlgAVQJYAFUCWABVAlgAVQJYAFUCWABVAlgAQQJYAEYCWABGAlgARgJYAFACWAAjAlj/9gJYADwCWAA8AlgAKwJYACsCWAAAAlgAKAJYADcCWAAeAlgAWgJYAF0CWACbAlgA/wJYAP8CWAD/AlgA/wJYAC0CWAAtAlgADgJY//gCWACgAlgANwJYADcCWAA3AlgAVQJYANkCWAAjAlgAHgJY/7ACWABzAlgA/wJYAHMCWAD/AlgAZAJYAGQCWAAAAlgAVQJYALQCWABGAlgAPAJYADwCWAAjAlgAtAJYACMCWAAjAlgANwJYAB4CWAAAAlgAQQJYADICWP/2AlgAAAJY//YCWP/2Alj/9gJY//YCWP/2AlgACgJYAAoCWAAoAlgACgJYAAoCWAAtAlgAKAJYAC0CWP+wAlgACgJY/7ACWP+wAlj/sAJY/7ACWABkAlj/sAJYAGQCWP+wAlj/9gJY/7ACWP/2Alj/sAJYAA8CWP/iAlgACgJYABQCWP/YAlj/2AJY/7ACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYASwCWAINAlgAAAJYASwCWAAAAlgAAAJYAAACWAAAAlj/9gJYASwCWAAAAlgAAAJYADwCWAAAAlgAAAJY//YCWP/2Alj/9gJY//YCWP/2Alj/9gJYALQCWP/2Alj/9gJYADwCWAAAAlgAAAJYAJYCWACWAlgAAAJYAAACWAAAAlgAAAJYAAACWP/2AlgAAAJY//YCWP/2Alj/9gJYAAACWP/2Alj/9gJYAAACWP/2AlgAAAJY//YCWACWAlgAlgJYAJYCWACMAlgAlgJYAJYCWACWAlgAjAJY/+wCWP/sAlgAlgJY/+wCWP/sAlj/7AJYAJYCWACWAlj/7AJY/+wCWACWAlj/7AJY/+wCWACWAlj/7AJY/+wCWP/sAlgAyAJYAMgCWP/sAlj/7AJY/+wCWP/sAlgA+gJYAMgCWP/sAlj/7AJY/+wCWAD6AlgASwJYAMgCWADIAlj/7AJY/+wCWADIAlj/7AJY/+wCWP/sAlgAGQJYAMgCWAD6AlgAJQJYAMgCWADIAlj/7AJY/+wCWADIAlgAyAJYAMgCWP/sAlj/7AJYAMgCWP/sAlj/7AJY/+wCWP/sAlj/7AJY/+wCWP/sAlj/7AJY/+wCWAD6Alj/7AJYAPoCWP/sAlj/7AJY/+wCWABGAlgA+gJYAPoCWP/sAlj/7AJYAPoCWP/sAlj/7AJY/+wCWAAZAlgA+gJYAPoCWAAlAlgA+gJYAPoCWADIAlj/7AJY/+wCWAD6AlgA+gJY/+wCWP/sAlgA+gJY/+wCWP/sAlj/7AJY/+wCWP/sAlj/7AJY/+wCWP/sAlj/7AJY/+wCWACWAlj/7AJY/+wCWP/sAlj/7AJYAMgCWADIAlj/7AJY/+wCWP/sAlj/7AJYAMgCWAD6Alj/7AJY/+wCWAD6Alj/7AJY/+wCWACWAlj/7AJY/+wCWADIAlj/7AJY/+wCWAD6Alj/7AJY/+wCWAD6AlgANwJYAF4CWABGAlj/9gJYABQCWAAlAlgAQgJYAB8CWAAnAlgADQJYAIICWAAtAlgANwJYAEECWABNAlgALQJYAC0CWAAPAlgAlgJYAKUCWABVAlgA/wJYAP8CWABQAlgARgJYAFACWAAeAlgAPAJYABsCWAAZAlgAgAJYADwCWAAaAlgAGgJYABoCWAAaAlgAGgJYABoCWACEAlgAHQJYAB0CWAAdAlgAHQJYAB0CWACCAlgAggJYAIACWACCAlgAUQJYAAoCWAAPAlgAjgJYABoCWACBAlgAGgJY/+wCWP/sAlj/7AJYAPUCWAAGAlgAPAJYAIECWAAAAlgAewJYAHsCWAB7AlgAFAJYABQCWAAUAlgAFAJYAFoCWABKAlgAgQJYAHQCWP5cAlgAjAJY/dUCWP39Alj7wwJY/hECWP6nAlj70gJY/rsCWP67Alj+4wJY/KQCWPzHAlj6yQJY/KQCWPzWAlj+pwJY+9ICWP67Alj+EwJY/iACWPv/Alj92gJY/ioCWPugAlj7oAJY/fgCWPulAlj7pQJY/f0CWPulAlj7pQJY+4wCWP4MAlj7swJY/mECWP6JAlj+zwJY+7MCWP4qAlj7swJY+7MCWPxt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AEwBAgBFAPoATQEDAEgA+ABQAQcAUgEJAQoAVAEMAFYBDwBVAQ4AVwEQAFgBEQBbARQAXQEXAFwBFgEVAF4BGAB0AS8AYgEcAHMBLgB5ATQAfgE5AIABOwB/AToAggE9AIUBQACEAT8AgwE+AIwBRwCLAUYAigFFAKABYACdAV0AkAFLAJ8BXwCcAVwAngFeAKQBZACqAWoAqwCyAXIAtAF0ALMBcwFDAIgANgBtASgAlgFWAAkAvQA8APAAdQEwADoA7gAZAM0AdwEyAIYBQQCNAUgArwFvBOkE5wUJBQMFCgUOBQsFBgTsBO0E8AT0BPUE8gTrBOoE9gTzBO4E8QUyBTQCAALXAgECAgIDAgUCBgIlAgcCCAIrAiwCLQIjAigCJAInAikCJgIqAgkCLwIwAi4BgAGmAXwBngGdAaABoQGiAZsBnAGjAYYBkAGXAXgBeQF6AXsBfgF/AYEBggGDAYQBhQGRAZIBlAGTAZUBlgGZAZoBmAGfAaQBpQGwAbEBsgGzAbYBtwG5AboBuwG8Ab0ByQHKAcwBywHNAc4B0QHSAdAB1wHcAd0BuAHeAbQB1gHVAdgB2QHaAdMB1AHbAb4ByAHPAX0BtQGnAd8BqAHgAakB4QGqAeIBqwHjAawB5AGtAeUBrgHmAa8B5wCmAWYAowFjAKUBZQARAMUAEwDHAAsAvwANAMEADgDCAA8AwwAMAMAABAC4AAYAugAHALsACAC8AAUAuQAxAOUAMwDnADcA6gAqAN4ALADgAC0A4QAuAOIAKwDfAEsBAQBJAP8AagElAGwBJwBkAR8AZgEhAGcBIgBoASMAZQEgAG4BKQBwASsAcQEsAHIBLQBvASoAkwFTAJUBVQCXAVcAmQFZAJoBWgCbAVsAmAFYAK0BbQCsAWwArgFuALABcAKLAowChwKJAooCiARaBFwCZARWBFcCkQJqAm0CVQJmAmcCMgRdBIoEiQNlA18DYQNjA2cDaANmA2ADYgNkA1cC7QMvAvwC9wMOA1IDDQL5AywC7wMtAxcDSwLrAy4DPwM9AvQC+wMKAyEDDAM+AxsC+gMRAx8DHgMSAw8DEwMQAwQC/QNRA1QDFAMVA0ADQQMLA00DTgNeA1sDXANVA1kC+AMFA1gC9gRzBGIDdwR/AnsCfQJ8An4DNAMyAzMDNwM1AzYDAwMBAwIDSANGA0cDAAL/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AAAA+gAAAPoAAAFKAAAA+wAAAPwAAAFNAAAA/QAAAP0AAAFpAAAA/gAAAP4AAAE2AAAA/wAAAP8AAAFrAAABAAAAAQAAAAAUAAABAQAAAQEAAADIAAABAgAAAQIAAAADAAABAwAAAQMAAAC3AAABBAAAAQQAAAAVAAABBQAAAQUAAADJAAABBgAAAQYAAAAcAAABBwAAAQcAAADQAAABCAAAAQgAAAAfAAABCQAAAQkAAADTAAABCgAAAQoAAAAgAAABCwAAAQsAAADUAAABDAAAAQwAAAAdAAABDQAAAQ0AAADRAAABDgAAAQ4AAAAjAAABDwAAAQ8AAADXAAABEAAAARAAAAAkAAABEQAAAREAAADYAAABEgAAARIAAAA0AAABEwAAARMAAADoAAABFAAAARQAAAAnAAABFQAAARUAAADbAAABFgAAARYAAAAwAAABFwAAARcAAADkAAABGAAAARgAAAA1AAABGQAAARkAAADpAAABGgAAARoAAAAoAAABGwAAARsAAADcAAABHAAAARwAAAA9AAABHQAAAR0AAADxAAABHgAAAR4AAAA7AAABHwAAAR8AAADvAAABIAAAASAAAAA/AAABIQAAASEAAADzAAABIgAAASIAAAA+AAABIwAAASMAAADyAAABJAAAASQAAABCAAABJQAAASUAAAD2AAABJgAAASYAAABBAAABJwAAAScAAAD1AAABKAAAASgAAABOAAABKQAAASkAAAEEAAABKgAAASoAAABMAAABKwAAASsAAAECAAABLAAAASwAAABFAAABLQAAAS0AAAD6AAABLgAAAS4AAABNAAABLwAAAS8AAAEDAAABMAAAATAAAABIAAABMQAAATEAAAD4AAABNAAAATQAAABQAAABNQAAATUAAAEHAAABNgAAATYAAABSAAABNwAAATgAAAEJAAABOQAAATkAAABUAAABOgAAAToAAAEMAAABOwAAATsAAABWAAABPAAAATwAAAEPAAABPQAAAT0AAABVAAABPgAAAT4AAAEOAAABPwAAAT8AAABXAAABQAAAAUAAAAEQAAABQQAAAUEAAABYAAABQgAAAUIAAAERAAABQwAAAUMAAABbAAABRAAAAUQAAAEUAAABRQAAAUUAAABdAAABRgAAAUYAAAEXAAABRwAAAUcAAABcAAABSAAAAUgAAAEW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SrdK7EsXS01LWkt0S6BLt0vzTAlMLkxETFFMYExvTKxM4E0MTTpNe02NTcxN/U5TToZOuU7cTwZPKU9OT3lPpE/PT+NP61AEUDBQQ1BfUHpQllC3UNhQ71D7UQpRNFFQUaVR31H7UhdSIlJCUmJSeFKTUrJS71L3UwpTF1MvU0dTT1NaU2VTsVQoVD1UX1SGVM1VCFUQVThVYFWqVbVVwFXLVdNV3lXpVf1WMFZWVl5WcFZ7VpRWqVbMVvZXGlc8V09XulfcWBNYHlijWNtZIFlhWaBZxlnuWhZaP1plWo5atlrfWyJbYVusW7db+1wpXFNcflyJXM1c5l0CXQ1dNF1YXXxdjV3DXepeEV5SXl5ea154XoVekl6fXqxeuV7GXtJe317sXvlfBl8TXyBfLV87X0lfVl9kX3FfgV+VX6Vftl/EX9pf6mEPY1BkeWSVZMdk+2UlZZpl62YRZiFmOWZpZnZmimaXZqpmtWbJZtxm8GcLZxlnJWcyZ0BnVGdnZ3tnkGecZ6dnumfFZ9Jn3mfpZ/ZoCGgaaCxoPmheaHhokWikaMNo22jzaQdpMmlRaXFpiGmdabJpxGnUaelp+WoOaiVqOGpIal1qbWqCaplqs2rIat1q72sDaxBrImsya0JrT2tca25rimuoa7VrzGvna/RsBWwUbCZsNWxCbFhsamx8bJVsqmy/bNds62z+bRRtLW1GbV9teG2SbbRtxW3Wbeht/G4JbhxuLG48bkluVm5oboRuom6vbsZu4W7ubwBvEm8ibzJvP29Xb2pvfW+Wb6tvwG/Yb+xv/3AVcC5wRHBYcGxwg3CUcKlwuHDNcNxw83EFcRpxKnE/cU9xaHF8cZBxsHHIceFx93IJchtyM3JGcllye3KTcqtys3LncvNzH3Myc0RzXXN2c49zo3OydAZ0UHRrdNd1LnWCdcF153X1dgt2GHYsdkF2fXaadup3IXc1d0l3WHdpd313kXeld7l3zXfhd/B4BHgYeCx4QHhUeGN4cniBeJB4p3i/eUJ5UXlleXR5iHnbeiJ6WHpxepl6sXrAew17HHsrezp7Tntie3Z7inuUe557rXu8e8R77HxCfM19mH3ufgF+JH5lfn5+in6jfr1+7H8KfzJ/SX90f5Z/94AUgDqAY4CYgNiBFIEogUOBaIGNgcWB8IITgjCCXoJqgnaCmoLKgtaC94Mf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/tQCWP95AAMAABE1IRUCWP7UpaUAAQAA/tQCWAAeAAMAABERIRECWP7UAUr+tgABAAD+1AJYAMMAAwAAEREhEQJY/tQB7/4RAAEAAP7UAlgBaAADAAARESERAlj+1AKU/WwAAQAA/tQCWAINAAMAABERIRECWP7UAzn8xwABAAD+1AJYArIAAwAAEREhEQJY/tQD3vwiAAEAAP7UAlgDVwADAAARESERAlj+1ASD+30AAQAA/tQCWAP8AAMAABERIRECWP7UBSj62AABAAABaAJYA/wAAwAAEREhEQJYAWgClP1sAAEAAANXAlgD/AADAAARNSEVAlgDV6WlAAEAAP7UAEsD/AADAAARETMRS/7UBSj62AAAAQAA/tQAlgP8AAMAABERMxGW/tQFKPrYAAABAAD+1ADIA/wAAwAAEREzEcj+1AUo+tgAAAEAAP7UASwD/AADAAARESERASz+1AUo+tgAAQAA/tQBdwP8AAMAABERIREBd/7UBSj62AABAAD+1AHCA/wAAwAAEREhEQHC/tQFKPrYAAEAAP7UAg0D/AADAAARESERAg3+1AUo+tgAAQEs/tQCWAP8AAMAAAERIREBLAEs/tQFKPrYAAECDf7UAlgD/AADAAABETMRAg1L/tQFKPrYAAABAAD+1AEsAWgAAwAAEREhEQEs/tQClP1sAAEBLP7UAlgBaAADAAABESERASwBLP7UApT9bAABAAABaAEsA/wAAwAAEREhEQEsAWgClP1sAAEAAP7UAlgD/AAFAAARESERIREBLAEs/tQFKP1s/WwAAgAA/tQCWAP8AAMABwAAEREhGQIhEQEsASwBaAKU/Wz9bAKU/WwAAAEAAP7UAlgD/AAFAAARESERIRECWP7U/tQFKP1s/WwAAf/2/tQCWAP8AAUAAAERIREhEQEs/soCYv7UApQClPrYAAEBLAFoAlgD/AADAAABESERASwBLAFoApT9bAACAAD+1AJYA/wAAwAHAAABESERAREhEQEsASz9qAEsAWgClP1s/WwClP1sAAEAAP7UAlgD/AAFAAARESERIREBLAEs/tQClAKU+tgANwA8/xACWAP8AAMABwALAA8AEwAXABsAHwAjACcAKwAvADMANwA7AD8AQwBHAEsATwBTAFcAWwBfAGMAZwBrAG8AcwB3AHsAfwCDAIcAiwCPAJMAlwCbAJ8AowCnAKsArwCzALcAuwC/AMMAxwDLAM8A0wDXANsAAAE1MxUhNTMVMzUzFTM1MxUzNTMVFzUzFSE1MxUzNTMVMzUzFTM1MxUXNTMVITUzFTM1MxUzNTMVMzUzFRc1MxUhNTMVMzUzFTM1MxUzNTMVFzUzFSE1MxUzNTMVMzUzFTM1MxUXNTMVITUzFTM1MxUzNTMVMzUzFRc1MxUhNTMVMzUzFTM1MxUzNTMVFzUzFSE1MxUzNTMVMzUzFTM1MxUXNTMVITUzFTM1MxUzNTMVMzUzFRc1MxUhNTMVMzUzFTM1MxUzNTMVFzUzFSE1MxUzNTMVMzUzFTM1MxUCHDz95Dw8PDw8PDw8PP3kPDw8PDw8PDw8/eQ8PDw8PDw8PDz95Dw8PDw8PDw8PP3kPDw8PDw8PDw8/eQ8PDw8PDw8PDz95Dw8PDw8PDw8PP3kPDw8PDw8PDw8/eQ8PDw8PDw8PDz95Dw8PDw8PDw8PP3kPDw8PDw8PAPAPDw8PDw8PDw8PHg8PDw8PDw8PDw8eDw8PDw8PDw8PDx4PDw8PDw8PDw8PHg8PDw8PDw8PDw8eDw8PDw8PDw8PDx4PDw8PDw8PDw8PHg8PDw8PDw8PDw8eDw8PDw8PDw8PDx4PDw8PDw8PDw8PHg8PDw8PDw8PDw8AG4AAP7UAlgD/AADAAcACwAPABMAFwAbAB8AIwAnACsALwAzADcAOwA/AEMARwBLAE8AUwBXAFsAXwBjAGcAawBvAHMAdwB7AH8AgwCHAIsAjwCTAJcAmwCfAKMApwCrAK8AswC3ALsAvwDDAMcAywDPANMA1wDbAN8A4wDnAOsA7wDzAPcA+wD/AQMBBwELAQ8BEwEXARsBHwEjAScBKwEvATMBNwE7AT8BQwFHAUsBTwFTAVcBWwFfAWMBZwFrAW8BcwF3AXsBfwGDAYcBiwGPAZMBlwGbAZ8BowGnAasBrwGzAbcAAAE1MxUBNTMVJzUzFRU1MxUVNTMVJzUzFRU1MxUVNTMVFTUzFRU1MxUBNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFQE1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUBNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFQE1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUBNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFQE1MxUVNTMVFTUzFRU1MxUVNTMVJzUzFRU1MxUVNTMVAhw8/ag8PDw8PLQ8PDw8PP7UPDw8PDw8PP5cPDw8PDw8PDw8/eQ8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/eQ8PDw8PDw8PDz+XDw8PDw8PDz+1Dw8PDw8tDw8PAPAPDz7FDw8eDw8PDw8PDw88Dw8PDw8PDw8PDw8PDw8AWg8PDw8PDw8PDw8PDw8PDw8PDw8PAHgPDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDwCWDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8ApQ8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PAKUPDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDwClDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8ApQ8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PAKUPDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDwCWDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8AeA8PDw8PDw8PDw8PDw8PDw8PDw8PAFoPDw8PDw8PDw8PDw8PDzwPDw8PDw8PDwAKQAA/tQCWAP8AD0AQQBFAEkATQBRAFUAWQBdAGEAZQBpAG0AcQB1AHkAfQCBAIUAiQCNAJEAlQCZAJ0AoQClAKkArQCxALUAuQC9AMEAxQDJAM0A0QDVANkA3QAAETUzNSM1MzUjNTM1IzUzNSM1MzUjNTM1IzUzNSM1MzUjNTM1IzUzNSM1MzUzFTM1MxUzNTMV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AAEECQACAA4B/QADAAEECQADADwCCwADAAEECQAEACwCRwADAAEECQAFABoCcwADAAEECQAGACoCjQADAAEECQAHAGICtwADAAEECQAIABIDGQADAAEECQAJAEoDKwADAAEECQALADIDdQADAAEECQAMADIDdQADAAEECQANASIDpwADAAEECQAOADYEyQADAAEECQAZACQE/wADAAEECQEAAAwFIwADAAEECQEBAAgFLwADAAEECQECABQFNwADAAEECQEDAAoFSwADAAEECQEEAA4B/QADAAEECQEFAAwFVQADAAEECQEGABAFYQADAAEECQEHAAgFcQADAAEECQEIABIFeQADAAEECQEJAC4FiwADAAEECQEKADoFuQADAAEECQELADAF8wADAAEECQEMADQGIwADAAEECQENADIGVwADAAEECQEOADYGiQADAAEECQEPAC4GvwADAAEECQEQADgG7QADAAEECQERAAwHJQADAAEECQESAAoHMUpldEJyYWluc01vbm9Sb21hbldlaWdodFRoaW5FeHRyYUxpZ2h0TGlnaHRSZWd1bGFyTWVkaXVtU2VtaUJvbGRCb2xkRXh0cmFCb2xkSmV0QnJhaW5zTW9ub1JvbWFuLVRoaW5KZXRCcmFpbnNNb25vUm9tYW4tRXh0cmFMaWdodEpldEJyYWluc01vbm9Sb21hbi1MaWdodEpldEJyYWluc01vbm9Sb21hbi1SZWd1bGFySmV0QnJhaW5zTW9ub1JvbWFuLU1lZGl1bUpldEJyYWluc01vbm9Sb21hbi1TZW1pQm9sZEpldEJyYWluc01vbm9Sb21hbi1Cb2xkSmV0QnJhaW5zTW9ub1JvbWFuLUV4dHJhQm9sZEl0YWxpY1JvbWFuAEMAbwBwAHkAcgBpAGcAaAB0ACAAMgAwADIAMAAgAFQAaABlACAASgBlAHQAQgByAGEAaQBuAHMAIABNAG8AbgBvACAAUAByAG8AagBlAGMAdAAgAEEAdQB0AGgAbwByAHMAIAAoAGgAdAB0AHAAcwA6AC8ALwBnAGkAdABoAHUAYgAuAGMAbwBtAC8ASgBlAHQAQgByAGEAaQBuAHMALwBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvACkASgBlAHQAQgByAGEAaQBuAHMAIABNAG8AbgBvAFIAZQBnAHUAbABhAHIAMgAuADIANAAyADsASgBCADsASgBlAHQAQgByAGEAaQBuAHMATQBvAG4AbwAtAFIAZQBnAHUAbABhAHIASgBlAHQAQgByAGEAaQBuAHMAIABNAG8AbgBvACAAUgBlAGcAdQBsAGEAcgBWAGUAcgBzAGkAbwBuACAAMgAuADIANAAyAEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8ALQBSAGUAZwB1AGwAYQByAEoAZQB0AEIAcgBhAGkAbgBzACAATQBvAG4AbwAgAGkAcwAgAGEAIAB0AHIAYQBkAGUAbQBhAHIAawAgAG8AZgAgAEoAZQB0AEIAcgBhAGkAbgBzACAAcwAuAHIALgBvAC4ASgBlAHQAQgByAGEAaQBuAHMAUABoAGkAbABpAHAAcAAgAE4AdQByAHUAbABsAGkAbgAsACAASwBvAG4AcwB0AGEAbgB0AGkAbgAgAEIAdQBsAGUAbgBrAG8AdgBoAHQAdABwAHMAOgAvAC8AdwB3AHcALgBqAGUAdABiAHIAYQBpAG4AcwAuAGMAbwBtAFQAaABpAHMAIABGAG8AbgB0ACAAUwBvAGYAdAB3AGEAcgBlACAAaQBzACAAbABpAGMAZQBuAHMAZQBkACAAdQBuAGQAZQByACAAdABoAGUAIABTAEkATAAgAE8AcABlAG4AIABGAG8AbgB0ACAATABpAGMAZQBuAHMAZQAsACAAVgBlAHIAcwBpAG8AbgAgADEALgAxAC4AIABUAGgAaQBzACAAbABpAGMAZQBuAHMAZQAgAGkAcwAgAGEAdgBhAGkAbABhAGIAbABlACAAdwBpAHQAaAAgAGEAIABGAEEAUQAgAGEAdAA6ACAAaAB0AHQAcABzADoALwAvAHMAYwByAGkAcAB0AHMALgBzAGkAbAAuAG8AcgBnAC8ATwBGAEwAaAB0AHQAcABzADoALwAvAHMAYwByAGkAcAB0AHMALgBzAGkAbAAuAG8AcgBnAC8ATwBGAEwASgBlAHQAQgByAGEAaQBuAHMATQBvAG4AbwBSAG8AbQBhAG4AVwBlAGkAZwBoAHQAVABoAGkAbgBFAHgAdAByAGEATABpAGcAaAB0AEwAaQBnAGgAdABNAGUAZABpAHUAbQBTAGUAbQBpAEIAbwBsAGQAQgBvAGwAZABFAHgAdAByAGEAQgBvAGwAZABKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAFIAbwBtAGEAbgAtAFQAaABpAG4ASgBlAHQAQgByAGEAaQBuAHMATQBvAG4AbwBSAG8AbQBhAG4ALQBFAHgAdAByAGEATABpAGcAaAB0AEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8AUgBvAG0AYQBuAC0ATABpAGcAaAB0AEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8AUgBvAG0AYQBuAC0AUgBlAGcAdQBsAGEAcgBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAFIAbwBtAGEAbgAtAE0AZQBkAGkAdQBtAEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8AUgBvAG0AYQBuAC0AUwBlAG0AaQBCAG8AbABkAEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8AUgBvAG0AYQBuAC0AQgBvAGwAZABKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAFIAbwBtAGEAbgAtAEUAeAB0AHIAYQBCAG8AbABkAEkAdABhAGwAaQBjAFIAbwBtAGEAbgAAAAACAAAAAAAA/2UAMgAAAAEAAAAAAAAAAAAAAAAAAAAABU8AAAAkAMkBAgEDAQQBBQEGAQcBCADHAQkBCgELAQwBDQBiAQ4ArQEPARABEQBjAK4AkAESACUAJgD9AP8AZAETARQAJwDpARUBFgAoAGUBFwEYAMgBGQEaARsBHAEdAMoBHgEfAMsBIAEhASIBIwEkACkAKgElAPgBJgEnASgBKQArASoBKwAsAMwBLADNAM4A+gEtAM8BLgEvATABMQAtATIALgEzAC8BNAE1ATYBNwDiADAAMQE4ATkBOgE7AGYAMgDQATwA0QE9AT4BPwFAAUEAZwFCANMBQwFEAUUBRgFHAUgBSQFKAUsBTACRAU0ArwCwADMA7QA0ADUBTgFPAVAANgFRAOQA+wFSAVMBVAFVADcBVgFXAVgBWQA4ANQBWgDVAGgBWwDWAVwBXQFeAV8BYAFhAWIBYwFkAWUBZgFnADkAOgFoAWkBagFrADsAPADrAWwAuwFtAW4BbwFwAXEAPQFyAOYBcwBEAGkBdAF1AXYBdwF4AXkBegBrAXsBfAF9AX4BfwBsAYAAagGBAYIBgwBuAG0AoAGEAEUARgD+AQAAbwGFAYYARwDqAYcBAQBIAHABiAGJAHIBigGLAYwBjQGOAHMBjwGQAHEBkQGSAZMBlAGVAEkASgGWAPkBlwGYAZkBmgBLAZsBnABMANcAdAGdAZ4AdgB3AZ8BoAB1AaEBogGjAaQATQGlAaYATgGnAagATwGpAaoBqwGsAa0A4wBQAFEBrgGvAbABsQGyAHgAUgB5AbMBtAB7AbUBtgG3AbgBuQB8AboAegG7AbwBvQG+Ab8BwAHBAcIBwwHEAKEBxQB9ALEAUwDuAFQAVQHGAccByABWAckA5QD8AcoBywCJAcwAVwHNAc4BzwHQAFgAfgHRAdIAgACBAdMB1AHVAdYB1wB/AdgB2QHaAdsB3AHdAd4B3wHgAeEB4gHjAFkAWgHkAeUB5gHnAFsAXADsAegAugHpAeoB6wHsAe0AXQHuAOcB7wHwAJ0AngHxAfIB8wH0AfUB9gH3AfgB+QH6AfsB/AH9Af4B/wIAAgECAgIDAgQCBQIGAgcCCAIJAgoCCwIMAg0CDgIPAhACEQISAhMCFAIVAhYCFwIYAhkCGgIbAhwCHQIeAh8CIAIhAiICIwIkAiUCJgInAigCKQIqAisCLAItAi4CLwIwAjECMgIzAjQCNQI2AjcCOAI5AjoCOwI8Aj0CPgI/AkACQQJCAkMCRAJFAkYCRwJIAkkCSgJLAkwCTQJOAk8CUAJRAlICUwJUAlUCVgJXAlgCWQJaAlsCXAJdAl4CXwJgAmECYgJjAmQCZQJmAmcCaAJpAmoCawJsAm0CbgJvAnACcQJyAnMCdAJ1AnYCdwJ4AnkCegJ7AnwCfQJ+An8CgAKBAoICgwKEAoUChgKHAogCiQKKAosCjAKNAo4CjwKQApEAmwKSApMClAKVApYClwKYApkCmgKbApwCnQKeAp8CoAKhAqICowKkAqUCpgKnAqgCqQKqAqsCrAKtABMAFAAVABYAFwAYABkAGgAbABwCrgKvArACsQKyArMCtAK1ArYCtwK4ArkCugK7ArwCvQK+Ar8CwALBAsIAvAD0APUA9gLDABEADwAdAB4AqwAEAKMAIgCiAMMAhwANAsQCxQAGAsYCxwASAD8CyALJAsoCywALAAwAXgBgAD4AQALMAs0CzgLPAtAC0QLSAtMC1ALVABAC1gCyALMC1wBCAMQAxQC0ALUAtgC3AKkAqgC+AL8C2AAFAAoC2QLaAtsC3ALdAt4C3wLgAuEC4gLjAuQC5QLmAucC6ALpAuoC6wLsAu0C7gLvAvAC8QLyAvMC9AL1AvYC9wL4AvkC+gL7AvwC/QL+Av8DAAMBAwIDAwMEAwUDBgMHAwgDCQMKAwsDDAMNAw4DDwMQAxEDEgMTAxQDFQMWAxcDGAMZAxoDGwMcAx0DHgMfAAMDIAMhAyIDIwCEAL0ABwMkAyUApgMmAIUDJwCWAygDKQMqAysDLAMtAy4DLwMwAzEDMgMzAzQDNQM2AzcDOAM5AzoDOwM8Az0DPgM/A0ADQQNCA0MDRANFA0YDRwNIA0kDSgNLA0wDTQNOA08DUANRA1IDUwAOAO8A8AC4ACAAjwAhAB8AlQCUAJMApwCkAGEAQQCSA1QDVQNWA1cDWACcAJoAmQClAJgDWQNaA1sDXANdA14DXwNgAAgAxgNhA2IDYwNkA2UDZgNnA2gDaQNqA2sDbANtA24DbwNwA3EDcgNzA3QDdQN2A3cDeAN5A3oDewN8A30DfgN/A4ADgQOCA4MDhAOFA4YDhwOIA4kDigOLA4wDjQOOA48DkAORA5IDkwOUA5UDlgOXA5gDmQOaA5sDnAOdA54DnwOgA6EDogOjA6QDpQOmA6cDqAOpA6oDqwOsA60DrgOvA7ADsQOyA7MDtAO1A7YDtwO4A7kDugO7A7wDvQO+A78DwAPBA8IDwwPEA8UDxgPHA8gDyQPKA8sAuQPMA80DzgPPA9AD0QPSA9MD1APVA9YD1wPYA9kD2gPbA9wD3QPeA98D4APhA+ID4wPkA+UD5gPnA+gD6QPqA+sD7APtA+4D7wPwA/ED8gPzA/QD9QP2A/cD+AP5A/oD+wP8A/0D/gP/BAAEAQQCBAMEBAQFBAYEBwQIBAkECgQLBAwEDQQOBA8EEAQRBBIEEwQUBBUEFgQXBBgEGQQaBBsEHAQdBB4EHwQgBCEEIgQjBCQEJQQmBCcEKAQpBCoEKwQsBC0ELgQvBDAEMQQyBDMENAQ1BDYENwQ4BDkEOgQ7BDwEPQQ+BD8EQARBBEIEQwREBEUERgRHBEgESQRKBEsETARNBE4ETwRQBFEEUgRTBFQEVQRWBFcEWARZBFoEWwRcBF0EXgRfBGAEYQRiBGMEZARlBGYEZwRoBGkEagRrBGwEbQRuBG8EcARxBHIEcwAjAAkAiACGAIsAigCMAIMEdAR1AF8A6ACCBHYAwgR3BHgEeQR6BHsEfAR9BH4EfwSABIEEggSDBIQEhQSGBIcEiASJBIoEiwSMBI0EjgSPBJAEkQSSBJMElASVBJYElwSYBJkEmgSbBJwEnQSeBJ8EoAShBKIEowSkBKUEpgSnBKgEqQSqBKsErAStBK4ErwSwBLEEsgSzBLQEtQS2BLcEuAS5BLoEuwS8BL0EvgS/BMAEwQTCBMMExATFBMYExwTIBMkEygTLBMwEzQTOBM8E0ATRBNIE0wTUBNUE1gTXBNgE2QTaBNsE3ATdBN4E3wTgBOEE4gTjBOQE5QTmBOcE6ATpBOoE6wTsBO0E7gTvBPAE8QTyBPME9AT1BPYE9wT4BPkE+gT7BPwE/QT+BP8FAAUBBQIFAwUEBQUFBgUHBQgFCQUKBQsFDAUNBQ4FDwUQBREFEgUTBRQFFQUWBRcFGAUZBRoFGwCOANwAQwCNAN8A2ADhANsA3QDZANoA3gDgBRwFHQUeBR8FIAUhBSIFIwUkBSUFJgUnBSgFKQUqBSsFLAUtBS4FLwUwBTEFMgUzBTQFNQU2BTcFOAU5BToFOwU8BT0FPgU/BUAFQQVCBUMFRAVFBUYFRwVIBUkFSgVLBUwFTQVOBU8FUAVRBVIFUwVUBVUFVgVXBVgFWQVaBVsGQWJyZXZlB3VuaTFFQUUHdW5pMUVCNgd1bmkxRUIwB3VuaTFFQjIHdW5pMUVCNAd1bmkwMUNEB3VuaTFFQTQHdW5pMUVBQwd1bmkxRUE2B3VuaTFFQTgHdW5pMUVBQQd1bmkxRUEwB3VuaTFFQTIHQW1hY3JvbgdBb2dvbmVrB0FFYWN1dGULQ2NpcmN1bWZsZXgKQ2RvdGFjY2VudAZEY2Fyb24GRGNyb2F0BkVicmV2ZQZFY2Fyb24HdW5pMUVCRQd1bmkxRUM2B3VuaTFFQzAHdW5pMUVDMgd1bmkxRUM0CkVkb3RhY2NlbnQHdW5pMUVCOAd1bmkxRUJBB0VtYWNyb24HRW9nb25lawd1bmkwMTkwB3VuaTFFQkMHdW5pMDFGNAZHY2Fyb24LR2NpcmN1bWZsZXgHdW5pMDEyMgpHZG90YWNjZW50BEhiYXILSGNpcmN1bWZsZXgGSWJyZXZlB3VuaTFFQ0EHdW5pMUVDOAdJbWFjcm9uB0lvZ29uZWsGSXRpbGRlC0pjaXJjdW1mbGV4B3VuaTAxMzYGTGFjdXRlBkxjYXJvbgd1bmkwMTNCBExkb3QGTmFjdXRlBk5jYXJvbgd1bmkwMTQ1A0VuZwZPYnJldmUHdW5pMUVEMAd1bmkxRUQ4B3VuaTFFRDIHdW5pMUVENAd1bmkxRUQ2B3VuaTFFQ0MHdW5pMUVDRQVPaG9ybgd1bmkxRURBB3VuaTFFRTIHdW5pMUVEQwd1bmkxRURFB3VuaTFFRTANT2h1bmdhcnVtbGF1dAdPbWFjcm9uB3VuaTAxRUELT3NsYXNoYWN1dGUGUmFjdXRlBlJjYXJvbgd1bmkwMTU2BlNhY3V0ZQtTY2lyY3VtZmxleAd1bmkwMjE4B3VuaTFFOUUHdW5pMDE4RgRUYmFyBlRjYXJvbgd1bmkwMTYyB3VuaTAyMUEGVWJyZXZlB3VuaTFFRTQHdW5pMUVFNgVVaG9ybgd1bmkxRUU4B3VuaTFFRjAHdW5pMUVFQQd1bmkxRUVDB3VuaTFFRUUNVWh1bmdhcnVtbGF1dAdVbWFjcm9uB1VvZ29uZWsFVXJpbmcGVXRpbGRlBldhY3V0ZQtXY2lyY3VtZmxleAlXZGllcmVzaXMGV2dyYXZlC1ljaXJjdW1mbGV4B3VuaTFFRjQGWWdyYXZlB3VuaTFFRjYHdW5pMDIzMgd1bmkxRUY4BlphY3V0ZQpaZG90YWNjZW50BmFicmV2ZQd1bmkxRUFGB3VuaTFFQjcHdW5pMUVCMQd1bmkxRUIzB3VuaTFFQjUHdW5pMDFDRQd1bmkxRUE1B3VuaTFFQUQHdW5pMUVBNwd1bmkxRUE5B3VuaTFFQUIHdW5pMUVBMQd1bmkxRUEzB2FtYWNyb24HYW9nb25lawdhZWFjdXRlC2NjaXJjdW1mbGV4CmNkb3RhY2NlbnQGZGNhcm9uBmVicmV2ZQZlY2Fyb24HdW5pMUVCRgd1bmkxRUM3B3VuaTFFQzEHdW5pMUVDMwd1bmkxRUM1CmVkb3RhY2NlbnQHdW5pMUVCOQd1bmkxRUJCB2VtYWNyb24HZW9nb25lawd1bmkxRUJEB3VuaTAyNTkHdW5pMDFGNQZnY2Fyb24LZ2NpcmN1bWZsZXgHdW5pMDEyMwpnZG90YWNjZW50BGhiYXILaGNpcmN1bWZsZXgGaWJyZXZlB3VuaTAxRDAJaS5sb2NsVFJLB3VuaTFFQ0IHdW5pMUVDOQdpbWFjcm9uB2lvZ29uZWsGaXRpbGRlB3VuaTAyMzcLamNpcmN1bWZsZXgHdW5pMDEzNwxrZ3JlZW5sYW5kaWMGbGFjdXRlB3VuaTAxOUIGbGNhcm9uB3VuaTAxM0MEbGRvdAZuYWN1dGULbmFwb3N0cm9waGUGbmNhcm9uB3VuaTAxNDYDZW5nBm9icmV2ZQd1bmkwMUQyB3VuaTFFRDEHdW5pMUVEOQd1bmkxRUQzB3VuaTFFRDUHdW5pMUVENwd1bmkxRUNEB3VuaTFFQ0YFb2hvcm4HdW5pMUVEQgd1bmkxRUUzB3VuaTFFREQHdW5pMUVERgd1bmkxRUUxDW9odW5nYXJ1bWxhdXQHb21hY3Jvbgd1bmkwMUVCC29zbGFzaGFjdXRlBnJhY3V0ZQZyY2Fyb24HdW5pMDE1NwZzYWN1dGULc2NpcmN1bWZsZXgHdW5pMDIxOQVsb25ncwR0YmFyBnRjYXJvbgd1bmkwMTYzB3VuaTAyMUIGdWJyZXZlB3VuaTAxRDQHdW5pMDFEOAd1bmkwMURBB3VuaTAxREMHdW5pMDFENgd1bmkxRUU1B3VuaTFFRTcFdWhvcm4HdW5pMUVFOQd1bmkxRUYxB3VuaTFFRUIHdW5pMUVFRAd1bmkxRUVGDXVodW5nYXJ1bWxhdXQHdW1hY3Jvbgd1b2dvbmVrBXVyaW5nBnV0aWxkZQZ3YWN1dGULd2NpcmN1bWZsZXgJd2RpZXJlc2lzBndncmF2ZQt5Y2lyY3VtZmxleAd1bmkxRUY1BnlncmF2ZQd1bmkxRUY3B3VuaTAyMzMHdW5pMUVGOQZ6YWN1dGUKemRvdGFjY2VudA9nZXJtYW5kYmxzLmNhbHQHdW5pMDQxMAd1bmkwNDExB3VuaTA0MTIHdW5pMDQxMwd1bmkwNDAzB3VuaTA0OTAHdW5pMDQxNAd1bmkwNDE1B3VuaTA0MDEHdW5pMDQxNgd1bmkwNDE3B3VuaTA0MTgHdW5pMDQxOQd1bmkwNDFBB3VuaTA0MEMHdW5pMDQxQgd1bmkwNDFDB3VuaTA0MUQHdW5pMDQxRQd1bmkwNDFGB3VuaTA0MjAHdW5pMDQyMQd1bmkwNDIyB3VuaTA0MjMHdW5pMDQwRQd1bmkwNDI0B3VuaTA0MjUHdW5pMDQyNwd1bmkwNDI2B3VuaTA0MjgHdW5pMDQyOQd1bmkwNDBGB3VuaTA0MkMHdW5pMDQyQQd1bmkwNDJCB3VuaTA0MDkHdW5pMDQwQQd1bmkwNDA1B3VuaTA0MDQHdW5pMDQyRAd1bmkwNDA2B3VuaTA0MDcHdW5pMDQwOAd1bmkwNDBCB3VuaTA0MkUHdW5pMDQyRgd1bmkwNDAyB3VuaTA0OTIHdW5pMDQ5QQd1bmkwNEEyB3VuaTA0QUUHdW5pMDRCMAd1bmkwNEI2B3VuaTA0QkEHdW5pMDREOAd1bmkwNEU4B3VuaTA0MzAHdW5pMDQzMQd1bmkwNDMyB3VuaTA0MzMHdW5pMDQ1Mwd1bmkwNDkxB3VuaTA0MzQHdW5pMDQzNQd1bmkwNDUxB3VuaTA0MzYHdW5pMDQzNwd1bmkwNDM4B3VuaTA0MzkHdW5pMDQzQQd1bmkwNDVDB3VuaTA0M0IHdW5pMDQzQwd1bmkwNDNEB3VuaTA0M0UHdW5pMDQzRgd1bmkwNDQwB3VuaTA0NDEHdW5pMDQ0Mgd1bmkwNDQzB3VuaTA0NUUHdW5pMDQ0NAd1bmkwNDQ1B3VuaTA0NDcHdW5pMDQ0Ngd1bmkwNDQ4B3VuaTA0NDkHdW5pMDQ1Rgd1bmkwNDRDB3VuaTA0NEEHdW5pMDQ0Qgd1bmkwNDU5B3VuaTA0NUEHdW5pMDQ1NQd1bmkwNDU0B3VuaTA0NEQHdW5pMDQ1Ngd1bmkwNDU3B3VuaTA0NTgHdW5pMDQ1Qgd1bmkwNDRFB3VuaTA0NEYHdW5pMDQ1Mgd1bmkwNDkzB3VuaTA0OUIHdW5pMDRBMwd1bmkwNEFGB3VuaTA0QjEHdW5pMDRCNwd1bmkwNEJCB3VuaTA0RDkHdW5pMDRFOQVBbHBoYQRCZXRhBUdhbW1hB3VuaTAzOTQHRXBzaWxvbgRaZXRhA0V0YQVUaGV0YQRJb3RhBUthcHBhBkxhbWJkYQJNdQJOdQJYaQdPbWljcm9uAlBpA1JobwVTaWdtYQNUYXUHVXBzaWxvbgNQaGkDQ2hpA1BzaQd1bmkwM0E5CkFscGhhdG9ub3MMRXBzaWxvbnRvbm9zCEV0YXRvbm9zCUlvdGF0b25vcwxPbWljcm9udG9ub3MMVXBzaWxvbnRvbm9zCk9tZWdhdG9ub3MMSW90YWRpZXJlc2lzD1Vwc2lsb25kaWVyZXNpcwd1bmkwM0NGBWFscGhhBGJldGEFZ2FtbWEFZGVsdGEHZXBzaWxvbgR6ZXRhA2V0YQV0aGV0YQRpb3RhBWthcHBhBmxhbWJkYQd1bmkwM0JDAm51AnhpB29taWNyb24DcmhvB3VuaTAzQzIFc2lnbWEDdGF1B3Vwc2lsb24DcGhpA2NoaQNwc2kFb21lZ2EJaW90YXRvbm9zDGlvdGFkaWVyZXNpcxFpb3RhZGllcmVzaXN0b25vcwx1cHNpbG9udG9ub3MPdXBzaWxvbmRpZXJlc2lzFHVwc2lsb25kaWVyZXNpc3Rvbm9zDG9taWNyb250b25vcwpvbWVnYXRvbm9zCmFscGhhdG9ub3MMZXBzaWxvbnRvbm9zCGV0YXRvbm9zB3VuaTAzRDcHdW5pMDNENQd1bmkwM0Q2BnUxRDUzRAd1bmkyMTE1B3VuaTIxMUEGdTFENTRBB3VuaTIxMjQJemVyby56ZXJvB3VuaTIwODAHdW5pMjA4MQd1bmkyMDgyB3VuaTIwODMHdW5pMjA4NAd1bmkyMDg1B3VuaTIwODYHdW5pMjA4Nwd1bmkyMDg4B3VuaTIwODkHdW5pMjA3MAd1bmkwMEI5B3VuaTAwQjIHdW5pMDBCMwd1bmkyMDc0B3VuaTIwNzUHdW5pMjA3Ngd1bmkyMDc3B3VuaTIwNzgHdW5pMjA3OQd1bmkwQUVBB3VuaTIwNDUHdW5pMjA0Ng5vbmVkb3RlbmxlYWRlcgd1bmkyMDNFB3VuaTIwM0YKY29sb24uY2FzZRtwZXJpb2RjZW50ZXJlZC5sb2NsQ0FULmNhc2UWcGVyaW9kY2VudGVyZWQubG9jbENBVAd1bmkyNzcwB3VuaTI3NkUHdW5pMjc3MQd1bmkyNzZGB3VuaTIzMDgHdW5pMjMwQQd1bmkyMzA5B3VuaTIzMEIHdW5pMjk4Nwd1bmkyOTg4B3VuaTAwQUQHdW5pMjAxMAd1bmkyMDM0Emh5cGhlbl9oeXBoZW4ubGlnYRloeXBoZW5faHlwaGVuX2h5cGhlbi5saWdhGmh5cGhlbl9oeXBoZW5fZ3JlYXRlci5saWdhD2h5cGhlbl9iYXIubGlnYRNoeXBoZW5fZ3JlYXRlci5saWdhG2h5cGhlbl9ncmVhdGVyX2dyZWF0ZXIubGlnYRBoeXBoZW5fbGVzcy5saWdhFWh5cGhlbl9sZXNzX2xlc3MubGlnYRZoeXBoZW5fYXNjaWl0aWxkZS5saWdhEmJyYWNlbGVmdF9iYXIubGlnYRRicmFja2V0bGVmdF9iYXIubGlnYRVicmFja2V0bGVmdF9sZXNzLmxpZ2EcYnJhY2tldHJpZ2h0X251bWJlcnNpZ24ubGlnYRJwZXJpb2RfcGVyaW9kLmxpZ2EZcGVyaW9kX3BlcmlvZF9wZXJpb2QubGlnYRdwZXJpb2RfcGVyaW9kX2xlc3MubGlnYRRwZXJpb2RfcXVlc3Rpb24ubGlnYRFwZXJpb2RfZXF1YWwubGlnYRBjb2xvbl9jb2xvbi5saWdhFmNvbG9uX2NvbG9uX2NvbG9uLmxpZ2EWY29sb25fY29sb25fZXF1YWwubGlnYRNjb2xvbl9xdWVzdGlvbi5saWdhG2NvbG9uX3F1ZXN0aW9uX2dyZWF0ZXIubGlnYRBjb2xvbl9lcXVhbC5saWdhEmNvbG9uX2dyZWF0ZXIubGlnYQ9jb2xvbl9sZXNzLmxpZ2EYc2VtaWNvbG9uX3NlbWljb2xvbi5saWdhInNlbWljb2xvbl9zZW1pY29sb25fc2VtaWNvbG9uLmxpZ2ESZXhjbGFtX2V4Y2xhbS5saWdhEWV4Y2xhbV9lcXVhbC5saWdhF2V4Y2xhbV9lcXVhbF9lcXVhbC5saWdhFHF1ZXN0aW9uX3BlcmlvZC5saWdhE3F1ZXN0aW9uX2NvbG9uLmxpZ2EWcXVlc3Rpb25fcXVlc3Rpb24ubGlnYR9xdWVzdGlvbl9xdWVzdGlvbl9xdWVzdGlvbi5saWdhE3F1ZXN0aW9uX2VxdWFsLmxpZ2EfYXN0ZXJpc2tfYXN0ZXJpc2tfYXN0ZXJpc2subGlnYRVhc3Rlcmlza19ncmVhdGVyLmxpZ2ETYXN0ZXJpc2tfc2xhc2gubGlnYRludW1iZXJzaWduX3BhcmVubGVmdC5saWdhGW51bWJlcnNpZ25fYnJhY2VsZWZ0LmxpZ2EbbnVtYmVyc2lnbl9icmFja2V0bGVmdC5saWdhFW51bWJlcnNpZ25fY29sb24ubGlnYRZudW1iZXJzaWduX2V4Y2xhbS5saWdhGG51bWJlcnNpZ25fcXVlc3Rpb24ubGlnYRpudW1iZXJzaWduX251bWJlcnNpZ24ubGlnYSVudW1iZXJzaWduX251bWJlcnNpZ25fbnVtYmVyc2lnbi5saWdhMG51bWJlcnNpZ25fbnVtYmVyc2lnbl9udW1iZXJzaWduX251bWJlcnNpZ24ubGlnYRVudW1iZXJzaWduX2VxdWFsLmxpZ2EabnVtYmVyc2lnbl91bmRlcnNjb3JlLmxpZ2EkbnVtYmVyc2lnbl91bmRlcnNjb3JlX3BhcmVubGVmdC5saWdhE3NsYXNoX2FzdGVyaXNrLmxpZ2Ecc2xhc2hfYXN0ZXJpc2tfYXN0ZXJpc2subGlnYRBzbGFzaF9lcXVhbC5saWdhFnNsYXNoX2VxdWFsX2VxdWFsLmxpZ2ESc2xhc2hfZ3JlYXRlci5saWdhEHNsYXNoX3NsYXNoLmxpZ2EWc2xhc2hfc2xhc2hfZXF1YWwubGlnYRZzbGFzaF9zbGFzaF9zbGFzaC5saWdhHnVuZGVyc2NvcmVfYmFyX3VuZGVyc2NvcmUubGlnYRp1bmRlcnNjb3JlX3VuZGVyc2NvcmUubGlnYQd1bmkyN0U4B3VuaTI3RUEHdW5pMjdFNgd1bmkyN0U5B3VuaTI3RUIHdW5pMjdFNwlhbm90ZWxlaWEHdW5pMDM3RQZFTXF1YWQOWkVST1dJRFRIU1BBQ0UHdW5pMDBBMAJDUgd1bmlGRUZGB3VuaTIwQkYEZG9uZwRFdXJvB3VuaTIwQkQHdW5pMjBBRQd1bmkyMjQzB3VuaTIyMTkHdW5pMjI1NAd1bmkyMjAxCWNvbmdydWVudAd1bmkyMjEwB3VuaTIzQUEHdW5pMjJDRQd1bmkyMjIzB3VuaTIyMTUHdW5pMjIzOAd1bmkyMkQwB3VuaTIyRjEHZWxlbWVudAd1bmkyMkVFB3VuaTIyMEULZXF1aXZhbGVuY2UHdW5pMjIzOQtleGlzdGVudGlhbAd1bmkyMjczB3VuaTIzQTkHdW5pMjNBOAd1bmkyM0E3B3VuaTIzQTIHdW5pMjNBMwd1bmkyM0ExB3VuaTIyNzIHdW5pMjJFRgd1bmkyMkI4B3VuaTIyOEUHdW5pMkEwMAd1bmkyQTA2B3VuaTIyNDcHdW5pMjI4OAd1bmkyMjQ5B3VuaTIyMEMKbm90ZWxlbWVudAd1bmkyMjZGB3VuaTIyNzEHdW5pMjI2Mgd1bmkyMjZFB3VuaTIyNzAJbm90c3Vic2V0B3VuaTIyODUIZW1wdHlzZXQKbG9naWNhbGFuZAlsb2dpY2Fsb3IMaW50ZXJzZWN0aW9uBXVuaW9uB3VuaTAwQjUHdW5pMjIyNQd1bmkyMzlDB3VuaTIzOUQHdW5pMjM5Qgd1bmkyMzlGB3VuaTIzQTAHdW5pMjM5RQd1bmkyMDdBB3VuaTIyN0EHdW5pMjI3Qwd1bmkyMjM3B3VuaTIyNUYHdW5pMjIzNgxyZWZsZXhzdWJzZXQOcmVmbGV4c3VwZXJzZXQHdW5pMjkxNgd1bmkyM0FEB3VuaTIzQUMHdW5pMjNBQgd1bmkyM0E1B3VuaTIzQTYHdW5pMjNBNAd1bmkyMkEyB3VuaTIyNTcHdW5pMjIxOAdzaW1pbGFyB3VuaTIyOTMHdW5pMjI5NAd1bmkyMjkxB3VuaTIyQzYMcHJvcGVyc3Vic2V0CHN1Y2h0aGF0B3VuaTIxNDAOcHJvcGVyc3VwZXJzZXQHdW5pMjJBNAd1bmkyMjRCCXVuaXZlcnNhbAd1bmkyMkYwB3VuaTIyQTUHdW5pMjI5Qgd1bmkyMjk2DmNpcmNsZW11bHRpcGx5B3VuaTIyOTkKY2lyY2xlcGx1cwdhcnJvd3VwB3VuaTIxOTcKYXJyb3dyaWdodAd1bmkyMTk4CWFycm93ZG93bgd1bmkyMTk5CWFycm93bGVmdAd1bmkyMTk2CWFycm93Ym90aAlhcnJvd3VwZG4HdW5pMjFBRAd1bmkyMTlFB3VuaTIxQTAHdW5pMjFBMwd1bmkyMUE1B3VuaTIxQTYHdW5pMjFBNwd1bmkyMUM5CmFycm93ZGJsdXANYXJyb3dkYmxyaWdodAxhcnJvd2RibGRvd24MYXJyb3dkYmxib3RoB3VuaTIxRTcHdW5pMjFFOAd1bmkyMzA0B3VuaTI3OUMHdW5pMjdGNQd1bmkyN0Y2B3VuaTI3RjcHdW5pMjU4MQd1bmkyNTgyB3VuaTI1ODMHZG5ibG9jawd1bmkyNTg1B3VuaTI1ODYHdW5pMjU4NwVibG9jawd1cGJsb2NrB3VuaTI1OTQHdW5pMjU4Rgd1bmkyNThFB3VuaTI1OEQHbGZibG9jawd1bmkyNThCB3VuaTI1OEEHdW5pMjU4OQdydGJsb2NrB3VuaTI1OTUHdW5pMjU5Ngd1bmkyNTk3B3VuaTI1OTgHdW5pMjU5OQd1bmkyNTlBB3VuaTI1OUIHdW5pMjU5Qwd1bmkyNTlEB3VuaTI1OUUHdW5pMjU5RgdsdHNoYWRlBXNoYWRlB2Rrc2hhZGUHdW5pMjVDRgd1bmkyNUVGB3VuaTI1RDQHdW5pMjVENQd1bmkyNUNDB3VuaTI1Q0UKb3BlbmJ1bGxldAd1bmkyNUM2B3VuaTI1QzcJZmlsbGVkYm94B3VuaTI1QTEHdW5pMjVBQQd1bmkyNUFCB3VuaTI1RTcHdW5pMjVFOAd1bmkyNUU5B3VuaTI1RUEHdW5pMjVFQgd0cmlhZ3VwB3VuaTI1QjYHdHJpYWdkbgd1bmkyNUMwB3VuaTI1QjMHdW5pMjVCNwd1bmkyNUJEB3VuaTI1QzEHdHJpYWdydAd0cmlhZ2xmB3VuaTI1QkIHdW5pMjVDNQd1bmkyNUI0B3VuaTI1QjgHdW5pMjVCRQd1bmkyNUMyB3VuaTI1QjUHdW5pMjVCOQd1bmkyNUJGB3VuaTI1QzMHdW5pMjU2Ngd1bmkyNTU3B3VuaTI1NTQHdW5pMjU1MAd1bmkyNTY5B3VuaTI1NUQHdW5pMjU1QQd1bmkyNTUxB3VuaTI1NkMHdW5pMjU2Mwd1bmkyNTYwB3VuaTI1NjUHdW5pMjU1Ngd1bmkyNTUzB3VuaTI1MzAHdW5pMjUxMgd1bmkyNTI3B3VuaTI1MEUHdW5pMjUxRgd1bmkyNTQxB3VuaTI1MkYHdW5pMjUxMQd1bmkyNTI5B3VuaTI1MEQHdW5pMjUyMQd1bmkyNTQ3B3VuaTI1NjQHdW5pMjU1NQd1bmkyNTUyB3VuaTI1NEQHdW5pMjU0Rgd1bmkyNTdCB3VuaTI1MzMHdW5pMjUxMwd1bmkyNTBGB3VuaTI1MDEHdW5pMjU3OAd1bmkyNTdFB3VuaTI1MDkHdW5pMjUwQgd1bmkyNTdBB3VuaTI1MDUHdW5pMjUwNwd1bmkyNTc5B3VuaTI1M0IHdW5pMjUxQgd1bmkyNTdGB3VuaTI1MTcHdW5pMjUwMwd1bmkyNTRCB3VuaTI1MkIHdW5pMjUyMwd1bmkyNTQ1B3VuaTI1MkQHdW5pMjUzNQd1bmkyNTNEB3VuaTI1MzIHdW5pMjUzQQd1bmkyNTRBB3VuaTI1NDMHdW5pMjU2RQd1bmkyNTZEB3VuaTI1NkYHdW5pMjU3MAd1bmkyNTczB3VuaTI1NzIHdW5pMjU3MQd1bmkyNTRDB3VuaTI1NEUHdW5pMjU3Nwd1bmkyNTJDB3VuaTI1MTAHdW5pMjUwQwd1bmkyNTAwB3VuaTI1NzQHdW5pMjU3Qwd1bmkyNTA4B3VuaTI1MEEHdW5pMjU3Ngd1bmkyNTA0B3VuaTI1MDYHdW5pMjU3NQd1bmkyNTdEB3VuaTI1MzQHdW5pMjUxOAd1bmkyNTE0B3VuaTI1MDIHdW5pMjUzQwd1bmkyNTI0B3VuaTI1MUMHdW5pMjU0Ngd1bmkyNTJFB3VuaTI1MzYHdW5pMjUzRQd1bmkyNTMxB3VuaTI1MzkHdW5pMjU0OQd1bmkyNTQ0B3VuaTI1NjgHdW5pMjU1Qwd1bmkyNTU5B3VuaTI1NDAHdW5pMjUzOAd1bmkyNTI2B3VuaTI1MUEHdW5pMjUxRQd1bmkyNTE2B3VuaTI1NDgHdW5pMjUzNwd1bmkyNTJBB3VuaTI1MTkHdW5pMjUyMgd1bmkyNTE1B3VuaTI1NjcHdW5pMjU1Qgd1bmkyNTU4B3VuaTI1NkIHdW5pMjU2Mgd1bmkyNTVGB3VuaTI1NDIHdW5pMjUyOAd1bmkyNTIwB3VuaTI1M0YHdW5pMjUyNQd1bmkyNTFEB3VuaTI1NkEHdW5pMjU2MQd1bmkyNTVFB3VuaTIzNzMHdW5pMjM3NAd1bmkyMzY4B3VuaTI2QTAHdW5pMjZBMQd1bmkyNzEzB3VuaTI3MTUHdW5pMjcxNwd1bmkyNzM2EmFja25vd2xlZGdlY29udHJvbBBiYWNrc3BhY2Vjb250cm9sBm1pbnV0ZQZzZWNvbmQHdW5pMjExMwd1bmkyMTE2CWVzdGltYXRlZAtiZWxsY29udHJvbA1jYW5jZWxjb250cm9sFWNhcnJpYWdlUmV0dXJuY29udHJvbAd1bmkyMzAzFWRhdGFMaW5rRXNjYXBlY29udHJvbA1kZWxldGVjb250cm9sGGRldmljZUNvbnRyb2xGb3VyY29udHJvbBdkZXZpY2VDb250cm9sT25lY29udHJvbBlkZXZpY2VDb250cm9sVGhyZWVjb250cm9sF2RldmljZUNvbnRyb2xUd29jb250cm9sEmVuZE9mTWVkaXVtY29udHJvbBBlbmRPZlRleHRjb250cm9sGGVuZE9mVHJhbnNtaXNzaW9uY29udHJvbB1lbmRPZlRyYW5zbWlzc2lvbkJsb2NrY29udHJvbA5lbnF1aXJ5Y29udHJvbA1lc2NhcGVjb250cm9sFGZpbGVTZXBhcmF0b3Jjb250cm9sD2Zvcm1GZWVkY29udHJvbBVncm91cFNlcGFyYXRvcmNvbnRyb2wbaG9yaXpvbnRhbFRhYnVsYXRpb25jb250cm9sBWhvdXNlB3VuaTIzMjUHdW5pMjMxOA9saW5lRmVlZGNvbnRyb2wabmVnYXRpdmVBY2tub3dsZWRnZWNvbnRyb2wObmV3bGluZWNvbnRyb2wLbnVsbGNvbnRyb2wHdW5pMjNGQgd1bmkyM0ZDB3VuaTJCNTgHdW5pMjNGRAd1bmkyM0ZFB3VuaTIzMDUWcmVjb3JkU2VwYXJhdG9yY29udHJvbAtyZXBsYWNlbWVudA5zaGlmdEluY29udHJvbA9zaGlmdE91dGNvbnRyb2wMc3BhY2Vjb250cm9sFXN0YXJ0T2ZIZWFkaW5nY29udHJvbBJzdGFydE9mVGV4dGNvbnRyb2wRc3Vic3RpdHV0ZWNvbnRyb2wWc3luY2hyb25vdXNJZGxlY29udHJvbAd1bmkyMThCB3VuaTIxOEEUdW5pdFNlcGFyYXRvcmNvbnRyb2wZdmVydGljYWxUYWJ1bGF0aW9uY29udHJvbAd1bmkwMkYzB3VuaTAyRjcSYXRfdW5kZXJzY29yZS5saWdhGGFtcGVyc2FuZF9hbXBlcnNhbmQubGlnYSJhbXBlcnNhbmRfYW1wZXJzYW5kX2FtcGVyc2FuZC5saWdhFGFtcGVyc2FuZF9lcXVhbC5saWdhD2Jhcl9oeXBoZW4ubGlnYRdiYXJfaHlwaGVuX2dyZWF0ZXIubGlnYRNiYXJfYnJhY2VyaWdodC5saWdhFWJhcl9icmFja2V0cmlnaHQubGlnYQxiYXJfYmFyLmxpZ2ETYmFyX2Jhcl9oeXBoZW4ubGlnYRBiYXJfYmFyX2Jhci5saWdhGGJhcl9iYXJfYmFyX2dyZWF0ZXIubGlnYRJiYXJfYmFyX2VxdWFsLmxpZ2EUYmFyX2Jhcl9ncmVhdGVyLmxpZ2EOYmFyX2VxdWFsLmxpZ2EWYmFyX2VxdWFsX2dyZWF0ZXIubGlnYRBiYXJfZ3JlYXRlci5saWdhE2RvbGxhcl9ncmVhdGVyLmxpZ2EOcGx1c19wbHVzLmxpZ2ETcGx1c19wbHVzX3BsdXMubGlnYRFwbHVzX2dyZWF0ZXIubGlnYRBlcXVhbF9jb2xvbi5saWdhFmVxdWFsX2NvbG9uX2VxdWFsLmxpZ2EXZXF1YWxfZXhjbGFtX2VxdWFsLmxpZ2EQZXF1YWxfZXF1YWwubGlnYRZlcXVhbF9lcXVhbF9lcXVhbC5saWdhGGVxdWFsX2VxdWFsX2dyZWF0ZXIubGlnYRJlcXVhbF9ncmVhdGVyLmxpZ2EaZXF1YWxfZ3JlYXRlcl9ncmVhdGVyLmxpZ2EUZXF1YWxfbGVzc19sZXNzLmxpZ2EWZXF1YWxfc2xhc2hfZXF1YWwubGlnYRNncmVhdGVyX2h5cGhlbi5saWdhG2dyZWF0ZXJfaHlwaGVuX2dyZWF0ZXIubGlnYRlncmVhdGVyX2JyYWNrZXRyaWdodC5saWdhEmdyZWF0ZXJfY29sb24ubGlnYRJncmVhdGVyX2VxdWFsLmxpZ2EaZ3JlYXRlcl9lcXVhbF9ncmVhdGVyLmxpZ2EUZ3JlYXRlcl9ncmVhdGVyLmxpZ2EbZ3JlYXRlcl9ncmVhdGVyX2h5cGhlbi5saWdhGmdyZWF0ZXJfZ3JlYXRlcl9lcXVhbC5saWdhHGdyZWF0ZXJfZ3JlYXRlcl9ncmVhdGVyLmxpZ2EQbGVzc19oeXBoZW4ubGlnYRdsZXNzX2h5cGhlbl9oeXBoZW4ubGlnYRRsZXNzX2h5cGhlbl9iYXIubGlnYRhsZXNzX2h5cGhlbl9ncmVhdGVyLmxpZ2EVbGVzc19oeXBoZW5fbGVzcy5saWdhD2xlc3NfY29sb24ubGlnYRRsZXNzX2NvbG9uX2xlc3MubGlnYR5sZXNzX2V4Y2xhbV9oeXBoZW5faHlwaGVuLmxpZ2ESbGVzc19hc3Rlcmlzay5saWdhGmxlc3NfYXN0ZXJpc2tfZ3JlYXRlci5saWdhDWxlc3NfYmFyLmxpZ2ERbGVzc19iYXJfYmFyLmxpZ2EVbGVzc19iYXJfYmFyX2Jhci5saWdhFWxlc3NfYmFyX2dyZWF0ZXIubGlnYRBsZXNzX2RvbGxhci5saWdhGGxlc3NfZG9sbGFyX2dyZWF0ZXIubGlnYSJsZXNzX251bWJlcnNpZ25faHlwaGVuX2h5cGhlbi5saWdhDmxlc3NfcGx1cy5saWdhFmxlc3NfcGx1c19ncmVhdGVyLmxpZ2EPbGVzc19lcXVhbC5saWdhE2xlc3NfZXF1YWxfYmFyLmxpZ2EVbGVzc19lcXVhbF9lcXVhbC5saWdhHWxlc3NfZXF1YWxfZXF1YWxfZ3JlYXRlci5saWdhF2xlc3NfZXF1YWxfZ3JlYXRlci5saWdhFGxlc3NfZXF1YWxfbGVzcy5saWdhEWxlc3NfZ3JlYXRlci5saWdhDmxlc3NfbGVzcy5saWdhFWxlc3NfbGVzc19oeXBoZW4ubGlnYRRsZXNzX2xlc3NfZXF1YWwubGlnYRNsZXNzX2xlc3NfbGVzcy5saWdhGWxlc3NfbGVzc19hc2NpaXRpbGRlLmxpZ2EUbGVzc19hc2NpaXRpbGRlLmxpZ2EcbGVzc19hc2NpaXRpbGRlX2dyZWF0ZXIubGlnYR9sZXNzX2FzY2lpdGlsZGVfYXNjaWl0aWxkZS5saWdhD2xlc3Nfc2xhc2gubGlnYRdsZXNzX3NsYXNoX2dyZWF0ZXIubGlnYRZhc2NpaXRpbGRlX2h5cGhlbi5saWdhEmFzY2lpdGlsZGVfYXQubGlnYRdhc2NpaXRpbGRlX2dyZWF0ZXIubGlnYRphc2NpaXRpbGRlX2FzY2lpdGlsZGUubGlnYSJhc2NpaXRpbGRlX2FzY2lpdGlsZGVfZ3JlYXRlci5saWdhFmFzY2lpY2lyY3VtX2VxdWFsLmxpZ2EHdW5pMjY2RAd1bmkyNjZGB3VuaTAzNzQHdW5pMDM3NQd1bmkwMkJDB3VuaTAyQkEHdW5pMDJDOQd1bmkwMkI5B3VuaTAzMDgHdW5pMDMwNwlncmF2ZWNvbWIJYWN1dGVjb21iB3VuaTAzMEILdW5pMDMwQy5hbHQHdW5pMDMwMgd1bmkwMzBDB3VuaTAzMDYHdW5pMDMwQQl0aWxkZWNvbWIHdW5pMDMwNA1ob29rYWJvdmVjb21iB3VuaTAzMEYHdW5pMDMxMgd1bmkwMzFCDGRvdGJlbG93Y29tYgd1bmkwMzI1B3VuaTAzMjYHdW5pMDMyNwd1bmkwMzI4B3VuaTAzMzYHdW5pMDMzNwd1bmkwMzM4C3VuaTAzMjYuYWx0DHVuaTAzMDguY2FzZQx1bmkwMzA3LmNhc2UOZ3JhdmVjb21iLmNhc2UOYWN1dGVjb21iLmNhc2UMdW5pMDMwQi5jYXNlDHVuaTAzMDIuY2FzZQx1bmkwMzBDLmNhc2UMdW5pMDMwNi5jYXNlDHVuaTAzMEEuY2FzZQ50aWxkZWNvbWIuY2FzZQx1bmkwMzA0LmNhc2USaG9va2Fib3ZlY29tYi5jYXNlDHVuaTAzMEYuY2FzZQx1bmkwMzExLmNhc2UMdW5pMDMxMi5jYXNlDHVuaTAzMUIuY2FzZRFkb3RiZWxvd2NvbWIuY2FzZQx1bmkwMzI0LmNhc2UMdW5pMDMyNi5jYXNlDHVuaTAzMjcuY2FzZQx1bmkwMzI4LmNhc2UMdW5pMDMyRS5jYXNlDHVuaTAzMzEuY2FzZQ1kaWVyZXNpcy5jYXNlDmRvdGFjY2VudC5jYXNlCmdyYXZlLmNhc2UKYWN1dGUuY2FzZRFodW5nYXJ1bWxhdXQuY2FzZQ9jaXJjdW1mbGV4LmNhc2UKY2Fyb24uY2FzZQpicmV2ZS5jYXNlCXJpbmcuY2FzZQp0aWxkZS5jYXNlC21hY3Jvbi5jYXNlBXRvbm9zCnRvbm9zLmNhc2UNZGllcmVzaXN0b25vcwticmV2ZWNvbWJjeQt1bmkwMzA2MDMwMQt1bmkwMzA2MDMwMAt1bmkwMzA2MDMwOQt1bmkwMzA2MDMwMwt1bmkwMzAyMDMwMQt1bmkwMzAyMDMwMAt1bmkwMzAyMDMwOQt1bmkwMzAyMDMwMxB1bmkwMzA2MDMwMS5jYXNlEHVuaTAzMDYwMzAwLmNhc2UQdW5pMDMwNjAzMDkuY2FzZRB1bmkwMzA2MDMwMy5jYXNlEHVuaTAzMDIwMzAxLmNhc2UQdW5pMDMwMjAzMDAuY2FzZRB1bmkwMzAyMDMwOS5jYXNlEHVuaTAzMDIwMzAzLmNhc2UHdW5pRTBBMAd1bmlFMEExB3VuaUUwQTIHdW5pRTBCMAd1bmlFMEIxB3VuaUUwQjIHdW5pRTBCMwROVUxMA1NQQwAAAAEAAf//AA8AAQADABIAAAAAAAABtAAAAfAAAgBFAAEANQABADcAXQABAF8AeAABAHoAegABAHwAhgABAIkA1QABANkA6gABAOwA9AABAPYBDAABAQ4BFwABARkBMwABATUBQQABAUQBdAABAXgBeAABAXoBfAABAX8BgAABAYMBhgABAYgBigABAYwBkAABAZIBkgABAZ0BnQABAaABogABAacBqwABAbABsAABAbMBtAAB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AAAZFBj4AAAX2AAAGRQY+AAAEtIAABkUGPgAABLSAAAZFBj4AAAS0gAAGRQY+AAAEsgAABkUGPgAABLSAAAS/Bj4AAAS2AAAGRQY+AAAEuIAABkUGPgAABLsAAAZFBj4AAAX6AAAGRQY+AAAEvIAABkUGPgAABjyAAAS/Bj4AAATBgAAGRQY+AAAExAAABkUGPgAABMaAAAZFBj4AAAY8gAAGRQY+AAAEyQAABkUGPgAABmKAAAZkAAAAAATSAAAE3IAAAAAEy4AABNyAAAAABM+AAATcgAAAAATPgAAE3IAAAAAEz4AABNyAAAAABNIAAATUgAAAAATYgAAE3IAAAAAGYoAABmQAAAZDhmKAAAZkAAAGQ4YAgAAGZAAABkOGYoAABmQGRQAABfyAAAZkBkUAAAYAgAAGZAZFAAAGAIAABmQGRQAABkaAAAZkBkUAAAUdgAAGZAZFAAAGYoAABciGRQAABROAAAZkBkUAAAUWAAAGZAZFAAAFGIAABmQGRQAABmKAAAZkBkUAAAUbAAAGZAZFAAAGAgAABmQAAAAABN8AAAZkAAAAAAZigAAGZAAAAAAGYoAABbUAAAAABOcAAATrAAAGQ4TggAAE6wAABkOE5wAABOsAAAZDhOcAAATkgAAGQ4TnAAAE6wAABkOE7IAABPCAAATzBmKAAAZkAAAAAAZigAAGZAAAAAAF/IAABmQAAAAABgCAAAZkAAAAAAZigAAFtQAAAAAFGwAABmQAAAAABmKGQgZkBlUGQ4X8hkIGZAZVBkOGAIZCBmQGVQZDhgCGQgZkBlUGQ4T3BkIGZAZVBkOGAIZCBciGVQZDhPmGQgZkBlUGQ4T8BkIGZAZVBkOE/oZCBmQGVQZDhkaGQgZkBlUGQ4ZihkIFyIZVBkOFE4ZCBmQGVQZDhRYGQgZkBlUGQ4UChkIGZAZVBkOFAAZCBmQGVQZDhQKGQgXIhlUGQ4UEBkIGZAZVBkOFBoZCBmQGVQZDhQkGQgZkBlUGQ4ULhkIGZAZVBkOFGIZCBmQGVQZDhmKGQgAAAAAAAAZihjyGZAAAAAAF/IY8hmQAAAAABRsGQgZkBlUGQ4ZigAAGZAAAAAAGYoAABmQAAAAABmKAAAZkAAAAAAX8gAAGZAAAAAAGAIAABmQAAAAABmKAAAW1AAAAAAZigAAGZAAAAAAF/IAABmQAAAAABgCAAAZkAAAAAAZigAAGZAAAAAAGAIAABmQAAAAABmKAAAW1AAAAAAZigAAGZAAABkOGYoAABmQAAAZDhgCAAAZkAAAGQ4ZigAAGZAAABkOGYoAABbUAAAZDhmKFD4ZkBlUAAAX8hQ+GZAZVAAAGAIUPhmQGVQAABgCFD4ZkBlUAAAZGhQ+GZAZVAAAGYoUPhciGVQAABROFD4ZkBlUAAAUWBQ+GZAZVAAAGYoUPhmQGVQAABfyFD4ZkBlUAAAZihQ+FyIZVAAAFE4UPhmQGVQAABRYFD4ZkBlUAAAUbBQ+GZAZVAAAFC4UPhmQGVQAABRiFD4ZkBlUAAAZihQ+AAAAAAAAFDQUPhmQGVQAABRsFD4ZkBlUAAAZigAAGZAAAAAAGYoAABmQAAAAABfyAAAZkAAAAAAYAgAAGZAAAAAAGRoAABmQAAAAABROAAAZkAAAAAAZigAAGZAAAAAAGYoAABmQAAAAABfyAAAZkAAAAAAYAgAAGZAAAAAAGRoAABmQAAAAABmKAAAXIgAAAAAUTgAAGZAAAAAAFFgAABmQAAAAABRiAAAZkAAAAAAUbAAAGZAAAAAAGYoAABmQAAAZDhfyAAAZkAAAGQ4YAgAAGZAAABkOFHYAABmQAAAZDhlqAAAYXBhiAAAWEAAAGFwYYgAAFiQAABhcGGIAABSAAAAYXBhiAAAWJAAAFNAYYgAAFIAAABhcGGIAABSKAAAYXBhiAAAUlAAAGFwYYgAAFiQAABhcGGIAABYkAAAYXBhiAAAUngAAGFwYYgAAFiQAABTQGGIAABSoAAAYXBhiAAAUsgAAGFwYYgAAFLwAABhcGGIAABTGAAAYXBhiAAAZagAAFNAYYgAAFNoAABhcGGIAABTkAAAYXBhiAAAU7gAAGFwYYgAAGWoAABhcGGIAABT4AAAYXBhiAAAWKgAAGFwYYgAAGZYAAAAAAAAAABiCAAAAAAAAAAAZigAAGZAAAAAAGXAAABl6AAAAABUCAAAZegAAAAAVEgAAGXoAAAAAGXAAABl6AAAAABUSAAAZegAAAAAVHAAAGXoAAAAAGYoAABmQAAAZZBmWAAAZkBlUAAAYggAAGZAZVAAAGJIAABmQGVQAABiSAAAZkBlUAAAYkgAAGZAZVAAAFjQAABmQGVQAABiSAAAXIhlUAAAWPgAAGZAZVAAAFkgAABmQGVQAABZSAAAZkBlUAAAZKgAAGZAZVAAAGSoAABmQGVQAABmWAAAXIhlUAAAXsAAAGZAZVAAAF7oAABmQGVQAABfEAAAZkBlUAAAZlgAAAAAAAAAAF84AABmQGVQAABmKAAAZkAAAAAAVJgAAGMgAAAAAFSwAABjIAAAAABU2AAAYyAAAAAAVNgAAGMgAAAAAFTYAABjIAAAAABU8AAAYyAAAAAAVRgAAGMgAAAAAGYoAABmQAAAZDhVQAAAZkAAAGQ4YmAAAGZAYsgAAFWAAABiiGLIAABVqAAAYohiyAAAVegAAGKIYsgAAFXoAABiiGLIAABV6AAAYohiyAAAYmAAAGKIYsgAAGJgAABiiGLIAABiYAAAVhBiyAAAVjgAAGKIYsgAAFZ4AABiiGLIAABWuAAAYohiyAAAYmAAAGKIYsgAAFbgAABiiGLIAABi4AAAYyAAAAAAVwgAAGMgAAAAAFcwAABjIAAAAABmKAAAZkAAAAAAZigAAFtQAAAAAGZYAAAAAAAAAABYAAAAZFAAAGQ4V1gAAGRQAABkOFgAAABkUAAAZDhYAAAAV5gAAGQ4V8AAAGZAAABX6FgAAABkUAAAZDhmWAAAZkAAAAAAZagAAGZAAAAAAFhAAABmQAAAAABlqAAAWGgAAAAAWJAAAGZAAAAAAGWoAABbUAAAAABYqAAAZkAAAAAAZlhlEGZAZVBlkGIIZRBmQGVQZZBiSGUQZkBlUGWQYkhlEGZAZVBlkGJIZRBmQGVQZZBY0GUQZkBlUGWQYkhlEFyIZVBlkFj4ZRBmQGVQZZBZIGUQZkBlUGWQWUhlEGZAZVBlkGSoZRBmQGVQZZBmWGUQXIhlUGWQXsBlEGZAZVBlkF7oZRBmQGVQZZBZmGUQZkBlUGWQWXBlEGZAZVBlkFmYZRBciGVQZZBZsGUQZkBlUGWQWdhlEGZAZVBlkFoAZRBmQGVQZZBeQGUQZkBlUGWQXxBlEGZAZVBlkGZYZRAAAAAAAABmWGUQZkAAAAAAYghlEGZAAAAAAF84ZRBmQGVQZZBmWAAAZkAAAAAAWigAAFpQAAAAAGZYAABmQAAAAABa+AAAWtAAAAAAWpAAAFrQAAAAAFq4AABa0AAAAABa+AAAWxAAAAAAZlgAAGZAAAAAAGIIAABmQAAAAABiSAAAZkAAAAAAZlgAAGZAAAAAAGJIAABmQAAAAABmW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AAMAAkLAQsAAATy4AAAAAQAAADYAAwABQqwAATykAAE8pAABAAAANwADAAAAATyQAAI8kDyQAAEAAAA4AAEAAAABAAgAATx0AFMAAQAAAAEACAABPGYC6QAGAAAABAAOAB4ALgBAAAMAATrmAAE65gABOuYAAAADAAAAATrWAAI61jrWAAAAAwABQjoAATrGAAAAAQAAADoAAwAAAAE6tAABOrQAAQAAADsAAQAAAAEACAABOpoBiwAGAAAABQAQACIANABIAFwAAwABOoQAATqEAAI6hDqEAAAAAwAAAAE6cgADOnI6cjpyAAAAAwACQdRB1AABOmAAAAABAAAAPQADAAFBwAABOkwAATpMAAEAAAA+AAMAAAABOjgAAjo4OjgAAQAAAD8AAQAAAAEACAABOhwBjAABAAAAAQAIAAE6DgI4AAYAAAAEAA4AHgAuAEAAAwABJxQAAScUAAE+oAAAAAMAAAABJwQAAj6QPpAAAAADAAFBTgABPoAAAAABAAAAQQADAAAAASbiAAE+bgABAAAAQQABAAAAAQAIAAIk/gACBU4CpAAGAAAABQAQACAAMABAAFIAAwABJq4AASauAAEmrgAAAAMAAAABJp4AAiaeJp4AAAADAAAAASaOAAImjjvgAAAAAwABQNgAASZ+AAAAAQAAAEMAAwAAAAEmbAABJmwAAQAAAEQAAQAAAAEACAABJlIARwAGAAAABQAQACIANABIAFwAAwABJjwAASY8AAImPCY8AAAAAwAAAAEmKgADJiomKiYqAAAAAwACQHJAcgABJhgAAAABAAAARgADAAFAXgABJgQAASYEAAEAAABHAAMAAAABJfAAAiXwJfAAAQAAAEgAAQAAAAEACAABJdQASAAGAAAABQAQACIANABIAFwAAwABJb4AASW+AAIlvjsQAAAAAwAAAAElrAADJaw6/jr+AAAAAwACP/Q/9AABOuwAAAABAAAASgADAAE/4AABJYYAATrYAAEAAABKAAMAAAABJXIAAiVyOsQAAQAAAEsAAQAAAAEACAACAAoAAgVOAqMAAQACAloDHQABAAAAAQAIAAElPAL0AAYAAAAHABQAKAA+AFIAaAB+AJQAAwABOnQAATp0AAM9njRGNEYAAAADAAI8mj8EAAE6YAADPYo0MjQyAAAAAwAAAAE6SgAEPXQ0HDQcNBwAAAAD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AAAAAQAAAG0AAwACOCw4LAABKnAAASpwAAEAAABuAAMAATgWAAEqWgACKloqWgABAAAAbwADAAAAATL4AAMqRCpEKkQAAQAAAG0AAQAAAAEACAACAQYAAgVOBMQABgAAAAYAEgCkACQANgBKAF4AAwABMr4AATK+AAIqCioKAAAAAwAAAAEyrAADKfgp+DMkAAAAAwACN6I3ogABKeYAAAABAAAAcQADAAE3jgABKdIAASnSAAEAAAByAAMAAAABMnIAAim+Kb4AAQAAAHEAAQAAAAEACAACAIIAAgVOBMMABgAAAAUAEAAgADIAQgBUAAMAATI8AAEyPAABKYgAAAADAAAAATIsAAMpeCl4KXgAAAADAAAAATIaAAIpZjKSAAAAAwABNxIAASlWAAAAAQAAAHQAAwAAAAEx+AABKUQAAQAAAHQAAQAAAAEACAACAAoAAgVOBMIAAQACAx0EWAAGAAAABQAQACAAMABAAFIAAwABK44AASuOAAEpCAAAAAMAATGsAAErfgABKPgAAAADAAAAAStuAAIo6CjoAAAAAwABNpQAASjYAAAAAQAAAHYAAwAAAAErTAABKMYAAQAAAHYAAQAAAAEACAACFMQAAgVOApcABgAAAAUAEAAiADQASABcAAMAASsYAAErGAACMb4xvgAAAAMAAAABKwYAAzGsMawxrAAAAAMAAjYqNioAATGaAAAAAQAAAHgAAwABNhYAATGGAAExhgABAAAAeQADAAAAASrMAAIxcjFyAAEAAAB4AAEAAAABAAgAAiKcAAIFTgKZAAYAAAAGFWQAEgAkADYASgBeAAMAASqUAAEqlAACKpQxOgAAAAMAAAABKoIAAyqCMSgxKAAAAAMAAjWmNaYAATEWAAAAAQAAAHsAAwABNZIAASpcAAExAgABAAAAewADAAAAASpIAAIqSDDuAAEAAAB8AAEAAAABAAgAAiIYAAIFTgKWAAYAAAAIABYAJgA2AEYAVgBmAHYAiAADAAExlgABKgwAATCyAAAAAwABKfwAASn8AAEwogAAAAMAATCSAAEp7AABMJIAAAADAAEnVgABKdwAATCCAAAAAwAAAAEpzAACMHIwcgAAAAMAAS1+AAEpvAABMGIAAAADAAE04gABMFIAAAABAAAAfgADAAAAASmaAAEwQAABAAAAfgABAAAAAQAIAAIhbAACBU4CmAAGAAAACAAWACYANgBGAFYAZgB2AIgAAwABMAYAATAGAAEwBgAAAAMAAAABL/YAAi/2L/YAAAADAAAAAS/mAAIv5jN8AAAAAwAAAAEv1gACL9YpMAAAAAMAATNcAAEvxgABL8YAAAADAAEvsAABL7YAAS+2AAAAAwABNDYAAS+mAAAAAQAAAIAAAwAAAAEvlAABL5QAAQAAAIEAAQAAAAEACAABL3oBmAAGAAAABQAQACIANABIAFwAAwABL2QAAS9kAAIvZC9kAAAAAwAAAAEvUgADL1IvUi9SAAAAAwACM9Az0AABL0AAAAABAAAAgwADAAEzvAABLywAAS8sAAEAAACEAAMAAAABLxgAAi8YLxgAAQAAAIUAAQAAAAEACAABLvwBmwAGAAAABgASACIAMgBCAFIAZAADAAEu5AABLuQAATJ6AAAAAwAAAAEu1AACMmoyagAAAAMAAAABLsQAAjJaLsQAAAADAAAAAS60AAIySi48AAAAAwABMzQAATI6AAAAAQAAAIcAAwAAAAEukgABMigAAQAAAIcAAQAAAAEACAACHioAAgSyBU4ABgAAAAQADgAeAC4AQAADAAEuYAABLmAAATGEAAAAAwAAAAEuUAACMXQxdAAAAAMAATLQAAExZAAAAAEAAACJAAMAAAABLi4AATFSAAEAAACJAAEAAAABAAgAAgnYAAIEsQVOAAYAAAAJABgAKAA4AEgAWABoAHgAiACaAAMAAS3yAAEt8gABMpoAAAADAAEq/gABLeIAATKKAAAAAwABLFoAAS3SAAEyegAAAAMAASlyAAEtwgABMmoAAAADAAEtrAABLbIAATJaAAAAAwABMTgAAS2iAAEySgAAAAMAAAABLZIAAjI6MjoAAAADAAEyEgABMioAAAABAAAAiwADAAAAAS1wAAEyGAABAAAAiwABAAAAAQAIAAIACgACBLAFTgABAAICdgMcAAYAAAAHABQAJAA0AEQAVgBmAHgAAwAAAAEsuAACMMYsuAAAAAMAAAABLKgAAjC2I/QAAAADAAEsmAABLJgAATCmAAAAAwACLsIxLAABLIgAATCWAAAAAwAAAAEsdgACMIQwhAAAAAMAATFuAAEwdAAAAAEAAACNAAMAAAABLFQAATBiAAEAAACNAAEAAAABAAgAAiFAAAIEywVOAAYAAAAFABAAIgA0AEYAWgADAAAAASwgAAMsIDAuMC4AAAADAAEsDgABLA4AAiwOMBwAAAADAAExBAABMAoAAAABAAAAjwADAAEw8gABK+oAAS/4AAEAAACPAAMAAAABK9YAAivWL+QAAQAAAJAAAQAAAAEACAACIMAAAgTUBU4ABgAAAAcAFAAmADoATABeAHIAhgADAAErnAABK5wAAi+qL6oAAAADAAItxDAuAAErigACL5gvmAAAAAMAAAABK3YAAy+EL4QvhAAAAAMAAAABK2QAAy9yL3Ir3AAAAAMAAjBaMFoAAS9gAAAAAQAAAJIAAwABMEYAAS9MAAEvTAABAAAAkwADAAAAASsqAAIvOC84AAEAAACSAAEAAAABAAgAAiAUAAIEzQVOAAYAAAAFABAAIgA0AEgAXAADAAEq9AABKvQAAiJAK2wAAAADAAAAASriAAMiLitaK1oAAAADAAIv2C/YAAErSAAAAAEAAACVAAMAAS/EAAEiCAABKzQAAQAAAJUAAwAAAAEqqAACIfQrIAABAAAAlQABAAAAAQAIAAIADAADBMUFTgVOAAEAAwMcAx0EWAAGAAAABQAQACIANABIAFwAAwABLwQAAS8EAAIhsi8EAAAAAwAAAAEu8gADIaAu8i7yAAAAAwACL0ovSgABLuAAAAABAAAAlwADAAEvNgABIXoAAS7MAAEAAACXAAMAAAABLrgAAiFmLrgAAQAAAJgAAQAAAAEACAACAAoAAgLPBU4AAQACAoYEWAAGAAAABwAUACQANgBKAFoAagB8AAMAAS0CAAEtAgABLeYAAAADAAIsAi5sAAEs8gABLdYAAAADAAMptivwLloAASzgAAEtxAAAAAMAAS2wAAEszAABLbAAAAADAAAAASy8AAItoC2gAAAAAwABLooAAS2QAAAAAQAAAJoAAwAAAAEsmgABLX4AAQAAAJoAAQAAAAEACAACAeoAAgVOArEABgAAAAYAEgAiADQASABYAGoAAwABLGQAASxkAAEsZAAAAAMAAitkLc4AASxUAAEsVAAAAAMAAykYK1ItvAABLEIAASxCAAAAAwAAAAEsLgACLC4sLgAAAAMAAS38AAEsHgAAAAEAAACcAAMAAAABLAwAASwMAAEAAACdAAEAAAABAAgAASvyAFEAAQAAAAEACAABK+QC7wAGAAAABwAUACYAOgBQAGIAdgCKAAMAASvKAAErygACLK4srgAAAAMAAirILTIAASu4AAIsnCycAAAAAwADKHoqtC0eAAErpAACLIgsiAAAAAMAAAABK44AAyxyLHIscgAAAAMAAi1aLVoAASxgAAAAAQAAAJ8AAwABLUYAASxMAAEsTAABAAAAoAADAAAAAStUAAIsOCw4AAEAAACfAAEAAAABAAgAAgCiAAIFTgKyAAYAAAAGABIAJAA4AEoAXgByAAMAASwAAAEsAAACKxwsAAAAAAMAAioaLIQAASvuAAIrCivuAAAAAwAAAAEr2gADKvYr2ivaAAAAAwACLMIswgABK8gAAAABAAAAogADAAEsrgABKtAAASu0AAEAAACiAAMAAAABK6AAAiq8K6AAAQAAAKMAAQAAAAEACAACAAoAAgVOBKYAAQACAl8DGgAGAAAACgAaACoAOgBKAFoAbgCAAJAAoACyAAMAASimAAErWAABJ8IAAAADAAErSAABK0gAASeyAAAAAwABJ6IAASs4AAEnogAAAAMAAR5mAAErKAABJ5IAAAADAAMnCilEK64AASsYAAEnggAAAAMAAikwK5oAASsEAAEnbgAAAAMAAAABKvIAAidcKvIAAAADAAAAASriAAInTCdMAAAAAwABK8wAASc8AAAAAQAAAKUAAwAAAAEqwAABJyoAAQAAAKUAAQAAAAEACAACFsIAAgVOBKoABgAAAAcAFAAkADgASgBaAGoAfAADAAEqiAABKogAASqIAAAAAwADJmoopCsOAAEqeAABKngAAAADAAIokCr6AAEqZAABKmQAAAADAAAAASpSAAIqUipSAAAAAwAAAAEqQgACKkImrAAAAAMAASssAAEqMgAAAAEAAACnAAMAAAABKiAAASogAAEAAACoAAEAAAABAAgAASoGAY0ABgAAAAgAFgAoADwATgBgAHIAhgCaAAMAASnqAAEp6gACKeop6gAAAAMAAigEKm4AASnYAAIp2CnYAAAAAwABJbYAASnEAAIpxCnEAAAAAwAAAAEpsgADKbIpsimyAAAAAwAAAAEpoAADKaApoCYKAAAAAwACKogqiAABKY4AAAABAAAAqgADAAEqdAABKXoAASl6AAEAAACrAAMAAAABKWYAAilmKWYAAQAAAKwAAQAAAAEACAABKUoBjgAGAAAABgASACQAOABKAF4AcgADAAEpMgABKTIAAijAKTIAAAADAAInTCm2AAEpIAACKK4pIAAAAAMAAAABKQwAAyiaKQwpDAAAAAMAAin0KfQAASj6AAAAAQAAAK4AAwABKeAAASh0AAEo5gABAAAArgADAAAAASjSAAIoYCjSAAEAAACvAAEAAAABAAgAAgTSAAIFTgSlAAYAAAAFABAAIAAwAEAAUgADAAEonAABKCoAASicAAAAAwABKBoAASgaAAEojAAAAAMAAAABKAoAAih8KHwAAAADAAEpZgABKGwAAAABAAAAsQADAAAAASfoAAEoWgABAAAAsQABAAAAAQAIAAIEXAACBU4CqwAGAAAABAAOAB4ALgBAAAMAASe2AAEntgABJJIAAAADAAAAASemAAIkgiSCAAAAAwABKQIAASRyAAAAAQAAALMAAwAAAAEnhAABJGAAAQAAALMAAQAAAAEACAACAAoAAgVOAqwAAQACAlwDHAAGAAAABQAQACAAMABAAFIAAwABJ0gAASdIAAEjrAAAAAMAASOcAAEnOAABI5wAAAADAAAAAScoAAIjjCOMAAAAAwABKIQAASN8AAAAAQAAALUAAwAAAAEnBgABI2oAAQAAALUAAQAAAAEACAACAAoAAgVOAq0AAQACAlwDHQAGAAAABQAQACAAMABAAFIAAwABJsoAASbKAAEmygAAAAMAAAABJroAAia6JroAAAADAAAAASaqAAImqiccAAAAAwABKAYAASaaAAAAAQAAALcAAwAAAAEmiAABJogAAQAAALgAAQAAAAEACAABJm4ASgAGAAAABAAOAB4ALgBAAAMAAQDeAAEA3gABAN4AAAADAAAAAQDOAAIAzgDOAAAAAwABJ6YAAQC+AAAAAQAAALoAAwAAAAEArAABAKwAAQAAALsAAQAAAAEACAABAJIAUQAGAAAABQAQACIANABIAFwAAwABAHwAAQB8AAIAfAB8AAAAAwAAAAEAagADAGoAagBqAAAAAwACJ0AnQAABAFgAAAABAAAAvQADAAEnLAABAEQAAQBEAAEAAAC+AAMAAAABADAAAgAwADAAAQAAAL8AAQAAAAEACAABABQAUgABAAAAAQAIAAEABgLxAAEAAQJdAAYAAAAFABAAIgA0AEgAXAADAAElZgABJWYAAiVmJWYAAAADAAAAASVUAAMlVCVUJVQAAAADAAImriauAAElQgAAAAEAAADBAAMAASaaAAElLgABJS4AAQAAAMIAAwAAAAElGgACJRolGgABAAAAwwABAAAAAQAIAAEk/gBLAAYAAAAFABAAIAAwAEAAUgADAAEk6AABJOgAASOGAAAAAwAAAAEk2AACI3YjdgAAAAMAAAABJMgAAiNmIaQAAAADAAEmJAABI1YAAAABAAAAxQADAAAAASSmAAEjRAABAAAAxQABAAAAAQAIAAIIkAACBU4CqQAGAAAABQAQACIANABIAFwAAwABJHIAASRyAAIjECFOAAAAAwAAAAEkYAADIv4hPCE8AAAAAwACJbolugABISoAAAABAAAAxwADAAElpgABItgAASEWAAEAAADHAAMAAAABJCYAAiLEIQIAAQAAAMcAAQAAAAEACAACAAwAAwVOBU4CqgABAAMCXAJhAxwABgAAAAUAEAAiADQASABcAAMAASPkAAEj5AACI+QkVgAAAAMAAAABI9IAAyPSJEQkRAAAAAMAAiUsJSwAASQyAAAAAQAAAMkAAwABJRgAASOsAAEkHgABAAAAyQADAAAAASOYAAIjmCQKAAEAAADKAAEAAAABAAgAAgAKAAIFTgKoAAEAAgJcAxoAAQAAAAEACAABI2IC8gAGAAAABgASACYAOgBQAGYAfAADAAEW+gABFvoAAxb6FvogJgAAAAMAAAABFuYABBbmFuYgEiASAAAAAwADJI4kjiSOAAEf/gAAAAEAAADMAAMAAiR4JHgAARa8AAEf6AABAAAAzAADAAEkYgABFqYAAhamH9IAAQAAAM0AAwAAAAEWkAADFpAWkB+8AAEAAADOAAEAAAABAAgAAgEEAAIEmgVOAAYAAAAGABIAJAA2AEgAXABwAAMAARZWAAEWVgACFlYfggAAAAMAAR74AAEWRAACFkQfcAAAAAMAAAABFjIAAxYyH14fXgAAAAMAAiPcI9wAAR9MAAAAAQAAANAAAwABI8gAARYMAAEfOAABAAAA0AADAAAAARX4AAIV+B8kAAEAAADRAAEAAAABAAgAAgBuAAIEnAVOAAYAAAAEAA4AHgAuAEAAAwABFcQAARXEAAEe8AAAAAMAAAABFbQAAh7gHuAAAAADAAEjYAABHtAAAAABAAAA0wADAAAAARWSAAEevgABAAAA0wABAAAAAQAIAAIACgACBJ8FTgABAAIDHARYAAYAAAAFABAAJAA2AEoAXgADAAEVVgABFVYAAxVWF9wX3AAAAAMAAAABFUIAAxVCFUIXyAAAAAMAAiLsIuwAARe2AAAAAQAAANUAAwABItgAARUcAAEXogABAAAA1QADAAAAARUIAAIVCBeOAAEAAADWAAEAAAABAAgAAgEEAAIEmAVOAAYAAAAFABAAJAA2AEoAXgADAAEU0gABFNIAAxTSIZQhlAAAAAMAAAABFL4AAxS+FL4hgAAAAAMAAiJoImgAASFuAAAAAQAAANgAAwABIlQAARSYAAEhWgABAAAA2AADAAAAARSEAAIUhCFGAAEAAADZAAEAAAABAAgAAgD+AAIEmwVOAAYAAAAFABAAIAAwAEAAUgADAAEUTgABFE4AARbUAAAAAwAAAAEUPgACFsQWxAAAAAMAAAABFC4AAha0HVoAAAADAAEh2gABFqQAAAABAAAA2wADAAAAARQMAAEWkgABAAAA2wABAAAAAQAIAAIACgACBJMFTgABAAICgQRYAAYAAAAFABAAIAAwAEAAUgADAAET0AABE9AAASCSAAAAAwAAAAETwAACIIIc7AAAAAMAAAABE7AAAiByIHIAAAADAAEhXAABIGIAAAABAAAA3QADAAAAAROOAAEgUAABAAAA3QABAAAAAQAIAAIACgACBJ0FTgABAAIDGgRYAAYAAAAGABIAIgAyAEIAUgBkAAMAARNQAAETUAABE1AAAAADAAAAARNAAAITQBNAAAAAAwABHUAAARMwAAETMAAAAAMAAAABEyAAAhMgIPQAAAADAAEgzAABExAAAAABAAAA3wADAAAAARL+AAES/gABAAAA4AABAAAAAQAIAAES5AA/AAEAAAABAAgAARLWAPYABgAAAAcAFAAmADwATABcAGwAfgADAAEczAABFUIAAhVCG+gAAAADAAQeiBteHZggAgABFTAAARUwAAAAAwABFRoAARUaAAEVGgAAAAMAARs4AAEVCgABFQoAAAADAAAAART6AAIU+hT6AAAAAwABICAAARTqAAAAAQAAAOIAAwAAAAEU2AABFNgAAQAAAOMAAQAAAAEACAABFL4AEwAGAAAABQAQACIANABIAFwAAwABGtYAARrWAAIUqBSoAAAAAwAAAAEaxAADFJYUlhSWAAAAAwACH7ofugABFIQAAAABAAAA5QADAAEfpgABFHAAARRwAAEAAADmAAMAAAABGooAAhRcFFwAAQAAAOUAAQAAAAEACAACDtQAAgS5BU4ABgAAAAYAEgAmADgASgBeAHIAAwABG64AARQkAAMUJBQkGsoAAAADAAEUEAABFBAAAhQQFBAAAAADAAAAARP+AAMT/hP+E/4AAAADAAIfIh8iAAET7AAAAAEAAADoAAMAAR8OAAET2AABE9gAAQAAAOkAAwAAAAETxAACE8QTxAABAAAA6gABAAAAAQAIAAETqAAUAAEAAAABAAgAAROaAs0ABgAAAAQADgAeAC4AQAADAAEb7gABG+4AARvuAAAAAwAAAAEb3gACG94b3gAAAAMAAR6cAAEbzgAAAAEAAADsAAMAAAABG7wAARu8AAEAAADtAAEAAAABAAgAARuiAFQABgAAAAUAEAAiADQASABcAAMAARuMAAEbjAACG4wbjAAAAAMAAAABG3oAAxt6G3obegAAAAMAAh42HjYAARtoAAAAAQAAAO8AAwABHiIAARtUAAEbVAABAAAA8AADAAAAARtAAAIbQBtAAAEAAADxAAEAAAABAAgAARskAFUAAQAAAAEACAABGxYC7QAGAAAABQAQACAAMABAAFIAAwABGwAAARsAAAEcYgAAAAMAAAABGvAAAhxSHFIAAAADAAAAARrgAAIcQhy0AAAAAwABHZ4AARwyAAAAAQAAAPMAAwAAAAEavgABHCAAAQAAAPMAAQAAAAEACAACAAoAAgK0BU4AAQACAlwCYQAGAAAACQAYACgAOABMAGAAdACIAJoArAADAAEaegABGnoAARxOAAAAAwAAAAEaagACHD4cPgAAAAMAARzEAAEaWgADHC4bvBwuAAAAAwABHLAAARpGAAMcGhs2HBoAAAADAAEcnAABGjIAAxwGF/gX+AAAAAMAARyIAAEaHgADG/IYVhvyAAAAAwABHHQAARoKAAIb3hhIAAAAAwABHMYAARvMAAAAAQAAAPUAAwAAAAEZ5gABG7oAAQAAAPUAAQAAAAEACAACAAoAAgVOArcAAQACAmEDGgAGAAAABAAOAB4ALgBAAAMAARmsAAEZrAABAiAAAAADAAAAARmcAAICEAIQAAAAAwABHFoAAQIAAAAAAQAAAPcAAwAAAAEZegABAe4AAQAAAPcAAQAAAAEACAACAAoAAgKzBU4AAQACAloCYQAGAAAABAAOAB4ALgBAAAMAAQFcAAEBXAABAVwAAAADAAAAAQFMAAIBTAFMAAAAAwABG+4AAQE8AAAAAQAAAPkAAwAAAAEBKgABASoAAQAAAPoAAQAAAAEACAABARAAQQAGAAAABQAQACAAMABAAFIAAwABAPoAAQD6AAEasgAAAAMAAAABAOoAAhqiGqIAAAADAAAAAQDaAAIakhb8AAAAAwABG3wAARqCAAAAAQAAAPwAAwAAAAEAuAABGnAAAQAAAPwAAQAAAAEACAACAAoAAgSSBU4AAQACAxoETwAGAAAABQAQACIANABIAFwAAwABAHwAAQB8AAIAfAB8AAAAAwAAAAEAagADAGoAagBqAAAAAwACGwobCgABAFgAAAABAAAA/gADAAEa9gABAEQAAQBEAAEAAAD/AAMAAAABADAAAgAwADAAAQAAAQAAAQAAAAEACAABABQAQgABAAAAAQAIAAEABgD/AAEAAQRPAAYAAAAEAA4AHgAuAEAAAwABAEQAAQBEAAEZpAAAAAMAAAABADQAAhmUGZQAAAADAAEafgABGYQAAAABAAABAgADAAAAAQASAAEZcgABAAABAgABAAECWgABAAAAAQAIAAIACgACBU4CpQABAAICWgMaAAYAAAAEAA4AHgAuAEAAAwABGcIAARnCAAEZwgAAAAMAAAABGbIAAhmyGbIAAAADAAEaDAABGaIAAAABAAABBAADAAAAARmQAAEZkAABAAABBQABAAAAAQAIAAEZdgBKAAEAAAABAAgAARloAsgABgAAAAYAEgAkADgASgBeAHIAAwABGMAAARjAAAIVJBjAAAAAAwACFtoZRAABGK4AAhUSGK4AAAADAAAAARiaAAMU/hiaGJoAAAADAAIZghmCAAEYiAAAAAEAAAEHAAMAARluAAEU2AABGHQAAQAAAQcAAwAAAAEYYAACFMQYYAABAAABCAABAAAAAQAIAAIACgACBU4ErQABAAICawMaAAYAAAAFABAAIgA0AEgAXAADAAEUFAABFBQAAg3mFBQAAAADAAAAARQCAAMN1BQCFAIAAAADAAIY+Bj4AAET8AAAAAEAAAEKAAMAARjkAAENrgABE9wAAQAAAQoAAwAAAAETyAACDZoTyAABAAABCwABAAAAAQAIAAIIEgACBU4EvAAGAAAABgASACQAOABKAF4AcgADAAETkAABE5AAAheeE5AAAAADAAIVuBgiAAETfgACF4wTfgAAAAMAAAABE2oAAxd4E2oTagAAAAMAAhhgGGAAARNYAAAAAQAAAQ0AAwABGEwAARdSAAETRAABAAABDQADAAAAARMwAAIXPhMwAAEAAAEOAAEAAAABAAgAAggaAAIFTgTQAAYAAAAHABQAKAA+AFIAZgB8AJIAAwABEvYAARL2AAMXBBcEE24AAAADAAIVHBeGAAES4gADFvAW8BNaAAAAAwAAAAESzAAEFtoW2hNEE0QAAAADAAIXwBfAAAETMAAAAAEAAAEQAAMAAhesF6wAARayAAETHAABAAABEAADAAEXlgABFpwAAhacEwYAAQAAAREAAwAAAAESeAADFoYWhhLwAAEAAAEQAAEAAAABAAgAAgAMAAMFTgTOBU4AAQADAxoDHAMdAAYAAAAIABYAKAA6AFAAZAB2AIoAngADAAETigABFjwAAhY8EqYAAAADAAEWKgABFioAAhYqEpQAAAADAAMSChREFq4AARYYAAIWGBKCAAAAAwACFC4WmAABFgIAAhYCEmwAAAADAAAAARXuAAMV7hJYElgAAAADAAIW1hbWAAESRgAAAAEAAAETAAMAARbCAAEVyAABEjIAAQAAARMAAwAAAAEVtAACFbQSHgABAAABFAABAAAAAQAIAAIBtAACBU4EqQABAAAAAQAIAAEVhgI0AAYAAAAGABIAJAA4AEoAXgByAAMAARVuAAEVbgACEdgR2AAAAAMAAhOIFfIAARVcAAIRxhHGAAAAAwAAAAEVSAADEbIRshGyAAAAAwACFjAWMAABEaAAAAABAAABFgADAAEWHAABEYwAARGMAAEAAAEXAAMAAAABFQ4AAhF4EXgAAQAAARYAAQAAAAEACAACAQ4AAgVOBKsABgAAAAUAEAAiADQASABcAAMAARFCAAERQgACFNgRQgAAAAMAAAABETAAAxTGETARMAAAAAMAAhWuFa4AAREeAAAAAQAAARkAAwABFZoAARSgAAERCgABAAABGQADAAAAARD2AAIUjBD2AAEAAAEaAAEAAAABAAgAAgCMAAIFTgSzAAYAAAAFABAAIgA0AEgAXAADAAEQwAABEMAAAhDAFFYAAAADAAAAARCuAAMQrhREFEQAAAADAAIVLBUsAAEUMgAAAAEAAAEcAAMAARUYAAEQiAAB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bMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRsxGzEbMRs52znbOds52znbPBs8GzwbPBs8GzwbPBs8GzwbPBs8GzwbPBs8Gz5bPltAm0CbQttFG0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbR1tHW0dbSZtdm1/bX9thm2dbb9t4W3hbept8250buBu92+bb9xwJHB5cJhwpnC4cMZw2HDwcUtxbXHjcetx9HH+cgdyG3Ikci1yNnI/ckhyUXJacmNybHJ1cn5yh3KQcplyonKrcqtyyHNcc2VzbnN3c4BzgHOAc4BzgHOAc6FzqnOqc7NzvHPFc85z13Pgc+lz8nP7dAR0DXQWdFN01HWddsB3N3dKd3Z303fod/J4CHgeeE14aHiTeKt45HkLeZF5s3nfehx6WnqpevF7A3sbe017f3vJfAB8MnxafJZ8oHypfNN9EX0bfUF9cX16fZ99xH3kfgV+Jn4wfjl+jn8rf+CACIA0gGSAp4EtgcqCJ4JjgrqC5IMNgzCDXoOMg7qD7oP3hBeEQYRKhPWFfoYphwqHM4d4h8KIgIkLiYGKUYp+isCK1Irkiu2K+4sNixaLJotRi22Le4uJi5uLqYu9i9GL84wWjFOMYYyJjJuMqYzHjOONEY0fjU+NfI2KjZiNpo2vjbiNwY3KjdON3I3lje6N944AjgmOEo4bjiSOT45ujnyOio6cjrCOxI7mjwmPRo9Uj3uPjY+zj8GP4I/8kCeQNZBlkJKQtJDCkMuQ1JDdkOaQ75D4kQGRCpETkRyRJZEzkUOReZGbkcWR75I2ko+Sp5K/kvWTPZNu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AAIAAACFhYWFAIACAAwAAgABAAIAAACFhYWFAIACAAwAAgABAAIAAACGhoaGAIACAAwAAgABAAIAAACFhYWFAIACAAwAAgABAAIAAACFhYWFAIACAAwAAgABAAIAAACFhYWFAIACAAwABQABAAIAAACAAAKDhYWFgAIADAACAAEAAgAAAIWFhYUAgAIADAACAAEAAgAAAIWFhYUAgAIADAACAAEAAgAAAIWFhYUAgAIADAACAAEAAgAAAIWFhYUAgAIADAACAAEAAgAAAIWFhYUAgAIADAA8AAEAPAAAABz7CRwcHCIZ8/P59vb28/L29hQU9vbt7fb27e329oMFCAj++/0FgQj/APb29fb29giCByQk7e0QENzchBzr5eLi4vj8B/IBCQkJAwAJCezsCgomJgoKJiYKCoMQ6ury+wEMAQHt9wIKERcXF+qCB9DQDg7i4jAwhACAAgAMAAIAAQACAAAAhISEhACAAgAMAAIAAQACAAAAhYWFhQCAAgAMAAwAAQAMAAAFBAECAgICBBQA7vfsgAMk8hYABOcPIw8jgAPGFtwAAIACAAwASAABAEMgAAAjAgcOEREREQ4HAv76+PggIA4C9+np6en3Ag8gICAHB/j4+Pr+g4IE+/YKBQGCAf//gRAPJCQkEwn27N3d3fIAFBTw8IEAAYQVFAEBAQEBAQEBAgECAgMCAQIFAgICART57OTk5OTs+QgVHuIOICAO4goeFQiABQUJCvb3+4EL/Pbkz/UKMu8cCgQAgAIADAAFAAEAAgAAAIAABoOFhYWAAgAMAAUAAQACAAAAgAAGg4WFhYACAAwABQABAAIAAACAAAaDhYWFgAIADAAFAAEAAgAAAIAABoOFhYWAAgAMAAUAAQACAAAAgAACg4WFhYACAAwABQABAAIAAACAAAaDhYWFgAIADAAOAAEADgAABgUBAgICAgIFEekX7xfpgADwgQEUAAXlId8b3yGAACCBAesAgAIADAARAAEAEQAACAcAAgMCAgICAoEFEekX7xfpAw/wAPCBARQAgQXlId8b3yGAAhQAIIEB6wCAAgAMAAIAAQACAAAAhYWFhQCAAgAMAA4AAQAOAAAGBQECAgICAgUPFg/x7PEF3CQAJNwABefj5xkdGQU1ywDLNQCAAgAMAAIAAQACAAAAhYWFhQCAAgAMAAIAAQACAAAAhYWF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9+/i09PT4+/5CAv58wUJBIEbLCwbCfvu6QH88/b2+/////v29u/8Aurv/QobLIMAgAIADABHAAEARwAAACEOGxseFg8RExUVFRAHAfvw6+vr9PjiAAkTFBYMAPft7e33g4AKBgYPCQkJCAcHBQGCEgECAwUNFQDw8PwGEyMjIxMF/PCDIeDm49/j4+fr7e3t8/0BBQ0TExMTDyIA79vb2+8AESUlJRGDgAoFBgH9/f3+//79/oIS+/Tx8+zkACcnEv7p09PT6f4SJ4MAgAIADABIAAEASgAAACMREu/uAAoWFhYWCQD26urq6vUABw4RERERDgcA+fLv7+/v8vqDEQsA9gDb2+r2ChYlJSUWCvbq24EE//r2CgWEBAUJ9vr/hCP4+QgHAPLp6enp8wAMFxcXFw0A+ezk5OTk7PkACBQcHBwcFAiDEfYKCvYsLB0K9uTU1NTk9godLIEFBQkK9vb7ggX79vUKCQWEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAOgABADoAAACAGggPDw8PCAD48fHx8fgABAoKCgoEAP329vb2/YOBA/vyDQaCEgYN8vsA6env8g0RFxcXEQ3y7+mDgBr89vb29vwABAoKCgoEAPjx8fHx+AAIDw8PDwiDgQMCAf7+ghL+/gECABYWCwH+9Orq6vT+AQsWgwCAAgAMABAAAQAQAAAHBgECAQEBAgIGDw0ODhD09gboHBT4AOgABvb49vb4EQ8GFezq/QAVAACAAgAMADQAAQA0AAAADQQE9wIQEBAIAPjw8AkGgQj8+Pj48Orv+/uDgAzc2uX8BQ0XFxcLAgIBggYEBv/v6ejohBjz8//7+Pj4/gQKEBD39PsECRISEgwJGw0Ng4AMCgYC/v717e3t9f7+/4IG/v369vgTE4QAgAIADAA6IAEAOQAAABIRAQECAgEBAgEBAQIBAgIBAgIBEQQI8PoABxERBv8ABgr3/Pn29oAQ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BAgMCwECAgICAgICAgICAgsD+wMTGxPt5e39Bf0L7PsICPvs7PsICPvsgAIADAAHAAEABwAAAAMZFOzsg4cD8fEeFIOHAIACAAwAKQABACoAAAARBQUPERQUFAoHB/j29O/s7Oz3hAgI9PT09/oBBQWBBwEDBQUCBAgIgxL29gADBgYGAPv7Cw0SGyMjIxgPgwbq+fn5+vn/gQn29vz9/Pjz8Orqg4ACAAwAJgABACYAAAAQ+wkcHBwiGfPz+fb29vPy9vaDBQgI/vv9BYEI/wD29vX29vYIgxD17+zs7AIGEfwLExMTDQoTE4MQ6ury+wEMAQHt9wIKERcXF+qDAIACAAwAHgABABkgAACADAUPD/X1+gAGCwvx8fuDAQMDggT48fHx+IIAA4MHBgABAgIBBAKABfbnEwrtGQb7+wALGAD+gAIADAAGAAEABgAAAgEBAgEU7AH5GQHsFAEK54ACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwAAgABAAIAAACEhISEAIACAAwABwABAAcAAAADFhbw74OHA+LhIRuDhwCAAgAMAAwAAQAHAAAAAxQU7O6DA/7+/v6DA+zuFBKDhwACAAwAKyABADQgAA4NAAEBAQEDAwQDAgICAwENDxLz8/0I/fAKEAr++P6DCQb+9AIG/vT0AgYQDwABAQECAgICAgICAgICAgIP5+UXGQP7AxMbE+3l7f0F/Q8bGhob9AMQEAP09AMQEAP0AIACAAwAHgABABkgAACADAUPD/X1+gAGCwvx8fuDAQMDggT48fHx+IIAA4MHBgABAgIBBAKABfbnEwrtGQb7+wALGAD+gAIADAAfIAEAJwAAAAoJAQICAwICAgEBAQkJFPsCBewVEOzsBQUA+fEAAoOAEPvx8RkZCf/35+cPDwT+/iAbg4EPBQoKER4eHhEKCgUAHigoHoMAgAIADAAfIAEAJwAAAAoJAQICAwICAgEBAQkJFPsC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); +} +@font-face { + font-family: "JetBrains Mono"; + font-style: italic; + font-weight: 100 800; + font-stretch: normal; + src: url(data:application/octet-stream;base64,AAEAAAAVAQAABABQRFNJRwAAAAEAA54wAAAACEdERUb5pK0fAAHbTAAAAyVHUE9T5SzrawAB3nQAACU+R1NVQrPVm0EAAgO0AABbnEhWQVIFXwAzAAJfUAAAADZPUy8yEhULcAAAAdgAAABgU1RBVBOf1wsAAl+IAAAA9GF2YXIK0yABAAJgfAAAACpjbWFwg535LwAAF3QAADpoZnZhcosVeawAAmCoAAAAdGdhc3AAAAAQAAHbRAAAAAhnbHlmPGeH9gAAXIQAATnsZ3Zhcp8SfOkAAmEcAAE9EmhlYWQVt/RQAAABXAAAADZoaGVhAOcJnwAAAZQAAAAkaG10eNDm/NEAAAI4AAAVPGxvY2Fm7LSVAABR5AAACqBtYXhwBccCbgAAAbgAAAAgbmFtZSHO1dgAAZZwAAALfHBvc3SOldnQAAGh7AAAOVdwcmVwaAaMhQAAUdwAAAAHAAEAAAACPfSpj7N6Xw889QADA+gAAAAA3Sm1GAAAAADdKb2R+S7+cAMcBGAAAgAGAAIAAAAAAAAAAQAAA/z+1AAAAlj5Lv88AxwD6ACeAAAAAAAAAAAAAAAABU8AAQAABU8BuABuALQABgABAAAAAAAAAAAAAAAAAAMAAQAEAlgBkAAFAAACigJY//QASwKKAlgANwFeADIBQAAAAgAACQAAAAAAAKAEAv8SAPn7AgAAKAAAAABKQgAAAIEAAP//A/z+1AAAA/wBLCAAAZ/f1wAAAiYC2gAAACAABgJYAFoCWAAGAlgABgJYAAYCWAAGAlgABgJYAAYCWAAGAlgABgJYAAYCWAAGAlgABgJYAAYCWAAGAlgABgJYAAYCWAAGAlgABgJYAAYCWAAGAlgABgJYAAYCWAAGAlgABgJY//ICWP/yAlgAMQJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYADACWAAKAlgAMAJYAAoCWAA4AlgAOAJYADgCWAA4AlgAOAJYADgCWAA4AlgAOAJYADgCWAA4AlgAOAJYADgCWAA4AlgAOAJYADgCWAA4AlgAOAJYADICWAA4AlgAMwJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWAAxAlgAMQJYADECWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAASAlgAEgJYADACWAAwAlgAWwJYAFsCWABbAlgAWwJYAFsCWAAMAlgAIAJYAC4CWAAuAlgALgJYAC4CWAAuAlgALgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWP/xAlj/8QJYAEICWAAQAlgAMAJYAC4CWAA6AlgAMAJYADACWAAwAlgAMAJYAC0CWAAtAlgALQJYAC0CWAAtAlgALQJYADACWABEAlgAcgJYAHECWAByAlgAcgJYAGwCWAA+AlgAPgJYAD4CWAA+AlgAPgJYAD4CWAA+AlgAPgJYAD4CWAA+AlgAPgJYAD4CWAA+AlgAPgJYAD4CWAA+AlgARAJYAD4CWAA+AlgAegJYAEECWABBAlgAQQJYAEECWABBAlj//AJYAGsCWABrAlgAawJYAGsCWABrAlgAawJYAGsCWABrAlgAawJYACkCWAApAlgAKQJYACkCWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAD0CWAA9AlgAPQJYAAICWAACAlgAMAJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAD0CWAAyAlgAIwJYAD4CWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABEAlgAAAJYAEUCWABFAlgARQJYAEUCWABFAlgARQJYAEUCWAAwAlgALgJYABwCWAAkAlgAJAJYACQCWAAkAlgAJAJYACQCWAAkAlgAJAJYACQCWAAkAlgAJAJYACQCWAAkAlgAJAJYAAwCWAAMAlgADAJYADMCWAAzAlgANQJYAGMCWABjAlgABwJYAGMCWABcAlgATwJYAGMCWAAWAlgAMAJYADACWAAmAlgAMAJYADACWAAyAlgAMAJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlgAQgJYAEICWABCAlj/8gJY//ICWABCAlgAAwJYABMCWAAOAlgAPAJYAEMCWABDAlgAQwJY/8cCWAA7AlgAOwJYADsCWAA7AlgAOwJYADsCWP98Alj/0QJYAFUCWABPAlgAVQJYAFUCWABVAlgAPwJYAD8CWAA/AlgAPwJYAD8CWAA/AlgAPwJYAD8CWAA/AlgAPwJYAD8CWAA/AlgAPwJYAD4CWAA+AlgAPgJYAD4CWAA+AlgAPgJYAD8CWAA/AlgAPgJYAD8CWAA/AlgAZwJYAE4CWABOAlgATgJYAE4CWABOAlgACwJYAEYCWABGAlgARgJYAEYCWABGAlgARgJYAEYCWABGAlgARgJYAC4CWAAuAlgALgJYAC4CWAAwAlgA0gJYAN0CWAAGAlgAMgJYADECWABWAlgAVgJYAFYCWP/XAlgAOAJYADgCWP/gAlgAIQJYAC4CWAAuAlgAMAJYADACWP/nAlgAIAJYADECWABCAlgAMgJYADACWABCAlgAcgJYAHoCWAB6AlgAKAJY//wCWABYAlgAMgJYABYCWAAUAlgAMgJYADICWAA2AlgAFQJY/84CWAAJAlgALQJYAEQCWAA+AlgAPQJYAD0CWAASAlgAOwJYABACWAAMAlgAOwJYACYCWAAlAlgALQJYAGsCWABrAlgATgJYABcCWAA+AlgAPgJYAD0CWAA+AlgAMQJYADYCWAA2AlgAVgJYAEQCWABCAlgAQgJY/+YCWAAqAlgAPgJYAD4CWAA1AlgANQJY/+wCWAAgAlgAMgJYAEICWAAyAlgAEwJYAEACWABWAlgARgJYAEYCWP/3AlgACwJYAE4CWAAyAlgAFgJYABQCWAAyAlgANgJYAB4CWAAVAlj/2AJYABQCWAA7AlgARAJYADoCWAAkAlgAJAJYAAwCWAAuAlgAEgJYABACWAAuAlgAMQJYADACWAAvAlgAaAJYAEUCWABJAlgAOQJYAEICWABEAlgABgJYADECWABWAlgABgJYADgCWAApAlgAMQJYAEICWAA9AlgAMAJYAAYCWAAgAlgALgJYACQCWABCAlgAMgJYADACWAAfAlgAcgJYAGsCWAAoAlj//AJYADcCWAAGAlgABgJY/7sCWP+7Alj/uwJY/94CWP+xAlj/3gJYAD0CWABrAlgAMAJYAD0CWAATAlgAaAJYAD8CWAAyAlgAKAJYADACWABCAlgAVQJYADUCWAAHAlgAFQJYAGcCWAA7AlgAQgJYADkCWAATAlgAQAJYAD8CWABVAlgAPwJYABwCWP/8AlgAGwJYABgCWABVAlgAVQJYAFUCWAA/AlgAPwJYAD8CWABCAlgAGAJYAD0CWAAyAlgAMAJYADICWP/3AlgAGAJYAFoCWABaAlgAaQJYAEQCWABbAlgAOgJYAC4CWAAwAlgAMAJYADMCWABAAlgALQJYAHgCWAAqAlgAWwJYAEQCWABeAlgArwJYALoCWACnAlgAYwJYAFsCWABeAlgAjAJYAGACWAB5AlgAsAJYAK8CWAC6AlgApwJYALUCWACtAlgAsAJYAN4CWACzAlgAywJYAC4CWAAuAlgALgJYAC4CWABMAlgAsgJYAF4CWACyAlgAZQJYABMCWAC6AlgArgJYAI0CWAA+AlgAsgJYALoCWAA1AlgAigJYAGUCWAAXAlgAsgJYAEECWAAOAlgAogJY/+wCWAC/AAD+8gAA/1ECWACfAlgAMwJYAFwCWAAYAlgAkAJYAFkCWABuAlgAlgJYAGkCWACTAlgAkAJYAJACWADhAlgAWQJYAKACWABzAlgAjgJYAI4CWABSAlgAAgJYAI4CWAAAAlgAXgJYABACWABpAlgAcwJYAVkCWAC8AlgAHgJY//UCWACTAlgAbAJYADICWAC6AlgBGgJY/jYCWPveAlj7qAJY/l4CWP3/Alj7pwJY/f8CWPunAlj+EwJY/koCWP5+Alj+UQJY/gECWP6sAlj8aAJY/EkCWP5aAlj+YgJY/qoCWPyiAlj8HQJY/owCWPwHAlj+PQJY/loCWP5aAlj+XQJY/FUCWP6eAlj95wJY+4UCWP6bAlj+mwJY/mcCWPwFAlj+XQJY+60CWP3YAlj93QJY/cACWP3AAlj9wAJY/b8CWP2/Alj9wAJY/d4CWPuGAlj5LgJY/b8CWP3AAlj7aAJY/bYCWPteAlj91AJY+yYCWP3ZAlj+AQJY+70CWPvWAlj75gJY/agCWAB9AlgAZAJYAKACWABzAlgALgJYAGkCWADeAlgAZQJYAAACWAAAAlgAAAJYAAAAAAAAAlgAMQJYAEICWAAdAlgALgJYACECWAAOAlj/twJYAAsCWAAfAlgAOQJYACMCWAA1AlgAsgJY/+sCWACbAlgAJgJY/98CWAD/AlgAOQJYANMCWAAuAlgAewJYAB0CWP/2AlgAGwJYAOYCWAB4AlgANQJYAAcCWAAkAlgAJQJYAP8CWAAtAlgA/wJYAP8CWAD/AlgA/wJYABYCWP/2AlgAFAJYAEYCWP/2AlgAKwJYACYCWAAGAlgALAJYAAICWAAbAlgAMwJYABoCWAA1AlgARgJYACgCWAAjAlgABQJYAEMCWACOAlgAWgJYAGcCWABEAlgAQgJYADMCWABVAlgAKQJYACkCWAAaAlgALAJYAEICWABPAlgAWgJYABwCWAAEAlgAGAJYAGcCWAArAlgAKwJY/7cCWAAlAlj/7gJYADwCWABEAlgAFQJYAG8CWAD/AlgA/wJYAP8CWAD/AlgALQJYAC0CWP/iAlj/zAJYALUCWABEAlgAGgJYABECWAA1AlgA2QJYAAYCWP/yAlj/sAJYAHMCWAD/AlgAcwJYAP8CWABkAlgAZAJYAAACWAA1AlgAtAJYAEICWAA8AlgAPAJYACMCWAC0AlgAIwJYAAICWAA3AlgABQJYAAACWAAcAlgAegJY//YCWAAAAlj/9gJY//YCWP/2Alj/9gJY//YCWAAKAlgACgJYACgCWAAKAlgACgJYAC0CWAAoAlgALQJY/7ACWAAKAlj/sAJY/7ACWP+wAlj/sAJYAGQCWP+wAlgAZAJY/7ACWP/2Alj/sAJY//YCWP+wAlgADwJY/+ICWAAKAlgAFAJY/9gCWP/YAlj/sAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgAAAJYAAACWAAAAlgBLAJYAg0CWAAAAlgBLAJYAAACWAAAAlgAAAJYAAACWP/2AlgBLAJYAAACWAAAAlgAPAJYAAACWAAAAlj/9gJY//YCWP/2Alj/9gJY//YCWP/2AlgAtAJY//YCWP/2AlgAPAJYAAACWAAAAlgAlgJYAJYCWAAAAlgAAAJYAAACWAAAAlgAAAJY//YCWAAAAlj/9gJY//YCWP/2AlgAAAJY//YCWP/2AlgAAAJY//YCWAAAAlj/9gJYAJYCWACWAlgAlgJYAIwCWACWAlgAlgJYAJYCWACMAlj/7AJY/+wCWACWAlj/7AJY/+wCWP/sAlgAlgJYAJYCWP/sAlj/7AJYAJYCWP/sAlj/7AJYAJYCWP/sAlj/7AJY/+wCWADIAlgAyAJY/+wCWP/s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AE0BAwBIAPgAUAEHAFIBCQEKAFQBDABWAQ8AVQEOAFcBEABYAREAWwEUAF0BFwBcARYBFQBeARgAdAEvAGIBHABzAS4AeQE0AH4BOQCAATsAfwE6AIIBPQCFAUAAhAE/AIMBPgCMAUcAiwFGAIoBRQCgAWAAnQFdAJABSwCfAV8AnAFcAJ4BXgCkAWQAqgFqAKsAsgFyALQBdACzAXMBQwCIADYAbQEoAJYBVgAJAL0APADwAHUBMAA6AO4AGQDNAHcBMgCGAUEAjQFIAK8BbwTpBOcFCQUDBQoFDgULBQYE7ATtBPAE9AT1BPIE6wTqBPYE8wTuBPEFMgU0AgAC1wIBAgICAwIFAgYCJQIHAggCKwIsAi0CIwIoAiQCJwIpAiYCKgIJAi8CMAIuAYABpgF8AZ4BnQGgAaEBogGbAZwBowGGAZABlwF4AXkBegF7AX4BfwGBAYIBgwGEAYUBkQGSAZQBkwGVAZYBmQGaAZgBnwGkAaUBsAGxAbIBswG2AbcBuQG6AbsBvAG9AckBygHMAcsBzQHOAdEB0gHQAdcB3AHdAbgB3gG0AdYB1QHYAdkB2gHTAdQB2wG+AcgBzwF9AbUBpwHfAagB4AGpAeEBqgHiAasB4wGsAeQBrQHlAa4B5gGvAecApgFmAKMBYwClAWUAEQDFABMAxwALAL8ADQDBAA4AwgAPAMMADADAAAQAuAAGALoABwC7AAgAvAAFALkAMQDlADMA5wA3AOoAKgDeACwA4AAtAOEALgDiACsA3wBLAQEASQD/AGoBJQBsAScAZAEfAGYBIQBnASIAaAEjAGUBIABuASkAcAErAHEBLAByAS0AbwEqAJMBUwCVAVUAlwFXAJkBWQCaAVoAmwFbAJgBWACtAW0ArAFsAK4BbgCwAXACiwKMAocCiQKKAogEWQRbAmQEVQRWApECagJtAlUCZgJnAjIEXASJBIgDZANeA2ADYgNmA2cDZQNfA2EDYwNWAuwDLgL7AvYDDQNRAwwC+AMrAu4DLAMWA0oC6gMtAz4DPALzAvoDCQMgAwsDPQMaAvkDEAMeAx0DEQMOAxIDDwMDAvwDUANTAxMDFAM/A0ADCgNMA00DXQNaA1sDVANYAvcDBANXAvUEcgRhA3YEfgJ7An0CfAJ+AzMDMQMyAzYDNAM1AwIDAAMBA0cDRQNGAv8C/gL9Au8DRAND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AAACjQAAAKwAAACsAAADIgAAAK0AAACtAAACggAAAK4AAACuAAAEUgAAAK8AAACvAAAFDAAAALAAAACwAAAEVAAAALEAAACxAAADHwAAALIAAACzAAACTQAAALQAAAC0AAAFBQAAALUAAAC1AAADLwAAALYAAAC2AAAETwAAALcAAAC3AAACYwAAALgAAAC4AAAFDQAAALkAAAC5AAACTAAAALoAAAC6AAABdwAAALsAAAC7AAACjgAAALwAAAC8AAACVwAAAL0AAAC9AAACVgAAAL4AAAC+AAACWAAAAL8AAAC/AAACYgAAAMAAAADAAAAAEgAAAMEAAADBAAAAAgAAAMIAAADCAAAACgAAAMMAAADDAAAAFwAAAMQAAADEAAAAEAAAAMUAAADFAAAAFgAAAMYAAADGAAAAGAAAAMcAAADHAAAAHgAAAMgAAADIAAAAMgAAAMkAAADJAAAAJgAAAMoAAADKAAAAKQAAAMsAAADLAAAALwAAAMwAAADMAAAASgAAAM0AAADNAAAARAAAAM4AAADPAAAARgAAANAAAADQAAAAIgAAANEAAADRAAAAXwAAANIAAADSAAAAawAAANMAAADTAAAAYQAAANQAAADUAAAAYwAAANUAAADVAAAAeAAAANYAAADWAAAAaQAAANcAAADXAAADFwAAANgAAADYAAAAdgAAANkAAADZAAAAlAAAANoAAADaAAAAjwAAANsAAADcAAAAkQAAAN0AAADdAAAAqQAAAN4AAADeAAAAewAAAN8AAADfAAABQgAAAOAAAADgAAAAxgAAAOEAAADhAAAAtgAAAOIAAADiAAAAvgAAAOMAAADjAAAAywAAAOQAAADkAAAAxAAAAOUAAADlAAAAygAAAOYAAADmAAAAzAAAAOcAAADnAAAA0gAAAOgAAADoAAAA5gAAAOkAAADpAAAA2gAAAOoAAADqAAAA3QAAAOsAAADrAAAA4wAAAOwAAADsAAABAAAAAO0AAADtAAAA+QAAAO4AAADvAAAA/AAAAPAAAADwAAAA1gAAAPEAAADxAAABGQAAAPIAAADyAAABJgAAAPMAAADzAAABGwAAAPQAAAD0AAABHgAAAPUAAAD1AAABMwAAAPYAAAD2AAABJAAAAPcAAAD3AAADGAAAAPgAAAD4AAABMQAAAPkAAAD5AAABVAAAAPoAAAD6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AAABmwAABAsAAAQLAAABowAABAwAAAQMAAABhgAABA4AAAQOAAABkAAABA8AAAQPAAABlwAABBAAAAQTAAABeAAABBQAAAQVAAABfgAABBYAAAQaAAABgQAABBsAAAQjAAABhwAABCQAAAQlAAABkQAABCYAAAQmAAABlAAABCcAAAQnAAABkwAABCgAAAQpAAABlQAABCoAAAQrAAABmQAABCwAAAQsAAABmAAABC0AAAQtAAABnwAABC4AAAQvAAABpAAABDAAAAQzAAABsAAABDQAAAQ1AAABtgAABDYAAAQ6AAABuQAABDsAAARDAAABvwAABEQAAARFAAAByQAABEYAAARGAAABzAAABEcAAARHAAABywAABEgAAARJAAABzQAABEoAAARLAAAB0QAABEwAAARMAAAB0AAABE0AAARNAAAB1wAABE4AAARPAAAB3AAABFEAAARRAAABuAAABFIAAARSAAAB3gAABFMAAARTAAABtAAABFQAAARUAAAB1gAABFUAAARVAAAB1QAABFYAAARYAAAB2AAABFkAAARaAAAB0wAABFsAAARbAAAB2wAABFwAAARcAAABvgAABF4AAAReAAAByAAABF8AAARfAAABzwAABJAAAASQAAABfQAABJEAAASRAAABtQAABJIAAASSAAABpwAABJMAAASTAAAB3wAABJoAAASaAAABqAAABJsAAASbAAAB4AAABKIAAASiAAABqQAABKMAAASjAAAB4QAABK4AAASuAAABqgAABK8AAASvAAAB4gAABLAAAASwAAABqwAABLEAAASxAAAB4wAABLYAAAS2AAABrAAABLcAAAS3AAAB5AAABLoAAAS6AAABrQAABLsAAAS7AAAB5QAABNgAAATYAAABrgAABNkAAATZAAAB5gAABOgAAAToAAABrwAABOkAAATpAAAB5wAACuoAAArqAAACWQAAHoAAAB6AAAAApgAAHoEAAB6BAAABZgAAHoIAAB6CAAAAowAAHoMAAB6DAAABYwAAHoQAAB6EAAAApQAAHoUAAB6FAAABZQAAHp4AAB6eAAAAhwAAHqAAAB6gAAAAEQAAHqEAAB6hAAAAxQAAHqIAAB6iAAAAEwAAHqMAAB6jAAAAxwAAHqQAAB6kAAAACwAAHqUAAB6lAAAAvwAAHqYAAB6mAAAADQAAHqcAAB6nAAAAwQAAHqgAAB6oAAAADgAAHqkAAB6pAAAAwgAAHqoAAB6qAAAADwAAHqsAAB6rAAAAwwAAHqwAAB6sAAAADAAAHq0AAB6tAAAAwAAAHq4AAB6uAAAABAAAHq8AAB6vAAAAuAAAHrAAAB6wAAAABgAAHrEAAB6xAAAAugAAHrIAAB6yAAAABwAAHrMAAB6zAAAAuwAAHrQAAB60AAAACAAAHrUAAB61AAAAvAAAHrYAAB62AAAABQAAHrcAAB63AAAAuQAAHrgAAB64AAAAMQAAHrkAAB65AAAA5QAAHroAAB66AAAAMwAAHrsAAB67AAAA5wAAHrwAAB68AAAANwAAHr0AAB69AAAA6gAAHr4AAB6+AAAAKgAAHr8AAB6/AAAA3gAAHsAAAB7AAAAALAAAHsEAAB7BAAAA4AAAHsIAAB7CAAAALQAAHsMAAB7DAAAA4QAAHsQAAB7EAAAALgAAHsUAAB7FAAAA4gAAHsYAAB7GAAAAKwAAHscAAB7HAAAA3wAAHsgAAB7IAAAASwAAHskAAB7JAAABAQAAHsoAAB7KAAAASQAAHssAAB7LAAAA/wAAHswAAB7MAAAAagAAHs0AAB7NAAABJQAAHs4AAB7OAAAAbAAAHs8AAB7PAAABJwAAHtAAAB7QAAAAZAAAHtEAAB7RAAABHwAAHtIAAB7SAAAAZgAAHtMAAB7TAAABIQAAHtQAAB7UAAAAZwAAHtUAAB7VAAABIgAAHtYAAB7WAAAAaAAAHtcAAB7XAAABIwAAHtgAAB7YAAAAZQAAHtkAAB7ZAAABIAAAHtoAAB7aAAAAbgAAHtsAAB7bAAABKQAAHtwAAB7cAAAAcAAAHt0AAB7dAAABKwAAHt4AAB7eAAAAcQAAHt8AAB7fAAABLAAAHuAAAB7gAAAAcgAAHuEAAB7hAAABLQAAHuIAAB7iAAAAbwAAHuMAAB7jAAABKgAAHuQAAB7kAAAAkwAAHuUAAB7lAAABUwAAHuYAAB7mAAAAlQAAHucAAB7nAAABVQAAHugAAB7oAAAAlwAAHukAAB7pAAABVwAAHuoAAB7qAAAAmQAAHusAAB7rAAABWQAAHuwAAB7sAAAAmgAAHu0AAB7tAAABWgAAHu4AAB7uAAAAmwAAHu8AAB7vAAABWwAAHvAAAB7wAAAAmAAAHvEAAB7xAAABWAAAHvIAAB7yAAAArQAAHvMAAB7zAAABbQAAHvQAAB70AAAArAAAHvUAAB71AAABbAAAHvYAAB72AAAArgAAHvcAAB73AAABbgAAHvgAAB74AAAAsAAAHvkAAB75AAABcAAAIAEAACABAAAC2QAAIBAAACAQAAAChQAAIBMAACAUAAACgwAAIBgAACAZAAACiwAAIBoAACAaAAAChwAAIBwAACAdAAACiQAAIB4AACAeAAACiAAAICAAACAgAAAEWQAAICEAACAhAAAEWwAAICIAACAiAAACZAAAICQAACAkAAACaQAAICYAACAmAAACXgAAIDAAACAwAAADOAAAIDIAACAzAAAEVQAAIDQAACA0AAACkQAAIDkAACA6AAACjwAAID4AACA+AAACagAAID8AACA/AAACbQAAIEQAACBEAAACVQAAIEUAACBGAAACZgAAIHAAACBwAAACSwAAIHQAACB5AAACTwAAIHoAACB6AAADOQAAIIAAACCJAAACQQAAIKsAACCsAAAC4gAAIK4AACCuAAAC5wAAIL0AACC9AAAC5QAAIL8AACC/AAAC3gAAIRMAACETAAAEWgAAIRUAACEVAAACMgAAIRYAACEWAAAEXAAAIRoAACEaAAACMwAAISIAACEiAAAEUwAAISQAACEkAAACNQAAIS4AACEuAAAEXQAAIUAAACFAAAADUgAAIYoAACGKAAAEiQAAIYsAACGLAAAEiAAAIZAAACGQAAADZAAAIZEAACGRAAADXgAAIZIAACGSAAADYAAAIZMAACGTAAADYgAAIZQAACGVAAADZgAAIZYAACGWAAADZQAAIZcAACGXAAADXwAAIZgAACGYAAADYQAAIZkAACGZAAADYwAAIZ4AACGeAAADaQAAIaAAACGgAAADagAAIaMAACGjAAADawAAIaUAACGnAAADbAAAIa0AACGtAAADaAAAIckAACHJAAADbwAAIdEAACHUAAADcAAAIecAACHoAAADdAAAIgAAACIAAAADVgAAIgEAACIBAAAC7AAAIgIAACICAAADLgAAIgMAACIDAAAC+wAAIgUAACIFAAADJQAAIggAACIIAAAC9gAAIgkAACIJAAADDQAAIgsAACILAAADUQAAIgwAACIMAAADDAAAIg4AACIOAAAC+AAAIg8AACIPAAADKwAAIhAAACIQAAAC7gAAIhEAACIRAAADLAAAIhIAACISAAADFgAAIhUAACIVAAAC8gAAIhgAACIYAAADSgAAIhkAACIZAAAC6gAAIhoAACIaAAADLQAAIh4AACIeAAADJAAAIiMAACIjAAAC8QAAIiUAACIlAAADMAAAIicAACIrAAADJgAAIjYAACI2AAADPgAAIjcAACI3AAADPAAAIjgAACI4AAAC8wAAIjkAACI5AAAC+gAAIjwAACI8AAADSwAAIkMAACJDAAAC6QAAIkUAACJFAAAC7QAAIkcAACJHAAADCQAAIkgAACJIAAADIAAAIkkAACJJAAADCwAAIksAACJLAAADVQAAIlQAACJUAAAC6wAAIlcAACJXAAADSQAAIl8AACJfAAADPQAAImAAACJgAAADGgAAImEAACJhAAAC+QAAImIAACJiAAADEAAAImQAACJkAAADHgAAImUAACJlAAADHQAAIm4AACJuAAADEQAAIm8AACJvAAADDgAAInAAACJwAAADEgAAInEAACJxAAADDwAAInIAACJyAAADAwAAInMAACJzAAAC/AAAInoAACJ6AAADOgAAInwAACJ8AAADOwAAIoIAACKCAAADUAAAIoMAACKDAAADUwAAIoQAACKFAAADEwAAIoYAACKHAAADPwAAIogAACKIAAADCgAAIo4AACKOAAADBgAAIpEAACKRAAADTgAAIpMAACKUAAADTAAAIpUAACKVAAADXQAAIpYAACKXAAADWgAAIpkAACKZAAADXAAAIpsAACKbAAADWQAAIqIAACKiAAADSAAAIqQAACKkAAADVAAAIqUAACKlAAADWAAAIrgAACK4AAADBQAAIsYAACLGAAADTwAAIs4AACLOAAAC8AAAItAAACLQAAAC9AAAIu4AACLuAAAC9wAAIu8AACLvAAADBAAAIvAAACLwAAADVwAAIvEAACLxAAAC9QAAIwIAACMCAAAEcgAAIwMAACMDAAAEYQAAIwQAACMEAAADdgAAIwUAACMFAAAEfgAAIwgAACMIAAACewAAIwkAACMJAAACfQAAIwoAACMKAAACfAAAIwsAACMLAAACfgAAIxgAACMYAAAEdAAAIyUAACMlAAAEcwAAI2gAACNoAAAERAAAI3MAACN0AAAEQgAAI5sAACObAAADMwAAI5wAACOdAAADMQAAI54AACOeAAADNgAAI58AACOg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AAAEJAAAJWkAACVpAAADxgAAJWoAACVqAAAEPwAAJWsAACVrAAAENgAAJWwAACVsAAADygAAJW0AACVtAAAD/wAAJW4AACVuAAAD/gAAJW8AACVwAAAEAAAAJXEAACVxAAAEBAAAJXIAACVyAAAEAwAAJXMAACVzAAAEAgAAJXQAACV0AAAEDAAAJXUAACV1AAAEEwAAJXYAACV2AAAEEAAAJXcAACV3AAAEBwAAJXgAACV4AAAD5gAAJXkAACV5AAAD7QAAJXoAACV6AAAD6gAAJXsAACV7AAAD4QAAJXwAACV8AAAEDQAAJX0AACV9AAAEFAAAJX4AACV+AAAD5wAAJX8AACV/AAAD8AAAJYAAACWAAAADgwAAJYEAACWIAAADewAAJYkAACWJAAADiwAAJYoAACWKAAADigAAJYsAACWLAAADiQAAJYwAACWMAAADiAAAJY0AACWNAAADhwAAJY4AACWOAAADhgAAJY8AACWPAAADhQAAJZAAACWQAAADjAAAJZEAACWTAAADmAAAJZQAACWUAAADhAAAJZUAACWfAAADjQAAJaAAACWhAAADpQAAJaoAACWrAAADpwAAJbIAACWyAAADrgAAJbMAACWzAAADsgAAJbQAACW0AAADugAAJbUAACW1AAADvgAAJbYAACW2AAADrwAAJbcAACW3AAADswAAJbgAACW4AAADuwAAJbkAACW5AAADvwAAJboAACW6AAADtgAAJbsAACW7AAADuAAAJbwAACW8AAADsAAAJb0AACW9AAADtAAAJb4AACW+AAADvAAAJb8AACW/AAADwAAAJcAAACXAAAADsQAAJcEAACXBAAADtQAAJcIAACXCAAADvQAAJcMAACXDAAADwQAAJcQAACXEAAADtwAAJcUAACXFAAADuQAAJcYAACXHAAADogAAJcoAACXKAAADpAAAJcwAACXMAAADnwAAJc4AACXOAAADoAAAJc8AACXPAAADmwAAJdQAACXVAAADnQAAJeYAACXmAAADoQAAJecAACXrAAADqQAAJe8AACXvAAADnAAAJm0AACZtAAAE4gAAJm8AACZvAAAE4wAAJqAAACahAAAERQAAJxMAACcTAAAERwAAJxUAACcVAAAESAAAJxcAACcXAAAESQAAJzYAACc2AAAESgAAJ24AACduAAACeAAAJ28AACdv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UTVRQlFRUWBRolHWUgJSMFJxUoNSyFL9U1tTklPJU+5UGlRAVGZUk1TBVO9VBlUOVSdVWFVtVYtVp1XEVedWClYlVjFWX1ZwVoxW51chVzRXR1dSV3JXllevV8tX5VgpWDFYRlhTWGtYg1iLWJZYoVj+WYRZnFm/WehaN1p6WqFazlr7W0VbUFtbW2Zbblt5W4RbmFvRW/db/1wRXBxcNVxKXHBcn1zDXOlc/F1zXY9dxl3RXlZejl7TXxRfU195X6FfyV/yYBhgQWBpYJJg1WEUYV9hamGuYdxiBmIxYjxigGKZYrViwGLnYwtjL2NAY3ZjnWPEZAVkEWQeZCtkOGRFZFJkX2RsZHlkhWSSZJ9krGS5ZMZk02TgZO5k/GUJZRdlJGU0ZUhlWGVpZXdljWWdZsJpA2osakhqemquathrTWuea8Rr1GvsbBxsKWw9bEpsXWxobHxsj2yjbL5szGzYbOVs820HbRptLm1DbU9tWm1tbXhthW2RbZxtqW27bc1t323xbhFuK25Ebldudm6ObqZuum7lbwRvJG87b1BvZW93b4dvnG+sb8Fv2G/rb/twEHAgcDVwTHBmcHtwkHCicLZww3DVcOVw9XECcQ9xIXE9cVtxaHF/cZpxp3G4ccdx2XHocfVyC3Idci9ySHJdcnJyinKecrFyx3LgcvlzEnMrc0VzZ3N4c4lzm3Ovc7xzz3Pfc+9z/HQJdBt0N3RVdGJ0eXSUdKF0s3TFdNV05XTydQp1HXUwdUl1XnVzdYt1n3Wydch14XX3dgt2H3Y2dkd2XHZrdoB2j3amdrh2zXbddvJ3Ancbdy93Q3djd3t3lHeqd7x3znfmd/l4DHgueEZ4XnhmeKB4rHjgePN5BXkeeTd5UHlkeXN50XohekB6tHsVe3J7tXvfe+18A3wRfCh8QHyDfKV8/n01fUl9XX1sfX19kX2lfbl9zX3hffV+BH4Yfix+QH5Ufmh+d36GfpV+pH67ftN/Vn9lf3l/iH+cf++ANoBsgIWArYDFgNSBIYEwgT+BToFigXaBioGegaiBsoHBgdCB/IIFgi2CjoMkg/+EXIRxhI2E0ITshPiFFIUxhWOFhYWwhcqF7oYRhn2Gn4bMhvqHM4d7h76H1IfyiA+ILIhViH6Io4i5iNeI44jviRaJPolKiW2Jl4mnib2J3In4ihaKNIpAilCKl4sJ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AYcBiwGPAZMBlwGbAZ8BowGnAasBrwGzAbcAAAE1MxUBNTMVJzUzFRU1MxUVNTMVJzUzFRU1MxUVNTMVFTUzFRU1MxUBNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFQE1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUBNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFQE1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUBNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVATUzFRU1MxUVNTMVFTUzFRU1MxUVNTMVFTUzFQE1MxUVNTMVFTUzFRU1MxUVNTMVJzUzFRU1MxUVNTMVAhw8/ag8PDw8PLQ8PDw8PP7UPDw8PDw8PP5cPDw8PDw8PDw8/eQ8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/ag8PDw8PDw8PDw8/eQ8PDw8PDw8PDz+XDw8PDw8PDz+1Dw8PDw8tDw8PAPAPDz7FDw8eDw8PDw8PDw88Dw8PDw8PDw8PDw8PDw8AWg8PDw8PDw8PDw8PDw8PDw8PDw8PAHgPDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDwCWDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8ApQ8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PAKUPDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDwClDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8ApQ8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PAKUPDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8PDwCWDw8PDw8PDw8PDw8PDw8PDw8PDw8PDw8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AG4AbwAgAFAAcgBvAGoAZQBjAHQAIABBAHUAdABoAG8AcgBzACAAKABoAHQAdABwAHMAOgAvAC8AZwBpAHQAaAB1AGIALgBjAG8AbQAvAEoAZQB0AEIAcgBhAGkAbgBzAC8ASgBlAHQAQgByAGEAaQBuAHMATQBvAG4AbwApAEoAZQB0AEIAcgBhAGkAbgBzACAATQBvAG4AbwBJAHQAYQBsAGkAYwAyAC4AMgA0ADIAOwBKAEIAOwBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAC0ASQB0AGEAbABpAGMASgBlAHQAQgByAGEAaQBuAHMAIABNAG8AbgBvACAASQB0AGEAbABpAGMAVgBlAHIAcwBpAG8AbgAgADIALgAyADQAMgBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAC0ASQB0AGEAbABpAGMASgBlAHQAQgByAGEAaQBuAHMAIABNAG8AbgBvACAAaQBzACAAYQAgAHQAcgBhAGQAZQBtAGEAcgBrACAAbwBmACAASgBlAHQAQgByAGEAaQBuAHMAIABzAC4AcgAuAG8ALgBKAGUAdABCAHIAYQBpAG4AcwBQAGgAaQBsAGkAcABwACAATgB1AHIAdQBsAGwAaQBuACwAIABLAG8AbgBzAHQAYQBuAHQAaQBuACAAQgB1AGwAZQBuAGsAbwB2AGgAdAB0AHAAcwA6AC8ALwB3AHcAdwAuAGoAZQB0AGIAcgBhAGkAbgBzAC4AYwBvAG0AVABoAGkAcwAgAEYAbwBuAHQAIABTAG8AZgB0AHcAYQByAGUAIABpAHMAIABsAGkAYwBlAG4AcwBlAGQAIAB1AG4AZABlAHIAIAB0AGgAZQAgAFMASQBMACAATwBwAGUAbgAgAEYAbwBuAHQAIABMAGkAYwBlAG4AcwBlACwAIABWAGUAcgBzAGkAbwBuACAAMQAuADEALgAgAFQAaABpAHMAIABsAGkAYwBlAG4AcwBlACAAaQBzACAAYQB2AGEAaQBsAGEAYgBsAGUAIAB3AGkAdABoACAAYQAgAEYAQQBRACAAYQB0ADoAIABoAHQAdABwAHMAOgAvAC8AcwBjAHIAaQBwAHQAcwAuAHMAaQBsAC4AbwByAGcALwBPAEYATABoAHQAdABwAHMAOgAvAC8AcwBjAHIAaQBwAHQAcwAuAHMAaQBsAC4AbwByAGcALwBPAEYATABKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAEkAdABhAGwAaQBjAFcAZQBpAGcAaAB0AFQAaABpAG4AIABJAHQAYQBsAGkAYwBFAHgAdAByAGEATABpAGcAaAB0ACAASQB0AGEAbABpAGMATABpAGcAaAB0ACAASQB0AGEAbABpAGMATQBlAGQAaQB1AG0AIABJAHQAYQBsAGkAYwBTAGUAbQBpAEIAbwBsAGQAIABJAHQAYQBsAGkAYwBCAG8AbABkACAASQB0AGEAbABpAGMARQB4AHQAcgBhAEIAbwBsAGQAIABJAHQAYQBsAGkAYwBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAEkAdABhAGwAaQBjAC0AVABoAGkAbgBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAEkAdABhAGwAaQBjAC0ARQB4AHQAcgBhAEwAaQBnAGgAdABKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAEkAdABhAGwAaQBjAC0ATABpAGcAaAB0AEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8ASQB0AGEAbABpAGMALQBSAGUAZwB1AGwAYQByAEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8ASQB0AGEAbABpAGMALQBNAGUAZABpAHUAbQBKAGUAdABCAHIAYQBpAG4AcwBNAG8AbgBvAEkAdABhAGwAaQBjAC0AUwBlAG0AaQBCAG8AbABkAEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8ASQB0AGEAbABpAGMALQBCAG8AbABkAEoAZQB0AEIAcgBhAGkAbgBzAE0AbwBuAG8ASQB0AGEAbABpAGMALQBFAHgAdAByAGEAQgBvAGwAZABUAGgAaQBuAEUAeAB0AHIAYQBMAGkAZwBoAHQATABpAGcAaAB0AFIAZQBnAHUAbABhAHIATQBlAGQAaQB1AG0AUwBlAG0AaQBCAG8AbABkAEIAbwBsAGQARQB4AHQAcgBhAEIAbwBsAGQAAgAA//cAAP9lADIAAAABAAAAAAAAAAAAAAAAAAAAAAVPAAAAJADJAQIBAwEEAQUBBgEHAQgAxwEJAQoBCwEMAQ0AYgEOAK0BDwEQAREAYwCuAJABEgAlACYA/QD/AGQBEwEUACcA6QEVARYAKABlARcBGADIARkBGgEbARwBHQDKAR4BHwDLASABIQEiASMBJAApACoBJQD4ASYBJwEoASkAKwEqASsALADMASwAzQDOAPoBLQDPAS4BLwEwATEALQEyAC4BMwAvATQBNQE2ATcA4gAwADEBOAE5AToBOwBmADIA0AE8ANEBPQE+AT8BQAFBAGcBQgDTAUMBRAFFAUYBRwFIAUkBSgFLAUwAkQFNAK8AsAAzAO0ANAA1AU4BTwFQADYBUQDkAPsBUgFTAVQBVQA3AVYBVwFYAVkAOADUAVoA1QBoAVsA1gFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwA5ADoBaAFpAWoBawA7ADwA6wFsALsBbQFuAW8BcAFxAD0BcgDmAXMARABpAXQBdQF2AXcBeAF5AXoAawF7AXwBfQF+AX8AbAGAAGoBgQGCAYMAbgBtAKABhABFAEYA/gEAAG8BhQGGAEcA6gGHAQEASABwAYgBiQByAYoBiwGMAY0BjgBzAY8BkABxAZEBkgGTAZQBlQBJAEoBlgD5AZcBmAGZAZoASwGbAZwATADXAHQBnQGeAHYAdwGfAaAAdQGhAaIBowGkAE0BpQGmAE4BpwGoAE8BqQGqAasBrAGtAOMAUABRAa4BrwGwAbEBsgB4AFIAeQGzAbQAewG1AbYBtwG4AbkAfAG6AHoBuwG8Ab0BvgG/AcABwQHCAcMBxAChAcUAfQCxAFMA7gBUAFUBxgHHAcgAVgHJAOUA/AHKAcsAiQHMAFcBzQHOAc8B0ABYAH4B0QHSAIAAgQHTAdQB1QHWAdcAfwHYAdkB2gHbAdwB3QHeAd8B4AHhAeIB4wBZAFoB5AHlAeYB5wBbAFwA7AHoALoB6QHqAesB7AHtAF0B7gDnAe8B8ACdAJ4B8QHyAfMB9AH1AfYB9wH4AfkB+gH7AfwB/QH+Af8CAAIBAgICAwIEAgUCBgIHAggCCQIKAgsCDAINAg4CDwIQAhECEgITAhQCFQIWAhcCGAIZAhoCGwIcAh0CHgIfAiACIQIiAiMCJAIlAiYCJwIoAikCKgIrAiwCLQIuAi8CMAIxAjICMwI0AjUCNgI3AjgCOQI6AjsCPAI9Aj4CPwJAAkECQgJDAkQCRQJGAkcCSAJJAkoCSwJMAk0CTgJPAlACUQJSAlMCVAJVAlYCVwJYAlkCWgJbAlwCXQJeAl8CYAJhAmICYwJkAmUCZgJnAmgCaQJqAmsCbAJtAm4CbwJwAnECcgJzAnQCdQJ2AncCeAJ5AnoCewJ8An0CfgJ/AoACgQKCAoMChAKFAoYChwKIAokCigKLAowCjQKOAo8CkAKRAJsCkgKTApQClQKWApcCmAKZApoCmwKcAp0CngKfAqACoQKiAqMCpAKlAqYCpwKoAqkCqgKrAqwCrQATABQAFQAWABcAGAAZABoAGwAcAq4CrwKwArECsgKzArQCtQK2ArcCuAK5AroCuwK8Ar0CvgK/AsACwQLCALwA9AD1APYCwwARAA8AHQAeAKsABACjACIAogDDAIcADQLEAsUABgLGAscAEgA/AsgCyQLKAssACwAMAF4AYAA+AEACzALNAs4CzwLQAtEC0gLTAtQC1QAQAtYAsgCzAtcAQgDEAMUAtAC1ALYAtwCpAKoAvgC/AtgABQAKAtkC2gLbAtwC3QLeAt8C4ALhAuIC4wLkAuUC5gLnAugC6QLqAusC7ALtAu4C7wLwAvEC8gLzAvQC9QL2AvcC+AL5AvoC+wL8Av0C/gL/AwADAQMCAwMDBAMFAwYDBwMIAwkDCgMLAwwDDQMOAw8DEAMRAxIDEwMUAxUDFgMXAxgDGQMaAxsDHAMdAx4AAwMfAyADIQMiAIQAvQAHAyMDJACmAyUAhQMmAJYDJwMoAykDKgMrAywDLQMuAy8DMAMxAzIDMwM0AzUDNgM3AzgDOQM6AzsDPAM9Az4DPwNAA0EDQgNDA0QDRQNGA0cDSANJA0oDSwNMA00DTgNPA1ADUQNSAA4A7wDwALgAIACPACEAHwCVAJQAkwCnAGEApABBAJIDUwNUA1UDVgNXAJwAmgCZAKUAmANYA1kDWgNbA1wDXQNeA18ACADGA2ADYQNiA2MDZANlA2YDZwNoA2kDagNrA2wDbQNuA28DcANxA3IDcwN0A3UDdgN3A3gDeQN6A3sDfAN9A34DfwOAA4EDggODA4QDhQOGA4cDiAOJA4oDiwOMA40DjgOPA5ADkQOSA5MDlAOVA5YDlwOYA5kDmgObA5wDnQOeA58DoAOhA6IDowOkA6UDpgOnA6gDqQOqA6sDrAOtA64DrwOwA7EDsgOzA7QDtQO2A7cDuAO5A7oDuwO8A70DvgO/A8ADwQPCA8MDxAPFA8YDxwPIA8kDygC5A8sDzAPNA84DzwPQA9ED0gPTA9QD1QPWA9cD2APZA9oD2wPcA90D3gPfA+AD4QPiA+MD5APlA+YD5wPoA+kD6gPrA+wD7QPuA+8D8APxA/ID8wP0A/UD9gP3A/gD+QP6A/sD/AP9A/4D/wQABAEEAgQDBAQEBQQGBAcECAQJBAoECwQMBA0EDgQPBBAEEQQSBBMEFAQVBBYEFwQYBBkEGgQbBBwEHQQeBB8EIAQhBCIEIwQkBCUEJgQnBCgEKQQqBCsELAQtBC4ELwQwBDEEMgQzBDQENQQ2BDcEOAQ5BDoEOwQ8BD0EPgQ/BEAEQQRCBEMERARFBEYERwRIBEkESgRLBEwETQROBE8EUARRBFIEUwRUBFUEVgRXBFgEWQRaBFsEXARdBF4EXwRgBGEEYgRjBGQEZQRmBGcEaARpBGoEawRsBG0EbgRvBHAEcQRyACMACQCIAIYAiwCKAIwAgwRzBHQAXwDoAIIEdQDCBHYEdwR4BHkEegR7BHwEfQR+BH8EgASBBIIEgwSEBIUEhgSHBIgEiQSKBIsEjASNBI4EjwSQBJEEkgSTBJQElQSWBJcEmASZBJoEmwScBJ0EngSfBKAEoQSiBKMEpASlBKYEpwSoBKkEqgSrBKwErQSuBK8EsASxBLIEswS0BLUEtgS3BLgEuQS6BLsEvAS9BL4EvwTABMEEwgTDBMQExQTGBMcEyATJBMoEywTMBM0EzgTPBNAE0QTSBNME1ATVBNYE1wTYBNkE2gTbBNwE3QTeBN8E4AThBOIE4wTkBOUE5gTnBOgE6QTqBOsE7ATtBO4E7wTwBPEE8gTzBPQE9QT2BPcE+AT5BPoE+wT8BP0E/gT/BQAFAQUCBQMFBAUFBQYFBwUIBQkFCgULBQwFDQUOBQ8FEAURBRIFEwUUBRUFFgUXBRgFGQUaBRsAjgDcAEMAjQDfANgA4QDbAN0A2QDaAN4A4AUcBR0FHgUfBSAFIQUiBSMFJAUlBSYFJwUoBSkFKgUrBSwFLQUuBS8FMAUxBTIFMwU0BTUFNgU3BTgFOQU6BTsFPAU9BT4FPwVABUEFQgVDBUQFRQVGBUcFSAVJBUoFSwVMBU0FTgVPBVAFUQVSBVMFVAVVBVYFVwVYBVkFWgVbBkFicmV2ZQd1bmkxRUFFB3VuaTFFQjYHdW5pMUVCMAd1bmkxRUIyB3VuaTFFQjQHdW5pMDFDRAd1bmkxRUE0B3VuaTFFQUMHdW5pMUVBNgd1bmkxRUE4B3VuaTFFQUEHdW5pMUVBMAd1bmkxRUEyB0FtYWNyb24HQW9nb25lawdBRWFjdXRlC0NjaXJjdW1mbGV4CkNkb3RhY2NlbnQGRGNhcm9uBkRjcm9hdAZFYnJldmUGRWNhcm9uB3VuaTFFQkUHdW5pMUVDNgd1bmkxRUMwB3VuaTFFQzIHdW5pMUVDNApFZG90YWNjZW50B3VuaTFFQjgHdW5pMUVCQQdFbWFjcm9uB0VvZ29uZWsHdW5pMDE5MAd1bmkxRUJDB3VuaTAxRjQGR2Nhcm9uC0djaXJjdW1mbGV4B3VuaTAxMjIKR2RvdGFjY2VudARIYmFyC0hjaXJjdW1mbGV4BklicmV2ZQd1bmkxRUNBB3VuaTFFQzgHSW1hY3JvbgdJb2dvbmVrBkl0aWxkZQtKY2lyY3VtZmxleAd1bmkwMTM2BkxhY3V0ZQZMY2Fyb24HdW5pMDEzQgRMZG90Bk5hY3V0ZQZOY2Fyb24HdW5pMDE0NQNFbmcGT2JyZXZlB3VuaTFFRDAHdW5pMUVEOAd1bmkxRUQyB3VuaTFFRDQHdW5pMUVENgd1bmkxRUNDB3VuaTFFQ0UFT2hvcm4HdW5pMUVEQQd1bmkxRUUyB3VuaTFFREMHdW5pMUVERQd1bmkxRUUwDU9odW5nYXJ1bWxhdXQHT21hY3Jvbgd1bmkwMUVBC09zbGFzaGFjdXRlBlJhY3V0ZQZSY2Fyb24HdW5pMDE1NgZTYWN1dGULU2NpcmN1bWZsZXgHdW5pMDIxOAd1bmkxRTlFB3VuaTAxOEYEVGJhcgZUY2Fyb24HdW5pMDE2Mgd1bmkwMjFBBlVicmV2ZQd1bmkxRUU0B3VuaTFFRTYFVWhvcm4HdW5pMUVFOAd1bmkxRUYwB3VuaTFFRUEHdW5pMUVFQwd1bmkxRUVFDVVodW5nYXJ1bWxhdXQHVW1hY3JvbgdVb2dvbmVrBVVyaW5nBlV0aWxkZQZXYWN1dGULV2NpcmN1bWZsZXgJV2RpZXJlc2lzBldncmF2ZQtZY2lyY3VtZmxleAd1bmkxRUY0BllncmF2ZQd1bmkxRUY2B3VuaTAyMzIHdW5pMUVGOAZaYWN1dGUKWmRvdGFjY2VudAZhYnJldmUHdW5pMUVBRgd1bmkxRUI3B3VuaTFFQjEHdW5pMUVCMwd1bmkxRUI1B3VuaTAxQ0UHdW5pMUVBNQd1bmkxRUFEB3VuaTFFQTcHdW5pMUVBOQd1bmkxRUFCB3VuaTFFQTEHdW5pMUVBMwdhbWFjcm9uB2FvZ29uZWsHYWVhY3V0ZQtjY2lyY3VtZmxleApjZG90YWNjZW50BmRjYXJvbgZlYnJldmUGZWNhcm9uB3VuaTFFQkYHdW5pMUVDNwd1bmkxRUMxB3VuaTFFQzMHdW5pMUVDNQplZG90YWNjZW50B3VuaTFFQjkHdW5pMUVCQgdlbWFjcm9uB2VvZ29uZWsHdW5pMUVCRAd1bmkwMjU5B3VuaTAxRjUGZ2Nhcm9uC2djaXJjdW1mbGV4B3VuaTAxMjMKZ2RvdGFjY2VudARoYmFyC2hjaXJjdW1mbGV4BmlicmV2ZQd1bmkwMUQwCWkubG9jbFRSSwd1bmkxRUNCB3VuaTFFQzkHaW1hY3Jvbgdpb2dvbmVrBml0aWxkZQd1bmkwMjM3C2pjaXJjdW1mbGV4B3VuaTAxMzcMa2dyZWVubGFuZGljBmxhY3V0ZQd1bmkwMTlCBmxjYXJvbgd1bmkwMTNDBGxkb3QGbmFjdXRlC25hcG9zdHJvcGhlBm5jYXJvbgd1bmkwMTQ2A2VuZwZvYnJldmUHdW5pMDFEMgd1bmkxRUQxB3VuaTFFRDkHdW5pMUVEMwd1bmkxRUQ1B3VuaTFFRDcHdW5pMUVDRAd1bmkxRUNGBW9ob3JuB3VuaTFFREIHdW5pMUVFMwd1bmkxRUREB3VuaTFFREYHdW5pMUVFMQ1vaHVuZ2FydW1sYXV0B29tYWNyb24HdW5pMDFFQgtvc2xhc2hhY3V0ZQZyYWN1dGUGcmNhcm9uB3VuaTAxNTcGc2FjdXRlC3NjaXJjdW1mbGV4B3VuaTAyMTkFbG9uZ3MEdGJhcgZ0Y2Fyb24HdW5pMDE2Mwd1bmkwMjFCBnVicmV2ZQd1bmkwMUQ0B3VuaTAxRDgHdW5pMDFEQQd1bmkwMURDB3VuaTAxRDYHdW5pMUVFNQd1bmkxRUU3BXVob3JuB3VuaTFFRTkHdW5pMUVGMQd1bmkxRUVCB3VuaTFFRUQHdW5pMUVFRg11aHVuZ2FydW1sYXV0B3VtYWNyb24HdW9nb25lawV1cmluZwZ1dGlsZGUGd2FjdXRlC3djaXJjdW1mbGV4CXdkaWVyZXNpcwZ3Z3JhdmULeWNpcmN1bWZsZXgHdW5pMUVGNQZ5Z3JhdmUHdW5pMUVGNwd1bmkwMjMzB3VuaTFFRjkGemFjdXRlCnpkb3RhY2NlbnQPZ2VybWFuZGJscy5jYWx0B3VuaTA0MTAHdW5pMDQxMQd1bmkwNDEyB3VuaTA0MTMHdW5pMDQwMwd1bmkwNDkwB3VuaTA0MTQHdW5pMDQxNQd1bmkwNDAxB3VuaTA0MTYHdW5pMDQxNwd1bmkwNDE4B3VuaTA0MTkHdW5pMDQxQQd1bmkwNDBDB3VuaTA0MUIHdW5pMDQxQwd1bmkwNDFEB3VuaTA0MUUHdW5pMDQxRgd1bmkwNDIwB3VuaTA0MjEHdW5pMDQyMgd1bmkwNDIzB3VuaTA0MEUHdW5pMDQyNAd1bmkwNDI1B3VuaTA0MjcHdW5pMDQyNgd1bmkwNDI4B3VuaTA0MjkHdW5pMDQwRgd1bmkwNDJDB3VuaTA0MkEHdW5pMDQyQgd1bmkwNDA5B3VuaTA0MEEHdW5pMDQwNQd1bmkwNDA0B3VuaTA0MkQHdW5pMDQwNgd1bmkwNDA3B3VuaTA0MDgHdW5pMDQwQgd1bmkwNDJFB3VuaTA0MkYHdW5pMDQwMgd1bmkwNDkyB3VuaTA0OUEHdW5pMDRBMgd1bmkwNEFFB3VuaTA0QjAHdW5pMDRCNgd1bmkwNEJBB3VuaTA0RDgHdW5pMDRFOAd1bmkwNDMwB3VuaTA0MzEHdW5pMDQzMgd1bmkwNDMzB3VuaTA0NTMHdW5pMDQ5MQd1bmkwNDM0B3VuaTA0MzUHdW5pMDQ1MQd1bmkwNDM2B3VuaTA0MzcHdW5pMDQzOAd1bmkwNDM5B3VuaTA0M0EHdW5pMDQ1Qwd1bmkwNDNCB3VuaTA0M0MHdW5pMDQzRAd1bmkwNDNFB3VuaTA0M0YHdW5pMDQ0MAd1bmkwNDQxB3VuaTA0NDIHdW5pMDQ0Mwd1bmkwNDVFB3VuaTA0NDQHdW5pMDQ0NQd1bmkwNDQ3B3VuaTA0NDYHdW5pMDQ0OAd1bmkwNDQ5B3VuaTA0NUYHdW5pMDQ0Qwd1bmkwNDRBB3VuaTA0NEIHdW5pMDQ1OQd1bmkwNDVBB3VuaTA0NTUHdW5pMDQ1NAd1bmkwNDREB3VuaTA0NTYHdW5pMDQ1Nwd1bmkwNDU4B3VuaTA0NUIHdW5pMDQ0RQd1bmkwNDRGB3VuaTA0NTIHdW5pMDQ5Mwd1bmkwNDlCB3VuaTA0QTMHdW5pMDRBRgd1bmkwNEIxB3VuaTA0QjcHdW5pMDRCQgd1bmkwNEQ5B3VuaTA0RTkFQWxwaGEEQmV0YQVHYW1tYQd1bmkwMzk0B0Vwc2lsb24EWmV0YQNFdGEFVGhldGEESW90YQVLYXBwYQZMYW1iZGECTXUCTnUCWGkHT21pY3JvbgJQaQNSaG8FU2lnbWEDVGF1B1Vwc2lsb24DUGhpA0NoaQNQc2kHdW5pMDNBOQpBbHBoYXRvbm9zDEVwc2lsb250b25vcwhFdGF0b25vcwlJb3RhdG9ub3MMT21pY3JvbnRvbm9zDFVwc2lsb250b25vcwpPbWVnYXRvbm9zDElvdGFkaWVyZXNpcw9VcHNpbG9uZGllcmVzaXMHdW5pMDNDRgVhbHBoYQRiZXRhBWdhbW1hBWRlbHRhB2Vwc2lsb24EemV0YQNldGEFdGhldGEEaW90YQVrYXBwYQZsYW1iZGEHdW5pMDNCQwJudQJ4aQdvbWljcm9uA3Jobwd1bmkwM0MyBXNpZ21hA3RhdQd1cHNpbG9uA3BoaQNjaGkDcHNpBW9tZWdhCWlvdGF0b25vcwxpb3RhZGllcmVzaXMRaW90YWRpZXJlc2lzdG9ub3MMdXBzaWxvbnRvbm9zD3Vwc2lsb25kaWVyZXNpcxR1cHNpbG9uZGllcmVzaXN0b25vcwxvbWljcm9udG9ub3MKb21lZ2F0b25vcwphbHBoYXRvbm9zDGVwc2lsb250b25vcwhldGF0b25vcwd1bmkwM0Q3B3VuaTAzRDUHdW5pMDNENgZ1MUQ1M0QHdW5pMjExNQd1bmkyMTFBBnUxRDU0QQd1bmkyMTI0CXplcm8uemVybwd1bmkyMDgwB3VuaTIwODEHdW5pMjA4Mgd1bmkyMDgzB3VuaTIwODQHdW5pMjA4NQd1bmkyMDg2B3VuaTIwODcHdW5pMjA4OAd1bmkyMDg5B3VuaTIwNzAHdW5pMDBCOQd1bmkwMEIyB3VuaTAwQjMHdW5pMjA3NAd1bmkyMDc1B3VuaTIwNzYHdW5pMjA3Nwd1bmkyMDc4B3VuaTIwNzkHdW5pMEFFQQd1bmkyMDQ1B3VuaTIwNDYOb25lZG90ZW5sZWFkZXIHdW5pMjAzRQd1bmkyMDNGCmNvbG9uLmNhc2UbcGVyaW9kY2VudGVyZWQubG9jbENBVC5jYXNlFnBlcmlvZGNlbnRlcmVkLmxvY2xDQVQHdW5pMjc3MAd1bmkyNzZFB3VuaTI3NzEHdW5pMjc2Rgd1bmkyMzA4B3VuaTIzMEEHdW5pMjMwOQd1bmkyMzBCB3VuaTI5ODcHdW5pMjk4OAd1bmkwMEFEB3VuaTIwMTAHdW5pMjAzNBJoeXBoZW5faHlwaGVuLmxpZ2EZaHlwaGVuX2h5cGhlbl9oeXBoZW4ubGlnYRpoeXBoZW5faHlwaGVuX2dyZWF0ZXIubGlnYQ9oeXBoZW5fYmFyLmxpZ2ETaHlwaGVuX2dyZWF0ZXIubGlnYRtoeXBoZW5fZ3JlYXRlcl9ncmVhdGVyLmxpZ2EQaHlwaGVuX2xlc3MubGlnYRVoeXBoZW5fbGVzc19sZXNzLmxpZ2EWaHlwaGVuX2FzY2lpdGlsZGUubGlnYRJicmFjZWxlZnRfYmFyLmxpZ2EUYnJhY2tldGxlZnRfYmFyLmxpZ2EVYnJhY2tldGxlZnRfbGVzcy5saWdhHGJyYWNrZXRyaWdodF9udW1iZXJzaWduLmxpZ2EScGVyaW9kX3BlcmlvZC5saWdhGXBlcmlvZF9wZXJpb2RfcGVyaW9kLmxpZ2EXcGVyaW9kX3BlcmlvZF9sZXNzLmxpZ2EUcGVyaW9kX3F1ZXN0aW9uLmxpZ2ERcGVyaW9kX2VxdWFsLmxpZ2EQY29sb25fY29sb24ubGlnYRZjb2xvbl9jb2xvbl9jb2xvbi5saWdhFmNvbG9uX2NvbG9uX2VxdWFsLmxpZ2ETY29sb25fcXVlc3Rpb24ubGlnYRtjb2xvbl9xdWVzdGlvbl9ncmVhdGVyLmxpZ2EQY29sb25fZXF1YWwubGlnYRJjb2xvbl9ncmVhdGVyLmxpZ2EPY29sb25fbGVzcy5saWdhGHNlbWljb2xvbl9zZW1pY29sb24ubGlnYSJzZW1pY29sb25fc2VtaWNvbG9uX3NlbWljb2xvbi5saWdhEmV4Y2xhbV9leGNsYW0ubGlnYRFleGNsYW1fZXF1YWwubGlnYRdleGNsYW1fZXF1YWxfZXF1YWwubGlnYRRxdWVzdGlvbl9wZXJpb2QubGlnYRNxdWVzdGlvbl9jb2xvbi5saWdhFnF1ZXN0aW9uX3F1ZXN0aW9uLmxpZ2EfcXVlc3Rpb25fcXVlc3Rpb25fcXVlc3Rpb24ubGlnYRNxdWVzdGlvbl9lcXVhbC5saWdhH2FzdGVyaXNrX2FzdGVyaXNrX2FzdGVyaXNrLmxpZ2EVYXN0ZXJpc2tfZ3JlYXRlci5saWdhE2FzdGVyaXNrX3NsYXNoLmxpZ2EZbnVtYmVyc2lnbl9wYXJlbmxlZnQubGlnYRludW1iZXJzaWduX2JyYWNlbGVmdC5saWdhG251bWJlcnNpZ25fYnJhY2tldGxlZnQubGlnYRVudW1iZXJzaWduX2NvbG9uLmxpZ2EWbnVtYmVyc2lnbl9leGNsYW0ubGlnYRhudW1iZXJzaWduX3F1ZXN0aW9uLmxpZ2EabnVtYmVyc2lnbl9udW1iZXJzaWduLmxpZ2ElbnVtYmVyc2lnbl9udW1iZXJzaWduX251bWJlcnNpZ24ubGlnYTBudW1iZXJzaWduX251bWJlcnNpZ25fbnVtYmVyc2lnbl9udW1iZXJzaWduLmxpZ2EVbnVtYmVyc2lnbl9lcXVhbC5saWdhGm51bWJlcnNpZ25fdW5kZXJzY29yZS5saWdhJG51bWJlcnNpZ25fdW5kZXJzY29yZV9wYXJlbmxlZnQubGlnYRNzbGFzaF9hc3Rlcmlzay5saWdhHHNsYXNoX2FzdGVyaXNrX2FzdGVyaXNrLmxpZ2EQc2xhc2hfZXF1YWwubGlnYRZzbGFzaF9lcXVhbF9lcXVhbC5saWdhEnNsYXNoX2dyZWF0ZXIubGlnYRBzbGFzaF9zbGFzaC5saWdhFnNsYXNoX3NsYXNoX2VxdWFsLmxpZ2EWc2xhc2hfc2xhc2hfc2xhc2gubGlnYR51bmRlcnNjb3JlX2Jhcl91bmRlcnNjb3JlLmxpZ2EadW5kZXJzY29yZV91bmRlcnNjb3JlLmxpZ2EHdW5pMjdFOAd1bmkyN0VBB3VuaTI3RTYHdW5pMjdFOQd1bmkyN0VCB3VuaTI3RTcJYW5vdGVsZWlhB3VuaTAzN0UGRU1xdWFkB3VuaTAwQTACQ1IHdW5pRkVGRgd1bmkyMEJGBGRvbmcERXVybwd1bmkyMEJEB3VuaTIwQUUHdW5pMjI0Mwd1bmkyMjE5B3VuaTIyNTQHdW5pMjIwMQljb25ncnVlbnQHdW5pMjIxMAd1bmkyM0FBB3VuaTIyQ0UHdW5pMjIyMwd1bmkyMjE1B3VuaTIyMzgHdW5pMjJEMAd1bmkyMkYxB2VsZW1lbnQHdW5pMjJFRQd1bmkyMjBFC2VxdWl2YWxlbmNlB3VuaTIyMzkLZXhpc3RlbnRpYWwHdW5pMjI3Mwd1bmkyM0E5B3VuaTIzQTgHdW5pMjNBNwd1bmkyM0EyB3VuaTIzQTMHdW5pMjNBMQd1bmkyMjcyB3VuaTIyRUYHdW5pMjJCOAd1bmkyMjhFB3VuaTJBMDAHdW5pMkEwNgd1bmkyMjQ3B3VuaTIyODgHdW5pMjI0OQd1bmkyMjBDCm5vdGVsZW1lbnQHdW5pMjI2Rgd1bmkyMjcxB3VuaTIyNjIHdW5pMjI2RQd1bmkyMjcwCW5vdHN1YnNldAd1bmkyMjg1CGVtcHR5c2V0CmxvZ2ljYWxhbmQJbG9naWNhbG9yDGludGVyc2VjdGlvbgV1bmlvbgd1bmkwMEI1B3VuaTIyMjUHdW5pMjM5Qwd1bmkyMzlEB3VuaTIzOUIHdW5pMjM5Rgd1bmkyM0EwB3VuaTIzOUUHdW5pMjA3QQd1bmkyMjdBB3VuaTIyN0MHdW5pMjIzNwd1bmkyMjVGB3VuaTIyMzYMcmVmbGV4c3Vic2V0DnJlZmxleHN1cGVyc2V0B3VuaTI5MTYHdW5pMjNBRAd1bmkyM0FDB3VuaTIzQUIHdW5pMjNBNQd1bmkyM0E2B3VuaTIzQTQHdW5pMjJBMgd1bmkyMjU3B3VuaTIyMTgHc2ltaWxhcgd1bmkyMjkzB3VuaTIyOTQHdW5pMjI5MQd1bmkyMkM2DHByb3BlcnN1YnNldAhzdWNodGhhdAd1bmkyMTQwDnByb3BlcnN1cGVyc2V0B3VuaTIyQTQHdW5pMjI0Qgl1bml2ZXJzYWwHdW5pMjJGMAd1bmkyMkE1B3VuaTIyOUIHdW5pMjI5Ng5jaXJjbGVtdWx0aXBseQd1bmkyMjk5CmNpcmNsZXBsdXMHYXJyb3d1cAd1bmkyMTk3CmFycm93cmlnaHQHdW5pMjE5OAlhcnJvd2Rvd24HdW5pMjE5OQlhcnJvd2xlZnQHdW5pMjE5NglhcnJvd2JvdGgJYXJyb3d1cGRuB3VuaTIxQUQHdW5pMjE5RQd1bmkyMUEwB3VuaTIxQTMHdW5pMjFBNQd1bmkyMUE2B3VuaTIxQTcHdW5pMjFDOQphcnJvd2RibHVwDWFycm93ZGJscmlnaHQMYXJyb3dkYmxkb3duDGFycm93ZGJsYm90aAd1bmkyMUU3B3VuaTIxRTgHdW5pMjMwNAd1bmkyNzlDB3VuaTI3RjUHdW5pMjdGNgd1bmkyN0Y3B3VuaTI1ODEHdW5pMjU4Mgd1bmkyNTgzB2RuYmxvY2sHdW5pMjU4NQd1bmkyNTg2B3VuaTI1ODcFYmxvY2sHdXBibG9jawd1bmkyNTk0B3VuaTI1OEYHdW5pMjU4RQd1bmkyNThEB2xmYmxvY2sHdW5pMjU4Qgd1bmkyNThBB3VuaTI1ODkHcnRibG9jawd1bmkyNTk1B3VuaTI1OTYHdW5pMjU5Nwd1bmkyNTk4B3VuaTI1OTkHdW5pMjU5QQd1bmkyNTlCB3VuaTI1OUMHdW5pMjU5RAd1bmkyNTlFB3VuaTI1OUYHbHRzaGFkZQVzaGFkZQdka3NoYWRlB3VuaTI1Q0YHdW5pMjVFRgd1bmkyNUQ0B3VuaTI1RDUHdW5pMjVDQwd1bmkyNUNFCm9wZW5idWxsZXQHdW5pMjVDNgd1bmkyNUM3CWZpbGxlZGJveAd1bmkyNUExB3VuaTI1QUEHdW5pMjVBQgd1bmkyNUU3B3VuaTI1RTgHdW5pMjVFOQd1bmkyNUVBB3VuaTI1RUIHdHJpYWd1cAd1bmkyNUI2B3RyaWFnZG4HdW5pMjVDMAd1bmkyNUIzB3VuaTI1QjcHdW5pMjVCRAd1bmkyNUMxB3RyaWFncnQHdHJpYWdsZgd1bmkyNUJCB3VuaTI1QzUHdW5pMjVCNAd1bmkyNUI4B3VuaTI1QkUHdW5pMjVDMgd1bmkyNUI1B3VuaTI1QjkHdW5pMjVCRgd1bmkyNUMzB3VuaTI1NjYHdW5pMjU1Nwd1bmkyNTU0B3VuaTI1NTAHdW5pMjU2OQd1bmkyNTVEB3VuaTI1NUEHdW5pMjU1MQd1bmkyNTZDB3VuaTI1NjMHdW5pMjU2MAd1bmkyNTY1B3VuaTI1NTYHdW5pMjU1Mwd1bmkyNTMwB3VuaTI1MTIHdW5pMjUyNwd1bmkyNTBFB3VuaTI1MUYHdW5pMjU0MQd1bmkyNTJGB3VuaTI1MTEHdW5pMjUyOQd1bmkyNTBEB3VuaTI1MjEHdW5pMjU0Nwd1bmkyNTY0B3VuaTI1NTUHdW5pMjU1Mgd1bmkyNTREB3VuaTI1NEYHdW5pMjU3Qgd1bmkyNTMzB3VuaTI1MTMHdW5pMjUwRgd1bmkyNTAxB3VuaTI1NzgHdW5pMjU3RQd1bmkyNTA5B3VuaTI1MEIHdW5pMjU3QQd1bmkyNTA1B3VuaTI1MDcHdW5pMjU3OQd1bmkyNTNCB3VuaTI1MUIHdW5pMjU3Rgd1bmkyNTE3B3VuaTI1MDMHdW5pMjU0Qgd1bmkyNTJCB3VuaTI1MjMHdW5pMjU0NQd1bmkyNTJEB3VuaTI1MzUHdW5pMjUzRAd1bmkyNTMyB3VuaTI1M0EHdW5pMjU0QQd1bmkyNTQzB3VuaTI1NkUHdW5pMjU2RAd1bmkyNTZGB3VuaTI1NzAHdW5pMjU3Mwd1bmkyNTcyB3VuaTI1NzEHdW5pMjU0Qwd1bmkyNTRFB3VuaTI1NzcHdW5pMjUyQwd1bmkyNTEwB3VuaTI1MEMHdW5pMjUwMAd1bmkyNTc0B3VuaTI1N0MHdW5pMjUwOAd1bmkyNTBBB3VuaTI1NzYHdW5pMjUwNAd1bmkyNTA2B3VuaTI1NzUHdW5pMjU3RAd1bmkyNTM0B3VuaTI1MTgHdW5pMjUxNAd1bmkyNTAyB3VuaTI1M0MHdW5pMjUyNAd1bmkyNTFDB3VuaTI1NDYHdW5pMjUyRQd1bmkyNTM2B3VuaTI1M0UHdW5pMjUzMQd1bmkyNTM5B3VuaTI1NDkHdW5pMjU0NAd1bmkyNTY4B3VuaTI1NUMHdW5pMjU1OQd1bmkyNTQwB3VuaTI1MzgHdW5pMjUyNgd1bmkyNTFBB3VuaTI1MUUHdW5pMjUxNgd1bmkyNTQ4B3VuaTI1MzcHdW5pMjUyQQd1bmkyNTE5B3VuaTI1MjIHdW5pMjUxNQd1bmkyNTY3B3VuaTI1NUIHdW5pMjU1OAd1bmkyNTZCB3VuaTI1NjIHdW5pMjU1Rgd1bmkyNTQyB3VuaTI1MjgHdW5pMjUyMAd1bmkyNTNGB3VuaTI1MjUHdW5pMjUxRAd1bmkyNTZBB3VuaTI1NjEHdW5pMjU1RQd1bmkyMzczB3VuaTIzNzQHdW5pMjM2OAd1bmkyNkEwB3VuaTI2QTEHdW5pMjcxMwd1bmkyNzE1B3VuaTI3MTcHdW5pMjczNhJhY2tub3dsZWRnZWNvbnRyb2wQYmFja3NwYWNlY29udHJvbAZtaW51dGUGc2Vjb25kB3VuaTIxMTMHdW5pMjExNgllc3RpbWF0ZWQLYmVsbGNvbnRyb2wNY2FuY2VsY29udHJvbBVjYXJyaWFnZVJldHVybmNvbnRyb2wHdW5pMjMwMxVkYXRhTGlua0VzY2FwZWNvbnRyb2wNZGVsZXRlY29udHJvbBhkZXZpY2VDb250cm9sRm91cmNvbnRyb2wXZGV2aWNlQ29udHJvbE9uZWNvbnRyb2wZZGV2aWNlQ29udHJvbFRocmVlY29udHJvbBdkZXZpY2VDb250cm9sVHdvY29udHJvbBJlbmRPZk1lZGl1bWNvbnRyb2wQZW5kT2ZUZXh0Y29udHJvbBhlbmRPZlRyYW5zbWlzc2lvbmNvbnRyb2wdZW5kT2ZUcmFuc21pc3Npb25CbG9ja2NvbnRyb2wOZW5xdWlyeWNvbnRyb2wNZXNjYXBlY29udHJvbBRmaWxlU2VwYXJhdG9yY29udHJvbA9mb3JtRmVlZGNvbnRyb2wVZ3JvdXBTZXBhcmF0b3Jjb250cm9sG2hvcml6b250YWxUYWJ1bGF0aW9uY29udHJvbAVob3VzZQd1bmkyMzI1B3VuaTIzMTgPbGluZUZlZWRjb250cm9sGm5lZ2F0aXZlQWNrbm93bGVkZ2Vjb250cm9sDm5ld2xpbmVjb250cm9sC251bGxjb250cm9sB3VuaTIzRkIHdW5pMjNGQwd1bmkyQjU4B3VuaTIzRkQHdW5pMjNGRQd1bmkyMzA1FnJlY29yZFNlcGFyYXRvcmNvbnRyb2wLcmVwbGFjZW1lbnQOc2hpZnRJbmNvbnRyb2wPc2hpZnRPdXRjb250cm9sDHNwYWNlY29udHJvbBVzdGFydE9mSGVhZGluZ2NvbnRyb2wSc3RhcnRPZlRleHRjb250cm9sEXN1YnN0aXR1dGVjb250cm9sFnN5bmNocm9ub3VzSWRsZWNvbnRyb2wHdW5pMjE4Qgd1bmkyMThBFHVuaXRTZXBhcmF0b3Jjb250cm9sGXZlcnRpY2FsVGFidWxhdGlvbmNvbnRyb2wLdW5pMjZBMC4wMDEHdW5pMDJGMwd1bmkwMkY3EmF0X3VuZGVyc2NvcmUubGlnYRhhbXBlcnNhbmRfYW1wZXJzYW5kLmxpZ2EiYW1wZXJzYW5kX2FtcGVyc2FuZF9hbXBlcnNhbmQubGlnYRRhbXBlcnNhbmRfZXF1YWwubGlnYQ9iYXJfaHlwaGVuLmxpZ2EXYmFyX2h5cGhlbl9ncmVhdGVyLmxpZ2ETYmFyX2JyYWNlcmlnaHQubGlnYRViYXJfYnJhY2tldHJpZ2h0LmxpZ2EMYmFyX2Jhci5saWdhE2Jhcl9iYXJfaHlwaGVuLmxpZ2EQYmFyX2Jhcl9iYXIubGlnYRhiYXJfYmFyX2Jhcl9ncmVhdGVyLmxpZ2ESYmFyX2Jhcl9lcXVhbC5saWdhFGJhcl9iYXJfZ3JlYXRlci5saWdhDmJhcl9lcXVhbC5saWdhFmJhcl9lcXVhbF9ncmVhdGVyLmxpZ2EQYmFyX2dyZWF0ZXIubGlnYRNkb2xsYXJfZ3JlYXRlci5saWdhDnBsdXNfcGx1cy5saWdhE3BsdXNfcGx1c19wbHVzLmxpZ2ERcGx1c19ncmVhdGVyLmxpZ2EQZXF1YWxfY29sb24ubGlnYRZlcXVhbF9jb2xvbl9lcXVhbC5saWdhF2VxdWFsX2V4Y2xhbV9lcXVhbC5saWdhEGVxdWFsX2VxdWFsLmxpZ2EWZXF1YWxfZXF1YWxfZXF1YWwubGlnYRhlcXVhbF9lcXVhbF9ncmVhdGVyLmxpZ2ESZXF1YWxfZ3JlYXRlci5saWdhGmVxdWFsX2dyZWF0ZXJfZ3JlYXRlci5saWdhFGVxdWFsX2xlc3NfbGVzcy5saWdhFmVxdWFsX3NsYXNoX2VxdWFsLmxpZ2ETZ3JlYXRlcl9oeXBoZW4ubGlnYRtncmVhdGVyX2h5cGhlbl9ncmVhdGVyLmxpZ2EZZ3JlYXRlcl9icmFja2V0cmlnaHQubGlnYRJncmVhdGVyX2NvbG9uLmxpZ2ESZ3JlYXRlcl9lcXVhbC5saWdhGmdyZWF0ZXJfZXF1YWxfZ3JlYXRlci5saWdhFGdyZWF0ZXJfZ3JlYXRlci5saWdhG2dyZWF0ZXJfZ3JlYXRlcl9oeXBoZW4ubGlnYRpncmVhdGVyX2dyZWF0ZXJfZXF1YWwubGlnYRxncmVhdGVyX2dyZWF0ZXJfZ3JlYXRlci5saWdhEGxlc3NfaHlwaGVuLmxpZ2EXbGVzc19oeXBoZW5faHlwaGVuLmxpZ2EUbGVzc19oeXBoZW5fYmFyLmxpZ2EYbGVzc19oeXBoZW5fZ3JlYXRlci5saWdhFWxlc3NfaHlwaGVuX2xlc3MubGlnYQ9sZXNzX2NvbG9uLmxpZ2EUbGVzc19jb2xvbl9sZXNzLmxpZ2EebGVzc19leGNsYW1faHlwaGVuX2h5cGhlbi5saWdhEmxlc3NfYXN0ZXJpc2subGlnYRpsZXNzX2FzdGVyaXNrX2dyZWF0ZXIubGlnYQ1sZXNzX2Jhci5saWdhEWxlc3NfYmFyX2Jhci5saWdhFWxlc3NfYmFyX2Jhcl9iYXIubGlnYRVsZXNzX2Jhcl9ncmVhdGVyLmxpZ2EQbGVzc19kb2xsYXIubGlnYRhsZXNzX2RvbGxhcl9ncmVhdGVyLmxpZ2EibGVzc19udW1iZXJzaWduX2h5cGhlbl9oeXBoZW4ubGlnYQ5sZXNzX3BsdXMubGlnYRZsZXNzX3BsdXNfZ3JlYXRlci5saWdhD2xlc3NfZXF1YWwubGlnYRNsZXNzX2VxdWFsX2Jhci5saWdhFWxlc3NfZXF1YWxfZXF1YWwubGlnYR1sZXNzX2VxdWFsX2VxdWFsX2dyZWF0ZXIubGlnYRdsZXNzX2VxdWFsX2dyZWF0ZXIubGlnYRRsZXNzX2VxdWFsX2xlc3MubGlnYRFsZXNzX2dyZWF0ZXIubGlnYQ5sZXNzX2xlc3MubGlnYRVsZXNzX2xlc3NfaHlwaGVuLmxpZ2EUbGVzc19sZXNzX2VxdWFsLmxpZ2ETbGVzc19sZXNzX2xlc3MubGlnYRlsZXNzX2xlc3NfYXNjaWl0aWxkZS5saWdhFGxlc3NfYXNjaWl0aWxkZS5saWdhHGxlc3NfYXNjaWl0aWxkZV9ncmVhdGVyLmxpZ2EfbGVzc19hc2NpaXRpbGRlX2FzY2lpdGlsZGUubGlnYQ9sZXNzX3NsYXNoLmxpZ2EXbGVzc19zbGFzaF9ncmVhdGVyLmxpZ2EWYXNjaWl0aWxkZV9oeXBoZW4ubGlnYRJhc2NpaXRpbGRlX2F0LmxpZ2EXYXNjaWl0aWxkZV9ncmVhdGVyLmxpZ2EaYXNjaWl0aWxkZV9hc2NpaXRpbGRlLmxpZ2EiYXNjaWl0aWxkZV9hc2NpaXRpbGRlX2dyZWF0ZXIubGlnYRZhc2NpaWNpcmN1bV9lcXVhbC5saWdhB3VuaTI2NkQHdW5pMjY2Rgd1bmkwMzc0B3VuaTAzNzUHdW5pMDJCQwd1bmkwMkJBB3VuaTAyQzkHdW5pMDJCOQd1bmkwMzA4B3VuaTAzMDcJZ3JhdmVjb21iCWFjdXRlY29tYgd1bmkwMzBCC3VuaTAzMEMuYWx0B3VuaTAzMDIHdW5pMDMwQwd1bmkwMzA2B3VuaTAzMEEJdGlsZGVjb21iB3VuaTAzMDQNaG9va2Fib3ZlY29tYgd1bmkwMzBGB3VuaTAzMTIHdW5pMDMxQgxkb3RiZWxvd2NvbWIHdW5pMDMyNQd1bmkwMzI2B3VuaTAzMjcHdW5pMDMyOAd1bmkwMzM2B3VuaTAzMzcHdW5pMDMzOAt1bmkwMzI2LmFsdAx1bmkwMzA4LmNhc2UMdW5pMDMwNy5jYXNlDmdyYXZlY29tYi5jYXNlDmFjdXRlY29tYi5jYXNlDHVuaTAzMEIuY2FzZQx1bmkwMzAyLmNhc2UMdW5pMDMwQy5jYXNlDHVuaTAzMDYuY2FzZQx1bmkwMzBBLmNhc2UOdGlsZGVjb21iLmNhc2UMdW5pMDMwNC5jYXNlEmhvb2thYm92ZWNvbWIuY2FzZQx1bmkwMzBGLmNhc2UMdW5pMDMxMS5jYXNlDHVuaTAzMTIuY2FzZQx1bmkwMzFCLmNhc2URZG90YmVsb3djb21iLmNhc2UMdW5pMDMyNC5jYXNlDHVuaTAzMjYuY2FzZQx1bmkwMzI3LmNhc2UMdW5pMDMyOC5jYXNlDHVuaTAzMkUuY2FzZQx1bmkwMzMxLmNhc2UNZGllcmVzaXMuY2FzZQ5kb3RhY2NlbnQuY2FzZQpncmF2ZS5jYXNlCmFjdXRlLmNhc2URaHVuZ2FydW1sYXV0LmNhc2UPY2lyY3VtZmxleC5jYXNlCmNhcm9uLmNhc2UKYnJldmUuY2FzZQlyaW5nLmNhc2UKdGlsZGUuY2FzZQttYWNyb24uY2FzZQV0b25vcwp0b25vcy5jYXNlDWRpZXJlc2lzdG9ub3MLYnJldmVjb21iY3kLdW5pMDMwNjAzMDELdW5pMDMwNjAzMDALdW5pMDMwNjAzMDkLdW5pMDMwNjAzMDMLdW5pMDMwMjAzMDELdW5pMDMwMjAzMDALdW5pMDMwMjAzMDkLdW5pMDMwMjAzMDMQdW5pMDMwNjAzMDEuY2FzZRB1bmkwMzA2MDMwMC5jYXNl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AiYACgAAAAIAB4AAAAP+2wFFHYYACgACADiAAAAB/tUBGAAB/tQBEwAD/xwC2gAKAAAAAgACgAAB2ht4AAAbfhqcAAAU5AAAG34anAAAGW4AABt+GpwAABKGAAAbfhqcAAAZbgAAGHAanAAAEoYAABt+GpwAABKGAAAbfhqcAAAT9gAAG34anAAAFO4AABt+GpwAABTuAAAbfhqcAAAT2AAAG34anAAAFO4AABhwGpwAABPiAAAbfhqcAAAT7AAAG34anAAAE/YAABt+GpwAABraAAAbfhqcAAAbeAAAGHAanAAAFLYAABt+GpwAABTGAAAbfhqcAAAU0AAAG34anAAAG3gAABt+GpwAABSiAAAbfhqcAAAU2gAAG34anAAAG3gAABt+AAAAABTkAAAbfgAAAAAbeAAAG34AAAAAGWgAABtCAAAAABKMAAAbQgAAAAASlgAAG0IAAAAAGWgAABtCAAAAABKWAAAbQgAAAAASnAAAG0IAAAAAG3gAABt+AAAazht4AAAbfgAAGs4U7gAAG34AABrOG3gAABt+AAAazhqsAAAashq4AAAZRAAAGrIauAAAEqYAABqyGrgAABK6AAAashq4AAASugAAGrIauAAAErAAABqyGrgAABK6AAAS5Bq4AAASwAAAGrIauAAAEsoAABqyGrgAABLUAAAashq4AAAZVAAAGrIauAAAEtoAABqyGrgAABqsAAAS5Bq4AAAS7gAAGrIauAAAEvgAABqyGrgAABMCAAAashq4AAAarAAAGrIauAAAEwwAABqyGrgAABt4AAAbfgAAAAATQAAAE3AAAAAAExYAABNwAAAAABMmAAATcAAAAAATNgAAE3AAAAAAEzYAABNwAAAAABNAAAATUAAAAAATYAAAE3AAAAAAG3gAABt+AAAazht4AAAbfgAAGs4U7gAAG34AABrOG3gAABt+GtQAABTkAAAbfhrUAAAZbgAAG34a1AAAFO4AABt+GtQAABraAAAbfhrUAAAU9AAAG34a1AAAG3gAABhwGtQAABS2AAAbfhrUAAAUxgAAG34a1AAAFNAAABt+GtQAABt4AAAbfhrUAAAU2gAAG34a1AAAGYgAABt+AAAAABN6AAAbfgAAAAAbeAAAG34AAAAAG3gAABcgAAAAABOeAAATqAAAGs4ThAAAE6gAABrOE54AABOoAAAazhOeAAATlAAAGs4TngAAE6gAABrOE64AABO+AAATyBt4AAAbfgAAAAAbeAAAG34AAAAAFOQAABt+AAAAABTuAAAbfgAAAAAbeAAAFyAAAAAAFNoAABt+AAAAABt4GsgbfhswGs4U5BrIG34bMBrOGW4ayBt+GzAazhTuGsgbfhswGs4T2BrIG34bMBrOFO4ayBhwGzAazhPiGsgbfhswGs4T7BrIG34bMBrOE/YayBt+GzAazhraGsgbfhswGs4beBrIGHAbMBrOFLYayBt+GzAazhTGGsgbfhswGs4UDBrIG34bMBrOE/wayBt+GzAazhQMGsgYcBswGs4UHBrIG34bMBrOFCwayBt+GzAazhQ8GsgbfhswGs4UnBrIG34bMBrOFNAayBt+GzAazht4GsgAAAAAAAAbeBqsG34AAAAAFOQarBt+AAAAABTaGsgbfhswGs4beAAAG34AAAAAG3gAABt+AAAAABt4AAAbfgAAAAAU5AAAG34AAAAAFO4AABt+AAAAABt4AAAXIAAAAAAbeAAAG34AAAAAFOQAABt+AAAAABTuAAAbfgAAAAAbeAAAG34AAAAAFO4AABt+AAAAABt4AAAXIAAAAAAbeAAAG34AABrOG3gAABt+AAAazhTuAAAbfgAAGs4beAAAG34AABrOG3gAABcgAAAazht4FKwbfhswAAAU5BSsG34bMAAAGW4UrBt+GzAAABTuFKwbfhswAAAa2hSsG34bMAAAG3gUrBhwGzAAABS2FKwbfhswAAAUxhSsG34bMAAAFFwUrBt+GzAAABRMFKwbfhswAAAUXBSsGHAbMAAAFGwUrBt+GzAAABR8FKwbfhswAAAUjBSsG34bMAAAFJwUrBt+GzAAABTQFKwbfhswAAAbeBSsAAAAAAAAFKIUrBt+GzAAABTaFKwbfhswAAAbeAAAG34AAAAAG3gAABt+AAAAABTkAAAbfgAAAAAU7gAAG34AAAAAGtoAABt+AAAAABS2AAAbfgAAAAAbeAAAG34AAAAAG3gAABt+AAAAABTkAAAbfgAAAAAU7gAAG34AAAAAGtoAABt+AAAAABt4AAAYcAAAAAAUtgAAG34AAAAAFMYAABt+AAAAABTQAAAbfgAAAAAU2gAAG34AAAAAG3gAABt+AAAazhTkAAAbfgAAGs4U7gAAG34AABrOFPQAABt+AAAazhs8AAAbQhtIAAAU/gAAG0IbSAAAFTYAABtCG0gAABUIAAAbQhtIAAAVNgAAFWQbSAAAFQgAABtCG0gAABUSAAAbQhtIAAAVHAAAG0IbSAAAFSYAABtCG0gAABU2AAAbQhtIAAAVLAAAG0IbSAAAFTYAABVkG0gAABU8AAAbQhtIAAAVRgAAG0IbSAAAFVAAABtCG0gAABVaAAAbQhtIAAAbPAAAFWQbSAAAFW4AABtCG0gAABV4AAAbQhtIAAAVggAAG0IbSAAAGzwAABtCG0gAABWMAAAbQhtIAAAVlgAAG0IbSAAAGxoAAAAAAAAAABoGAAAAAAAAAAAbeAAAG34AAAAAG14AABtoAAAAABWgAAAbaAAAAAAVsAAAG2gAAAAAG14AABtoAAAAABW6AAAbaAAAAAAVxAAAG2gAAAAAG3gAABt+AAAbNhsaAAAbfhswAAAaBgAAG34bMAAAGPoAABt+GzAAABoqAAAbfhswAAAY+gAAG34bMAAAFzQAABt+GzAAABj6AAAYcBswAAAXPgAAG34bMAAAF0gAABt+GzAAABdSAAAbfhswAAAbAAAAG34bMAAAGwAAABt+GzAAABsaAAAYcBswAAAZEAAAG34bMAAAGSAAABt+GzAAABkqAAAbfhswAAAbGgAAAAAAAAAAGToAABt+GzAAABt4AAAbfgAAAAAV1AAAFgQAAAAAFdoAABYEAAAAABXqAAAWBAAAAAAV5AAAFgQAAAAAFeoAABYEAAAAABXwAAAWBAAAAAAV+gAAFgQAAAAAG3gAABt+AAAazhYKAAAbfgAAGs4aUAAAG34aagAAFiAAABpgGmoAABYqAAAaYBpqAAAWRAAAGmAaagAAFjoAABpgGmoAABZEAAAaYBpqAAAaUAAAGmAaagAAGlAAABpgGmoAABpQAAAWThpqAAAWWAAAGmAaagAAFmIAABpgGmoAABZyAAAaYBpqAAAaUAAAGmAaagAAFoIAABpgGmoAABpwAAAAAAAAAAAWkgAAAAAAAAAAFpwAAAAAAAAAABt4AAAbfgAAAAAbeAAAFyAAAAAAGxoAAAAAAAAAABbmAAAW9gAAGs4WrAAAFvYAABrOFuYAABb2AAAazhbmAAAWvAAAGs4WzAAAFtYAABbgFuYAABb2AAAazhuEAAAbfgAAAAAbhAAAG34AAAAAFwYAABt+AAAAABuE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PbQAAQAAADEAAQAAAAEACAACAKQAAgLIBU4ABgAAAAcAFAAkADQARABUAGQAdgADAAE9egABPXoAAT7sAAAAAwABPtwAAT1qAAE+3AAAAAMAASkIAAE9WgABPswAAAADAAAAAT1KAAI+vD68AAAAAwAAAAE9OgACPqw9OgAAAAMAAUMyAAE+nAAAAAEAAAA0AAMAAAABPRgAAT6KAAEAAAA0AAEAAAABAAgAAgAKAAIFTgK6AAEAAgJlAmsABgAAAAUAEAAiADQASABcAAMAATzcAAE83AACPNw83AAAAAMAAAABPMoAAzzKPMo8ygAAAAMAAkLAQsAAATy4AAAAAQAAADYAAwABQqwAATykAAE8pAABAAAANwADAAAAATyQAAI8kDyQAAEAAAA4AAEAAAABAAgAATx0AFMAAQAAAAEACAABPGYC6QAGAAAABAAOAB4ALgBAAAMAATrmAAE65gABOuYAAAADAAAAATrWAAI61jrWAAAAAwABQjoAATrGAAAAAQAAADoAAwAAAAE6tAABOrQAAQAAADsAAQAAAAEACAABOpoBjAAGAAAABQAQACIANABIAFwAAwABOoQAATqEAAI6hDqEAAAAAwAAAAE6cgADOnI6cjpyAAAAAwACQdRB1AABOmAAAAABAAAAPQADAAFBwAABOkwAATpMAAEAAAA+AAMAAAABOjgAAjo4OjgAAQAAAD8AAQAAAAEACAABOhwBjQABAAAAAQAIAAE6DgI5AAYAAAAEAA4AHgAuAEAAAwABJxQAAScUAAE+oAAAAAMAAAABJwQAAj6QPpAAAAADAAFBTgABPoAAAAABAAAAQQADAAAAASbiAAE+bgABAAAAQQABAAAAAQAIAAIk/gACBU4CpAAGAAAABQAQACAAMABAAFIAAwABJq4AASauAAEmrgAAAAMAAAABJp4AAiaeJp4AAAADAAAAASaOAAImjjvgAAAAAwABQNgAASZ+AAAAAQAAAEMAAwAAAAEmbAABJmwAAQAAAEQAAQAAAAEACAABJlIARwAGAAAABQAQACIANABIAFwAAwABJjwAASY8AAImPCY8AAAAAwAAAAEmKgADJiomKiYqAAAAAwACQHJAcgABJhgAAAABAAAARgADAAFAXgABJgQAASYEAAEAAABHAAMAAAABJfAAAiXwJfAAAQAAAEgAAQAAAAEACAAB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AAEAAABpAAEAAAABAAgAAiHAAAMFTgTPBU4ABgAAAAUAEAAiADQASABcAAMAATPyAAEz8gACLcQ0agAAAAMAAAABM+AAAy2yNFg0WAAAAAMAAjjWONYAATRGAAAAAQAAAGsAAwABOMIAAS2MAAE0MgABAAAAawADAAAAATOmAAIteDQeAAEAAABrAAEAAAABAAgAAgAMAAMFTgS7BU4AAQADAoEDGwMcAAYAAAAGABIAJgA6AFAAZgB8AAMAATNiAAEzYgADKq4qriquAAAAAwAAAAEzTgAEKpoqmiqaKpoAAAADAAM4QjhCOEIAASqGAAAAAQAAAG0AAwACOCw4LAABKnAAASpwAAEAAABuAAMAATgWAAEqWgACKloqWgABAAAAbwADAAAAATL4AAMqRCpEKkQAAQAAAG0AAQAAAAEACAACAQYAAgVOBMQABgAAAAYAEgCkACQANgBKAF4AAwABMr4AATK+AAIqCioKAAAAAwAAAAEyrAADKfgp+DMkAAAAAwACN6I3ogABKeYAAAABAAAAcQADAAE3jgABKdIAASnSAAEAAAByAAMAAAABMnIAAim+Kb4AAQAAAHEAAQAAAAEACAACAIIAAgVOBMMABgAAAAUAEAAgADIAQgBUAAMAATI8AAEyPAABKYgAAAADAAAAATIsAAMpeCl4KXgAAAADAAAAATIaAAIpZjKSAAAAAwABNxIAASlWAAAAAQAAAHQAAwAAAAEx+AABKUQAAQAAAHQAAQAAAAEACAACAAoAAgVOBMIAAQACAxwEVwAGAAAABQAQACAAMABAAFIAAwABK44AASuOAAEpCAAAAAMAATGsAAErfgABKPgAAAADAAAAAStuAAIo6CjoAAAAAwABNpQAASjYAAAAAQAAAHYAAwAAAAErTAABKMYAAQAAAHYAAQAAAAEACAACFMQAAgVOApcABgAAAAUAEAAiADQASABcAAMAASsYAAErGAACMb4xvgAAAAMAAAABKwYAAzGsMawxrAAAAAMAAjYqNioAATGaAAAAAQAAAHgAAwABNhYAATGGAAExhgABAAAAeQADAAAAASrMAAIxcjFyAAEAAAB4AAEAAAABAAgAAiKcAAIFTgKZAAYAAAAGFWQAEgAkADYASgBeAAMAASqUAAEqlAACKpQxOgAAAAMAAAABKoIAAyqCMSgxKAAAAAMAAjWmNaYAATEWAAAAAQAAAHsAAwABNZIAASpcAAExAgABAAAAewADAAAAASpIAAIqSDDuAAEAAAB8AAEAAAABAAgAAiIYAAIFTgKWAAYAAAAIABYAJgA2AEYAVgBmAHYAiAADAAExlgABKgwAATCyAAAAAwABKfwAASn8AAEwogAAAAMAATCSAAEp7AABMJIAAAADAAEnVgABKdwAATCCAAAAAwAAAAEpzAACMHIwcgAAAAMAAS1+AAEpvAABMGIAAAADAAE04gABMFIAAAABAAAAfgADAAAAASmaAAEwQAABAAAAfgABAAAAAQAIAAIhbAACBU4CmAAGAAAACAAWACYANgBGAFYAZgB2AIgAAwABMAYAATAGAAEwBgAAAAMAAAABL/YAAi/2L/YAAAADAAAAAS/mAAIv5jN8AAAAAwAAAAEv1gACL9YpMAAAAAMAATNcAAEvxgABL8YAAAADAAEvsAABL7YAAS+2AAAAAwABNDYAAS+mAAAAAQAAAIAAAwAAAAEvlAABL5QAAQAAAIEAAQAAAAEACAABL3oBmQAGAAAABQAQACIANABIAFwAAwABL2QAAS9kAAIvZC9kAAAAAwAAAAEvUgADL1IvUi9SAAAAAwACM9Az0AABL0AAAAABAAAAgwADAAEzvAABLywAAS8sAAEAAACEAAMAAAABLxgAAi8YLxgAAQAAAIUAAQAAAAEACAABLvwBnAAGAAAABgASACIAMgBCAFIAZAADAAEu5AABLuQAATJ6AAAAAwAAAAEu1AACMmoyagAAAAMAAAABLsQAAjJaLsQAAAADAAAAAS60AAIySi48AAAAAwABMzQAATI6AAAAAQAAAIcAAwAAAAEukgABMigAAQAAAIcAAQAAAAEACAACHioAAgSyBU4ABgAAAAQADgAeAC4AQAADAAEuYAABLmAAATGEAAAAAwAAAAEuUAACMXQxdAAAAAMAATLQAAExZAAAAAEAAACJAAMAAAABLi4AATFSAAEAAACJAAEAAAABAAgAAgnYAAIEsQVOAAYAAAAJABgAKAA4AEgAWABoAHgAiACaAAMAAS3yAAEt8gABMpoAAAADAAEq/gABLeIAATKKAAAAAwABLFoAAS3SAAEyegAAAAMAASlyAAEtwgABMmoAAAADAAEtrAABLbIAATJaAAAAAwABMTgAAS2iAAEySgAAAAMAAAABLZIAAjI6MjoAAAADAAEyEgABMioAAAABAAAAiwADAAAAAS1wAAEyGAABAAAAiwABAAAAAQAIAAIACgACBLAFTgABAAICdgMbAAYAAAAHABQAJAA0AEQAVgBmAHgAAwAAAAEsuAACMMYsuAAAAAMAAAABLKgAAjC2I/QAAAADAAEsmAABLJgAATCmAAAAAwACLsIxLAABLIgAATCWAAAAAwAAAAEsdgACMIQwhAAAAAMAATFuAAEwdAAAAAEAAACNAAMAAAABLFQAATBiAAEAAACNAAEAAAABAAgAAiFAAAIEywVOAAYAAAAFABAAIgA0AEYAWgADAAAAASwgAAMsIDAuMC4AAAADAAEsDgABLA4AAiwOMBwAAAADAAExBAABMAoAAAABAAAAjwADAAEw8gABK+oAAS/4AAEAAACPAAMAAAABK9YAAivWL+QAAQAAAJAAAQAAAAEACAACIMAAAgTUBU4ABgAAAAcAFAAmADoATABeAHIAhgADAAErnAABK5wAAi+qL6oAAAADAAItxDAuAAErigACL5gvmAAAAAMAAAABK3YAAy+EL4QvhAAAAAMAAAABK2QAAy9yL3Ir3AAAAAMAAjBaMFoAAS9gAAAAAQAAAJIAAwABMEYAAS9MAAEvTAABAAAAkwADAAAAASsqAAIvOC84AAEAAACSAAEAAAABAAgAAiAUAAIEzQVOAAYAAAAFABAAIgA0AEgAXAADAAEq9AABKvQAAiJAK2wAAAADAAAAASriAAMiLitaK1oAAAADAAIv2C/YAAErSAAAAAEAAACVAAMAAS/EAAEiCAABKzQAAQAAAJUAAwAAAAEqqAACIfQrIAABAAAAlQABAAAAAQAIAAIADAADBMUFTgVOAAEAAwMbAxwEVwAGAAAABQAQACIANABIAFwAAwABLwQAAS8EAAIhsi8EAAAAAwAAAAEu8gADIaAu8i7yAAAAAwACL0ovSgABLuAAAAABAAAAlwADAAEvNgABIXoAAS7MAAEAAACXAAMAAAABLrgAAiFmLrgAAQAAAJgAAQAAAAEACAACAAoAAgLPBU4AAQACAoYEVwAGAAAABwAUACQANgBKAFoAagB8AAMAAS0CAAEtAgABLeYAAAADAAIsAi5sAAEs8gABLdYAAAADAAMptivwLloAASzgAAEtxAAAAAMAAS2wAAEszAABLbAAAAADAAAAASy8AAItoC2gAAAAAwABLooAAS2QAAAAAQAAAJoAAwAAAAEsmgABLX4AAQAAAJoAAQAAAAEACAACAeoAAgVOArEABgAAAAYAEgAiADQASABYAGoAAwABLGQAASxkAAEsZAAAAAMAAitkLc4AASxUAAEsVAAAAAMAAykYK1ItvAABLEIAASxCAAAAAwAAAAEsLgACLC4sLgAAAAMAAS38AAEsHgAAAAEAAACcAAMAAAABLAwAASwMAAEAAACdAAEAAAABAAgAASvyAFEAAQAAAAEACAABK+QC7wAGAAAABwAUACYAOgBQAGIAdgCKAAMAASvKAAErygACLK4srgAAAAMAAirILTIAASu4AAIsnCycAAAAAwADKHoqtC0eAAErpAACLIgsiAAAAAMAAAABK44AAyxyLHIscgAAAAMAAi1aLVoAASxgAAAAAQAAAJ8AAwABLUYAASxMAAEsTAABAAAAoAADAAAAAStUAAIsOCw4AAEAAACfAAEAAAABAAgAAgCiAAIFTgKyAAYAAAAGABIAJAA4AEoAXgByAAMAASwAAAEsAAACKxwsAAAAAAMAAioaLIQAASvuAAIrCivuAAAAAwAAAAEr2gADKvYr2ivaAAAAAwACLMIswgABK8gAAAABAAAAogADAAEsrgABKtAAASu0AAEAAACiAAMAAAABK6AAAiq8K6AAAQAAAKMAAQAAAAEACAACAAoAAgVOBKYAAQACAl8DGQAGAAAACgAaACoAOgBKAFoAbgCAAJAAoACyAAMAASimAAErWAABJ8IAAAADAAErSAABK0gAASeyAAAAAwABJ6IAASs4AAEnogAAAAMAAR5mAAErKAABJ5IAAAADAAMnCilEK64AASsYAAEnggAAAAMAAikwK5oAASsEAAEnbgAAAAMAAAABKvIAAidcKvIAAAADAAAAASriAAInTCdMAAAAAwABK8wAASc8AAAAAQAAAKUAAwAAAAEqwAABJyoAAQAAAKUAAQAAAAEACAACFsIAAgVOBKoABgAAAAcAFAAkADgASgBaAGoAfAADAAEqiAABKogAASqIAAAAAwADJmoopCsOAAEqeAABKngAAAADAAIokCr6AAEqZAABKmQAAAADAAAAASpSAAIqUipSAAAAAwAAAAEqQgACKkImrAAAAAMAASssAAEqMgAAAAEAAACnAAMAAAABKiAAASogAAEAAACoAAEAAAABAAgAASoGAY4ABgAAAAgAFgAoADwATgBgAHIAhgCaAAMAASnqAAEp6gACKeop6gAAAAMAAigEKm4AASnYAAIp2CnYAAAAAwABJbYAASnEAAIpxCnEAAAAAwAAAAEpsgADKbIpsimyAAAAAwAAAAEpoAADKaApoCYKAAAAAwACKogqiAABKY4AAAABAAAAqgADAAEqdAABKXoAASl6AAEAAACrAAMAAAABKWYAAilmKWYAAQAAAKwAAQAAAAEACAABKUoBjwAGAAAABgASACQAOABKAF4AcgADAAEpMgABKTIAAijAKTIAAAADAAInTCm2AAEpIAACKK4pIAAAAAMAAAABKQwAAyiaKQwpDAAAAAMAAin0KfQAASj6AAAAAQAAAK4AAwABKeAAASh0AAEo5gABAAAArgADAAAAASjSAAIoYCjSAAEAAACvAAEAAAABAAgAAgTSAAIFTgSlAAYAAAAFABAAIAAwAEAAUgADAAEonAABKCoAASicAAAAAwABKBoAASgaAAEojAAAAAMAAAABKAoAAih8KHwAAAADAAEpZgABKGwAAAABAAAAsQADAAAAASfoAAEoWgABAAAAsQABAAAAAQAIAAIEXAACBU4CqwAGAAAABAAOAB4ALgBAAAMAASe2AAEntgABJJIAAAADAAAAASemAAIkgiSCAAAAAwABKQIAASRyAAAAAQAAALMAAwAAAAEnhAABJGAAAQAAALMAAQAAAAEACAACAAoAAgVOAqwAAQACAlwDGwAGAAAABQAQACAAMABAAFIAAwABJ0gAASdIAAEjrAAAAAMAASOcAAEnOAABI5wAAAADAAAAAScoAAIjjCOMAAAAAwABKIQAASN8AAAAAQAAALUAAwAAAAEnBgABI2oAAQAAALUAAQAAAAEACAACAAoAAgVOAq0AAQACAlwDHAAGAAAABQAQACAAMABAAFIAAwABJsoAASbKAAEmygAAAAMAAAABJroAAia6JroAAAADAAAAASaqAAImqiccAAAAAwABKAYAASaaAAAAAQAAALcAAwAAAAEmiAABJogAAQAAALgAAQAAAAEACAABJm4ASgAGAAAABAAOAB4ALgBAAAMAAQDeAAEA3gABAN4AAAADAAAAAQDOAAIAzgDOAAAAAwABJ6YAAQC+AAAAAQAAALoAAwAAAAEArAABAKwAAQAAALsAAQAAAAEACAABAJIAUQAGAAAABQAQACIANABIAFwAAwABAHwAAQB8AAIAfAB8AAAAAwAAAAEAagADAGoAagBqAAAAAwACJ0AnQAABAFgAAAABAAAAvQADAAEnLAABAEQAAQBEAAEAAAC+AAMAAAABADAAAgAwADAAAQAAAL8AAQAAAAEACAABABQAUgABAAAAAQAIAAEABgLxAAEAAQJdAAYAAAAFABAAIgA0AEgAXAADAAElZgABJWYAAiVmJWYAAAADAAAAASVUAAMlVCVUJVQAAAADAAImriauAAElQgAAAAEAAADBAAMAASaaAAElLgABJS4AAQAAAMIAAwAAAAElGgACJRolGgABAAAAwwABAAAAAQAIAAEk/gBLAAYAAAAFABAAIAAwAEAAUgADAAEk6AABJOgAASOGAAAAAwAAAAEk2AACI3YjdgAAAAMAAAABJMgAAiNmIaQAAAADAAEmJAABI1YAAAABAAAAxQADAAAAASSmAAEjRAABAAAAxQABAAAAAQAIAAIIkAACBU4CqQAGAAAABQAQACIANABIAFwAAwABJHIAASRyAAIjECFOAAAAAwAAAAEkYAADIv4hPCE8AAAAAwACJbolugABISoAAAABAAAAxwADAAElpgABItgAASEWAAEAAADHAAMAAAABJCYAAiLEIQIAAQAAAMcAAQAAAAEACAACAAwAAwVOBU4CqgABAAMCXAJhAxsABgAAAAUAEAAiADQASABcAAMAASPkAAEj5AACI+QkVgAAAAMAAAABI9IAAyPSJEQkRAAAAAMAAiUsJSwAASQyAAAAAQAAAMkAAwABJRgAASOsAAEkHgABAAAAyQADAAAAASOYAAIjmCQKAAEAAADKAAEAAAABAAgAAgAKAAIFTgKoAAEAAgJcAxkAAQAAAAEACAABI2IC8gAGAAAABgASACYAOgBQAGYAfAADAAEW+gABFvoAAxb6FvogJgAAAAMAAAABFuYABBbmFuYgEiASAAAAAwADJI4kjiSOAAEf/gAAAAEAAADMAAMAAiR4JHgAARa8AAEf6AABAAAAzAADAAEkYgABFqYAAhamH9IAAQAAAM0AAwAAAAEWkAADFpAWkB+8AAEAAADOAAEAAAABAAgAAgEEAAIEmgVOAAYAAAAGABIAJAA2AEgAXABwAAMAARZWAAEWVgACFlYfggAAAAMAAR74AAEWRAACFkQfcAAAAAMAAAABFjIAAxYyH14fXgAAAAMAAiPcI9wAAR9MAAAAAQAAANAAAwABI8gAARYMAAEfOAABAAAA0AADAAAAARX4AAIV+B8kAAEAAADRAAEAAAABAAgAAgBuAAIEnAVOAAYAAAAEAA4AHgAuAEAAAwABFcQAARXEAAEe8AAAAAMAAAABFbQAAh7gHuAAAAADAAEjYAABHtAAAAABAAAA0wADAAAAARWSAAEevgABAAAA0wABAAAAAQAIAAIACgACBJ8FTgABAAIDGwRXAAYAAAAFABAAJAA2AEoAXgADAAEVVgABFVYAAxVWF9wX3AAAAAMAAAABFUIAAxVCFUIXyAAAAAMAAiLsIuwAARe2AAAAAQAAANUAAwABItgAARUcAAEXogABAAAA1QADAAAAARUIAAIVCBeOAAEAAADWAAEAAAABAAgAAgEEAAIEmAVOAAYAAAAFABAAJAA2AEoAXgADAAEU0gABFNIAAxTSIZQhlAAAAAMAAAABFL4AAxS+FL4hgAAAAAMAAiJoImgAASFuAAAAAQAAANgAAwABIlQAARSYAAEhWgABAAAA2AADAAAAARSEAAIUhCFGAAEAAADZAAEAAAABAAgAAgD+AAIEmwVOAAYAAAAFABAAIAAwAEAAUgADAAEUTgABFE4AARbUAAAAAwAAAAEUPgACFsQWxAAAAAMAAAABFC4AAha0HVoAAAADAAEh2gABFqQAAAABAAAA2wADAAAAARQMAAEWkgABAAAA2wABAAAAAQAIAAIACgACBJMFTgABAAICgQRXAAYAAAAFABAAIAAwAEAAUgADAAET0AABE9AAASCSAAAAAwAAAAETwAACIIIc7AAAAAMAAAABE7AAAiByIHIAAAADAAEhXAABIGIAAAABAAAA3QADAAAAAROOAAEgUAABAAAA3QABAAAAAQAIAAIACgACBJ0FTgABAAIDGQRXAAYAAAAGABIAIgAyAEIAUgBkAAMAARNQAAETUAABE1AAAAADAAAAARNAAAITQBNAAAAAAwABHUAAARMwAAETMAAAAAMAAAABEyAAAhMgIPQAAAADAAEgzAABExAAAAABAAAA3wADAAAAARL+AAES/gABAAAA4AABAAAAAQAIAAES5ABAAAEAAAABAAgAARLWAPcABgAAAAcAFAAmADwATABcAGwAfgADAAEczAABFUIAAhVCG+gAAAADAAQeiBteHZggAgABFTAAARUwAAAAAwABFRoAARUaAAEVGgAAAAMAARs4AAEVCgABFQoAAAADAAAAART6AAIU+hT6AAAAAwABICAAARTqAAAAAQAAAOIAAwAAAAEU2AABFNgAAQAAAOMAAQAAAAEACAABFL4AEwAGAAAABQAQACIANABIAFwAAwABGtYAARrWAAIUqBSoAAAAAwAAAAEaxAADFJYUlhSWAAAAAwACH7ofugABFIQAAAABAAAA5QADAAEfpgABFHAAARRwAAEAAADmAAMAAAABGooAAhRcFFwAAQAAAOUAAQAAAAEACAACDtQAAgS5BU4ABgAAAAYAEgAmADgASgBeAHIAAwABG64AARQkAAMUJBQkGsoAAAADAAEUEAABFBAAAhQQFBAAAAADAAAAARP+AAMT/hP+E/4AAAADAAIfIh8iAAET7AAAAAEAAADoAAMAAR8OAAET2AABE9gAAQAAAOkAAwAAAAETxAACE8QTxAABAAAA6gABAAAAAQAIAAETqAAUAAEAAAABAAgAAROaAs0ABgAAAAQADgAeAC4AQAADAAEb7gABG+4AARvuAAAAAwAAAAEb3gACG94b3gAAAAMAAR6cAAEbzgAAAAEAAADsAAMAAAABG7wAARu8AAEAAADtAAEAAAABAAgAARuiAFQABgAAAAUAEAAiADQASABcAAMAARuMAAEbjAACG4wbjAAAAAMAAAABG3oAAxt6G3obegAAAAMAAh42HjYAARtoAAAAAQAAAO8AAwABHiIAARtUAAEbVAABAAAA8AADAAAAARtAAAIbQBtAAAEAAADxAAEAAAABAAgAARskAFUAAQAAAAEACAABGxYC7QAGAAAABQAQACAAMABAAFIAAwABGwAAARsAAAEcYgAAAAMAAAABGvAAAhxSHFIAAAADAAAAARrgAAIcQhy0AAAAAwABHZ4AARwyAAAAAQAAAPMAAwAAAAEavgABHCAAAQAAAPMAAQAAAAEACAACAAoAAgK0BU4AAQACAlwCYQAGAAAACQAYACgAOABMAGAAdACIAJoArAADAAEaegABGnoAARxOAAAAAwAAAAEaagACHD4cPgAAAAMAARzEAAEaWgADHC4bvBwuAAAAAwABHLAAARpGAAMcGhs2HBoAAAADAAEcnAABGjIAAxwGF/gX+AAAAAMAARyIAAEaHgADG/IYVhvyAAAAAwABHHQAARoKAAIb3hhIAAAAAwABHMYAARvMAAAAAQAAAPUAAwAAAAEZ5gABG7oAAQAAAPUAAQAAAAEACAACAAoAAgVOArcAAQACAmEDGQAGAAAABAAOAB4ALgBAAAMAARmsAAEZrAABAiAAAAADAAAAARmcAAICEAIQAAAAAwABHFoAAQIAAAAAAQAAAPcAAwAAAAEZegABAe4AAQAAAPcAAQAAAAEACAACAAoAAgKzBU4AAQACAloCYQAGAAAABAAOAB4ALgBAAAMAAQFcAAEBXAABAVwAAAADAAAAAQFMAAIBTAFMAAAAAwABG+4AAQE8AAAAAQAAAPkAAwAAAAEBKgABASoAAQAAAPoAAQAAAAEACAABARAAQgAGAAAABQAQACAAMABAAFIAAwABAPoAAQD6AAEasgAAAAMAAAABAOoAAhqiGqIAAAADAAAAAQDaAAIakhb8AAAAAwABG3wAARqCAAAAAQAAAPwAAwAAAAEAuAABGnAAAQAAAPwAAQAAAAEACAACAAoAAgSSBU4AAQACAxkETgAGAAAABQAQACIANABIAFwAAwABAHwAAQB8AAIAfAB8AAAAAwAAAAEAagADAGoAagBqAAAAAwACGwobCgABAFgAAAABAAAA/gADAAEa9gABAEQAAQBEAAEAAAD/AAMAAAABADAAAgAwADAAAQAAAQAAAQAAAAEACAABABQAQwABAAAAAQAIAAEABgEAAAEAAQROAAYAAAAEAA4AHgAuAEAAAwABAEQAAQBEAAEZpAAAAAMAAAABADQAAhmUGZQAAAADAAEafgABGYQAAAABAAABAgADAAAAAQASAAEZcgABAAABAgABAAECWgABAAAAAQAIAAIACgACBU4CpQABAAICWgMZAAYAAAAEAA4AHgAuAEAAAwABGcIAARnCAAEZwgAAAAMAAAABGbIAAhmyGbIAAAADAAEaDAABGaIAAAABAAABBAADAAAAARmQAAEZkAABAAABBQABAAAAAQAIAAEZdgBKAAEAAAABAAgAARloAsgABgAAAAYAEgAkADgASgBeAHIAAwABGMAAARjAAAIVJBjAAAAAAwACFtoZRAABGK4AAhUSGK4AAAADAAAAARiaAAMU/hiaGJoAAAADAAIZghmCAAEYiAAAAAEAAAEHAAMAARluAAEU2AABGHQAAQAAAQcAAwAAAAEYYAACFMQYYAABAAABCAABAAAAAQAIAAIACgACBU4ErQABAAICawMZAAYAAAAFABAAIgA0AEgAXAADAAEUFAABFBQAAg3mFBQAAAADAAAAARQCAAMN1BQCFAIAAAADAAIY+Bj4AAET8AAAAAEAAAEKAAMAARjkAAENrgABE9wAAQAAAQoAAwAAAAETyAACDZoTyAABAAABCwABAAAAAQAIAAIIEgACBU4EvAAGAAAABgASACQAOABKAF4AcgADAAETkAABE5AAAheeE5AAAAADAAIVuBgiAAETfgACF4wTfgAAAAMAAAABE2oAAxd4E2oTagAAAAMAAhhgGGAAARNYAAAAAQAAAQ0AAwABGEwAARdSAAETRAABAAABDQADAAAAARMwAAIXPhMwAAEAAAEOAAEAAAABAAgAAggaAAIFTgTQAAYAAAAHABQAKAA+AFIAZgB8AJIAAwABEvYAARL2AAMXBBcEE24AAAADAAIVHBeGAAES4gADFvAW8BNaAAAAAwAAAAESzAAEFtoW2hNEE0QAAAADAAIXwBfAAAETMAAAAAEAAAEQAAMAAhesF6wAARayAAETHAABAAABEAADAAEXlgABFpwAAhacEwYAAQAAAREAAwAAAAESeAADFoYWhhLwAAEAAAEQAAEAAAABAAgAAgAMAAMFTgTOBU4AAQADAxkDGwMcAAYAAAAIABYAKAA6AFAAZAB2AIoAngADAAETigABFjwAAhY8EqYAAAADAAEWKgABFioAAhYqEpQAAAADAAMSChREFq4AARYYAAIWGBKCAAAAAwACFC4WmAABFgIAAhYCEmwAAAADAAAAARXuAAMV7hJYElgAAAADAAIW1hbWAAESRgAAAAEAAAETAAMAARbCAAEVyAABEjIAAQAAARMAAwAAAAEVtAACFbQSHgABAAABFAABAAAAAQAIAAIBtAACBU4EqQABAAAAAQAIAAEVhgI1AAYAAAAGABIAJAA4AEoAXgByAAMAARVuAAEVbgACEdgR2AAAAAMAAhOIFfIAARVcAAIRxhHGAAAAAwAAAAEVSAADEbIRshGyAAAAAwACFjAWMAABEaAAAAABAAABFgADAAEWHAABEYwAARGMAAEAAAEXAAMAAAABFQ4AAhF4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Yehh6GHoYfpiVmKZYyBjaGOwY9tkDGQ3ZGJklGTQZQxlL2U4ZVtlm2W2ZdZl+mYfZktmeGahZq9m9WcMZyxnqWfUZ+hn/GgFaDVoZ2iJaKpoymksaTVpR2lVaXdpmWmiaatptGolas5q4GsRa0prqmwDbDdsdmy1bLVsvmzHbNBs2WzibOts/W0/bT9tSG1bbWZtfm1+bbVt+G34bi9uQ273bxtvW29kb+hv+HAdcB1wNXA1cDVwNXA1cDVwNXA1cDVwNXA1cDVwPnA+cD5wPnA+cEdwR3BHcEdwUHBQcHNwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcJRwlHCUcLdwt3C3cLdwt3DAcMBwwHDAcMBwwHDAcMBwwHDAcMBwwHDAcMBwyXDJcNJw0nDbcORw7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XDtcO1w7XD2cUZxUHFQcVdxbnGQcbJxsnG7ccRyRnKycs9zdXPKdCF0dnSUdKJ0tHTCdNR09nVTdYV1/nYGdg92GXYidjZ2P3ZIdlF2WnZjdmx2dXZ+dod2kHaZdqJ2q3a0dr12xnbGduN3d3eAd4l3knebd5t3m3ebd5t3m3e8d8V3xXfOd9d34Hfpd/J3+3gEeA14FngfeCh4KHgxeG548Hm5et97W3tze5N78HwMfBZ8MnxIfHd8m3zGfOZ9EX04fcF99H43fnR+v38af2t/hn+pf81/8YAggE+AgYCdgMGAy4DUgQKBMYE7gWGBkYGagbOB2IH4ghmCOoJEgk2Co4NBg/eEEoQxhFSEf4T7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); +} +body { + --font-interface-theme: "Source Sans 3", sans-serif; + --font-text-theme: "Source Sans 3", sans-serif; + --font-monospace-theme: "JetBrains Mono", monospace; + --h1-size: 2.2em; + --h2-size: 2em; + --h3-size: 1.8em; + --h4-size: 1.6em; + --h5-size: 1.4em; + --h6-size: 1.2em; + --h1-weight: var(--font-extrabold); + --h2-weight: var(--font-extrabold); + --h3-weight: var(--font-extrabold); + --h4-weight: var(--font-extrabold); + --h5-weight: var(--font-extrabold); + --h6-weight: var(--font-extrabold); + --list-indent: 1em; + --indentation-guide-width: 2px; + --tag-padding-y: 0; + --tag-padding-x: 0.75ch; + --tag-border-width: 2px; + --tag-size: var(--font-smallest); + --file-folding-offset: 20px; + --text-error: var(--color-red-text); + --text-accent: var(--interactive-accent-text); + --icon-color-focused: var(--interactive-accent-text); + --background-modifier-error: var(--color-red-text); + --background-modifier-border: var(--window-border); + --background-modifier-border-focus: var(--interactive-accent-base); + --background-modifier-border-hover: var(--interactive-accent-tint); + --icon-color-hover: var(--highlight-text-normal); + --nav-item-color-hover: var(--highlight-text-normal); + --checkbox-marker-color: var(--highlight-text-normal); + --checklist-done-color: var(--interactive-accent-tint); + --checkbox-border-color-hover: var(--interactive-accent-tint); + --blockquote-border-color: var(--window-border); + --ribbon-background-collapsed: var(--background-secondary); + --titlebar-background-focused: var(--background-secondary); + --header-height: 41px; + --input-height: 32px; + --input-radius: var(--radius-s); + --toggle-thumb-height: 18px; + --toggle-thumb-width: 18px; + --toggle-border-width: 1px; + --toggle-width: 42px; + --toggle-s-thumb-height: 14px; + --toggle-s-thumb-width: 14px; + --toggle-s-border-width: 4px; + --callout-padding: 4px; + --callout-radius: var(--radius-m); + --divider-color-hover: var(--interactive-accent-tint); + --file-header-font-size: var(--font-ui-medium); + --vault-name-font-size: var(--font-ui-medium); + --status-bar-font-size: var(--font-ui-small); + --tab-stacked-font-size: var(--font-ui-medium); + --modal-width: 85vw; + --modal-max-width: 1400px; + --modal-height: 80vh; + --modal-max-height: 1000px; + --modal-border-color: var(--window-border); + --drag-ghost-text-color: var(--text-normal); + --clickable-icon-radius: var(--radius-s); + --toggle-radius: var(--size-4-1); + --toggle-thumb-radius: 3px; + --slider-thumb-radius: var(--size-4-1); + --slider-thumb-width: 10px; + --scrollbar-active-thumb-bg: var(--interactive-accent-base); + --scrollbar-thumb-bg: var(--background-primary); + --text-on-accent: var(--text-normal); + --prompt-border-color: var(--window-border); + --blur-intensity: 8px; + --accent-border-width: 2px; + --scroll-bar-size: 12px; + --callout-background-alpha: 15%; + --custom-vault-banner-icon-url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' x='0px' y='0px'%0Awidth='40' height='40'%0AviewBox='0 0 40 40'%0Astyle=' fill:%23000000;'%3E%3Cpath fill='%23dbb065' d='M1.5 35.5L1.5 4.5 11.793 4.5 14.793 7.5 35.5 7.5 35.5 35.5z'%3E%3C/path%3E%3Cpath fill='%23967a44' d='M11.586,5l2.707,2.707L14.586,8H15h20v27H2V5H11.586 M12,4H1v32h35V7H15L12,4L12,4z'%3E%3C/path%3E%3Cg%3E%3Cpath fill='%23f5ce85' d='M1.599 35.5L5.417 14.5 16.151 14.5 19.151 12.5 39.41 12.5 35.577 35.5z'%3E%3C/path%3E%3Cpath fill='%23967a44' d='M38.82,13l-3.667,22H2.198l3.636-20H16h0.303l0.252-0.168L19.303,13H38.82 M40,12H19l-3,2H5L1,36 h35L40,12L40,12z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E"); + --mark-highlight-base: var(--color-yellow-base); + --status-bar-background-color-lt: #EBECEF; + --status-bar-background-color-dt: #2B2B2B; +} +body:is(.theme-light, .theme-dark) { + --color-red-base: var(--red100); + --color-orange-base: var(--orange100); + --color-yellow-base: var(--yellow100); + --color-green-base: var(--green100); + --color-mint-base: var(--mint100); + --color-cyan-base: var(--cyan100); + --color-blue-base: var(--blue100); + --color-purple-base: var(--purple100); + --color-pink-base: var(--pink100); + --color-grey-base: var(--grey100); + --color-red-tint: var(--red200); + --color-orange-tint: var(--orange200); + --color-yellow-tint: var(--yellow200); + --color-green-tint: var(--green200); + --color-mint-tint: var(--mint200); + --color-cyan-tint: var(--cyan200); + --color-blue-tint: var(--blue200); + --color-purple-tint: var(--purple200); + --color-pink-tint: var(--pink200); + --color-grey-tint: var(--grey200); + --color-red-text: var(--red300); + --color-orange-text: var(--orange300); + --color-yellow-text: var(--yellow300); + --color-green-text: var(--green300); + --color-mint-text: var(--mint300); + --color-cyan-text: var(--cyan300); + --color-blue-text: var(--blue300); + --color-purple-text: var(--purple300); + --color-pink-text: var(--pink300); + --color-grey-text: var(--grey300); + --color-red: var(--color-red-text); + --color-green: var(--color-green-text); + --color-orange: var(--color-orange-text); + --color-yellow: var(--color-yellow-text); + --color-cyan: var(--color-cyan-text); + --color-blue: var(--color-blue-text); + --color-purple: var(--color-purple-text); + --color-pink: var(--color-pink-text); + --color-accent-base-lt: hsl(var(--color-accent-h-lt) var(--color-accent-s-lt) var(--color-accent-l-base-lt)); + --color-accent-tint-lt: hsl(var(--color-accent-h-lt) var(--color-accent-s-lt) var(--color-accent-l-tint-lt)); + --color-accent-text-lt: hsl(var(--color-accent-h-lt) var(--color-accent-s-lt) var(--color-accent-l-text-lt)); + --input-shadow: unset; + --input-shadow-hover: unset; + --tab-stacked-shadow: 0; + --background-modifier-hover: hsla(var(--interactive-accent-base-hsl) / 50%); + --hue-background-lt: linear-gradient( to right, hsl(0 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(30 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(60 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(90 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(120 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(150 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(180 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(210 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(240 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(270 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(300 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(330 var(--color-accent-s-lt) var(--color-accent-l-base-lt)), hsl(360 var(--color-accent-s-lt) var(--color-accent-l-base-lt)) ); + --saturation-background-lt: linear-gradient( to right, hsl(var(--color-accent-h-lt) 0% var(--color-accent-l-base-lt)), hsl(var(--color-accent-h-lt) 50% var(--color-accent-l-base-lt)), hsl(var(--color-accent-h-lt) 100% var(--color-accent-l-base-lt)) ); + --lightness-background-lt: linear-gradient( to right, hsl(var(--color-accent-h-lt) var(--color-accent-s-lt) 0%), hsl(var(--color-accent-h-lt) var(--color-accent-s-lt) 50%), hsl(var(--color-accent-h-lt) var(--color-accent-s-lt) 100%) ); + --color-accent-base-dt: hsl(var(--color-accent-h-dt) var(--color-accent-s-dt) var(--color-accent-l-base-dt)); + --color-accent-tint-dt: hsl(var(--color-accent-h-dt) var(--color-accent-s-dt) var(--color-accent-l-tint-dt)); + --color-accent-text-dt: hsl(var(--color-accent-h-dt) var(--color-accent-s-dt) var(--color-accent-l-text-dt)); + --hue-background-dt: linear-gradient( to right, hsl(0 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(30 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(60 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(90 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(120 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(150 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(180 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(210 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(240 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(270 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(300 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(330 var(--color-accent-s-dt) var(--color-accent-l-base-dt)), hsl(360 var(--color-accent-s-dt) var(--color-accent-l-base-dt)) ); + --saturation-background-dt: linear-gradient( to right, hsl(var(--color-accent-h-dt) 0% var(--color-accent-l-base-dt)), hsl(var(--color-accent-h-dt) 50% var(--color-accent-l-base-dt)), hsl(var(--color-accent-h-dt) 100% var(--color-accent-l-base-dt)) ); + --lightness-background-dt: linear-gradient( to right, hsl(var(--color-accent-h-dt) var(--color-accent-s-dt) 0%), hsl(var(--color-accent-h-dt) var(--color-accent-s-dt) 50%), hsl(var(--color-accent-h-dt) var(--color-accent-s-dt) 100%) ); + --text-highlight-bg: var(--interactive-accent-base); + --interactive-accent: var(--interactive-accent-tint); + --interactive-hover: var(--background-primary); + --text-accent-hover: var(--interactive-accent-hover); + --scroll-button-background-color: var(--background-primary); + --color-accent-h-lt: 0; + --color-accent-s-lt: 60%; + --color-accent-l-base-lt: 82%; + --color-accent-l-tint-lt: 67%; + --color-accent-l-text-lt: 42%; + --color-accent-h-dt: 0; + --color-accent-s-dt: 50%; + --color-accent-l-base-dt: 20%; + --color-accent-l-tint-dt: 40%; + --color-accent-l-text-dt: 65%; +} +body:is(.theme-light, .theme-dark).pt-disable-blur { + --background-secondary-blur: var(--background-secondary); +} +body.theme-light { + --window-border: var(--background-secondary-alt); + --page-background-color: var(--background-primary); + --text-selection: var(--background-secondary-alt); + --graph-line-color-lt: var(--background-secondary-alt); + --graph-fill-color-lt: var(--color-grey-tint); + --graph-fill-focused-color-lt: var(--interactive-accent-tint); + --graph-tag-color-lt: var(--color-blue-tint); + --graph-attachment-color-lt: var(--color-yellow-tint); + --graph-unresolved-color-lt: var(--color-red-tint); + --graph-highlight-color-lt: var(--interactive-accent-tint); + --graph-highlight-line-color-lt: var(--interactive-accent-tint); + --h1-text-color-lt: var(--text-normal); + --h2-text-color-lt: var(--text-normal); + --h3-text-color-lt: var(--text-normal); + --h4-text-color-lt: var(--text-normal); + --h5-text-color-lt: var(--text-normal); + --h6-text-color-lt: var(--text-normal); + --h1-color: var(--h1-text-color-lt); + --h2-color: var(--h2-text-color-lt); + --h3-color: var(--h3-text-color-lt); + --h4-color: var(--h4-text-color-lt); + --h5-color: var(--h5-text-color-lt); + --h6-color: var(--h6-text-color-lt); + --text-bold-color-lt: var(--text-normal); + --text-italic-color-lt: var(--text-normal); + --text-italic-bold-color-lt: var(--text-normal); + --link-internal-color-lt: var(--interactive-accent-text); + --link-external-color-lt: var(--interactive-accent-text); + --bold-color: var(--text-bold-color-lt); + --italic-color: var(--text-italic-color-lt); + --link-color: var(--link-internal-color-lt); + --link-unresolved-color: var(--link-internal-color-lt); + --link-external-color: var(--link-external-color-lt); + --code-background: var(--background-primary-alt); + --blockquote-background-color: var(--background-primary-alt); + --checkbox-color: var(--background-primary-alt); + --checkbox-border-color: var(--background-secondary-alt); + --scrollbar-bg: var(--background-secondary); +} +body.theme-light.pt-highlight-text-light-lt { + --highlight-text-normal: var(--background-primary); +} +body.theme-light.pt-highlight-text-dark-lt { + --highlight-text-normal: var(--text-normal); +} +body.theme-light.pt-highlight-text-accent-lt { + --highlight-text-normal: var(--interactive-accent-text); +} +body.theme-light.pt-highlight-text-custom-lt { + --highlight-text-normal: var(--highlight-text-accent-custom-lt); +} +body.theme-light.pt-accent-color-custom-lt { + --interactive-accent-base: var(--color-accent-base-lt); + --interactive-accent-tint: var(--color-accent-tint-lt); + --interactive-accent-text: var(--color-accent-text-lt); + --interactive-accent-hover: var(--color-accent-tint-lt); +} +body.theme-light.pt-accent-color-red-lt { + --interactive-accent-base-hsl: var(--color-red-base-hsl); + --interactive-accent-base: var(--color-red-base); + --interactive-accent-tint: var(--color-red-tint); + --interactive-accent-text: var(--color-red-text); + --interactive-accent-hover: var(--color-red-tint); +} +body.theme-light.pt-accent-color-orange-lt { + --interactive-accent-base-hsl: var(--color-orange-base-hsl); + --interactive-accent-base: var(--color-orange-base); + --interactive-accent-tint: var(--color-orange-tint); + --interactive-accent-text: var(--color-orange-text); + --interactive-accent-hover: var(--color-orange-tint); +} +body.theme-light.pt-accent-color-yellow-lt { + --interactive-accent-base-hsl: var(--color-yellow-base-hsl); + --interactive-accent-base: var(--color-yellow-base); + --interactive-accent-tint: var(--color-yellow-tint); + --interactive-accent-text: var(--color-yellow-text); + --interactive-accent-hover: var(--color-yellow-tint); +} +body.theme-light.pt-accent-color-green-lt { + --interactive-accent-base-hsl: var(--color-green-base-hsl); + --interactive-accent-base: var(--color-green-base); + --interactive-accent-tint: var(--color-green-tint); + --interactive-accent-text: var(--color-green-text); + --interactive-accent-hover: var(--color-green-tint); +} +body.theme-light.pt-accent-color-mint-lt { + --interactive-accent-base-hsl: var(--color-mint-base-hsl); + --interactive-accent-base: var(--color-mint-base); + --interactive-accent-tint: var(--color-mint-tint); + --interactive-accent-text: var(--color-mint-text); + --interactive-accent-hover: var(--color-mint-tint); +} +body.theme-light.pt-accent-color-cyan-lt { + --interactive-accent-base-hsl: var(--color-cyan-base-hsl); + --interactive-accent-base: var(--color-cyan-base); + --interactive-accent-tint: var(--color-cyan-tint); + --interactive-accent-text: var(--color-cyan-text); + --interactive-accent-hover: var(--color-cyan-tint); +} +body.theme-light.pt-accent-color-blue-lt { + --interactive-accent-base-hsl: var(--color-blue-base-hsl); + --interactive-accent-base: var(--color-blue-base); + --interactive-accent-tint: var(--color-blue-tint); + --interactive-accent-text: var(--color-blue-text); + --interactive-accent-hover: var(--color-blue-tint); +} +body.theme-light.pt-accent-color-purple-lt { + --interactive-accent-base-hsl: var(--color-purple-base-hsl); + --interactive-accent-base: var(--color-purple-base); + --interactive-accent-tint: var(--color-purple-tint); + --interactive-accent-text: var(--color-purple-text); + --interactive-accent-hover: var(--color-purple-tint); +} +body.theme-light.pt-accent-color-pink-lt { + --interactive-accent-base-hsl: var(--color-pink-base-hsl); + --interactive-accent-base: var(--color-pink-base); + --interactive-accent-tint: var(--color-pink-tint); + --interactive-accent-text: var(--color-pink-text); + --interactive-accent-hover: var(--color-pink-tint); +} +body.theme-light.pt-accent-color-grey-lt { + --interactive-accent-base-hsl: var(--color-grey-base-hsl); + --interactive-accent-base: var(--color-grey-base); + --interactive-accent-tint: var(--color-grey-tint); + --interactive-accent-text: var(--color-grey-text); + --interactive-accent-hover: var(--color-grey-tint); +} +body.theme-dark { + --window-border: var(--background-primary-alt); + --page-background-color: var(--background-secondary); + --text-selection: var(--background-primary-alt); + --graph-line-color-dt: var(--background-primary-alt); + --graph-fill-color-dt: var(--color-grey-tint); + --graph-fill-focused-color-dt: var(--interactive-accent-tint); + --graph-tag-color-dt: var(--color-blue-tint); + --graph-attachment-color-dt: var(--color-yellow-tint); + --graph-unresolved-color-dt: var(--color-red-tint); + --graph-highlight-color-dt: var(--interactive-accent-tint); + --graph-highlight-line-color-dt: var(--interactive-accent-tint); + --h1-text-color-dt: var(--text-normal); + --h2-text-color-dt: var(--text-normal); + --h3-text-color-dt: var(--text-normal); + --h4-text-color-dt: var(--text-normal); + --h5-text-color-dt: var(--text-normal); + --h6-text-color-dt: var(--text-normal); + --h1-color: var(--h1-text-color-dt); + --h2-color: var(--h2-text-color-dt); + --h3-color: var(--h3-text-color-dt); + --h4-color: var(--h4-text-color-dt); + --h5-color: var(--h5-text-color-dt); + --h6-color: var(--h6-text-color-dt); + --text-bold-color-dt: var(--text-normal); + --text-italic-color-dt: var(--text-normal); + --text-italic-bold-color-dt: var(--text-normal); + --link-internal-color-dt: var(--interactive-accent-text); + --link-external-color-dt: var(--interactive-accent-text); + --bold-color: var(--text-bold-color-dt); + --italic-color: var(--text-italic-color-dt); + --link-color: var(--link-internal-color-dt); + --link-unresolved-color: var(--link-internal-color-dt); + --link-external-color: var(--link-external-color-dt); + --code-background: var(--background-secondary); + --blockquote-background-color: var(--background-secondary-alt); + --checkbox-color: var(--background-primary); + --checkbox-border-color: var(--background-primary-alt); + --toggle-thumb-color: var(--text-normal); + --background-modifier-form-field: var(--background-secondary); + --modal-background: var(--background-secondary-alt); + --scrollbar-bg: var(--background-secondary); +} +body.theme-dark.pt-highlight-text-light-dt { + --highlight-text-normal: var(--text-normal); +} +body.theme-dark.pt-highlight-text-dark-dt { + --highlight-text-normal: var(--background-primary); +} +body.theme-dark.pt-highlight-text-accent-dt { + --highlight-text-normal: var(--interactive-accent-text); +} +body.theme-dark.pt-highlight-text-custom-dt { + --highlight-text-normal: var(--highlight-text-accent-custom-dt); +} +body.theme-dark.pt-accent-color-custom-dt { + --interactive-accent-base: var(--color-accent-base-dt); + --interactive-accent-tint: var(--color-accent-tint-dt); + --interactive-accent-text: var(--color-accent-text-dt); + --interactive-accent-hover: var(--color-accent-tint-dt); +} +body.theme-dark.pt-accent-color-red-dt { + --interactive-accent-base-hsl: var(--color-red-base-hsl); + --interactive-accent-base: var(--color-red-base); + --interactive-accent-tint: var(--color-red-tint); + --interactive-accent-text: var(--color-red-text); + --interactive-accent-hover: var(--color-red-tint); +} +body.theme-dark.pt-accent-color-orange-dt { + --interactive-accent-base-hsl: var(--color-orange-base-hsl); + --interactive-accent-base: var(--color-orange-base); + --interactive-accent-tint: var(--color-orange-tint); + --interactive-accent-text: var(--color-orange-text); + --interactive-accent-hover: var(--color-orange-tint); +} +body.theme-dark.pt-accent-color-yellow-dt { + --interactive-accent-base-hsl: var(--color-yellow-base-hsl); + --interactive-accent-base: var(--color-yellow-base); + --interactive-accent-tint: var(--color-yellow-tint); + --interactive-accent-text: var(--color-yellow-text); + --interactive-accent-hover: var(--color-yellow-tint); +} +body.theme-dark.pt-accent-color-green-dt { + --interactive-accent-base-hsl: var(--color-green-base-hsl); + --interactive-accent-base: var(--color-green-base); + --interactive-accent-tint: var(--color-green-tint); + --interactive-accent-text: var(--color-green-text); + --interactive-accent-hover: var(--color-green-tint); +} +body.theme-dark.pt-accent-color-mint-dt { + --interactive-accent-base-hsl: var(--color-mint-base-hsl); + --interactive-accent-base: var(--color-mint-base); + --interactive-accent-tint: var(--color-mint-tint); + --interactive-accent-text: var(--color-mint-text); + --interactive-accent-hover: var(--color-mint-tint); +} +body.theme-dark.pt-accent-color-cyan-dt { + --interactive-accent-base-hsl: var(--color-cyan-base-hsl); + --interactive-accent-base: var(--color-cyan-base); + --interactive-accent-tint: var(--color-cyan-tint); + --interactive-accent-text: var(--color-cyan-text); + --interactive-accent-hover: var(--color-cyan-tint); +} +body.theme-dark.pt-accent-color-blue-dt { + --interactive-accent-base-hsl: var(--color-blue-base-hsl); + --interactive-accent-base: var(--color-blue-base); + --interactive-accent-tint: var(--color-blue-tint); + --interactive-accent-text: var(--color-blue-text); + --interactive-accent-hover: var(--color-blue-tint); +} +body.theme-dark.pt-accent-color-purple-dt { + --interactive-accent-base-hsl: var(--color-purple-base-hsl); + --interactive-accent-base: var(--color-purple-base); + --interactive-accent-tint: var(--color-purple-tint); + --interactive-accent-text: var(--color-purple-text); + --interactive-accent-hover: var(--color-purple-tint); +} +body.theme-dark.pt-accent-color-pink-dt { + --interactive-accent-base-hsl: var(--color-pink-base-hsl); + --interactive-accent-base: var(--color-pink-base); + --interactive-accent-tint: var(--color-pink-tint); + --interactive-accent-text: var(--color-pink-text); + --interactive-accent-hover: var(--color-pink-tint); +} +body.theme-dark.pt-accent-color-grey-dt { + --interactive-accent-base-hsl: var(--color-grey-base-hsl); + --interactive-accent-base: var(--color-grey-base); + --interactive-accent-tint: var(--color-grey-tint); + --interactive-accent-text: var(--color-grey-text); + --interactive-accent-hover: var(--color-grey-tint); +} +.theme-light.pt-color-scheme-swan-lt { + --grey100: hsl(0 0% 82%); + --grey200: hsl(0 0% 62%); + --grey300: hsl(0 0% 40%); + --red100: hsl(7 83% 86%); + --red200: hsl(7 71% 69%); + --red300: hsl(358 100% 38%); + --orange100: hsl(27 81% 81%); + --orange200: hsl(29 77% 54%); + --orange300: hsl(27 100% 32%); + --yellow100: hsl(47 58% 74%); + --yellow200: hsl(49 100% 37%); + --yellow300: hsl(44 100% 25%); + --green100: hsl(114 36% 78%); + --green200: hsl(115 36% 52%); + --green300: hsl(120 100% 23%); + --mint100: hsl(157 40% 78%); + --mint200: hsl(162 51% 46%); + --mint300: hsl(162 100% 23%); + --cyan100: hsl(194 43% 80%); + --cyan200: hsl(192 43% 55%); + --cyan300: hsl(191 100% 26%); + --blue100: hsl(220 67% 86%); + --blue200: hsl(221 62% 69%); + --blue300: hsl(223 58% 49%); + --purple100: hsl(249 69% 89%); + --purple200: hsl(253 65% 74%); + --purple300: hsl(259 61% 55%); + --pink100: hsl(329 57% 86%); + --pink200: hsl(325 53% 68%); + --pink300: hsl(319 68% 42%); + --color-grey-base-hsl: 0 0% 82%; + --color-red-base-hsl: 7 83% 86%; + --color-orange-base-hsl: 27 81% 81%; + --color-yellow-base-hsl: 47 58% 74%; + --color-green-base-hsl: 114 36% 78%; + --color-mint-base-hsl: 157 40% 78%; + --color-cyan-base-hsl: 194 43% 80%; + --color-blue-base-hsl: 220 67% 86%; + --color-purple-base-hsl: 249 69% 89%; + --color-pink-base-hsl: 329 57% 86%; + --text-normal: hsl(0 0% 25%); + --text-muted: hsl(0 0% 40%); + --text-faint: hsl(0 0% 50%); + --background-primary: hsl(0 0% 100%); + --background-primary-alt: hsl(0 0% 96.5%); + --background-secondary: hsl(0 0% 94%); + --background-secondary-blur: hsl(0 0% 94% / 80%); + --background-secondary-alt: hsl(0 0% 80%); + --shadow-s: hsl(0 0% 0% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(0 0% 0% / 3%) 0 1px 2px, + hsl(0 0% 0% / 3%) 0 2px 4px, + hsl(0 0% 0% / 3%) 0 4px 8px, + hsl(0 0% 0% / 3%) 0 8px 16px; +} +.theme-dark.pt-color-scheme-raven-dt { + --grey100: hsl(0 0% 24%); + --grey200: hsl(0 0% 42%); + --grey300: hsl(0 0% 62%); + --red100: hsl(358 51% 27%); + --red200: hsl(359 36% 48%); + --red300: hsl(2 37% 67%); + --orange100: hsl(24 55% 23%); + --orange200: hsl(24 55% 40%); + --orange300: hsl(23 56% 61%); + --yellow100: hsl(46 48% 19%); + --yellow200: hsl(45 48% 33%); + --yellow300: hsl(45 47% 49%); + --green100: hsl(122 35% 20%); + --green200: hsl(121 31% 35%); + --green300: hsl(121 31% 54%); + --mint100: hsl(162 41% 19%); + --mint200: hsl(161 37% 34%); + --mint300: hsl(161 35% 51%); + --cyan100: hsl(196 47% 21%); + --cyan200: hsl(195 47% 36%); + --cyan300: hsl(195 47% 56%); + --blue100: hsl(232 44% 32%); + --blue200: hsl(229 27% 49%); + --blue300: hsl(226 29% 67%); + --purple100: hsl(263 45% 32%); + --purple200: hsl(259 24% 50%); + --purple300: hsl(256 25% 68%); + --pink100: hsl(330 43% 27%); + --pink200: hsl(332 31% 47%); + --pink300: hsl(333 30% 66%); + --color-grey-base-hsl: 0 0% 24%; + --color-red-base-hsl: 358 51% 27%; + --color-orange-base-hsl: 24 55% 23%; + --color-yellow-base-hsl: 46 48% 19%; + --color-green-base-hsl: 122 35% 20%; + --color-mint-base-hsl: 162 41% 19%; + --color-cyan-base-hsl: 196 47% 21%; + --color-blue-base-hsl: 232 44% 32%; + --color-purple-base-hsl: 263 45% 32%; + --color-pink-base-hsl: 330 43% 27%; + --text-normal: hsl(0 0% 80%); + --text-muted: hsl(0 0% 70%); + --text-faint: hsl(0 0% 50%); + --background-primary: hsl(0 0% 13%); + --background-primary-alt: hsl(0 0% 18%); + --background-secondary: hsl(0 0% 7%); + --background-secondary-blur: hsl(0 0% 7% / 80%); + --background-secondary-alt: hsl(0 0% 5%); + --shadow-s: hsl(0 0% 0% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(0 0% 0% / 5%) 0 1px 2px, + hsl(0 0% 0% / 5%) 0 2px 4px, + hsl(0 0% 0% / 5%) 0 4px 8px, + hsl(0 0% 0% / 5%) 0 8px 16px; +} +.theme-light.pt-color-scheme-latte-lt { + --grey100: hsl(356 5% 82%); + --grey200: hsl(356 5% 65%); + --grey300: hsl(356 5% 47%); + --red100: hsl(352 70% 83%); + --red200: hsl(352 70% 71%); + --red300: hsl(352 53% 55%); + --orange100: hsl(18 66% 82%); + --orange200: hsl(18 66% 70%); + --orange300: hsl(18 54% 52%); + --yellow100: hsl(35 70% 83%); + --yellow200: hsl(35 70% 65%); + --yellow300: hsl(35 55% 46%); + --green100: hsl(121 37% 81%); + --green200: hsl(121 37% 65%); + --green300: hsl(121 45% 43%); + --mint100: hsl(149 33% 84%); + --mint200: hsl(149 33% 67%); + --mint300: hsl(149 65% 40%); + --cyan100: hsl(180 31% 81%); + --cyan200: hsl(180 31% 64%); + --cyan300: hsl(180 50% 40%); + --blue100: hsl(235 27% 84%); + --blue200: hsl(235 27% 71%); + --blue300: hsl(235 30% 56%); + --purple100: hsl(275 38% 82%); + --purple200: hsl(275 38% 70%); + --purple300: hsl(275 36% 52%); + --pink100: hsl(325 42% 83%); + --pink200: hsl(325 42% 69%); + --pink300: hsl(325 42% 50%); + --color-grey-base-hsl: 356 5% 82%; + --color-red-base-hsl: 352 70% 83%; + --color-orange-base-hsl: 18 66% 82%; + --color-yellow-base-hsl: 35 70% 83%; + --color-green-base-hsl: 121 37% 81%; + --color-mint-base-hsl: 149 33% 84%; + --color-cyan-base-hsl: 180 31% 81%; + --color-blue-base-hsl: 235 27% 84%; + --color-purple-base-hsl: 275 38% 82%; + --color-pink-base-hsl: 325 42% 83%; + --text-normal: hsl(28 32% 18%); + --text-muted: hsl(28 32% 35%); + --text-faint: hsl(28 32% 50%); + --background-primary: hsl(28 32% 95%); + --background-primary-alt: hsl(28 32% 93%); + --background-secondary: hsl(28 32% 90%); + --background-secondary-blur: hsl(28 32% 90% / 80%); + --background-secondary-alt: hsl(28 32% 77%); + --shadow-s: hsl(28 32% 7% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(28 32% 7% / 4%) 0 1px 2px, + hsl(28 32% 7% / 4%) 0 2px 4px, + hsl(28 32% 7% / 4%) 0 4px 8px, + hsl(28 32% 7% / 4%) 0 8px 16px; +} +.theme-dark.pt-color-scheme-mocha-dt { + --grey100: hsl(356 5% 20%); + --grey200: hsl(356 5% 34%); + --grey300: hsl(356 5% 69%); + --red100: hsl(352 62% 18%); + --red200: hsl(352 62% 31%); + --red300: hsl(352 72% 66%); + --orange100: hsl(18 60% 20%); + --orange200: hsl(18 60% 33%); + --orange300: hsl(18 75% 64%); + --yellow100: hsl(35 76% 16%); + --yellow200: hsl(35 76% 28%); + --yellow300: hsl(35 65% 56%); + --green100: hsl(121 25% 20%); + --green200: hsl(121 25% 34%); + --green300: hsl(121 44% 55%); + --mint100: hsl(149 30% 22%); + --mint200: hsl(149 30% 35%); + --mint300: hsl(149 52% 55%); + --cyan100: hsl(180 35% 17%); + --cyan200: hsl(180 35% 30%); + --cyan300: hsl(180 46% 48%); + --blue100: hsl(235 30% 21%); + --blue200: hsl(235 30% 40%); + --blue300: hsl(235 60% 75%); + --purple100: hsl(275 30% 19%); + --purple200: hsl(275 30% 36%); + --purple300: hsl(275 60% 69%); + --pink100: hsl(325 39% 19%); + --pink200: hsl(325 39% 33%); + --pink300: hsl(325 62% 68%); + --color-grey-base-hsl: 356 5% 20%; + --color-red-base-hsl: 352 62% 18%; + --color-orange-base-hsl: 18 60% 20%; + --color-yellow-base-hsl: 35 76% 16%; + --color-green-base-hsl: 121 25% 20%; + --color-mint-base-hsl: 149 30% 22%; + --color-cyan-base-hsl: 180 35% 17%; + --color-blue-base-hsl: 235 30% 21%; + --color-purple-base-hsl: 275 30% 19%; + --color-pink-base-hsl: 325 39% 19%; + --text-normal: hsl(28 32% 85%); + --text-muted: hsl(28 32% 70%); + --text-faint: hsl(28 32% 60%); + --background-primary: hsl(27 30% 13%); + --background-primary-alt: hsl(28 32% 15.5%); + --background-secondary: hsl(28 32% 9.2%); + --background-secondary-blur: hsl(28 32% 9.2% / 80%); + --background-secondary-alt: hsl(28 32% 6.8%); + --shadow-s: hsl(28 32% 7% / 50%) 0 1px 2px 0; + --shadow-l: + hsl(28 32% 7% / 50%) 0 1px 2px, + hsl(28 32% 7% / 50%) 0 2px 4px, + hsl(28 32% 7% / 50%) 0 4px 8px, + hsl(28 32% 7% / 50%) 0 8px 16px; +} +.theme-light.pt-color-scheme-periwinkle-lt { + --grey100: hsl(233 5% 82%); + --grey200: hsl(233 5% 68%); + --grey300: hsl(233 5% 47%); + --red100: hsl(345 70% 83%); + --red200: hsl(345 70% 74%); + --red300: hsl(345 53% 55%); + --orange100: hsl(12 66% 82%); + --orange200: hsl(12 66% 73%); + --orange300: hsl(12 54% 52%); + --yellow100: hsl(36 70% 83%); + --yellow200: hsl(36 70% 70%); + --yellow300: hsl(36 55% 46%); + --green100: hsl(121 35% 81%); + --green200: hsl(121 35% 68%); + --green300: hsl(121 45% 40%); + --mint100: hsl(149 40% 82%); + --mint200: hsl(149 40% 67%); + --mint300: hsl(149 58% 38%); + --cyan100: hsl(180 31% 82%); + --cyan200: hsl(180 31% 69%); + --cyan300: hsl(180 50% 40%); + --blue100: hsl(232 34% 84%); + --blue200: hsl(232 34% 74%); + --blue300: hsl(232 35% 56%); + --purple100: hsl(255 38% 82%); + --purple200: hsl(255 38% 73%); + --purple300: hsl(255 36% 51%); + --pink100: hsl(303 42% 83%); + --pink200: hsl(303 42% 72%); + --pink300: hsl(303 42% 50%); + --color-grey-base-hsl: 233 5% 82%; + --color-red-base-hsl: 345 70% 83%; + --color-orange-base-hsl: 12 66% 82%; + --color-yellow-base-hsl: 36 70% 83%; + --color-green-base-hsl: 121 35% 81%; + --color-mint-base-hsl: 149 40% 82%; + --color-cyan-base-hsl: 180 31% 82%; + --color-blue-base-hsl: 232 34% 84%; + --color-purple-base-hsl: 255 38% 82%; + --color-pink-base-hsl: 303 42% 83%; + --text-normal: hsl(225 35% 30%); + --text-muted: hsl(225 35% 40%); + --text-faint: hsl(225 35% 50%); + --background-primary: hsl(225 35% 95%); + --background-primary-alt: hsl(225 35% 93%); + --background-secondary: hsl(225 35% 90%); + --background-secondary-blur: hsl(225 35% 90% / 80%); + --background-secondary-alt: hsl(225 35% 79%); + --shadow-s: hsl(225 35% 7% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(225 35% 7% / 4%) 0 1px 2px, + hsl(225 35% 7% / 4%) 0 2px 4px, + hsl(225 35% 7% / 4%) 0 4px 8px, + hsl(225 35% 7% / 4%) 0 8px 16px; +} +.theme-dark.pt-color-scheme-indigo-dt { + --grey100: hsl(233 5% 23%); + --grey200: hsl(233 5% 40%); + --grey300: hsl(233 5% 69%); + --red100: hsl(345 65% 21%); + --red200: hsl(345 65% 36%); + --red300: hsl(345 77% 70%); + --orange100: hsl(12 62% 23%); + --orange200: hsl(12 62% 40%); + --orange300: hsl(12 78% 69%); + --yellow100: hsl(36 69% 19%); + --yellow200: hsl(36 69% 32%); + --yellow300: hsl(36 65% 61%); + --green100: hsl(121 28% 23%); + --green200: hsl(121 28% 36%); + --green300: hsl(121 43% 59%); + --mint100: hsl(149 33% 25%); + --mint200: hsl(149 33% 37%); + --mint300: hsl(149 60% 57%); + --cyan100: hsl(180 38% 20%); + --cyan200: hsl(180 38% 33%); + --cyan300: hsl(180 45% 49%); + --blue100: hsl(232 31% 24%); + --blue200: hsl(232 31% 45%); + --blue300: hsl(232 74% 73%); + --purple100: hsl(255 36% 22%); + --purple200: hsl(255 36% 45%); + --purple300: hsl(255 60% 71%); + --pink100: hsl(303 41% 22%); + --pink200: hsl(303 41% 40%); + --pink300: hsl(303 62% 68%); + --color-grey-base-hsl: 233 5% 23%; + --color-red-base-hsl: 345 65% 21%; + --color-orange-base-hsl: 12 62% 23%; + --color-yellow-base-hsl: 36 69% 19%; + --color-green-base-hsl: 121 28% 23%; + --color-mint-base-hsl: 149 33% 25%; + --color-cyan-base-hsl: 180 38% 20%; + --color-blue-base-hsl: 232 31% 24%; + --color-purple-base-hsl: 255 36% 22%; + --color-pink-base-hsl: 303 41% 22%; + --text-normal: hsl(245 30% 85%); + --text-muted: hsl(245 30% 75%); + --text-faint: hsl(245 30% 65%); + --background-primary: hsl(245 30% 16%); + --background-primary-alt: hsl(245 30% 20%); + --background-secondary: hsl(245 30% 11.2%); + --background-secondary-blur: hsl(245 30% 11.2% / 80%); + --background-secondary-alt: hsl(245 30% 8.5%); + --shadow-s: hsl(245 30% 7% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(245 30% 7% / 10%) 0 1px 2px, + hsl(245 30% 7% / 10%) 0 2px 4px, + hsl(245 30% 7% / 10%) 0 4px 8px, + hsl(245 30% 7% / 10%) 0 8px 16px; +} +.theme-light.pt-color-scheme-pistachio-lt { + --grey100: hsl(233 5% 82%); + --grey200: hsl(233 5% 68%); + --grey300: hsl(233 5% 47%); + --red100: hsl(355 70% 83%); + --red200: hsl(355 70% 74%); + --red300: hsl(355 53% 55%); + --orange100: hsl(21 66% 82%); + --orange200: hsl(21 66% 73%); + --orange300: hsl(21 54% 52%); + --yellow100: hsl(40 70% 83%); + --yellow200: hsl(40 70% 70%); + --yellow300: hsl(40 55% 46%); + --green100: hsl(110 35% 81%); + --green200: hsl(110 35% 68%); + --green300: hsl(110 45% 40%); + --mint100: hsl(151 40% 82%); + --mint200: hsl(151 40% 67%); + --mint300: hsl(151 58% 38%); + --cyan100: hsl(190 31% 85%); + --cyan200: hsl(190 31% 72%); + --cyan300: hsl(190 50% 40%); + --blue100: hsl(222 27% 84%); + --blue200: hsl(222 27% 74%); + --blue300: hsl(222 30% 56%); + --purple100: hsl(260 38% 82%); + --purple200: hsl(260 38% 73%); + --purple300: hsl(260 36% 51%); + --pink100: hsl(323 42% 83%); + --pink200: hsl(323 42% 72%); + --pink300: hsl(323 42% 50%); + --color-grey-base-hsl: 233 5% 82%; + --color-red-base-hsl: 355 70% 83%; + --color-orange-base-hsl: 21 66% 82%; + --color-yellow-base-hsl: 40 70% 83%; + --color-green-base-hsl: 110 35% 81%; + --color-mint-base-hsl: 151 40% 82%; + --color-cyan-base-hsl: 190 31% 85%; + --color-blue-base-hsl: 222 27% 84%; + --color-purple-base-hsl: 260 38% 82%; + --color-pink-base-hsl: 323 42% 83%; + --text-normal: hsl(135 35% 20%); + --text-muted: hsl(135 35% 30%); + --text-faint: hsl(135 35% 40%); + --background-primary: hsl(135 35% 95.5%); + --background-primary-alt: hsl(135 35% 93%); + --background-secondary: hsl(135 35% 90.5%); + --background-secondary-blur: hsl(135 35% 90.5% / 80%); + --background-secondary-alt: hsl(135 35% 75%); + --shadow-s: hsl(135 35% 7% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(135 35% 7% / 4%) 0 1px 2px, + hsl(135 35% 7% / 4%) 0 2px 4px, + hsl(135 35% 7% / 4%) 0 4px 8px, + hsl(135 35% 7% / 4%) 0 8px 16px; +} +.theme-dark.pt-color-scheme-pine-dt { + --grey100: hsl(233 2% 23%); + --grey200: hsl(233 2% 42%); + --grey300: hsl(233 2% 71%); + --red100: hsl(355 58% 21%); + --red200: hsl(355 58% 40%); + --red300: hsl(355 74% 70%); + --orange100: hsl(21 62% 22%); + --orange200: hsl(21 62% 40%); + --orange300: hsl(21 72% 62%); + --yellow100: hsl(40 70% 20%); + --yellow200: hsl(40 70% 33%); + --yellow300: hsl(40 70% 53%); + --green100: hsl(110 35% 23%); + --green200: hsl(110 35% 37%); + --green300: hsl(110 48% 52%); + --mint100: hsl(151 31% 25%); + --mint200: hsl(151 31% 38%); + --mint300: hsl(151 58% 52%); + --cyan100: hsl(190 38% 20%); + --cyan200: hsl(190 38% 35%); + --cyan300: hsl(190 50% 53%); + --blue100: hsl(222 30% 24%); + --blue200: hsl(222 30% 46%); + --blue300: hsl(222 70% 70%); + --purple100: hsl(260 40% 22%); + --purple200: hsl(260 40% 47%); + --purple300: hsl(260 65% 73%); + --pink100: hsl(323 46% 22%); + --pink200: hsl(323 46% 42%); + --pink300: hsl(323 67% 73%); + --color-grey-base-hsl: 233 2% 23%; + --color-red-base-hsl: 355 58% 21%; + --color-orange-base-hsl: 21 62% 22%; + --color-yellow-base-hsl: 40 70% 20%; + --color-green-base-hsl: 110 35% 23%; + --color-mint-base-hsl: 151 31% 25%; + --color-cyan-base-hsl: 190 38% 20%; + --color-blue-base-hsl: 222 30% 24%; + --color-purple-base-hsl: 260 40% 22%; + --color-pink-base-hsl: 323 46% 22%; + --text-normal: hsl(135 35% 85%); + --text-muted: hsl(135 35% 70%); + --text-faint: hsl(135 35% 60%); + --background-primary: hsl(135 35% 12%); + --background-primary-alt: hsl(135 35% 15.5%); + --background-secondary: hsl(135 35% 7.7%); + --background-secondary-blur: hsl(135 35% 7.7% / 80%); + --background-secondary-alt: hsl(135 35% 6%); + --shadow-s: hsl(135 35% 7% / 10%) 0 1px 2px 0; + --shadow-l: + hsl(135 35% 7% / 10%) 0 1px 2px, + hsl(135 35% 7% / 10%) 0 2px 4px, + hsl(135 35% 7% / 10%) 0 4px 8px, + hsl(135 35% 7% / 10%) 0 8px 16px; +} +body.pt-titlebar-hide-text .titlebar .titlebar-text { + display: none; +} +.mod-windows .titlebar-button.mod-close:hover { + color: hsl(0deg, 100%, 100%); + background-color: #C42B1C; +} +.pt-status-bar-position-floating .status-bar { + --status-bar-position: absolute; + right: 0; + left: 0; + width: fit-content; + margin: 0 auto calc(var(--size-2-3) + var(--scroll-bar-size)); + background: var(--background-secondary-blur); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); + box-shadow: var(--shadow-l); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.pt-status-bar-position-fixed .status-bar { + --status-bar-position: relative; + padding: 1px var(--size-4-2); + border-top: 1px solid var(--window-border); + border-radius: unset; +} +.pt-fixed-status-bar-align-left .status-bar { + justify-content: flex-start; +} +.pt-fixed-status-bar-align-center .status-bar { + justify-content: center; +} +.pt-fixed-status-bar-align-right .status-bar { + justify-content: flex-end; +} +.theme-light.pt-status-bar-custom-lt .status-bar { + background: var(--status-bar-background-color-lt); +} +.theme-dark.pt-status-bar-custom-dt .status-bar { + background: var(--status-bar-background-color-dt); +} +:is(.theme-light.pt-status-bar-text-light-lt, .theme-dark.pt-status-bar-text-dark-dt) .status-bar { + color: var(--background-primary); +} +:is(.theme-light.pt-status-bar-text-dark-lt, .theme-dark.pt-status-bar-text-light-dt) .status-bar { + color: var(--text-muted); +} +:is(.theme-light.pt-status-bar-text-accent-lt, .theme-dark.pt-status-bar-text-accent-dt) .status-bar { + color: var(--interactive-accent-text); +} +.workspace-tab-header { + padding: 0 var(--size-4-2); + border: var(--accent-border-width) solid transparent; + border-radius: var(--radius-m); +} +.workspace-tab-header.is-active { + border-radius: var(--radius-m); +} +.workspace-tab-header.is-active:hover svg { + color: var(--interactive-accent-hover); +} +.workspace-tab-header.is-active .workspace-tab-header-inner-icon { + color: var(--icon-color-focused); +} +.workspace-tab-header::before, +.workspace-tab-header::after { + display: none; +} +.mod-left-split .workspace-tabs .workspace-tab-header-spacer, +.mod-right-split .workspace-tabs .workspace-tab-header-spacer { + display: none; +} +.pt-fade-inactive-tabs :not(.mod-active) .workspace-tab-header.is-active:not(.mod-active) { + opacity: 0.55; +} +.workspace-tab-header-container { + padding-right: unset; + padding-left: 1px; +} +.workspace .mod-root .workspace-tab-header { + padding: unset; +} +.mod-root .workspace-tab-header-inner { + gap: var(--size-4-1); + padding: 0 var(--size-4-1) 0 var(--size-4-2); +} +.workspace-tab-header-inner-close-button::after { + display: none; +} +.workspace .mod-root .workspace-tab-header-inner::after { + display: none; +} +.workspace-tab-header:not(.is-active):hover .workspace-tab-header-inner-title { + color: var(--highlight-text-normal); +} +.workspace-tabs .workspace-tab-header-container-inner { + gap: var(--size-4-1); + padding: unset; + margin: var(--size-4-1); +} +:is(.workspace-tab-header-tab-list, .workspace-tab-header-new-tab) { + margin-left: unset; +} +:is(.workspace-tab-header-tab-list, .workspace-tab-header-new-tab) .clickable-icon { + padding: var(--size-4-1); +} +.workspace-tab-header-new-tab { + padding: var(--size-4-1) 0; +} +.workspace-tab-header-tab-list { + padding: var(--size-4-1); + margin-right: unset; +} +.workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header { + background-color: var(--background-secondary); + border: unset; + border-right: 1px solid var(--window-border); +} +.workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header:not(.is-active) .workspace-tab-header-inner { + padding-top: 10px; +} +.workspace-split.mod-left-split .workspace-tab-header-container { +} +.pt-tab-label-left-sidebar-left .workspace-split.mod-left-split .workspace-tab-header-container { + justify-content: flex-start; +} +.pt-tab-label-left-sidebar-center .workspace-split.mod-left-split .workspace-tab-header-container { + justify-content: center; +} +.pt-tab-label-left-sidebar-right .workspace-split.mod-left-split .workspace-tab-header-container { + justify-content: flex-end; +} +.workspace-split.mod-right-split .workspace-tab-header-container { +} +.pt-tab-label-right-sidebar-left .workspace-split.mod-right-split .workspace-tab-header-container { + justify-content: flex-start; +} +.pt-tab-label-right-sidebar-center .workspace-split.mod-right-split .workspace-tab-header-container { + justify-content: center; +} +.pt-tab-label-right-sidebar-right .workspace-split.mod-right-split .workspace-tab-header-container { + justify-content: flex-end; +} +.nav-header { + display: flex; + height: var(--header-height); + background-color: var(--background-secondary); + border-bottom: 1px solid var(--window-border); +} +.nav-buttons-container { + gap: var(--size-4-1); + align-items: center; + width: fit-content; +} +.nav-action-button { + display: flex; + align-items: center; + justify-content: center; + width: 26px; + height: 26px; + padding: 2px; + border-radius: var(--radius-m); +} +:is(.nav-files-container, .workspace-leaf-content[data-type=tag] .tag-container, .workspace-leaf-content[data-type=backlink] .backlink-pane, .workspace-leaf-content[data-type=search] .search-results-children, .workspace-leaf-content[data-type=starred] .item-list, .workspace-leaf-content[data-type=dictionary-view] .contents) { + padding-bottom: calc(38px + 2 * var(--scroll-bar-size)); +} +.workspace-leaf-content .nav-header { +} +:is(.pt-nav-header-left-sidebar-align-left .workspace-split.mod-left-split .workspace-leaf-content .nav-header, .pt-nav-header-right-sidebar-align-left .workspace-split.mod-right-split .workspace-leaf-content .nav-header) { + justify-content: flex-start; +} +:is(.pt-nav-header-left-sidebar-align-center .workspace-split.mod-left-split .workspace-leaf-content .nav-header, .pt-nav-header-right-sidebar-align-center .workspace-split.mod-right-split .workspace-leaf-content .nav-header) { + justify-content: center; +} +:is(.pt-nav-header-left-sidebar-align-right .workspace-split.mod-left-split .workspace-leaf-content .nav-header, .pt-nav-header-right-sidebar-align-right .workspace-split.mod-right-split .workspace-leaf-content .nav-header) { + justify-content: flex-end; +} +:is(.pt-nav-header-left-sidebar-position-bottom .workspace-split.mod-left-split, .pt-nav-header-right-sidebar-position-bottom .workspace-split.mod-right-split, .pt-nav-header-left-sidebar-position-bottom .workspace-drawer.mod-left, .pt-nav-header-right-sidebar-position-bottom .workspace-drawer.mod-right) .nav-header { + position: absolute; + bottom: calc(var(--size-2-3) + var(--scroll-bar-size)); + z-index: var(--layer-popover); + order: 2; + width: -webkit-fill-available; + width: fill-available; + height: unset; + padding: 0 var(--size-4-4); + pointer-events: none; + background-color: unset; + border-bottom: unset; +} +:is(.pt-nav-header-left-sidebar-position-bottom .workspace-split.mod-left-split, .pt-nav-header-right-sidebar-position-bottom .workspace-split.mod-right-split, .pt-nav-header-left-sidebar-position-bottom .workspace-drawer.mod-left, .pt-nav-header-right-sidebar-position-bottom .workspace-drawer.mod-right) .nav-buttons-container { + padding: var(--size-4-1); + pointer-events: auto; + background: var(--background-secondary-blur); + border: 1px solid var(--window-border); + border-radius: var(--radius-m); + box-shadow: var(--shadow-l); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.modal.mod-settings .vertical-tab-header { + flex: none; + width: 215px; + min-width: unset; + max-width: unset; + padding: 0; +} +.modal.mod-settings .vertical-tab-header::before { + position: sticky; + top: 0; + display: block; + width: -webkit-fill-available; + width: fill-available; + height: 42px; + margin-bottom: -1px; + content: ""; + background: var(--background-secondary-blur); + border-bottom: 1px solid var(--window-border); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.modal.mod-settings .vertical-tab-header::after { + position: absolute; + top: var(--size-4-2); + left: var(--size-4-2); + display: inline-flex; + flex-direction: column; + align-content: center; + justify-content: center; + width: fit-content; + height: 24px; + padding: 0 8px; + font-size: 14px; + font-weight: 600; + color: var(--interactive-accent-text); + content: "Prism v3.0.0 Beta 9"; + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +.theme-light .modal.mod-settings .vertical-tab-header::after { + background-color: var(--background-primary); +} +.theme-dark .modal.mod-settings .vertical-tab-header::after { + background-color: var(--background-secondary-alt); +} +.vertical-tab-content { + height: calc(100% - 43px); +} +.vertical-tab-content-container::before { + position: relative; + z-index: var(--layer-status-bar); + display: block; + width: -webkit-fill-available; + width: fill-available; + height: 42px; + content: ""; + background: var(--background-secondary-blur); + border-bottom: 1px solid var(--window-border); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.vertical-tab-header-group { + padding: unset; +} +.vertical-tab-header-group-title { + font-size: var(--font-ui-medium); + color: var(--text-normal); + text-align: center; + background-color: var(--background-secondary); + border-top: 1px solid var(--window-border); + border-bottom: 1px solid var(--window-border); +} +.vertical-tab-header-group-items { + gap: var(--size-2-1); + padding: var(--size-4-2); +} +:is(.horizontal-tab-content, .vertical-tab-content) { + padding: var(--size-4-8); +} +.theme-light :is(.horizontal-tab-content, .vertical-tab-content, .vertical-tab-header) { + background-color: var(--background-primary); +} +.theme-dark :is(.horizontal-tab-content, .vertical-tab-content, .vertical-tab-header) { + background-color: var(--background-secondary-alt); +} +.installed-plugins-container { + padding-top: var(--size-4-2); + border-top: unset; +} +.plugin-list-plugins:last-child { + padding-top: var(--size-4-1); +} +.vertical-tab-nav-item { + padding: var(--size-2-1) var(--size-4-2); + margin-bottom: unset; + color: var(--text-muted); + border: var(--accent-border-width) solid transparent; +} +@media (hover: hover) { + .horizontal-tab-nav-item:hover, + .vertical-tab-nav-item:hover { + color: var(--icon-color-focused); + } +} +.modal.mod-image-lightbox { + width: var(--modal-width); + max-width: var(--modal-max-width); + height: var(--modal-height); + max-height: var(--modal-max-height); +} +.modal.mod-image-lightbox .modal-content { + display: flex; + align-content: center; + justify-content: center; + height: 100%; + padding: var(--size-4-2); +} +img.community-theme-lightbox { + object-fit: contain; + max-width: 100%; + max-height: 100%; +} +.modal.mod-community-theme { + max-width: var(--modal-max-width); + max-height: var(--modal-max-height); +} +.community-modal-sidebar { + padding: unset; +} +.theme-light .community-modal-sidebar { + background-color: var(--background-primary); +} +.theme-dark .community-modal-sidebar { + background-color: var(--background-secondary-alt); +} +.community-modal-info { + display: grid; + grid-template-areas: "info-name button-container button-container" "info-author info-version info-version" "info-repo info-repo info-downloads" "info-desc info-desc info-desc" "seperator seperator seperator" "readme readme readme"; + row-gap: var(--size-2-1); + padding: var(--size-4-8) var(--size-4-12); +} +.community-modal-info hr { + grid-area: seperator; + margin: 1em 0; +} +.community-modal-button-container { + display: flex; + grid-area: button-container; + gap: var(--size-4-2); + justify-content: flex-end; + margin: unset; +} +.community-modal-button-container button { + margin-right: unset; +} +.community-modal-info-name { + display: flex; + grid-area: info-name; + align-items: center; + margin-bottom: unset; +} +.community-modal-info-downloads { + display: flex; + grid-area: info-downloads; + align-items: center; + justify-content: flex-end; + margin-top: unset; + font-weight: 500; +} +.community-modal-info-author { + display: flex; + grid-area: info-author; + align-items: center; + justify-content: left; + font-weight: 500; +} +.community-modal-info-author a { + margin-left: var(--size-4-1); +} +.community-modal-info-version { + display: flex; + grid-area: info-version; + align-items: center; + justify-content: flex-end; + font-weight: 500; +} +.community-modal-info-repo { + display: flex; + grid-area: info-repo; + align-items: center; + justify-content: flex-start; + font-weight: 500; +} +.community-modal-info-desc { + grid-area: info-desc; +} +.community-modal-readme { + grid-area: readme; +} +.modal.mod-community-theme .community-item { + display: grid; + grid-template-areas: "item-name item-name" "item-author item-downloads" "item-screenshot item-screenshot"; +} +.modal.mod-community-plugin .community-item { + display: grid; + grid-template-areas: "item-name item-name" "item-author item-downloads" "item-desc item-desc"; +} +.community-item-name { + display: inline-flex; + grid-area: item-name; + font-weight: var(--font-semibold); +} +.community-item-author { + grid-area: item-author; + font-weight: 500; +} +.community-item-downloads { + display: flex; + grid-area: item-downloads; + justify-content: flex-end; + margin-bottom: unset; + font-weight: 500; +} +.community-item-screenshot { + grid-area: item-screenshot; + margin-top: var(--size-4-2); + image-rendering: unset; +} +.community-item-desc { + grid-area: item-desc; +} +.community-item .flair { + height: fit-content; + margin-left: auto; +} +.community-modal-controls { + position: absolute; + display: flex; + gap: var(--size-4-3); + align-items: center; + width: 100%; + height: 43px; + background-color: var(--background-secondary); + border-bottom: 1px solid var(--window-border); +} +.community-modal-controls .community-modal-search-summary { + display: inline-flex; + width: fit-content; + padding: 0 var(--size-4-1) 0; +} +.community-modal-controls .setting-item { + display: inline-flex; + padding: unset; +} +.community-modal-controls .setting-item:first-child { + margin-bottom: unset; +} +.modal-setting-nav-bar { + position: absolute; + height: 0; + padding: 0 var(--size-4-2); + border-bottom: unset; +} +.modal-setting-nav-bar .clickable-icon { + width: 30px; + height: 30px; + padding: var(--size-4-1); + margin-top: var(--size-4-2); +} +.modal-setting-nav-bar .clickable-icon svg.svg-icon { + width: 28px; + height: 28px; +} +.community-modal-search-results-wrapper { + border-top: unset; +} +:is(.community-modal-search-results-wrapper, .community-modal-details) { + margin-top: 43px; +} +.setting-item { + padding: var(--size-4-2) 0; + border-top: unset; +} +.setting-item.setting-item-heading { + margin-bottom: var(--size-4-1); + border-bottom: 1px solid var(--window-border); +} +.setting-item-name { + font-weight: var(--font-medium); +} +body:not(.native-scrollbars) .modal-close-button { + top: var(--size-4-1); + right: var(--size-4-1); + z-index: var(--layer-popover); +} +.mod-warning { + color: var(--color-red-text); +} +.setting-hotkey { + font-family: var(--font-interface); +} +.checkbox-container { + height: 24px; + background-color: var(--background-secondary); + border: 1px solid var(--window-border); + box-shadow: unset; +} +.checkbox-container::after { + border: 1px solid var(--window-border); + box-shadow: unset; +} +.checkbox-container.is-enabled { + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-tint); +} +.checkbox-container.is-enabled::after { + border-color: var(--interactive-accent-tint); + transform: translate3d(calc(var(--toggle-width) - var(--toggle-thumb-width) - var(--toggle-border-width) - 4px), 0, 0); +} +.checkbox-container.mod-small { + height: 20px; +} +.checkbox-container.mod-small::after { + margin: 1px 0 0; + transform: translate3d(1px, 0, 0); +} +.checkbox-container.mod-small.is-enabled::after { + transform: translate3d(calc(var(--toggle-s-width) - var(--toggle-s-thumb-width) - var(--toggle-s-border-width) - 1px), 0, 0); +} +input[type=range] { + width: 125px; + height: 0.7em; + background-color: var(--background-secondary); + border: 1px solid var(--window-border); + border-radius: var(--size-2-1); +} +input[type=range]::-webkit-slider-thumb { + height: 19px; + background-color: var(--toggle-thumb-color); + box-shadow: unset; +} +select.dropdown { + font-family: var(--font-interface); + background-color: var(--background-primary); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); + box-shadow: var(--shadow-s); +} +select.dropdown option[value*=accent]:not([value*=accent-style]):not([value*=accent-color]) { + color: var(--interactive-accent-text); + background-color: var(--interactive-accent-base); +} +select.dropdown option[value*=red] { + color: var(--color-red-text); + background-color: var(--color-red-base); +} +select.dropdown option[value*=orange] { + color: var(--color-orange-text); + background-color: var(--color-orange-base); +} +select.dropdown option[value*=yellow] { + color: var(--color-yellow-text); + background-color: var(--color-yellow-base); +} +select.dropdown option[value*=green] { + color: var(--color-green-text); + background-color: var(--color-green-base); +} +select.dropdown option[value*=mint] { + color: var(--color-mint-text); + background-color: var(--color-mint-base); +} +select.dropdown option[value*=cyan] { + color: var(--color-cyan-text); + background-color: var(--color-cyan-base); +} +select.dropdown option[value*=blue] { + color: var(--color-blue-text); + background-color: var(--color-blue-base); +} +select.dropdown option[value*=purple] { + color: var(--color-purple-text); + background-color: var(--color-purple-base); +} +select.dropdown option[value*=pink] { + color: var(--color-pink-text); + background-color: var(--color-pink-base); +} +select.dropdown option[value*=grey] { + color: var(--color-grey-text); + background-color: var(--color-grey-base); +} +body:not(.native-scrollbars) .kanban-plugin__scroll-container::-webkit-scrollbar, +body:not(.native-scrollbars) ::-webkit-scrollbar { + width: var(--scroll-bar-size); + height: var(--scroll-bar-size); + background-color: var(--background-secondary); + border-radius: unset; +} +body:not(.native-scrollbars) .kanban-plugin__scroll-container::-webkit-scrollbar:vertical, +body:not(.native-scrollbars) ::-webkit-scrollbar:vertical { + border-left: 1px solid var(--window-border); +} +body:not(.native-scrollbars) .kanban-plugin__scroll-container::-webkit-scrollbar:horizontal, +body:not(.native-scrollbars) ::-webkit-scrollbar:horizontal { + border-top: 1px solid var(--window-border); +} +body:not(.native-scrollbars) .kanban-plugin__scroll-container::-webkit-scrollbar-thumb, +body:not(.native-scrollbars) ::-webkit-scrollbar-thumb { + border: 1px solid var(--window-border); + border-radius: unset; +} +body:not(.native-scrollbars) .kanban-plugin__scroll-container::-webkit-scrollbar-thumb:active, +body:not(.native-scrollbars) .kanban-plugin__scroll-container::-webkit-scrollbar-thumb:hover, +body:not(.native-scrollbars) ::-webkit-scrollbar-thumb:active, +body:not(.native-scrollbars) ::-webkit-scrollbar-thumb:hover { + border-radius: unset; +} +.show-view-header .cm-scroller::-webkit-scrollbar-track { + margin-top: var(--header-height) !important; +} +.progress-bar { + background-color: var(--background-secondary-blur); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.progress-bar-line { + background-color: var(--interactive-accent-base); +} +.progress-bar-subline { + background-color: var(--interactive-accent-base); + border: 2px solid var(--interactive-accent-tint); + border-radius: var(--radius-s); +} +body:not(.css-settings-manager) .workspace-split.mod-left-split::before { + display: block; + width: -webkit-fill-avaliable; + height: fit-content; + padding: 10px; + font-weight: 600; + text-align: center; + content: "Style Settings Plugin is required for Prism to function correctly!"; + background-color: var(--color-red-base); + border: var(--accent-border-width) solid var(--color-red-tint); + border-radius: var(--radius-m); +} +:is(.workspace-split.mod-vertical > * > .workspace-leaf-resize-handle, .workspace-split.mod-left-split > .workspace-leaf-resize-handle, .workspace-split.mod-right-split > .workspace-leaf-resize-handle) { + height: calc(var(--divider-vertical-height) - var(--header-height)); +} +.theme-light .workspace-tabs .workspace-leaf { + background-color: var(--background-primary); +} +.theme-dark .workspace-tabs .workspace-leaf { + background-color: var(--background-secondary-alt); +} +:is(.is-focused .workspace-leaf.mod-active .view-header, .view-header) { + position: fixed; + width: 100%; + background: var(--background-secondary-blur); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.workspace-tabs .view-header { + margin: unset; + border-bottom: 1px solid var(--window-border); +} +.view-header-nav-buttons { + padding-left: var(--size-4-2); +} +.view-header-title-container::after { + display: none; +} +.view-actions { + padding-right: var(--size-4-2); +} +.is-focused .workspace-leaf.mod-active .view-header-title, +.view-header-title { + color: var(--interactive-accent-text); +} +.is-focused .workspace-leaf.mod-active .view-header-title:hover, +.view-header-title:hover { + color: var(--text-accent-hover); +} +.view-header-title-parent .view-header-breadcrumb:hover { + color: var(--highlight-text-normal); +} +.show-view-header { + --file-margins: 64px 32px 32px 32px; +} +:is(.workspace-ribbon.mod-left, .workspace-split.mod-right-split, .workspace-split.mod-vertical.mod-root) .sidebar-toggle-button { + width: fit-content; + height: calc(var(--header-height) - 9px); + padding: 2px; + margin: 4px; + border: 2px solid transparent; + border-radius: var(--radius-m); +} +:is(.mod-active .document-search-container, .document-search-container) { + position: relative; + right: var(--scroll-bar-size); + height: var(--header-height); + padding: var(--size-4-1) 0; + margin: unset; + background: var(--background-secondary-blur); + border-bottom: 1px solid var(--window-border); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +:is(.mod-active .document-search-container, .document-search-container) .document-search-input.mod-no-match { + background-color: var(--color-red-base); + border: 2px solid var(--color-red-tint); +} +.popover { + background-color: var(--page-background-color); + box-shadow: var(--shadow-l); +} +.popover.hover-popover { + border: 1px solid var(--window-border); +} +:is(.markdown-embed-link, .file-embed-link) { + right: 12px; +} +.menu { + background: var(--background-secondary-blur); + border-color: var(--window-border); + box-shadow: var(--shadow-l); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +div.notice-container div.notice { + font-weight: 600; + color: var(--text-normal); + background: var(--interactive-accent-base); + border: 2px solid var(--interactive-accent-tint); + border-radius: var(--radius-m); + box-shadow: var(--shadow-s); +} +.prompt-instructions { + padding-bottom: unset; +} +.tooltip { + display: flex; + font-weight: 600; + color: var(--text-normal); + background: var(--background-secondary); + border: 1px solid var(--window-border); + border-radius: var(--radius-m); + box-shadow: var(--shadow-l); +} +.tooltip .tooltip-arrow { + margin-top: -1px; + border-bottom-color: var(--window-border); +} +.tooltip.mod-top .tooltip-arrow { + margin-top: unset; + margin-top: 1px; + border-top-color: var(--window-border); +} +.tooltip.mod-right .tooltip-arrow { + margin-top: unset; + margin-left: -6px; + border-right-color: var(--window-border); +} +.tooltip.mod-left .tooltip-arrow { + margin-top: unset; + margin-left: -2px; + border-left-color: var(--window-border); +} +.tooltip.mod-error { + color: var(--highlight-text-normal); + background-color: var(--color-red-base); + border-color: var(--color-red-tint); +} +.drag-ghost { + background: var(--background-secondary); + border: 2px solid var(--window-border); + box-shadow: var(--shadow-l); + animation: pop-down 200ms forwards ease-in-out; +} +.modal button:not(.mod-cta):not(.mod-warning) { + display: inline-flex; + flex-direction: column; + align-items: center; + justify-content: center; +} +.workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header.is-active, +.workspace-tab-header.is-active, +.nav-action-button.is-active, +.vertical-tab-nav-item.is-active, +.nav-file-title.is-active, +.suggestion-hotkey { + color: var(--highlight-text-normal); + border: var(--accent-border-width) solid; + box-shadow: unset; +} +:is(.search-result-file-match-destination-file, .search-result-file-match-replace-button) { + color: var(--text-normal); + border: var(--accent-border-width) solid; + border-radius: var(--radius-s); +} +button.mod-cta { + color: var(--highlight-text-normal); +} +:is(.pcr-button, button.mod-cta, button.mod-warning, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .setting-hotkey, .flair.mod-pop, .community-item .flair, button.copy-code-button, .modal-setting-nav-bar .clickable-icon, .document-search-button, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]) { + border: var(--accent-border-width) solid; + border-radius: var(--radius-s); +} +.side-dock-ribbon-action.is-active[aria-label="Start/stop recording"] { + padding: var(--size-2-1) var(--size-2-2); +} +:is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left) { + color: var(--highlight-text-normal); + border: var(--accent-border-width) solid; + border-radius: var(--radius-m); +} +:is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left) svg.svg-icon { + color: var(--highlight-text-normal); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .nav-action-button.is-active, +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .vertical-tab-nav-item.is-active, +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .nav-file-title.is-active, +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .suggestion-hotkey { + background-color: var(--background-primary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .search-result-file-match-destination-file { + color: var(--text-normal); + background-color: var(--background-secondary); + border-color: var(--background-secondary); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .search-result-file-match-destination-file:hover { + color: var(--interactive-accent-hover); + background-color: var(--background-secondary); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .search-result-file-match-replace-button { + background-color: var(--background-secondary); + border-color: var(--background-secondary); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .search-result-file-match-replace-button:hover { + color: var(--interactive-accent-text); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) button.mod-cta { + background-color: var(--background-primary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) button.mod-cta:hover { + color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]) { + color: var(--color-red-text); + background-color: var(--background-primary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]):hover { + color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button) { + color: var(--color-grey-text); + background-color: var(--background-primary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button):hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .setting-command-hotkeys .setting-hotkey { + color: var(--color-blue-text); + background-color: var(--background-primary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .setting-command-hotkeys .setting-hotkey.mod-empty { + color: var(--text-normal); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) .setting-command-hotkeys .setting-hotkey.has-conflict { + color: var(--color-red-text); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(.flair.mod-pop, .community-item .flair) { + color: var(--color-green-text); + background-color: var(--background-secondary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) button.copy-code-button { + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) button.copy-code-button:hover { + color: var(--interactive-accent-hover); +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left) { + background-color: var(--background-primary); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-text-dt, .theme-light.pt-accent-style-text-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left):hover { + color: var(--interactive-accent-hover); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .nav-action-button.is-active, +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .vertical-tab-nav-item.is-active, +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .nav-file-title.is-active, +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .suggestion-hotkey { + background-color: var(--background-primary); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .search-result-file-match-destination-file { + color: var(--text-normal); + background-color: var(--background-secondary); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .search-result-file-match-destination-file:hover { + color: var(--interactive-accent-hover); + background-color: var(--background-secondary); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .search-result-file-match-replace-button { + background-color: var(--background-primary); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .search-result-file-match-replace-button:hover { + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) button.mod-cta { + background-color: var(--background-primary); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) button.mod-cta:hover { + color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]) { + color: var(--text-normal); + background-color: var(--background-primary); + border-color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]):hover { + color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button) { + color: var(--text-normal); + background-color: var(--background-secondary); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button):hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .setting-command-hotkeys .setting-hotkey { + color: var(--text-normal); + background-color: var(--background-secondary); + border-color: var(--color-blue-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .setting-command-hotkeys .setting-hotkey.mod-empty { + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) .setting-command-hotkeys .setting-hotkey.has-conflict { + border-color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(.flair.mod-pop, .community-item .flair) { + color: var(--text-normal); + background-color: var(--background-secondary); + border-color: var(--color-green-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) button.copy-code-button { + color: var(--text-normal); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) button.copy-code-button:hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left) { + background-color: var(--background-primary); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-border-dt, .theme-light.pt-accent-style-border-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left):hover { + color: var(--interactive-accent-hover); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .nav-action-button.is-active, +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .vertical-tab-nav-item.is-active, +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .nav-file-title.is-active, +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .suggestion-hotkey { + background-color: var(--interactive-accent-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .search-result-file-match-destination-file { + color: var(--text-normal); + background-color: var(--color-grey-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .search-result-file-match-destination-file:hover { + color: var(--interactive-accent-hover); + background-color: var(--interactive-accent-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .search-result-file-match-replace-button { + background-color: var(--color-grey-base); + border-color: var(--color-grey-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .search-result-file-match-replace-button:hover { + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) button.mod-cta { + background-color: var(--interactive-accent-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) button.mod-cta:hover { + color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]) { + color: var(--text-normal); + background-color: var(--color-red-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]):hover { + color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button) { + color: var(--text-normal); + background-color: var(--color-grey-base); + border-color: var(--color-grey-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button):hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .setting-command-hotkeys .setting-hotkey { + color: var(--text-normal); + background-color: var(--color-blue-base); + border-color: var(--color-blue-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .setting-command-hotkeys .setting-hotkey.mod-empty { + background-color: var(--color-grey-base); + border-color: var(--color-grey-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) .setting-command-hotkeys .setting-hotkey.has-conflict { + background-color: var(--color-red-base); + border-color: var(--color-red-base); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(.flair.mod-pop, .community-item .flair) { + color: var(--highlight-text-normal); + background-color: var(--color-green-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) button.copy-code-button { + color: var(--text-normal); + background-color: var(--color-grey-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) button.copy-code-button:hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left) { + background-color: var(--interactive-accent-base); + border-color: transparent; +} +:is(.theme-dark.pt-accent-style-filled-dt, .theme-light.pt-accent-style-filled-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left):hover { + color: var(--interactive-accent-hover); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .workspace .mod-root .workspace-tabs.mod-stacked .workspace-tab-container .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .workspace-tab-header.is-active, +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .nav-action-button.is-active, +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .vertical-tab-nav-item.is-active, +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .nav-file-title.is-active, +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .suggestion-hotkey { + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .search-result-file-match-destination-file { + color: var(--text-normal); + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .search-result-file-match-destination-file:hover { + color: var(--interactive-accent-hover); + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .search-result-file-match-replace-button { + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .search-result-file-match-replace-button:hover { + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) button.mod-cta { + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) button.mod-cta:hover { + color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]) { + color: var(--text-normal); + background-color: var(--color-red-base); + border-color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(button.mod-warning, .side-dock-ribbon-action.is-active[aria-label="Start/stop recording"]):hover { + color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button) { + color: var(--text-normal); + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(.pcr-button, .modal button:not(.mod-cta):not(.mod-warning), .graph-control-content button, .modal-setting-nav-bar .clickable-icon, .document-search-button):hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .setting-command-hotkeys .setting-hotkey { + color: var(--text-normal); + background-color: var(--color-blue-base); + border-color: var(--color-blue-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .setting-command-hotkeys .setting-hotkey.mod-empty { + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) .setting-command-hotkeys .setting-hotkey.has-conflict { + background-color: var(--color-red-base); + border-color: var(--color-red-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(.flair.mod-pop, .community-item .flair) { + color: var(--text-normal); + background-color: var(--color-green-base); + border-color: var(--color-green-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) button.copy-code-button { + color: var(--text-normal); + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) button.copy-code-button:hover { + color: var(--color-grey-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left) { + background-color: var(--interactive-accent-base); + border-color: var(--interactive-accent-tint); +} +:is(.theme-dark.pt-accent-style-borderandfilled-dt, .theme-light.pt-accent-style-borderandfilled-lt) :is(.workspace.is-right-sidedock-open .sidebar-toggle-button.mod-right, .workspace.is-left-sidedock-open .sidebar-toggle-button.mod-left):hover { + color: var(--interactive-accent-hover); +} +.theme-light .workspace-split.mod-root .view-content { + background-color: var(--background-primary); +} +.theme-dark .workspace-split.mod-root .view-content { + background-color: var(--background-secondary-alt); +} +p { + margin-block-start: 0.5em; + margin-block-end: 0.5em; +} +.theme-light :is(em strong, .cm-em.cm-strong) { + color: var(--text-italic-bold-color-lt); +} +.theme-dark :is(em strong, .cm-em.cm-strong) { + color: var(--text-italic-bold-color-dt); +} +:is(.cm-inline-code, .cm-math) { + padding: 0 var(--size-4-1); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +:is(.HyperMD-codeblock.HyperMD-codeblock-begin, .cm-s-obsidian div.HyperMD-codeblock-begin-bg) { + border-top: 1px solid var(--window-border); +} +.cm-s-obsidian div.HyperMD-codeblock { + border-right: 1px solid var(--window-border); + border-left: 1px solid var(--window-border); +} +:is(.HyperMD-codeblock.HyperMD-codeblock-end, .cm-s-obsidian div.HyperMD-codeblock-end-bg) { + border-bottom: 1px solid var(--window-border); +} +.cm-s-obsidian .cm-hashtag { + font-family: var(--font-text); + font-weight: 600; + vertical-align: middle; +} +.cm-line .cm-hashtag-begin { + background-color: var(--background-secondary); + border: 2px solid var(--window-border); + border-right: unset; + border-top-left-radius: var(--radius-s); + border-bottom-left-radius: var(--radius-s); +} +.cm-line .cm-hashtag-end { + background-color: var(--background-secondary); + border: 2px solid var(--window-border); + border-left: unset; + border-top-right-radius: var(--radius-s); + border-bottom-right-radius: var(--radius-s); +} +.cm-line .cm-hashtag.cm-meta:not(.cm-hashtag-begin, .cm-hashtag-end) { + background-color: var(--background-secondary); + border: 2px solid var(--window-border); + border-right: unset; + border-left: unset; +} +.cm-s-obsidian span.cm-hmd-escape-backslash { + color: var(--color-red-text); +} +:is(code[class*=language-], pre[class*=language-]) { + line-height: var(--line-height-tight); +} +.markdown-source-view.mod-cm6 .cm-embed-block pre { + margin: 1em 0; +} +.markdown-source-view.mod-cm6 .cm-indent::before { + transform: translateX(0.4em); +} +.markdown-source-view.mod-cm6 :is(.cm-formatting-list-ul, .cm-formatting-list-ol) { + padding-right: 0.3em; +} +.markdown-source-view.mod-cm6 .cm-foldPlaceholder { + color: var(--interactive-accent-text); +} +input[type=checkbox] { + border-width: 2px; +} +input[type=checkbox]:checked { + border-color: var(--interactive-accent-tint); +} +input[type=checkbox]:checked::after { + top: -2px; + left: -2px; +} +a.tag { + font-weight: 600; + background-color: var(--background-secondary); + border-color: var(--window-border); + border-radius: var(--radius-s); +} +a.tag:hover { + color: var(--interactive-accent-text); + background-color: var(--background-primary); + border-color: var(--interactive-accent-tint); + transition: all ease 200ms; +} +:is(.markdown-preview-view, .markdown-rendered) :is(code, kbd) { + padding: 0 var(--size-4-1); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +.code-block-flair { + font-weight: 600; + background-color: var(--background-secondary-alt); + border: 1px solid var(--window-border); +} +:is(.markdown-source-view.mod-cm6.is-live-preview .cm-content .HyperMD-quote, .markdown-rendered blockquote) { + padding: var(--size-4-2) var(--size-4-4); + border-width: 1px 1px 1px 5px; +} +:is(.theme-light.pt-highlight-text-color-lt, .theme-dark.pt-highlight-text-color-dt) span.cm-link { + color: var(--link-external-color); +} +:is(.theme-light.pt-highlight-text-color-lt, .theme-dark.pt-highlight-text-color-dt) span.cm-hmd-internal-link { + color: var(--link-color); +} +.theme-light .markdown-rendered mark .internal-link { + color: var(--link-internal-color-lt); +} +.theme-dark .markdown-rendered mark .internal-link { + color: var(--link-internal-color-dt); +} +.markdown-rendered pre { + border: 1px solid var(--window-border); +} +.markdown-rendered :is(h1, h2, h3, h4, h5, h6) { + margin: 0; +} +.markdown-rendered.show-indentation-guide :is(li > ul::before, li > ol::before) { + left: -13px; +} +.callout { + background-color: unset; +} +.callout .callout-title { + position: relative; + z-index: 5; + gap: unset; + align-items: center; + min-height: 36px; + border: 2px solid; + border-radius: var(--radius-m); +} +.callout .callout-title-inner { + padding: var(--size-4-1) 0; + margin-left: var(--size-4-1); +} +.callout .callout-icon { + margin: 0 var(--size-4-1) 0 var(--size-4-2); + border-radius: var(--radius-m); +} +.callout .callout-fold { + display: flex; + align-self: center; + margin-left: auto; +} +.callout .callout-content { + padding: var(--size-4-5) var(--size-4-3) var(--size-4-1) var(--size-4-3); + margin-top: -16px; + border-right: 1px solid; + border-bottom: 1px solid; + border-left: 1px solid; + border-bottom-right-radius: var(--radius-m); + border-bottom-left-radius: var(--radius-m); +} +.callout[data-callout=note] .callout-title { + color: var(--color-grey-text); + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +.callout[data-callout=note] .callout-icon .svg-icon { + color: var(--color-grey-text); +} +.callout[data-callout=note] .callout-content { + background-color: hsla(var(--color-grey-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-grey-tint); +} +:is(.callout[data-callout=abstract], .callout[data-callout=summary], .callout[data-callout=tldr]) .callout-title { + color: var(--color-cyan-text); + background-color: var(--color-cyan-base); + border-color: var(--color-cyan-tint); +} +:is(.callout[data-callout=abstract], .callout[data-callout=summary], .callout[data-callout=tldr]) .callout-icon .svg-icon { + color: var(--color-cyan-text); +} +:is(.callout[data-callout=abstract], .callout[data-callout=summary], .callout[data-callout=tldr]) .callout-content { + background-color: hsla(var(--color-cyan-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-cyan-tint); +} +:is(.callout[data-callout=info], .callout[data-callout=todo]) .callout-title { + color: var(--color-blue-text); + background-color: var(--color-blue-base); + border-color: var(--color-blue-tint); +} +:is(.callout[data-callout=info], .callout[data-callout=todo]) .callout-icon .svg-icon { + color: var(--color-blue-text); +} +:is(.callout[data-callout=info], .callout[data-callout=todo]) .callout-content { + background-color: hsla(var(--color-blue-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-blue-tint); +} +:is(.callout[data-callout=tip], .callout[data-callout=hint], .callout[data-callout=important]) .callout-title { + color: var(--color-mint-text); + background-color: var(--color-mint-base); + border-color: var(--color-mint-tint); +} +:is(.callout[data-callout=tip], .callout[data-callout=hint], .callout[data-callout=important]) .callout-icon .svg-icon { + color: var(--color-mint-text); +} +:is(.callout[data-callout=tip], .callout[data-callout=hint], .callout[data-callout=important]) .callout-content { + background-color: hsla(var(--color-mint-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-mint-tint); +} +:is(.callout[data-callout=success], .callout[data-callout=check], .callout[data-callout=done]) .callout-title { + color: var(--color-green-text); + background-color: var(--color-green-base); + border-color: var(--color-green-tint); +} +:is(.callout[data-callout=success], .callout[data-callout=check], .callout[data-callout=done]) .callout-icon .svg-icon { + color: var(--color-green-text); +} +:is(.callout[data-callout=success], .callout[data-callout=check], .callout[data-callout=done]) .callout-content { + background-color: hsla(var(--color-green-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-green-tint); +} +:is(.callout[data-callout=question], .callout[data-callout=help], .callout[data-callout=faq]) .callout-title { + color: var(--color-yellow-text); + background-color: var(--color-yellow-base); + border-color: var(--color-yellow-tint); +} +:is(.callout[data-callout=question], .callout[data-callout=help], .callout[data-callout=faq]) .callout-icon .svg-icon { + color: var(--color-yellow-text); +} +:is(.callout[data-callout=question], .callout[data-callout=help], .callout[data-callout=faq]) .callout-content { + background-color: hsla(var(--color-yellow-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-yellow-tint); +} +:is(.callout[data-callout=warning], .callout[data-callout=caution], .callout[data-callout=attention]) .callout-title { + color: var(--color-orange-text); + background-color: var(--color-orange-base); + border-color: var(--color-orange-tint); +} +:is(.callout[data-callout=warning], .callout[data-callout=caution], .callout[data-callout=attention]) .callout-icon .svg-icon { + color: var(--color-orange-text); +} +:is(.callout[data-callout=warning], .callout[data-callout=caution], .callout[data-callout=attention]) .callout-content { + background-color: hsla(var(--color-orange-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-orange-tint); +} +:is(.callout[data-callout=failure], .callout[data-callout=fail], .callout[data-callout=missing]) .callout-title { + color: var(--color-red-text); + background-color: var(--color-red-base); + border-color: var(--color-red-tint); +} +:is(.callout[data-callout=failure], .callout[data-callout=fail], .callout[data-callout=missing]) .callout-icon .svg-icon { + color: var(--color-red-text); +} +:is(.callout[data-callout=failure], .callout[data-callout=fail], .callout[data-callout=missing]) .callout-content { + background-color: hsla(var(--color-red-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-red-tint); +} +:is(.callout[data-callout=danger], .callout[data-callout=error]) .callout-title { + color: var(--color-red-text); + background-color: var(--color-red-base); + border-color: var(--color-red-tint); +} +:is(.callout[data-callout=danger], .callout[data-callout=error]) .callout-icon .svg-icon { + color: var(--color-red-text); +} +:is(.callout[data-callout=danger], .callout[data-callout=error]) .callout-content { + background-color: hsla(var(--color-red-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-red-tint); +} +.callout[data-callout=bug] .callout-title { + color: var(--color-pink-text); + background-color: var(--color-pink-base); + border-color: var(--color-pink-tint); +} +.callout[data-callout=bug] .callout-icon .svg-icon { + color: var(--color-pink-text); +} +.callout[data-callout=bug] .callout-content { + background-color: hsla(var(--color-pink-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-pink-tint); +} +.callout[data-callout=example] .callout-title { + color: var(--color-purple-text); + background-color: var(--color-purple-base); + border-color: var(--color-purple-tint); +} +.callout[data-callout=example] .callout-icon .svg-icon { + color: var(--color-purple-text); +} +.callout[data-callout=example] .callout-content { + background-color: hsla(var(--color-purple-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-purple-tint); +} +:is(.callout[data-callout=quote], .callout[data-callout=cite]) .callout-title { + color: var(--color-grey-text); + background-color: var(--color-grey-base); + border-color: var(--color-grey-tint); +} +:is(.callout[data-callout=quote], .callout[data-callout=cite]) .callout-icon .svg-icon { + color: var(--color-grey-text); +} +:is(.callout[data-callout=quote], .callout[data-callout=cite]) .callout-content { + background-color: hsla(var(--color-grey-base-hsl)/var(--callout-background-alpha)); + border-color: var(--color-grey-tint); +} +:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress) { + height: 15px; + vertical-align: middle; +} +:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::before { + position: fixed; + width: inherit; + height: inherit; + font-family: var(--font-editor); + font-family: var(--font-text); + font-size: 10px; + font-weight: 700; + text-align: center; + content: attr(value) " %"; +} +.theme-light :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::before { + text-shadow: + -1px -1px 0 hsla(0deg, 0%, 100%, 0.5), + 1px -1px 0 hsla(0deg, 0%, 100%, 0.5), + -1px 1px 0 hsla(0deg, 0%, 100%, 0.5), + 1px 1px 0 hsla(0deg, 0%, 100%, 0.5); +} +.theme-dark :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::before { + text-shadow: + -1px -1px 0 hsla(0deg, 0%, 0%, 0.5), + 1px -1px 0 hsla(0deg, 0%, 0%, 0.5), + -1px 1px 0 hsla(0deg, 0%, 0%, 0.5), + 1px 1px 0 hsla(0deg, 0%, 0%, 0.5); +} +:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::-webkit-progress-bar { + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +.theme-light :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::-webkit-progress-bar { + background-color: var(--background-secondary); +} +.theme-dark :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::-webkit-progress-bar { + background-color: var(--background-secondary-alt); +} +:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)::-webkit-progress-value { + border: 1px solid; + border-color: transparent; + border-radius: var(--radius-s); +} +:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="0"]::-webkit-progress-value { + border: unset; +} +:is(:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="0"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="1"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="2"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="3"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="4"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="5"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="6"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="7"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="8"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="9"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="10"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="11"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="12"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="13"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="14"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="15"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="16"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="17"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="18"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="19"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="20"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="21"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="22"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="23"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="24"])::-webkit-progress-value { + background-color: var(--color-red-base); + border-color: var(--color-red-tint); +} +:is(:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="25"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="26"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="27"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="28"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="29"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="30"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="31"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="32"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="33"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="34"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="35"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="36"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="37"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="38"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="39"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="40"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="41"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="42"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="43"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="44"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="45"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="46"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="47"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="48"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="49"])::-webkit-progress-value { + background-color: var(--color-orange-base); + border-color: var(--color-orange-tint); +} +:is(:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="50"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="51"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="52"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="53"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="54"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="55"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="56"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="57"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="58"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="59"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="60"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="61"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="62"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="63"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="64"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="65"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="66"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="67"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="68"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="69"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="70"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="71"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="72"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="73"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="74"])::-webkit-progress-value { + background-color: var(--color-yellow-base); + border-color: var(--color-yellow-tint); +} +:is(:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="75"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="76"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="77"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="78"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="79"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="80"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="81"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="82"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="83"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="84"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="85"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="86"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="87"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="88"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="89"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="90"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="91"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="92"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="93"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="94"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="95"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="96"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="97"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="98"], :is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="99"])::-webkit-progress-value { + background-color: var(--color-green-base); + border-color: var(--color-green-tint); +} +:is(.markdown-rendered progress, .markdown-source-view.is-live-preview progress)[value="100"]::-webkit-progress-value { + background-color: var(--color-blue-base); + border-color: var(--color-blue-tint); +} +.theme-light.pt-color-scheme-swan-lt audio { + filter: brightness(100%) contrast(115%); +} +.theme-light.pt-color-scheme-latte-lt audio { + filter: invert(-94%) sepia(4%) saturate(828%) hue-rotate(320deg) brightness(107%) contrast(93%); +} +.theme-light.pt-color-scheme-periwinkle-lt audio { + filter: invert(-98%) sepia(1%) saturate(3004%) hue-rotate(187deg) brightness(96%) contrast(101%); +} +.theme-light.pt-color-scheme-pistachio-lt audio { + filter: invert(-96%) sepia(4%) saturate(313%) hue-rotate(80deg) brightness(103%) contrast(94%); +} +.theme-dark.pt-color-scheme-mocha-dt audio { + filter: sepia(10%) saturate(115%); +} +.theme-dark.pt-color-scheme-indigo-dt audio { + filter: invert(-10%) sepia(10%) saturate(2635%) hue-rotate(205deg) brightness(94%) contrast(97%); +} +.theme-dark.pt-color-scheme-pine-dt audio { + filter: invert(-11%) sepia(15%) saturate(1727%) hue-rotate(82deg) brightness(91%) contrast(91%); +} +.modal-container .prompt { + border: 1px solid var(--window-border); +} +.modal-container .prompt .prompt-results { + padding: var(--size-4-2); +} +.theme-light .modal-container .prompt .prompt-results { + background-color: var(--background-primary); +} +.theme-dark .modal-container .prompt .prompt-results { + background-color: var(--background-secondary-alt); +} +.modal-container .prompt .prompt-results::-webkit-scrollbar-track { + margin-left: 1px solid var(--window-border); + border-radius: unset; +} +.theme-light .modal-container .prompt .prompt-results::-webkit-scrollbar-track { + background-color: var(--background-primary); +} +.theme-dark .modal-container .prompt .prompt-results::-webkit-scrollbar-track { + background-color: var(--background-secondary-alt); +} +.modal-container .prompt .prompt-instructions { + padding: var(--size-2-1) var(--size-4-2); + background-color: var(--background-secondary); + border-top: 1px solid var(--window-border); +} +.modal-container .prompt .suggestion-item.mod-complex .suggestion-hotkey { + font-weight: 600; + border-radius: var(--radius-s); +} +.prompt-input-container { + padding: var(--size-4-2); + margin: unset; + background-color: var(--background-secondary); + border-bottom: 1px solid var(--window-border); +} +input.prompt-input { + height: 40px; + padding: 0 var(--size-4-4); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +input.prompt-input:hover, +input.prompt-input:focus, +input.prompt-input:focus-visible { + border: 1px solid var(--window-border); +} +.suggestion-container { + max-width: 700px; + background-color: var(--background-secondary-blur); + border: 1px solid var(--window-border); + box-shadow: var(--shadow-l); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.suggestion-container .suggestion { + padding: var(--size-4-2); +} +.suggestion-container .suggestion::-webkit-scrollbar-track { + border-radius: var(--radius-s); + box-shadow: var(--shadow-s); +} +.theme-light .suggestion-container .suggestion::-webkit-scrollbar-track { + background-color: var(--background-secondary); +} +.theme-dark .suggestion-container .suggestion::-webkit-scrollbar-track { + background-color: var(--background-secondary-alt); +} +.suggestion-container .suggestion-item { + padding: var(--size-4-2); +} +.suggestion-item.mod-complex { + align-items: center; +} +.suggestion-item.mod-complex .suggestion-content { + overflow: visible; +} +.suggestion-prefix { + padding: 0 var(--size-4-1); + margin-right: var(--size-4-2); + font-size: 0.9em; + font-weight: 600; + color: var(--interactive-accent-text); + background-color: var(--background-secondary); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +.suggestion-prefix::after { + display: none; +} +.workspace-leaf-content[data-type=file-explorer] .nav-files-container { + padding-top: unset; + padding-right: unset; + padding-left: unset; +} +.workspace-leaf-content[data-type=file-explorer] .nav-folder.mod-root > .nav-folder-children { + padding: var(--size-4-1); +} +.nav-folder.mod-root .nav-folder > .nav-folder-children { + padding-left: var(--size-4-1); + margin: var(--size-4-1) 0 var(--size-4-1) 10px; + border-left: 1px solid var(--window-border); +} +.nav-folder.mod-root .nav-folder > .nav-folder-title { + padding-left: var(--size-4-1); +} +:is(.nav-file:not(.mod-root), .nav-folder:not(.mod-root) > .nav-folder-children > .nav-folder) { + margin-left: var(--file-explorer-left-margin); +} +:is(.nav-file-title, .nav-folder-title) { + padding: 1px var(--size-4-2); + border: 2px solid transparent; +} +:is(.nav-file-title, .nav-folder-title).is-being-dragged-over { + background-color: var(--interactive-accent-base); + border: 2px solid var(--interactive-accent-tint); +} +.workspace-leaf.mod-active .nav-folder.has-focus > .nav-folder-title { + background-color: var(--interactive-accent-base); + border: var(--accent-border-width) solid transparent; + border-radius: var(--radius-s); +} +.workspace-leaf.mod-active .nav-file.has-focus { + background-color: var(--interactive-accent-base); + border: unset; + border-radius: var(--radius-s); +} +body:not(.is-grabbing) .nav-file-title.is-being-dragged, +body:not(.is-grabbing) .nav-folder-title.is-being-dragged, +.nav-file-title.is-being-dragged, +.nav-folder-title.is-being-dragged { + color: var(--highlight-text-normal); + background-color: var(--interactive-accent-base); +} +:is(.graph-controls-button.mod-close, .graph-controls-button.mod-reset) { + top: var(--size-4-2); +} +.theme-light :is(.workspace-leaf-content[data-type=graph] .view-content, .workspace-leaf-content[data-type=localgraph] .view-content) { + background-color: var(--page-background-color); +} +.theme-dark :is(.workspace-leaf-content[data-type=graph] .view-content, .workspace-leaf-content[data-type=localgraph] .view-content) { + background-color: var(--background-secondary-alt); +} +.graph-controls { + background: var(--background-secondary-blur); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.graph-controls.is-close { + padding: var(--size-4-1); + background: var(--background-secondary-blur); + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); + border: 1px solid var(--background-modifier-border); +} +.graph-controls :not(.is-close) { + max-height: calc(100% - 25px); +} +.show-view-header .workspace-split.mod-root .graph-controls { + top: calc(var(--header-height) + var(--size-4-3)); +} +.show-view-header .workspace-split.mod-root .graph-controls:not(.is-close) { + max-height: calc(100% - var(--header-height) - 25px); +} +.graph-control-section { + padding: var(--size-4-2); +} +.graph-control-section:last-child .tree-item-children { + padding-bottom: var(--size-4-2); +} +.graph-control-section .tree-item-children { + padding: var(--size-4-1) 0; +} +.graph-control-section .setting-item:not(.mod-search-setting) { + padding: var(--size-2-3) var(--size-4-2); +} +:is(.graph-view.color-fill-unresolved, .graph-view.color-arrow) { + opacity: 1; +} +.theme-light .graph-view.color-line { + color: var(--graph-line-color-lt); +} +.theme-light .graph-view.color-fill { + color: var(--graph-fill-color-lt); +} +.theme-light .graph-view.color-fill-focused { + color: var(--graph-fill-focused-color-lt); +} +.theme-light .graph-view.color-fill-tag { + color: var(--graph-tag-color-lt); +} +.theme-light .graph-view.color-fill-attachment { + color: var(--graph-attachment-color-lt); +} +.theme-light .graph-view.color-fill-unresolved { + color: var(--graph-unresolved-color-lt); +} +.theme-light .graph-view.color-fill-highlight { + color: var(--graph-highlight-color-lt); +} +.theme-light .graph-view.color-line-highlight { + color: var(--graph-highlight-line-color-lt); +} +.theme-dark .graph-view.color-line { + color: var(--graph-line-color-dt); +} +.theme-dark .graph-view.color-fill { + color: var(--graph-fill-color-dt); +} +.theme-dark .graph-view.color-fill-focused { + color: var(--graph-fill-focused-color-dt); +} +.theme-dark .graph-view.color-fill-tag { + color: var(--graph-tag-color-dt); +} +.theme-dark .graph-view.color-fill-attachment { + color: var(--graph-attachment-color-dt); +} +.theme-dark .graph-view.color-fill-unresolved { + color: var(--graph-unresolved-color-dt); +} +.theme-dark .graph-view.color-fill-highlight { + color: var(--graph-highlight-color-dt); +} +.theme-dark .graph-view.color-line-highlight { + color: var(--graph-highlight-line-color-dt); +} +.outline { + padding: var(--size-4-1); +} +.tree-item > .tree-item-children .tree-item { + margin-left: var(--file-explorer-left-margin); +} +.nav-header ~ .search-input-container { + width: 100%; + height: var(--header-height); + margin: unset; + background-color: var(--background-secondary); + border-bottom: 1px solid var(--window-border); +} +.search-input-container input { + width: -webkit-fill-available; + width: fill-available; + margin: var(--size-4-1); +} +.search-result-container { + padding: var(--size-4-1); +} +.search-result-file-matched-text { + padding: 0 4px; + font-weight: 600; + color: var(--interactive-accent-text); + background-color: var(--interactive-accent-base); +} +.search-result { + margin-bottom: var(--size-4-1); +} +.search-result-file-matches { + margin: var(--size-4-2); +} +.theme-dark .search-result-file-matches { + background-color: var(--background-secondary-alt); +} +.search-result-hover-button { + padding: var(--size-2-1); +} +.search-result-hover-button svg.svg-icon { + width: 14px; + height: 14px; +} +.internal-query .search-result-container { + padding: var(--size-4-2) var(--size-4-1); +} +.search-input-container::before { + top: calc((var(--input-height) - var(--search-icon-size) + var(--size-4-2)) / 2); + left: var(--size-4-3); +} +.workspace-leaf-content[data-type=starred] .item-list { + padding-top: var(--size-4-1); + padding-right: var(--size-4-1); + padding-left: var(--size-4-1); +} +.workspace-leaf-content[data-type=starred] .item-list::after { + height: calc(38px + 2 * var(--scroll-bar-size)); + content: ""; +} +.workspace-leaf-content[data-type=starred] .item-list .nav-file { + margin-left: unset; +} +.workspace-leaf-content[data-type=starred] .item-list .nav-file .nav-file-title { + padding-left: var(--size-4-1); +} +.workspace-leaf-content[data-type=starred] .nav-file-icon { + padding-right: var(--size-4-2); + margin: unset; +} +.tag-container { + padding: var(--size-4-1); +} +.tag-container > div > .tree-item > .tree-item-children .tree-item { + margin-left: var(--file-explorer-left-margin); +} +.tag-container .tree-item-children > div:first-child { + display: none; +} +.tree-item .tree-item-self { + align-items: center; + width: 100%; + padding: 1px var(--size-4-1) 1px var(--size-4-2); + border: 2px solid transparent; +} +.tree-item-self { + align-items: center; +} +.tree-item-flair { + padding: 1px 2px; +} +.tree-item-self .tree-item-icon { + width: 16px; + padding-inline-end: unset; +} +.tree-item-children { + padding-left: var(--size-4-1); + margin: var(--size-4-1) 0 var(--size-4-1) 10px; + border-left: 1px solid var(--window-border); +} +.tree-item-children:empty { + display: none; +} +:is(.backlink-pane, .outgoing-link-pane) { + padding: 0; +} +:is(.backlink-pane, .outgoing-link-pane) > .search-result-container { + padding: var(--size-4-1); +} +:is(.backlink-pane, .outgoing-link-pane) .search-result-container .search-result-container { + padding: unset; + margin: var(--size-4-1) var(--size-4-1) var(--size-4-2) var(--size-4-5); +} +:is(.backlink-pane, .outgoing-link-pane) > .tree-item-self { + padding: var(--size-4-1) var(--size-4-2); + margin-bottom: -1px; + background-color: var(--background-secondary); + border-radius: unset; +} +:is(.backlink-pane, .outgoing-link-pane) > .tree-item-self:first-child { + border-bottom: 1px solid var(--window-border); +} +:is(.backlink-pane, .outgoing-link-pane) > .tree-item-self:nth-last-child(2) { + border-top: 1px solid var(--window-border); + border-bottom: 1px solid var(--window-border); +} +:is(.backlink-pane, .outgoing-link-pane) > .tree-item-self .collapse-icon { + display: block; +} +.embedded-backlinks .nav-header { + height: unset; + margin-top: var(--size-4-4); + margin-right: var(--size-4-3); + background-color: unset; + border-bottom: unset; +} +.embedded-backlinks .backlink-pane { + padding: var(--size-4-5) var(--size-4-2); + border: 1px solid var(--window-border); + border-radius: var(--radius-m); +} +.embedded-backlinks .nav-buttons-container { + padding: var(--size-4-1); + pointer-events: auto; + background: var(--background-secondary-blur); + border: 1px solid var(--window-border); + border-radius: var(--radius-m); +} +.outgoing-link-pane .tree-item-self .tree-item-icon { + margin-right: var(--size-4-2); +} +.pt-custom-vault-banner .nav-folder-title[data-path="/"] { + align-items: center; + min-width: -webkit-fill-available; + min-width: fill-available; + height: var(--header-height); + padding: 0 10px; + margin-bottom: unset; + line-height: 16px; + overflow-wrap: break-word; + white-space: unset; + background: var(--background-secondary-blur); + border: unset; + border-bottom: 1px solid var(--window-border); + border-radius: unset; + -webkit-backdrop-filter: blur(var(--blur-intensity)); + backdrop-filter: blur(var(--blur-intensity)); +} +.pt-custom-vault-banner .nav-folder-title[data-path="/"]:hover { + color: var(--nav-item-color-hover); + background-color: var(--nav-item-background-hover); +} +.pt-custom-vault-banner .nav-folder-title[data-path="/"] .nav-folder-collapse-indicator { + display: block; + width: 28px; + height: 28px; + margin: 6px; + background-image: var(--custom-vault-banner-icon-url); + background-repeat: no-repeat; + background-position: center; + background-size: contain; + border-radius: unset; +} +.pt-custom-vault-banner .nav-folder-title[data-path="/"] .nav-folder-title-content { + margin: 0 4px; +} +.pt-custom-vault-banner.pt-custom-vault-banner-justify-content-left .nav-folder-title[data-path="/"] { + justify-content: flex-start; +} +.pt-custom-vault-banner.pt-custom-vault-banner-justify-content-center .nav-folder-title[data-path="/"] { + justify-content: center; +} +.pt-custom-vault-banner.pt-custom-vault-banner-justify-content-right .nav-folder-title[data-path="/"] { + justify-content: flex-end; +} +.pt-custom-vault-banner.pt-custom-vault-banner-sticky .nav-folder-title[data-path="/"] { + position: sticky; + top: 0; + z-index: var(--layer-popover); +} +.pt-custom-vault-banner.pt-custom-vault-banner-order-ltr .nav-folder-title[data-path="/"] .nav-folder-collapse-indicator.collapse-icon { + order: 0; +} +.pt-custom-vault-banner.pt-custom-vault-banner-order-rtl .nav-folder-title[data-path="/"] .nav-folder-collapse-indicator.collapse-icon { + order: 1; +} +mark, +.cm-highlight { + --mark-highlight-base: var(--interactive-accent-base); + --mark-highlight-dark: var(--interactive-accent-tint); + --mark-highlight-text: var(--interactive-accent-text); + padding: 0 3px; + font-size: var(--font-smallest); + font-weight: 600; + border-radius: var(--radius-s); + -webkit-box-decoration-break: clone; + box-decoration-break: clone; +} +:is(.theme-dark.pt-highlight-style-none-dt mark, .theme-light.pt-highlight-style-none-lt mark, .theme-dark.pt-highlight-style-none-dt .cm-highlight, .theme-light.pt-highlight-style-none-lt .cm-highlight) { + padding: 0; + font-size: 1em; + background-color: transparent; + opacity: 1; +} +:is(.theme-dark.pt-highlight-style-border-dt mark, .theme-light.pt-highlight-style-border-lt mark, .theme-dark.pt-highlight-style-border-dt .cm-highlight, .theme-light.pt-highlight-style-border-lt .cm-highlight) { + background-color: var(--background-primary); + border: var(--accent-border-width) solid var(--mark-highlight-dark); +} +:is(.theme-dark.pt-highlight-style-filled-dt mark, .theme-light.pt-highlight-style-filled-lt mark, .theme-dark.pt-highlight-style-filled-dt .cm-highlight, .theme-light.pt-highlight-style-filled-lt .cm-highlight) { + background-color: var(--mark-highlight-base); + border: var(--accent-border-width) solid var(--mark-highlight-base); +} +:is(.theme-dark.pt-highlight-style-borderandfilled-dt mark, .theme-light.pt-highlight-style-borderandfilled-lt mark, .theme-dark.pt-highlight-style-borderandfilled-dt .cm-highlight, .theme-light.pt-highlight-style-borderandfilled-lt .cm-highlight) { + background-color: var(--mark-highlight-base); + border: var(--accent-border-width) solid var(--mark-highlight-dark); +} +:is(.theme-light.pt-highlight-text-none-lt mark, .theme-dark.pt-highlight-text-none-dt mark, .theme-light.pt-highlight-text-none-lt .cm-highlight, .theme-dark.pt-highlight-text-none-dt .cm-highlight) { + color: var(--text-normal); +} +:is(.theme-light.pt-highlight-text-color-lt mark, .theme-dark.pt-highlight-text-color-dt mark, .theme-light.pt-highlight-text-color-lt .cm-highlight, .theme-dark.pt-highlight-text-color-dt .cm-highlight) { + color: var(--mark-highlight-text); +} +mark:is(.red, .Red) { + --mark-highlight-base: var(--color-red-base); + --mark-highlight-dark: var(--color-red-tint); + --mark-highlight-text: var(--color-red-text); +} +mark:is(.orange, .Orange) { + --mark-highlight-base: var(--color-orange-base); + --mark-highlight-dark: var(--color-orange-tint); + --mark-highlight-text: var(--color-orange-text); +} +mark:is(.yellow, .Yellow) { + --mark-highlight-base: var(--color-yellow-base); + --mark-highlight-dark: var(--color-yellow-tint); + --mark-highlight-text: var(--color-yellow-text); +} +mark:is(.green, .Green) { + --mark-highlight-base: var(--color-green-base); + --mark-highlight-dark: var(--color-green-tint); + --mark-highlight-text: var(--color-green-text); +} +mark:is(.mint, .Mint) { + --mark-highlight-base: var(--color-mint-base); + --mark-highlight-dark: var(--color-mint-tint); + --mark-highlight-text: var(--color-mint-text); +} +mark:is(.aqua, .Aqua, .cyan, .Cyan) { + --mark-highlight-base: var(--color-cyan-base); + --mark-highlight-dark: var(--color-cyan-tint); + --mark-highlight-text: var(--color-cyan-text); +} +mark:is(.blue, .Blue) { + --mark-highlight-base: var(--color-blue-base); + --mark-highlight-dark: var(--color-blue-tint); + --mark-highlight-text: var(--color-blue-text); +} +mark:is(.purple, .Purple) { + --mark-highlight-base: var(--color-purple-base); + --mark-highlight-dark: var(--color-purple-tint); + --mark-highlight-text: var(--color-purple-text); +} +mark:is(.pink, .Pink) { + --mark-highlight-base: var(--color-pink-base); + --mark-highlight-dark: var(--color-pink-tint); + --mark-highlight-text: var(--color-pink-text); +} +mark:is(.grey, .Grey) { + --mark-highlight-base: var(--color-grey-base); + --mark-highlight-dark: var(--color-grey-tint); + --mark-highlight-text: var(--color-grey-text); +} +.pt-font-alt-a * { + font-feature-settings: "ss03"; +} +.pt-font-alt-g * { + font-feature-settings: "ss04"; +} +.pt-font-alt-a.pt-font-alt-g * { + font-feature-settings: "ss03", "ss04"; +} +.pt-font-slashed-zero * { + font-variant: slashed-zero; +} +.pt-font-disable-ligatures * { + font-variant-ligatures: none; +} +div.workspace-leaf-content[data-type=style-settings] div.view-content { + padding: var(--file-margins); +} +div.workspace-leaf-content[data-type=style-settings] .view-content .style-settings-container .setting-item:not(.setting-item-heading) { + flex-direction: row; +} +.style-settings-heading[data-level="0"] + .style-settings-container .style-settings-collapse-indicator { + margin-left: unset; +} +:is(.setting-item.setting-item-heading.style-settings-heading, .style-settings-container .style-settings-heading) { + border-bottom: unset; +} +.setting-item-heading .setting-item-description { + padding-left: var(--size-4-4); +} +.setting-item.setting-item-heading.is-collapsed { + margin-bottom: unset; +} +.style-settings-container > .setting-item:last-of-type { + padding-bottom: unset; +} +:is(.style-settings-heading[data-level="0"] + .style-settings-container, .style-settings-container) { + padding-bottom: var(--size-4-2); + padding-left: var(--size-4-4); + margin-left: var(--size-4-1); + border-left: 1px solid var(--window-border); +} +.setting-item.style-settings-heading[data-id=appearance] .style-settings-collapse-indicator::after { + margin-left: var(--size-4-2); + content: "\1f3a8"; +} +.setting-item.style-settings-heading[data-id=editor] .style-settings-collapse-indicator::after { + margin-left: var(--size-4-2); + content: "\1f4dd"; +} +.setting-item.style-settings-heading[data-id=user-interface] .style-settings-collapse-indicator::after { + margin-left: var(--size-4-2); + content: "\1f446"; +} +.setting-item.style-settings-heading[data-id=plugins] .style-settings-collapse-indicator::after { + margin-left: var(--size-4-2); + content: "\1f9e9"; +} +.setting-item.style-settings-heading[data-id=feature-toggles] { + border-bottom: unset; +} +.setting-item.style-settings-heading[data-id=feature-toggles] .style-settings-collapse-indicator::after { + margin-left: var(--size-4-2); + content: "\1faa0"; +} +.style-settings-heading[data-id=support] { + margin-bottom: 0; + pointer-events: none; + cursor: text; + border-top: 2px solid var(--window-border); +} +.style-settings-heading[data-id=support] :is(.setting-item-control, .style-settings-collapse-indicator) { + display: none; +} +.style-settings-heading[data-id=support] .setting-item-name::before { + display: inline-block; + width: 20px; + height: fit-content; + padding-right: 8px; + font-family: + "Segoe UI Emoji", + "Apple Color Emoji", + sans-serif; + font-weight: initial; + color: unset; + content: "\2764\fe0f"; +} +:is(.style-settings-heading[data-id=support-star-repo], .style-settings-heading[data-id=support-submit-issue], .style-settings-heading[data-id=support-donate], .style-settings-heading[data-id=prism-wiki-link]) { + padding-bottom: 0; + margin-bottom: 0; +} +:is(.style-settings-heading[data-id=support-star-repo], .style-settings-heading[data-id=support-submit-issue], .style-settings-heading[data-id=support-donate], .style-settings-heading[data-id=prism-wiki-link]) :is(.setting-item-control, .style-settings-collapse-indicator) { + display: none; +} +.setting-item.style-settings-heading[data-id=support-star-repo] { + cursor: default; +} +.setting-item.style-settings-heading[data-id=support-star-repo]:hover div.setting-item-name { + color: var(--text-normal); +} +.setting-item.style-settings-heading[data-id=support-star-repo] .setting-item-name::before { + display: inline-block; + width: 20px; + height: fit-content; + padding-right: var(--size-4-2); + font-family: + "Segoe UI Emoji", + "Apple Color Emoji", + sans-serif; + font-weight: initial; + color: unset; + content: "\2b50"; +} +.setting-item.style-settings-heading[data-id=support-star-repo] .setting-item-description { + color: var(--interactive-accent-text); + cursor: text; + user-select: all; +} +.setting-item.style-settings-heading[data-id=support-submit-issue] { + cursor: default; +} +.setting-item.style-settings-heading[data-id=support-submit-issue]:hover div.setting-item-name { + color: var(--text-normal); +} +.setting-item.style-settings-heading[data-id=support-submit-issue] .setting-item-name::before { + display: inline-block; + width: 20px; + height: fit-content; + padding-right: 8px; + font-family: + "Segoe UI Emoji", + "Apple Color Emoji", + sans-serif; + font-weight: initial; + color: unset; + content: "\26a0\fe0f"; +} +.setting-item.style-settings-heading[data-id=support-submit-issue] .setting-item-description { + color: var(--interactive-accent-text); + cursor: text; + user-select: all; +} +.setting-item.style-settings-heading[data-id=support-donate] { + cursor: default; +} +.setting-item.style-settings-heading[data-id=support-donate]:hover div.setting-item-name { + color: var(--text-normal); +} +.setting-item.style-settings-heading[data-id=support-donate] .setting-item-name::before { + display: inline-block; + width: 20px; + height: fit-content; + padding-right: 8px; + font-family: + "Segoe UI Emoji", + "Apple Color Emoji", + sans-serif; + font-weight: initial; + color: unset; + content: "\2615"; +} +.setting-item.style-settings-heading[data-id=support-donate] .setting-item-description { + color: var(--interactive-accent-text); + cursor: text; + user-select: all; +} +.style-settings-container .setting-item:is([data-id*=color-accent-h-], [data-id*=color-accent-s-], [data-id*=color-accent-l-base-], [data-id*=color-accent-l-tint-], [data-id*=color-accent-l-text-]) .setting-item-control::before { + width: 1.5em; + height: 1.5em; + margin-right: 8px; + content: " "; + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +.style-settings-container .setting-item:is([data-id*=color-accent-h-], [data-id*=color-accent-s-], [data-id*=color-accent-l-base-], [data-id*=color-accent-l-tint-], [data-id*=color-accent-l-text-]) input.slider { + width: 150px; + height: 1.5em; +} +.style-settings-container .setting-item:is([data-id*=color-accent-h-], [data-id*=color-accent-s-], [data-id*=color-accent-l-base-], [data-id*=color-accent-l-tint-], [data-id*=color-accent-l-text-]) input.slider::-webkit-slider-thumb { + width: 4px; + height: 1.75em; + margin-top: -3px; + border: 1px solid var(--window-border); + -webkit-appearance: none; +} +.theme-light .style-settings-container .setting-item:is([data-id*=color-accent-h-], [data-id*=color-accent-s-], [data-id*=color-accent-l-base-], [data-id*=color-accent-l-tint-], [data-id*=color-accent-l-text-]) input.slider::-webkit-slider-thumb { + background-color: var(--background-primary); +} +.theme-dark .style-settings-container .setting-item:is([data-id*=color-accent-h-], [data-id*=color-accent-s-], [data-id*=color-accent-l-base-], [data-id*=color-accent-l-tint-], [data-id*=color-accent-l-text-]) input.slider::-webkit-slider-thumb { + background-color: var(--text-normal); +} +.style-settings-container .setting-item:is([data-id^=color-accent-h-lt]) input.slider { + background: var(--hue-background-lt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-h-lt]) .setting-item-control::before { + background-color: var(--color-accent-base-lt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-s-lt]) input.slider { + background: var(--saturation-background-lt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-s-lt]) .setting-item-control::before { + background-color: var(--color-accent-base-lt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-l-base-lt], [data-id^=color-accent-l-tint-lt], [data-id^=color-accent-l-text-lt]) input.slider { + background: var(--lightness-background-lt); +} +.style-settings-container .setting-item[data-id^=color-accent-l-base-lt] .setting-item-control::before { + background-color: var(--color-accent-base-lt); +} +.style-settings-container .setting-item[data-id^=color-accent-l-tint-lt] .setting-item-control::before { + background-color: var(--color-accent-tint-lt); +} +.style-settings-container .setting-item[data-id^=color-accent-l-text-lt] .setting-item-control::before { + background-color: var(--color-accent-text-lt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-h-dt]) input.slider { + background: var(--hue-background-dt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-h-dt]) .setting-item-control::before { + background-color: var(--color-accent-base-dt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-s-dt]) input.slider { + background: var(--saturation-background-dt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-s-dt]) .setting-item-control::before { + background-color: var(--color-accent-base-dt); +} +.style-settings-container .setting-item:is([data-id^=color-accent-l-base-dt], [data-id^=color-accent-l-tint-dt], [data-id^=color-accent-l-text-dt]) input.slider { + background: var(--lightness-background-dt); +} +.style-settings-container .setting-item[data-id^=color-accent-l-base-dt] .setting-item-control::before { + background-color: var(--color-accent-base-dt); +} +.style-settings-container .setting-item[data-id^=color-accent-l-tint-dt] .setting-item-control::before { + background-color: var(--color-accent-tint-dt); +} +.style-settings-container .setting-item[data-id^=color-accent-l-text-dt] .setting-item-control::before { + background-color: var(--color-accent-text-dt); +} +.kanban-plugin__lane-header-wrapper { + gap: var(--size-4-1); + padding: var(--size-4-1) var(--size-4-2); +} +.theme-dark .kanban-plugin__item-title-wrapper { + background: var(--background-secondary-alt); +} +.kanban-plugin__new-item-button { + border: 1px solid var(--window-border); +} +.kanban-plugin__new-item-button:hover { + background-color: var(--background-modifier-hover); +} +.kanban-plugin__lane-items { + gap: var(--size-4-1); + padding: var(--size-4-2); + margin: unset; +} +.kanban-plugin__lane-items > div { + margin-top: unset; +} +:is(.kanban-plugin__lane-grip, div.kanban-plugin__lane-title-count, .kanban-plugin__lane button.kanban-plugin__lane-settings-button) { + margin: unset; +} +.kanban-plugin__lane button.kanban-plugin__lane-settings-button { + box-shadow: unset; +} +.modal.kanban-plugin__board-settings-modal { + width: var(--modal-width); + max-width: var(--modal-max-width); + height: var(--modal-height); + max-height: var(--modal-max-height); +} +.modal.kanban-plugin__board-settings-modal .modal-title:empty { + display: block; + width: -webkit-fill-available; + width: fill-available; + height: 42px; + margin-bottom: unset; + content: ""; + border-bottom: 1px solid var(--window-border); +} +.modal.kanban-plugin__board-settings-modal .modal-content { + padding: var(--size-4-8); +} +.modal.kanban-plugin__board-settings-modal :is(h3, h4) { + margin: var(--size-4-2) 0; + border-bottom: 1px solid var(--window-border); +} +.kanban-plugin__board > div { + padding: var(--size-4-4); +} +.show-view-header .kanban-plugin__board > div { + padding-top: calc(var(--header-height) + var(--size-4-4)); +} +.theme-light div.kanban-plugin__lane-title-count, +.theme-dark div.kanban-plugin__lane-title-count { + display: block; + height: fit-content; + padding: 0 4px; + font-size: 0.75em; + font-weight: 600; + line-height: 1.5em; + color: var(--text-normal); + background-color: var(--background-secondary); + border: 1px solid var(--window-border); + border-radius: var(--radius-s); +} +.pt-center-kanban-title-text .kanban-plugin__lane-title { + align-items: center; +} +.pt-disable-kanban-title-count div.kanban-plugin__lane-title-count { + display: none; +} +.workspace-leaf-content[data-type=advanced-tables-toolbar] { +} +.workspace-leaf-content[data-type=advanced-tables-toolbar] .view-content { + padding: 0; +} +.workspace-leaf-content[data-type=advanced-tables-toolbar] .view-content > div { + display: block; + width: 100%; + height: 100%; +} +.workspace-leaf-content[data-type=advanced-tables-toolbar] .nav-header { + flex-direction: column; +} +.pt-icon-folder-accent .obsidian-icon-folder-icon { + color: var(--interactive-accent-text); +} +.pt-icons-accent .obsidian-icon { + color: var(--interactive-accent-text); +} +/*! +/* @settings +name: Prism Theme +id: obsidian-prism-theme +settings: + - + id: appearance + title: Appearance + description: Options which change how Prism styles Obsidian. + type: heading + level: 1 + collapsed: true + - + id: accent-color-schemes-and-style + title: Accent, Color Schemes and Style + description: Main visual options for Prism. + type: heading + level: 2 + collapsed: true + - + id: accent-colors-styles-lt + title: Light Theme + type: heading + level: 3 + collapsed: true + - + id: color-schemes-lt + title: Color Scheme + type: class-select + allowEmpty: false + default: pt-color-scheme-swan-lt + options: + - + label: Swan + value: pt-color-scheme-swan-lt + - + label: Latte + value: pt-color-scheme-latte-lt + - + label: Periwinkle + value: pt-color-scheme-periwinkle-lt + - + label: Pistachio + value: pt-color-scheme-pistachio-lt + - + id: accent-style-lt + title: Accent Style + description: Adjusts the style used by the Accented elements in the UI. + type: class-select + allowEmpty: false + default: pt-accent-style-borderandfilled-lt + options: + - + label: Plain + value: pt-accent-style-text-lt + - + label: Border + value: pt-accent-style-border-lt + - + label: Filled + value: pt-accent-style-filled-lt + - + label: Border & Filled + value: pt-accent-style-borderandfilled-lt + - + id: light-accent-color-preset + title: Accent Color Preset + description: Changes the Light Theme Accent Color around the entire UI. Select from present colors or choose 'Custom' and tune the color in the Custom Accent Color Tuning section below. + type: class-select + allowEmpty: false + default: pt-accent-color-purple-lt + options: + - + label: Custom + value: pt-accent-color-custom-lt + - + label: Red + value: pt-accent-color-red-lt + - + label: Orange + value: pt-accent-color-orange-lt + - + label: Yellow + value: pt-accent-color-yellow-lt + - + label: Green + value: pt-accent-color-green-lt + - + label: Mint + value: pt-accent-color-mint-lt + - + label: Cyan + value: pt-accent-color-cyan-lt + - + label: Blue + value: pt-accent-color-blue-lt + - + label: Purple + value: pt-accent-color-purple-lt + - + label: Pink + value: pt-accent-color-pink-lt + - + label: Grey + value: pt-accent-color-grey-lt + - + id: highlight-text-accent-lt + title: Accent Text Color Preset + description: Adjusts the color used by the text in the Light Theme Accented elements of the UI. + type: class-select + allowEmpty: false + default: pt-highlight-text-accent-lt + options: + - + label: Custom + value: pt-highlight-text-custom-lt + - + label: Dark + value: pt-highlight-text-dark-lt + - + label: Light + value: pt-highlight-text-light-lt + - + label: Accent Color + value: pt-highlight-text-accent-lt + - + id: highlight-text-accent-custom-lt + title: Custom Accent Text Color + description: Make sure you selected 'Custom' in Light Theme Accent Text Color for this to work. + type: variable-color + format: hsl + opacity: false + default: '#FFFFFF' + - + id: color-accent-custom-lt + title: Custom Accent Color Tuning + description: Make sure you selected 'Custom' in Accent Color Preset for this to work. The default Lightness values should net good results for most Hues. Tweak them to your preference. + type: heading + level: 4 + collapsed: true + - + id: color-accent-h-lt + title: Custom Accent Base Color Hue + description: Changes the the Hue of the Base color. + type: variable-number-slider + default: 0 + min: 0 + max: 360 + step: 1 + - + id: color-accent-s-lt + title: Custom Accent Base Color Saturation + description: Changes the Saturation of the Base Color. + type: variable-number-slider + format: '%' + default: 60 + min: 0 + max: 100 + step: 1 + - + id: color-accent-l-base-lt + title: Custom Accent Base Color Lightness + description: Base Color Lightness should ideally be the lighteest of the 3. + type: variable-number-slider + format: '%' + default: 82 + min: 0 + max: 100 + step: 1 + - + id: color-accent-l-tint-lt + title: Custom Accent Tint Color Lightness + description: Tint Color Lightness should ideally be between Base and Text. + type: variable-number-slider + format: '%' + default: 67 + min: 0 + max: 100 + step: 1 + - + id: color-accent-l-text-lt + title: Custom Accent Text Color Lightness + description: Text Color Lightness should ideally be the darkest of the 3. + type: variable-number-slider + format: '%' + default: 42 + min: 0 + max: 100 + step: 1 + - + id: accent-colors-styles-dt + title: Dark Theme + type: heading + level: 3 + collapsed: true + - + id: color-schemes-dt + title: Color Scheme + type: class-select + allowEmpty: false + default: pt-color-scheme-raven-dt + options: + - + label: Raven + value: pt-color-scheme-raven-dt + - + label: Mocha + value: pt-color-scheme-mocha-dt + - + label: Indigo + value: pt-color-scheme-indigo-dt + - + label: Pine + value: pt-color-scheme-pine-dt + - + id: accent-style-dt + title: Accent Style + description: Adjusts the style used by the Accented elements in the UI. + type: class-select + allowEmpty: false + default: pt-accent-style-borderandfilled-dt + options: + - + label: Plain + value: pt-accent-style-text-dt + - + label: Border + value: pt-accent-style-border-dt + - + label: Filled + value: pt-accent-style-filled-dt + - + label: Border & Filled + value: pt-accent-style-borderandfilled-dt + - + id: dark-accent-color-preset + title: Accent Color Preset + description: Changes the Dark Theme Accent Color around the entire UI. Select from present colors or choose 'Custom' and tune the color in the Custom Accent Color Tuning section below. + type: class-select + allowEmpty: false + default: pt-accent-color-purple-dt + options: + - + label: Custom + value: pt-accent-color-custom-dt + - + label: Red + value: pt-accent-color-red-dt + - + label: Orange + value: pt-accent-color-orange-dt + - + label: Yellow + value: pt-accent-color-yellow-dt + - + label: Green + value: pt-accent-color-green-dt + - + label: Mint + value: pt-accent-color-mint-dt + - + label: Cyan + value: pt-accent-color-cyan-dt + - + label: Blue + value: pt-accent-color-blue-dt + - + label: Purple + value: pt-accent-color-purple-dt + - + label: Pink + value: pt-accent-color-pink-dt + - + label: Grey + value: pt-accent-color-grey-dt + - + id: highlight-text-accent-dt + title: Accent Text Color Preset + description: Adjusts the color used by the text in the Dark Theme Accented elements of the UI. + type: class-select + allowEmpty: false + default: pt-highlight-text-accent-dt + options: + - + label: Custom + value: pt-highlight-text-custom-dt + - + label: Dark + value: pt-highlight-text-dark-dt + - + label: Light + value: pt-highlight-text-light-dt + - + label: Accent Color + value: pt-highlight-text-accent-dt + - + id: highlight-text-accent-custom-dt + title: Custom Accent Text Color + description: Make sure you selected 'Custom' in Dark Theme Accent Text Color for this to work. + type: variable-color + format: hsl + opacity: false + default: '#FFFFFF' + - + id: color-accent-custom-dt + title: Custom Accent Color Tuning + description: Make sure you selected 'Custom' in Accent Color Preset for this to work. The default Lightness values should net good results for most Hues. Tweak them to your preference. + type: heading + level: 4 + collapsed: true + - + id: color-accent-h-dt + title: Custom Accent Base Color Hue + description: Changes the the Hue of the Base color. + type: variable-number-slider + default: 0 + min: 0 + max: 360 + step: 1 + - + id: color-accent-s-dt + title: Custom Accent Base Color Saturation + description: Changes the Saturation of the Base Color. + type: variable-number-slider + format: '%' + default: 50 + min: 0 + max: 100 + step: 1 + - + id: color-accent-l-base-dt + title: Custom Accent Base Color Lightness + description: Base Color Lightness should ideally be the darkest of the 3. + type: variable-number-slider + format: '%' + default: 20 + min: 0 + max: 100 + step: 1 + - + id: color-accent-l-tint-dt + title: Custom Accent Tint Color Lightness + description: Tint Color Lightness should ideally be between Base and Text. + type: variable-number-slider + format: '%' + default: 40 + min: 0 + max: 100 + step: 1 + - + id: color-accent-l-text-dt + title: Custom Accent Text Color Lightness + description: Text Color Lightness should ideally be the lightest of the 3. + type: variable-number-slider + format: '%' + default: 65 + min: 0 + max: 100 + step: 1 + - + id: graph-view-colors + title: Graph Color Customisation + description: Define the colors used in the Graph View. In order to see changes you need to refresh the Graph View (restart Obsidian or toggle the Light/Dark theme). + type: heading + level: 2 + collapsed: true + - + id: graph-view-light-theme + title: Light Theme + type: heading + level: 3 + collapsed: true + - + id: pt-graph-line-color-lt + title: Graph Lines Color + description: The color of a Graph lines connecting Graph Nodes. + type: heading + level: 4 + collapsed: true + - + id: graph-line-color-lt + title: Graph Line Presets + type: variable-select + allowEmpty: false + default: var(--background-secondary-alt) + options: + - + label: Default + value: var(--background-secondary-alt) + - + label: Custom + value: var(--graph-line-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-line-custom-color-lt + title: Graph Lines Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Lines Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#C4C7CA' + - + id: graph-line-opacity-lt + title: Graph Lines Opacity + type: variable-number-slider + default: 1 + min: 0 + max: 1 + step: 0.05 + - + id: pt-graph-fill-color-lt + title: Graph Note Color + description: The color of a Graph Node representing a note file. + type: heading + level: 4 + collapsed: true + - + id: graph-fill-color-lt + title: Graph Note Color Presets + type: variable-select + allowEmpty: false + default: var(--color-grey-text) + options: + - + label: Custom + value: var(--graph-fill-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-fill-custom-color-lt + title: Graph Note Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Note Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#C4C7CA' + - + id: pt-graph-fill-focused-color-lt + title: Graph Note Focused Color + description: The color of a Graph Node representing currently focused note file. + type: heading + level: 4 + collapsed: true + - + id: graph-fill-focused-color-lt + title: Graph Note Focused Color Presets + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--graph-fill-focused-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-fill-focused-custom-color-lt + title: Graph Note Focused Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Note Focused Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#8670FF' + - + id: pt-graph-tag-color-lt + title: Graph Tag Color + description: The color of a Graph Node representing a tag. + type: heading + level: 4 + collapsed: true + - + id: graph-tag-color-lt + title: Graph Tag Color Presets + type: variable-select + allowEmpty: false + default: var(--color-blue-text) + options: + - + label: Custom + value: var(--graph-tag-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-tag-custom-color-lt + title: Graph Tag Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Tag Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#619EFF' + - + id: pt-graph-attachment-color-lt + title: Graph Attachment Color + description: The color of a Graph Node representing an attachment. + type: heading + level: 4 + collapsed: true + - + id: graph-attachment-color-lt + title: Graph Attachment Color Presets + type: variable-select + allowEmpty: false + default: var(--color-yellow-text) + options: + - + label: Custom + value: var(--graph-attachment-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-attachment-custom-color-lt + title: Graph Attachment Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Attachment Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#FDDB6D' + - + id: pt-graph-unresolved-color-lt + title: Graph Unresolved Color + description: The color of a Graph Node representing an unresolved note. + type: heading + level: 4 + collapsed: true + - + id: graph-unresolved-color-lt + title: Graph Unresolved Color Presets + type: variable-select + allowEmpty: false + default: var(--color-red-text) + options: + - + label: Custom + value: var(--graph-unresolved-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-unresolved-custom-color-lt + title: Graph Unresolved Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Unresolved Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#FF7070' + - + id: pt-graph-highlight-color-lt + title: Graph Highlight Color + description: The color of a Graph Node when highlighted. + type: heading + level: 4 + collapsed: true + - + id: graph-highlight-color-lt + title: Graph Highlight Color Presets + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--graph-highlight-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-highlight-custom-color-lt + title: Graph Highlight Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Highlight Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#8670FF' + - + id: pt-graph-highlight-line-color-lt + title: Graph Highlight Line Color + description: The color of the lines connected to a highlighted Graph Node. + type: heading + level: 4 + collapsed: true + - + id: graph-highlight-line-color-lt + title: Graph Highlight Line Color Presets + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--graph-highlight-line-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-highlight-line-custom-color-lt + title: Graph Highlight Line Custom Color + description: Make sure you selected 'Custom' in Light Theme Graph Highlight Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#8670FF' + - + id: graph-view-dark-theme + title: Dark Theme + type: heading + level: 3 + collapsed: true + - + id: pt-graph-line-color-dt + title: Graph Lines Color + description: The color of a Graph lines connecting Graph Nodes. + type: heading + level: 4 + collapsed: true + - + id: graph-line-color-dt + title: Graph Lines Presets + type: variable-select + allowEmpty: false + default: var(--background-primary-alt) + options: + - + label: Default + value: var(--background-primary-alt) + - + label: Custom + value: var(--graph-line-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-line-custom-color-dt + title: Graph Lines Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Lines Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#C4C7CA' + - + id: pt-graph-fill-color-dt + title: Graph Note Color + description: The color of a Graph Node representing a note file. + type: heading + level: 4 + collapsed: true + - + id: graph-fill-color-dt + title: Graph Note Color Presets + type: variable-select + allowEmpty: false + default: var(--color-grey-text) + options: + - + label: Custom + value: var(--graph-fill-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-fill-custom-color-dt + title: Graph Note Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Note Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#878787' + - + id: pt-graph-fill-focused-color-dt + title: Graph Note Focused Color + description: The color of a Graph Node representing currently focused note file. + type: heading + level: 4 + collapsed: true + - + id: graph-fill-focused-color-dt + title: Graph Note Focused Color Presets + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--graph-fill-focused-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-fill-focused-custom-color-dt + title: Graph Note Focused Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Note Focused Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#4C3AB6' + - + id: pt-graph-tag-color-dt + title: Graph Tag Color + description: The color of a Graph Node representing a tag. + type: heading + level: 4 + collapsed: true + - + id: graph-tag-color-dt + title: Graph Tag Color Presets + type: variable-select + allowEmpty: false + default: var(--color-blue-text) + options: + - + label: Custom + value: var(--graph-tag-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-tag-custom-color-dt + title: Graph Tag Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Tag Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#3663AB' + - + id: pt-graph-attachment-color-dt + title: Graph Attachment Color + description: The color of a Graph Node representing an attachment. + type: heading + level: 4 + collapsed: true + - + id: graph-attachment-color-dt + title: Graph Attachment Color Presets + type: variable-select + allowEmpty: false + default: var(--color-yellow-text) + options: + - + label: Custom + value: var(--graph-attachment-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-attachment-custom-color-dt + title: Graph Attachment Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Attachment Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#AF943C' + - + id: pt-graph-unresolved-color-dt + title: Graph Unresolved Color + description: The color of a Graph Node representing an unresolved note. + type: heading + level: 4 + collapsed: true + - + id: graph-unresolved-color-dt + title: Graph Unresolved Color Presets + type: variable-select + allowEmpty: false + default: var(--color-red-text) + options: + - + label: Custom + value: var(--graph-unresolved-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-unresolved-custom-color-dt + title: Graph Unresolved Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Unresolved Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#B63A3A' + - + id: pt-graph-highlight-color-dt + title: Graph Highlight Color + description: The color of a Graph Node when highlighted. + type: heading + level: 4 + collapsed: true + - + id: graph-highlight-color-dt + title: Graph Highlight Color Presets + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--graph-highlight-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-highlight-custom-color-dt + title: Graph Highlight Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Highlight Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#4C3AB6' + - + id: pt-graph-highlight-line-color-lt + title: Graph Highlight Line Color + description: The color of the lines connected to a highlighted Graph Node. + type: heading + level: 4 + collapsed: true + - + id: graph-highlight-line-color-dt + title: Graph Highlight Line Color Presets + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--graph-highlight-line-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: graph-highlight-line-custom-color-dt + title: Graph Highlight Line Custom Color + description: Make sure you selected 'Custom' in Dark Theme Graph Highlight Color Presets for this to work. + type: variable-color + format: hsl + opacity: false + default: '#4C3AB6' + - + id: editor + title: Editor + description: Settings for elements inside the Editor / Preview area of Obsidian. + type: heading + level: 1 + collapsed: true + - + id: file-line-width + title: Custom Readable Line Length (px) + description: Changes the maximum width of the Readable Line Length (px). Enable 'Readable line length' in the Editor tab in Settings for this to apply. + type: variable-number-slider + level: 2 + min: 100 + max: 1800 + step: 5 + default: 700 + format: px + - + id: font-options + title: Font Specific Options + description: Options for the default Sans Serif 3 font. + type: heading + level: 2 + collapsed: true + - + id: pt-font-alt-a + title: Alternative lower case 'a' appearance + default: false + type: class-toggle + - + id: pt-font-alt-g + title: Alternative lower case 'g' appearance + default: false + type: class-toggle + - + id: pt-font-slashed-zero + title: Alternative '0' appearance (Slashed Zero) + default: false + type: class-toggle + - + id: pt-font-disable-ligatures + title: Disable Ligatures + default: true + type: class-toggle + - + id: header-styles + title: Headers + description: Customisation options for the Headers (H1 - H6). + type: heading + level: 2 + collapsed: true + - + id: header-font-size + title: Header Font Size + description: The sizes are scalled based on the Font Size selected in the Appearance tab of the Settings. + type: heading + level: 3 + collapsed: true + - + id: h1-size + title: Header 1 (H1) Font Size (em) + type: variable-number-slider + min: 0.5 + max: 5 + step: 0.05 + default: 2.2 + format: em + - + id: h2-size + title: Header 2 (H2) Font Size (em) + type: variable-number-slider + min: 0.5 + max: 5 + step: 0.05 + default: 2 + format: em + - + id: h3-size + title: Header 3 (H3) Font Size (em) + type: variable-number-slider + min: 0.5 + max: 5 + step: 0.05 + default: 1.8 + format: em + - + id: h4-size + title: Header 4 (H4) Font Size (em) + type: variable-number-slider + min: 0.5 + max: 5 + step: 0.05 + default: 1.6 + format: em + - + id: h5-size + title: Header 5 (H5) Font Size (em) + type: variable-number-slider + min: 0.5 + max: 5 + step: 0.05 + default: 1.4 + format: em + - + id: h6-size + title: Header 6 (H6) Font Size (em) + type: variable-number-slider + min: 0.5 + max: 5 + step: 0.05 + default: 1.2 + format: em + - + id: header-padding-size + title: Header Padding Size + description: The additional space above and below the headers. + type: heading + level: 3 + collapsed: true + - + id: h1-padding-size + title: Header 1 (H1) Padding Size (px) + type: variable-number-slider + min: 0 + max: 20 + step: 1 + default: 0 + format: px + - + id: h2-padding-size + title: Header 2 (H2) Padding Size (px) + type: variable-number-slider + min: 0 + max: 20 + step: 1 + default: 0 + format: px + - + id: h3-padding-size + title: Header 3 (H3) Padding Size (px) + type: variable-number-slider + min: 0 + max: 20 + step: 1 + default: 0 + format: px + - + id: h4-padding-size + title: Header 4 (H4) Padding Size (px) + type: variable-number-slider + min: 0 + max: 20 + step: 1 + default: 0 + format: px + - + id: h5-padding-size + title: Header 5 (H5) Padding Size (px) + type: variable-number-slider + min: 0 + max: 20 + step: 1 + default: 0 + format: px + - + id: h6-padding-size + title: Header 6 (H6) Padding Size (px) + type: variable-number-slider + min: 0 + max: 20 + step: 1 + default: 0 + format: px + - + id: header-text-color + title: Header Text Color + description: Options for changing the color of each header type. + type: heading + level: 3 + collapsed: true + - + id: header-text-color-lt + title: Light Theme + type: heading + level: 4 + collapsed: true + - + id: h1-text-color-lt + title: Header 1 (H1) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h1-text-color-custom-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h1-text-color-custom-lt + title: Header 1 (H1) Custom Text Color + description: Make sure you selected 'Custom' in Light Theme Header 1 (H1) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h2-text-color-lt + title: Header 2 (H2) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h2-text-color-custom-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h2-text-color-custom-lt + title: Header 2 (H2) Custom Text Color + description: Make sure you selected 'Custom' in Light Theme Header 2 (H2) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h3-text-color-lt + title: Header 3 (H3) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h3-text-color-custom-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h3-text-color-custom-lt + title: Header 3 (H3) Custom Text Color + description: Make sure you selected 'Custom' in Light Theme Header 3 (H3) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h4-text-color-lt + title: Header 4 (H4) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h4-text-color-custom-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h4-text-color-custom-lt + title: Header 4 (H4) Custom Text Color + description: Make sure you selected 'Custom' in Light Theme Header 4 (H4) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h5-text-color-lt + title: Header 5 (H5) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h5-text-color-custom-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h5-text-color-custom-lt + title: Header 5 (H5) Custom Text Color + description: Make sure you selected 'Custom' in Light Theme Header 5 (H5) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h6-text-color-lt + title: Header 6 (H6) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h6-text-color-custom-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h6-text-color-custom-lt + title: Header 6 (H6) Custom Text Color + description: Make sure you selected 'Custom' in Light Theme Header 6 (H6) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: header-text-color-dt + title: Dark Theme + type: heading + level: 4 + collapsed: true + - + id: h1-text-color-dt + title: Header 1 (H1) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h1-text-color-custom-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h1-text-color-custom-dt + title: Header 1 (H1) Custom Text Color + description: Make sure you selected 'Custom' in Dark Theme Header 1 (H1) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h2-text-color-dt + title: Header 2 (H2) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h2-text-color-custom-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h2-text-color-custom-dt + title: Header 2 (H2) Custom Text Color + description: Make sure you selected 'Custom' in Dark Theme Header 2 (H2) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h3-text-color-dt + title: Header 3 (H3) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h3-text-color-custom-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h3-text-color-custom-dt + title: Header 3 (H3) Custom Text Color + description: Make sure you selected 'Custom' in Dark Theme Header 3 (H3) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h4-text-color-dt + title: Header 4 (H4) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h4-text-color-custom-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h4-text-color-custom-dt + title: Header 4 (H4) Custom Text Color + description: Make sure you selected 'Custom' in Dark Theme Header 4 (H4) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h5-text-color-dt + title: Header 5 (H5) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h5-text-color-custom-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h5-text-color-custom-dt + title: Header 5 (H5) Custom Text Color + description: Make sure you selected 'Custom' in Dark Theme Header 5 (H5) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: h6-text-color-dt + title: Header 6 (H6) Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--h6-text-color-custom-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: h6-text-color-custom-dt + title: Header 6 (H6) Custom Text Color + description: Make sure you selected 'Custom' in Dark Theme Header 6 (H6) Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: editor-text-styles + title: Editor Text Color + description: Adjust the color of different types of text in the Editor. + type: heading + level: 2 + collapsed: true + - + id: editor-text-light-theme + title: Light Theme + type: heading + level: 3 + collapsed: true + - + id: text-bold-color-lt + title: Bold Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--text-bold-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: text-bold-custom-color-lt + title: Bold Text Custom Color + description: Make sure you selected 'Custom' in Light Theme Bold Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: text-italic-color-lt + title: Italic Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--text-italic-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: text-italic-custom-color-lt + title: Italic Text Custom Color + description: Make sure you selected 'Custom' in Light Theme Italic Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: text-italic-bold-color-lt + title: Italic and Bold Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--text-italic-bold-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: text-italic-bold-custom-color-lt + title: Italic Text Custom Color + description: Make sure you selected 'Custom' in Light Theme Italic Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: link-internal-color-lt + title: Internal Link Color Preset + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--link-internal-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: link-internal-custom-color-lt + title: Internal Link Custom Color + description: Make sure you selected 'Custom' in Light Theme Internal Link Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: link-external-color-lt + title: External Link Color Preset + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--link-external-custom-color-lt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: link-external-custom-color-lt + title: External Link Custom Color + description: Make sure you selected 'Custom' in Light Theme External Link Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: editor-text-dark-theme + title: Dark Theme + type: heading + level: 3 + collapsed: true + - + id: text-bold-color-dt + title: Bold Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--text-bold-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: text-bold-custom-color-dt + title: Bold Text Custom Color + description: Make sure you selected 'Custom' in Dark Theme Bold Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: text-italic-color-dt + title: Italic Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--text-italic-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: text-italic-custom-color-dt + title: Italic Text Custom Color + description: Make sure you selected 'Custom' in Dark Theme Italic Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: text-italic-bold-color-dt + title: Italic and Bold Text Color Preset + type: variable-select + allowEmpty: false + default: var(--text-normal) + options: + - + label: Default + value: var(--text-normal) + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--text-italic-bold-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: text-italic-bold-custom-color-dt + title: Italic Text Custom Color + description: Make sure you selected 'Custom' in Light Theme Italic Text Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: link-internal-color-dt + title: Internal Link Color Preset + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--link-internal-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: link-internal-custom-color-dt + title: Internal Link Custom Color + description: Make sure you selected 'Custom' in Dark Theme Internal Link Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: link-external-color-dt + title: External Link Color Preset + type: variable-select + allowEmpty: false + default: var(--interactive-accent-text) + options: + - + label: Accent Color + value: var(--interactive-accent-text) + - + label: Custom + value: var(--link-external-custom-color-dt) + - + label: Red + value: var(--color-red-text) + - + label: Orange + value: var(--color-orange-text) + - + label: Yellow + value: var(--color-yellow-text) + - + label: Green + value: var(--color-green-text) + - + label: Mint + value: var(--color-mint-text) + - + label: Cyan + value: var(--color-cyan-text) + - + label: Blue + value: var(--color-blue-text) + - + label: Purple + value: var(--color-purple-text) + - + label: Pink + value: var(--color-pink-text) + - + label: Grey + value: var(--color-grey-text) + - + id: link-external-custom-color-dt + title: External Link Custom Color + description: Make sure you selected 'Custom' in Dark Theme External Link Color Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: mark-highlight-styles + title: Mark Highlight + description: Adjusts the style used by the tag highlight system. Colors available = red, orange, yellow, green, mint, cyan, blue, purple, pink and grey. e.g. Your text + type: heading + level: 2 + collapsed: true + - + id: mark-highlight-light-theme + title: Light Theme + type: heading + level: 3 + collapsed: true + - + id: light-mark-highlight-style + title: Mark Highlight Style + type: class-select + allowEmpty: false + default: pt-highlight-style-borderandfilled-lt + options: + - + label: None + value: pt-highlight-style-none-lt + - + label: Border + value: pt-highlight-style-border-lt + - + label: Filled + value: pt-highlight-style-filled-lt + - + label: Border & Filled + value: pt-highlight-style-borderandfilled-lt + - + id: light-mark-highlight-text-color-preset + title: Mark Highlight Text Color Preset + type: class-select + allowEmpty: false + default: pt-highlight-text-color-lt + options: + - + label: None + value: pt-highlight-text-none-lt + - + label: Color + value: pt-highlight-text-color-lt + - + id: mark-highlight-dark-theme + title: Dark Theme + type: heading + level: 3 + collapsed: true + - + id: dark-mark-highlight-style + title: Mark Highlight Style + type: class-select + allowEmpty: false + default: pt-highlight-style-borderandfilled-dt + options: + - + label: None + value: pt-highlight-style-none-dt + - + label: Border + value: pt-highlight-style-border-dt + - + label: Filled + value: pt-highlight-style-filled-dt + - + label: Border & Filled + value: pt-highlight-style-borderandfilled-dt + - + id: dark-mark-highlight-text-color-preset + title: Mark Highlight Text Color Preset + type: class-select + allowEmpty: false + default: pt-highlight-text-color-dt + options: + - + label: None + value: pt-highlight-text-none-dt + - + label: Color + value: pt-highlight-text-color-dt + - + id: user-interface + title: User Interface + description: Settings for spacing, position, alignment and other adjustments of different UI elements. + type: heading + level: 1 + collapsed: true + - + id: window-adjustments + title: Window Adjustments + description: Settings for changing the gaps between windows and border radius around all UI elements. + type: heading + level: 2 + collapsed: true + - + id: radius-m + title: Border Radius Medium (px) + description: The size of the border radius around larger elements of the UI. + type: variable-number-slider + format: 'px' + default: 8 + level: 2 + min: 0 + max: 20 + step: 1 + - + id: radius-s + title: Border Radius Small (px) + description: The size of the border radius around smaller elements of the UI. + type: variable-number-slider + format: 'px' + default: 4 + level: 2 + min: 0 + max: 20 + step: 1 + - + id: sidebar-elements + title: Sidebar Elements + description: Settings for positioning, alignment, etc. of different UI elements within the Sidebars. + type: heading + level: 2 + collapsed: true + - + id: tab-label + title: Tab Label + description: Settings for positioning, alignment, etc. of the Tab Labels. + type: heading + level: 3 + collapsed: true + - + id: left-sidebar-tab-label-alignment + title: Left Sidebar Tab Label Alignment + description: Horizontal Alignment of the Tab Labels in the Left Sidebar. + type: class-select + allowEmpty: false + default: pt-tab-label-left-sidebar-left + options: + - + label: Left + value: pt-tab-label-left-sidebar-left + - + label: Center + value: pt-tab-label-left-sidebar-center + - + label: Right + value: pt-tab-label-left-sidebar-right + - + id: right-sidebar-tab-label-alignment + title: Right Sidebar Tab Label Alignment + description: Horizontal Alignment of the Tab Labels in the Right Sidebar. + type: class-select + allowEmpty: false + default: pt-tab-label-right-sidebar-left + options: + - + label: Left + value: pt-tab-label-right-sidebar-left + - + label: Center + value: pt-tab-label-right-sidebar-center + - + label: Right + value: pt-tab-label-right-sidebar-right + - + id: nav-header + title: Nav Header + description: Settings for positioning, alignment, etc. of the Nav Headers. + type: heading + level: 3 + collapsed: true + - + id: nav-header-left-sidebar-position + title: Left Sidebar Nav Header Position + description: Vertical Position of the Nav Header in the Left Sidebar Workspace Leaf. + type: class-select + allowEmpty: false + default: pt-nav-header-left-sidebar-position-bottom + options: + - + label: Top + value: pt-nav-header-left-sidebar-position-top + - + label: Bottom + value: pt-nav-header-left-sidebar-position-bottom + - + id: nav-header-left-sidebar-alignment + title: Left Sidebar Nav Header Alignment + description: Horizontal Alignment of the Nav Header in the Left Sidebar Workspace Leaf. + type: class-select + allowEmpty: false + default: pt-nav-header-left-sidebar-align-center + options: + - + label: Left + value: pt-nav-header-left-sidebar-align-left + - + label: Center + value: pt-nav-header-left-sidebar-align-center + - + label: Right + value: pt-nav-header-left-sidebar-align-right + - + id: nav-header-right-sidebar-position + title: Right Sidebar Nav Header Position + description: Vertical Position of the Nav Header in the Right Sidebar Workspace Leaf. + type: class-select + allowEmpty: false + default: pt-nav-header-right-sidebar-position-bottom + options: + - + label: Top + value: pt-nav-header-right-sidebar-position-top + - + label: Bottom + value: pt-nav-header-right-sidebar-position-bottom + - + id: nav-header-right-sidebar-alignment + title: Right Sidebar Nav Header Alignment + description: Horizontal Alignment of the Nav Header in the Right Sidebar Workspace Leaf. + type: class-select + allowEmpty: false + default: pt-nav-header-right-sidebar-align-center + options: + - + label: Left + value: pt-nav-header-right-sidebar-align-left + - + label: Center + value: pt-nav-header-right-sidebar-align-center + - + label: Right + value: pt-nav-header-right-sidebar-align-right + - + id: file-explorer + title: File Explorer + description: Customisation options for the File Explorer module. + type: heading + level: 3 + collapsed: true + - + id: file-explorer-left-margin + title: File Explorer File/Folder Left Margin (px) + description: Increases the Left Margin for Files/Folders in order indent them within another folder. + type: variable-number-slider + format: 'px' + default: 4 + min: 1 + max: 25 + step: 1 + - + id: custom-vault-banner + title: Custom Vault Banner + description: Custom Vault Banner in the File Explorer with a custom icon option. + type: heading + level: 4 + collapsed: true + - + id: pt-custom-vault-banner + title: Enable Custom Vault Banner + description: Enables the Custom Vault Banner in the File Explorer. + type: class-toggle + default: true + - + id: custom-vault-banner-horizontal-align + title: Custom Vault Banner Alignment + description: Horizontally aligns the Custom Vault Banner content. + type: class-select + allowEmpty: false + default: pt-custom-vault-banner-justify-content-center + options: + - + label: Left + value: pt-custom-vault-banner-justify-content-left + - + label: Center + value: pt-custom-vault-banner-justify-content-center + - + label: Right + value: pt-custom-vault-banner-justify-content-right + - + id: custom-vault-banner-order + title: Custom Vault Banner Order + description: Select the order in which the content appears in the Custom Vault Banner. + type: class-select + allowEmpty: false + default: pt-custom-vault-banner-order-ltr + options: + - + label: Left to Right + value: pt-custom-vault-banner-order-ltr + - + label: Right to Left + value: pt-custom-vault-banner-order-rtl + - + id: pt-custom-vault-banner-sticky + title: Custom Vault Banner Sticky + description: Make the Custom Vault Banner stick to the top of the File Explorer. + type: class-toggle + default: true + - + id: custom-vault-banner-icon-url + title: Vault Banner Icon (URL) + description: Customise the Vault Banner Icon. Insert a URL to an image in between the brackets of 'url()'. + type: variable-text + default: url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' x='0px' y='0px'%0Awidth='40' height='40'%0AviewBox='0 0 40 40'%0Astyle=' fill:%23000000;'%3E%3Cpath fill='%23dbb065' d='M1.5 35.5L1.5 4.5 11.793 4.5 14.793 7.5 35.5 7.5 35.5 35.5z'%3E%3C/path%3E%3Cpath fill='%23967a44' d='M11.586,5l2.707,2.707L14.586,8H15h20v27H2V5H11.586 M12,4H1v32h35V7H15L12,4L12,4z'%3E%3C/path%3E%3Cg%3E%3Cpath fill='%23f5ce85' d='M1.599 35.5L5.417 14.5 16.151 14.5 19.151 12.5 39.41 12.5 35.577 35.5z'%3E%3C/path%3E%3Cpath fill='%23967a44' d='M38.82,13l-3.667,22H2.198l3.636-20H16h0.303l0.252-0.168L19.303,13H38.82 M40,12H19l-3,2H5L1,36 h35L40,12L40,12z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E) + - + id: titlebar + title: Titlebar + description: Settings for changing the style of the Titlebar. + type: heading + level: 2 + collapsed: true + - + id: pt-titlebar-hide-text + title: Hide Titlebar Title Text + description: Hides the Titlebar Title Text (Useful when the Statusbar is at the top). + type: class-toggle + default: false + - + id: status-bar + title: Status Bar + description: Settings for the Status Bar. Adjust position, Change the order of items, etc. + type: heading + level: 2 + collapsed: true + - + id: pt-status-bar-style + title: Status Bar Style + description: Change the Position of the Status Bar. + type: class-select + allowEmpty: false + default: pt-status-bar-position-floating + options: + - + label: Floating + value: pt-status-bar-position-floating + - + label: Fixed + value: pt-status-bar-position-fixed + - + id: pt-fixed-status-bar-align + title: Fixed Status Bar Horizontal Alignment + description: Change the Horizontal Alignment of the Fixed Status Bar. + type: class-select + allowEmpty: false + default: pt-status-bar-align-center + options: + - + label: Left + value: pt-fixed-status-bar-align-left + - + label: Center + value: pt-fixed-status-bar-align-center + - + label: Right + value: pt-fixed-status-bar-align-right + - + id: status-bar-customisation-lt + title: Light Theme Customisation + type: heading + level: 3 + collapsed: true + - + id: status-bar-preset-lt + title: Status Bar Preset + description: Choose between Default and Custom colors for the Light Theme Status Bar. + default: pt-status-bar-default-lt + type: class-select + options: + - + label: Default + value: pt-status-bar-default-lt + - + label: Custom + value: pt-status-bar-custom-lt + - + id: status-bar-background-color-lt + title: Status Bar Background Color + description: Make sure you selected 'Custom' in Light Theme Status Bar Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#EBECEF' + - + id: status-bar-text-color-lt + title: Status Bar Text/Icons Color + description: Choose the color used for the Light Theme Status Bar Text/Icons. + default: pt-status-bar-text-dark-lt + type: class-select + options: + - + label: Light + value: pt-status-bar-text-light-lt + - + label: Dark + value: pt-status-bar-text-dark-lt + - + label: Accent Color + value: pt-status-bar-text-accent-lt + - + id: status-bar-customisation-dt + title: Dark Theme Customisation + type: heading + level: 3 + collapsed: true + - + id: status-bar-preset-dt + title: Status Bar Preset + description: Choose between Default and Custom colors for the Dark Theme Status Bar. + default: pt-status-bar-default-dt + level: 2 + type: class-select + options: + - + label: Default + value: pt-status-bar-default-dt + - + label: Custom + value: pt-status-bar-custom-dt + - + id: status-bar-background-color-dt + title: Status Bar Background Color + description: Make sure you selected 'Custom' in Dark Theme Status Bar Preset for this to work. + type: variable-color + format: hsl + opacity: false + default: '#2B2B2B' + - + id: status-bar-text-color-dt + title: Status Bar Text/Icons Color + description: Choose the color used for the Dark Theme Status Bar Text/Icons. + default: pt-status-bar-text-light-dt + type: class-select + options: + - + label: Light + value: pt-status-bar-text-light-dt + - + label: Dark + value: pt-status-bar-text-dark-dt + - + label: Accent Color + value: pt-status-bar-text-accent-dt + - + id: scrollbar + title: Scrollbar + description: Settings for the Scrollbar. Adjust the width, Add Scroll Buttons, etc. + type: heading + level: 2 + collapsed: true + - + id: scroll-bar-size + title: Scrollbar Width + description: Change the width of the Scrollbar (px). + type: variable-number-slider + default: 12 + min: 5 + max: 20 + format: px + - + id: plugins + title: Plugins + description: Plugin Specific Settings. + type: heading + level: 1 + collapsed: true + - + id: kanban-settings + title: Kanban + description: Mgmeyers Obsidian Kanban Plugin (https://github.com/mgmeyers/obsidian-kanban). + type: heading + level: 2 + collapsed: true + - + id: pt-disable-kanban-title-count + title: Disable Kanban Title Card Count + description: Removes the Card Count in the Kanban Lane Title. + type: class-toggle + default: false + - + id: pt-center-kanban-title-text + title: Center Kanban Title Text + description: Aligns the Kanban Lane Title to the center. + type: class-toggle + default: true + - + id: pt-kanban-background-lt + title: Light Theme Kanban Background + description: Change the Light Theme background of the Kanban board. + type: class-select + allowEmpty: false + default: pt-kanban-background-grid-plain-lt + options: + - + label: Solid Color + value: pt-kanban-background-default-lt + - + label: Transparent + value: pt-kanban-background-transparent-lt + - + label: Dots Plain Color + value: pt-kanban-background-dots-plain-lt + - + label: Dots Accent Color + value: pt-kanban-background-dots-accent-lt + - + label: Grid Plain Color + value: pt-kanban-background-grid-plain-lt + - + label: Grid Accent Color + value: pt-kanban-background-grid-accent-lt + - + id: pt-kanban-background-dt + title: Dark Theme Kanban Background + description: Change the Dark Theme background of the Kanban board. + type: class-select + allowEmpty: false + default: pt-kanban-background-grid-plain-dt + options: + - + label: Solid Color + value: pt-kanban-background-default-dt + - + label: Transparent + value: pt-kanban-background-transparent-dt + - + label: Dots Plain Color + value: pt-kanban-background-dots-plain-dt + - + label: Dots Accent Color + value: pt-kanban-background-dots-accent-dt + - + label: Grid Plain Color + value: pt-kanban-background-grid-plain-dt + - + label: Grid Accent Color + value: pt-kanban-background-grid-accent-dt + - + id: icon-folder-settings + title: Icon Folder + description: Florian Woelki Icon Folder (https://github.com/FlorianWoelki/obsidian-icon-folder). + type: heading + level: 2 + collapsed: true + - + id: pt-icon-folder-accent + title: Use UI Accent Color for Icon Folder + description: Makes the Folder Icons inherit the UI Accent Color. + type: class-toggle + default: true + - + id: icons-settings + title: Icons + description: visini Icons (https://github.com/visini/obsidian-icons-plugin). + type: heading + level: 2 + collapsed: true + - + id: pt-icons-accent + title: Use UI Accent Color for Icons + description: Makes the Icons inherit the UI Accent Color. + type: class-toggle + default: false + - + id: feature-toggles + title: Feature Toggles + description: Disable / hide certain aspects of the theme. + type: heading + level: 1 + collapsed: true + - + id: pt-disable-blur + title: Disable Blurred Background Effect + description: Disables the blur background in all elements that use it by making them opaque. + default: false + type: class-toggle + - + id: pt-fade-inactive-tabs + title: Fade Inactive Tabs + description: Fades out inactive UI tabs to help distinguish the currently active tab. + default: false + type: class-toggle + - + id: support + title: Support the Development of Prism + description: If you are enjoying the theme here are some ways to support its development. + type: heading + level: 1 + collapsed: false + - + id: support-star-repo + title: Star the project on GitHub + description: https://github.com/damiankorcz/Prism-Theme + type: heading + level: 2 + collapsed: true + - + id: support-submit-issue + title: Submit an issue with the theme + description: https://github.com/damiankorcz/Prism-Theme/issues + type: heading + level: 2 + collapsed: true + - + id: support-donate + title: Buy Me a Coffee + description: https://www.buymeacoffee.com/DamianKorcz + type: heading + level: 2 + collapsed: true +*/ +/*! +/* @plugins +core: +- audio-recorder +- backlink +- command-palette +- daily-notes +- file-explorer +- file-recovery +- global-search +- graph +- markdown-importer +- note-composer +- open-with-default-app +- outgoing-link +- outline +- page-preview +- publish +- random-note +- slash-commands +- slides +- starred +- sync +- switcher +- tag-pane +- templates +- word-count +- workspaces +- zk-prefixer + +community: +- obsidian-collapse-all-plugin +- table-editor-obsidian +- obsidian-kanban +- quick-explorer +- calendar +- cmenu-plugin +- obsidian-dangling-links +- pane-relief +- obsidian-icon-folder +- obsidian-map-view +- obsidian-emoji-toolbar +- obsidian-reminder-plugin +- obsidian-tagfolder +- obsidian-dictionary-plugin +- obsidian-icons-plugin +- obsidian-jump-to-date-plugin +- obsidian-hover-editor +- obsidian-quiet-outline +- recent-files-obsidian +- file-tree-alternative +*/ diff --git a/.obsidian/workspace.json b/.obsidian/workspace.json new file mode 100644 index 0000000..a0a3da8 --- /dev/null +++ b/.obsidian/workspace.json @@ -0,0 +1,171 @@ +{ + "main": { + "id": "8e9accceb03b8cbb", + "type": "split", + "children": [ + { + "id": "77f1190466bc3393", + "type": "tabs", + "children": [ + { + "id": "3830486783f1e583", + "type": "leaf", + "state": { + "type": "markdown", + "state": { + "file": "OJ notes/OJ-index.md", + "mode": "preview", + "backlinks": false, + "source": true + } + } + } + ] + } + ], + "direction": "vertical" + }, + "left": { + "id": "8f339aba13fc7b34", + "type": "split", + "children": [ + { + "id": "181b0904a5ea9093", + "type": "tabs", + "dimension": 80.92443140132062, + "children": [ + { + "id": "dc7b766adde71133", + "type": "leaf", + "state": { + "type": "file-explorer", + "state": { + "sortOrder": "byCreatedTime" + } + } + }, + { + "id": "9fea4d6a3fb7b065", + "type": "leaf", + "state": { + "type": "search", + "state": { + "query": "BFS", + "matchingCase": false, + "explainSearch": false, + "collapseAll": true, + "extraContext": false, + "sortOrder": "alphabetical" + } + } + } + ] + }, + { + "id": "67a5b9b7405b0aab", + "type": "tabs", + "dimension": 19.075568598679386, + "children": [ + { + "id": "433ee2e054563ec8", + "type": "leaf", + "state": { + "type": "starred", + "state": {} + } + } + ] + } + ], + "direction": "horizontal", + "width": 471 + }, + "right": { + "id": "84d48f88a06a5d05", + "type": "split", + "children": [ + { + "id": "600e2282db7d13db", + "type": "tabs", + "dimension": 50.03668378576669, + "children": [ + { + "id": "b7747330b7aae8d3", + "type": "leaf", + "state": { + "type": "backlink", + "state": { + "file": "OJ notes/OJ-index.md", + "collapseAll": false, + "extraContext": false, + "sortOrder": "alphabetical", + "showSearch": false, + "searchQuery": "", + "backlinkCollapsed": false, + "unlinkedCollapsed": false + } + } + }, + { + "id": "9519bbe1baa8be43", + "type": "leaf", + "state": { + "type": "outgoing-link", + "state": { + "file": "OJ notes/OJ-index.md", + "linksCollapsed": false, + "unlinkedCollapsed": true + } + } + }, + { + "id": "bad3fb60ee1eaeb0", + "type": "leaf", + "state": { + "type": "tag", + "state": { + "sortOrder": "frequency", + "useHierarchy": true + } + } + } + ] + }, + { + "id": "5904586ead812fd4", + "type": "tabs", + "dimension": 49.96331621423331, + "children": [ + { + "id": "08480958817d433e", + "type": "leaf", + "state": { + "type": "outline", + "state": { + "file": "OJ notes/OJ-index.md" + } + } + } + ] + } + ], + "direction": "horizontal", + "width": 419 + }, + "ribbon": { + "mostRecentAction": "" + }, + "active": "3830486783f1e583", + "lastOpenFiles": [ + "OJ notes/pages/Leetcode Linked-List-Cycle.md", + "OJ notes/pages/Leetcode Binary-Tree-Level-Order-Traversal.md", + "OJ notes/pages/Leetcode 01-Matrix.md", + "OJ notes/pages/Breadth First Search.md", + "OJ notes/pages/Leetcode Reverse-Linked-List.md", + "OJ notes/pages/Two pointers approach.md", + "OJ notes/pages/Leetcode Remove-Nth-Node-From-End-of-List.md", + "OJ notes/pages/Leetcode Remove-Linked-List-Elements.md", + "OJ notes/pages/Leetcode Remove-Duplicates-From-Sorted-List.md", + "OJ notes/pages/Leetcode Middle-of-the-Linked-List.md" + ] +} \ No newline at end of file