[Castore-commits] ParserListe.java NONE 1.1

Céline BENOIT cbenoit at adullact1.hosting.cri74.org
Mer 22 Mar 15:35:17 CET 2006


Update of /cvsroot/castore/castore-core/src/java/fr/emn/castor/documents/metier/docGenerique/soumission/resources/liste
In directory adullact1:/tmp/cvs-serv14257/src/java/fr/emn/castor/documents/metier/docGenerique/soumission/resources/liste

Added Files:
	ParserListe.java 
Log Message:
déplacement du fichier 

--- NEW FILE: ParserListe.java ---
/*
 * $Id: ParserListe.java,v 1.1 2006/03/22 14:35:15 cbenoit Exp $
 *
 * Plateforme CASTORE
 * CeCILL Copyright (C) 2005-2006 by EMN
 * Made by Stéphane Bouchet, Olivier Grouhan, Vanessa Bergere
 * 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.docGenerique.soumission.resources.liste;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.LinkedHashMap;

import org.xml.sax.Attributes;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.helpers.XMLReaderFactory;

import fr.emn.castor.common.Constants;
import fr.emn.castor.common.mutex.FileMutexManager;
import fr.emn.castor.common.mutex.Mutex;

/**
 * Classe permettant de parser une liste d'elements.
 * @author  $Author: cbenoit $
 * @version $Revision: 1.1 $
 */
public final class ParserListe extends DefaultHandler {

    /**
     * specifie si l'item en cours de lecture est une liste.
     */
    private boolean inList = false;

    /**
     * specifie si l'item en cours de lecture est un element d'une liste.
     */
    private boolean inElementList = false;

    /**
     */
    private boolean inElementValue = false;

    /**
     */
    private boolean inLabelValue = false;

    /**
     */
    private boolean isDefaultValue;

    /**
     * element de la liste par defaut.
     */
    private String defaultElemt;

    /**
     */
    private String currentValue;

    /**
     */
    private String currentLabel;

    /**
     * Liste d'elements utilises pour les champs controles.
     */
    private LinkedHashMap currentList = null;

    /**
     * le reader XML.
     */
    private XMLReader xmlReader = null;

    /**
     * le buffer de caracteres.
     */
    private StringBuffer charBuf = new StringBuffer();

    private void parse(String filePath) {
        InputStream in = null;
        try {
            this.xmlReader = XMLReaderFactory
                .createXMLReader(Constants.XML_SAX_PARSER);
            this.xmlReader.setContentHandler(this);
            this.xmlReader.setErrorHandler(this);
            String fileP = Constants.CASTOR_LISTES_PATH
                    + Constants.FILE_SEPARATOR + filePath;
            File file = new File(fileP);
            in = new FileInputStream(file);
            InputSource inputsource = new InputSource(in);
            inputsource.setSystemId(file.getAbsolutePath());
            this.xmlReader.parse(inputsource);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (in != null) {
                    in.close();
                }
            } catch (IOException e1) {
                e1.printStackTrace();
            }
        }
    }

    /**
     * Constructor.
     */
    public ParserListe(String filePath) {
        Mutex mutex = FileMutexManager.getMutexForFileCalled(filePath);
        mutex.lock();
        this.parse(filePath);
        mutex.unlock();
    }

    /**
     * @see org.xml.sax.ContentHandler
     * #startElement(java.lang.String,
     * java.lang.String, java.lang.String, org.xml.sax.Attributes)
     */
    public void startElement(
            final String uri, final String localName, final String qName,
            final Attributes attributes) throws SAXException {
        if (qName.equals("list")) {
            this.currentList = new LinkedHashMap();
            this.inList = true;
        } else if (qName.equals("element")) {
            this.inElementList = true;
            String parDefaut = null;
            this.isDefaultValue = false;
            if ((parDefaut = attributes.getValue("default")) != null) {
                if (parDefaut.equals("true")) {
                    this.isDefaultValue = true;
                }
            }
        } else if (qName.equals("value")) {
            this.inElementValue = true;
        } else if (qName.equals("label")) {
            this.inLabelValue = true;
        }
    }

    /**
     * @see org.xml.sax.ContentHandler#characters(char[], int, int)
     */
    public void characters(
            final char[] text, final int start, final int length) {
        // on recupere le texte entre les balises.
        StringBuffer buf = new StringBuffer();
        buf.append(text, start, length);
        // si on a pas vidé le buffer, on rajoute un espace entre
        // les caracteres
        // on vérifie tout de meme si on est pas au début du buffer de lecture
        // de SAX, sinon on insere un espace en trop !
        if ((this.charBuf.length() > 0) && (start != 0)) {
            this.charBuf.append(" ");
        }
        this.charBuf.append(buf.toString().trim());
    }

    /**
     * @see org.xml.sax.ContentHandler#endElement(java.lang.String, java.lang.String,java.lang.String)
     */
    public void endElement(
            final String uri, final String localName, final String qName)
            throws SAXException {
        if (this.inElementValue) {
            this.currentValue = this.charBuf.toString().trim();
            this.inElementValue = false;
        } else if (this.inLabelValue) {
            this.currentLabel = this.charBuf.toString().trim();
            this.inLabelValue = false;
        } else if (this.inElementList) {
            this.inElementList = false;
            if (this.currentLabel == null) {
                this.currentLabel = this.currentValue;
            }
            if (this.isDefaultValue) {
                this.defaultElemt = this.currentValue;
            }
            this.currentList.put(this.currentValue, this.currentLabel);
            this.currentLabel = null;
            this.currentValue = null;
        }
        this.charBuf.setLength(0);
    }

    /**
     * Retourne une liste d'elements (lu dans le fichier xml).
     * Le resultat est retourne dans une map :
     *   - les cles correspondent aux elements
     *   - les valeurs specifient si l'attribut est celui par defaut ou non
     * @return une map
     */
    public HashMap getListe() {
        return this.currentList;
    }

    public String getDefaultElement() {
        return this.defaultElemt;
    }
}



Plus d'informations sur la liste de diffusion Castore-commits