Add Copyright or License text to the Source Files Recursively
Recently I was assigned to the task of adding a
After looking into the responses for a while, I felt the need of bringing things together to create a small tool that does following:
- Ability to add a block of text(Copyright, License, Any Generic Comment etc) to the top of the Source Code(or any target files).
- Ability to read the block of text from a file and add to the Source Code.
- Do not update the Source Code file with the Copyright/License content if it present already.
- Add the Copyright content to the files recursively.
- Ability to ignore certain folders while adding the content to the Source Files. This was important because, I didn't want to add my organization's Copyright note into the Source Code of any external libraries like, reactJs.
Meet the Tool
add-copyright is able to meet all the requirements mentioned above with few limitations that we will see at the end.
You can clone the repo and use it from here:
The main files of the tool are followings,
copyright.txt: An input file where you keep the text block(Copyright/License text) to apply on your Source Code.
addcopyright.sh: The Script file which is responsible for adding the text block to the target Source Code.
Command to Run
find <SOURCE_CODE_DIRECTIRY> -type d -name "<EXCLUDE_DIRECTORY>" -prune -o -name "*.js" -print0 | xargs -0 ./addcopyright.sh
Where the <SOURCE_CODE_DIRECTIRY> is the path of your source code. Where the <EXCLUDE_DIRECTORY> is the directory to exclude if it exists under <SOURCE_CODE_DIRECTIRY> for updating the Copyright information.
For example, running the tool on the JsvaScript Source Code under the folder
/opt/atapas/code by excluding the folder
node_modules, use this command,
find /opt/atapas/code -type d -name "node_modules" -prune -o -name "*.js" -print0 | xargs -0 ./addcopyright.sh
You can ignore multiple folders in single command and can use on different types of Source Code files. Please go through the Readme documentation for more details.
Here is the output of running the command,
Few Limitations included:
- This tool can only be run from a Linux Bash Shell. For running it from windows use any bash shell like GitBash.
copyright.txtshould be changed according to the mult-line comment format. For example,
/* This is a comment */
- For HTML(.htm or .html) file the format should be,
<!-- This is a HTML Comment -->
Last few words..
I hope the tool will be useful to many of you as it was to me. Please like/share(👍) this post and give a star(⭐) to my project in GitHub. If you are willing to contribute to it in any form, you are most welcome!
There could be various other ways(may be better one too) to achieve the same goal. Please feel free to share in the comment section.