Separzione tracciati step 1

git-svn-id: svn://10.65.10.50/trunk@3342 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
alex 1996-08-08 15:40:13 +00:00
parent 1b8fe6d0a4
commit 4cb1eba51e
2 changed files with 283 additions and 209 deletions

View File

@ -39,8 +39,11 @@ struct direct
class TManutenzione_app : public TApplication
{
TDir_sheet* _browse;
TArray _dirs;
TArray _recs;
TMask* _mask;
long _firm;
long _level;
long _history_firm;
TRec_sheet* _rec;
@ -58,13 +61,14 @@ protected:
virtual void print();
virtual void do_print(TPrinter & p, TRec_sheet & r);
const char* dumpfilename(const FileDes& dep) const;
void load_des();
void open_history();
void put_history(const char* firm);
void close_history();
public:
TManutenzione_app() : _browse(NULL), _rec(NULL), _mask(NULL), _firm(0) {}
TManutenzione_app() : _browse(NULL), _rec(NULL), _mask(NULL), _firm(0), _level(0) {}
};
HIDDEN void build_filelist(const char *path, TArray & list)
@ -271,9 +275,9 @@ bool TManutenzione_app::create() // initvar e arrmask
{
if (!set_firm())
return FALSE;
load_des();
const bool superprassi = user() == "PRASSI";
_mask = new TMask ("ba1100a");
_browse = new TDir_sheet ("Manutenzione file di sistema", superprassi ? 0xC : 0x8);
@ -419,7 +423,7 @@ void TManutenzione_app::edit_riga (long riga_sel, TToken_string& riga)
_mask->reset (FLD_EXTEND);
_mask->reset (F_TAB);
const TRecnotype oldeox = atol(_mask->get(FLD_EOX));
const TRecnotype oldeox = _mask->get_long(FLD_EOX);
const bool com = prefix().is_com() || !*prefix().name();
const char* name = _mask->get(FLD_NOME);
const bool enable_extend = (com ? *name != '$' : *name == '$') &&
@ -457,7 +461,7 @@ void TManutenzione_app::edit_riga (long riga_sel, TToken_string& riga)
dep.Flags = atol(_mask->get (FLD_FLAG));
strcpy (dep.Des,_mask->get (FLD_DESC));
strcpy (dep.FCalc,_mask->get (FLD_FORMULA));
const TRecnotype eox = atol(_mask->get(FLD_EOX));
const TRecnotype eox = _mask->get_bool(FLD_EXTEND) ? _mask->get_long(FLD_EOX) : oldeox;
_browse->dir()->get(logicnum, _lock, _nordir, _sysdirop);
_browse->dir()->set(dep.SysName, dep.EOD, dep.Flags,
@ -581,22 +585,16 @@ void TManutenzione_app::update_dir()
if (prefix().get_codditta() <= _history_firm)
return;
prefix().set("");
const int orig_items = _dirs.last();
TString desc(256), s(256);
TDir d;
d.get(LF_DIR);
const int orig_items = (int)d.eod();
prefix().set(pref);
TDir d ;
d.get(LF_DIR);
const int items = (int)d.eod();
s = "Aggiornamento direttorio ";
if (is_com) s << "comune.";
else s << "della ditta " << atol (pref) <<".";
TString80 s("Aggiornamento direttorio ");
if (is_com) s << "comune";
else s << " della ditta " << atol (pref) <<".";
#if XVT_OS == XVT_OS_WIN
s << " Memoria libera: " << (long)GetFreeSpace(0)/1024 << " Kbytes.";
#endif
@ -607,19 +605,22 @@ void TManutenzione_app::update_dir()
for (int i = 2; i <= items; i++)
{
p.addstatus(1);
prefix().set("");
d.get(i, _nolock, _nordir, _sysdirop);
bool is_firm = d.is_firm();
bool to_create = (is_com ? d.is_com() : d.is_firm());
desc = d.des();
s = d.name();
// prefix().set("");
const TDir & ds = (const TDir &) _dirs[i];
const bool is_firm = ds.is_firm();
const bool to_create = (is_com ? ds.is_com() : ds.is_firm());
// TString s(ds.name());
TFilename fd(ds.filename());
bool towrite = FALSE;
long flags = d.flags();
word len = d.len();
prefix().set(pref);
// long flags = ds.flags();
// word len = ds.len();
// prefix().set(pref);
d.get(i);
if (!fexist(d.filename()))
TFilename fs(d.filename());
if (!fexist(fs))
{
if (d.eox() > 0L)
{
@ -632,7 +633,7 @@ void TManutenzione_app::update_dir()
else
if (i > 2)
{
FILE * f = fopen(d.filename(), "r");
FILE * f = fopen(fs, "r");
if (f != NULL)
{
fseek(f, 0L, SEEK_END);
@ -673,25 +674,14 @@ void TManutenzione_app::update_dir()
d.get(i, _nolock, _nordir, _sysdirop);
if (to_create)
{
TDir d1;
prefix().set("");
d1.get(i);
TFilename fd(d1.name());
prefix().set(pref);
d1.get(i);
TFilename fs(d1.name());
fs.ext("dbf");
fd.ext("dbf");
/* non piu' necessario
if (is_firm)
{
TString name(fd);
fd.cut(0);
fd << fs.path() << name;
}
*/
if (fexist(fs) && (fd != fs))
{
@ -763,36 +753,38 @@ void TManutenzione_app::update_dir()
ok = FALSE;
if (ok)
{
d.set(s, d.eox(), 0L, desc, d.expr());
d.set(s, d.eox(), 0L, ds.des(), d.expr());
towrite = TRUE;
}
}
}
else
{
towrite = (desc != d.des());
towrite = (TString(ds.des()) != d.des());
if (towrite)
strcpy((char *) d.des(), desc);
strcpy((char *) d.des(), ds.des());
}
if (towrite)
d.put(i, _nordir, _sysdirop);
d.get(i);
// d.get(i);
} // end of for scope
prefix().set(pref);
// prefix().set(pref);
if (items >= orig_items) return;
for (i = items + 1; i <= orig_items; i++)
{
prefix().set("");
d.get(i, _nolock, _nordir, _sysdirop);
prefix().set(pref);
d.set_len(0);
d.eox() = 0;
d.flags() = 0L;
d.put(i, _nordir, _sysdirop);
// prefix().set("");
// d.get(i, _nolock, _nordir, _sysdirop);
// prefix().set(pref);
TDir d1((TDir &) _dirs[i]);
d1.set_len(0);
d1.eox() = 0;
d1.flags() = 0L;
d1.put(i, _nordir, _sysdirop);
}
prefix().set(pref);
// prefix().set(pref);
d.get(LF_DIR, _nolock, _nordir, _sysdirop);
d.eod() = orig_items;
if (d.eox() < d.eod())
@ -806,7 +798,6 @@ void TManutenzione_app::convert_dir()
const bool is_com = prefix().is_com();
TDir d;
TTrec r;
if (prefix().get_codditta() <= _history_firm)
return;
@ -829,14 +820,14 @@ void TManutenzione_app::convert_dir()
for (int i = 2; i <= items; i++)
{
p.addstatus(1);
prefix().set("");
r.get(i);
d.get(i);
prefix().set(pref);
if (d.len() > 0)
// prefix().set("");
const TTrec & rs = (const TTrec &) _recs[i];
const TDir & ds = (const TDir &) _dirs[i];
// prefix().set(pref);
if (ds.len() > 0)
{
TBaseisamfile b(i);
const int module = abs((int)d.flags());
const int module = abs((int)ds.flags());
int err = b.is_valid();
if (err == -60) err=NOERR;
d.get(i, _nolock, _nordir, _sysdirop);
@ -849,7 +840,7 @@ void TManutenzione_app::convert_dir()
TSystemisamfile f(i);
f.update(r);
f.update(rs);
if (f.status() == 8) // cio' significa che e' accaduto quasi l'irreparabile...
{
{
@ -869,8 +860,7 @@ void TManutenzione_app::convert_dir()
if (to_create && has_module(module, CHK_DONGLE))
{
d.get(i);
TFilename s(d.name());
s.ext("dbf");
TFilename s(d.filename());
if (!fexist(s))
{
TSystemisamfile f(i);
@ -880,20 +870,88 @@ void TManutenzione_app::convert_dir()
}
else
{
TTrec r(rs);
r.zero();
r.put(i);
}
}
prefix().set("");
const long level = prefix().filelevel();
prefix().set(pref);
// prefix().set(pref);
d.get(LF_DIR, _nolock, _nordir, _sysdirop);
d.flags() = level;
d.flags() = _level;
d.put(LF_DIR, _nordir, _sysdirop);
put_history(pref);
}
void TManutenzione_app::load_des()
{
const TString pref(prefix().name());
_dirs.destroy();
_recs.destroy();
_level = prefix().filelevel();
TDir d;
TTrec r;
d.get(LF_DIR);
const int items = (int)d.eod();
const bool standard = pref.empty();
TString80 s("Caricamento descrizioni archivi ");
if (standard) s << "standard";
else
if (prefix().is_com()) s << "comuni";
else s << " della ditta " << atol (pref);
TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
p.setstatus(1);
for (int i = 2; i <= items; i++)
{
p.addstatus(1);
d.get(i, _nolock, _nordir, _sysdirop);
r.get(i);
if (standard)
{
TFilename desc_file;
desc_file << DESCDIR << "/f" << i;
desc_file.ext("trr");
if (fexist(desc_file))
{
{
ifstream in(desc_file);
TFilename descfname;
descfname.format("%s/d%d.des", DESCDIR, i);
if (!fexist(descfname))
{
FILE * fd = fopen(descfname, "w");
if (fd != NULL)
fclose(fd);
}
TConfig descr(descfname, DESCPAR);
r.set_des(&descr);
in >> r;
r.put(i);
d.set_len(r.len());
d.put(i, _nordir, _sysdirop);
r.set_des();
}
remove(desc_file);
}
}
_dirs.add(d, i);
_recs.add(r, i);
}
}
void TManutenzione_app::update()
{
bool ok = TRUE;
@ -939,12 +997,14 @@ void TManutenzione_app::update()
do_events();
begin_wait();
prefix().set("");
load_des();
prefix().set("com");
if (prefix().filelevel() <= 199502L)
/* if (prefix().filelevel() <= 199502L)
{
TExternal_app app("bacnv 4 0");
app.run();
}
} */
update_dir();
convert_dir();
@ -983,6 +1043,7 @@ void TManutenzione_app::update()
if (firm > 0) set_firm(firm);
else prefix().set(pref);
load_des();
ok = FALSE;
while (!ok)

View File

@ -166,14 +166,26 @@ HIDDEN bool len_handler(TMask_field& f, KEY key)
}
bool TRec_sheet::fld_notify(TSheet_field& f, int r, KEY k)
{
if (k == K_CTRL + K_INS)
{
TToken_string & row = f.row(r);
row.add("1", f.cid2index(FLD_TIPO));
}
return TRUE;
}
bool TRec_sheet::key_notify(TSheet_field& f, int r, KEY k)
{
if (k == K_INS)
{
const int items = f.items();
f.disable_cell(0, 1);
if (f.items() >= 8) return FALSE;
}
else
if (k = K_CTRL + K_INS)
f.enable_cell(r, 1, r > 0);
return TRUE;
}
@ -214,6 +226,7 @@ void TRec_sheet::edit()
_mask->set (F_NUM, _dir->num());
_mask->set (F_DES, _dir->des());
f1.sheet_mask().field(FLD_LEN).set_handler(len_handler);
f1.set_notify(fld_notify);
f1.set_append(FALSE);
int nfields = _rec->fields();