Aggiunti metodi per stabilire il tipo di file (comune o ditta)
Aggiunta gestione descrizioni nei tracciati record Aggiunta stampa di tutti i tracciati record git-svn-id: svn://10.65.10.50/trunk@954 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
parent
77aedf89a6
commit
f14e63a20c
175
ba/ba1100.cpp
175
ba/ba1100.cpp
@ -1,4 +1,5 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
|
||||||
#include <applicat.h>
|
#include <applicat.h>
|
||||||
#include <isam.h>
|
#include <isam.h>
|
||||||
@ -12,6 +13,14 @@
|
|||||||
#include "ba1.h"
|
#include "ba1.h"
|
||||||
#include "ba1100.h"
|
#include "ba1100.h"
|
||||||
|
|
||||||
|
#if XVT_OS==XVT_OS_SCOUNIX
|
||||||
|
#define DIRSIZ 14
|
||||||
|
struct direct
|
||||||
|
{
|
||||||
|
unsigned short d_ino;
|
||||||
|
char d_name[DIRSIZ];
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
class TManutenzione_app : public TApplication
|
class TManutenzione_app : public TApplication
|
||||||
{
|
{
|
||||||
@ -32,6 +41,7 @@ protected:
|
|||||||
void update_dir();
|
void update_dir();
|
||||||
void convert_dir();
|
void convert_dir();
|
||||||
virtual void print();
|
virtual void print();
|
||||||
|
virtual void do_print(TPrinter & p, TRec_sheet & r);
|
||||||
const char* dumpfilename(const FileDes& dep) const;
|
const char* dumpfilename(const FileDes& dep) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -39,61 +49,159 @@ public:
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void TManutenzione_app::print()
|
HIDDEN void build_filelist(const char *path, TArray & list)
|
||||||
|
|
||||||
|
{
|
||||||
|
#if XVT_OS==XVT_OS_SCOUNIX
|
||||||
|
struct directx
|
||||||
|
{
|
||||||
|
ino_t d_ino;
|
||||||
|
char d_name[DIRSIZ + 1];
|
||||||
|
} dlink;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
if ((fd = open(path, 0)) == -1)
|
||||||
|
return;
|
||||||
|
dlink.d_name[DIRSIZ] = '\0';
|
||||||
|
while(read(fd, &dlink, sizeof(struct direct)) ==
|
||||||
|
sizeof(struct direct))
|
||||||
|
{
|
||||||
|
if (dlink.d_ino > 0)
|
||||||
|
{
|
||||||
|
TFixed_string dname(dlink.d_name);
|
||||||
|
|
||||||
|
if (dname.find(".des") > 0 && dname[0] == 'd' && !isdigit(dname[1]))
|
||||||
|
list.add(dname.mid(1,3));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
close(fd);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void TManutenzione_app::do_print(TPrinter & p, TRec_sheet & r)
|
||||||
|
|
||||||
{
|
{
|
||||||
if (_rec == NULL) return;
|
|
||||||
const char* table[] = {"", "Alfanumerico", "Intero", "Intero Lungo",
|
const char* table[] = {"", "Alfanumerico", "Intero", "Intero Lungo",
|
||||||
"Reale", "Data", "Intero", "Carattere",
|
"Reale", "Data", "Intero", "Carattere",
|
||||||
"Booleano", "Intero Zerofilled",
|
"Booleano", "Intero Zerofilled",
|
||||||
"Intero Lungo Zerofilled"};
|
"Intero Lungo Zerofilled"};
|
||||||
TPrinter& p = printer();
|
|
||||||
TPrintrow row;
|
TPrintrow row;
|
||||||
TToken_string s;
|
TToken_string s;
|
||||||
|
TParagraph_string d("", 35);
|
||||||
|
TConfig * descr = NULL;
|
||||||
|
TTrec & rec = *r.rec();
|
||||||
|
TDir & dir = *r.dir();
|
||||||
|
const char * descfname = r.descfname();
|
||||||
|
TString16 tab(r.tab());
|
||||||
|
const bool istab = tab.not_empty();
|
||||||
|
|
||||||
|
tab.upper();
|
||||||
|
if (fexist(descfname))
|
||||||
|
descr = new TConfig(descfname, DESCPAR);
|
||||||
|
|
||||||
|
const bool hasdescr = descr != NULL;
|
||||||
|
|
||||||
p.open();
|
|
||||||
p.headerlen(6);
|
|
||||||
p.footerlen(4);
|
|
||||||
row.reset();
|
row.reset();
|
||||||
row.put(format("Lista tracciato %s (%s)", _rec->dir()->des(),
|
if (istab)
|
||||||
_rec->dir()->name()), 2);
|
row.put(format("Lista tabella %s ", (const char *) tab), 2);
|
||||||
row.put("Pag. @#", 66);
|
else
|
||||||
|
row.put(format("Lista tracciato %s (%s)", dir.des(), dir.name()), 2);
|
||||||
|
row.put("Pag. @#", 69);
|
||||||
p.setheaderline(2, row);
|
p.setheaderline(2, row);
|
||||||
row.reset();
|
row.reset();
|
||||||
row.put("Nome", 7);
|
row.put("Nome", 7);
|
||||||
row.put("Tipo", 18);
|
row.put("Tipo", 18);
|
||||||
row.put("Lunghezza", 45);
|
row.put("Lun.", 38);
|
||||||
row.put(" Decimali", 55);
|
row.put(" Dec.", 43);
|
||||||
row.put("Posizione", 65);
|
row.put("Pos.", 48);
|
||||||
|
row.put("Descrizione", 53);
|
||||||
p.setheaderline(4, row);
|
p.setheaderline(4, row);
|
||||||
p.setbackground("l[1,6,75,6]");
|
p.setbackground("l[1,6,78,6]");
|
||||||
for (int i = 0; i < _rec->rec()->fields(); i ++)
|
for (int i = 0; i < rec.fields(); i ++)
|
||||||
{
|
{
|
||||||
row.reset();
|
row.reset();
|
||||||
s = _rec->rec()->fielddef(i);
|
s = rec.fielddef(i);
|
||||||
|
TString16 name = s.get();
|
||||||
row.put(format("%3d", i + 1), 2);
|
row.put(format("%3d", i + 1), 2);
|
||||||
row.put(s.get(), 7);
|
row.put(name, 7);
|
||||||
row.put(table[s.get_int()], 18);
|
row.put(table[s.get_int()], 18);
|
||||||
row.put(format(" %4d", s.get_int()), 45);
|
row.put(format("%4d", s.get_int()), 38);
|
||||||
row.put(format(" %4d", s.get_int()), 55);
|
row.put(format("%4d", s.get_int()), 43);
|
||||||
row.put(format(" %4d", _rec->rec()->rec()->Fd[i].RecOff), 65);
|
row.put(format("%4d", rec.rec()->Fd[i].RecOff), 48);
|
||||||
|
const char *wd = NULL;
|
||||||
|
|
||||||
|
d = "";
|
||||||
|
if (hasdescr)
|
||||||
|
d = descr->get(name);
|
||||||
|
if (!istab || d.not_empty())
|
||||||
|
{
|
||||||
|
if (hasdescr)
|
||||||
|
{
|
||||||
|
wd = d.get();
|
||||||
|
if (wd != NULL)
|
||||||
|
row.put(wd, 53);
|
||||||
|
}
|
||||||
p.print(row);
|
p.print(row);
|
||||||
|
wd = d.get();
|
||||||
|
while(wd != NULL)
|
||||||
|
{
|
||||||
|
row.reset();
|
||||||
|
row.put(wd, 53);
|
||||||
|
p.print(row);
|
||||||
|
wd = d.get();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
p.formfeed();
|
p.formfeed();
|
||||||
row.reset();
|
row.reset();
|
||||||
row.put("Espressione chiave", 7);
|
row.put("Espressione chiave", 7);
|
||||||
row.put("Duplicabile", 68);
|
row.put("Duplicabile", 68);
|
||||||
p.setheaderline(4, row);
|
p.setheaderline(4, row);
|
||||||
for (i = 0; i < _rec->rec()->keys(); i ++)
|
for (i = 0; i < rec.keys(); i ++)
|
||||||
{
|
{
|
||||||
row.reset();
|
row.reset();
|
||||||
s = _rec->rec()->keydef(i);
|
s = rec.keydef(i);
|
||||||
row.put(format("%3d", i + 1), 2);
|
row.put(format("%3d", i + 1), 2);
|
||||||
row.put(s.get(), 7);
|
row.put(s.get(), 7);
|
||||||
row.put(*s.get() == 'X' ? "Si" : "No", 68);
|
row.put(*s.get() == 'X' ? "Si" : "No", 68);
|
||||||
p.print(row);
|
p.print(row);
|
||||||
}
|
}
|
||||||
p.formfeed();
|
p.formfeed();
|
||||||
|
if (hasdescr)
|
||||||
|
delete descr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void TManutenzione_app::print()
|
||||||
|
|
||||||
|
{
|
||||||
|
TPrinter & p = printer();
|
||||||
|
|
||||||
|
p.open();
|
||||||
|
p.headerlen(6);
|
||||||
|
p.footerlen(4);
|
||||||
|
if (_rec == NULL)
|
||||||
|
{
|
||||||
|
int items = _rec->dir()->items();
|
||||||
|
|
||||||
|
for (int i = 2 ; i <= items; i++)
|
||||||
|
{
|
||||||
|
TRec_sheet r(i, "");
|
||||||
|
do_print(p, r);
|
||||||
|
}
|
||||||
|
|
||||||
|
TArray list;
|
||||||
|
|
||||||
|
build_filelist(DESCDIR, list);
|
||||||
|
items = list.items();
|
||||||
|
for (i = 0; i < items; i++)
|
||||||
|
{
|
||||||
|
TString & tab = (TString &) list[i];
|
||||||
|
TRec_sheet r(4, tab);
|
||||||
|
|
||||||
|
do_print(p, r);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else do_print(p, *_rec);
|
||||||
p.close();
|
p.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,6 +227,7 @@ bool TManutenzione_app::create() // initvar e arrmask
|
|||||||
_browse->add_button(DLG_ADDFILE, "Aggiunge", K_F8);
|
_browse->add_button(DLG_ADDFILE, "Aggiunge", K_F8);
|
||||||
dispatch_e_menu(BAR_ITEM(1));
|
dispatch_e_menu(BAR_ITEM(1));
|
||||||
}
|
}
|
||||||
|
enable_menu_item(M_FILE_PRINT);
|
||||||
return TRUE ;
|
return TRUE ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,9 +250,11 @@ void TManutenzione_app::insert_riga (long riga_sel, TToken_string& riga)
|
|||||||
_mask->disable(DLG_RECORD);
|
_mask->disable(DLG_RECORD);
|
||||||
_mask->disable(DLG_LOAD);
|
_mask->disable(DLG_LOAD);
|
||||||
_mask->disable(DLG_DUMP);
|
_mask->disable(DLG_DUMP);
|
||||||
|
_mask->show(F_TAB, logicnum >= LF_TABGEN && logicnum <= LF_TAB);
|
||||||
_mask->hide(FLD_EXTEND);
|
_mask->hide(FLD_EXTEND);
|
||||||
_mask->hide(FLD_EOX);
|
_mask->hide(FLD_EOX);
|
||||||
_mask->set (FLD_NUM, riga.get(0));
|
_mask->set (FLD_NUM, riga.get(0));
|
||||||
|
_mask->reset (F_TAB);
|
||||||
|
|
||||||
if (_mask->run() == K_ENTER)
|
if (_mask->run() == K_ENTER)
|
||||||
{
|
{
|
||||||
@ -197,6 +308,7 @@ void TManutenzione_app::edit_riga (long riga_sel, TToken_string& riga)
|
|||||||
_mask->enable(DLG_RECORD);
|
_mask->enable(DLG_RECORD);
|
||||||
_mask->enable(DLG_LOAD);
|
_mask->enable(DLG_LOAD);
|
||||||
_mask->enable(DLG_DUMP);
|
_mask->enable(DLG_DUMP);
|
||||||
|
_mask->show(F_TAB, logicnum >= LF_TABGEN && logicnum <= LF_TAB);
|
||||||
_mask->set (FLD_NUM, riga.get(0));
|
_mask->set (FLD_NUM, riga.get(0));
|
||||||
_mask->set (FLD_NOME, riga.get());
|
_mask->set (FLD_NOME, riga.get());
|
||||||
_mask->set (FLD_EOD, riga.get());
|
_mask->set (FLD_EOD, riga.get());
|
||||||
@ -206,11 +318,12 @@ void TManutenzione_app::edit_riga (long riga_sel, TToken_string& riga)
|
|||||||
_mask->set (FLD_FORMULA, riga.get());
|
_mask->set (FLD_FORMULA, riga.get());
|
||||||
_mask->set (FLD_FLAG, riga.get());
|
_mask->set (FLD_FLAG, riga.get());
|
||||||
_mask->reset (FLD_EXTEND);
|
_mask->reset (FLD_EXTEND);
|
||||||
|
_mask->reset (F_TAB);
|
||||||
|
|
||||||
const TRecnotype oldeox = atol(_mask->get(FLD_EOX));
|
const TRecnotype oldeox = atol(_mask->get(FLD_EOX));
|
||||||
const bool com = strcmp(prefhndl->name(), "com") == 0 || !*prefhndl->name();
|
const bool com = prefhndl->is_com() || !*prefhndl->name();
|
||||||
const char* name = _mask->get(FLD_NOME);
|
const char* name = _mask->get(FLD_NOME);
|
||||||
const bool enable_extend = (com ? *name == '%' : *name != '%') && (riga_sel > 0);
|
const bool enable_extend = (com ? *name != '$' : *name == '$') && (riga_sel > 0);
|
||||||
|
|
||||||
_mask->show(FLD_EXTEND, enable_extend);
|
_mask->show(FLD_EXTEND, enable_extend);
|
||||||
_mask->show(FLD_EOX, enable_extend);
|
_mask->show(FLD_EOX, enable_extend);
|
||||||
@ -265,12 +378,10 @@ void TManutenzione_app::edit_riga (long riga_sel, TToken_string& riga)
|
|||||||
else
|
else
|
||||||
if (tasto == K_F6)
|
if (tasto == K_F6)
|
||||||
{
|
{
|
||||||
enable_menu_item(M_FILE_PRINT);
|
_rec = new TRec_sheet(logicnum, _mask->get(F_TAB));
|
||||||
_rec = new TRec_sheet(logicnum);
|
|
||||||
_rec->edit();
|
_rec->edit();
|
||||||
delete _rec;
|
delete _rec;
|
||||||
_rec = NULL;
|
_rec = NULL;
|
||||||
disable_menu_item(M_FILE_PRINT);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
if (tasto == K_F7)
|
if (tasto == K_F7)
|
||||||
@ -338,11 +449,11 @@ void TManutenzione_app::update_dir()
|
|||||||
|
|
||||||
{
|
{
|
||||||
const TString pref(prefhndl->name());
|
const TString pref(prefhndl->name());
|
||||||
|
const bool is_com = prefhndl->is_com();
|
||||||
|
|
||||||
prefhndl->set("");
|
prefhndl->set("");
|
||||||
|
|
||||||
TDir d;
|
TDir d;
|
||||||
const bool update_com = ( pref == "com");
|
|
||||||
d.get(LF_DIR);
|
d.get(LF_DIR);
|
||||||
const int orig_items = (int)d.eod();
|
const int orig_items = (int)d.eod();
|
||||||
|
|
||||||
@ -352,8 +463,8 @@ void TManutenzione_app::update_dir()
|
|||||||
const int items = (int)d.eod();
|
const int items = (int)d.eod();
|
||||||
TString80 s("Aggiornamento direttorio ");
|
TString80 s("Aggiornamento direttorio ");
|
||||||
|
|
||||||
if (pref == "com") s << "comune";
|
if (is_com) s << "comune";
|
||||||
else s << " della ditta " <<atol (pref);
|
else s << " della ditta " << atol (pref);
|
||||||
|
|
||||||
TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
|
TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
|
||||||
|
|
||||||
@ -371,9 +482,9 @@ void TManutenzione_app::update_dir()
|
|||||||
word len = d.len();
|
word len = d.len();
|
||||||
prefhndl->set(pref);
|
prefhndl->set(pref);
|
||||||
d.get(i, _nolock, _nordir, _sysdirop);
|
d.get(i, _nolock, _nordir, _sysdirop);
|
||||||
bool to_create = (update_com ? *d.name() == '%' : *d.name() == '$');
|
bool to_create = (is_com ? d.is_com() : d.is_firm());
|
||||||
|
|
||||||
if (flags == -1 && len != d.len() && s != d.name())
|
if (flags < 0 && len != d.len() && s != d.name())
|
||||||
{
|
{
|
||||||
d.set(s, d.eox(), 0L, desc, d.expr());
|
d.set(s, d.eox(), 0L, desc, d.expr());
|
||||||
towrite = TRUE;
|
towrite = TRUE;
|
||||||
@ -425,7 +536,7 @@ void TManutenzione_app::convert_dir()
|
|||||||
const int items = (int)d.eod();
|
const int items = (int)d.eod();
|
||||||
TString80 s("Aggiornamento archivi ");
|
TString80 s("Aggiornamento archivi ");
|
||||||
|
|
||||||
if (pref == "com") s << "comuni";
|
if (prefhndl->is_com()) s << "comuni";
|
||||||
else s << " della ditta " << atol (pref);
|
else s << " della ditta " << atol (pref);
|
||||||
|
|
||||||
TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
|
TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
|
||||||
|
14
ba/ba1100.h
14
ba/ba1100.h
@ -5,12 +5,17 @@
|
|||||||
#include <sheet.h>
|
#include <sheet.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef __CONFIG_H
|
||||||
|
#include <config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "ba1100a.h"
|
#include "ba1100a.h"
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////
|
||||||
// TDir_sheet
|
// TDir_sheet
|
||||||
///////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////
|
||||||
|
#define DESCPAR "FieldDescr"
|
||||||
|
#define DESCDIR "recdesc"
|
||||||
|
|
||||||
class TDir_sheet : public TSheet
|
class TDir_sheet : public TSheet
|
||||||
{
|
{
|
||||||
@ -41,7 +46,10 @@ class TRec_sheet : public TObject
|
|||||||
TTrec *_rec_old;
|
TTrec *_rec_old;
|
||||||
TDir *_dir;
|
TDir *_dir;
|
||||||
bool _comfile;
|
bool _comfile;
|
||||||
|
TConfig *_descr;
|
||||||
static TMask *_mask;
|
static TMask *_mask;
|
||||||
|
TFilename _descfname;
|
||||||
|
TString16 _tab;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool check_key_expr(int key, const char* key_expr);
|
bool check_key_expr(int key, const char* key_expr);
|
||||||
@ -51,10 +59,12 @@ protected:
|
|||||||
virtual long items() const { return _rec->fields(); }
|
virtual long items() const { return _rec->fields(); }
|
||||||
|
|
||||||
public:
|
public:
|
||||||
TRec_sheet(int logicnum);
|
TRec_sheet(int logicnum, const char * tab);
|
||||||
~TRec_sheet();
|
~TRec_sheet();
|
||||||
TDir* dir() const { return _dir; }
|
TDir* dir() const { return _dir; }
|
||||||
TTrec* rec() const { return _rec; }
|
TTrec* rec() const { return _rec; }
|
||||||
|
const char * descfname() const { return _descfname;}
|
||||||
|
const char * tab() const { return _tab; }
|
||||||
void edit();
|
void edit();
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
#define FLD_EOX 112
|
#define FLD_EOX 112
|
||||||
#define F_LEN 113
|
#define F_LEN 113
|
||||||
#define DLG_EDIR 114
|
#define DLG_EDIR 114
|
||||||
|
#define F_TAB 115
|
||||||
|
|
||||||
#define FLD_OUTFILE 201
|
#define FLD_OUTFILE 201
|
||||||
#define FLD_WITHKEY 202
|
#define FLD_WITHKEY 202
|
||||||
@ -32,6 +33,7 @@
|
|||||||
#define FLD_TIPO 102
|
#define FLD_TIPO 102
|
||||||
#define FLD_LEN 103
|
#define FLD_LEN 103
|
||||||
#define FLD_DEC 104
|
#define FLD_DEC 104
|
||||||
|
#define FLD_DES 105
|
||||||
#define F_NUMF 110
|
#define F_NUMF 110
|
||||||
|
|
||||||
#define F_NUM 501
|
#define F_NUM 501
|
||||||
|
@ -67,6 +67,12 @@ BEGIN
|
|||||||
FLAGS "RD"
|
FLAGS "RD"
|
||||||
END
|
END
|
||||||
|
|
||||||
|
STRING F_TAB 3
|
||||||
|
BEGIN
|
||||||
|
PROMPT 2 9 "Tabella "
|
||||||
|
FLAGS "U"
|
||||||
|
END
|
||||||
|
|
||||||
BUTTON DLG_OK 9 2
|
BUTTON DLG_OK 9 2
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT -14 -3 ""
|
PROMPT -14 -3 ""
|
||||||
|
@ -55,6 +55,7 @@ BEGIN
|
|||||||
ITEM "Tipo"
|
ITEM "Tipo"
|
||||||
ITEM "Lunghezza"
|
ITEM "Lunghezza"
|
||||||
ITEM "Decimali"
|
ITEM "Decimali"
|
||||||
|
ITEM "Descrizione@50"
|
||||||
END
|
END
|
||||||
|
|
||||||
SPREADSHEET F_KEYS
|
SPREADSHEET F_KEYS
|
||||||
@ -68,7 +69,7 @@ ENDPAGE
|
|||||||
|
|
||||||
ENDMASK
|
ENDMASK
|
||||||
|
|
||||||
PAGE "Campo" -1 -1 60 9
|
PAGE "Campo" -1 -1 70 11
|
||||||
|
|
||||||
STRING F_NUMF 3 3
|
STRING F_NUMF 3 3
|
||||||
BEGIN
|
BEGIN
|
||||||
@ -126,6 +127,12 @@ BEGIN
|
|||||||
WARNING "Numero di decimali errato"
|
WARNING "Numero di decimali errato"
|
||||||
END
|
END
|
||||||
|
|
||||||
|
STRING FLD_DES 80 50
|
||||||
|
BEGIN
|
||||||
|
PROMPT 2 6 "Descrizione "
|
||||||
|
HELP "Descrizione del campo"
|
||||||
|
END
|
||||||
|
|
||||||
BUTTON DLG_OK 8 2
|
BUTTON DLG_OK 8 2
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT -13 -1 ""
|
PROMPT -13 -1 ""
|
||||||
|
@ -77,7 +77,8 @@ void TDir_sheet::page_build(long first, byte rows)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
TRec_sheet::TRec_sheet(int logicnum)
|
TRec_sheet::TRec_sheet(int logicnum, const char * tab)
|
||||||
|
: _descr(NULL), _tab(tab)
|
||||||
|
|
||||||
{
|
{
|
||||||
_dir = new TDir;
|
_dir = new TDir;
|
||||||
@ -88,6 +89,24 @@ TRec_sheet::TRec_sheet(int logicnum)
|
|||||||
_dir->get(logicnum, _lock, _nordir, _sysdirop);
|
_dir->get(logicnum, _lock, _nordir, _sysdirop);
|
||||||
_rec->get(logicnum);
|
_rec->get(logicnum);
|
||||||
*_rec_old = *_rec;
|
*_rec_old = *_rec;
|
||||||
|
_tab.lower();
|
||||||
|
if (fexist(DESCDIR))
|
||||||
|
{
|
||||||
|
if (logicnum >= LF_TABGEN && logicnum <= LF_TAB && _tab.not_empty())
|
||||||
|
_descfname.format("%s/d%s.des", DESCDIR, (const char *) _tab);
|
||||||
|
else
|
||||||
|
_descfname.format("%s/d%d.des", DESCDIR, _dir->num());
|
||||||
|
FILE * fd = NULL;
|
||||||
|
|
||||||
|
if (!fexist(_descfname) && (fd = fopen(_descfname, "w")) == NULL)
|
||||||
|
error_box("Non riesco a creare il file delle descrizioni");
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (fd != NULL)
|
||||||
|
fclose(fd);
|
||||||
|
_descr = new TConfig(_descfname, DESCPAR);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TRec_sheet::~TRec_sheet()
|
TRec_sheet::~TRec_sheet()
|
||||||
@ -97,6 +116,8 @@ TRec_sheet::~TRec_sheet()
|
|||||||
delete _rec_old;
|
delete _rec_old;
|
||||||
delete _mask;
|
delete _mask;
|
||||||
_mask = NULL;
|
_mask = NULL;
|
||||||
|
if (_descr)
|
||||||
|
delete _descr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool TRec_sheet::check_key_expr(int key, const char * key_expr)
|
bool TRec_sheet::check_key_expr(int key, const char * key_expr)
|
||||||
@ -171,10 +192,20 @@ bool TRec_sheet::key_notify(int r, KEY k)
|
|||||||
void TRec_sheet::save()
|
void TRec_sheet::save()
|
||||||
|
|
||||||
{
|
{
|
||||||
if (*_rec == *_rec_old ||
|
if ((*_rec == *_rec_old && !_descr) ||
|
||||||
!yesnocancel_box("Devo salvare le modifiche")) return;
|
!yesnocancel_box("Devo salvare le modifiche")) return;
|
||||||
TSystemisamfile f(_rec->num());
|
TSystemisamfile f(_rec->num());
|
||||||
|
|
||||||
|
if (_descr)
|
||||||
|
{
|
||||||
|
TSheet_field& f1 = (TSheet_field&) _mask->field(F_FIELDS);
|
||||||
|
const int nfields = f1.items();
|
||||||
|
|
||||||
|
for (int i = 0; i < nfields; i++)
|
||||||
|
_descr->set(_rec->rec()->Fd[i].Name, f1.row(i).get(-2));
|
||||||
|
delete _descr;
|
||||||
|
_descr = new TConfig(_descfname, DESCPAR);
|
||||||
|
}
|
||||||
f.update(*_rec);
|
f.update(*_rec);
|
||||||
*_rec_old = *_rec;
|
*_rec_old = *_rec;
|
||||||
}
|
}
|
||||||
@ -191,7 +222,16 @@ void TRec_sheet::edit()
|
|||||||
f1.set_notify(fld_notify);
|
f1.set_notify(fld_notify);
|
||||||
f1.sheet_mask().field(FLD_LEN).set_handler(len_handler);
|
f1.sheet_mask().field(FLD_LEN).set_handler(len_handler);
|
||||||
int nfields = _rec->fields();
|
int nfields = _rec->fields();
|
||||||
for (int i = 0; i < nfields; i++) f1.row(i) = _rec->fielddef(i);
|
|
||||||
|
f1.enable_column(FLD_DES - 101, _descr != NULL);
|
||||||
|
for (int i = 0; i < nfields; i++)
|
||||||
|
{
|
||||||
|
f1.row(i) = _rec->fielddef(i);
|
||||||
|
if (_descr)
|
||||||
|
f1.row(i).add(_descr->get(_rec->rec()->Fd[i].Name));
|
||||||
|
else
|
||||||
|
f1.row(i).add("");
|
||||||
|
}
|
||||||
f2.set_notify(key_notify);
|
f2.set_notify(key_notify);
|
||||||
int nkeys = _rec->keys();
|
int nkeys = _rec->keys();
|
||||||
for (i = 0; i < nkeys; i++) f2.row(i) = _rec->keydef(i);
|
for (i = 0; i < nkeys; i++) f2.row(i) = _rec->keydef(i);
|
||||||
@ -205,7 +245,9 @@ void TRec_sheet::edit()
|
|||||||
_rec->set_fields(nfields);
|
_rec->set_fields(nfields);
|
||||||
for (i = 0; i < nfields; i++)
|
for (i = 0; i < nfields; i++)
|
||||||
{
|
{
|
||||||
TToken_string& s = f1.row(i);
|
TToken_string s(f1.row(i));
|
||||||
|
|
||||||
|
s.destroy(-2);
|
||||||
_rec->update_fielddef(i, s);
|
_rec->update_fielddef(i, s);
|
||||||
}
|
}
|
||||||
_rec->rehash();
|
_rec->rehash();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user