mirror of
https://github.com/realm/SwiftLint.git
synced 2026-06-06 20:18:40 +00:00
49 lines
1.8 KiB
Swift
49 lines
1.8 KiB
Swift
//
|
|
// VariableNameMaxLengthRule.swift
|
|
// SwiftLint
|
|
//
|
|
// Created by Mickaël Morier on 05/11/2015.
|
|
// Copyright © 2015 Realm. All rights reserved.
|
|
//
|
|
|
|
import SourceKittenFramework
|
|
import SwiftXPC
|
|
|
|
public struct VariableNameMaxLengthRule: ASTRule, ViolationLevelRule {
|
|
public var warning = RuleParameter(severity: .Warning, value: 40)
|
|
public var error = RuleParameter(severity: .Error, value: 60)
|
|
|
|
public init() {}
|
|
|
|
public static let description = RuleDescription(
|
|
identifier: "variable_name_max_length",
|
|
name: "Variable Name Max Length Rule",
|
|
description: "Variable name should not be too long.",
|
|
nonTriggeringExamples: [
|
|
"let myLet = 0",
|
|
"var myVar = 0",
|
|
"private let _myLet = 0"
|
|
],
|
|
triggeringExamples: [
|
|
"↓let myExtremelyVeryVeryVeryVeryVeryVeryLongLet = 0",
|
|
"↓var myExtremelyVeryVeryVeryVeryVeryVeryLongVar = 0",
|
|
"private ↓let _myExtremelyVeryVeryVeryVeryVeryVeryLongLet = 0"
|
|
]
|
|
)
|
|
|
|
public func validateFile(file: File, kind: SwiftDeclarationKind,
|
|
dictionary: XPCDictionary) -> [StyleViolation] {
|
|
return file.validateVariableName(dictionary, kind: kind).map { name, offset in
|
|
let charCount = name.characters.count
|
|
for parameter in [error, warning] where charCount > parameter.value {
|
|
return [StyleViolation(ruleDescription: self.dynamicType.description,
|
|
severity: parameter.severity,
|
|
location: Location(file: file, byteOffset: offset),
|
|
reason: "Variable name should be \(parameter.value) characters " +
|
|
"or less: currently \(charCount) characters")]
|
|
}
|
|
return []
|
|
} ?? []
|
|
}
|
|
}
|