1
0
mirror of https://github.com/oceanprotocol/docs.git synced 2024-11-26 19:49:26 +01:00

Merge pull request #41 from oceanprotocol/feature/document-submodule-usage

Added notes on "Living with Submodules"
This commit is contained in:
Troy McConaghy 2018-11-20 15:07:22 +01:00 committed by GitHub
commit 208b9c1978
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -26,9 +26,10 @@
- [Editing Docs](#editing-docs) - [Editing Docs](#editing-docs)
- [Repositories](#repositories) - [Repositories](#repositories)
- [Development](#development) - [Development](#development)
- [Use Docker](#use-docker) - [Using npm](#using-npm)
- [Linting & formatting](#linting--formatting) - [Using Docker](#use-docker)
- [Editor setup: VS Code](#editor-setup-vs-code) - [Linting & Formatting](#linting--formatting)
- [Editor Setup: VS Code](#editor-setup-vs-code)
- [GitHub GraphQL API](#github-graphql-api) - [GitHub GraphQL API](#github-graphql-api)
- [Deployment](#deployment) - [Deployment](#deployment)
- [Authors](#authors) - [Authors](#authors)
@ -171,15 +172,43 @@ in [`/data/repositories.yml`](data/repositories.yml).
The site is a React app built with [Gatsby](https://www.gatsbyjs.org). The site is a React app built with [Gatsby](https://www.gatsbyjs.org).
As a prerequisite you'll need on your machine: This Git repo has [Git submodules](https://git-scm.com/book/en/v2/Git-Tools-Submodules). They are the subdirectories of `external/`. Each one is basically another Git repo, i.e. an external Git repo that just _looks_ like it's part of this Git repo. It's very easy to get Git into a confusing state when there are submodules. If you follow the following tips, you should probably be okay:
1. Clone this repo using:
```bash
git clone --recurse-submodules git@github.com:oceanprotocol/docs.git
```
1. Don't edit anything in the submodules (i.e. in `external/`). Instead, edit it over in the other Git repository and merge your changes over there.
1. Get all the submodules up-to-date using:
```bash
git submodule update --remote --recursive
```
That will get each submodule up-to-date with the HEAD commit of some branch in a remote repository. Which branch? That's set in the `.gitmodules` file. You can check the current commit hashes of all the submodules using `git submodule status`
1. Before doing any `git checkout ...` or other normal Git operations, do this:
```bash
git config --global submodule.recurse true
```
That's like adding the `--recurse-submodules` option to all those Git commands (except for `git clone`) so you don't have to.
### Using npm
As a prerequisite, you'll need the following on your machine:
- Node.js - Node.js
- npm - npm
- Your `GITHUB_TOKEN`, see [GitHub GraphQL API](#github-graphql-api)
Clone this repo, install all dependencies, and start the development server: Clone this repo, install all dependencies, and start the development server:
```bash ```bash
git clone --recursive git@github.com:oceanprotocol/docs.git git clone --recurse-submodules git@github.com:oceanprotocol/docs.git
cd docs/ cd docs/
# add GITHUB_TOKEN # add GITHUB_TOKEN
@ -190,27 +219,32 @@ npm i
npm start npm start
``` ```
For getting your `GITHUB_TOKEN`, see [GitHub GraphQL API](#github-graphql-api).
This will start a hot-reloading local server exposed under [localhost:8000](http://localhost:8000). This will start a hot-reloading local server exposed under [localhost:8000](http://localhost:8000).
### Use Docker ### Using Docker
Alternatively, you can use Docker for which you need to have installed on your machine: Alternatively, you can use Docker for which you need to have installed on your machine:
- [Docker](https://www.docker.com) - [Docker](https://www.docker.com)
- [Docker Compose](https://docs.docker.com/compose/) - [Docker Compose](https://docs.docker.com/compose/)
- `GITHUB_TOKEN` in `.env`, see [GitHub GraphQL API](#github-graphql-api) - Your `GITHUB_TOKEN`, see [GitHub GraphQL API](#github-graphql-api)
Then use Docker Compose to bring everything up: Then use Docker Compose to bring everything up:
```bash ```bash
git clone --recurse-submodules git@github.com:oceanprotocol/docs.git
cd docs/
# add GITHUB_TOKEN
cp .env.sample .env
vi .env
docker-compose up docker-compose up
``` ```
This will expose a hot-reloading server under [localhost:8000](http://localhost:8000). This will expose a hot-reloading server under [localhost:8000](http://localhost:8000).
## Linting & formatting ## Linting & Formatting
To enforce a consistent code style, linting is setup for pretty much every file. Linting is part of the test suite, meaning builds on Travis will fail in case of linting errors. To enforce a consistent code style, linting is setup for pretty much every file. Linting is part of the test suite, meaning builds on Travis will fail in case of linting errors.
@ -229,7 +263,7 @@ npm run lint
npm run format npm run format
``` ```
### Editor setup: VS Code ### Editor Setup: VS Code
If you use VS Code as your editor, you can install those extensions to get linting as you type, and auto-formatting as you save: If you use VS Code as your editor, you can install those extensions to get linting as you type, and auto-formatting as you save: