| WEBSITE_REPO=github.com/hashicorp/terraform-website |
| VERSION?="0.3.44" |
| PWD=$$(pwd) |
| DOCKER_IMAGE="hashicorp/terraform-website:full" |
| DOCKER_IMAGE_LOCAL="hashicorp-terraform-website-local" |
| DOCKER_RUN_FLAGS=--interactive \ |
| --rm \ |
| --tty \ |
| --workdir "/website" \ |
| --volume "$(shell pwd):/website/ext/terraform" \ |
| --volume "$(shell pwd)/website:/website/preview" \ |
| --publish "3000:3000" \ |
| -e "IS_CONTENT_PREVIEW=true" \ |
| -e "PREVIEW_FROM_REPO=terraform" \ |
| -e "NAV_DATA_DIRNAME=./preview/data" \ |
| -e "CONTENT_DIRNAME=./preview/docs" \ |
| -e "CURRENT_GIT_BRANCH=$$(git rev-parse --abbrev-ref HEAD)" |
| |
| # generate runs `go generate` to build the dynamically generated |
| # source files, except the protobuf stubs which are built instead with |
| # "make protobuf". |
| generate: |
| go generate ./... |
| |
| # We separate the protobuf generation because most development tasks on |
| # Terraform do not involve changing protobuf files and protoc is not a |
| # go-gettable dependency and so getting it installed can be inconvenient. |
| # |
| # If you are working on changes to protobuf interfaces, run this Makefile |
| # target to be sure to regenerate all of the protobuf stubs using the expected |
| # versions of protoc and the protoc Go plugins. |
| protobuf: |
| go run ./tools/protobuf-compile . |
| |
| fmtcheck: |
| @sh -c "'$(CURDIR)/scripts/gofmtcheck.sh'" |
| |
| staticcheck: |
| @sh -c "'$(CURDIR)/scripts/staticcheck.sh'" |
| |
| exhaustive: |
| @sh -c "'$(CURDIR)/scripts/exhaustive.sh'" |
| |
| # Default: run this if working on the website locally to run in watch mode. |
| website: |
| @echo "==> Downloading latest Docker image..." |
| @docker pull ${DOCKER_IMAGE} |
| @echo "==> Starting website in Docker..." |
| @docker run ${DOCKER_RUN_FLAGS} ${DOCKER_IMAGE} npm start |
| |
| website/local: |
| @echo "==> Starting website in Docker..." |
| @docker run ${DOCKER_RUN_FLAGS} ${DOCKER_IMAGE_LOCAL} npm start |
| |
| .PHONY: website/build-local |
| website/build-local: |
| @echo "==> Building local Docker image" |
| @docker build https://github.com/hashicorp/terraform-website.git\#master \ |
| -t $(DOCKER_IMAGE_LOCAL) |
| |
| # disallow any parallelism (-j) for Make. This is necessary since some |
| # commands during the build process create temporary files that collide |
| # under parallel conditions. |
| .NOTPARALLEL: |
| |
| .PHONY: fmtcheck generate protobuf website website-test staticcheck website/local website/build-local |