# Developing Neutrino Developing and contributing to Neutrino, its core presets, and middleware is done through our monorepo located at https://github.com/mozilla-neutrino/neutrino-dev. The code is broken up into a couple different sections: packages and documentation. _Note: In this guide, commands executable from the command line are prepended with `❯`. Lines not starting with this symbol show sample console output from running the previous command._ ## Requirements Developing for neutrino-dev requires: - Node.js v6.9+ - Yarn client, installation instructions at https://yarnpkg.com/en/docs/install - git, GitHub account ## Getting started The first step to start developing neutrino-dev is [forking the repository to your own GitHub account](https://help.github.com/articles/fork-a-repo/). Fork mozilla-neutrino/neutrino-dev on GitHub Once that is done, you can clone your copy of the repository on your computer, replacing `USER` with the username of the account you forked the repository to: ```bash ❯ git clone git@github.com:USER/neutrino-dev.git ❯ cd neutrino-dev ``` Upon cloning, you should install dependencies and bootstrap the project: ```bash ❯ yarn ❯ yarn bootstrap ``` This will create symlinks between the various packages, making local development much easier. It also creates yarn links for testing out these packages elsewhere on your system. ## Development commands The package.json for neutrino-dev defines several commands to assist in the development and deployment process. --- `bootstrap` Installs all sub-package dependencies using yarn. External dependencies are installed normally, whereas those belonging to the neutrino-dev monorepo itself are `yarn link`ed. ```bash ❯ yarn bootstrap ``` --- `changelog` Generates a changelog for the `mozilla-neutrino/neutrino-dev` GitHub repository. This changelog is output to a `CHANGELOG.md` file in the root of the repository. ```bash ❯ yarn changelog ``` --- `deps:add [--dev] <...dependencies>` Adds one or more new dependencies or development dependencies to a sub-package. Any flags used, such as `--dev` are passed on to `yarn add`. For example, if you wanted to add "lodash.clonedeep" to the neutrino package: ```bash ❯ yarn deps:add neutrino lodash.clonedeep ``` --- `deps:remove <...dependencies>` Removes one or more dependencies from a sub-package. Any flags used are passed on to `yarn remove`. For example, if you wanted to remove "lodash.clonedeep" from the neutrino package: ```bash ❯ yarn deps:remove neutrino lodash.clonedeep ``` --- `deps:upgrade <...dependencies>` Upgrades one or more dependencies in a sub-package. Any flags used are passed on to `yarn upgrade`. For example, if you wanted to upgrade "lodash.clonedeep" in the neutrino package: ```bash ❯ yarn deps:upgrade neutrino lodash.clonedeep ``` --- `deps:clean` Removes the `node_modules` directory from all sub-packages. After running this you will need to re-bootstrap neutrino-dev in order to continue development. Useful if you have somehow put your local development environment in an unworkable state with regards to local inter-dependencies. ```bash ❯ yarn deps:clean ``` --- `docs:serve` Starts a local development server which builds the documentation in `docs` to a gitbook running on port 4000. ```bash ❯ yarn docs:serve ``` --- `docs:build` Generates a static site by building the documentation in `docs` to a gitbook to the `_book` directory. ```bash ❯ yarn docs:build ``` --- `docs:deploy` Generates a static site by building the documentation in `docs` to a gitbook to the `_book` directory, then pushing the contents of `_book` to a `gh-pages` branch on GitHub. In order to run this command, you must have an `upstream` remote configured pointing to the root neutrino-dev repo, and have sufficient rights to push to the repository. ```bash ❯ yarn docs:deploy ``` ## Making changes When you make changes to neutrino-dev, you should make them in a branch separate from `master`. Start from the master branch and create a new branch for your changes. _Example: You want to create a core preset for JavaScript Standard Style. You need a new branch for this work._ ```bash ❯ git checkout -b standard-style Switched to a new branch 'standard-style' ``` While making changes, be sure to test your code out for expected operation. If possible or applicable, write a test that can verify these changes in the future. ## Submitting a pull request Once you are satisfied with your changes, you should commit them and submit a pull request. Use `git add` in order to add files that should be committed. Give your changes a descriptive but not overly verbose message. ```bash ❯ git add . ❯ git commit -m "Feature: Adding new core preset for JavaScript Standard Style" ❯ git push origin standard-style ``` Now if you open the GitHub page for your repository, GitHub should display a button to open a pull request for the branch and commit you just pushed. When filling out the details of the pull request, try to be as descriptive as possible, following our detailed [contribution guidelines](./README.md). ### Congrats! You just made a contribution to Neutrino! We are so happy to have your help! 🎉 ## Receiving updates If you need to update your local copy of neutrino-dev to be in sync with the main neutrino-dev repository, you will want to fetch upstream changes. Add the main neutrino-dev repo as an upstream to your local copy, then fetch the latest changes from the master branch. ```bash ❯ git checkout master ❯ git remote add upstream https://github.com/mozilla-neutrino/neutrino-dev.git ❯ git pull upstream master ```