Skip to main content

Add or update the header of a file with the appropriate comment style.

Project description

add header comment

A pre-commit hook to automatically add or update a header of a text file with the appropriate comment style for your source code.

Why does this exist?

This exists so that you can include a license (or any other piece of text) at the top of a lot of different files, and it can automatically update them all at once.

There are already other pre-commit hooks that do this (such as Lucas-C/pre-commit-hooks), how does this one differ?

This pre-commit hook

  • Always keeps your header up to date when you change the header text.
    • It does not rely on an fuzzy string matching or require you to remove all the old headers with a separate command before applying the new header.
    • Instead, it looks for the end of the comment or a custom string that you set to identify the end of the header.
  • Has the ability to wrap long text onto a new line. This is not as useful for just pasting a license at the top of a file that is already formatted with newlines, but quite useful if the block of text is just a long single line.

How to use?

This is how to set up the pre-commit hook. You may consider running the hook multiple times for different file extensions. Related, you should change the files regex and name (to help better identify each check) appropriately. And you can pass any of the below options in the args section.

repos:
  - repo: https://github.com/sayari-analytics/add-header-comment
    rev: v1.0.1
    hooks:
      - id: add-header
        name: Add or update header for Python files
        args:
          - --header-filepath
          - path/to/header.txt
          # put optional arguments here
        files: \.py$

Options

These are the options that the script accepts. This is mostly copied from the output of the --help option.

One thing to note is that the filepaths you want this script to run on are passed as positional arguments. In a pre-commit hook, this is handled automatically. Something to keep note of if you are using this outside of pre-commit.

  • --header-filepath (required, string) - The filepath to the header file.
  • --comment-style (optional, string) - A single comment prefix or a triplet separated by vertical bars (<comment-start>|<comment-prefix>|<comment-end>). E.g., a Java comment block would be: /*| *| */. Defaults to #.
  • --newline-after-comment-start (optional, boolean flag) - Adds a newline after the comment start.
  • --newline-before-comment-end (optional, boolean flag) - Adds a newline before the comment end.
  • --start-header-after (optional, string) - A string to search for to start the header afterwards. Helpful if you want to add a header to a shell script.
  • --ignore-below-string (optional, string) - A string to search for to determine where the header stops and the rest of the content starts (typically in a comment). Defaults to ignore below.
  • --stop-at-ignore-below (optional, boolean flag) - Stops adding the header when the ignore-below-string is found.
  • --max-line-length (optional, integer) - Splits lines by word tokens that are longer than the specified length.
  • --fail-on-fix (optional, boolean flag) - Exits with a non-zero status if any files were modified. No need to pass this when using as a pre-commit hook since pre-commit will fail if any files have been modified.

Other ways to install

If you prefer to use this tool without pre-commit, you can install the standalone Python package.

pip install add-header-comment

After installing the package, you can use the cli tool by typing:

# with the installed console script entry point
add-header-comment -h
# or the use the alias
add-header -h
# or through the Python module
python -m add_header_comment -h

Examples

Here are some examples demonstrating this pre-commit hook's ability. Additionally, you might find it helpful to look at our test cases for more examples.

Markdown with entirely different header

The command to run:

add-header \
  --header-filepath path/to/header.txt \
  --comment-style "<!--||-->" \
  filepath1.md filepath2.md

If the existing header is like this:

<!-- There is no common text between this old header and the new one -->
# Hello World

Outputs a header like this (there is no fuzzy string matching or running a separate command to remove the old header required):

<!-- This is the new header comment -->
# Hello World

Java with max line length and newline before comment end

The command to run:

add-header \
  --header-filepath path/to/header.txt \
  --comment-style "/*| *| */" \
  --newline-before-comment-end \
  --max-line-length 110 \
  filepath1.java filepath2.java

Outputs a header like this:

/* This is a really long comment that should get split after 110 characters. This is a really long comment
 * that should get split after 110 characters.
 */
public class HelloWorld {}

Java without max line length and without newline before comment end

The command to run:

add-header \
  --header-filepath path/to/header.txt \
  --comment-style "/*| *| */" \
  filepath1.java filepath2.java

Outputs a header like this:

/* This is a really long comment that does not get get split. This is a really long comment that does not get get split. */
public class HelloWorld {}

Bash

The command to run:

add-header \
  --header-filepath path/to/header.txt \
  --start-header-after "#!/bin/bash" \
  filepath1.sh filepath2.sh

Outputs a header like this:

#!/bin/bash
# this is the header comment
echo hi

JavaScript

The command to run:

add-header \
  --header-filepath path/to/header.txt \
  --comment-style "//" \
  filepath1.js filepath2.js

Outputs a header like this:

// this is the header comment
console.log('hi')

Python with additional file specific custom header

The command to run:

add-header \
  --header-filepath path/to/header.txt \
  --stop-at-ignore-below \
  filepath1.py filepath2.py

Outputs a header like this:

# this is the header comment
# this is another line of the header comment
# header ends here, ignore below
# This is a custom comment at the top of the file that is not modified by the pre-commit hook
import os

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

add_header_comment-1.0.1.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

add_header_comment-1.0.1-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file add_header_comment-1.0.1.tar.gz.

File metadata

  • Download URL: add_header_comment-1.0.1.tar.gz
  • Upload date:
  • Size: 6.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for add_header_comment-1.0.1.tar.gz
Algorithm Hash digest
SHA256 8702519af634c134d1ee77f91a6cfdf005876bd971d92ab05708e573982b7398
MD5 5070f7b8792d8c5b332b0c260cda98ea
BLAKE2b-256 951d101cc164835428d639b9fc889aecdf99d9658bcf9af128ae2723f88d8997

See more details on using hashes here.

File details

Details for the file add_header_comment-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for add_header_comment-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 851157022b5f5295bd90c1bfda4736ec86255fe3a495ff0463db6e9e22dc52c6
MD5 0eaa62076c939b5305c05bb260acfdf4
BLAKE2b-256 bd7ce46e19f3b0186f34fdcb2450c3a16b22fbe627de9ca3b3fe3f2c509f696b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page