1 // SALOME Utils : general SALOME's definitions and tools
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
24 // File : Utils_DESTRUCTEUR_GENERIQUE.cxx
25 // Author : Antoine YESSAYAN, EDF
29 void Nettoyage( void ) ;
32 # include "utilities.h"
33 # include "Utils_DESTRUCTEUR_GENERIQUE.hxx"
41 static list<DESTRUCTEUR_GENERIQUE_*> *Destructeurs=0 ;
48 * Mécanisme pour faire exécuter une seule fois DESTRUCTEUR_GENERIQUE_::Nettoyage
49 * à la fin du traitement : creation d'un singleton statique de l'objet
50 * tres specialise ATEXIT_.
52 * La création d'un objet de type ATEXIT_ entraîne l'inscription de la fonction
53 * Nettoyage() par atexit(). Il suffit donc de créer un singleton statique du type ATEXIT_
54 * pour effectuer cet enregistrement une seule fois indépendament de l'utilisateur.
61 * Allocation dynamique de Destructeurs, une liste chaînée de DESTRUCTEUR_GENERIQUE_* et enregistrement
62 * de la fonction Nettoyage() par atexit().
64 * La liste chaînée Destructeurs est détruite dans la fonction Nettoyage.
68 ASSERT (Destructeurs==0);
69 MESSAGE("Construction ATEXIT"); // message necessaire pour utiliser logger dans Nettoyage (cf.BUG KERNEL4561)
70 Destructeurs = new list<DESTRUCTEUR_GENERIQUE_*> ; // Destructeurs alloué dynamiquement (cf. ci-dessous) ,
71 // il est utilisé puis détruit par la fonction Nettoyage
72 int cr = atexit( Nettoyage ); // exécute Nettoyage lors de exit, après la destruction des données statiques !
78 MESSAGE("Destruction ATEXIT") ;
85 static ATEXIT_ nettoyage ; /* singleton statique */
89 * traitement effectué :
90 * -# exécution de tous les objets de type DESTRUCTEUR_DE_ stockés dans la liste Destructeurs (ce qui détruit les
91 * singletons correspondant) ;
92 * -# puis destruction de tous les objets de type DESTRUCTEUR_DE_ stockés dans la liste Destructeurs;
93 * -# destruction de la liste Destructeurs.
96 void Nettoyage( void )
98 BEGIN_OF("Nettoyage( void )") ;
99 ASSERT(Destructeurs) ;
100 SCRUTE( Destructeurs->size() ) ;
101 if( Destructeurs->size() )
103 list<DESTRUCTEUR_GENERIQUE_*>::iterator it = Destructeurs->end() ;
107 MESSAGE( "DESTRUCTION d'un SINGLETON") ;
109 DESTRUCTEUR_GENERIQUE_* ptr = *it ;
110 //Destructeurs->remove( *it ) ;
113 }while( it!= Destructeurs->begin() ) ;
115 Destructeurs->clear() ;
116 SCRUTE( Destructeurs->size() ) ;
117 ASSERT( Destructeurs->size()==0 ) ;
118 ASSERT( Destructeurs->empty() ) ;
123 END_OF("Nettoyage( void )") ;
129 * Adds a destruction object to the list of actions to be performed at the end
132 const int DESTRUCTEUR_GENERIQUE_::Ajout( DESTRUCTEUR_GENERIQUE_ &objet )
134 // N.B. : l'ordre de creation des SINGLETON etant important
135 // on n'utilise pas deux fois la meme position pour
136 // les stocker dans la pile des objets.
137 ASSERT(Destructeurs) ;
138 Destructeurs->push_back( &objet ) ;
139 return Destructeurs->size() ;