make "jira" golang package, move code from jira/cli to root, move jira/main.go to main/main.go

This commit is contained in:
Cory Bennett
2015-12-22 17:56:53 -08:00
parent 2df21d3023
commit 7268b9e346
6 changed files with 41 additions and 24 deletions
+27 -12
View File
@@ -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)
+5 -2
View File
@@ -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 -1
View File
@@ -1,4 +1,4 @@
package cli package jira
import ( import (
"bytes" "bytes"
+6 -7
View File
@@ -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 -1
View File
@@ -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 -1
View File
@@ -1,4 +1,4 @@
package cli package jira
import ( import (
"bufio" "bufio"