1996-11-14 17:40:05 +00:00
|
|
|
#include "effetti.h"
|
|
|
|
#include "reffetti.h"
|
|
|
|
#include "cession.h"
|
1996-12-06 15:50:15 +00:00
|
|
|
#include "ef0301.h"
|
1996-11-14 17:40:05 +00:00
|
|
|
|
1996-12-06 15:50:15 +00:00
|
|
|
///////////////////////////////////////////////////
|
|
|
|
// definizione dei metodi della classe TDistinta //
|
|
|
|
///////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// costruttore distinta utilizzando il record passato
|
1996-11-14 17:40:05 +00:00
|
|
|
TDistinta::TDistinta(const TRectype& rec)
|
|
|
|
{
|
|
|
|
read(rec);
|
|
|
|
}
|
|
|
|
|
1996-11-27 14:11:39 +00:00
|
|
|
// costruisce la distinta del tipo e numero passati
|
1996-11-14 17:40:05 +00:00
|
|
|
TDistinta::TDistinta(const char tipo, const long numero)
|
|
|
|
{
|
|
|
|
read(tipo,numero);
|
|
|
|
}
|
|
|
|
|
1996-11-27 14:11:39 +00:00
|
|
|
// permette di leggere la distinta del tipo e numero passati
|
1996-11-14 17:40:05 +00:00
|
|
|
int TDistinta::read(const char tipo, const long numero)
|
|
|
|
{
|
|
|
|
int err = NOERR;
|
1996-11-22 17:17:26 +00:00
|
|
|
CHECK(tipo!='\0' && numero > 0,"Can't read distinta from NULL elements");
|
|
|
|
TLocalisamfile f(LF_EFFETTI);
|
1996-11-14 17:40:05 +00:00
|
|
|
for (int i=0; err == NOERR ; i++)
|
|
|
|
{
|
|
|
|
TEffetto* effetto = new TEffetto;
|
1996-11-27 14:11:39 +00:00
|
|
|
err = effetto->read(f, tipo, numero, i+1);//legge un effetto per chiave 4
|
1996-11-14 17:40:05 +00:00
|
|
|
if (err == NOERR)
|
|
|
|
_righe_dist.add(effetto);
|
|
|
|
}
|
1996-11-27 14:11:39 +00:00
|
|
|
if ((_righe_dist.items()>0)||(err == _iseof) )//se ho letto degli effetti della distinta ed ho
|
|
|
|
err = NOERR; //trovato la fine file elimino l'errore
|
1996-11-14 17:40:05 +00:00
|
|
|
return err;
|
|
|
|
}
|
1996-11-27 14:11:39 +00:00
|
|
|
|
1996-12-06 15:50:15 +00:00
|
|
|
// permette di leggere la distinta dal record passato
|
1996-11-14 17:40:05 +00:00
|
|
|
int TDistinta::read(const TRectype& rec)
|
|
|
|
{
|
|
|
|
CHECK(rec.num() == LF_EFFETTI,"Can't read distinta from a different record type");
|
|
|
|
const char tipo = rec.get_char(EFF_TIPODIST);
|
|
|
|
const long numero = rec.get_long(EFF_NDIST);
|
1996-11-27 14:11:39 +00:00
|
|
|
return read(tipo,numero);//legge la distinta
|
1996-11-14 17:40:05 +00:00
|
|
|
}
|
|
|
|
|
1996-11-27 14:11:39 +00:00
|
|
|
// scrive la distinta
|
1996-11-14 17:40:05 +00:00
|
|
|
int TDistinta::write(bool force, TToken_string* dati_dist)
|
|
|
|
{
|
|
|
|
int err = NOERR;
|
1996-11-27 14:11:39 +00:00
|
|
|
const int elem = items(); //quanti effetti sono nella distinta (nell'array in memoria)
|
1996-11-22 17:17:26 +00:00
|
|
|
TLocalisamfile f(LF_EFFETTI);
|
1996-11-14 17:40:05 +00:00
|
|
|
for (int i=0; i<elem && err==NOERR; i++)
|
|
|
|
{
|
|
|
|
TEffetto& effetto = (TEffetto&)_righe_dist[i];
|
1996-12-06 15:50:15 +00:00
|
|
|
dati_dist->restart();// token string che contiene i dati da registrare sull'effetto
|
1996-11-14 17:40:05 +00:00
|
|
|
effetto.put("TIPODIST", dati_dist->get());
|
|
|
|
effetto.put("NDIST", dati_dist->get_long());
|
|
|
|
effetto.put("DATADIST", dati_dist->get());
|
|
|
|
effetto.put("CODABIP", dati_dist->get_long());
|
|
|
|
effetto.put("CODCABP", dati_dist->get_long());
|
|
|
|
effetto.put("NRIGADIST", i+1);
|
1996-11-27 14:11:39 +00:00
|
|
|
err = effetto.rewrite(f);//riscrivo l'effetto con i dati della distinta a cui appartiene
|
1996-11-14 17:40:05 +00:00
|
|
|
}
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
1996-12-06 15:50:15 +00:00
|
|
|
// rimuove la distinta (non si effettua la rimozione del record su file ma si elimina dal file il
|
|
|
|
// collegamento tra gli effetti e la distinta)
|
1996-11-14 17:40:05 +00:00
|
|
|
int TDistinta::remove(char tipodist, long ndist)
|
|
|
|
{
|
1996-11-22 17:17:26 +00:00
|
|
|
int err;
|
|
|
|
TLocalisamfile file(LF_EFFETTI);
|
1996-12-06 15:50:15 +00:00
|
|
|
// scandisco tutti gli effetti della distinta (nell'array),
|
|
|
|
// cancello i dati della distinta e riscrivo gli effetti
|
1996-11-22 17:17:26 +00:00
|
|
|
for (int i = 0; i < items(); i++)
|
1996-11-14 17:40:05 +00:00
|
|
|
{
|
1996-11-22 17:17:26 +00:00
|
|
|
TEffetto& effetto = (TEffetto&)_righe_dist[i];
|
|
|
|
err = effetto.read(file, tipodist,ndist,i+1);
|
|
|
|
effetto.zero("TIPODIST");
|
|
|
|
effetto.zero("NDIST");
|
|
|
|
effetto.zero("DATADIST");
|
|
|
|
effetto.zero("NRIGADIST");
|
|
|
|
effetto.zero("CODABIP");
|
|
|
|
effetto.zero("CODCABP");
|
|
|
|
err = effetto.rewrite(file);
|
1996-11-14 17:40:05 +00:00
|
|
|
}
|
1996-12-06 15:50:15 +00:00
|
|
|
reset();//elimino gli effetti dalla memoria resettando l'array
|
1996-11-14 17:40:05 +00:00
|
|
|
return err;
|
|
|
|
}
|