A Python linter focused on naming conventions with 5 strictness levels
Project description
yina
A simple, yet opinionated linter for Python that helps you choose more descriptive variable names.
pip install yina
Usage
- Run
yina lint file.pyto lint a file oryina lint src/for a directory. - Use the
--level Noption to specify the strictness level. Defaults to level 3. - With
yina inityou can generate a configuration file for the working directory with default values you can edit.
Strictness levels
Yina lint operates on 5 strictness levels. Each level includes all the rules from the previous levels.
| Level | Rules |
|---|---|
| Level 1: Length and charset | - Variables must be at least 3 characters long. - Variables can only contain characters: a-Z, A-Z, 0-9 and _. - Variables cannot start with a number. |
| Level 2: Naming conventions | - Snake case will be enforced for regular variables and camel case for class names. - All constants must be fully capitalized. - Snake case variables that are not constants cannot have capital letters. |
| Level 3 (default): Word length, max length, repetition | - Max variable length: 32 characters. - No more than 2 underscores in a row. - Applied for each "word" in a variable name, like "one" in "one_two_three": - No more than 2 of the same letter in a row. - At least 3 characters long. |
| Level 4: Pronounceability | - Applied for each "word" in a variable name, like "one" in "one_two_three": - At least one vowel - No more than 4 consonants in a row |
| Level 5: Non vagueness | - No vague words like "item(s)", "thing(s)", "object(s)", "element(s)", "data", "value" or "result". "string" or "dataframe" are also disallowed. Applies only to the entire variable name, vague segments are allowed. - No numbers. |
Configuration
- If there is a
.yina.tomlfile in the working directory, it will be used. - If not, the default
yina-lint/config/yina.tomlfile will be applied.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
yina-0.1.6.tar.gz
(10.7 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
yina-0.1.6-py3-none-any.whl
(11.5 kB
view details)
File details
Details for the file yina-0.1.6.tar.gz.
File metadata
- Download URL: yina-0.1.6.tar.gz
- Upload date:
- Size: 10.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5b9f1482dae32efeceeab5505bed8832fa91502b13d31995c7f15a7cafaacbbc
|
|
| MD5 |
3496e94509621c81b77039bf031b92eb
|
|
| BLAKE2b-256 |
00cae1d5e3c70ef16aac78923a1c5cf79d6db2b1060da64703a8c1c7afcc2222
|
File details
Details for the file yina-0.1.6-py3-none-any.whl.
File metadata
- Download URL: yina-0.1.6-py3-none-any.whl
- Upload date:
- Size: 11.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b1145899f79bdc7cc5c39b055cde0644518a957624c823906fdcd8c759d9d6b9
|
|
| MD5 |
edafee3a0014b47aea223d6105cd2fe0
|
|
| BLAKE2b-256 |
057c6831cf95a69901f58f1f215532a6d8e334f5c3edc526bcc0a19ff19b578f
|