- Ways to contribute
- Making Changes
- Microformats specifications
- Node support
- Developer environment
- License
Anyone can contribute to this project in one of many ways, for example:
- Create an issue for a bug
- Open a pull request to make an improvement
- Open a pull request to fix a bug
- Participate in discussion
- Fork the repo into your own GitHub account and clone it to your local machine.
- Use the versions of node and yarn from development environment.
- Create a branch for the code changes you're looking to make with
git checkout -b branch-name
. - Add some tests to our test suites to describe the change you want to make. These are in the form of JSON/HTML pairs.
- Write some code to pass the tests!
- Commit your changes using
git commit -am 'A description of the change'
. We try to follow conventional commit types, but this is not required. - Push the branch to your fork:
git push -u origin branch-name
. - Create a new pull request!
You don't need to make your Pull Request perfect! The important thing is to get a PR open so we can begin making this parser better.
We're more than happy to help with any TypeScript, linting or test problems, or to refactor after a merge. These should not be a barrier to contributing!
You can test your changes using the interactive demo. Just run yarn build
and yarn demo
and visit http://localhost:8080
to parse a real-world example.
This project follows the microformats2 parsing specification and tests all code against the microformats test suite.
All pull requests making changes to the parsing behaviour should reference the relevant specification and provide additional tests to cover the change.
We support all versions that are currently supported on the node LTS schedule.
This project is developed using:
- node@lts (active)
- yarn@1
If you use nvm
, you can run nvm use
in the root of this project to switch to the correct version of node.
We use a few developer tools to help maintain code quality.
- TypeScript is used to statically typecheck all code.
- Prettier (
yarn prettier:list
) is used as an opinionated code-formatter. A fix command is executed on each commit automatically. - ESLint (
yarn lint
) validates your code against specific rules. A check is executed on each commit automatically, and will prevent a commit if there are any errors found. - Mocha (
yarn test
) tests the package against a set of tests (located in/test
). These are ran automatically in CI for each push.- These tests are ran against the microformats test suite and some additional test cases.
- Mocha tests for the built package is ran against all supported LTS versions of node.
- Tests require 100% code coverage to pass.
- Tests are not required to pass to be able to commit.
- More information on adding new tests is available in the test suite README.
By contributing to this project, you agree that any contributions are made under the MIT license.