forked from palantir/tslint
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[New rule] add fileNameCasing rule (palantir#3978)
* add fileNameCasing rule * use camel case name for tslintCli * refactor casing check into helper function * use stylized name for casing in failure message
- Loading branch information
Showing
9 changed files
with
129 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,3 @@ | ||
#!/usr/bin/env node | ||
|
||
require("../lib/tslint-cli"); | ||
require("../lib/tslintCli"); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
/** | ||
* @license | ||
* Copyright 2018 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. | ||
*/ | ||
|
||
import * as path from "path"; | ||
import * as ts from "typescript"; | ||
|
||
import * as Lint from "../index"; | ||
import { isCamelCased, isKebabCased, isPascalCased } from "../utils"; | ||
|
||
enum Casing { | ||
CamelCase = "camel-case", | ||
PascalCase = "pascal-case", | ||
KebabCase = "kebab-case", | ||
} | ||
|
||
export class Rule extends Lint.Rules.AbstractRule { | ||
/* tslint:disable:object-literal-sort-keys */ | ||
public static metadata: Lint.IRuleMetadata = { | ||
ruleName: "file-name-casing", | ||
description: "Enforces a consistent file naming convention", | ||
rationale: "Helps maintain a consistent style across a file hierarchy", | ||
optionsDescription: Lint.Utils.dedent` | ||
One of the following arguments must be provided: | ||
* \`${Casing.CamelCase}\`: File names must be camel-cased: \`fileName.ts\`. | ||
* \`${Casing.PascalCase}\`: File names must be Pascal-cased: \`FileName.ts\`. | ||
* \`${Casing.KebabCase}\`: File names must be kebab-cased: \`file-name.ts\`.`, | ||
options: { | ||
type: "array", | ||
items: [ | ||
{ | ||
type: "string", | ||
enum: [Casing.CamelCase, Casing.PascalCase, Casing.KebabCase], | ||
}, | ||
], | ||
}, | ||
optionExamples: [ | ||
[true, Casing.CamelCase], | ||
[true, Casing.PascalCase], | ||
[true, Casing.KebabCase], | ||
], | ||
hasFix: false, | ||
type: "style", | ||
typescriptOnly: false, | ||
}; | ||
/* tslint:enable:object-literal-sort-keys */ | ||
|
||
private static FAILURE_STRING(expectedCasing: Casing): string { | ||
return `File name must be ${Rule.stylizedNameForCasing(expectedCasing)}`; | ||
} | ||
|
||
private static stylizedNameForCasing(casing: Casing): string { | ||
switch (casing) { | ||
case Casing.CamelCase: | ||
return "camelCase"; | ||
case Casing.PascalCase: | ||
return "PascalCase"; | ||
case Casing.KebabCase: | ||
return "kebab-case"; | ||
} | ||
} | ||
|
||
private static isCorrectCasing(fileName: string, casing: Casing): boolean { | ||
switch (casing) { | ||
case Casing.CamelCase: | ||
return isCamelCased(fileName); | ||
case Casing.PascalCase: | ||
return isPascalCased(fileName); | ||
case Casing.KebabCase: | ||
return isKebabCased(fileName); | ||
} | ||
} | ||
|
||
public apply(sourceFile: ts.SourceFile): Lint.RuleFailure[] { | ||
if (this.ruleArguments.length !== 1) { | ||
return []; | ||
} | ||
|
||
const casing = this.ruleArguments[0] as Casing; | ||
const fileName = path.parse(sourceFile.fileName).name; | ||
if (!Rule.isCorrectCasing(fileName, casing)) { | ||
return [new Lint.RuleFailure(sourceFile, 0, 0, Rule.FAILURE_STRING(casing), this.ruleName)]; | ||
} | ||
|
||
return []; | ||
} | ||
} |
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
|
||
~nil [File name must be camelCase] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"rules": { | ||
"file-name-casing": [true, "camel-case"] | ||
} | ||
} |