X-Git-Url: https://git.josue.xyz/?a=blobdiff_plain;f=.config%2Fcoc%2Fextensions%2Fnode_modules%2Fcoc-prettier%2Fnode_modules%2Ftslint%2Flib%2Fformatters%2FstylishFormatter.js;fp=.config%2Fcoc%2Fextensions%2Fnode_modules%2Fcoc-prettier%2Fnode_modules%2Ftslint%2Flib%2Fformatters%2FstylishFormatter.js;h=82d2073b8e68ed88039989c0ce02a6da375392c5;hb=3aba54c891969552833dbc350b3139e944e17a97;hp=0000000000000000000000000000000000000000;hpb=1def8ecce8e6f3aa32e6978d0ba7846a99b8de34;p=dotfiles%2F.git diff --git a/.config/coc/extensions/node_modules/coc-prettier/node_modules/tslint/lib/formatters/stylishFormatter.js b/.config/coc/extensions/node_modules/coc-prettier/node_modules/tslint/lib/formatters/stylishFormatter.js new file mode 100644 index 00000000..82d2073b --- /dev/null +++ b/.config/coc/extensions/node_modules/coc-prettier/node_modules/tslint/lib/formatters/stylishFormatter.js @@ -0,0 +1,114 @@ +"use strict"; +/** + * @license + * Copyright 2013 Palantir Technologies, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +Object.defineProperty(exports, "__esModule", { value: true }); +var tslib_1 = require("tslib"); +var chalk_1 = require("chalk"); +var abstractFormatter_1 = require("../language/formatter/abstractFormatter"); +var Utils = require("../utils"); +var Formatter = /** @class */ (function (_super) { + tslib_1.__extends(Formatter, _super); + function Formatter() { + return _super !== null && _super.apply(this, arguments) || this; + } + /* tslint:enable:object-literal-sort-keys */ + Formatter.prototype.format = function (failures) { + failures = this.sortFailures(failures); + var outputLines = this.mapToMessages(failures); + // Removes initial blank line + if (outputLines[0] === "") { + outputLines.shift(); + } + return outputLines.join("\n") + "\n"; + }; + Formatter.prototype.mapToMessages = function (failures) { + if (failures.length === 0) { + return []; + } + var outputLines = []; + var positionMaxSize = this.getPositionMaxSize(failures); + var ruleMaxSize = this.getRuleMaxSize(failures); + var currentFile; + for (var _i = 0, failures_1 = failures; _i < failures_1.length; _i++) { + var failure = failures_1[_i]; + var fileName = failure.getFileName(); + var lineAndCharacter = failure.getStartPosition().getLineAndCharacter(); + var positionTuple = lineAndCharacter.line + 1 + ":" + (lineAndCharacter.character + 1); + // Output the name of each file once + if (currentFile !== fileName) { + outputLines.push(""); + outputLines.push("" + fileName + chalk_1.default.hidden(":" + positionTuple)); + currentFile = fileName; + } + var failureString = failure.getFailure(); + failureString = chalk_1.default.yellow(failureString); + // Rule + var ruleName = failure.getRuleName(); + ruleName = this.pad(ruleName, ruleMaxSize); + ruleName = chalk_1.default.grey(ruleName); + // Lines + positionTuple = this.pad(positionTuple, positionMaxSize); + positionTuple = + failure.getRuleSeverity() === "warning" + ? chalk_1.default.blue(failure.getRuleSeverity().toUpperCase() + ": " + positionTuple) + : chalk_1.default.red(failure.getRuleSeverity().toUpperCase() + ": " + positionTuple); + // Output + var output = positionTuple + " " + ruleName + " " + failureString; + outputLines.push(output); + } + return outputLines; + }; + Formatter.prototype.pad = function (str, len) { + var padder = Array(len + 1).join(" "); + return (str + padder).substring(0, padder.length); + }; + Formatter.prototype.getPositionMaxSize = function (failures) { + var positionMaxSize = 0; + for (var _i = 0, failures_2 = failures; _i < failures_2.length; _i++) { + var failure = failures_2[_i]; + var lineAndCharacter = failure.getStartPosition().getLineAndCharacter(); + var positionSize = (lineAndCharacter.line + 1 + ":" + (lineAndCharacter.character + 1)) + .length; + if (positionSize > positionMaxSize) { + positionMaxSize = positionSize; + } + } + return positionMaxSize; + }; + Formatter.prototype.getRuleMaxSize = function (failures) { + var ruleMaxSize = 0; + for (var _i = 0, failures_3 = failures; _i < failures_3.length; _i++) { + var failure = failures_3[_i]; + var ruleSize = failure.getRuleName().length; + if (ruleSize > ruleMaxSize) { + ruleMaxSize = ruleSize; + } + } + return ruleMaxSize; + }; + /* tslint:disable:object-literal-sort-keys */ + Formatter.metadata = { + formatterName: "stylish", + description: "Human-readable formatter which creates stylish messages.", + descriptionDetails: Utils.dedent(templateObject_1 || (templateObject_1 = tslib_1.__makeTemplateObject(["\n The output matches what is produced by ESLint's stylish formatter.\n Its readability is enhanced through spacing and colouring."], ["\n The output matches what is produced by ESLint's stylish formatter.\n Its readability is enhanced through spacing and colouring."]))), + sample: Utils.dedent(templateObject_2 || (templateObject_2 = tslib_1.__makeTemplateObject(["\n myFile.ts\n Error: 1:14 semicolon Missing semicolon"], ["\n myFile.ts\n Error: 1:14 semicolon Missing semicolon"]))), + consumer: "human", + }; + return Formatter; +}(abstractFormatter_1.AbstractFormatter)); +exports.Formatter = Formatter; +var templateObject_1, templateObject_2;