[Castore-commits] ListUpdaterThread.java NONE 1.1
Céline BENOIT
cbenoit at adullact1.hosting.cri74.org
Mer 22 Mar 15:32:08 CET 2006
Update of /cvsroot/castore/castore-core/src/java/fr/emn/castor/documents/metier/docGenerique/soumission/resources/liste
In directory adullact1:/tmp/cvs-serv11427/src/java/fr/emn/castor/documents/metier/docGenerique/soumission/resources/liste
Added Files:
ListUpdaterThread.java
Log Message:
déplacement du fichier
--- NEW FILE: ListUpdaterThread.java ---
/*
* $Id: ListUpdaterThread.java,v 1.1 2006/03/22 14:32:06 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.util.Map;
import fr.emn.castor.common.Constants;
import fr.emn.castor.common.mutex.FileMutexManager;
import fr.emn.castor.common.mutex.Mutex;
/**
* Thread permettant la mise a jour des fichiers xml des listes. Pour le moment,
* on ne met a jour que les valeurs (pas les labels)
*
* @author $Author: cbenoit $
* @version $Revision: 1.1 $
*/
public class ListUpdaterThread extends Thread {
/**
* Path du fichier xml.
*/
private String listFile;
/**
* Gestionaire d'exclusion mutuelle associe au fichier.
*/
private Mutex mutex;
/**
* valeurs a editer eventuellement.
*/
private String[] valeur;
/**
* nombre de valeurs a editer eventuellement.
*/
private int nbValeurs = 0;
/**
* Constructeur.
*
* @param xmlFile path du fichier xml de liste
* @param newValue nouvelles valeurs potentielles
* (a verifier lors de la mise a jour)
*/
public ListUpdaterThread(final String xmlFile, final String[] newValue) {
this.listFile = this.getListPath() + "/" + xmlFile;
//recuperation du mutex associe au fichier
this.mutex = FileMutexManager.getMutexForFileCalled(xmlFile);
if (newValue != null) {
this.valeur = newValue;
this.nbValeurs = newValue.length;
}
}
/**
* Mise a jour de la liste xml.
*
* @throws Exception erreur lors de la mise a jour
*/
private void update() throws Exception {
//creation d'un gestionnaire d'ecriture sur le fichier xml
WriterListe writer = new WriterListe(new File(this.listFile));
//recuperation des elements xml
Map oldList = writer.getContentOfList();
//on scanne les valeurs et on regarde si elles existent ou non
for (int i = 0; i < this.nbValeurs; i++) {
if (!oldList.containsKey(this.valeur[i])) {
//si la valeur n'existe pas, on l'ecrie dans le fichier
writer.addNewElement(this.valeur[i]);
}
}
}
/**
* Methode permettant de retrouver le path des fichiers de liste.
*
* @return le path dans le systeme de fichier où se trouve ces fichiers.
*/
public String getListPath() {
return Constants.CASTOR_LISTES_PATH;
}
/**
* @see java.lang.Thread#start()
*/
public synchronized void start() {
//recuperation d'un droit d'acces au fichier
this.mutex.lock();
//droit d'acces accorde
try {
//traitement
this.update();
} catch (Exception e) {
} finally {
//restitution du droit d'acces
this.mutex.unlock();
}
}
}
Plus d'informations sur la liste de diffusion Castore-commits