forked from pool/parboiled
This commit is contained in:
@@ -16,31 +16,58 @@
|
||||
#
|
||||
|
||||
|
||||
%global flavor @BUILD_FLAVOR@%{nil}
|
||||
%if "%{flavor}" == "scala"
|
||||
%bcond_without scala
|
||||
%else
|
||||
%bcond_with scala
|
||||
%endif
|
||||
%global scala_short_version 2.10
|
||||
Name: parboiled
|
||||
Version: 1.1.6
|
||||
Release: 0
|
||||
%global base_name parboiled
|
||||
%if %{with scala}
|
||||
Name: %{base_name}-scala
|
||||
Summary: Parboiled for Scala
|
||||
License: Apache-2.0
|
||||
Group: Development/Libraries/Java
|
||||
%else
|
||||
Name: %{base_name}
|
||||
Summary: Java/Scala library providing parsing of input text based on PEGs
|
||||
License: Apache-2.0
|
||||
Group: Development/Libraries/Java
|
||||
%endif
|
||||
Version: 1.1.6
|
||||
Release: 0
|
||||
URL: http://parboiled.org/
|
||||
Source0: https://github.com/sirthias/parboiled/archive/%{version}.tar.gz
|
||||
Source1: %{name}-%{version}-build.tar.xz
|
||||
Source1: %{base_name}-%{version}-build.tar.xz
|
||||
# for build see https://github.com/sirthias/parboiled/wiki/Building-parboiled
|
||||
Source2: http://repo1.maven.org/maven2/org/parboiled/%{name}-core/%{version}/%{name}-core-%{version}.pom
|
||||
Source3: http://repo1.maven.org/maven2/org/parboiled/%{name}-java/%{version}/%{name}-java-%{version}.pom
|
||||
Source2: http://repo1.maven.org/maven2/org/parboiled/%{base_name}-core/%{version}/%{base_name}-core-%{version}.pom
|
||||
Source3: http://repo1.maven.org/maven2/org/parboiled/%{base_name}-java/%{version}/%{base_name}-java-%{version}.pom
|
||||
Source4: http://repo1.maven.org/maven2/org/parboiled/%{base_name}-scala_%{scala_short_version}/%{version}/%{base_name}-scala_%{scala_short_version}-%{version}.pom
|
||||
Patch0: parboiled-port-to-objectweb-asm-5.0.1.patch
|
||||
BuildRequires: ant
|
||||
BuildRequires: fdupes
|
||||
BuildRequires: javapackages-local
|
||||
%if %{with scala}
|
||||
BuildRequires: ant-scala
|
||||
BuildRequires: parboiled
|
||||
BuildConflicts: java-devel >= 9
|
||||
Requires: mvn(org.parboiled:parboiled-core) = %{version}
|
||||
Requires: mvn(org.scala-lang:scala-library)
|
||||
%else
|
||||
BuildRequires: objectweb-asm
|
||||
Requires: mvn(org.ow2.asm:asm)
|
||||
Requires: mvn(org.ow2.asm:asm-analysis)
|
||||
Requires: mvn(org.ow2.asm:asm-tree)
|
||||
Requires: mvn(org.ow2.asm:asm-util)
|
||||
%endif
|
||||
BuildArch: noarch
|
||||
|
||||
%description
|
||||
%if %{with scala}
|
||||
An internal Scala DSL for efficiently defining your parser rules.
|
||||
|
||||
%endif
|
||||
parboiled is a mixed Java/Scala library providing parsing of
|
||||
arbitrary input text based on Parsing expression grammars (PEGs).
|
||||
PEGs are an alternative to context free grammars (CFGs) for formally
|
||||
@@ -56,34 +83,49 @@ Group: Documentation/HTML
|
||||
This package contains javadoc for %{name}.
|
||||
|
||||
%prep
|
||||
%setup -q -a1
|
||||
%setup -q -n %{base_name}-%{version} -a1
|
||||
|
||||
find . -name "*.class" -delete
|
||||
find . -name "*.jar" -delete
|
||||
|
||||
%patch0 -p1
|
||||
|
||||
cp %{SOURCE2} %{base_name}-core/pom.xml
|
||||
cp %{SOURCE3} %{base_name}-java/pom.xml
|
||||
cp %{SOURCE4} %{base_name}-scala/pom.xml
|
||||
|
||||
%build
|
||||
mkdir -p lib
|
||||
build-jar-repository -s lib objectweb-asm
|
||||
%{ant} package javadoc
|
||||
build-jar-repository -s lib \
|
||||
%if %{with scala}
|
||||
%{base_name}
|
||||
%else
|
||||
objectweb-asm
|
||||
%endif
|
||||
%{ant} \
|
||||
%if %{with scala}
|
||||
-Dscala.libDir=%{_datadir}/scala/lib \
|
||||
-f build-scala.xml \
|
||||
%endif
|
||||
package javadoc
|
||||
|
||||
%install
|
||||
# jars
|
||||
install -dm 0755 %{buildroot}%{_javadir}/%{name}
|
||||
for i in core java; do
|
||||
install -pm 0644 %{name}-${i}/target/%{name}-${i}*%{version}.jar %{buildroot}%{_javadir}/%{name}/${i}.jar
|
||||
done
|
||||
# poms
|
||||
install -dm 0755 %{buildroot}%{_mavenpomdir}/%{name}
|
||||
install -pm 0644 %{SOURCE2} %{buildroot}%{_mavenpomdir}/%{name}/core.pom
|
||||
%add_maven_depmap %{name}/core.pom %{name}/core.jar
|
||||
install -pm 0644 %{SOURCE3} %{buildroot}%{_mavenpomdir}/%{name}/java.pom
|
||||
%add_maven_depmap %{name}/java.pom %{name}/java.jar
|
||||
# javadoc
|
||||
for i in core java; do
|
||||
install -dm 0755 %{buildroot}%{_javadocdir}/%{name}/${i}
|
||||
cp -pr %{name}-${i}/target/site/apidocs/* %{buildroot}%{_javadocdir}/%{name}/${i}/
|
||||
%if %{with scala}
|
||||
%global modules scala
|
||||
%else
|
||||
%global modules core java
|
||||
%endif
|
||||
install -dm 0755 %{buildroot}%{_javadir}/%{base_name}
|
||||
install -dm 0755 %{buildroot}%{_mavenpomdir}/%{base_name}
|
||||
for i in %{modules}; do
|
||||
# jar
|
||||
install -pm 0644 %{base_name}-${i}/target/%{base_name}-${i}*%{version}.jar %{buildroot}%{_javadir}/%{base_name}/${i}.jar
|
||||
# pom
|
||||
install -pm 0644 %{base_name}-${i}/pom.xml %{buildroot}%{_mavenpomdir}/%{base_name}/${i}.pom
|
||||
%add_maven_depmap %{base_name}/${i}.pom %{base_name}/${i}.jar
|
||||
# javadoc
|
||||
install -dm 0755 %{buildroot}%{_javadocdir}/%{base_name}/${i}
|
||||
cp -pr %{base_name}-${i}/target/site/apidocs/* %{buildroot}%{_javadocdir}/%{base_name}/${i}/
|
||||
done
|
||||
%fdupes -s %{buildroot}%{_javadocdir}
|
||||
|
||||
@@ -93,6 +135,6 @@ done
|
||||
|
||||
%files javadoc
|
||||
%license LICENSE
|
||||
%{_javadocdir}/%{name}
|
||||
%{_javadocdir}/%{base_name}
|
||||
|
||||
%changelog
|
||||
|
Reference in New Issue
Block a user