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:
alex 1995-02-02 18:08:03 +00:00
parent 77aedf89a6
commit f14e63a20c
6 changed files with 244 additions and 66 deletions

View File

@ -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);
p.print(row); 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);
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);

View File

@ -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
{ {
@ -40,8 +45,11 @@ class TRec_sheet : public TObject
TTrec *_rec; TTrec *_rec;
TTrec *_rec_old; TTrec *_rec_old;
TDir *_dir; TDir *_dir;
bool _comfile; bool _comfile;
static TMask *_mask; TConfig *_descr;
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();
}; };

View File

@ -4,34 +4,36 @@
#define FLD_NUM 101 #define FLD_NUM 101
#define FLD_NOME 102 #define FLD_NOME 102
#define FLD_DESC 103 #define FLD_DESC 103
#define FLD_FORMULA 104 #define FLD_FORMULA 104
#define FLD_EOD 105 #define FLD_EOD 105
#define FLD_FLAG 106 #define FLD_FLAG 106
#define DLG_PACK 107 #define DLG_PACK 107
#define DLG_RECORD 108 #define DLG_RECORD 108
#define DLG_DUMP 109 #define DLG_DUMP 109
#define DLG_LOAD 110 #define DLG_LOAD 110
#define FLD_EXTEND 111 #define FLD_EXTEND 111
#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
#define FLD_KEYNO 203 #define FLD_KEYNO 203
#define FLD_FS 204 #define FLD_FS 204
#define FLD_FD 205 #define FLD_FD 205
#define FLD_RS 206 #define FLD_RS 206
#define FLD_FIXLEN 207 #define FLD_FIXLEN 207
#define FLD_WITHDEL 208 #define FLD_WITHDEL 208
#define FLD_INFILE 301 #define FLD_INFILE 301
#define F_NOMEF 101 #define F_NOMEF 101
#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
@ -39,8 +41,8 @@
#define F_FIELDS 503 #define F_FIELDS 503
#define F_KEYS 504 #define F_KEYS 504
#define F_KEXPR 101 #define F_KEXPR 101
#define F_KDUP 102 #define F_KDUP 102
#define DLG_IMPORT 606 #define DLG_IMPORT 606
#define DLG_EXPORT 607 #define DLG_EXPORT 607

View File

@ -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 ""

View File

@ -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 ""

View File

@ -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;
} }
@ -185,13 +216,22 @@ void TRec_sheet::edit()
{ {
TSheet_field& f1 = (TSheet_field&) _mask->field(F_FIELDS); TSheet_field& f1 = (TSheet_field&) _mask->field(F_FIELDS);
TSheet_field& f2 = (TSheet_field&) _mask->field(F_KEYS); TSheet_field& f2 = (TSheet_field&) _mask->field(F_KEYS);
_mask->set (F_NUM, _dir->num()); _mask->set (F_NUM, _dir->num());
_mask->set (F_DES, _dir->des()); _mask->set (F_DES, _dir->des());
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();