File xmlgraphics-fop.spec of Package xmlgraphics-fop

# spec file for package xmlgraphics-fop
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
# Copyright (c) 2000-2008, JPackage Project
# All rights reserved.
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.

# Please submit bugfixes or comments via

# norootforbuild

%define section free
%define bname fop

%bcond_with tests

Name:           xmlgraphics-fop
Version:        1.0
Release:        11
Summary:        Formatter for Printing XSLT Processed XML Files
License:        Apache-2.0
Group:          Productivity/Publishing/XML
#FIX-OPENSUSE: add xmlgraphics-commons to classpath
Source1:        %{name}.script
Source3:        %{name}-fontmetrics.script
Source4:        %{name}-fontlist.script
# Manpage(s)
Source10:       %{name}.xml
Source11:       %{name}-fontmetrics.xml
Source12:       %{name}-fontlist.xml
Patch0:         xmlgraphics-fop-build.patch
Patch1:         xmlgraphics-fop-cli.patch
Patch2:         xmlgraphics-fop-asf51789.patch
Requires(post):    jpackage-utils >= 1.7.4
Requires(postun):  jpackage-utils >= 1.7.4
Requires:       jpackage-utils >= 1.7.4
Requires:       java >= 1.5.0
Requires:       xmlgraphics-batik
Requires:       excalibur-avalon-logkit
Requires:       excalibur-avalon-framework-api
Requires:       excalibur-avalon-framework-impl
Requires:       xalan-j2
Requires:       xerces-j2
Requires:       xmlgraphics-commons
Requires:       xml-commons-jaxp-1.3-apis
BuildRequires:  unzip
BuildRequires:  jpackage-utils >= 1.7.4
BuildRequires:  java-devel >= 1.5.0
BuildRequires:  java-javadoc
BuildRequires:  ant >= 1.6.5
BuildRequires:  ant-trax
BuildRequires:  ant-junit
BuildRequires:  junit
BuildRequires:  xmlgraphics-batik
BuildRequires:  xmlgraphics-batik-javadoc
BuildRequires:  excalibur-avalon-logkit
BuildRequires:  excalibur-avalon-framework-api
BuildRequires:  excalibur-avalon-framework-impl
BuildRequires:  servlet_api
BuildRequires:  xalan-j2
BuildRequires:  xerces-j2
BuildRequires:  xmlgraphics-commons >= 1.2
BuildRequires:  xmlunit
BuildRequires:  xml-commons-jaxp-1.3-apis
BuildRequires:  qdox
BuildRequires:  docbook-xsl-stylesheets libxslt
BuildRoot:      %{_tmppath}/%{name}-%{version}-build
BuildArch:      noarch
#!BuildIgnore:  saxon
Provides:       %{bname} = %{version}-%{release}
Obsoletes:      %{bname} < %{version}-%{release}

FOP (Formatting Objects Processor) is driven by XSL formatting objects
(XSL-FO). It is a Java application that reads a formatting object (FO)
tree and renders the resulting pages to one of the following output
formats: PDF (primary output target), PCL, PS, SVG, XML (area tree
representation), Print, AWT, MIF, and TXT.

%package        javadoc
License:        Apache-2.0
Summary:        Javadoc for %{name}
Group:          Documentation/HTML

%description    javadoc
API documentation for %{name} automatically extracted from comments in source files.

%setup -q -n %{bname}-%{version} -a5 
ln -thyph offo-hyphenation/hyph/*.xml
find -name "*.jar" | xargs -t rm
%patch0 -p0 -b .build
%patch1 -p1 -b .cli
%patch2 -p1

pushd lib
ln -s $(build-classpath excalibur/avalon-framework-api)
ln -s $(build-classpath excalibur/avalon-framework-impl)
ln -s $(build-classpath commons-io)
ln -s $(build-classpath commons-logging)
ln -s $(build-classpath servlet_api)
ln -s $(build-classpath xml-commons-jaxp-1.3-apis)
ln -s $(build-classpath xml-commons-jaxp-1.3-apis-ext)
ln -s $(build-classpath xmlgraphics-batik/anim)
ln -s $(build-classpath xmlgraphics-batik/awt-util)
ln -s $(build-classpath xmlgraphics-batik/bridge)
ln -s $(build-classpath xmlgraphics-batik/css)
ln -s $(build-classpath xmlgraphics-batik/dom)
ln -s $(build-classpath xmlgraphics-batik/ext)
ln -s $(build-classpath xmlgraphics-batik/extension)
ln -s $(build-classpath xmlgraphics-batik/gvt)
ln -s $(build-classpath xmlgraphics-batik/parser)
ln -s $(build-classpath xmlgraphics-batik/svg-dom)
ln -s $(build-classpath xmlgraphics-batik/svggen)
ln -s $(build-classpath xmlgraphics-batik/script)
ln -s $(build-classpath xmlgraphics-batik/transcoder)
ln -s $(build-classpath xmlgraphics-batik/util)
ln -s $(build-classpath xmlgraphics-batik/xml)
ln -s $(build-classpath xalan-j2)
ln -s $(build-classpath xalan-j2-serializer)
ln -s $(build-classpath xerces-j2)
ln -s $(build-classpath xmlgraphics-commons)
ln -s $(build-classpath xmlunit)
ln -s $(build-classpath qdox)

cp %{SOURCE2} %{SOURCE3} %{SOURCE4} .
# Replace keyword "VERSION" in XML files with the real one:
for x in %{SOURCE10} %{SOURCE11} %{SOURCE12}; do
 sed -i "s=@VERSION@=%{version}=" $x

export OPT_JAR_LIST=`%{__cat} %{_sysconfdir}/ant.d/{junit,trax}`
%{ant} \
  -Dbatik.javadoc=%{_javadocdir}/xmlgraphics-batik \
  package \
%if %{with tests}
  junit \

# false
# Build the manpage(s) and HTML
for m in %{SOURCE10} %{SOURCE11} %{SOURCE12}; do
 xsltproc $DB/manpages/docbook.xsl $m
# Only filename for HTML is needed, remove anything before /
 xsltproc --output ${xml%%.xml}.html $DB/html/docbook.xsl $m

# jars
mkdir -p $RPM_BUILD_ROOT%{_javadir}
install -m 644 build/%{bname}.jar $RPM_BUILD_ROOT%{_javadir}/%{name}-%{version}.jar
(cd $RPM_BUILD_ROOT%{_javadir} && for jar in *-%{version}*; do ln -sf ${jar} `echo $jar| sed "s|-%{version}||g"`; done)
%add_to_maven_depmap org.apache.xmlgraphics %{bname} %{version} JPP %{name}

# pom
install -d -m 755 $RPM_BUILD_ROOT%{_datadir}/maven2/poms
install -pm 644 build/maven/pom.xml $RPM_BUILD_ROOT%{_datadir}/maven2/poms/JPP-%{name}.pom

# script
mkdir -p $RPM_BUILD_ROOT%{_bindir}
cp -p %{SOURCE1}  $RPM_BUILD_ROOT%{_bindir}/%{name}
cp -p %{SOURCE3}  $RPM_BUILD_ROOT%{_bindir}/%{name}-fontmetrics
cp -p %{SOURCE4}  $RPM_BUILD_ROOT%{_bindir}/%{name}-fontlist
# compat symlink
ln -s %{name}             %{buildroot}%{_bindir}/%{bname}
ln -s %{name}-fontmetrics %{buildroot}%{_bindir}/%{bname}-fontmetrics
ln -s %{name}-fontlist    %{buildroot}%{_bindir}/%{bname}-fontlist

# data
mkdir -p $RPM_BUILD_ROOT%{_datadir}/%{name}
cp -pr hyph $RPM_BUILD_ROOT%{_datadir}/%{name}
cp -pr conf $RPM_BUILD_ROOT%{_datadir}/%{name}

# javadoc
mkdir -p $RPM_BUILD_ROOT%{_javadocdir}/%{name}-%{version}
cp -pr build/javadocs/* $RPM_BUILD_ROOT%{_javadocdir}/%{name}-%{version}
ln -s %{name}-%{version} $RPM_BUILD_ROOT%{_javadocdir}/%{name}

# Manpages
mkdir -p $RPM_BUILD_ROOT%_mandir/man1
for m in *.1; do
  gzip $m
cp -vi *.1.gz $RPM_BUILD_ROOT%_mandir/man1

# Remove prefix xmlgraphics to make also the linked manpage version available
pushd $RPM_BUILD_ROOT%_mandir/man1
for m in *.1.gz; do
  ln -s $m ${m#*-}




%doc NOTICE LICENSE README known-issues.xml status.xml
%doc *.html

%attr(0755,root,root) %{_bindir}/%{name}
%attr(0755,root,root) %{_bindir}/%{bname}
%attr(0755,root,root) %{_bindir}/%{name}-fontmetrics
%attr(0755,root,root) %{_bindir}/%{bname}-fontmetrics
%attr(0755,root,root) %{_bindir}/%{name}-fontlist
%attr(0755,root,root) %{_bindir}/%{bname}-fontlist
%config %{_mavendepmapfragdir}/*

%files javadoc