[Castore-commits] ConverterXML.java NONE 1.1
Céline BENOIT
cbenoit at adullact1.hosting.cri74.org
Mer 22 Mar 14:19:55 CET 2006
Update of /cvsroot/castore/castore-core/src/java/fr/emn/castor/documents/metier/textes/retro
In directory adullact1:/tmp/cvs-serv21948/src/java/fr/emn/castor/documents/metier/textes/retro
Added Files:
ConverterXML.java
Log Message:
déplacement et renommage du fichier
adaptation du code aux médias
--- NEW FILE: ConverterXML.java ---
/*
* $Id: ConverterXML.java,v 1.1 2006/03/22 13:19:53 cbenoit Exp $
*
* Plateforme CASTORE
* CeCILL Copyright (C) 2005-2006 by EMN
* Made by Stéphane Bouchet, Olivier Grouhan, Vanessa Bergere, Céline Benoit
* Web site = http://www.emn.fr/castore
* Contact = Cédric Dumas, e-mail = Cedric.Dumas at emn.fr
*
* Version 1.0 (1er mars 2005)
*
* Ce logiciel est un programme informatique servant à créer une plateforme
* open-source de bibliothèque numérique XML pour Conserver, Valoriser et
* Diffuser le patrimoine documentaire de votre institut.
*
* Ce logiciel est régi par la licence CeCILL soumise au droit français et
* respectant les principes de diffusion des logiciels libres. Vous pouvez
* utiliser, modifier et/ou redistribuer ce programme sous les conditions de la
* licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA sur le site
* "http://www.cecill.info". En contrepartie de l'accessibilité au code source
* et des droits de copie, de modification et de redistribution accordés par
* cette licence, il n'est offert aux utilisateurs qu'une garantie limitée. Pour
* les mêmes raisons, seule une responsabilité restreinte pèse sur l'auteur du
* programme, le titulaire des droits patrimoniaux et les concédants successifs.
* A cet égard l'attention de l'utilisateur est attirée sur les risques associés
* au chargement, à l'utilisation, à la modification et/ou au développement et à
* la reproduction du logiciel par l'utilisateur étant donné sa spécificité de
* logiciel libre, qui peut le rendre complexe à manipuler et qui le réserve
* donc à des développeurs et des professionnels avertis possédant des
* connaissances informatiques approfondies. Les utilisateurs sont donc invités
* à charger et tester l'adéquation du logiciel à leurs besoins dans des
* conditions permettant d'assurer la sécurité de leurs systèmes et ou de leurs
* données et, plus généralement, à l'utiliser et l'exploiter dans les mêmes
* conditions de sécurité. Le fait que vous puissiez accéder à cet en-tête
* signifie que vous avez pris connaissance de la licence CeCILL, et que vous en
* avez accepté les termes.
*
*/
package fr.emn.castor.documents.metier.textes.retro;
import java.io.File;
import java.util.Collection;
import fr.emn.castor.common.Constants;
import fr.emn.castor.common.PropertiesHelper;
import fr.emn.castor.common.Utils;
import fr.emn.castor.documents.DocumentsConstants;
import fr.emn.castor.documents.metier.docGenerique.conversion.AConverter;
/**
* Classe de retro-conversion de documents texte en XML.
*
* @author $Author: cbenoit $
* @version $Revision: 1.1 $
*/
public final class ConverterXML extends AConverter {
/** l'instance du converteur.*/
private static ConverterXML instance = null;
/**
* Constructeur.
*/
private ConverterXML() {
super();
// création de la Map contenant les extensions lisibles par OOo
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.doc"), "Word");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.odt"), "Word");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.sxw"), "Word");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.html"), "HTML");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.htm"), "HTML");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.xhtml"), "HTML");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.rtf"), "Word");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.sdw"), "Word");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.vor"), "Word");
this.filesExtensionsAccepted.put(PropertiesHelper.getProperty(
DocumentsConstants.EXTENSION, "ext.txt"), "InputStream");
}
/**
* Returns the singleton instance.
* @return the singleton instance
*/
public static ConverterXML getInstance() {
if (instance == null) {
instance = new ConverterXML();
}
return instance;
}
/**
* Methode ordonnant la conversion du document, suivant son type.
*
* @param idDoc l'identifiant du document.
* @param format le format du document. On s'appuie sur les formats connus
* de OpenOffice.
* @param fsUsed la feuille de style utilisée (ex : /emn-castore-eleves-s4s.xslt)
*/
public void convert(
final String idDoc, final String format, final String fsUsed) {
String inputFormat;
if (this.filesExtensionsAccepted.containsKey(format)) {
inputFormat = this.filesExtensionsAccepted.get(format);
if (log.isDebugEnabled() ) {
log.debug("Retro conversion " + inputFormat + ", Extension : "
+ format);
}
ConverterThread thread = new ConverterThread(
idDoc, inputFormat, fsUsed);
thread.start();
this.fonds.setConvStatut(
idDoc, DocumentsConstants.CONVERSION_RUNNING);
} else {
if (log.isErrorEnabled()) {
log.error("Format non supporté :" + format);
}
this.fonds
.setConvStatut(idDoc, DocumentsConstants.CONVERSION_ERROR);
}
}
/**
* Methode renvoyant les fichier XML de transformation, sous forme de Map.
* Ceux-ci sont issus de la transformation d'une feuille de style
* quelconque en XML via un convertisseur specifique.
* @return une collection de fichiers de transformation.
*/
public Collection getS4sFiles() {
TransFilesParser parser = new TransFilesParser("s4s.xml");
return parser.getFiles();
}
/**
* Methode supprimant les residus de la retro-conversion.
* @param idDoc le document dont les residus sont a nettoyer
* @param cleanPic indique si on veux supprimer le repertoire
* contenant les images
* @return <code>true</code> si l'operation s'est bien déroulée
*/
public boolean cleanConv(final String idDoc, final boolean cleanPic) {
boolean okTmp = true;
boolean okPic = true;
// suppression des repertoires de retro-conversion contenu dans le dossier "temp"
File tmpDir = new File(this.fonds.getPathForId(idDoc)
+ Constants.FILE_SEPARATOR + "tmp");
if (tmpDir.exists()) {
okTmp = Utils.deleteDirectory(tmpDir);
}
if (cleanPic) {
File picDir = new File(this.fonds.getPathForId(idDoc)
+ Constants.FILE_SEPARATOR + "Pictures");
if (picDir.exists()) {
okPic = Utils.deleteDirectory(picDir);
}
}
return (okTmp && okPic);
}
}
Plus d'informations sur la liste de diffusion Castore-commits