Go Modules migration

This commit is contained in:
uta-mori
2020-07-28 13:22:55 +09:00
parent 21c0264fc5
commit 86b970f35a
4 changed files with 58 additions and 53 deletions

View File

@@ -1,5 +1,5 @@
# Update the VARIANT arg in devcontainer.json to pick an Go version # Update the VARIANT arg in devcontainer.json to pick an Go version
ARG VARIANT=1 ARG VARIANT=1.14
FROM golang:${VARIANT} FROM golang:${VARIANT}
# This Dockerfile adds a non-root user with sudo access. Update the “remoteUser” property in # This Dockerfile adds a non-root user with sudo access. Update the “remoteUser” property in
@@ -27,17 +27,17 @@ RUN apt-get update \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
# Install Go tools # Install Go tools
ENV GO111MODULE=on
ARG GO_TOOLS_WITH_MODULES="\ ARG GO_TOOLS_WITH_MODULES="\
golang.org/x/tools/gopls \ golang.org/x/tools/gopls \
honnef.co/go/tools/... \ honnef.co/go/tools/... \
golang.org/x/tools/cmd/gorename \ golang.org/x/tools/cmd/gorename \
golang.org/x/tools/cmd/goimports \ golang.org/x/tools/cmd/goimports \
golang.org/x/tools/cmd/guru \ golang.org/x/tools/cmd/guru \
golang.org/x/lint/golint \
github.com/mdempsky/gocode \
github.com/cweill/gotests/... \ github.com/cweill/gotests/... \
github.com/haya14busa/goplay/cmd/goplay \ github.com/haya14busa/goplay/cmd/goplay \
github.com/sqs/goreturns \
github.com/josharian/impl \ github.com/josharian/impl \
github.com/davidrjenni/reftools/cmd/fillstruct \ github.com/davidrjenni/reftools/cmd/fillstruct \
github.com/uudashr/gopkgs/v2/cmd/gopkgs \ github.com/uudashr/gopkgs/v2/cmd/gopkgs \
@@ -49,29 +49,13 @@ ARG GO_TOOLS_WITH_MODULES="\
github.com/fatih/gomodifytags \ github.com/fatih/gomodifytags \
github.com/mgechev/revive \ github.com/mgechev/revive \
github.com/go-delve/delve/cmd/dlv" github.com/go-delve/delve/cmd/dlv"
RUN mkdir -p /tmp/gotools \
&& cd /tmp/gotools \ RUN (echo "${GO_TOOLS_WITH_MODULES}" | xargs -n 1 go get )2>&1 \
&& export GOPATH=/tmp/gotools \
# Go tools w/module support
&& export GO111MODULE=on \
&& (echo "${GO_TOOLS_WITH_MODULES}" | xargs -n 1 go get -x )2>&1 \
# gocode-gomod
&& export GO111MODULE=auto \
&& go get -x -d github.com/stamblerre/gocode 2>&1 \
&& go build -o gocode-gomod github.com/stamblerre/gocode \
# golangci-lint # golangci-lint
&& curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b /usr/local/bin 2>&1 \ && curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b /usr/local/bin 2>&1 \
# Move Go tools into path and clean up
&& mv /tmp/gotools/bin/* /usr/local/bin/ \
&& mv gocode-gomod /usr/local/bin/ \
&& rm -rf /tmp/gotools
ENV GO111MODULE=auto
# [Optional] Uncomment the next line to use go get to install anything else you need # [Optional] Uncomment the next line to use go get to install anything else you need
# RUN go get -x <your-dependency-or-tool> # RUN go get -x <your-dependency-or-tool>
# [Optional] Uncomment this section to install additional OS packages. # [Optional] Uncomment this section to install additional OS packages.
# RUN apt-get update \ # RUN apt-get update \
# && export DEBIAN_FRONTEND=noninteractive \ # && export DEBIAN_FRONTEND=noninteractive \
# && apt-get -y install --no-install-recommends <your-package-list-here> # && apt-get -y install --no-install-recommends <your-package-list-here>

View File

@@ -1,31 +1,52 @@
{ {
"name": "Go", "name": "Go",
"build": { "build": {
"dockerfile": "Dockerfile", "dockerfile": "Dockerfile",
// Update the VARIANT arg to pick a version of Go // Update the VARIANT arg to pick a version of Go
"args": { "VARIANT": "1" } "args": { "VARIANT": "1.14" }
}, },
"runArgs": [ "--cap-add=SYS_PTRACE", "--security-opt", "seccomp=unconfined" ], "runArgs": ["--cap-add=SYS_PTRACE", "--security-opt", "seccomp=unconfined"],
// Set *default* container specific settings.json values on container create. // Set *default* container specific settings.json values on container create.
"settings": { "settings": {
"terminal.integrated.shell.linux": "/bin/bash", "terminal.integrated.shell.linux": "/bin/bash",
"go.gopath": "/go", "go.useLanguageServer": true,
"go.inferGopath": true, "[go]": {
"go.useLanguageServer": true "editor.formatOnSave": true,
}, "editor.codeActionsOnSave": {
"source.organizeImports": true
// Add the IDs of extensions you want installed when the container is created. },
"extensions": [ // Optional: Disable snippets, as they conflict with completion ranking.
"golang.Go" "editor.snippetSuggestions": "none"
], },
"[go.mod]": {
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.organizeImports": true
}
},
"gopls": {
// Add parameter placeholders when completing a function.
"usePlaceholders": true,
// the completion engine is allowed to make suggestions for packages that you do not currently import.
"completeUnimported": true,
// Use 'forwardPorts' to make a list of ports inside the container available locally. // If true, enable additional analyses with staticcheck.
"forwardPorts": [9000], // Warning: This will significantly increase memory usage.
"staticcheck": true
},
"go.lintTool": "golangci-lint"
},
// Use 'postCreateCommand' to run commands after the container is created. // Add the IDs of extensions you want installed when the container is created.
// "postCreateCommand": "go version", "extensions": ["golang.Go"],
// Uncomment to connect as a non-root user. See https://aka.ms/vscode-remote/containers/non-root. // Use 'forwardPorts' to make a list of ports inside the container available locally.
"remoteUser": "vscode" "forwardPorts": [9000],
}
// Use 'postCreateCommand' to run commands after the container is created.
// "postCreateCommand": "go version",
// Uncomment to connect as a non-root user. See https://aka.ms/vscode-remote/containers/non-root.
"remoteUser": "vscode"
}

4
.vscode/launch.json vendored
View File

@@ -6,7 +6,7 @@
"type": "go", "type": "go",
"request": "launch", "request": "launch",
"mode": "debug", "mode": "debug",
"program": "${workspaceFolder}/src/main/server.go" "program": "${workspaceFolder}/server.go"
} }
] ]
} }

View File

@@ -1,4 +1,4 @@
{ {
"go.useLanguageServer": true, "go.useLanguageServer": true,
"go.inferGopath": true "go.inferGopath": false
} }