[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