Files
SwiftLint/Source/SwiftLintFramework/Rules/CustomRules.swift
T

73 lines
2.1 KiB
Swift

//
// CustomRules.swift
// SwiftLint
//
// Created by Scott Hoyt on 1/21/16.
// Copyright © 2016 Realm. All rights reserved.
//
import Foundation
import SourceKittenFramework
// MARK: - CustomRulesConfig
public struct CustomRulesConfig: RuleConfig, Equatable {
public var consoleDescription: String { return "user-defined" }
public var customRuleConfigs = [RegexConfig]()
public init() {}
public mutating func setConfig(config: AnyObject) throws {
guard let configDict = config as? [String: AnyObject] else {
throw ConfigurationError.UnknownConfiguration
}
for (key, value) in configDict {
var ruleConfig = RegexConfig(identifier: key)
try ruleConfig.setConfig(value)
customRuleConfigs.append(ruleConfig)
}
}
}
public func == (lhs: CustomRulesConfig, rhs: CustomRulesConfig) -> Bool {
return lhs.customRuleConfigs == rhs.customRuleConfigs
}
// MARK: - CustomRules
public struct CustomRules: Rule, ConfigProviderRule {
public static let description = RuleDescription(
identifier: "custom_rules",
name: "Custom Rules",
description: "Create custom rules by providing a regex string. " +
"Optionally specify what syntax kinds to match against, the severity " +
"level, and what message to display.")
public var config = CustomRulesConfig()
public init() {}
public func validateFile(file: File) -> [StyleViolation] {
if config.customRuleConfigs.isEmpty {
return []
}
return config.customRuleConfigs.flatMap {
self.validate(file, withConfig: $0)
}
}
private func validate(file: File, withConfig config: RegexConfig) -> [StyleViolation] {
return file.matchPattern(config.regex).filter {
!config.matchKinds.intersect($0.1).isEmpty
}.map {
StyleViolation(ruleDescription: config.description,
severity: config.severity,
location: Location(file: file, characterOffset: $0.0.location),
reason: config.message)
}
}
}