[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