.gitignore added
[dotfiles/.git] / .config / coc / extensions / node_modules / coc-prettier / node_modules / tslint / lib / formatters / stylishFormatter.js
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 (file)
index 0000000..82d2073
--- /dev/null
@@ -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;