5 releases (3 breaking)
| 0.4.0 | Jul 30, 2025 |
|---|---|
| 0.3.1 | Dec 29, 2024 |
| 0.3.0 | Dec 24, 2024 |
| 0.2.0 | Dec 13, 2024 |
| 0.1.0 | Dec 9, 2024 |
#604 in Command line utilities
25KB
323 lines
Gitignore to Megaignore converter
This is a simple tool to convert a .gitignore file to a .megaignore file. The .megaignore file is used by the Mega cloud storage service to exclude files from being uploaded to the cloud much like the .gitignore file is used to exclude files from being tracked by git.
You can read more about the .megaignore file format here.
The changelog is available here.
Installation
Cargo
Make sure you have Rust installed.
You can then install git2megaignore using cargo:
cargo install git2megaignore
Precompiled binaries
If you don't have Rust installed, you can download precompiled binaries from the releases page.
Usage example
# go to a directory with a .gitignore file
$ cd example
# or create a new .gitignore file
$ echo "*.txt
foo/
/[Bb]uild/
src/**/index.js
\!src/index.js" > .gitignore
# convert the .gitignore file to a .megaignore file
$ git2megaignore -em
resulting .megaignore file:
+sync:.megaignore
-nG:*.txt
-dnG:foo
-dpR:^[Bb]uild$
-pR:^src/(.*/)?index\.js$
+pG:src/index.js
sync:.megaignoreis a special rule that tells Mega to sync the.megaignorefile itself, this was added with the-moption+prefix means that the rule is an include rule-prefix means that the rule is an exclude rulenoption means that the rule should be applied to the file name, not the whole pathpoption means that the rule should be applied to the path of the file, not the file namedoption means that the rule targets directories only, otherwise it targets everythingGoption means that the rule is a case-sensitive glob patternRoption means that the rule is a case-sensitive regex pattern- for more information about the rule format, see the Mega help page
Other usage examples
# take input from stdin and write to stdout
# -e, --no-extras do not add extra header and footer lines
# -p, --print print to stdout
# -v, --verbose <VERBOSE> set verbosity level (0-4)
$ echo "foo/**/bar" | git2megaignore -ep -v=0
-pR:^foo/(.*/)?bar$
# copy .gitignore lines when converting to .megaignore
# -c --copy copy .gitignore lines to the .megaignore file
$ echo "/[Ll]ibrary/" | git2megaignore -c -ep -v=0
# from /[Ll]ibrary/
-dpR:^[Ll]ibrary$
# run from other directory
# this will read the .gitignore file from the specified directory
# and write the .megaignore file to the same directory
git2megaignore ~/path/to/repo
# specify input and output files explicitly
git2megaignore -i ../.gitignore -o /tmp/.megaignore
Options
Convert a .gitignore file to a .megaignore file
Usage: git2megaignore [OPTIONS] [DIRECTORY]
Arguments:
[DIRECTORY] directory to start searching for .gitignore files [default: ]
Options:
-m, --sync-megaignore sync the .megaignore file with the +sync:.megaignore rule
-c, --copy If `true`, every .gitignore line will be copied to the .megaignore file as **a comment**
-e, --no-extras the header and footer will not be added to the .megaignore file
-x, --force-regexp Force the use of the Regex <STRATEGY> for all rules, even if the glob pattern does not require it
-I, --ignore-case .megaignore rules will be case insensitive
-i, --input <FILE> Input file to read .gitignore rules from, defaults to .gitignore in the current directory
-o, --output <FILE> Output file to write .megaignore rules to, defaults to .megaignore in the current directory
-p, --print print the generated .megaignore file to STDOUT
-v, --verbose <VERBOSE> Set the level of verbosity from 0 (off) to 4 (debug) [default: 2]
-h, --help Print help
-V, --version Print version
Mass conversion
you can run the following bash script to convert all .gitignore files in the subdirectories of the current directory to .megaignore files:
find . -name .gitignore -execdir git2megaignore \;
for windows, you can use the following powershell script:
Get-ChildItem -Recurse -Filter .gitignore | ForEach-Object { git2megaignore $_.DirectoryName }
Dependencies
~1.2–2MB
~35K SLoC