-
-
Notifications
You must be signed in to change notification settings - Fork 139
/
Copy path.swiftlint.yml
101 lines (95 loc) · 3.51 KB
/
.swiftlint.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# By default, SwiftLint uses a set of sensible default rules you can adjust:
disabled_rules: # rule identifiers turned on by default to exclude from running
- function_body_length
- shorthand_operator
- opening_brace
- line_length
- statement_position
- todo
- for_where
- non_optional_string_data_conversion
- inclusive_language
- orphaned_doc_comment
- redundant_optional_initialization
- nesting
- trailing_whitespace
- cyclomatic_complexity # remove this later
opt_in_rules: # some rules are turned off by default, so you need to opt-in
- empty_count # find all the available rules by running: `swiftlint rules`
- explicit_init
# - contrasted_opening_brace
- explicit_type_interface # Force the specification of types
# Alternatively, specify all rules explicitly by uncommenting this option:
# only_rules: # delete `disabled_rules` & `opt_in_rules` if using this
# - empty_parameters
# - vertical_whitespace
analyzer_rules: # rules run by `swiftlint analyze`
- explicit_self
excluded: # case-sensitive paths to ignore during linting. Takes precedence over `included`
- Carthage
- Pods
- Sources/ExcludedFolder
- Sources/ExcludedFile.swift
- Sources/*/ExcludedFile.swift # exclude files with a wildcard
# If true, SwiftLint will not fail if no lintable files are found.
allow_zero_lintable_files: false
# If true, SwiftLint will treat all warnings as errors.
strict: false
# configurable rules can be customized from this configuration file
# binary rules can set their severity level
force_cast: warning # implicitly
force_try:
severity: warning # explicitly
# rules that have both warning and error levels, can set just the warning level
# implicitly
#line_length: 150
# they can set both implicitly with an array
type_body_length:
- 600 # warning
- 700 # error
# or they can set both explicitly
file_length:
warning: 500
error: 1200
# naming rules can set warnings/errors for min_length and max_length
# additionally they can set excluded names
type_name:
min_length: 4 # only warning
max_length: # warning and error
warning: 60
error: 80
excluded: iPhone # excluded via string
allowed_symbols: ["_"] # these are allowed in type names
identifier_name:
min_length: # only min_length
error: 3 # only error
max_length: # warning and error
warning: 70
error: 100
excluded: # excluded via string array
- id
- URL
- GlobalAPIKey
allowed_symbols: ["_"]
reporter: "xcode" # reporter type (xcode, json, csv, checkstyle, codeclimate, junit, html, emoji, sonarqube, markdown, github-actions-logging, summary)
custom_rules:
enum_associated_value_let_syntax:
name: "Enum Associated Value Let Syntax"
regex: 'case\s+\.?\w+\([^)]*:\s*[^)]'
message: "Use `let` syntax for enum associated values (e.g., `case .example(let value)` instead of `case .example(value: _)`)"
severity: warning
match_kinds:
- keyword # matches 'case'
- identifier # matches enum case names
- attribute.builtin # matches associated value declarations
# brackets_newline:
# name: "Opening Brackets not on Next Line"
# message: "Opening brackets should be placed on their own lines"
# include: "*.swift"
# regex: '^(?=.*\{)(?=.*(?:func|if|else|class|struct|catch|try|init|guard)).*$'
# severity: warning
# else_statement_position:
# name: "Else Statement Position"
# regex: '\}[ \t]*\n[ \t]*else'
# message: "Else statements should be on their own line, right after the closing brace of the preceding block."
# severity: error