Resa possibile convivenza di due istanze di campo installate in diverse cartelle

git-svn-id: svn://10.65.10.50/branches/R_10_00@22915 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
guy 2014-03-07 13:57:54 +00:00
parent 0dff96647c
commit 0a00dffb16
4 changed files with 77 additions and 41 deletions

View File

@ -1746,12 +1746,62 @@ HIDDEN int dir_sort(const TObject** d1, const TObject** d2)
class TStudy_mask : public TAutomask
{
bool is_valid_study(const char* path) const;
void list_studies(TString_array& s, bool count_firms) const;
protected:
virtual bool on_field_event(TOperable_field& o, TField_event e, long jolly);
public:
TStudy_mask();
};
bool TStudy_mask::is_valid_study(const char* path) const
{
TFilename n = path;
n.add("com/dir.gen");
return n.find(' ') < 0 && n.exist();
}
void TStudy_mask::list_studies(TString_array& sht, bool firms_count) const
{
TFilename str = firm2dir(-1);
for (int i = str.len()-2; i > 0; i--)
{
if (str[i] == '\\' || str[i] == '/')
{
str.cut(i);
break;
}
}
str.add("*");
SLIST dirs = xvt_fsys_list_files(DIR_TYPE, str, true);
for (SLIST_ELT e = xvt_slist_get_first(dirs); e; e = xvt_slist_get_next(dirs, e))
{
const char* f = xvt_slist_get(dirs, e, NULL);
if (is_valid_study(f))
{
if (firms_count)
{
str = f; str.add("?????A");
SLIST firms = xvt_fsys_list_files(DIR_TYPE, str, true);
const int nf = xvt_slist_count(firms);
xvt_slist_destroy(firms);
if (nf > 0)
{
TToken_string row = f;
row.add(nf);
sht.add(row);
}
}
else
sht.add(f);
}
}
xvt_slist_destroy(dirs);
}
bool TStudy_mask::on_field_event(TOperable_field& o, TField_event e, long jolly)
{
switch (o.dlg())
@ -1765,48 +1815,34 @@ bool TStudy_mask::on_field_event(TOperable_field& o, TField_event e, long jolly)
o.set(firm2dir(-1));
if (e == fe_modify || e == fe_close)
{
TFilename path(o.get());
path.add("com");
path.add("dir.gen");
if (!path.exist() || path.find(' ') >= 0)
return error_box("%s %s", (const char*)o.get(), TR("non e' uno studio valido!"));
TFilename s = o.get();
if (e == fe_modify && s.full() && !is_valid_study(s))
{
const TString name = s.name_only();
TString_array std; list_studies(std, false);
TString strBest;
double dBest = 0;
FOR_EACH_ARRAY_ROW(std, i, row)
{
const TFilename study = *row;
const TString& sn = study.name_only();
const double score = xvt_str_fuzzy_compare_ignoring_case(name, sn);
if (score > dBest)
{
strBest = study;
dBest = score;
}
}
if (dBest > 0.75)
o.set(s = strBest);
}
if (!is_valid_study(s))
return error_box("%s %s", (const char*)s, TR("non è uno studio valido!"));
}
if (e == fe_button)
{
TFilename str = firm2dir(-1);
for (int i = str.len()-2; i > 0; i--)
{
if (str[i] == '\\' || str[i] == '/')
{
str.cut(i);
break;
}
}
str.add("*");
SLIST dirs = xvt_fsys_list_files(DIR_TYPE, str, true);
TFilename dirgen;
TArray_sheet sht(-1, -1, 78, 20, TR("Scelta studio"), HR("Studio@70|Ditte"));
for (SLIST_ELT e = xvt_slist_get_first(dirs); e; e = xvt_slist_get_next(dirs, e))
{
const char* f = xvt_slist_get(dirs, e, NULL);
dirgen = f;
if (dirgen.find(' ') < 0) // Scarta gli studi contenenti spazi
{
dirgen.add("com/dir.gen");
if (dirgen.exist())
{
TToken_string row = f;
str = f; str.add("?????A");
SLIST firms = xvt_fsys_list_files(DIR_TYPE, str, true);
row.add(xvt_slist_count(firms));
xvt_slist_destroy(firms);
sht.add(row);
}
}
}
xvt_slist_destroy(dirs);
list_studies(sht.rows_array(), true);
sht.rows_array().TArray::sort(dir_sort);
if (sht.run() == K_ENTER)
o.set(sht.row(-1).get(0)); // -1 = selected row

View File

@ -636,7 +636,7 @@ bool TOutlook_mask::can_be_closed() const
TBook_field& bf = book_field();
if (bf.pages() > 0)
{
TMask cm(TR("Chiusura applicazioni"), 1, 50, 8);
TMask cm(TR("Chiusura applicazioni"), 1, 50, 9);
TToken_string options;
options = TR("Non chiudere le applicazioni in esecuzione");

View File

@ -1279,7 +1279,7 @@ bool TQuery_mask::on_field_event(TOperable_field& o, TField_event e, long jolly)
next_page(1001);
bool ok = true;
if (_sql_dirty && !field(F_SQL).empty())
ok = yesno_box(TR("Attenzione: la query verra' rigenerata\n"
ok = yesno_box(TR("Attenzione: la query verrà rigenerata\n"
"annullando eventuali modifiche manuali.\n"
"Si desidera proseguire?"));
if (ok)

View File

@ -140,7 +140,7 @@ PAGE "Sql" -1 -1 78 23
MEMO F_SQL 78 -3
BEGIN
PROMPT 1 0 "SQL query"
PROMPT 1 0 "ISAM / SQL query"
END
BUTTON F_EDITQUERY 10 2