Files correlati : Ricompilazione Demo : [ ] Commento : Riportata la versione 3.1 patch 766 git-svn-id: svn://10.65.10.50/trunk@14628 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			179 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			179 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
| #ifndef __CONFIG_H
 | ||
| #define __CONFIG_H 
 | ||
| 
 | ||
| #ifndef __ASSOC_H
 | ||
| #include <assoc.h>
 | ||
| #endif
 | ||
| 
 | ||
| // class ofstream;
 | ||
| class TConfig;
 | ||
| 
 | ||
| // questo sara' il principale, per ora non c'e'
 | ||
| #define CONFIG_GENERAL  0
 | ||
| // file campo.ini
 | ||
| #define CONFIG_INSTALL  1
 | ||
| // file parametri studio (uno per studio, per ora e' il principale)
 | ||
| #define CONFIG_STUDIO   2
 | ||
| // file parametri ditta (uno per ditta)
 | ||
| #define CONFIG_DITTA    3
 | ||
| // file conversioni archivi
 | ||
| #define CONFIG_FCONV    4
 | ||
| // file parametri utente
 | ||
| #define CONFIG_USER     5
 | ||
| // file parametri stampe
 | ||
| #define CONFIG_STAMPE   6
 | ||
| // file parametri GUI (nel senso di Graphic User Interface)
 | ||
| #define CONFIG_GUI      7
 | ||
| // file parametri workstation
 | ||
| #define CONFIG_WST      8
 | ||
| 
 | ||
| // Callback per for_each_paragraph
 | ||
| typedef int (*CONFIG_CALLBACK)(TConfig& cfg, void* jolly);
 | ||
| 
 | ||
| // @doc EXTERNAL
 | ||
| 
 | ||
| // @class TConfig | Classe per la gestione dei file di configurazione in formato
 | ||
| //                  Windows
 | ||
| //
 | ||
| // @base public | TObject
 | ||
| class TConfig : public TObject
 | ||
| 
 | ||
| // @author:(INTERNAL) Villa
 | ||
| 
 | ||
|   // @comm Sono definite alcune costanti per l'individuazione immediata di
 | ||
|   //       alcuni file particolari e di frequente uso. Tali file sono:
 | ||
|   //
 | ||
|   // @flag CONFIG_GENERAL | Questo sara' il principale, per ora non c'e'
 | ||
|   // @flag CONFIG_STUDIO | File parametri studio (uno per studio, per ora e'
 | ||
|   //                       il principale)
 | ||
|   // @flag CONFIG_DITTA | File parametri ditta (uno per ditta)
 | ||
|   // @flag CONFIG_FCONV | File conversioni archivi
 | ||
|   // @flag CONFIG_USER | File parametri utente
 | ||
|   // @flag CONFIG_STAMPE | File parametri stampe
 | ||
|   // @flag CONFIG_GOLEM | File parametri golem
 | ||
| 
 | ||
|   // @access:(INTERNAL) Private Member
 | ||
| {
 | ||
|   // @cmember:(INTERNAL) Contenuto del paragrafo
 | ||
|   TAssoc_array _data;
 | ||
|   // @cmember:(INTERNAL) Nome del file di configurazione
 | ||
|   TFilename _file;
 | ||
|   // @cmember:(INTERNAL) Indica se il paragrafo e' stato modificato (TRUE se esiste)
 | ||
|   bool _dirty;
 | ||
|   // @cmember:(INTERNAL) Indica se proteggere il TConfig da scrittura
 | ||
|   bool _write_protected;
 | ||
|   // @cmember:(INTERNAL) Indica se il paragrafo e' presente (TRUE se esiste)
 | ||
|   bool _ispresent;
 | ||
|   // @cmember:(INTERNAL) Nome del paragrafo attivo
 | ||
|   TString _paragraph;
 | ||
| 
 | ||
|   // @access Protected Member
 | ||
| protected:
 | ||
|   // @cmember Legge una riga del paragrafo
 | ||
|   bool add_line(const TString& line);
 | ||
|   // @cmember Legge i dati del paragrafo
 | ||
|   bool _read_paragraph();
 | ||
|   // @cmember Scrive i dati del paragrafo
 | ||
|   void _write_paragraph(ofstream&);
 | ||
|   // @cmember Scrive il file di configurazione
 | ||
|   void _write_file();
 | ||
|   // @cmember Inizializza il paragrafo leggendo dal file di nome <p fn > i dati
 | ||
|   void init(const char *fn, const char* pa);
 | ||
|  
 | ||
|   const char* get_varkey(const char* var, int index) const;
 | ||
| 
 | ||
|   // @access Public Memeber
 | ||
| public:
 | ||
| 
 | ||
|   // @cmember Ritorna il valore della variabile nella sezione corrente o in
 | ||
|   //          quella specificata
 | ||
|   virtual const TString& get(const char* var, const char* section = NULL, int index = -1, const char* def = "");
 | ||
| 
 | ||
|   // @cmember Ritorna il valore della variabile nella sezione corrente o in
 | ||
|   //          quella specificata (se la variabile contiene un long)
 | ||
|   long get_long(const char* var, const char* section = NULL, int index = -1, long def = 0L);
 | ||
| 
 | ||
|   // @cmember Ritorna il valore della variabile nella sezione corrente o in
 | ||
|   //          quella specificata (se la variabile contiene un long)
 | ||
|   char get_char(const char* var, const char* section = NULL, int index = -1, char def = ' ' );
 | ||
| 
 | ||
|   // @cmember Ritorna il valore della variabile nella sezione corrente o in
 | ||
|   //          quella specificata (se la variabile contiene un int)
 | ||
|   int get_int(const char* var, const char* section = NULL, int index = -1, int def = 0);
 | ||
|   
 | ||
|   // @cmember Ritorna il valore della variabile nella sezione corrente o in
 | ||
|   //          quella specificata (se la variabile contiene un bool)
 | ||
|   bool get_bool(const char* var, const char* section = NULL, int index = -1, bool def = FALSE);
 | ||
|   
 | ||
|   // @cmember Ritorna il valore del colore settato nella variabile nella
 | ||
|   //          sezione corrente o in quella specificata (COLOR = unsigned long)
 | ||
|   unsigned long get_color(const char* var, const char* section = NULL, int index = -1, unsigned long def = 0);
 | ||
|   
 | ||
|   // @cmember Setta il colore nella sezione corrente o specificata
 | ||
|   bool set_color(const char* var, unsigned long col, const char* section = NULL, bool force = TRUE, int index = -1);
 | ||
| 
 | ||
|   // @cmember Setta la variabile nella sezione corrente o specificata
 | ||
|   bool set(const char* var, const char* value, const char* section = NULL, bool force = TRUE, int index = -1);
 | ||
|   // @cmember Setta la variabile nella sezione corrente o specificata
 | ||
|   bool set(const char* var, long value, const char* section = NULL, bool force = TRUE, int index = -1);
 | ||
|   
 | ||
|   // @cmember Controlla se esite una variabile nel paragrafo attivo
 | ||
|   bool exist(const char* var, int index = -1);         
 | ||
|   
 | ||
|   // @cmember Elimina una variabile nel paragrafo attivo
 | ||
|   bool remove(const char* var, int index = -1);         
 | ||
|   
 | ||
|   // @cmember Elimina tutte le variabili nel paragrafo attivo
 | ||
|   void remove_all();
 | ||
| 
 | ||
|   // @cmember Controlla se il paragrafo corrente e' nuovo (TRUE se nuovo)
 | ||
|   bool new_paragraph() const
 | ||
|   { return !_ispresent; }
 | ||
| 
 | ||
|   // @cmember Ritorna quanti elementi dell'array nominato sono presenti nella
 | ||
|   //          sezione indicata.
 | ||
|   word items(const char* var, const char* section);
 | ||
|   
 | ||
|   // @cmember Ritorna il nome del paragrafo attivo
 | ||
|   const TString& get_paragraph() const { return _paragraph; }
 | ||
|   // @cmember Setta il paragrafo passato come quello attivo
 | ||
|   bool set_paragraph(const char* par);
 | ||
| 
 | ||
|   // @cmember Riempie pl con la lista dei paragrafi
 | ||
|   int list_paragraphs(TString_array& pl);
 | ||
|   
 | ||
|   // @cmember Riempie <p vl> con la lista dei nomi delle variabili 
 | ||
|   //          nella sezione corrente o in quella indicata; se 
 | ||
|   //          add_value e' TRUE ci mette "variabile<pipe>valore" 
 | ||
|   //          se sort=TRUE, l'array <20> ordinato per nomevar(i), altrimenti <20> in ordine HASH
 | ||
|   int list_variables(TString_array& vl, bool add_value = FALSE, const char* section = NULL, const bool sort=FALSE);
 | ||
| 
 | ||
|   // @cmember Ritorna l'intero array delle variabili della sezione 
 | ||
|   //          eventualmente specificata da <p section>
 | ||
|   TAssoc_array& list_variables(const char* section = NULL);
 | ||
|                             
 | ||
|   // @cmember Chiama cfgcb per ogni paragrafo
 | ||
|   int for_each_paragraph(CONFIG_CALLBACK cfgcb, void* jolly);
 | ||
|   
 | ||
|   // @cmember Ritorna il nome del file di configurazione
 | ||
|   const TFilename& name() const { return _file; }
 | ||
| 
 | ||
|   // @cmember Setta il valore del flag di protezione da scrittura
 | ||
|   void write_protect(const bool b = TRUE) { _write_protected = b; }
 | ||
| 
 | ||
|   // @cmember Ritorna il valore del flag di protezione da scrittura
 | ||
|   const bool is_write_protected() const { return _write_protected; }
 | ||
|   
 | ||
|   // @cmember Costruttore (il paragrafo iniziale e' il modulo corrente
 | ||
|   //          salvo diversa indicazione)
 | ||
|   TConfig(int which_config = CONFIG_GENERAL, const char* paragraph = NULL);
 | ||
|   // @cmember Costruttore (il paragrafo iniziale e' il modulo corrente
 | ||
|   //          salvo diversa indicazione)
 | ||
|   TConfig(const char* file, const char* paragraph = NULL);
 | ||
| 
 | ||
|   // @ cmember Distruttore. Riscrive il file con le modifiche se necessrio,
 | ||
|   virtual ~TConfig();
 | ||
| };
 | ||
| 
 | ||
| #endif
 |