A collection of useful .gitignore templates
Find a file
Daniel Johnson dcc0fc7bc2
Merge pull request #4700 from G0rocks/main
Add FreeCAD.gitignore file
2026-05-21 16:49:32 -07:00
.github
community Add *.FCBak to FreeCAD.gitignore 2026-05-03 16:26:41 +00:00
Global Merge pull request #4827 from arllemfarias/patch-1 2026-05-15 16:07:29 -07:00
Actionscript.gitignore
Ada.gitignore
AdventureGameStudio.gitignore
Agda.gitignore
AL.gitignore
Android.gitignore
Angular.gitignore
AppceleratorTitanium.gitignore
AppEngine.gitignore
ArchLinuxPackages.gitignore
Autotools.gitignore
Ballerina.gitignore
bun.gitignore
C++.gitignore Remove empty line in .gitignore 2026-05-10 17:09:15 +08:00
C.gitignore
CakePHP.gitignore
CFWheels.gitignore
ChefCookbook.gitignore
Clojure.gitignore
CMake.gitignore
CodeIgniter.gitignore
CommonLisp.gitignore
Composer.gitignore
Concrete5.gitignore
CONTRIBUTING.md
Coq.gitignore
CraftCMS.gitignore
CUDA.gitignore
D.gitignore
Dart.gitignore
Delphi.gitignore
Deno.gitignore
DM.gitignore
Dotnet.gitignore
Drupal.gitignore
Eagle.gitignore
ecu.test.gitignore
Elisp.gitignore
Elixir.gitignore
Elm.gitignore
EPiServer.gitignore
Erlang.gitignore
ExpressionEngine.gitignore
ExtJs.gitignore
Fancy.gitignore
Finale.gitignore
Firebase.gitignore
FlaxEngine.gitignore
Flutter.gitignore
ForceDotCom.gitignore
Fortran.gitignore
FuelPHP.gitignore
Gcov.gitignore
GitBook.gitignore
GitHubPages.gitignore
Gleam.gitignore
Go.gitignore
Godot.gitignore
Gradle.gitignore
Grails.gitignore
GWT.gitignore
Haskell.gitignore
Haxe.gitignore
HIP.gitignore fix: avoid using trailing comments as gitignore doesn't support them 2026-04-23 15:34:42 +03:00
IAR.gitignore
Idris.gitignore
IGORPro.gitignore
Java.gitignore
JBoss.gitignore
Jekyll.gitignore
JENKINS_HOME.gitignore
Joomla.gitignore
Julia.gitignore
Katalon.gitignore
KiCad.gitignore
Kohana.gitignore
Kotlin.gitignore
LabVIEW.gitignore
LangChain.gitignore
Laravel.gitignore
Lasal.gitignore
Lean.gitignore
Leiningen.gitignore
LemonStand.gitignore
LICENSE
Lilypond.gitignore
Lithium.gitignore
Lua.gitignore
Luau.gitignore
Magento.gitignore
Maven.gitignore
Mercury.gitignore
MetaProgrammingSystem.gitignore
Modelica.gitignore
ModelSim.gitignore
MoonBit.gitignore fix: Fix comment style issues 2026-04-27 15:21:45 +08:00
Nanoc.gitignore
Nestjs.gitignore
Nextjs.gitignore
Nim.gitignore
Nix.gitignore
Node.gitignore
Objective-C.gitignore
OCaml.gitignore
Opa.gitignore
OpenCart.gitignore
OracleForms.gitignore
Packer.gitignore
Perl.gitignore
Phalcon.gitignore
PlayFramework.gitignore
Plone.gitignore
Prestashop.gitignore
Processing.gitignore
PureScript.gitignore
Python.gitignore Merge pull request #4731 from gsilvan/main 2026-04-24 14:32:31 -07:00
Qooxdoo.gitignore
Qt.gitignore
R.gitignore
Racket.gitignore
Rails.gitignore
Raku.gitignore
README.md Fix grammar and improve clarity in README 2026-04-23 14:00:16 +05:30
ReScript.gitignore
RhodesRhomobile.gitignore
ROS.gitignore
Ruby.gitignore
Rust.gitignore Update Rust.gitignore to include rustc-ice files 2026-04-23 08:34:45 -07:00
Salesforce.gitignore
Sass.gitignore
Scala.gitignore
Scheme.gitignore
SCons.gitignore
Scrivener.gitignore
Sdcc.gitignore
SeamGen.gitignore
SketchUp.gitignore
Smalltalk.gitignore
Solidity-Remix.gitignore
SolidWorks.gitignore
SSDT-sqlproj.gitignore
Stella.gitignore
SugarCRM.gitignore
Swift.gitignore
Symfony.gitignore
SymphonyCMS.gitignore
Terraform.gitignore
TestComplete.gitignore
TeX.gitignore
Textpattern.gitignore
TurboGears2.gitignore
TwinCAT3.gitignore
Typo3.gitignore
Unity.gitignore Merge pull request #4780 from SzymonHalucha/patch-1 2026-04-20 13:27:12 -07:00
UnrealEngine.gitignore
VBA.gitignore
VisualStudio.gitignore
VVVV.gitignore
Waf.gitignore
WordPress.gitignore Fix lowercase letter in WordPress.gitignore comment 2026-04-24 12:06:30 +09:00
Xojo.gitignore
Yeoman.gitignore
Yii.gitignore
ZendFramework.gitignore
Zephir.gitignore
Zig.gitignore

A collection of .gitignore templates

This is GitHubs 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 projects that 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?

First and foremost, a template contribution must adhere to our Contributing Guidelines.

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.

Include details when opening a pull request if the template is important and visible. 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 cant 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, its not because its not awesome.

Contributing guidelines

Please see our Contributing Guidelines.

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

Heres 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 forks branch to our main 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.