Aggiunto meccanismo per caricare da file di testo con tre variabili predefinite :
%yr% = anno corrente %frm% = ditta corrente %att% = attivita prevalente dell ditta corrente git-svn-id: svn://10.65.10.50/trunk@714 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
parent
8ec5744a57
commit
b96e339c79
@ -18,6 +18,7 @@
|
|||||||
#include <relation.h>
|
#include <relation.h>
|
||||||
#include <scanner.h>
|
#include <scanner.h>
|
||||||
#include <utility.h>
|
#include <utility.h>
|
||||||
|
#include <lffiles.h>
|
||||||
|
|
||||||
#if XVT_OS==XVT_OS_SCOUNIX
|
#if XVT_OS==XVT_OS_SCOUNIX
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -822,7 +823,7 @@ int TSystemisamfile::build(TRecnotype eox)
|
|||||||
|
|
||||||
lf.format("%sstd/lf%04d.txt", __ptprf, num());
|
lf.format("%sstd/lf%04d.txt", __ptprf, num());
|
||||||
if (fexist(lf))
|
if (fexist(lf))
|
||||||
load(lf);
|
load(lf, '|', '\0', '\n', TRUE, TRUE);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1059,12 +1060,26 @@ int TSystemisamfile::packindex(bool vis)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int TSystemisamfile::load(const char* from, char fs, char fd, char rs, bool vis)
|
int TSystemisamfile::load(const char* from, char fs, char fd, char rs, bool vis, bool extended)
|
||||||
|
|
||||||
{
|
{
|
||||||
FILE* fl = fopen(from, "r+");
|
FILE* fl = fopen(from, "r+");
|
||||||
int err = ferror(fl);
|
int err = ferror(fl);
|
||||||
TRecnotype r = 0, e = 0, nitems = 0, nread = 0;
|
TRecnotype r = 0, e = 0, nitems = 0, nread = 0;
|
||||||
|
TString16 firm, year, attprev("00000");
|
||||||
|
|
||||||
|
if (extended)
|
||||||
|
{
|
||||||
|
TDate d(TODAY);
|
||||||
|
TLocalisamfile ditte(LF_NDITTE);
|
||||||
|
|
||||||
|
firm.format("%05ld", main_app().get_firm());
|
||||||
|
year.format("%04d", d.year());
|
||||||
|
ditte.zero();
|
||||||
|
ditte.put("CODDITTA", firm);
|
||||||
|
if (ditte.read() == NOERR)
|
||||||
|
attprev = ditte.get("CODATTPREV");
|
||||||
|
}
|
||||||
if (fl == NULL)
|
if (fl == NULL)
|
||||||
{
|
{
|
||||||
clearerr(fl);
|
clearerr(fl);
|
||||||
@ -1157,6 +1172,17 @@ int TSystemisamfile::load(const char* from, char fs, char fd, char rs, bool vis)
|
|||||||
s = f.line();
|
s = f.line();
|
||||||
while (s.not_empty() && !p.iscancelled())
|
while (s.not_empty() && !p.iscancelled())
|
||||||
{
|
{
|
||||||
|
if (extended)
|
||||||
|
{
|
||||||
|
int p, i;
|
||||||
|
|
||||||
|
while ((p = s.find("%yr%")) >= 0)
|
||||||
|
for (i = 0; i < 4; i++) s[p + i] = year[i];
|
||||||
|
while ((p = s.find("%frm%")) >= 0)
|
||||||
|
for (i = 0; i < 5; i++) s[p + i] = firm[i];
|
||||||
|
while ((p = s.find("%att%")) >= 0)
|
||||||
|
for (i = 0; i < 5; i++) s[p + i] = attprev[i];
|
||||||
|
}
|
||||||
if ((r + e) % 50 == 0)
|
if ((r + e) % 50 == 0)
|
||||||
{
|
{
|
||||||
s1.format("Imp. archivio %s\n%6ld records %6ld errori - %3d", filename(), r, e, last);
|
s1.format("Imp. archivio %s\n%6ld records %6ld errori - %3d", filename(), r, e, last);
|
||||||
|
@ -364,7 +364,7 @@ public:
|
|||||||
int packindex(bool vis = TRUE); // La stessa cosa sugli indici
|
int packindex(bool vis = TRUE); // La stessa cosa sugli indici
|
||||||
|
|
||||||
// @DES Importa un file ascii. from e' il nome del file da importare
|
// @DES Importa un file ascii. from e' il nome del file da importare
|
||||||
int load(const char* from, char fs = '|', char fd = '\0', char rs = '\n', bool vis = TRUE) ;
|
int load(const char* from, char fs = '|', char fd = '\0', char rs = '\n', bool vis = TRUE, bool extended = FALSE) ;
|
||||||
|
|
||||||
// @DES Esporta VERSO un file ascii.
|
// @DES Esporta VERSO un file ascii.
|
||||||
int dump(const char* to, int nkey = 1, char fs = '|', char fd = '\0', char rs = '\n', bool vis = TRUE, bool withdeleted = FALSE);
|
int dump(const char* to, int nkey = 1, char fs = '|', char fd = '\0', char rs = '\n', bool vis = TRUE, bool withdeleted = FALSE);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user