Top Related Projects
🤫 Easy access to gitignore boilerplates
Quick Overview
The github/gitignore repository is a collection of useful .gitignore templates maintained by GitHub. It provides a comprehensive set of gitignore files for various programming languages, frameworks, and development environments, helping developers easily set up their projects to ignore unnecessary files and directories in Git repositories.
Pros
- Extensive collection of gitignore templates for numerous technologies
- Regularly updated and maintained by the community
- Easy to use and integrate into projects
- Saves time and reduces errors in setting up Git repositories
Cons
- May include unnecessary patterns for some specific use cases
- Requires manual selection and customization for each project
- Can become outdated if not regularly maintained
- May not cover all edge cases or specialized development environments
Getting Started
To use a gitignore template from this repository:
- Visit the github/gitignore repository: https://github.com/github/gitignore
- Find the appropriate template for your project (e.g., Python.gitignore for Python projects)
- Copy the contents of the template
- Create a new file named
.gitignore
in the root of your project - Paste the copied contents into the
.gitignore
file - Customize the file as needed for your specific project requirements
Alternatively, you can use GitHub's web interface to create a new repository and select a gitignore template during the creation process.
Competitor Comparisons
🤫 Easy access to gitignore boilerplates
Pros of gibo
- Command-line tool for easy .gitignore file generation
- Allows for combining multiple templates
- Supports custom template repositories
Cons of gibo
- Requires installation and setup
- Limited to command-line interface
- May not always have the most up-to-date templates
Code Comparison
gitignore:
# Compiled source #
###################
*.com
*.class
*.dll
*.exe
*.o
*.so
gibo:
$ gibo dump Python Node > .gitignore
Both repositories aim to provide .gitignore templates, but they differ in their approach. gitignore is a collection of templates that can be manually copied, while gibo is a tool that generates .gitignore files from these templates.
gitignore offers a wide range of templates directly accessible on GitHub, making it easy to browse and copy. It's maintained by GitHub, ensuring regular updates and contributions from the community.
gibo, on the other hand, provides a command-line interface for generating .gitignore files. It allows users to combine multiple templates and even use custom repositories. However, it requires installation and may not always have the most recent updates compared to the main gitignore repository.
In terms of usage, gitignore involves manual copying of template content, while gibo automates the process through command-line operations. The choice between the two depends on user preference for manual control versus automation and command-line usage.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
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:
- The Ignoring Files chapter of the Pro Git book.
- The Ignoring Files article on the GitHub Help site.
- The gitignore(5) manual page.
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.
Include details when opening 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 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:
- Fork this project to your account.
- Create a branch for the change you intend to make.
- Make your changes to your fork.
- Send a pull request from your forkâs 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
Top Related Projects
🤫 Easy access to gitignore boilerplates
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot