diff --git a/.gitignore b/.gitignore index e69de29..71b1bc4 100644 --- a/.gitignore +++ b/.gitignore @@ -0,0 +1 @@ +/viper-be5ff3e.tar.gz diff --git a/change-import-path.patch b/change-import-path.patch new file mode 100644 index 0000000..c1fdf5a --- /dev/null +++ b/change-import-path.patch @@ -0,0 +1,39 @@ +From 946c1e2ba578c48091c2257873d0b17c5ffd8d34 Mon Sep 17 00:00:00 2001 +From: Jan Chaloupka +Date: Fri, 9 Oct 2015 00:56:51 +0200 +Subject: [PATCH] change import path + +--- + util.go | 2 +- + viper.go | 2 +- + 2 files changed, 2 insertions(+), 2 deletions(-) + +diff --git a/util.go b/util.go +index 7904b1a..79b8c02 100644 +--- a/util.go ++++ b/util.go +@@ -24,7 +24,7 @@ import ( + "github.com/BurntSushi/toml" + "github.com/magiconair/properties" + "github.com/spf13/cast" +- jww "github.com/spf13/jwalterweatherman" ++ jww "github.com/spf13/jWalterWeatherman" + "gopkg.in/yaml.v2" + ) + +diff --git a/viper.go b/viper.go +index 799983f..fd49119 100644 +--- a/viper.go ++++ b/viper.go +@@ -33,7 +33,7 @@ import ( + "github.com/kr/pretty" + "github.com/mitchellh/mapstructure" + "github.com/spf13/cast" +- jww "github.com/spf13/jwalterweatherman" ++ jww "github.com/spf13/jWalterWeatherman" + "github.com/spf13/pflag" + ) + +-- +1.9.3 + diff --git a/golang-github-spf13-viper.spec b/golang-github-spf13-viper.spec new file mode 100644 index 0000000..3bef178 --- /dev/null +++ b/golang-github-spf13-viper.spec @@ -0,0 +1,175 @@ +%if 0%{?fedora} || 0%{?rhel} == 6 +%global with_devel 1 +%global with_bundled 0 +%global with_debug 0 +%global with_check 1 +%global with_unit_test 1 +%else +%global with_devel 0 +%global with_bundled 0 +%global with_debug 0 +%global with_check 0 +%global with_unit_test 0 +%endif + +%if 0%{?with_debug} +%global _dwz_low_mem_die_limit 0 +%else +%global debug_package %{nil} +%endif + +%global provider github +%global provider_tld com +%global project spf13 +%global repo viper +# https://github.com/spf13/viper +%global provider_prefix %{provider}.%{provider_tld}/%{project}/%{repo} +%global import_path %{provider_prefix} +%global commit be5ff3e4840cf692388bde7a057595a474ef379e +%global shortcommit %(c=%{commit}; echo ${c:0:7}) + +Name: golang-%{provider}-%{project}-%{repo} +Version: 0 +Release: 0.1.git%{shortcommit}%{?dist} +Summary: Go configuration with fangs +License: MIT +URL: https://%{provider_prefix} +Source0: https://%{provider_prefix}/archive/%{commit}/%{repo}-%{shortcommit}.tar.gz + +Patch0: change-import-path.patch + +# e.g. el6 has ppc64 arch without gcc-go, so EA tag is required +ExclusiveArch: %{?go_arches:%{go_arches}}%{!?go_arches:%{ix86} x86_64 %{arm}} +# If go_compiler is not set to 1, there is no virtual provide. Use golang instead. +BuildRequires: %{?go_compiler:compiler(go-compiler)}%{!?go_compiler:golang} + +%description +%{summary} + +%if 0%{?with_devel} +%package devel +Summary: %{summary} +BuildArch: noarch + +%if 0%{?with_check} +BuildRequires: golang(github.com/BurntSushi/toml) +BuildRequires: golang(github.com/kr/pretty) +BuildRequires: golang(github.com/magiconair/properties) +BuildRequires: golang(github.com/mitchellh/mapstructure) +BuildRequires: golang(github.com/spf13/cast) +BuildRequires: golang(github.com/spf13/jWalterWeatherman) +BuildRequires: golang(github.com/spf13/pflag) +BuildRequires: golang(github.com/stretchr/testify/assert) +BuildRequires: golang(gopkg.in/yaml.v2) +%endif + +Requires: golang(github.com/BurntSushi/toml) +Requires: golang(github.com/kr/pretty) +Requires: golang(github.com/magiconair/properties) +Requires: golang(github.com/mitchellh/mapstructure) +Requires: golang(github.com/spf13/cast) +Requires: golang(github.com/spf13/jWalterWeatherman) +Requires: golang(github.com/spf13/pflag) +Requires: golang(github.com/stretchr/testify/assert) +Requires: golang(gopkg.in/yaml.v2) + +Provides: golang(%{import_path}) = %{version}-%{release} + +%description devel +%{summary} + +This package contains library source intended for +building other packages which use import path with +%{import_path} prefix. +%endif + +%if 0%{?with_unit_test} && 0%{?with_devel} +%package unit-test +Summary: Unit tests for %{name} package +%if 0%{?with_check} +#Here comes all BuildRequires: PACKAGE the unit tests +#in %%check section need for running +%endif + +# test subpackage tests code from devel subpackage +Requires: %{name}-devel = %{version}-%{release} + +%description unit-test +%{summary} + +This package contains unit tests for project +providing packages with %{import_path} prefix. +%endif + +%prep +%setup -q -n %{repo}-%{commit} +%patch0 -p1 + +%build + +%install +rm -rf remote +# source codes for building projects +%if 0%{?with_devel} +install -d -p %{buildroot}/%{gopath}/src/%{import_path}/ +echo "%%dir %%{gopath}/src/%%{import_path}/." >> devel.file-list +# find all *.go but no *_test.go files and generate devel.file-list +for file in $(find . -iname "*.go" \! -iname "*_test.go") ; do + echo "%%dir %%{gopath}/src/%%{import_path}/$(dirname $file)" >> devel.file-list + install -d -p %{buildroot}/%{gopath}/src/%{import_path}/$(dirname $file) + cp -pav $file %{buildroot}/%{gopath}/src/%{import_path}/$file + echo "%%{gopath}/src/%%{import_path}/$file" >> devel.file-list +done +%endif + +# testing files for this project +%if 0%{?with_unit_test} && 0%{?with_devel} +install -d -p %{buildroot}/%{gopath}/src/%{import_path}/ +# find all *_test.go files and generate unit-test.file-list +for file in $(find . -iname "*_test.go"); do + echo "%%dir %%{gopath}/src/%%{import_path}/$(dirname $file)" >> devel.file-list + install -d -p %{buildroot}/%{gopath}/src/%{import_path}/$(dirname $file) + cp -pav $file %{buildroot}/%{gopath}/src/%{import_path}/$file + echo "%%{gopath}/src/%%{import_path}/$file" >> unit-test.file-list +done +%endif + +%if 0%{?with_devel} +sort -u -o devel.file-list devel.file-list +%endif + +%check +%if 0%{?with_check} && 0%{?with_unit_test} && 0%{?with_devel} +%if ! 0%{?with_bundled} +export GOPATH=%{buildroot}/%{gopath}:%{gopath} +%else +export GOPATH=%{buildroot}/%{gopath}:$(pwd)/Godeps/_workspace:%{gopath} +%endif + +%if ! 0%{?gotest:1} +%global gotest go test +%endif + +%gotest %{import_path} +%endif + +#define license tag if not already defined +%{!?_licensedir:%global license %doc} + +%if 0%{?with_devel} +%files devel -f devel.file-list +%license LICENSE +%doc README.md +%dir %{gopath}/src/%{provider}.%{provider_tld}/%{project} +%endif + +%if 0%{?with_unit_test} && 0%{?with_devel} +%files unit-test -f unit-test.file-list +%license LICENSE +%doc README.md +%endif + +%changelog +* Thu Oct 08 2015 jchaloup - 0-0.1.gitbe5ff3e +- First package for Fedora + resolves: #1270064 diff --git a/sources b/sources index e69de29..2fb61a1 100644 --- a/sources +++ b/sources @@ -0,0 +1 @@ +e08e22240aa55e7766f0eef7ebefb956 viper-be5ff3e.tar.gz