Contenu
/opt/fop/{build,lib}
; Les composants
JAI contiennent libmlib_jai.so, jai_codec.jar, jai_core.jar et
mlibwrapper_jai.jar
Le paquet FOP (Formatting Objects Processor) contient un formateur d'impression guidé par les objets de formatage XSL (XSL-FO). C'est une application Java qui lit une arborescence d'objets de formatage et qui produit les pages qui en résultent vers une sortie spécifique. Les formats de sortie actuellement supportés comprennent le PDF, PCL, PostScript, SVG, XML (représentation en arborescence de zone), print, AWT, MIF et le texte ASCII. La cible de sortie principale est le PDF.
This package is known to build and work properly using an LFS-7.10 platform.
Téléchargement (HTTP) : https://archive.apache.org/dist/xmlgraphics/fop/source/fop-2.1-src.tar.gz
Somme de contrôle MD5 du téléchargement : 13b5b497dfb0ba8a01093dfc1a89d106
Taille du téléchargement : 23 Mio
Estimation de l'espace disque requis : 342 Mio
Estimation du temps de construction : 0.3 SBU
Paquets recommandés
Composants de l'API Java Advanced Imaging (JAI)
(dépend de l'architecture) :
http://download.java.net/media/jai/builds/release/1_1_3/jai-1_1_3-lib-linux-i586.tar.gz
a2cbc155ef3899bcde9c74a8035764b3
3.4 Mio
or
http://download.java.net/media/jai/builds/release/1_1_3/jai-1_1_3-lib-linux-amd64.tar.gz
4a906db35612f668aeef2c0606d7075b
3.4 Mio
JUnit-4.11 (pour lancer les tests), Système X Window (pour lancer les tests), JIMI SDK, XMLUnit, JAI Image I/O Tools, JEuclid, PMD (requiert Jaxen) et Forrest (Forrest n'est utilisé que pour construire la documentation)
Notes utilisateur : http://wiki.linuxfromscratch.org/blfs/wiki/fop
Assurez-vous que $JAVA_HOME
est
correctement paramétré avant de commencer la construction. Pour
construire les classes d'extension JIMI
SDK et/ou XMLUnit,
assurez-vous que les fichiers .jar
correspondant peuvent être trouvés par la variable d'environnement
CLASSPATH
.
Installez les composants de l'API de JAI. En tant qu'utilisateur
root
:
case `uname -m` in i?86) tar -xf ../jai-1_1_3-lib-linux-i586.tar.gz cp -v jai-1_1_3/lib/{jai*,mlibwrapper_jai.jar} $JAVA_HOME/jre/lib/ext/ cp -v jai-1_1_3/lib/libmlib_jai.so $JAVA_HOME/jre/lib/i386/ ;; x86_64) tar -xf ../jai-1_1_3-lib-linux-amd64.tar.gz cp -v jai-1_1_3/lib/{jai*,mlibwrapper_jai.jar} $JAVA_HOME/jre/lib/ext/ cp -v jai-1_1_3/lib/libmlib_jai.so $JAVA_HOME/jre/lib/amd64/ ;; esac
La commande javadoc venant avec OpenJDK 8 est devenu plus stricte qu'avant à propos de la conformité des commentaires javadoc dans le code source vers l'HTML. La documentation de FOP ne respecte pas ces standards, aussi les tests de conformité ont été désactivés. Cela peut être fait avec la commande suivante :
sed -i '\@</javad@i<arg value="-Xdoclint:none"/>' build.xml
Ensuite, compilez fop en lançant les commandes suivantes :
patch -Np1 -i ../fop-2.1-listNPE-1.patch && ant compile && ant jar-main && ant javadocs && mv build/javadocs .
Pour tester l'application, lancez ant junit-all. Les tests de césure échoueront. Pour voir une liste des autres cibles de test, utilisez ant -p. Vous devez lancer les tests depuis un X-window avec un serveur Xorg capable d'utiliser GL ou certains tests JUnit se suspendre.
Maintenant, en tant qu'utilisateur root
:
install -v -d -m755 /opt/fop-2.1 && cp -v KEYS LICENSE NOTICE README /opt/fop-2.1 && cp -va build conf examples fop* javadocs lib /opt/fop-2.1 && ln -v -sf fop-2.1 /opt/fop
ant target
: Ceci lit le fichier
build.xml
et construit les fichiers
cibles.
ln -v -sf fop-2.1
/opt/fop : Ceci est facultatif et crée un lien
symbolique pratique pour que $FOP_HOME
n'ait pas besoin d'être changé à chaque changement de version du
paquet.
Utiliser fop pour traiter de gros FO (dont les FO dérivés des sources XML de LFS) peut conduire à des erreurs de mémoire. À moins d'ajouter un paramètre à la commande java utilisée dans le script fop vous pouvez obtenir des messages similaires à ceci :
Exception in thread "main"
java.lang.OutOfMemoryError: Java heap space
Pour éviter de telles erreurs, vous devez passer un argument
supplémentaire à la commande java utilisée dans le script
fop. Ceci peut se
faire en créant un fichier ~/.foprc
(qui est sourcé par le script fop) et en ajoutant le
paramètre à la variable d'environnement FOP_OPTS
.
Le script fop
cherche une variable d'environnement FOP_HOME
pour localiser les bibliothèques de
classe fop. Vous pouvez créer
cette variable en utilisant le fichier ~/.foprc
aussi. Créez un fichier ~/.foprc
avec les commandes suivantes :
cat > ~/.foprc << "EOF"
FOP_OPTS="-Xmx<RAM_Installed>
m"
FOP_HOME="/opt/fop"
EOF
Remplacez <RAM_Installed>
avec un
nombre représentant la quantité de RAM installée dans votre
ordinateur (en mégaoctets). Par exemple, FOP_OPTS="-Xmx768m"
.
Pour inclure le script fop dans votre path, mettez à jour votre profile personnel ou du système ainsi :
PATH=$PATH:/opt/fop
L'exécution de fop peut être assez verbeuse.
Par défaut le niveau de journalisation est INFO et peut être
changé en FINEST, FINER, FINE, CONFIG, INFO, WARNING, SEVER,
ALL ou OFF. Pour ce faire, éditez $JAVA_HOME/jre/lib/logging.properties
et
changez les entrées pour .leval
et
java.util.logging.ConsoleHandler.level
à la
valeur désirée.
/opt/fop/{build,lib}
; Les composants
JAI contiennent libmlib_jai.so, jai_codec.jar, jai_core.jar et
mlibwrapper_jai.jar
Last updated on 2016-09-03 13:45:38 +0200