3c2aaeeaea
git-svn-id: svn://10.65.10.50/trunk@11842 c028cbd2-c16b-5b4b-a496-9718f37d4682
177 lines
7.0 KiB
C++
Executable File
177 lines
7.0 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 prawin.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
|
||
|
||
// 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
|
||
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
|