-
Notifications
You must be signed in to change notification settings - Fork 1
/
.swiftlint.yml
96 lines (83 loc) · 2.69 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
included: # paths to include during linting. `--path` is ignored if present.
- TestApplication # Rename this to the name of your project
# - Africa
# - The name of directory during linting
excluded: # paths to ignore during linting. Takes precedence over `included`.
- Carthage
- Pods
# - Source/ExcludedFolder
# - Source/ExcludedFile.swift
# - Source/*/ExcludedFile.swift # Exclude files with a wildcard
# 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
- trailing_whitespace
opt_in_rules:
- empty_count
- implicitly_unwrapped_optional
# Fomatting Specific Constructs
# - comment_spacing (default enabled)
# - switch_case_alignment (default enabled)
- switch_case_on_newline
- explicit_enum_raw_value
- redundant_string_enum_value
- trailing_closure
# Naming
# - identifier_name (default enabled)
- static_operator
# Programming practices rules
- no_extension_access_modifier
- modifier_order
- fallthrough
- force_try
- force_unwrapping
- operator_usage_whitespace
- multiline_parameters
- multiline_arguments
# 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` (experimental)
- explicit_self
# configurable rules can be customized from this configuration file
# binary rules can set their severity level
force_unwrapping: warning
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:
warning: 100
error: 200
ignores_comments: true
ignores_function_declarations: true
ignores_interpolated_strings: true
ignores_urls: true
# they can set both implicitly with an array
type_body_length:
- 300 # warning
- 400 # 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: 40
error: 50
excluded: iPhone # excluded via string
allowed_symbols: ["_"] # these are allowed in type names
identifier_name:
min_length: # only min_length
warning: 3
max_length:
warning: 35
excluded: # excluded via string array
- id
- URL
- GlobalAPIKey
reporter: "xcode" # reporter type (xcode, json, csv, checkstyle, codeclimate, junit, html, emoji, sonarqube, markdown, github-actions-logging)