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 <ctype.h>
 | 
			
		||||
 | 
			
		||||
#include <applicat.h>
 | 
			
		||||
#include <isam.h>
 | 
			
		||||
@ -12,6 +13,14 @@
 | 
			
		||||
#include "ba1.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
 | 
			
		||||
{
 | 
			
		||||
@ -32,6 +41,7 @@ protected:
 | 
			
		||||
  void update_dir();
 | 
			
		||||
  void convert_dir();
 | 
			
		||||
  virtual void print();
 | 
			
		||||
  virtual void do_print(TPrinter & p, TRec_sheet & r);
 | 
			
		||||
  const char* dumpfilename(const FileDes& dep) const;
 | 
			
		||||
 | 
			
		||||
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",
 | 
			
		||||
                          "Reale", "Data", "Intero", "Carattere",
 | 
			
		||||
                          "Booleano", "Intero Zerofilled", 
 | 
			
		||||
                          "Intero Lungo Zerofilled"};
 | 
			
		||||
  TPrinter& p = printer();
 | 
			
		||||
  TPrintrow row;
 | 
			
		||||
  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.put(format("Lista tracciato %s (%s)", _rec->dir()->des(),
 | 
			
		||||
                 _rec->dir()->name()), 2);
 | 
			
		||||
  row.put("Pag. @#", 66);
 | 
			
		||||
  if (istab)
 | 
			
		||||
    row.put(format("Lista tabella %s ", (const char *) tab), 2);
 | 
			
		||||
  else
 | 
			
		||||
    row.put(format("Lista tracciato %s (%s)", dir.des(), dir.name()), 2);
 | 
			
		||||
  row.put("Pag. @#", 69);
 | 
			
		||||
  p.setheaderline(2, row);
 | 
			
		||||
  row.reset();
 | 
			
		||||
  row.put("Nome", 7);
 | 
			
		||||
  row.put("Tipo", 18);
 | 
			
		||||
  row.put("Lunghezza", 45);
 | 
			
		||||
  row.put(" Decimali", 55);
 | 
			
		||||
  row.put("Posizione", 65);
 | 
			
		||||
  row.put("Lun.", 38);
 | 
			
		||||
  row.put(" Dec.", 43);
 | 
			
		||||
  row.put("Pos.", 48);
 | 
			
		||||
  row.put("Descrizione", 53);
 | 
			
		||||
  p.setheaderline(4, row);
 | 
			
		||||
  p.setbackground("l[1,6,75,6]");
 | 
			
		||||
  for (int i = 0; i < _rec->rec()->fields(); i ++)
 | 
			
		||||
  p.setbackground("l[1,6,78,6]");
 | 
			
		||||
  for (int i = 0; i < rec.fields(); i ++)
 | 
			
		||||
  {
 | 
			
		||||
    row.reset();
 | 
			
		||||
    s = _rec->rec()->fielddef(i);
 | 
			
		||||
    s = rec.fielddef(i);
 | 
			
		||||
    TString16 name = s.get();
 | 
			
		||||
    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(format("     %4d", s.get_int()), 45);
 | 
			
		||||
    row.put(format("     %4d", s.get_int()), 55);
 | 
			
		||||
    row.put(format("     %4d", _rec->rec()->rec()->Fd[i].RecOff), 65);
 | 
			
		||||
    row.put(format("%4d", s.get_int()), 38);
 | 
			
		||||
    row.put(format("%4d", s.get_int()), 43);
 | 
			
		||||
    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);
 | 
			
		||||
      wd = d.get();
 | 
			
		||||
      while(wd != NULL)
 | 
			
		||||
      {
 | 
			
		||||
        row.reset();
 | 
			
		||||
        row.put(wd, 53);
 | 
			
		||||
        p.print(row);
 | 
			
		||||
        wd = d.get();
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }  
 | 
			
		||||
  p.formfeed();
 | 
			
		||||
  row.reset();
 | 
			
		||||
  row.put("Espressione chiave", 7);
 | 
			
		||||
  row.put("Duplicabile", 68);
 | 
			
		||||
  p.setheaderline(4, row);
 | 
			
		||||
  for (i = 0; i < _rec->rec()->keys(); i ++)
 | 
			
		||||
  for (i = 0; i < rec.keys(); i ++)
 | 
			
		||||
  {
 | 
			
		||||
    row.reset();
 | 
			
		||||
    s = _rec->rec()->keydef(i);
 | 
			
		||||
    s = rec.keydef(i);
 | 
			
		||||
    row.put(format("%3d", i + 1), 2);
 | 
			
		||||
    row.put(s.get(), 7);
 | 
			
		||||
    row.put(*s.get() == 'X' ? "Si" : "No", 68);
 | 
			
		||||
    p.print(row);
 | 
			
		||||
  }
 | 
			
		||||
  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();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -119,6 +227,7 @@ bool TManutenzione_app::create() // initvar e arrmask
 | 
			
		||||
    _browse->add_button(DLG_ADDFILE, "Aggiunge", K_F8);
 | 
			
		||||
    dispatch_e_menu(BAR_ITEM(1));
 | 
			
		||||
  }  
 | 
			
		||||
  enable_menu_item(M_FILE_PRINT);
 | 
			
		||||
  return TRUE ;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -141,9 +250,11 @@ void TManutenzione_app::insert_riga (long riga_sel, TToken_string& riga)
 | 
			
		||||
  _mask->disable(DLG_RECORD);
 | 
			
		||||
  _mask->disable(DLG_LOAD);
 | 
			
		||||
  _mask->disable(DLG_DUMP);
 | 
			
		||||
  _mask->show(F_TAB, logicnum >= LF_TABGEN && logicnum <= LF_TAB);
 | 
			
		||||
  _mask->hide(FLD_EXTEND);
 | 
			
		||||
  _mask->hide(FLD_EOX);
 | 
			
		||||
  _mask->set (FLD_NUM, riga.get(0));
 | 
			
		||||
  _mask->reset (F_TAB);
 | 
			
		||||
  
 | 
			
		||||
  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_LOAD);
 | 
			
		||||
  _mask->enable(DLG_DUMP);
 | 
			
		||||
  _mask->show(F_TAB, logicnum >= LF_TABGEN && logicnum <= LF_TAB);
 | 
			
		||||
  _mask->set (FLD_NUM, riga.get(0));
 | 
			
		||||
  _mask->set (FLD_NOME, 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_FLAG, riga.get());
 | 
			
		||||
  _mask->reset (FLD_EXTEND);
 | 
			
		||||
  _mask->reset (F_TAB);
 | 
			
		||||
 | 
			
		||||
  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 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_EOX, enable_extend);
 | 
			
		||||
@ -265,12 +378,10 @@ void TManutenzione_app::edit_riga (long riga_sel, TToken_string& riga)
 | 
			
		||||
  else
 | 
			
		||||
    if (tasto == K_F6)
 | 
			
		||||
    {
 | 
			
		||||
      enable_menu_item(M_FILE_PRINT);
 | 
			
		||||
      _rec = new TRec_sheet(logicnum);
 | 
			
		||||
      _rec = new TRec_sheet(logicnum, _mask->get(F_TAB));
 | 
			
		||||
      _rec->edit();
 | 
			
		||||
      delete _rec;
 | 
			
		||||
      _rec = NULL;
 | 
			
		||||
      disable_menu_item(M_FILE_PRINT);
 | 
			
		||||
    }
 | 
			
		||||
    else
 | 
			
		||||
      if (tasto == K_F7)
 | 
			
		||||
@ -338,11 +449,11 @@ void TManutenzione_app::update_dir()
 | 
			
		||||
 | 
			
		||||
{
 | 
			
		||||
  const TString pref(prefhndl->name());
 | 
			
		||||
  const bool is_com = prefhndl->is_com();
 | 
			
		||||
 | 
			
		||||
  prefhndl->set(""); 
 | 
			
		||||
  
 | 
			
		||||
  TDir d;
 | 
			
		||||
  const bool update_com = ( pref == "com");
 | 
			
		||||
  d.get(LF_DIR);                 
 | 
			
		||||
  const int orig_items = (int)d.eod();
 | 
			
		||||
  
 | 
			
		||||
@ -352,8 +463,8 @@ void TManutenzione_app::update_dir()
 | 
			
		||||
  const int items = (int)d.eod();
 | 
			
		||||
  TString80 s("Aggiornamento direttorio ");
 | 
			
		||||
 | 
			
		||||
  if (pref == "com") s << "comune";
 | 
			
		||||
  else s << " della ditta " <<atol (pref);
 | 
			
		||||
  if (is_com) s << "comune";
 | 
			
		||||
  else s << " della ditta " << atol (pref);
 | 
			
		||||
  
 | 
			
		||||
  TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
 | 
			
		||||
 | 
			
		||||
@ -371,9 +482,9 @@ void TManutenzione_app::update_dir()
 | 
			
		||||
    word len = d.len();
 | 
			
		||||
    prefhndl->set(pref);
 | 
			
		||||
    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()); 
 | 
			
		||||
      towrite = TRUE;
 | 
			
		||||
@ -425,7 +536,7 @@ void TManutenzione_app::convert_dir()
 | 
			
		||||
  const int items = (int)d.eod();
 | 
			
		||||
  TString80 s("Aggiornamento archivi ");
 | 
			
		||||
 | 
			
		||||
  if (pref == "com") s << "comuni";
 | 
			
		||||
  if (prefhndl->is_com()) s << "comuni";
 | 
			
		||||
  else s << " della ditta " << atol (pref);
 | 
			
		||||
  
 | 
			
		||||
  TProgind p(items ? items : 1, s, TRUE, TRUE, 70);
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										14
									
								
								ba/ba1100.h
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								ba/ba1100.h
									
									
									
									
									
								
							@ -5,12 +5,17 @@
 | 
			
		||||
#include <sheet.h>                 
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifndef __CONFIG_H                 
 | 
			
		||||
#include <config.h>                 
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#include "ba1100a.h"
 | 
			
		||||
 | 
			
		||||
///////////////////////////////////////////////////////////
 | 
			
		||||
// TDir_sheet  
 | 
			
		||||
///////////////////////////////////////////////////////////
 | 
			
		||||
 | 
			
		||||
#define DESCPAR "FieldDescr"
 | 
			
		||||
#define DESCDIR "recdesc"
 | 
			
		||||
 | 
			
		||||
class TDir_sheet : public TSheet
 | 
			
		||||
{
 | 
			
		||||
@ -41,7 +46,10 @@ class TRec_sheet : public TObject
 | 
			
		||||
  TTrec         *_rec_old;
 | 
			
		||||
  TDir          *_dir;
 | 
			
		||||
  bool          _comfile;
 | 
			
		||||
  TConfig       *_descr;
 | 
			
		||||
  static TMask  *_mask;
 | 
			
		||||
  TFilename     _descfname;
 | 
			
		||||
  TString16     _tab;
 | 
			
		||||
 | 
			
		||||
protected:
 | 
			
		||||
  bool check_key_expr(int key, const char* key_expr);
 | 
			
		||||
@ -51,10 +59,12 @@ protected:
 | 
			
		||||
  virtual long items() const { return _rec->fields(); }
 | 
			
		||||
 | 
			
		||||
public:
 | 
			
		||||
  TRec_sheet(int logicnum);
 | 
			
		||||
  TRec_sheet(int logicnum, const char * tab);
 | 
			
		||||
  ~TRec_sheet();
 | 
			
		||||
  TDir* dir() const { return _dir; }
 | 
			
		||||
  TTrec* rec() const { return _rec; }
 | 
			
		||||
  const char * descfname() const { return _descfname;}
 | 
			
		||||
  const char * tab() const { return _tab; }
 | 
			
		||||
  void edit();
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
@ -16,6 +16,7 @@
 | 
			
		||||
#define FLD_EOX 112
 | 
			
		||||
#define F_LEN   113
 | 
			
		||||
#define DLG_EDIR        114
 | 
			
		||||
#define F_TAB   115
 | 
			
		||||
 | 
			
		||||
#define FLD_OUTFILE     201
 | 
			
		||||
#define FLD_WITHKEY     202
 | 
			
		||||
@ -32,6 +33,7 @@
 | 
			
		||||
#define FLD_TIPO        102
 | 
			
		||||
#define FLD_LEN 103
 | 
			
		||||
#define FLD_DEC 104
 | 
			
		||||
#define FLD_DES 105
 | 
			
		||||
#define F_NUMF 110
 | 
			
		||||
 | 
			
		||||
#define F_NUM 501
 | 
			
		||||
 | 
			
		||||
@ -67,6 +67,12 @@ BEGIN
 | 
			
		||||
	FLAGS "RD"
 | 
			
		||||
END
 | 
			
		||||
 | 
			
		||||
STRING F_TAB 3
 | 
			
		||||
BEGIN        
 | 
			
		||||
  PROMPT 2 9 "Tabella      "
 | 
			
		||||
  FLAGS "U"
 | 
			
		||||
END
 | 
			
		||||
 | 
			
		||||
BUTTON DLG_OK 9 2
 | 
			
		||||
BEGIN
 | 
			
		||||
	PROMPT -14 -3 ""
 | 
			
		||||
 | 
			
		||||
@ -55,6 +55,7 @@ BEGIN
 | 
			
		||||
  ITEM "Tipo"
 | 
			
		||||
  ITEM "Lunghezza"
 | 
			
		||||
  ITEM "Decimali"
 | 
			
		||||
  ITEM "Descrizione@50"
 | 
			
		||||
END
 | 
			
		||||
 | 
			
		||||
SPREADSHEET F_KEYS
 | 
			
		||||
@ -68,7 +69,7 @@ ENDPAGE
 | 
			
		||||
 | 
			
		||||
ENDMASK
 | 
			
		||||
 | 
			
		||||
PAGE "Campo" -1 -1 60 9
 | 
			
		||||
PAGE "Campo" -1 -1 70 11
 | 
			
		||||
 | 
			
		||||
STRING F_NUMF 3 3
 | 
			
		||||
BEGIN
 | 
			
		||||
@ -126,6 +127,12 @@ BEGIN
 | 
			
		||||
  WARNING "Numero di decimali errato"
 | 
			
		||||
END
 | 
			
		||||
 | 
			
		||||
STRING FLD_DES 80 50
 | 
			
		||||
BEGIN
 | 
			
		||||
  PROMPT 2 6 "Descrizione "
 | 
			
		||||
  HELP "Descrizione del campo"
 | 
			
		||||
END
 | 
			
		||||
 | 
			
		||||
BUTTON DLG_OK 8 2
 | 
			
		||||
BEGIN
 | 
			
		||||
  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;
 | 
			
		||||
@ -88,6 +89,24 @@ TRec_sheet::TRec_sheet(int logicnum)
 | 
			
		||||
  _dir->get(logicnum, _lock, _nordir, _sysdirop);
 | 
			
		||||
  _rec->get(logicnum);
 | 
			
		||||
  *_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()
 | 
			
		||||
@ -97,6 +116,8 @@ TRec_sheet::~TRec_sheet()
 | 
			
		||||
  delete _rec_old;
 | 
			
		||||
  delete _mask;
 | 
			
		||||
  _mask = NULL;
 | 
			
		||||
  if (_descr)
 | 
			
		||||
    delete _descr;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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()
 | 
			
		||||
 | 
			
		||||
{
 | 
			
		||||
  if (*_rec == *_rec_old ||
 | 
			
		||||
  if ((*_rec == *_rec_old && !_descr) ||
 | 
			
		||||
      !yesnocancel_box("Devo salvare le modifiche")) return;
 | 
			
		||||
  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);
 | 
			
		||||
  *_rec_old = *_rec;
 | 
			
		||||
}
 | 
			
		||||
@ -191,7 +222,16 @@ void TRec_sheet::edit()
 | 
			
		||||
  f1.set_notify(fld_notify);
 | 
			
		||||
  f1.sheet_mask().field(FLD_LEN).set_handler(len_handler);
 | 
			
		||||
  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);
 | 
			
		||||
  int nkeys = _rec->keys();
 | 
			
		||||
  for (i = 0; i < nkeys; i++) f2.row(i) = _rec->keydef(i);
 | 
			
		||||
@ -205,7 +245,9 @@ void TRec_sheet::edit()
 | 
			
		||||
      _rec->set_fields(nfields);
 | 
			
		||||
      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->rehash();
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user