Skip to content
This repository has been archived by the owner on May 9, 2022. It is now read-only.

Latest commit

 

History

History
57 lines (37 loc) · 3.78 KB

CONTRIBUTING.md

File metadata and controls

57 lines (37 loc) · 3.78 KB

Contributing

Project Scope

Picturefill aims to polyfill the standard features of the picture element and related srcset, sizes, type, and media attributes (some of which work on img elements without a picture parent as well). Issues and contributions that fall outside of this scope are not likely to be accepted by the project. Some exceptions include workarounds that improve browser support for standard features.

Code License

Picturefill is an open source project falling under the MIT License. By using, distributing, or contributing to this project, you accept and agree that all code within the Picturefill project are licensed under MIT license.

Working on Picturefill

Issue Discussion

General Picturefill discussion takes place in Slack, at http://picturefill.slack.com. To join, send an email to picturefill at ricg.io. Discussion of issues pretaining to the responsive images specifications takes place in the RICG IRC channel and issue tracker.

You can connect to the Picturefill Slack channel via IRC (SSL enabled).

Modifying the code

First, ensure that you have the latest Node.js and npm installed.

Test that Grunt's CLI is installed by running grunt --version. If the command isn't found, run npm install -g grunt-cli. For more information about installing Grunt, see the getting started guide.

  1. Fork and clone the repo.
  2. Run npm install to install all dependencies (including Grunt).
  3. Run grunt to grunt this project.

Assuming that you don't see any red, you're ready to go. Just be sure to run grunt after making any changes, to ensure that nothing is broken.

Development Workflow

  1. If no issue already exists for the work you’ll be doing, create one to document the problem(s) being solved and self-assign.
  2. Create a new branch—please don't work in your master branch directly. We reccomend naming the branch to match the issue being addressed (issue-777).
  3. Add failing tests for the change you want to make. Run grunt to see the tests fail.
  4. Fix stuff.
  5. Run grunt to see if the tests pass. Repeat steps 2-4 until done.
  6. Open test/*.html unit test file(s) in actual browsers to ensure tests pass everywhere.
  7. Update the documentation to reflect any changes.
  8. Push to your fork or push your issue-specific branch to the main repo, then submit a pull request against master.
  9. Once tested and +1’d by another team member (with no outstanding objections), self-merge into master.

Versioning

The rules of semver don’t necessarily apply here in the case of major releases (as a polyfill for a stable spec, we shouldn’t have breaking changes), so we’re using the following:

  1. MAJOR versions at maintaners’ discretion following significant changes to the codebase (e.g. refactoring core)
  2. MINOR versions for backwards-compatible enhancements (e.g. performance improvements)
  3. PATCH versions for backwards-compatible bug fixes (e.g. spec compliance bugs, support issues)

Important notes

Please don't edit files in the dist subdirectory as they are generated via Grunt. You'll find source code in the src subdirectory!

Code style

Regarding code style like indentation and whitespace, follow the conventions you see used in the source already.

PhantomJS

While Grunt can run the included unit tests via PhantomJS, this shouldn't be considered a substitute for the real thing. Please be sure to test the test/*.html unit test file(s) in actual browsers.