From 0845a64e0cde0f88f21b10b65aaeb1b459ac6ab9 Mon Sep 17 00:00:00 2001 From: Jared K. Smith Date: Aug 03 2016 16:12:59 +0000 Subject: Initial packaging --- diff --git a/.gitignore b/.gitignore index e69de29..d3bef20 100644 --- a/.gitignore +++ b/.gitignore @@ -0,0 +1,3 @@ +/examples-2.9.2.tar.bz2 +/jshint-2.9.2.tgz +/tests-2.9.2.tar.bz2 diff --git a/dl-tests.sh b/dl-tests.sh new file mode 100644 index 0000000..2719465 --- /dev/null +++ b/dl-tests.sh @@ -0,0 +1,115 @@ +#!/bin/bash + +tag=$(sed -n 's/^Version:\s\(.*\)$/\1/p' ./*.spec | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//') +url=$(sed -n 's/^URL:\s\(.*\)$/\1/p' ./*.spec | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//') +pkgdir=$(basename $url | sed -s 's/\.git$//') + +echo "tag: $tag" +echo "URL: $url" +echo "pkgdir: $pkgdir" + +set -e + +tmp=$(mktemp -d) + +trap cleanup EXIT +cleanup() { + echo Cleaning up... + set +e + [ -z "$tmp" -o ! -d "$tmp" ] || rm -rf "$tmp" +} + +unset CDPATH +pwd=$(pwd) + +pushd "$tmp" +git clone $url +cd $pkgdir +echo Finding git tag +gittag=$(git show-ref --tags | cut -d' ' -f2 | grep "${tag}$" || git show-ref --tags | cut -d' ' -f2 | sort -Vr | head -n1) +if [ -z $gittag ]; then + gittag=tags/$tag +fi +echo "Git Tag: $gittag" +if [ -d "test" ]; then + git archive --prefix='test/' --format=tar ${gittag}:test/ \ + | bzip2 > "$pwd"/tests-${tag}.tar.bz2 +elif [ -d "tests" ]; then + git archive --prefix='tests/' --format=tar ${gittag}:tests/ \ + | bzip2 > "$pwd"/tests-${tag}.tar.bz2 +elif [ -d "spec" ]; then + git archive --prefix='spec/' --format=tar ${gittag}:spec/ \ + | bzip2 > "$pwd"/tests-${tag}.tar.bz2 +else + echo "No test directory found for tag ${gittag}" +fi +if [ -d "support" ]; then + git archive --prefix='support/' --format=tar ${gittag}:support/ \ + | bzip2 > "$pwd"/support-${tag}.tar.bz2 +fi +if [ -d "fixture" ]; then + git archive --prefix='fixture/' --format=tar ${gittag}:fixture/ \ + | bzip2 > "$pwd"/fixture-${tag}.tar.bz2 +fi +if [ -d "examples" ]; then + git archive --prefix='examples/' --format=tar ${gittag}:examples/ \ + | bzip2 > "$pwd"/examples-${tag}.tar.bz2 +elif [ -d "example" ]; then + git archive --prefix='example/' --format=tar ${gittag}:example/ \ + | bzip2 > "$pwd"/examples-${tag}.tar.bz2 +fi +if [ -d "tasks" ]; then + git archive --prefix='tasks/' --format=tar ${gittag}:tasks/ \ + | bzip2 > "$pwd"/tasks-${tag}.tar.bz2 +fi +if [ -d "docs" ]; then + git archive --prefix='docs/' --format=tar ${gittag}:docs/ \ + | bzip2 > "$pwd"/docs-${tag}.tar.bz2 +elif [ -d "doc" ]; then + git archive --prefix='doc/' --format=tar ${gittag}:doc/ \ + | bzip2 > "$pwd"/docs-${tag}.tar.bz2 +fi +if [ -d "src" ]; then + git archive --prefix='src/' --format=tar ${gittag}:src/ \ + | bzip2 > "$pwd"/src-${tag}.tar.bz2 +elif [ -d "source" ]; then + git archive --prefix='source/' --format=tar ${gittag}:source/ \ + | bzip2 > "$pwd"/source-${tag}.tar.bz2 +fi +if [ -d "tools" ]; then + git archive --prefix='tools/' --format=tar ${gittag}:tools/ \ + | bzip2 > "$pwd"/tools-${tag}.tar.bz2 +fi +if [ -d "scripts" ]; then + git archive --prefix='scripts/' --format=tar ${gittag}:scripts/ \ + | bzip2 > "$pwd"/scripts-${tag}.tar.bz2 +fi +if [ -d "modules" ]; then + git archive --prefix='modules/' --format=tar ${gittag}:modules/ \ + | bzip2 > "$pwd"/modules-${tag}.tar.bz2 +fi +if [ -d "ts" ]; then + git archive --prefix='ts/' --format=tar ${gittag}:ts/ \ + | bzip2 > "$pwd"/ts-${tag}.tar.bz2 +fi +if [ -d "build" ]; then + git archive --prefix='build/' --format=tar ${gittag}:build/ \ + | bzip2 > "$pwd"/build-${tag}.tar.bz2 +fi +if [ -d "fixtures" ]; then + git archive --prefix='fixtures/' --format=tar ${gittag}:fixtures/ \ + | bzip2 > "$pwd"/fixtures-${tag}.tar.bz2 +fi +if [ -d "mocks" ]; then + git archive --prefix='mocks/' --format=tar ${gittag}:mocks/ \ + | bzip2 > "$pwd"/mocks-${tag}.tar.bz2 +fi +if [ -d "typings" ]; then + git archive --prefix='typings/' --format=tar ${gittag}:typings/ \ + | bzip2 > "$pwd"/typings-${tag}.tar.bz2 +fi +if [ -d "templates" ]; then + git archive --prefix='templates/' --format=tar ${gittag}:templates/ \ + | bzip2 > "$pwd"/templates-${tag}.tar.bz2 +fi +popd diff --git a/nodejs-jshint.spec b/nodejs-jshint.spec new file mode 100644 index 0000000..a878a9f --- /dev/null +++ b/nodejs-jshint.spec @@ -0,0 +1,114 @@ +%{?nodejs_find_provides_and_requires} + +%global packagename jshint +# tests diabled due to missing dependencies, such as npm(phantom) +%global enable_tests 0 + +Name: nodejs-jshint +Version: 2.9.2 +Release: 3%{?dist} +Summary: Static analysis tool for JavaScript + +License: MIT +URL: https://github.com/jshint/jshint.git +Source0: https://registry.npmjs.org/%{packagename}/-/%{packagename}-%{version}.tgz +# The test files are not included in the npm tarball. +# Source{1-2} are generated by running Source10, which pulls from the upstream +# version control repository. +Source1: tests-%{version}.tar.bz2 +Source2: examples-%{version}.tar.bz2 +Source10: dl-tests.sh + + +ExclusiveArch: %{nodejs_arches} noarch +BuildArch: noarch + +BuildRequires: nodejs-packaging +%if 0%{?enable_tests} +BuildRequires: nodeunit +BuildRequires: npm(browserify) +BuildRequires: npm(phantom) +%endif + +%description +Static analysis tool for JavaScript + + +%prep +%setup -q -n package + +%nodejs_fixdep shelljs + +# setup tests and examples +%setup -q -T -D -a 1 -n package +%setup -q -T -D -a 2 -n package + + +%nodejs_fixdep cli +%nodejs_fixdep lodash +%nodejs_fixdep minimatch + +%build +# nothing to do, since we're not building a browser version of this + +%install +mkdir -p %{buildroot}%{nodejs_sitelib}/%{packagename} +cp -pr package.json data/ src/ \ + %{buildroot}%{nodejs_sitelib}/%{packagename} + +mkdir -p %{buildroot}%{nodejs_sitelib}/%{packagename}/bin +# fix the interpreter for these scripts +for file in bin/* +do + sed -i '1!b;s/env node/node/' $file +done +install -p -D -m0755 bin/* %{buildroot}%{nodejs_sitelib}/%{packagename}/bin/ + +mkdir -p %{buildroot}%{_bindir} +ln -sf %{nodejs_sitelib}/%{packagename}/bin/jshint \ + %{buildroot}%{_bindir}/jshint + +%nodejs_symlink_deps + +%check +%nodejs_symlink_deps --check +%if 0%{?enable_tests} +%{_bindir}/nodeunit tests +%{_bindir}/nodeunit tests/regression +%{_bindir}/nodeunit tests/unit +%endif + + +%files +%{!?_licensedir:%global license %doc} +%doc *.md examples/ +%license LICENSE +%{nodejs_sitelib}/%{packagename} +%{_bindir}/jshint + + + +%changelog +* Wed Aug 03 2016 Jared Smith - 2.9.2-3 +- Fix shebang lines on scripts in bindir + +* Sat Jul 30 2016 Jared Smith - 2.9.2-2 +- Relax dependency on npm(shelljs) + +* Sat Jun 18 2016 Jared Smith - 2.9.2-1 +- Update to upstream 2.9.2 release + +* Tue Jan 19 2016 Jared Smith - 2.8.0-5 +- Handle jshint binary appropriately + +* Thu Oct 22 2015 Jared Smith - 2.8.0-4 +- Fix dependency version on npm(minimatch) + +* Thu Oct 22 2015 Jared Smith - 2.8.0-3 +- Fix dependency version on npm(lodash) + +* Thu Oct 22 2015 Jared Smith - 2.8.0-2 +- Fix dependency version on npm(cli) + +* Thu Oct 15 2015 Jared Smith - 2.8.0-1 +- Initial packaging diff --git a/sources b/sources index e69de29..5fdff15 100644 --- a/sources +++ b/sources @@ -0,0 +1,3 @@ +5e2fef648f3679aa35aca42eac546f72 examples-2.9.2.tar.bz2 +a988f759e6a63353d50e8d76509fbee5 jshint-2.9.2.tgz +927a5bce78eb6e2ff614982e3bf84c93 tests-2.9.2.tar.bz2