From a9dd6d9dc3ac653321e20912b2bf1dab07b58972 Mon Sep 17 00:00:00 2001 From: Adrian Klingen Date: Fri, 10 May 2024 09:57:33 +0200 Subject: [PATCH] Add support for Docker watch/devmode --- Dockerfile | 26 +++++++++++++------------- README.md | 13 ++++++++----- makefile | 4 ++-- 3 files changed, 23 insertions(+), 20 deletions(-) diff --git a/Dockerfile b/Dockerfile index c6cac2517b..804b8f3464 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,29 +3,29 @@ FROM golang:1.21 WORKDIR /cata -COPY . . -COPY gitconfig /etc/gitconfig RUN rm /bin/sh && ln -s /bin/bash /bin/sh -RUN apt-get update -RUN apt-get install -y protobuf-compiler -RUN go get -u google.golang.org/protobuf -RUN go install google.golang.org/protobuf/cmd/protoc-gen-go@latest +COPY . . +COPY gitconfig /etc/gitconfig + +# Install all Go dependencies +RUN apt-get update \ + && apt-get install -y protobuf-compiler \ + && go get -u google.golang.org/protobuf \ + && go install google.golang.org/protobuf/cmd/protoc-gen-go@latest \ + && curl -sSfL https://raw.githubusercontent.com/cosmtrek/air/master/install.sh | sh -s -- -b $(shell go env GOPATH)/bin -ENV NODE_VERSION=20.11.1 +ENV NODE_VERSION=20.13.1 ENV NVM_DIR="/root/.nvm" -RUN curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.38.0/install.sh | bash \ +# Install all Frontend dependencies +RUN curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash \ && . $NVM_DIR/nvm.sh \ && nvm install $NODE_VERSION \ && nvm alias default $NODE_VERSION \ && nvm use default -#RUN . "$NVM_DIR/nvm.sh" && nvm install ${NODE_VERSION} -#RUN . "$NVM_DIR/nvm.sh" && nvm use v${NODE_VERSION} -#RUN . "$NVM_DIR/nvm.sh" && nvm alias default v${NODE_VERSION} - ENV PATH="/root/.nvm/versions/node/v${NODE_VERSION}/bin/:${PATH}" -EXPOSE 8080/tcp +EXPOSE 8080 3333 5173 diff --git a/README.md b/README.md index bba7e1aae4..b4c351de7d 100644 --- a/README.md +++ b/README.md @@ -44,8 +44,8 @@ go get -u -v google.golang.org/protobuf go install google.golang.org/protobuf/cmd/protoc-gen-go@latest # Install node -curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.38.0/install.sh | bash -nvm install 19.8.0 +curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash +nvm install 20.13.1 # Install the npm package dependencies using node npm install @@ -65,6 +65,9 @@ docker run --rm -v $(pwd):/cata wowsims-cata npm install # For convenience, set this as an environment variable: CATA_CMD="docker run --rm -it -p 8080:8080 -v $(pwd):/cata wowsims-cata" +#For the watch commands assign this environment variable: +CATA_WATCH_CMD="docker run --rm -it -p 8080:8080 -p 3333:3333 -p 5173:5173 -e WATCH=1 -v $(pwd):/cata wowsims-cata" + # ... do some coding on the sim ... # Run tests @@ -84,7 +87,7 @@ If you want to develop on Windows, we recommend setting up a Ubuntu virtual mach * You can also use the Ubuntu setup instructions as above to run natively, with a few modifications: * You may need a different Go installer if `go1.18.3.linux-amd64.tar.gz` is not compatible with your system's architecture; you can do the Go install manually from `https://go.dev/doc/install`. * OS X uses Homebrew instead of apt, so in order to install protobuf-compiler you’ll instead need to run `brew install protobuf-c` (note the package name is also a little different than in apt). You might need to first update or upgrade brew. - * The provided install script for Node will not included a precompiled binary for OS X, but it’s smart enough to compile one. Be ready for your CPU to melt on running `curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.38.0/install.sh | bash`. + * The provided install script for Node will not included a precompiled binary for OS X, but it’s smart enough to compile one. Be ready for your CPU to melt on running `curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash`. # Commands We use a makefile for our build system. These commands will usually be all you need while developing for this project: @@ -122,8 +125,8 @@ make rundevserver WATCH=1 make rundevserver -# The same as rundevserver, recompiles `wowsimcata` binary and runs it on port 3333. Instead of serving content from the dist folder, -# this command also runs `vite serve` to start the Vite dev server on port 3174 (or similar) and automatically reloads the page on .ts changes in less than a second. +# The same as rundevserver, recompiles `wowsimcata` binary and runs it on port 3333. Instead of serving content from the dist folder, +# this command also runs `vite serve` to start the Vite dev server on port 5173 (or similar) and automatically reloads the page on .ts changes in less than a second. # This allows for more rapid development, with sub second reloads on TS changes. This combines the benefits of `WATCH=1 make rundevserver` and `WATCH=1 make host` # to create something that allows you to work in any part of the code with ease and speed. # This might get rolled into `WATCH=1 make rundevserver` at some point. diff --git a/makefile b/makefile index a4770d89ca..bb3465d3ea 100644 --- a/makefile +++ b/makefile @@ -270,8 +270,8 @@ endif devmode: air devserver ifeq ($(WATCH), 1) - npx vite serve & + npx vite serve --host & air -tmp_dir "/tmp" -build.include_ext "go,proto" -build.args_bin "--usefs=true --launch=false --wasm=false" -build.bin "./wowsimcata" -build.cmd "make devserver" -build.exclude_dir "assets,dist,node_modules,ui,tools" else ./wowsimcata --usefs=true --launch=false --host=":3333" -endif \ No newline at end of file +endif