Skip to content

Latest commit

 

History

History
199 lines (130 loc) · 7.69 KB

CONTRIBUTING.md

File metadata and controls

199 lines (130 loc) · 7.69 KB

Contributing Guidelines

Thank you for considering a contribution to the yagpdb-cc plugin for Vim. To get you started, here are a few guidelines we would like you to follow:

Code of Conduct

By participating within this project and its repositories, you agree to abide by our Code of Conduct.

Got a Question?

Please do not open issues for general support such as "how to install this plugin" as we want to keep this issue tracker for bug reports and feature requests. Instead, we suggest you use the search engine of your choice, as there are several good guides on how to install plugins.

As a shortcut, we can recommend pathogen.

To save your and our time, we will systematically close issues regarding general support. Issues regarding this repository (so-called "meta" issues) are excluded from this rule.

Found a Bug?

If you find a bug in the code, you can help us by submitting an issue. Or, better, submit a pull request with a fix readily available!

Missing a feature?

You can request a new feature by submitting an issue to the issue tracker. If you would like to implement a new feature, please consider the impact it would have on the codebase:

  • For a major impact affecting multiple files, adding wholly new topics and sections to the documentation, etc.: please open an issue first, outlining your proposal so that it can be discussed. This allows us to better coordinate our resources around your proposal and help you in crafting your contribution.

  • Small features can be put together and directly submitted as a Pull Request.

Submission Guidelines

Submitting an Issue

Before you submit a new issue, please search the issue tracker, maybe an issue relating to your problem already exists, and the discussion might inform you of fixes readily available.

We want to fix all the issues as soon as possible, but before fixing a bug we need to reproduce and confirm it. In order to reproduce bugs, we require that you provide a minimal reproduction. Having a minimal reproducible scenario gives us a wealth of important information without going back and forth to you with additional questions.

A minimal reproduction allows us to quickly confirm a bug (or point out a coding problem) as well as confirm that we are fixing the right problem. Often, developers find coding problems themselves while preparing a minimal reproduction.

Unfortunately, we are not able to investigate / fix bugs without a minimal reproduction, so if we don't hear back from you, we are going to close an issue that doesn't have enough info to be reproduced.

You can file new issues by selecting from our new issue templates and filling out the issue template.

Submitting a Pull Request (PR)

Before you submit your Pull Request, follow these steps:

  1. Search GitHub for an open or closed PR that relates to your submission. You wouldn't want to duplicate existing efforts.

  2. Be sure that an issue describes the problem you're fixing, or documents the design for the feature you're adding. Discussing the design upfront helps to ensure that we're ready to accept your work.

  3. Fork and then clone your fork.

  4. Load in the clone of your fork via the plugin loader of your choice.

  5. In your cloned repository, make your changes in a new branch:

    git checkout -b my-branch master
  6. Make your changes, including tests when appropriate. Please refer to test/README.md for a guide.

  7. Make sure the tests are still passing locally. We use vader.vim as our testing framework. Run the tests using make test.

  8. Follow the current coding style as close as possible. Simply take a look at other files and stick to their styling.

  9. Commit your changes using a descriptive commit message following our commit message conventions.

  10. Push your branch to GitHub:

    git push origin my-branch
  11. On GitHub, send a pull request to l-zeuch:master.

Reviewing a Pull Request

We reserve the right not to accept pull requests from community members who haven't been good citizens of the community; such behaviour includes not following the Code of Conduct and applies within or outside this project's scope.

Addressing review feedback

If we ask for changes via code reviews then:

  1. Make the required updates to the code.

  2. Push the new changes to your repository (this will update your Pull Request as well)

    git push --force-with-lease

After your pull request is merged

After your PR is merged, you can safely delete your branch and pull the changes from the upstream repository.

Commit Message Format

Formatting commit messages according to a specification makes it easier to read commit history.

Each commit message consists of a header, a body, and a footer:

<header>
<blank line>
<body>
<blank line>
<footer>

The header is mandatory and must conform to the commit header format.

The body is mandatory. The commit body structure describes how it should be used.

The footer is optional. The commit footer format describes what the footer is used for.

Commit Message Header

<scope>: <short summary>
   |           |
   |           └─> Summary in present tense. Not capitalized. No period at the end.
   |
   └─> Commit Scope: Where did this commit happen?
         e.g. docs, syntax, folding, keybinds, github, legal, ...

Scope

The scope should be descriptive. If your commit contained multiple scopes, split them up appropriately and consider individual pull requests should they not depend on each other.

Summary

Use the summary field to provide a succinct description of the change:

  • use the imperative, present tense: "change" not "changed" nor "changes"
  • don't capitalize the first letter
  • no dot (.) at the end

Commit Message Body

Just as in the summary, use the imperative, present tense: "fix" not "fixed" nor "fixes".

Explain the motivation for the change in the commit message body. This commit message should explain why you are making the change. You can include a comparison of the previous behavior with the new behavior in order to illustrate the impact of the change.

Commit Message Footer

The footer can contain information about breaking changes (if any) and is also the place to reference GitHub issues and other PRs that this commit closes or is related to, as well as Co-Authors:

BREAKING CHANGE: <breaking change summary>
<blank line>
<breaking change description + migrate instructions>
<blank line>
<blank line>
Fixes #<issue number>
<blank line>
<blank line>
Co-authored-by: name <[email protected]>

Revert commits

If the commit reverts a previous commit, it should begin with revert:, followed by the header of the reverted commit.

The content of the commit message body should contain:

  • information about the SHA of the commit being reverted in the following format: This reverts commit <SHA>,
  • a clear description of the reason for reverting the commit message.