[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