Files correlati : Ricompilazione Demo : [ ] Commento : git-svn-id: svn://10.65.10.50/trunk@18348 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			381 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			381 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
#include <automask.h>
 | 
						|
#include <filetext.h>
 | 
						|
  
 | 
						|
#include "../ve/velib.h"
 | 
						|
   
 | 
						|
#include "ps0077.h"
 | 
						|
#include "ps0077400a.h"
 | 
						|
 
 | 
						|
class TFilConad: public TFile_text
 | 
						|
{
 | 
						|
protected:
 | 
						|
  virtual void validate(TCursor& cur,TRecord_text &rec, TToken_string &val, TString& str);
 | 
						|
 | 
						|
public:
 | 
						|
  TFilConad(const TString& file_name, const TString& config_name);
 | 
						|
  virtual ~TFilConad() { }
 | 
						|
};
 | 
						|
 | 
						|
TFilConad::TFilConad(const TString& file_name, const TString& config_name)
 | 
						|
          : TFile_text(file_name, config_name)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
class TBolle2Conad_mask : public TAutomask
 | 
						|
{
 | 
						|
protected:
 | 
						|
  bool on_field_event(TOperable_field& o, TField_event e, long jolly);
 | 
						|
public:
 | 
						|
 | 
						|
  TBolle2Conad_mask();
 | 
						|
  
 | 
						|
  virtual ~TBolle2Conad_mask(){};
 | 
						|
};
 | 
						|
  
 | 
						|
TBolle2Conad_mask::TBolle2Conad_mask() :TAutomask ("ps0077400a")
 | 
						|
{
 | 
						|
}  
 | 
						|
  
 | 
						|
bool TBolle2Conad_mask::on_field_event(TOperable_field& o, TField_event e, long jolly)
 | 
						|
{ 
 | 
						|
  return TRUE;
 | 
						|
}
 | 
						|
 | 
						|
class TBolle2Conad : public TSkeleton_application
 | 
						|
{                     
 | 
						|
	TCursor*				   _cur;
 | 
						|
  TBolle2Conad_mask* _msk;
 | 
						|
  TDate							 _dataini, _datafin;
 | 
						|
  long 					     _codconad;
 | 
						|
  TString80					 _codforn;
 | 
						|
  TDocumento*				 _fattura;
 | 
						|
  TDocumento*  			 _bolla;
 | 
						|
  TRiga_documento*   _rigabolla;
 | 
						|
  TFilConad*				 _trasfile;
 | 
						|
  long							 _progressivo;
 | 
						|
  int								 _modalita;     // 0 = elabora doc. originali (MARPESCA) 1 = elabora doc. indicati (MAINARDI)
 | 
						|
  TAssoc_array*			 _elencobolle; // assoc array per verificare se la bolla è gia stat passata
 | 
						|
  
 | 
						|
protected:
 | 
						|
 | 
						|
  virtual const char * extra_modules() const {return "ve";}
 | 
						|
 | 
						|
  virtual bool create(void);
 | 
						|
  virtual bool destroy(void);
 | 
						|
  virtual void main_loop() ;
 | 
						|
  
 | 
						|
  void elabora_documenti();
 | 
						|
  void elabora_righe_doc();
 | 
						|
  void elabora_doc_originale(const TDocumento& documento);
 | 
						|
 | 
						|
public:
 | 
						|
	const TDocumento fattura() {return *_fattura;} ;
 | 
						|
	const TDocumento bolla() {return *_bolla;} ;
 | 
						|
	const TRiga_documento rigabolla() {return *_rigabolla;} ;
 | 
						|
	const long progressivo() {return _progressivo;} ;
 | 
						|
	const TString80 fornitore() { return _codforn;} ;
 | 
						|
	const long conad() { return _codconad;} ;
 | 
						|
  TBolle2Conad() {} ;
 | 
						|
  virtual ~TBolle2Conad() {} ;
 | 
						|
};  
 | 
						|
 | 
						|
// restituisce un riferimento all' applicazione
 | 
						|
inline TBolle2Conad& app() { return (TBolle2Conad&) main_app();}
 | 
						|
 | 
						|
// gestione dei messaggi estesi nei campi
 | 
						|
void TFilConad::validate(TCursor& cur,TRecord_text &rec, TToken_string &s, TString& str)
 | 
						|
{
 | 
						|
  const TString code(s.get(0));
 | 
						|
  TString valore;
 | 
						|
  if (code == "_FISSO")
 | 
						|
  {
 | 
						|
    // gestione dei campi fissi per i record delle riba
 | 
						|
    // sintassi: _FISSO,!<valore>
 | 
						|
    // dove: <valore> è la stringa fissa da emettere
 | 
						|
    TString in(s.get());
 | 
						|
    CHECK(in[0]=='!',"Macro _FISSO senza carattere '!'");
 | 
						|
    in.ltrim(1);
 | 
						|
    in.trim();
 | 
						|
    valore = in;
 | 
						|
  }
 | 
						|
  else if (code == "_PROGRESSIVO")
 | 
						|
  {
 | 
						|
    valore.format("%05d", app().progressivo());
 | 
						|
  }
 | 
						|
  else if (code == "_FORNITORE")
 | 
						|
  {
 | 
						|
    valore = app().fornitore();
 | 
						|
  }
 | 
						|
  else if (code == "_CONAD")
 | 
						|
  {
 | 
						|
    valore.format("%015d", app().conad());
 | 
						|
  }
 | 
						|
  else if (code == "_FATTURA")
 | 
						|
  {
 | 
						|
     // gestione campi da leggere dalla fattura 
 | 
						|
    TString in(s.get());
 | 
						|
    if (in == "DATA")
 | 
						|
    {
 | 
						|
    	TDate data = app().fattura().data();
 | 
						|
    	valore = data.string(brief, '-', full, full, amg_date);
 | 
						|
    	valore.strip("-");
 | 
						|
    }
 | 
						|
    else if (in == "NUMERO")
 | 
						|
    {
 | 
						|
    	valore.format("%06d", app().fattura().numero());
 | 
						|
    }
 | 
						|
  }
 | 
						|
  else if (code == "_BOLLA")
 | 
						|
  {
 | 
						|
     // gestione campi da leggere dalla bolla
 | 
						|
    TString in(s.get());
 | 
						|
    if (in == "DATA")
 | 
						|
    {
 | 
						|
    	TDate data = app().bolla().data();
 | 
						|
    	valore = data.string(brief, '-', full, full, amg_date);
 | 
						|
    	valore.strip("-");
 | 
						|
    }
 | 
						|
		else if (in == "NUMERO")
 | 
						|
		{
 | 
						|
			valore = str;
 | 
						|
			const TString16 codnum = cur.curr().get("CODNUM");
 | 
						|
			TString16 suffisso = cache().get("%NUM", codnum, "S7");
 | 
						|
			valore.trim();
 | 
						|
			suffisso.trim();
 | 
						|
			valore << suffisso;
 | 
						|
		}
 | 
						|
  }
 | 
						|
  else if (code == "_RIGABOLLA")
 | 
						|
  {
 | 
						|
  	// gestione campi da leggere dalla riga bolla corrente
 | 
						|
 		TString in(s.get()); 	
 | 
						|
 		if (in == "PREZZO")
 | 
						|
 		{
 | 
						|
 			real r = app().rigabolla().prezzo(TRUE, FALSE);
 | 
						|
 			valore = r.string(9,3);
 | 
						|
 			valore.strip(".");
 | 
						|
 		}
 | 
						|
 		else if (in == "IMPORTO")
 | 
						|
 		{
 | 
						|
 			real r = app().rigabolla().importo(TRUE, FALSE);
 | 
						|
 			valore = r.string(9,3);
 | 
						|
 			valore.strip(".");
 | 
						|
 		}
 | 
						|
 		else if (in == "ALIQUOTA")
 | 
						|
 		{
 | 
						|
 			real r = app().rigabolla().iva().percentuale();
 | 
						|
 			valore = r.string(2,0,'0');
 | 
						|
 		}
 | 
						|
 		else if (in == "QUANTITA")
 | 
						|
 		{
 | 
						|
 			real r = app().rigabolla().quantita();
 | 
						|
 			valore = r.string(7,2);
 | 
						|
 			valore.strip(".");
 | 
						|
 		}
 | 
						|
 		else if (in == "OMAGGIO")
 | 
						|
 		{
 | 
						|
 			if (app().rigabolla().is_omaggio())
 | 
						|
 				valore = "6";
 | 
						|
 			else	         
 | 
						|
 				valore = "1";
 | 
						|
 		}
 | 
						|
  }
 | 
						|
  else NFCHECK("Macro non definita: %s", (const char *)code);
 | 
						|
  
 | 
						|
  str = valore;
 | 
						|
}
 | 
						|
 | 
						|
bool TBolle2Conad::create()
 | 
						|
{      
 | 
						|
	open_files(LF_DOC, LF_RIGHEDOC, LF_CLIFO, LF_CFVEN, LF_INDSP, LF_ANAMAG, 0);
 | 
						|
  _msk = new TBolle2Conad_mask();
 | 
						|
  _trasfile = NULL;
 | 
						|
	_elencobolle = new TAssoc_array();
 | 
						|
  
 | 
						|
  return TSkeleton_application::create();
 | 
						|
}
 | 
						|
 | 
						|
bool TBolle2Conad::destroy()
 | 
						|
{             
 | 
						|
	delete _elencobolle;
 | 
						|
	if (_trasfile)  
 | 
						|
  	delete _trasfile;
 | 
						|
  delete _msk;
 | 
						|
 | 
						|
  return TSkeleton_application::destroy();
 | 
						|
}
 | 
						|
 | 
						|
void TBolle2Conad::main_loop()
 | 
						|
{
 | 
						|
	TConfig config("ps0077400conf.ini", "TRASFERIMENTO");
 | 
						|
	TFilename tracciatoname = config.get("TRACCIATO");
 | 
						|
	_modalita = config.get_int("MODALITA");
 | 
						|
	_codconad = config.get_long("CONAD");
 | 
						|
	_codforn = config.get("FORNITORE");
 | 
						|
	TFilename filename = config.get("NOMEFILE");
 | 
						|
	if (filename.exist())
 | 
						|
		remove(filename);
 | 
						|
  while (_msk->run()!=K_QUIT)
 | 
						|
  {                     
 | 
						|
		_elencobolle->destroy();
 | 
						|
  	_progressivo = 0;
 | 
						|
  	_trasfile = new TFilConad(filename, tracciatoname);
 | 
						|
  	_trasfile->open(filename,'w');
 | 
						|
	  _trasfile->force_record_separator(TRUE);
 | 
						|
  	
 | 
						|
    _dataini = _msk->get_date(F_DATAINI);
 | 
						|
    _datafin = _msk->get_date(F_DATAFIN);
 | 
						|
		elabora_documenti(); 		
 | 
						|
		_trasfile->close();
 | 
						|
		delete _trasfile;
 | 
						|
		_trasfile = NULL;
 | 
						|
	}	
 | 
						|
}
 | 
						|
 | 
						|
void TBolle2Conad::elabora_documenti()
 | 
						|
{
 | 
						|
  TSheet_field& sheet = _msk->sfield(F_SHEETDOC);
 | 
						|
 | 
						|
  TRelation doc_rel(LF_DOC);
 | 
						|
  doc_rel.add(LF_RIGHEDOC, "CODNUM==CODNUM|ANNO==ANNO|PROVV==PROVV|NDOC==NDOC");
 | 
						|
  doc_rel.add(LF_CFVEN, "TIPOCF==TIPOCF|CODCF==CODCF");
 | 
						|
  TRectype da(LF_DOC);
 | 
						|
  TRectype a(LF_DOC);
 | 
						|
  const long items = sheet.items();
 | 
						|
  if (items > 0)
 | 
						|
  {
 | 
						|
	  bool ok = TRUE;
 | 
						|
	  TString16 codnum;
 | 
						|
	  TString filt_expr;
 | 
						|
	  if (_modalita == 0) // MARPESCA, seleziono in base al codice cliente indicato in ps0077400conf.ini
 | 
						|
	  {
 | 
						|
			da.put("TIPOCF", "C");
 | 
						|
			da.put("CODCF", _codconad);
 | 
						|
			da.put("PROVV", "D");
 | 
						|
			da.put("ANNO", _dataini.year());
 | 
						|
			da.put("DATADOC", _dataini);
 | 
						|
 | 
						|
			a.put("TIPOCF", "C");
 | 
						|
			a.put("CODCF", _codconad);
 | 
						|
			a.put("PROVV", "D");
 | 
						|
			a.put("ANNO", _datafin.year());
 | 
						|
			a.put("DATADOC", _datafin);
 | 
						|
		}
 | 
						|
		else // MAINARDI selezione solo per data iniziale e finale
 | 
						|
		{
 | 
						|
		  da.put("DATADOC", _dataini);
 | 
						|
		  da.put("PROVV", "D");
 | 
						|
		  da.put("ANNO", _dataini.year());
 | 
						|
	  
 | 
						|
		  a.put("DATADOC", _datafin);
 | 
						|
		  a.put("PROVV", "D");
 | 
						|
		  a.put("ANNO", _datafin.year());
 | 
						|
		}
 | 
						|
	  filt_expr << "(";
 | 
						|
	  FOR_EACH_SHEET_ROW(sheet, r, row)
 | 
						|
	  {
 | 
						|
	    codnum = row->get(0);
 | 
						|
	    if (codnum.not_empty())
 | 
						|
	    {
 | 
						|
	    	filt_expr << "(CODNUM==\"";
 | 
						|
	    	filt_expr << codnum << "\")||";
 | 
						|
	    }
 | 
						|
	  }
 | 
						|
	  filt_expr.rtrim(2);  
 | 
						|
	  filt_expr << ")";
 | 
						|
    if (_modalita == 0)
 | 
						|
	  _cur = new TCursor(&doc_rel,filt_expr,2,&da,&a);
 | 
						|
	  else
 | 
						|
	  	_cur = new TCursor(&doc_rel,filt_expr,3,&da,&a);
 | 
						|
	  const long cur_items = _cur ->items(); // Scorre tutti i documenti che rientrano nell'intervallo selezionato
 | 
						|
	  if (cur_items != 0) 
 | 
						|
	  {
 | 
						|
		  _cur->freeze();
 | 
						|
	    TRectype& cur_rec = _cur->curr();
 | 
						|
	    for (*_cur = 0; _cur->pos() < cur_items; ++(*_cur))
 | 
						|
	    {
 | 
						|
	    	if (_modalita == 0)
 | 
						|
		    	elabora_righe_doc();
 | 
						|
	    	else                      
 | 
						|
	    	{
 | 
						|
	    		TString16 codprcf = _cur->curr(LF_CFVEN).get("CODPRCF");
 | 
						|
	    		if (codprcf.not_empty())
 | 
						|
	    		{
 | 
						|
						_bolla = new TDocumento(_cur->curr());
 | 
						|
						elabora_doc_originale(*_bolla);
 | 
						|
						delete _bolla;
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
	  }                  
 | 
						|
	  delete _cur;
 | 
						|
	}  
 | 
						|
}
 | 
						|
 | 
						|
void TBolle2Conad::elabora_righe_doc()
 | 
						|
{                          
 | 
						|
          
 | 
						|
	_fattura = new TDocumento(_cur->curr());
 | 
						|
	for (int i=1;i<=_fattura->rows();i++)
 | 
						|
	{
 | 
						|
		const TRiga_documento& riga = (*_fattura)[i];
 | 
						|
		const TString16 dacodnum = riga.get("DACODNUM");		
 | 
						|
		const int daanno = riga.get_int("DAANNO");		
 | 
						|
		const char daprovv = riga.get("DAPROVV")[0];		
 | 
						|
		const long dandoc = riga.get_long("DANDOC");		
 | 
						|
		if (dacodnum.not_empty() && daanno != 0  && daprovv != ' ' && dandoc != 0)
 | 
						|
		{
 | 
						|
			TString codicebolla = "";
 | 
						|
			codicebolla << daprovv;
 | 
						|
			codicebolla << daanno;
 | 
						|
			codicebolla << dacodnum;
 | 
						|
			codicebolla << dandoc;
 | 
						|
			if (!_elencobolle->is_key((const char*) codicebolla))
 | 
						|
			{ 
 | 
						|
				_elencobolle->add((const char*) codicebolla);
 | 
						|
				_bolla = new TDocumento(daprovv, daanno, dacodnum, dandoc);
 | 
						|
				elabora_doc_originale(*_bolla);
 | 
						|
				delete _bolla;
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}	
 | 
						|
	delete _fattura;
 | 
						|
}
 | 
						|
 
 | 
						|
void TBolle2Conad::elabora_doc_originale(const TDocumento& documento)
 | 
						|
{                                   
 | 
						|
	TRelation bol_rel(LF_DOC);
 | 
						|
  bol_rel.add(LF_RIGHEDOC, "CODNUM==CODNUM|ANNO==ANNO|PROVV==PROVV|NDOC==NDOC");
 | 
						|
  bol_rel.add(LF_ANAMAG, "CODART==CODART", 1, LF_RIGHEDOC);
 | 
						|
  bol_rel.add(LF_INDSP, "TIPOCF==TIPOCF|CODCF==CODCF|CODIND==CODINDSP", 1, LF_DOC);
 | 
						|
  bol_rel.add(LF_CFVEN, "TIPOCF==TIPOCF|CODCF==CODCF",1, LF_DOC);
 | 
						|
	TRectype da(documento.head());
 | 
						|
  
 | 
						|
  TCursor bol_cur(&bol_rel, "", 2, &da, &da);
 | 
						|
  bol_cur = 0;
 | 
						|
	_progressivo++;                   	
 | 
						|
	// scrivo il record 01 testata bolla
 | 
						|
  TRecord_text rec;
 | 
						|
  rec.set_type("01");
 | 
						|
  _trasfile->autoload(rec, bol_cur); 
 | 
						|
  _trasfile->write(rec);
 | 
						|
  // scrivo i record 02 righe bolla
 | 
						|
	for (int i=1;i<=documento.rows();i++)
 | 
						|
	{                                        
 | 
						|
		_rigabolla = new TRiga_documento(documento[i]);
 | 
						|
	  rec.set_type("02");
 | 
						|
  	_trasfile->autoload(rec, bol_cur); 
 | 
						|
  	_trasfile->write(rec);
 | 
						|
  	delete _rigabolla;
 | 
						|
  	bol_cur.next_match(LF_RIGHEDOC);
 | 
						|
  }  
 | 
						|
}
 | 
						|
 
 | 
						|
int ps0077400(int argc, char **argv) 
 | 
						|
{
 | 
						|
  TBolle2Conad a;
 | 
						|
  a.run(argc, argv, TR("Trasferimento bolle CONAD"));
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
 |