| Crates.io | licensesnip |
| lib.rs | licensesnip |
| version | 1.7.0 |
| created_at | 2022-03-30 17:02:41.447168+00 |
| updated_at | 2025-01-09 18:19:24.195007+00 |
| description | A tool to add license headers to your source code. |
| homepage | |
| repository | https://github.com/notken12/licensesnip |
| max_upload_size | |
| id | 559296 |
| size | 87,822 |
Tool to automatically add license headers to your source code. Customizable for any language.
Licensesnip is written is Rust and is fast and reliable ⚡.
cargo install licensesnip
In your project's root directory, add a file named .licensesnip and write your license header there. Licensesnip will automatically replace %FILENAME% with the file name and %YEAR% with the year.
To add license headers to all your source code:
licensesnip
Licensesnip ignores files in your .gitignore file by default. You can also add a file named .licensesnipignore and specify patterns the same way as in a .gitignore file.
To remove license headers from all source code:
licensesnip remove
To check if license headers are present in all of your source files:
licensesnip check
You can also specify a specific path or file to modify:
# Add licenses to src/main.rs
licensesnip src/main.rs
# Remove licenses from src folder
licensesnip remove src/
You can use licensesnip with pre-commit. Add it to your local .pre-commit-config.yaml as follows:
- repo: https://github.com/notken12/licensesnip
rev: 19b1186 # choose your preferred tag or commit hash
hooks:
- id: licensesnip
args: ["check"] # optionally modify the arguments for licensesnip (default arguments shown here)
Find your global Licensesnip config file:
licensesnip config
Create/find the local config file for the current directory:
licensesnip config -d
Example configuration:
{
"use_gitignore": true,
"file_types": {
"js,mjs,ts,cjs,jsx,tsx": {
"before_line": "// "
},
"vue,html": {
"before_block": "<!--",
"before_line": " ",
"after_block": "-->"
},
"rs": {
"before_line": "// "
},
"c": {
"enable": false
}
}
}
To configure a language just specify how the comments for that language work. Supported properties are before_line, after_line, before_block, and after_block. To disable adding licenses to a filetype, set enable to false.
I haven't added builtin support for many languages yet. Please help out and add your favorite languages to src/base-config.jsonc and submit a pull request. Thank you!