Files
ry.kazcloud.dev/node_modules/yaml-language-server/lib/umd/languageservice/utils/astUtils.js
Ryan Kazokas d181f77fb2
All checks were successful
Build and Push / build (push) Successful in 55s
Updates dockerfile
2026-02-16 15:09:37 -05:00

126 lines
4.9 KiB
JavaScript

/*---------------------------------------------------------------------------------------------
* Copyright (c) Red Hat, Inc. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
(function (factory) {
if (typeof module === "object" && typeof module.exports === "object") {
var v = factory(require, exports);
if (v !== undefined) module.exports = v;
}
else if (typeof define === "function" && define.amd) {
define(["require", "exports", "yaml"], factory);
}
})(function (require, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.isCollectionItem = exports.isInComment = exports.indexOf = exports.isMapContainsEmptyPair = exports.getParent = void 0;
const yaml_1 = require("yaml");
function getParent(doc, nodeToFind) {
let parentNode;
(0, yaml_1.visit)(doc, (_, node, path) => {
if (node === nodeToFind) {
parentNode = path[path.length - 1];
return yaml_1.visit.BREAK;
}
});
if ((0, yaml_1.isDocument)(parentNode)) {
return undefined;
}
return parentNode;
}
exports.getParent = getParent;
function isMapContainsEmptyPair(map) {
if (map.items.length > 1) {
return false;
}
const pair = map.items[0];
return (0, yaml_1.isScalar)(pair.key) && (0, yaml_1.isScalar)(pair.value) && pair.key.value === '' && !pair.value.value;
}
exports.isMapContainsEmptyPair = isMapContainsEmptyPair;
function indexOf(seq, item) {
for (const [i, obj] of seq.items.entries()) {
if (item === obj) {
return i;
}
}
return undefined;
}
exports.indexOf = indexOf;
/**
* Check that given offset is in YAML comment
* @param doc the yaml document
* @param offset the offset to check
*/
function isInComment(tokens, offset) {
let inComment = false;
for (const token of tokens) {
if (token.type === 'document') {
_visit([], token, (item) => {
if (isCollectionItem(item) && item.value?.type === 'comment') {
if (token.offset <= offset && item.value.source.length + item.value.offset >= offset) {
inComment = true;
return yaml_1.visit.BREAK;
}
}
else if (item.type === 'comment' && item.offset <= offset && item.offset + item.source.length >= offset) {
inComment = true;
return yaml_1.visit.BREAK;
}
});
}
else if (token.type === 'comment') {
if (token.offset <= offset && token.source.length + token.offset >= offset) {
return true;
}
}
if (inComment) {
break;
}
}
return inComment;
}
exports.isInComment = isInComment;
function isCollectionItem(token) {
return token['start'] !== undefined;
}
exports.isCollectionItem = isCollectionItem;
function _visit(path, item, visitor) {
let ctrl = visitor(item, path);
if (typeof ctrl === 'symbol')
return ctrl;
for (const field of ['key', 'value']) {
const token = item[field];
if (token && 'items' in token) {
for (let i = 0; i < token.items.length; ++i) {
const ci = _visit(Object.freeze(path.concat([[field, i]])), token.items[i], visitor);
if (typeof ci === 'number')
i = ci - 1;
else if (ci === yaml_1.visit.BREAK)
return yaml_1.visit.BREAK;
else if (ci === yaml_1.visit.REMOVE) {
token.items.splice(i, 1);
i -= 1;
}
}
if (typeof ctrl === 'function' && field === 'key')
ctrl = ctrl(item, path);
}
}
const token = item['sep'];
if (token) {
for (let i = 0; i < token.length; ++i) {
const ci = _visit(Object.freeze(path), token[i], visitor);
if (typeof ci === 'number')
i = ci - 1;
else if (ci === yaml_1.visit.BREAK)
return yaml_1.visit.BREAK;
else if (ci === yaml_1.visit.REMOVE) {
token.items.splice(i, 1);
i -= 1;
}
}
}
return typeof ctrl === 'function' ? ctrl(item, path) : ctrl;
}
});
//# sourceMappingURL=astUtils.js.map