campo-sirio/mg/mglib.h

707 lines
25 KiB
C
Raw Normal View History

// *******************************
// LIBRERIA di magazzino
// *******************************
#ifndef __MGLIB_H
#define __MGLIB_H
#ifndef __MULTIREC_H
#include <multirec.h>
#endif
#ifndef __MASK_H
#include <mask.h>
#endif
#ifndef __FORM_H
#include <form.h>
#endif
#ifndef __ANAMAG_H
#include "anamag.h"
#endif
#ifndef __UMART_H
#include "umart.h"
#endif
#ifndef __CODCORR_H
#include "codcorr.h"
#endif
#ifndef __DESLIN_H
#include "deslin.h"
#endif
#ifndef __MAG_H
#include "mag.h"
#endif
#ifndef __STOMAG_H
#include "stomag.h"
#endif
#ifndef __MOVMAG_H
#include "movmag.h"
#endif
#ifndef __RMOVMAG_H
#include "rmovmag.h"
#endif
// campi comuni alla maschere di magazzino
typedef enum {
riga_dadocumento='D', // derivata da documento
riga_automatica='A', // generata da causale collegata
riga_nongenerata=' ' // immissione direttta del mov.
} TTipo_rigamovmag;
extern char* Nome_valorizz[16];
typedef enum {
valorizz_ultcos,
valorizz_mediacos,
valorizz_przlist,
valorizz_coststd,
valorizz_costmedio,
valorizz_costmediopond,
valorizz_FIFOa,
valorizz_LIFOa,
valorizz_FIFO,
valorizz_LIFO,
valorizz_FIFOr,
valorizz_LIFOr
} TTipo_valorizz;
class TArticolo : public TMultiple_rectype
{
protected:
TString _codice;
// la get_str supporta anche la sintassi:
// #LF->fieldname
// oppure:
// #LF_par1->fieldname
// dove:
// LF = numero logico del sottofile collegato (LF_UMART, LF_DESLIN, LF_CODCORR
// par1 = chiave dell'indice del file collegato
// se par1 comincia con '#', esso indica il numero progressivo nell'indice
// (es:#49_#1: prima unit<69> di misura)
// fieldname = nome del campo nel file collegato
virtual const TString & get_str(const char* fieldname) const ;
virtual void set_body_key(TRectype & rowrec);
public:
virtual int read(const char * cod, word op = _isequal, word lockop = _nolock);
virtual int read(TRectype & rec, word op = _isequal, word lockop = _nolock);
virtual TObject* dup() const { return new TArticolo(codice()); }
// restituisce il codice (e' un reference "sicuro" ad una stringa interna)
const TString& codice() const;
const TString& descrizione(const char * lingua = NULL) const;
bool unlock() ;
bool lock_and_prompt(const char * cod) ;
void update_ultcosti(const real& costo, const TDate& data, long numreg, int numrig);
void set_prezzo_vendita(const real& prezzo, const char* um = NULL);
int find_um(const char * um, int from = 0) const { return find(LF_UMART, UMART_UM, um, from); }
int find_deslin(const char * deslin, int from = 0) const { return find(LF_DESLIN, DESLIN_CODLIN, deslin, from); }
int find_codcorr(const char * codcorr, int from = 0) const { return find(LF_CODCORR, CODCORR_CODARTALT, codcorr, from); }
real convert_to_um(const real& v, const char * to_um, const char* from_um = NULL);
TRecord_array & um() const { return body(LF_UMART); }
TRecord_array & deslin() const { return body(LF_DESLIN); }
TRecord_array & codcorr() const { return body(LF_CODCORR); }
TArticolo(const char* codice = NULL);
TArticolo(const TRectype& rec);
virtual ~TArticolo();
};
class TArticolo_giacenza : public TArticolo
{
TString16 _anno_mag;
TString16 _anno_sto;
protected:
// la get_str supporta anche la sintassi:
// #LF->fieldname
// #LF_par1->fieldname
// #LF_par1_par2->fieldname
// #LF_par1_par2_par3->fieldname
// dove:
// LF = numero logico del sottofile collegato (LF_UMART, LF_DESLIN, LF_CODCORR
// par1, par2, par3 = varie parti della chiave dell'indice del file collegato
// il numero di queste parti ed il loro valore dipende dal file collegato
// se parX comincia per # rappresenta il numero progressivo nell'indice
// fieldname = nome del campo nel file collegato
virtual const TString & get_str(const char* fieldname) const ;
virtual void set_body_key(TRectype & rowrec);
void set_anno_mag (const char * anno = NULL);
void set_anno_sto (const char * anno = NULL);
void reset_anno_mag () { set_anno_mag();}
void reset_anno_sto () { set_anno_sto();}
bool is_last_esercizio(const char* annoes) const;
void copia_storico(TRecord_array& nrstorico, const char * annoes,const char * codmag);
void add_storico(TRecord_array& nrstorico, const char * annoes,const char * codmag, const real & qta, const real & prz);
public:
virtual TObject* dup() const { return new TArticolo_giacenza(codice()); }
virtual void zero(char c = '\0');
int find_mag(TRecord_array& rmag, const char * codmag = NULL, const char * livello = NULL, int from = 0) const ;
int find_storico(TRecord_array& rsto, const char * codmag = NULL, int from = 0) const;
int find_mag(const char * annoes, const char * codmag = NULL, const char * livello = NULL, int from = 0) const ;
int find_storico(const char * annoesrif, const char * codmag = NULL, int from = 0) const;
TRecord_array & mag(const char * annoes) const;
TRecord_array & storico(const char * annoesrif) const;
// calcola disponibilit<69> (anche complessiva su pi<70> depositi o magazzini)
// solo_giac indica di fare il calcolo della sola giacenza
real disponibilita(const char * annoes, const char * codmag, const char * livello, bool solo_giac=FALSE) const;
// La seguente funzione riporta le rimanenze finali dell'esercizio oldes come
// rimanenze iniziali dell'esercizio newes, valorizzando secondo il tipo passato
// Si suppone che i saldi siano coerenti con i movimenti (effettuare una rebuild_balances()
// di oldes.
bool riporta_saldi(const char * oldes, const char* newes, const TTipo_valorizz tipo,
const char * catven ,const char * codlist, bool save_to_disk = TRUE);
// La seguente funzione azzera tutti i saldi di mgazzino per l'esercizio cod_es
bool azzera_saldi(const char* cod_es, bool save_to_disk = TRUE);
// valorizzazioni
real ultimo_costo(const char * annoes) const;
real media_costi(const char * annoes) const;
real prezzo_listino(const char * annoes, const char * catven ,const char * codlist) const;
real costo_standard(const char * annoes) const;
real costo_medio(const char * annoes, const char * codmag, const char * livello) const;
real costo_mediopond(const char * annoes, const char * codmag, const char * livello) const;
real LIFO_annuale(const char * annoes, const char * codmag, const char * livello,
bool giacenza_effettiva = TRUE, bool valorizza_componenti = TRUE) const;
real FIFO_annuale(const char * annoes, const char * codmag, const char * livello,
bool giacenza_effettiva = TRUE, bool valorizza_componenti = TRUE) const;
real LIFO(const char * annoes, const char * codmag, const char * livello,
bool giacenza_effettiva = TRUE, bool valorizza_componenti = TRUE) const;
real FIFO(const char * annoes, const char * codmag, const char * livello,
bool giacenza_effettiva = TRUE, bool valorizza_componenti = TRUE) const;
real LIFO_ragionieristico(const char * annoes, const char * codmag, const char * livello,
bool giacenza_effettiva = TRUE, bool valorizza_componenti = TRUE) const;
real FIFO_ragionieristico(const char * annoes, const char * codmag, const char * livello,
bool giacenza_effettiva = TRUE, bool valorizza_componenti = TRUE) const;
void agg_storicoLIFO (const char * annoes, const char * codmag, bool giac_eff, bool valorizza_componenti) ;
void agg_storicoFIFO (const char * annoes, const char * codmag, bool giac_eff, bool valorizza_componenti) ;
void agg_storico(const char * annoes, const char * codmag, bool giac_eff, bool valorizza_componenti, const real& val) ;
real giacenza_corretta(const TRectype & rec ,bool giacenza_effettiva,bool valorizza_componenti) const ;
void put_ultimo_costo(const real& costo, const TDate& data);
void put_costo_standard(const real& costo);
real giacenza_anno(const char* codmag, const char* livello, int anno) const;
real scorta_minima(const char* codmag, const char* livello, int anno=0, bool liv_riordino=FALSE) const;
long lead_time(const char* codmag, const char* livello, int anno=0) const;
TArticolo_giacenza(const char* codice = NULL);
TArticolo_giacenza(const TRectype& rec);
virtual ~TArticolo_giacenza() {}
};
class TArticolo_giacenza_data : public TArticolo_giacenza
{
protected:
virtual int write(TBaseisamfile&) const;
virtual int rewrite(TBaseisamfile&) const;
virtual int remove(TBaseisamfile&) const;
public:
void al(const TDate& data, const char* codmag = NULL, const char* livello = NULL,
TTipo_valorizz tipo = valorizz_costmedio, const char* catven = NULL, const char* codlis = NULL);
TArticolo_giacenza_data(const char* codice = NULL);
TArticolo_giacenza_data(const TRectype& rec);
};
class TArticolo_giacenza_loadable : public TArticolo_giacenza_data
{
public:
void load(TIsamtempfile& f);
TArticolo_giacenza_loadable(const char* codice = NULL);
TArticolo_giacenza_loadable(const TRectype& rec);
};
// *******************************
// LIBRERIA DI utility del magazzino
// *******************************
#define MAX_COD_LEVELS 10
class TR_automa;
class TMetachar : public TObject
{
TR_automa * _au;
TString _language;
char _metach_mand[10];
char _metach_opz[10];
void set_language(const char * language); // setta l'automa che ricosce il linguaggio passato
void add_tran(int statenum,unsigned char symbol,int next);// aggiunge le transizioni all'automa
public:
// @cmember restituisce la lunghezza massima della stringa che soddisfa il formato passato
static int maxstrlen(const char * format);
const char * language() const; // restituisce la stringa di metacaratteri del linguaggio riconosciuto
bool recognized(const char * pattern);
bool has_opzchars(const char * pattern);
bool has_mandchars(const char * pattern);
const char *mand_chars() {return _metach_mand;};
const char *opz_chars() {return _metach_opz;};
TMetachar(const char * str);
TMetachar();
virtual ~TMetachar();
};
class TCodice_livelli : public TObject
{
long _last_firm;
bool _autoinsert[MAX_COD_LEVELS];
bool _codiceadata[MAX_COD_LEVELS];
int _code_length[MAX_COD_LEVELS];
TString _name[MAX_COD_LEVELS];
TString _picture[MAX_COD_LEVELS];
int _last_level;
TDecoder *_gruppi;
protected:
bool _lev_enabled;
TArray _metachars;
void load(bool e, const char *tabcod,const char *tabgrp);
void add_metachar(int lev);
void update_firm();
void test_firm();
public:
// Ritorna il numero massimo di livelli possibili
virtual inline int max_levels() const {return MAX_COD_LEVELS;}
// Ritorna il numero di livelli abilitati
int last_level() const { return enabled() ? _last_level : 0; }
// Abilita la gestione dei livelli
void enable(bool on=TRUE) ;
// Ritorna se la gestione dei livelli <20> abilitata
const bool enabled() const ;
// Ritorna se il livello specificato <20> abilitato
const bool enabled(int levnum) const ;
// Ritorna il nome (descrizione) di quel livello
const TString & name(int levnum) const ;
// Ritorna la stringa di picture per i codici gruppo di quel livello
const TString & picture(int levnum) const;
// Ritorna la lunghezza dei codici gruppo di quel livello
const int code_length(int levnum) const ;
// Ritorna la posizione iniziale del codice gruppo di quel livello
const int code_start(int levnum) const ;
// Ritorna la lunghezza del codice compatto fino a quel livello
const int packed_length(int levnum) const ;
// Restituisce se esiste il gruppo dato il codice (compatto e non)
const int group_search(const char * code, int levnum) const;
const int group_search_packed(const char * packed_code, int levnum) const;
// Restituisce la descrizione del gruppo dato il codice (compatto e non)
const TString & group_descr(const char * code, int levnum) const;
const TString & group_descr_packed(const char * packed_code, int levnum) const;
// Setta il prompt del campo sulla maschera
void set_mask_field(TMask &m,int field, int lev) const;
// Setta i prompt dei campi livelli di codice sulla maschera
void set_mask_fields(TMask &m,int firstfield) const;
// Setta la colonna del campo livello codice di uno sheet in base alle abilitazioni
void set_sheetcolumn(TSheet_field &fld_righe,int field, int lev) const;
// Setta le colonne dei campi livello codice di uno sheet in base alle abilitazioni
void set_sheet_columns(TSheet_field &sht, short dlg) const;
// costruisce il codice compatto e viceversa
void pack_maskgrpcodes(TString & pc, const TMask & m, int field, int level);
void pack_grpcode(TString & pc, const TString &codlev, const int levnum); // Inserisce il codice del gruppo del livello levnum in pc
TString unpack_grpcode(const TString & pc, const int levnum) const ; // Estrae il codice del gruppo del livello levnum da pc
// costruisce il codice della tabella di decodifica dei livelli
TString build_tabcode(const TString & code, const int levnum) const ;
TString build_tabcode_packed(const TString & pcode, const int levnum) const ;
// Restituisce il formato previsto per il codice (default==ultimo livello)
const char* code_format(int levnum=-1) const ;
// Restituisce se <p codepart> e' riconosciuto come codice articolo (default==ultimo livello)
bool fit_to_format(const char *codepart, int levnum=-1) const ;
// Ritorna se il livello <20> abilitato all'autoinserimento
const bool autoinsert (int levnum) const ;
// Tenta l'autoinserimento; Ritorna se l'operazione ha avuto successo
const bool autoinsert(int levnum, TString & newcode) const;
const bool autoinsert(int levnum, TMask_field & fld) const;
// Ritorna se il codice del livello rappresenta una data
const bool codiceadata(int levnum) const ;
/* bool has_mandchars(const char * pattern);
bool has_opzchars(const char * pattern);
const char * opz_chars();
const char * mand_chars();*/
virtual void init() pure;
TCodice_livelli(); // costruttore
virtual ~TCodice_livelli(); // distruttore
};
class TCodart_livelli : public TCodice_livelli
{
public:
virtual inline int max_levels() const {return 10;}
virtual void init();
TCodart_livelli(); // costruttore
virtual ~TCodart_livelli() ; // distruttore
};
class TCodgiac_livelli : public TCodice_livelli
{
public:
virtual inline int max_levels() const {return 4;}
virtual void init();
TCodgiac_livelli(); // costruttore
virtual ~TCodgiac_livelli() {}; // distruttore
};
// *********************
// classe che incapsula tutti i magazzini
class TMagazzini : public TRecord_cache
{
long _last_firm;
TString16 _stdmag;
TString16 _stddep;
TConfig *_mgconfig;
bool _gestmag ;
bool _gestdep ;
char _gestubi ;
bool _gestmultimag;
private:
void init();
void test_firm() const;
public:
const TString & standardmag() const
{test_firm() ; return _stdmag;}
const TString & standarddep() const
{test_firm() ; return _stddep;}
bool gestmag(bool verbose=FALSE) const ;
bool gestdep() const ;
bool gestubi_man() const ;
bool gestubi_tab() const ;
bool gestmultimag() const ;
TMagazzini();
virtual ~TMagazzini();
};
// *********************
// classe che incapsula le causali di magazzino (record della tabella CAU)
typedef enum
{
s_giac,
s_acq,s_ent,
s_ven,s_usc,
s_ordc,s_ordf,
s_acl,s_incl,
s_prodc,s_prodf,
s_rim,
s_scart,
s_label,
s_user1,
s_user2,
s_user3,
s_user4,
s_user5,
s_user6
} TTipo_saldomag;
class TCausale_magazzino : public TRectype
{
public:
const TString & codice() const {return get("CODTAB");}
const TString & descr() const {return get("S0");}
char tipoprz() const {return get_char("S6");}
char tipomov() const {return get_char("S7");}
const TString & raggfisc() const {return get("S8");}
const TString & caus_collegata() const {return get("S9");}
int sgn(TTipo_saldomag fieldname) const;
bool update_qta() const {return !get_bool("B1");}
bool update_val() const {return !get_bool("B0");}
bool update_ultcos() const {return get_bool("B2");}
bool esplodente() const {return get_bool("B3");}
bool scarica_artprod() const {return get_bool("B4");}
bool movimenta_sospesi() const {return get_bool("B5");}
const TString & default_magdep() const {return get("S10");}
const char *default_mag() const {return get("S10").mid(0,3);}
const char *default_dep() const {return get("S10").mid(3,2);}
bool has_default_mag() const {return *default_mag() > ' '; }
bool has_default_dep() const {return *default_dep() > ' '; }
bool is_fiscale();
TCausale_magazzino(const char * codice);
TCausale_magazzino(const TRectype &r);
virtual ~TCausale_magazzino() {}
};
class TLine_movmag;
// classe per la definizione dei movimenti di magazzino
// ( un movimento (testata+righe) == un oggetto TMov_mag )
class TMov_mag : public TMultiple_rectype
{
static TCausale_magazzino *_causmag;
//
TString16 _annoes; // codice esercizio del movimento
TDate _datacomp; // data di competenza
//
TArticolo_giacenza curr_art;
TAssoc_array lines_to_add;
TAssoc_array lines_to_subtract;
protected:
virtual void load_rows_file(int logicnum);
virtual void set_body_key(TRectype & rowrec);
virtual bool key_complete();
virtual bool renum(); // rinumerazione ;
// ************ gestione saldi
// @member: compone le parti chiave + dati a partire dalla riga dello sheet
void line2key_data(int numriga, TToken_string &key,TLine_movmag &rest) const;
// @member: compone la chiave a partire dalla riga dello sheet
TToken_string & line2key(int numriga) const;
// @member: compone la dati a partire dalla riga dello sheet
TLine_movmag& line2data(int numriga) const;
// @member: estrae dalla Tokenstring della chiave i valori corrispondenti ai campi del file
static TString key2field(TToken_string &key,const char * f);
// @member: memorizza la linea come "da togliere"
int line_deleted(TToken_string &key,TLine_movmag &rest);
// @member: memorizza la linea come "da aggiungere"
int line_inserted(TToken_string &key,TLine_movmag &rest);
// @member: memorizza le linee attuali: tutte da togliere e nessuna da aggiungere (o viceversa)
void mark_current_lines(const bool as_deleted=TRUE);
// @member: effettua l'aggiornamento dei saldi relativi alle giacenze interessate al movimento
int update_balances() ;
// @member: effettua l'aggiornamento dei saldi di una giacenza
int update_balances(TRectype & magrec, const TLine_movmag &l,int sign) ;
// @member: effettua l'aggiornamento di un saldo di una giacenza
void update_balance(TRectype & magrec, const char * fieldname, real diff) const;
static void giac_putkey(TLocalisamfile & mag,TString16 annoes,TToken_string curr_key);
static bool lock_anamag(const char *codart);
static bool unlock_anamag(const char *codart) ;
virtual const char * codmag_rauto(int r) const { return NULL;}
virtual const char * prezzo_rauto(int r) const { return NULL;}
// @member: restituisce il codice del magazzino della riga automatica accoppiata a <par r>
//virtual const char * codmag_rauto(int r)
//{return NULL;}
// @member: restituisce il prezzo della riga automatica accoppiata a <par r>
//virtual const char * prezzo_rauto(int r)
//{return NULL;}
// aggiunge le righe automatiche e da esplosione
void add_extrarows() const;
// aggiunge le righe automatiche
bool add_autorows() const;
// aggiunge le righe da esplosione
bool add_explrows() const;
public:
// IO ad alto livello
virtual const char *get_next_key() ;
virtual int remove(TBaseisamfile& f) const ;
virtual void zero(char c = '\0');// azzeramento ;
virtual int write(TBaseisamfile& f) const ;
virtual int rewrite(TBaseisamfile& f) const ;
int force_update_bal();
const TCausale_magazzino& causale(const char* cod = NULL) const;
// @member: effettua l'aggiornamento dei saldi di una giacenza
int update_balances(TRectype& magrec, int numrig, int sign);
//
int codice_esercizio(const TDate &d);
// costruttori e distruttori
TMov_mag();
virtual ~TMov_mag();
};
bool rebuild_balances(const TString& annoes,
const TTipo_valorizz tipo=valorizz_costmediopond,
const char* catven=NULL,
const char* codlis=NULL);
#define FORM_MAXGIACLEV 4 // numero di livelli giacenza nel form
#define FORM_MAXARTLEV 8 // numero di livelli codice nel form
#define UNKNOWN_NAME "-"
typedef enum {
mg_normale, // Codice o descrizione
mg_ragg_fisc, // Raggr. Fiscale + Codice Articolo
mg_cat_merc, // Cat. Merceologica[1..3] + Codice Articolo
mg_scat_merc // Cat. Merceologica[1..5] + Codice Articolo
} TTipo_ordinamento_mg;
class TForm_stampemg : public TForm
{
bool _permag;
int _fromlivgiac,_tolivgiac,_fromlivart,_tolivart;
TTipo_ordinamento_mg _ordering;
//sostituire con le funzioni di TLivelli_... :
//TDecoder *_giacgrp,*_artgrp;
protected:
bool setdettaglio(bool show, int fromlivart,int livart,int fromlivgiac,int livgiac,bool dettgiac);
void add_giaclev(TString &levname,int from,int to);
real ordinato(int flag) const; // Ordinato fornitori - clienti
public:
public:
void gruppogiac(TForm_item &cf, TToken_string &s);
void gruppoart(TForm_item &cf, TToken_string &s);
void codgruppogiac(TForm_item &cf, TToken_string &s);
virtual bool validate(TForm_item &cf, TToken_string &s);
void set_ordering(const TTipo_ordinamento_mg t);
TTipo_ordinamento_mg get_ordering() const { return _ordering; }
bool setdett_perart(bool totaliart, int fromlivart,int livart,bool totaligiac, int fromlivgiac,int livgiac,bool showmag, bool showdep);
bool setdett_permag(bool totaliart, int fromlivart,int livart,bool totaligiac, int fromlivgiac, int livgiac,bool showmag, bool showdep,bool showdett);
TForm_stampemg(const char *name,const char *code) ;
virtual ~TForm_stampemg();
};
class TStampemg_mask: public TMask
{
TMagazzini _magazz_ini;
public:
void enable_livellicodice() ;
void set_livellicodice() ;
TMagazzini & magazz_ini() {return _magazz_ini;}
TStampemg_mask(const char * name) : TMask(name){;}
virtual ~TStampemg_mask(){}
};
TCodgiac_livelli &livelli_giacenza();
TCodart_livelli &livelli_articolo();
class TCondizione_vendita : public TObject
{
TString80 _sconto;
TString16 _codiva;
bool _ivarid;
real _prezzo;
real _provv;
real _molt_sconto;
TLocalisamfile _condv;
TLocalisamfile _rcondv;
TLocalisamfile _sconti;
TLocalisamfile * _anamag; // file passato e posizionato esternamente
TLocalisamfile * _umart; // file passato e posizionato esternamente
TConfig * _config_ditta;
bool _load_mask;
bool cerca(int tiporicerca,const char * cod, const real & qta, const char *um=NULL);
protected:
TRectype & testa() const { return (_condv.curr()); }
TRectype & riga() const { return (_rcondv.curr()); }
TLocalisamfile & anamag() const { CHECK(_anamag, "Anagrafica di magazzino non inizializzata") ; return *_anamag; }
TLocalisamfile & umart() const { CHECK(_umart, "Anagrafica di unita' di misura magazzino non inizializzata") ; return *_umart; }
public:
real get_prezzo() const { return _prezzo; }
TConfig &config_ditta() const { return *_config_ditta; }
void set_config( TConfig & ditta){ _config_ditta = &ditta; }
void set_anamag(TLocalisamfile & anamag) { _anamag = &anamag; }
void set_umart(TLocalisamfile & umart) { _umart = &umart; }
bool gestum() const { return _condv.get_bool("GESTUM"); }
// prepara la ricerca
void put_condv(const char *tipocv,const char * codcv,const char *catven,const char *tipocf,const char *codcf);
void put_listino(const char * codlist,const char *catven);
void put_contratto(const char * codcontr,const char *tipocf,const char *codcf);
void put_offerta(const char * codoff);
// ricerca il codice
bool ricerca(const char * cod, const real& qta = ZERO) ;
TCondizione_vendita(TConfig * _ditta = NULL, TLocalisamfile * anamag = NULL, TLocalisamfile * umart = NULL);
virtual ~TCondizione_vendita() {}
};
#define TIPOREG_VEN 1
#define TIPOREG_ACQ 2
#define TIPOREG_IVA 3
#define TIPOREG_INCPAG 4
#define TIPOREG_GIO 5
#define TIPOREG_LIBSOC 6
#define TIPOREG_CESPIT 7
#define TIPOREG_INVENT 8
#define TIPOREG_GIOMAG 9
class TRegistro_std : public TRectype
{
TString80 _intest;
protected:
bool read(const char* cod, int year);
public:
int year() const;
const TString& code() const ;
const TString & descr() const { return get("S0"); }
int tipo() const { return get_int("I0"); }
const TString & cod_intest() const { return get("S7"); }
const TString intest() const;
const TString & luogo_conserv() const { return get("S1"); }
int pag_stampate() const{ return get_int("I1"); }
int pag_numerate() const{ return get_int("I2"); }
TDate vidimazione() const { return get_date("D0"); }
TDate scadenza() const { return get_date("D1"); }
TDate last_print() const { return get_date("D3"); }
bool stampa_intditta() const { return get_bool("B9"); }
void set_pag_stampate(int p) { put("I1",p); }
void set_last_print(TDate &d) { put("D3",d); }
bool write(bool re) const ;
bool rewrite() const {return write(TRUE);}
int lock();
int unlock();
TRegistro_std(const char* code = "", int year = 0);
virtual ~TRegistro_std() {}
};
const char * add_magcode(TString & codmagdep, const char * m);
const char * add_depcode(TString & codmagdep, const char * d);
const char * get_magcode(TString & codmagdep);
const char * get_depcode(TString & codmagdep);
bool riporta_ordinato();
#endif //__MGLIB_H