You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Miklós Márton 1ee3d754b3 Add *.creator.user* files to the Qt .gitignore 5 lat temu
.github Trim trailing whitespace 6 lat temu
Global Merge pull request #2905 from marcusolini/netbeans-gen-files 5 lat temu
community Update CodeSniffer.gitignore 5 lat temu
.travis.yml stub a placeholder Travis config 5 lat temu
Actionscript.gitignore Fix comments on same line causing ignore to break 6 lat temu
Ada.gitignore ensure single trailing newline 10 lat temu
Agda.gitignore Create Agda.gitignore 10 lat temu
Android.gitignore Merge pull request #2927 from Yousha/master 5 lat temu
AppEngine.gitignore Added template for Google App Engine 9 lat temu
AppceleratorTitanium.gitignore Added Appcelerator Titanium .gitignore file. 11 lat temu
ArchLinuxPackages.gitignore Add .jar, .exe and .msi 9 lat temu
Autotools.gitignore Add configure logs 5 lat temu
C++.gitignore added prerequisites for C and C++ 7 lat temu
C.gitignore Update C.gitignore 7 lat temu
CFWheels.gitignore add cfwheels gitignore 13 lat temu
CMake.gitignore Ignore CMake FetchContent directory 5 lat temu
CONTRIBUTING.md Trim trailing whitespace 6 lat temu
CUDA.gitignore Add CUDA.gitignore 9 lat temu
CakePHP.gitignore Update CakePHP.gitignore 8 lat temu
ChefCookbook.gitignore Remove lockfiles from Chef template 10 lat temu
Clojure.gitignore Add .gitignore for Leiningen projects 13 lat temu
CodeIgniter.gitignore Merge branch 'master' into codeigniter3update 7 lat temu
CommonLisp.gitignore Update CommonLisp.gitignore 7 lat temu
Composer.gitignore Fix link to go to current anchor 6 lat temu
Concrete5.gitignore Added .htaccess to concrete5 gitignore 8 lat temu
Coq.gitignore Add mllib, mlpack files 7 lat temu
CraftCMS.gitignore Craft: update to follow official recs; add 'not necessary in v3' note 5 lat temu
D.gitignore Update D.gitignore 8 lat temu
DM.gitignore ensure single trailing newline 10 lat temu
Dart.gitignore remove Jetbrain and MacOS related values 6 lat temu
Delphi.gitignore Update Delphi.gitignore 5 lat temu
Drupal.gitignore update header for Drupal template 5 lat temu
EPiServer.gitignore ensure single trailing newline 10 lat temu
Eagle.gitignore Eagle: Remove duplicate entry 5 lat temu
Elisp.gitignore add final newline 7 lat temu
Elixir.gitignore ignore files generated by ElixirLS 5 lat temu
Elm.gitignore Ignore elm-stuff project-wide 7 lat temu
Erlang.gitignore Update Erlang.gitignore 7 lat temu
ExpressionEngine.gitignore Merge pull request #488 from nanadevelopment/eeConfigAdd 10 lat temu
ExtJs.gitignore Adds some files 6 lat temu
Fancy.gitignore ensure single trailing newline 10 lat temu
Finale.gitignore ensure single trailing newline 10 lat temu
ForceDotCom.gitignore ensure single trailing newline 10 lat temu
Fortran.gitignore Link a new fortran template to existing c++ one 9 lat temu
FuelPHP.gitignore update FuelPHP.gitignore 9 lat temu
GWT.gitignore GWT: Remove duplicate entry 5 lat temu
Gcov.gitignore Capitalise initial letter in template filenames for consistency/sorting 9 lat temu
GitBook.gitignore Correct URL for NPM URL reference 9 lat temu
Go.gitignore [Go] Fix typo in comment 5 lat temu
Godot.gitignore remove system specific ignores. 6 lat temu
Gradle.gitignore Only ignore the build directory in the same directory as .gitignore for Gradle 7 lat temu
Grails.gitignore Adding additional comments 9 lat temu
Haskell.gitignore Add cabal.project.local~ to Haskell.gitignore (#2479) 6 lat temu
IGORPro.gitignore Create IGORPro.gitignore 9 lat temu
Idris.gitignore Add an Idris gitignore 10 lat temu
JBoss.gitignore correct capitalization problems and add Octave which link to MATLAB 5 lat temu
Java.gitignore Added NiFi .nar files 6 lat temu
Jekyll.gitignore Update Jekyll.gitignore (#2540) 6 lat temu
Joomla.gitignore Joomla: don't ignore .gitignore 6 lat temu
Julia.gitignore Julia: ignore deps/deps.jl 8 lat temu
KiCad.gitignore KiCad .gitignore library fix 5 lat temu
Kohana.gitignore ensure single trailing newline 10 lat temu
Kotlin.gitignore Symlink Kotlin.gitignore to Java.gitignore 8 lat temu
LICENSE Use the exact CC-0 license text 7 lat temu
LabVIEW.gitignore Ignore the .cache folder for LabVIEW projects 6 lat temu
Laravel.gitignore Only ignore root vendor directory 5 lat temu
Leiningen.gitignore Update .gitignore with .cpcache 6 lat temu
LemonStand.gitignore ensure single trailing newline 10 lat temu
Lilypond.gitignore Add ignore file for lilypond. 13 lat temu
Lithium.gitignore The Lithium app should be the root repo folder 11 lat temu
Lua.gitignore Added a .gitignore template for Lua based projects. 9 lat temu
Magento.gitignore Remove patch files from repo 5 lat temu
Maven.gitignore maven-wrapper.jar should be ignored 5 lat temu
Mercury.gitignore Mercury.gitignore: Add Mercury.modules 9 lat temu
MetaProgrammingSystem.gitignore Grammar/formatting tweak to comments 10 lat temu
Nanoc.gitignore Nanoc: Ignore tmp/nanoc/, not tmp/ 6 lat temu
Nim.gitignore Create Nim.gitignore 9 lat temu
Node.gitignore Merge pull request #2908 from lmedson/env_test_ignore 5 lat temu
OCaml.gitignore Update OCaml.gitignore 6 lat temu
Objective-C.gitignore Update Objective-C.gitignore 5 lat temu
Opa.gitignore Added Opa.gitignore 12 lat temu
OpenCart.gitignore excluding vqmod cache files and logs 7 lat temu
OracleForms.gitignore added gitignore for Oracle Forms development 12 lat temu
Packer.gitignore Add a support for packer 10 lat temu
Perl.gitignore spelling: utils 6 lat temu
Perl6.gitignore A new template for Perl 6 7 lat temu
Phalcon.gitignore Remove trailing asterisks in Phalcon rules 10 lat temu
PlayFramework.gitignore Added /project/project to PlayFramework.gitignore 7 lat temu
Plone.gitignore Covered by global vim template 10 lat temu
Prestashop.gitignore Update Prestashop.gitignore 7 lat temu
Processing.gitignore Add ignore rules for Linux ARM exports 5 lat temu
PureScript.gitignore Added .gitignore for PureScript 8 lat temu
Python.gitignore Add pip-wheel-metadata to Python.gitignore 5 lat temu
Qooxdoo.gitignore Add gitignore for qooxdoo apps 13 lat temu
Qt.gitignore Add *.creator.user* files to the Qt .gitignore 5 lat temu
R.gitignore remove rsconnect folder from R.gitignore 5 lat temu
README.md Update README.md 5 lat temu
ROS.gitignore Added ignore for files created by `catkin_make_isolated` 6 lat temu
Rails.gitignore Ignore public/assets in Rails .gitignore 5 lat temu
RhodesRhomobile.gitignore Add Rhodes mobile application framework gitignore 13 lat temu
Ruby.gitignore Update Ruby.ignore to ignore .byebug_history file 5 lat temu
Rust.gitignore Update documentation link cargo.toml vs cargo.lock 6 lat temu
SCons.gitignore Added SCons.gitignore 10 lat temu
Sass.gitignore Add all sourcemap file formats 6 lat temu
Scala.gitignore [Scala] remove external tools excludes. 7 lat temu
Scheme.gitignore Add Scheme.gitignore 8 lat temu
Scrivener.gitignore Added .gitignore for Scrivener 10 lat temu
Sdcc.gitignore ensure single trailing newline 10 lat temu
SeamGen.gitignore Update SeamGen.gitignore 11 lat temu
SketchUp.gitignore Add gitignore for sketchup backup files. 12 lat temu
Smalltalk.gitignore Merge pull request #2027 from rejurime/dolphin-smalltalk 5 lat temu
Stella.gitignore Capitalise initial letter in template filenames for consistency/sorting 9 lat temu
SugarCRM.gitignore ensure the following ! rules are included 7 lat temu
Swift.gitignore Update Swift.gitignore 5 lat temu
Symfony.gitignore Ignore logs for Symfony4 5 lat temu
SymphonyCMS.gitignore added symphony and workspace/uploads dir 12 lat temu
TeX.gitignore [TeX] Ignore generated files by 'vhistory' package 5 lat temu
Terraform.gitignore Minor imporvements to terraform ignore file 5 lat temu
Textpattern.gitignore Added Textpattern gitignore 12 lat temu
TurboGears2.gitignore Add for TurboGears2 (based off of Python template) 13 lat temu
Typo3.gitignore Merge pull request #1646 from josefglatz/TYPO3-improvements 5 lat temu
Umbraco.gitignore Trim trailing whitespace 6 lat temu
Unity.gitignore Unity: Never ignore asset meta data 5 lat temu
UnrealEngine.gitignore Revert "add the *.VC.db to unreal engine ignore" 5 lat temu
VVVV.gitignore ensure single trailing newline 10 lat temu
VisualStudio.gitignore Remove trailing whitespace added last commit. 5 lat temu
Waf.gitignore Waf: Be more explicit in patterns 8 lat temu
WordPress.gitignore Added Must Use Plugins to gotignore (#2553) 6 lat temu
Xojo.gitignore Ignores *.xojo_uistate 9 lat temu
Yeoman.gitignore Create Yeoman.gitignore 10 lat temu
Yii.gitignore Merge remote-tracking branch 'origin/master' into pr/506 10 lat temu
ZendFramework.gitignore Remove double-spaced lines 6 lat temu
Zephir.gitignore Added comments for Zephir 10 lat temu

README.md

A collection of .gitignore templates

This is GitHub’s collection of .gitignore file templates. We use this list to populate the .gitignore template choosers available in the GitHub.com interface when creating new repositories and files.

For more information about how .gitignore files work, and how to use them, the following resources are a great place to start:

Folder structure

We support a collection of templates, organized in this way:

  • the root folder contains templates in common use, to help people get started with popular programming languages and technologies. These define a meaningful set of rules to help get started, and ensure you are not committing unimportant files into your repository
  • Global contains templates for various editors, tools and operating systems that can be used in different situations. It is recommended that you either add these to your global template or merge these rules into your project-specific templates if you want to use them permanently.
  • community contains specialized templates for other popular languages, tools and project, which don’t currently belong in the mainstream templates. These should be added to your project-specific templates when you decide to adopt the framework or tool.

What makes a good template?

A template should contain a set of rules to help Git repositories work with a specific programming language, framework, tool or environment.

If it’s not possible to curate a small set of useful rules for this situation, then the template is not a good fit for this collection.

If a template is mostly a list of files installed by a particular version of some software (e.g. a PHP framework), it could live under the community directory. See versioned templates for more details.

If you have a small set of rules, or want to support a technology that is not widely in use, and still believe this will be helpful to others, please read the section about specialized templates for more details.

If you believe your template is important and should be highly visible, please add details about the impact of the technology when you open a pull request. We may not accept it immediately, but we can promote it to the root at a later date based on interest.

Please also understand that we can’t list every tool that ever existed. Our aim is to curate a collection of the most common and helpful templates, not to make sure we cover every project possible. If we choose not to include your language, tool, or project, it’s not because it’s not awesome.

Contributing guidelines

We’d love for you to help us improve this project. To help us keep this collection high quality, we request that contributions adhere to the following guidelines.

  • Provide a link to the application or project’s homepage. Unless it’s extremely popular, there’s a chance the maintainers don’t know about or use the language, framework, editor, app, or project your change applies to.

  • Provide links to documentation supporting the change you’re making. Current, canonical documentation mentioning the files being ignored is best. If documentation isn’t available to support your change, do the best you can to explain what the files being ignored are for.

  • Explain why you’re making a change. Even if it seems self-evident, please take a sentence or two to tell us why your change or addition should happen. It’s especially helpful to articulate why this change applies to everyone who works with the applicable technology, rather than just you or your team.

  • Please consider the scope of your change. If your change is specific to a certain language or framework, then make sure the change is made to the template for that language or framework, rather than to the template for an editor, tool, or operating system.

  • Please only modify one template per pull request. This helps keep pull requests and feedback focused on a specific project or technology.

In general, the more you can do to help us understand the change you’re making, the more likely we’ll be to accept your contribution quickly.

Versioned templates

Some templates can change greatly between versions, and if you wish to contribute to this repository we need to follow this specific flow:

  • the template at the root should be the current supported version
  • the template at the root should not have a version in the filename (i.e. “evergreen”)
  • previous versions of templates should live under community/
  • previous versions of the template should embed the version in the filename, for readability

This helps ensure users get the latest version (because they’ll use whatever is at the root) but helps maintainers support older versions still in the wild.

Specialized templates

If you have a template that you would like to contribute, but it isn’t quite mainstream, please consider adding this to the community directory under a folder that best suits where it belongs.

The rules in your specialized template should be specific to the framework or tool, and any additional templates should be mentioned in a comment in the header of the template

For example, this template might live at community/DotNet/InforCRM.gitignore:

# gitignore template for InforCRM (formerly SalesLogix)
# website: https://www.infor.com/product-summary/cx/infor-crm/
#
# Recommended: VisualStudio.gitignore

# Ignore model files that are auto-generated
ModelIndex.xml
ExportedFiles.xml

# Ignore deployment files
[Mm]odel/[Dd]eployment

# Force include portal SupportFiles
!Model/Portal/*/SupportFiles/[Bb]in/
!Model/Portal/PortalTemplates/*/SupportFiles/[Bb]in

Contributing workflow

Here’s how we suggest you go about proposing a change to this project:

  1. Fork this project to your account.
  2. Create a branch for the change you intend to make.
  3. Make your changes to your fork.
  4. Send a pull request from your fork’s branch to our master branch.

Using the web-based interface to make changes is fine too, and will help you by automatically forking the project and prompting to send a pull request too.

License

CC0-1.0.