mirror of
https://github.com/Threnklyn/jira.git
synced 2026-06-06 21:20:48 +02:00
make "jira" golang package, move code from jira/cli to root, move jira/main.go to main/main.go
This commit is contained in:
@@ -14,20 +14,32 @@ PLATFORMS= \
|
|||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
DIST=$(shell pwd)/dist
|
DIST=$(shell pwd)/dist
|
||||||
|
|
||||||
export GOPATH=$(shell pwd)
|
export GOPATH=$(shell pwd)
|
||||||
GOBIN ?= $(shell pwd)/bin
|
|
||||||
|
GOBIN ?= $(shell pwd)
|
||||||
NAME=jira
|
NAME=jira
|
||||||
|
|
||||||
|
BIN ?= $(GOBIN)/$(NAME)
|
||||||
|
|
||||||
CURVER ?= $(shell [ -d .git ] && git describe --abbrev=0 --tags || grep ^\#\# CHANGELOG.md | awk '{print $$2; exit}')
|
CURVER ?= $(shell [ -d .git ] && git describe --abbrev=0 --tags || grep ^\#\# CHANGELOG.md | awk '{print $$2; exit}')
|
||||||
LDFLAGS:=-X main.buildVersion=$(CURVER)
|
LDFLAGS:=-X jira.VERSION=$(patsubst v%,%,$(CURVER)) -w
|
||||||
|
|
||||||
|
# use make DEBUG=1 and you can get a debuggable golang binary
|
||||||
|
# see https://github.com/mailgun/godebug
|
||||||
|
ifneq ($(DEBUG),)
|
||||||
|
GOBUILD=go get -v github.com/mailgun/godebug && ./bin/godebug build
|
||||||
|
else
|
||||||
|
GOBUILD=go build -v -ldflags "$(LDFLAGS) -s"
|
||||||
|
endif
|
||||||
|
|
||||||
build: src/github.com/Netflix-Skunkworks/go-jira
|
build: src/github.com/Netflix-Skunkworks/go-jira
|
||||||
go build -ldflags "$(LDFLAGS)" -o $(GOBIN)/$(NAME) jira/main.go
|
$(GOBUILD) -o $(BIN) main/main.go
|
||||||
|
|
||||||
src/%:
|
src/%:
|
||||||
mkdir -p $(@D)
|
mkdir -p $(@D)
|
||||||
test -L $@ || ln -sf ../../.. $@
|
test -L $@ || ln -sf ../../.. $@
|
||||||
go get -v $*/jira
|
go get -v $* $*/main
|
||||||
|
|
||||||
cross-setup:
|
cross-setup:
|
||||||
for p in $(PLATFORMS); do \
|
for p in $(PLATFORMS); do \
|
||||||
@@ -40,33 +52,36 @@ all:
|
|||||||
mkdir -p $(DIST); \
|
mkdir -p $(DIST); \
|
||||||
for p in $(PLATFORMS); do \
|
for p in $(PLATFORMS); do \
|
||||||
echo "Building for $$p"; \
|
echo "Building for $$p"; \
|
||||||
GOOS=$${p/-*/} GOARCH=$${p/*-/} go build -v -ldflags "$(LDFLAGS) -s" -o $(DIST)/$(NAME)-$$p jira/main.go ; \
|
${MAKE} build GOOS=$${p/-*/} GOARCH=$${p/*-/} BIN=$(DIST)/$(NAME)-$$p; \
|
||||||
done
|
done
|
||||||
|
|
||||||
fmt:
|
fmt:
|
||||||
gofmt -s -w jira
|
gofmt -s -w main/*.go *.go
|
||||||
|
|
||||||
install:
|
install:
|
||||||
export GOBIN=~/bin && ${MAKE} build
|
${MAKE} GOBIN=~/bin build
|
||||||
|
|
||||||
NEWVER ?= $(shell echo $(CURVER) | awk -F. '{print $$1"."$$2"."$$3+1}')
|
NEWVER ?= $(shell echo $(CURVER) | awk -F. '{print $$1"."$$2"."$$3+1}')
|
||||||
TODAY := $(shell date +%Y-%m-%d)
|
TODAY := $(shell date +%Y-%m-%d)
|
||||||
|
|
||||||
changes:
|
changes:
|
||||||
@git log --pretty=format:"* %s [%cn] [%h]" --no-merges ^$(CURVER) HEAD jira | grep -v gofmt | grep -v "bump version"
|
@git log --pretty=format:"* %s [%cn] [%h]" --no-merges ^$(CURVER) HEAD main/*.go *.go | grep -vE 'gofmt|go fmt'
|
||||||
|
|
||||||
update-changelog:
|
update-changelog:
|
||||||
@echo "# Changelog" > CHANGELOG.md.new; \
|
@echo "# Changelog" > CHANGELOG.md.new; \
|
||||||
echo >> CHANGELOG.md.new; \
|
echo >> CHANGELOG.md.new; \
|
||||||
echo "## $(NEWVER) - $(TODAY)" >> CHANGELOG.md.new; \
|
echo "## $(NEWVER) - $(TODAY)" >> CHANGELOG.md.new; \
|
||||||
echo >> CHANGELOG.md.new; \
|
echo >> CHANGELOG.md.new; \
|
||||||
$(MAKE) changes | \
|
$(MAKE) --no-print-directory --silent changes | \
|
||||||
perl -pe 's{\[([a-f0-9]+)\]}{[[$$1](https://github.com/Netflix-Skunkworks/go-jira/commit/$$1)]}g' | \
|
perl -pe 's{\[([a-f0-9]+)\]}{[[$$1](https://github.com/Netflix-Skunkworks/go-jira/commit/$$1)]}g' | \
|
||||||
perl -pe 's{\#(\d+)}{[#$$1](https://github.com/Netflix-Skunkworks/go-jira/issues/$$1)}g' >> CHANGELOG.md.new; \
|
perl -pe 's{\#(\d+)}{[#$$1](https://github.com/Netflix-Skunkworks/go-jira/issues/$$1)}g' >> CHANGELOG.md.new; \
|
||||||
tail +2 CHANGELOG.md >> CHANGELOG.md.new; \
|
tail -n +2 CHANGELOG.md >> CHANGELOG.md.new; \
|
||||||
mv CHANGELOG.md.new CHANGELOG.md; \
|
mv CHANGELOG.md.new CHANGELOG.md; \
|
||||||
git commit -m "Updated Changelog" CHANGELOG.md; \
|
git commit -m "Updated Changelog" CHANGELOG.md; \
|
||||||
git tag $(NEWVER)
|
git tag $(NEWVER)
|
||||||
|
|
||||||
|
version:
|
||||||
|
@echo $(patsubst v%,%,$(CURVER))
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -rf pkg dist bin src ./toolkit
|
rm -rf pkg dist bin src ./$(NAME)
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
package cli
|
package jira
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
@@ -18,7 +18,10 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var log = logging.MustGetLogger("jira.cli")
|
var (
|
||||||
|
log = logging.MustGetLogger("jira")
|
||||||
|
VERSION string
|
||||||
|
)
|
||||||
|
|
||||||
type Cli struct {
|
type Cli struct {
|
||||||
endpoint *url.URL
|
endpoint *url.URL
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
package cli
|
package jira
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
@@ -3,7 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/Netflix-Skunkworks/go-jira/jira/cli"
|
"github.com/Netflix-Skunkworks/go-jira"
|
||||||
"github.com/coryb/optigo"
|
"github.com/coryb/optigo"
|
||||||
"github.com/op/go-logging"
|
"github.com/op/go-logging"
|
||||||
"gopkg.in/coryb/yaml.v2"
|
"gopkg.in/coryb/yaml.v2"
|
||||||
@@ -16,7 +16,6 @@ import (
|
|||||||
var (
|
var (
|
||||||
log = logging.MustGetLogger("jira")
|
log = logging.MustGetLogger("jira")
|
||||||
format = "%{color}%{time:2006-01-02T15:04:05.000Z07:00} %{level:-5s} [%{shortfile}]%{color:reset} %{message}"
|
format = "%{color}%{time:2006-01-02T15:04:05.000Z07:00} %{level:-5s} [%{shortfile}]%{color:reset} %{message}"
|
||||||
buildVersion string
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@@ -172,7 +171,7 @@ Command Options:
|
|||||||
op := optigo.NewDirectAssignParser(map[string]interface{}{
|
op := optigo.NewDirectAssignParser(map[string]interface{}{
|
||||||
"h|help": usage,
|
"h|help": usage,
|
||||||
"version": func() {
|
"version": func() {
|
||||||
fmt.Println(fmt.Sprintf("version: %s", buildVersion))
|
fmt.Println(fmt.Sprintf("version: %s", jira.VERSION))
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
},
|
},
|
||||||
"v|verbose+": func() {
|
"v|verbose+": func() {
|
||||||
@@ -258,7 +257,7 @@ Command Options:
|
|||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
c := cli.New(opts)
|
c := jira.New(opts)
|
||||||
|
|
||||||
log.Debug("opts: %s", opts)
|
log.Debug("opts: %s", opts)
|
||||||
|
|
||||||
@@ -306,7 +305,7 @@ Command Options:
|
|||||||
for _, issue := range issues {
|
for _, issue := range issues {
|
||||||
if err = c.CmdEdit(issue.(map[string]interface{})["key"].(string)); err != nil {
|
if err = c.CmdEdit(issue.(map[string]interface{})["key"].(string)); err != nil {
|
||||||
switch err.(type) {
|
switch err.(type) {
|
||||||
case cli.NoChangesFound:
|
case jira.NoChangesFound:
|
||||||
log.Warning("No Changes found: %s", err)
|
log.Warning("No Changes found: %s", err)
|
||||||
err = nil
|
err = nil
|
||||||
continue
|
continue
|
||||||
@@ -441,9 +440,9 @@ func populateEnv(opts map[string]interface{}) {
|
|||||||
|
|
||||||
func loadConfigs(opts map[string]interface{}) {
|
func loadConfigs(opts map[string]interface{}) {
|
||||||
populateEnv(opts)
|
populateEnv(opts)
|
||||||
paths := cli.FindParentPaths(".jira.d/config.yml")
|
paths := jira.FindParentPaths(".jira.d/config.yml")
|
||||||
// prepend
|
// prepend
|
||||||
paths = append([]string{"/etc/jira-cli.yml"}, paths...)
|
paths = append([]string{"/etc/go-jira.yml"}, paths...)
|
||||||
|
|
||||||
// iterate paths in reverse
|
// iterate paths in reverse
|
||||||
for i := len(paths) - 1; i >= 0; i-- {
|
for i := len(paths) - 1; i >= 0; i-- {
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
package cli
|
package jira
|
||||||
|
|
||||||
var all_templates = map[string]string{
|
var all_templates = map[string]string{
|
||||||
"debug": default_debug_template,
|
"debug": default_debug_template,
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
package cli
|
package jira
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
Reference in New Issue
Block a user