Files
shields/CONTRIBUTING.md
Paul Melnikow cca46b7e94 Generate index.html only on gh-pages when deploying
- Build index.html at deploy time
- Update corresponding documentation references
- Since index.html is untracked, git add needs -f
- Clarify gh-pages generated commit message
- Improve Makefile dependencies related to website generation

As discussed in #936, tracking the index.html causes makes PRs longer / noisier
and causes extra merge conflicts. More importantly, it causes contributors to
inadvertently edit the wrong file, which causes extra work (#949) or
contributions to be lost (#898).

Since there's no need for index.html in development (everything uses try.html) a
logical solution is to generate and commit the index.html at deploy time.

Recording compiled or generated files in a deploy commit is a reasonable
practice for git-based deploys (Heroku, gh-pages, and others).

The old version of this was slightly "unsafe" for my taste, in that it depended
on the local copy of gh-pages (if it existed) and master. The new version just
replaces gh-pages with master + the new commit.

Closes #936.

Fixes #954 (the PR).
2017-04-25 23:40:08 +02:00

3.1 KiB

Contribution Guidelines

This is the home of Shields.io, home to the badge design specification, API documentation, and server code for Badges as a Service.

We invite participation through GitHub Issues, which we use much like a discussion forum. This repository should only contain non-implementation specific topics: specifications, design, and the web site.

This implementation

Please see INSTALL.md for information on how to start contributing code to shields.io. You can read a Tutorial on how to add a badge.

Note that the root gets redirected to http://shields.io. For testing purposes, you can go to http://localhost/try.html.

Ground rules

  • The left-hand side of a badge should not advertize. It should be a noun describing succinctly the meaning of the right-hand-side data.
  • New query parameters (such as ?label= or ?style=) should apply to any requested badge. They must be registered in the cache (see LruCache in server.js).
  • The format of new badges should be of the form /VENDOR/SUBVENDOR-BADGE-SPECIFIC/PARAMETERS.format. For instance, https://img.shields.io/gitter/room/nwjs/nw.js.svg. The vendor is gitter, the badge is for rooms, the parameter is nwjs/nw.js, and the format is svg.

Please minimize .svg files (eg. in logo/) through SVGO (eg. by using svgomg).

Implementations

The main implementation, available at http://shields.io, has its code located in this repository.

Other systems that produce badges following the same design, hosted elsewhere, are listed below.

website / AP language issues
shielded JavaScript shielded
buckler.repl.ca Go buckler
old img.shields.io (discontinued) Python img.shields.io-old
DotBadge C# DotBadge

Please report bugs and discuss implementation specific concerns (performance characteristics, etc.) in the repository for the respective implementation.

Adding support for a service

Please open an issue if you'd like to use Shields badges for a project that isn't yet supported.