campo-sirio/cg/cg1500.cpp

4184 lines
123 KiB
C++
Raw Normal View History

// Stampa bilanci
// W96SALDI e' la sigla di tutte le modifiche effettuate riguardo il cambiamento dell' archivio
// SALDI. L' archivio e' cambiato nel seguente modo:
// - Non esistono piu' i progressivi dei movimenti scaricati PDARESCA e PAVERESCA;
// - Ora esistono un record per i movimenti normali e un record per i movimenti scaricati; la
// distinzione e' resa possibile dall' introduzione in chiave di un flag FLSCA (vedi tracciato)
// che e' un booleano. Il record con FLSCA = FALSE contiene la somma dei saldi dei movimenti
// normali e dei movimenti scaricati, mentre il record con FLSCA = TRUE, contiene solo i saldi
// dei movimenti scaricati.
// Tutti i progressivi che nel programma venivano memorizzati nei campi PDARESCA e PAVERESCA dei
// file temporanei ora sono memorizzati in PDAREPRO e PAVEREPRO.
// Le funzioni che sono state modificate sono:
// - bil_verifica();
// - ricerca_cf(...);
// - scrivi_record_gruppo();
// - scrivi_record_conto();
// - leggi_clifo();
// - leggi_file_tmp();
// - UltimaData();
#include <currency.h>
#include <mask.h>
#include <modaut.h>
#include <progind.h>
#include <printapp.h>
#include <sort.h>
#include <utility.h>
#include <mov.h>
#include <rmov.h>
#include <rmoviva.h>
#include <pconti.h>
#include <comuni.h>
#include <clifo.h>
#include <attiv.h>
#include <causali.h>
#include <saldi.h>
#include <nditte.h>
#include <anagr.h>
#include "cg1.h"
#include "cg1500.h"
#include "cglib01.h"
#include "cglib02.h"
class TSaldo_cdc : public TSaldo
{
public:
bool data_limite_commessa(int bilancio, int g, int c, long s,
const TString& commessa, const TString& fase, const TDate& data_inf,
const TDate& data_sup, int indbil, int stp_prov);
};
//per bilancio scalare (ovvero a sezioni contrapposte) per data limite
bool TSaldo_cdc::data_limite_commessa(int bilancio, int g, int c, long s,
const TString& commessa, const TString& fase, const TDate& data_inf,
const TDate& data_sup, int indbil, int stp_prov)
{
TString filter;
filter << '(' << RMV_CODCMS << "==\"" << commessa << "\")";
if (fase.not_empty())
filter << "&&(" << RMV_FASCMS << "==\"" << fase << "\")";
return data_limite_bilancio(bilancio, g, c, s, data_inf, data_sup, indbil, stp_prov, filter);
}
class TStampa_bilanci : public TPrintapp
{
static bool mask_anno (TMask_field& f, KEY k);
static bool mask_datalim (TMask_field& f, KEY k);
static bool verifica_handler(TMask_field& f, KEY k);
static bool mask_date (TMask_field& f, KEY k);
static bool mask_bilancio(TMask_field& f, KEY k);
static bool mask_tipost (TMask_field& f, KEY k);
static bool cdc_handler (TMask_field& f, KEY k);
struct cli_for
{
char tipocf;
char gruppo[4];
char conto[4];
char codcf[7];
char ragsoc[51];
real saldodare;
real saldoavere;
real movdare;
real movavere;
real saldofinale;
TDate udata;
};
TSort * _sort;
TRelation* _rel;
TCursor * _cur;
TProgind * _prog;
TSaldi_list* _listacf, * _lista;
TLocalisamfile* _com, * _pcn, * _mov, * _rmov, * _clifo, * _saldi, * _nditte,* _anag,* _caus;
TIsamtempfile * _tmp_saldi_att, * _tmp_saldi_pass, * _tmp_saldi_conti_uno;
TIsamtempfile * _tmp_saldi_costi, * _tmp_saldi_ricavi,* _tmp_saldi_conti_due;
TParagraph_string* _d;
const char* _buff;
bool _noseparator; // Usa separatore delle migliaia o no?
TString _cofi,_cap,_paiva,_ragsoc,_comunefis,_provfis,_viafis;
TString _descr_dare, _descr_avere, _gc_corr_dare, _gc_corr_avere, _descr;
TString _gc_prec_dare, _gc_prec_avere, _situazione, _descr_succ;
TString _tmp;
char _tipo_conto, _tipoc_succ;
int _annoes, _bilancio, _tipo_stampa, _tipo_stampa1,_stampa_width,_gp,_cp,_i;
int _eof1, _eof2, _gruppo_dare, _gruppo_avere, _conto_dare, _conto_avere;
int _add_file_da, _add_file_a, _indbil_dare, _indbil_avere, _indbil;
int _eof3, _eof4, _eof5, _eof6, _verifica, _stampac, _stampav, _ordinamento;
int _gruppo, _conto, _gruppo_succ, _conto_succ, _annoapp;
long _sottoconto_dare, _sottoconto_avere, _sottoconto, _sottoconto_succ;
real _saldo_dare, _saldo_avere, _gruppo_a, _gruppo_da, _conto_a;
real _conto_da, _tot_dare, _tot_avere, _mov_periodo_dare, _saldo_ini_dare;
real _mov_periodo_avere, _saldo_ini_avere, _prg_prec_dare, _prg_prec_avere;
real _saldo_ini_conto_dare, _saldo_ini_conto_avere, _saldoini_dare;
real _saldoini_avere, _mov_dare, _mov_avere, _saldofinale;
real _saldoini_dare_succ, _saldoini_avere_succ, _mov_dare_succ;
real _mov_avere_succ, _saldofinale_succ;
real _saldo_dare_tot, _saldo_avere_tot, _mov_dare_tot, _mov_avere_tot;
real _saldo_finale_tot, _saldo_ini_gruppo_dare, _saldo_ini_gruppo_avere;
real _gruppo_da_ordine, _gruppo_a_ordine;
real _prg_saldoini_dare, _prg_saldoini_avere, _prg_inidare_ord, _prg_iniavere_ord;
real _nuovo_tot_saldo_d, _nuovo_tot_saldo_a;
TDate _datalim, _data, _datada, _dataa, _dataini, _ultima_data, _u_max;
bool _cambiato_conto_1, _cambiato_conto_2, _add_file_avere;
bool _add_file_dare, _prima_volta, _seconda_volta, _totali, _codici, _saldo;
bool _add_dare, _add_avere, _controlla, _salto_pagina, _flag, _stampato;
bool _sottoc_dare, _sottoc_avere, _salto_pagina1, _livello_conto;
bool _mov_ap,_quadratura;
bool _print_exercise, _hide_clifo;
int _stampa_mov_prov;
TString _cdc, _fsc;
TBill _bill_from, _bill_to;
TArray _clienti, _fornitori;
public:
TDate _inizioEs, _fineEs;
int date2esc(const TDate& d, int* prevesc = NULL);
bool menu (MENU_TAG m) { return TPrintapp::menu(m) ; }
virtual bool user_create() ;
virtual bool user_destroy();
bool set_print(int);
void next_c();
void header_cdc(int& r);
virtual bool preprocess_print(int,int);
virtual void preprocess_header();
virtual bool preprocess_page(int,int);
virtual print_action postprocess_page(int,int);
virtual void postclose_print();
virtual void set_page(int,int);
real compensazione(bool compensa, int indbil_conto, real& saldo);
//const char* causale_chiusura() { return _causale_chi;}
//const char* causale_apertura() { return _causale_ap;}
bool bil_sez_contr();
bool bil_verifica();
bool ricerca_sottoc_clifo(int,int,bool,int,real&);
bool ricerca_cf(int,int,char,int,real&,real&,real&,real&,real&,real&,real&);
bool calcola(int,int,long);
void leggi_pcon(); // Inizializza i TArray C/F
void crea_sort_clifo();
void leggi_clifo(const TArray&);
void init_sort();
void leggi_sort();
void riempi_record(char,int,int,long,const char*,const real&,
const real&,const real&,const real&,const real&);
void get_dati_ditta();
void scrivi_record_conto(const real&,const real&,const real&,
const real&, const real&);
void scrivi_record_gruppo(const real&,const real&,const real&,
const real&, const real&);
int stampa_record_conto(int,int,const TString&,const real&,const real&,
const real&,const real&,const real&,const char);
int stampa_intestazione_ditta();
int cerca_indbil(int,int);
void scrivig_file_temp();
void scrivic_file_temp();
void scrivis_file_temp(int,int,long,const real&);
void leggi_files_dare (TIsamtempfile*);
void leggi_files_avere(TIsamtempfile*);
void leggi_file_tmp();
void stampa_riga_totali(int);
void stampa_prima_colonna(int,int,long,const char*,const real&);
void stampa_seconda_colonna(int,int,long,const char*,const real&);
void stampa_totali();
void stampa_totali_uno(const real&, const real&);
void controlla_conto(int,int);
const char* DescrizioneConto(int,int,long,char); //chiama quella di TConto
TDate UltimaData(int,int,long,int);
void stampa_un_bilancio(const TMask& m);
TStampa_bilanci() {}
};
HIDDEN inline TStampa_bilanci& app() { return (TStampa_bilanci&)main_app(); }
TDate InizioEsercizio(int anno)
{
TEsercizi_contabili esc;
TDate inizio_es;
if (esc.exist(anno))
inizio_es = esc[anno].inizio();
return inizio_es;
}
TDate FineEsercizio(int anno)
{
TEsercizi_contabili esc;
TDate fine_es;
if (esc.exist(anno))
fine_es = esc[anno].fine();
return fine_es;
}
bool IsEsercizio (const TDate& datalim, int anno_eser)
{
TEsercizi_contabili esc;
bool yes = esc.date2esc(datalim) == anno_eser;
return yes;
}
int TStampa_bilanci::date2esc(const TDate& d, int* prevesc)
{
TEsercizi_contabili esc;
int anno = esc.date2esc(d);
if (prevesc)
*prevesc = esc.pred(anno);
return anno;
}
bool TStampa_bilanci::mask_anno(TMask_field& f, KEY k)
{
if (k == K_ENTER)
{
int tipo_stampa;
int anno = f.mask().get_int(F_ANNO);
int bilancio = f.mask().get_int(F_BILANCIO);
if (bilancio == 1)
tipo_stampa = f.mask().get_int(F_STAMPA);
else
tipo_stampa = f.mask().get_int(F_STAMPA1);
if (tipo_stampa == 2)
if (anno == 0)
{
f.error_box(TR("Indicare l'anno di esercizio"));
return FALSE;
}
}
if ( k == K_TAB || f.focusdirty())
{
int tipo_stampa;
int anno = f.mask().get_int(F_ANNO);
int bilancio = f.mask().get_int(F_BILANCIO);
if (bilancio == 1)
tipo_stampa = f.mask().get_int(F_STAMPA);
else
tipo_stampa = f.mask().get_int(F_STAMPA1);
if ((bilancio == 2) && (tipo_stampa == 1))
if (anno != 0)
{
f.mask().show(F_DATADA);
f.mask().show(F_DATAA);
//f.mask().show(F_STAMPAMPROV);
f.mask().show(96);
f.mask().show(97);
f.mask().hide(98);
f.mask().hide(99);
}
else
{
f.mask().show(F_DATADA);
f.mask().show(F_DATAA);
//f.mask().show(F_STAMPAMPROV);
f.mask().show(98);
f.mask().show(99);
f.mask().hide(96);
f.mask().hide(97);
}
}
if (k == K_TAB)
{
int tipo_bil, tipo_stp;
tipo_bil = f.mask().get_int(F_BILANCIO);
if (tipo_bil == 1)
tipo_stp = f.mask().get_int(F_STAMPA);
else
tipo_stp = f.mask().get_int(F_STAMPA1);
if (tipo_bil == 2 && tipo_stp == 1 /* && f.mask().get_int(F_ANNO) == 0 */)
f.mask().show(F_QUADRATURA);
else
{
f.mask().set (F_QUADRATURA,"");
f.mask().hide(F_QUADRATURA);
}
}
return TRUE;
}
bool TStampa_bilanci::mask_bilancio(TMask_field& f, KEY k)
{
int tipo_bil, tipo_stp;
if (k == K_SPACE)
{
TMask& m = f.mask();
const int anno = m.get_int(F_ANNO);
const int bilancio = m.get_int(F_BILANCIO);
int tipo_stampa;
if (bilancio == 1) //bilancio a sezioni contrapposte
{
tipo_stampa = m.get_int(F_STAMPA);
m.disable_page(1);
}
else
{
tipo_stampa = m.get_int(F_STAMPA1);
m.enable_page(1);
}
if (tipo_stampa == 2) //all'ultima immissione
{
m.hide(F_DATADA);
m.hide(F_DATAA);
//m.hide(F_STAMPAMPROV);
m.hide(98);
m.hide(99);
m.hide(96);
m.hide(97);
// Disabilito le commesse nelle stampe all'ultima immissione
m.hide(-4);
m.reset(-4);
}
else
{
if (bilancio == 2)
if (anno != 0)
{
m.show(F_DATADA);
m.show(F_DATAA);
//m.show(F_STAMPAMPROV);
m.show(96);
m.show(97);
m.hide(98);
m.hide(99);
}
else
{
m.show(F_DATADA);
m.show(F_DATAA);
//m.show(F_STAMPAMPROV);
m.show(98);
m.show(99);
m.hide(96);
m.hide(97);
}
// Abilito eventualmente le commesse
if (main_app().has_module(CMAUT))
m.show(-4);
else
{
m.hide(-4);
m.reset(-4);
}
}
tipo_bil = f.mask().get_int(F_BILANCIO);
if (tipo_bil == 1)
tipo_stp = f.mask().get_int(F_STAMPA);
else
tipo_stp = f.mask().get_int(F_STAMPA1);
if (tipo_bil == 2 && tipo_stp == 1 /* && f.mask().get_int(F_ANNO) == 0 */)
f.mask().show(F_QUADRATURA);
else
{
f.mask().set (F_QUADRATURA,"");
f.mask().hide(F_QUADRATURA);
}
}
return TRUE;
}
bool TStampa_bilanci::mask_datalim (TMask_field& f, KEY k)
{
if (k == K_ENTER)
{
int anno = f.mask().get_int(F_ANNO);
int bilancio = f.mask().get_int(F_BILANCIO);
TDate datalim(f.mask().get(F_DATALIM));
if (bilancio == 1)
if (anno != 0)
{
if ( datalim.ok() )
{
if (!IsEsercizio(datalim,anno))
{
f.error_box (TR("La data limite deve appartenere all'esercizio indicato"));
return FALSE;
}
}
else
f.mask().field(F_DATALIM).set(FineEsercizio(anno));
}
else //anno == 0
{
if (!datalim.ok())
{
f.error_box (TR("La data limite e' obbligatoria"));
return FALSE;
}
long anno = app().date2esc(datalim);
if (anno == 0)
{
f.error_box (TR("La data limite deve appartenere ad un esercizio attivo della ditta"));
return FALSE;
}
}
}
return TRUE;
}
bool TStampa_bilanci::mask_date(TMask_field& f, KEY k)
{
if (k == K_TAB)
{
const short id = f.dlg();
if (id == F_DATAA)
{
TDate data (f.get());
int bil = f.mask().get_int(F_BILANCIO);
TEsercizi_contabili esc;
int anno = esc.date2esc(data);
if (anno)
{
TDate dataini = esc[anno].fine();
if (data == dataini && bil == 2 /*&& f.mask().get_int(F_ANNO) == 0*/)
f.mask().show(F_QUADRATURA);
else
{
f.mask().reset(F_QUADRATURA);
f.mask().hide(F_QUADRATURA);
}
}
}
}
if (k == K_ENTER)
{
const short id = f.dlg();
int anno = f.mask().get_int(F_ANNO);
int bilancio = f.mask().get_int(F_BILANCIO);
if (bilancio == 2)
{
TDate data (f.mask().get(id));
if (anno != 0)
{
if (data.ok())
{
if (!IsEsercizio(data,anno))
{
f.error_box(TR("La data indicata deve essere all'interno dell'esercizio"));
return FALSE;
}
}
if (!data.ok())
{
if (id == F_DATADA)
f.mask().field(F_DATADA).set(InizioEsercizio(anno));
else if (id == F_DATAA)
f.mask().field(F_DATAA).set(FineEsercizio(anno));
}
app()._annoapp = anno;
}
else
{
if ( !data.ok() )
{
f.error_box(TR("Indicare una data appartenente ad un esercizio attivo della ditta"));
return FALSE;
}
else
{
if (id == F_DATAA)
{
TDate from (f.mask().get(id - 1));
app()._annoapp = app().date2esc(from);
if ( app()._annoapp != app().date2esc(data) )
{
f.error_box(TR("Le date devono appartenere ad uno stesso esercizio attivo della ditta"));
return FALSE;
}
if (from > data)
{
f.error_box(TR("La data limite inferiore non puo' essere maggiore della data limite superiore"));
return FALSE;
}
}
}
}
}
}
return TRUE;
}
bool TStampa_bilanci::verifica_handler(TMask_field& f, KEY k)
{
if (k == K_SPACE)
{
int tipo_stampa = atoi(f.mask().get(F_STAMPA1));
int verifica = atoi(f.mask().get(F_VERIFICA));
if ( (tipo_stampa == 1) && ((verifica == 1) || (verifica == 2)) )
{
f.mask().hide (F_SITUAZIONE);
f.mask().hide (F_STAMPAC);
f.mask().hide (F_ORDINAMENTO);
f.mask().show (F_STAMPAV);
f.mask().show (F_DATADA);
f.mask().show (F_DATAA);
}
if ( (tipo_stampa == 1) && (verifica == 3) )
{
f.mask().show (F_SITUAZIONE);
f.mask().show (F_STAMPAC);
f.mask().show (F_ORDINAMENTO);
f.mask().show (F_DATADA);
f.mask().show (F_DATAA);
f.mask().hide (F_STAMPAV);
}
if ( (tipo_stampa == 2) && ((verifica == 1)||(verifica == 2)) )
{
f.mask().hide (F_SITUAZIONE);
f.mask().hide (F_STAMPAC);
f.mask().hide (F_ORDINAMENTO);
f.mask().hide (F_DATADA);
f.mask().hide (F_DATAA);
f.mask().show (F_STAMPAV);
}
if ( (tipo_stampa == 2) && (verifica == 3) )
{
f.mask().show (F_SITUAZIONE);
f.mask().show (F_STAMPAC);
f.mask().show (F_ORDINAMENTO);
f.mask().hide (F_DATADA);
f.mask().hide (F_DATAA);
f.mask().hide (F_STAMPAV);
}
}
return TRUE;
}
bool TStampa_bilanci::cdc_handler(TMask_field& f, KEY k)
{
if (k == K_TAB)
{
TMask& m = f.mask();
const bool on = !(m.field(F_DACDC).empty() && m.field(F_ACDC).empty());
if (!on)
{
m.reset(F_DAFSC);
m.reset(F_AFSC);
}
m.enable(F_DAFSC, on);
m.enable(F_AFSC, on);
}
return TRUE;
}
void TStampa_bilanci::scrivig_file_temp()
{
TIsamtempfile* tmp = NULL;
TString nome_campo(12);
real valore;
if (!_totali)
{
if (_add_dare)
{
nome_campo = SLD_PDARE;
valore = _gruppo_da;
switch (_indbil)
{
case 1:
case 2:
tmp = _tmp_saldi_att;
break;
case 3:
case 4:
tmp = _tmp_saldi_costi;
break;
case 5:
tmp = _tmp_saldi_conti_uno;
valore = _gruppo_da_ordine;
break;
default:
break;
}
tmp->zero();
tmp->put(SLD_GRUPPO,_gp);
tmp->put(SLD_CONTO,0);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(SLD_ANNOES,0); // W96SALDI del 07-06-96
tmp->put(SLD_FLSCA,FALSE);
if (tmp->read() == NOERR)
{
tmp->put(SLD_CONTO,0);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(nome_campo, valore);
tmp->rewrite();
}
else
{
tmp->put(SLD_GRUPPO,_gp);
tmp->put(SLD_CONTO,0);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(SLD_ANNOES,0); // W96SALDI del 07-06-96
tmp->put(SLD_FLSCA,FALSE);
tmp->put(nome_campo, valore);
tmp->write();
}
}
if (_add_avere)
{
nome_campo = SLD_PAVERE;
valore = _gruppo_a;
switch (_indbil)
{
case 1:
case 2:
tmp = _tmp_saldi_pass;
break;
case 3:
case 4:
tmp = _tmp_saldi_ricavi;
break;
case 5:
tmp = _tmp_saldi_conti_due;
valore = _gruppo_a_ordine;
break;
default:
break;
}
tmp->zero();
tmp->put(SLD_GRUPPO,_gp);
tmp->put(SLD_CONTO,0);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(SLD_ANNOES,0); // W96SALDI del 07-06-96
tmp->put(SLD_FLSCA,FALSE);
if (tmp->read() == NOERR)
{
tmp->put(SLD_CONTO,0);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(nome_campo, valore);
tmp->rewrite();
}
else
{
tmp->put(SLD_GRUPPO,_gp);
tmp->put(SLD_CONTO,0);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(SLD_ANNOES,0); // W96SALDI del 07-06-96
tmp->put(SLD_FLSCA,FALSE);
tmp->put(nome_campo, valore);
tmp->write();
}
}
}
_add_dare = _add_avere = FALSE;
}
void TStampa_bilanci::scrivic_file_temp()
{
TIsamtempfile* tmp = NULL;
TString nome_campo(12);
real valore;
if (_add_file_dare)
{
_add_dare = TRUE;
nome_campo = SLD_PDARE;
valore = _conto_da;
if (_indbil == 1 || _indbil==2) tmp = _tmp_saldi_att; // da stampare a sx
else
if (_indbil==3 || _indbil==4) tmp = _tmp_saldi_costi; //da stampare a sx
else
if (_indbil==5) tmp = _tmp_saldi_conti_uno;
else return;
tmp->zero();
tmp->put(SLD_GRUPPO,_gp);
tmp->put(SLD_CONTO,_cp);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(nome_campo, valore);
tmp->write();
}
if (_add_file_avere)
{
_add_avere = TRUE;
nome_campo = SLD_PAVERE;
valore = _conto_a;
if (_indbil==2 || _indbil==1) tmp = _tmp_saldi_pass; //da stampare a dx
else
if (_indbil==4 || _indbil==3) tmp = _tmp_saldi_ricavi;//da stampare a dx
else
if (_indbil==5) tmp = _tmp_saldi_conti_due;
else return;
tmp->zero();
tmp->put(SLD_GRUPPO,_gp);
tmp->put(SLD_CONTO,_cp);
tmp->put(SLD_SOTTOCONTO,0L);
tmp->put(nome_campo, valore);
tmp->write();
}
}
void TStampa_bilanci::scrivis_file_temp(int g, int c, long s, const real& saldo)
{
TIsamtempfile* tmp = NULL;
TString16 nome_campo;
if (_indbil==1)
{
tmp = _tmp_saldi_att;
nome_campo = SLD_PDARE;
}
else
if (_indbil==2)
{
tmp = _tmp_saldi_pass;
nome_campo = SLD_PAVERE;
}
else
if (_indbil==3)
{
tmp = _tmp_saldi_costi;
nome_campo = SLD_PDARE;
}
else
if (_indbil==4)
{
tmp = _tmp_saldi_ricavi;
nome_campo = SLD_PAVERE;
}
else
if (_sottoc_dare)
{
tmp = _tmp_saldi_conti_uno;
nome_campo = SLD_PDARE;
}
else
if (_sottoc_avere)
{
tmp = _tmp_saldi_conti_due;
nome_campo = SLD_PAVERE;
}
CHECKD(tmp, "Null tmp file: indbil = ", _indbil);
tmp->zero();
tmp->put(SLD_GRUPPO,g);
tmp->put(SLD_CONTO,c);
tmp->put(SLD_SOTTOCONTO,s);
tmp->put(nome_campo, saldo);
tmp->write();
}
real TStampa_bilanci::compensazione(bool compensa, int indbil_conto, real& sld)
{
real saldo = sld;
if (!compensa)
{
switch (indbil_conto)
{
case 1:
if (saldo > ZERO)
_indbil = indbil_conto;
else
{
_indbil = 2;
saldo = -saldo;
}
break;
case 3:
if (saldo > ZERO)
_indbil = indbil_conto;
else
{
_indbil = 4;
saldo = -saldo;
}
break;
case 2:
if (saldo < ZERO)
{
_indbil = indbil_conto;
saldo = -saldo;
}
else
_indbil = 1;
break;
case 4:
if (saldo < ZERO)
{
_indbil = indbil_conto;
saldo = -saldo;
}
else
_indbil = 3;
break;
case 5:
default: break;
}
}
else //e' richiesta la compensazione
if ( indbil_conto==2 || indbil_conto==4)
saldo = -saldo;
return saldo;
}
void TStampa_bilanci::next_c()
{
TRecnotype recnum = _pcn->recno();
_pcn->next();
if (_pcn->eof())
{
scrivic_file_temp();
scrivig_file_temp();
}
_pcn->readat(recnum);
}
bool TStampa_bilanci::bil_sez_contr()
{
TSaldo_cdc sld;
int indbil_conto=0;
int g, c;
long s;
char tipo_conto = ' ';
real saldo;
bool compensa=FALSE, dettaglio=FALSE, cambiato=FALSE;
bool esiste_conto=FALSE, esiste_sc = FALSE;
bool movimentato = FALSE;
CHECK(_tmp_saldi_att == NULL, "Non posso riaprire cg01");
_tmp_saldi_att = new TIsamtempfile(LF_SALDI, "cg01", TRUE, TRUE);
_prog->addstatus(1);
_tmp_saldi_pass = new TIsamtempfile(LF_SALDI, "cg02", TRUE, TRUE);
_prog->addstatus(1);
_tmp_saldi_costi = new TIsamtempfile(LF_SALDI, "cg03", TRUE, TRUE);
_prog->addstatus(1);
_tmp_saldi_ricavi = new TIsamtempfile(LF_SALDI, "cg04", TRUE, TRUE);
_prog->addstatus(1);
_tmp_saldi_conti_uno = new TIsamtempfile(LF_SALDI, "cg05", TRUE, TRUE);
_prog->addstatus(1);
_tmp_saldi_conti_due = new TIsamtempfile(LF_SALDI, "cg06", TRUE, TRUE);
_prog->addstatus(1);
_gp=-1;
_cp=-1;
_gruppo_a = ZERO;
_gruppo_da = ZERO;
_gruppo_da_ordine = ZERO;
_gruppo_a_ordine = ZERO;
_prg_saldoini_dare = ZERO;
_prg_saldoini_avere = ZERO;
_prg_inidare_ord = ZERO;
_prg_iniavere_ord = ZERO;
_conto_a = ZERO;
_conto_da = ZERO;
_add_dare = FALSE;
_add_avere = FALSE;
sld.set_annoes(_annoes);
for (_pcn->first(); !_pcn->eof(); _pcn->next())
{
_prog->addstatus(1);
g = _pcn->get_int (PCN_GRUPPO);
c = _pcn->get_int (PCN_CONTO);
s = _pcn->get_long(PCN_SOTTOCONTO);
if (c != _cp)
cambiato = TRUE;
if ( (((_cp != -1) && (c != _cp)) || ((_gp != -1) && (g != _gp))) &&
esiste_sc )
{
scrivic_file_temp();
scrivig_file_temp();
_cp = c;
esiste_conto = TRUE;
_conto_da = ZERO;
_conto_a = ZERO;
}
if ( ((_gp != -1) && (g != _gp)) && esiste_conto )
{
scrivig_file_temp();
esiste_conto = FALSE;
_gp = g;
_gruppo_da = ZERO;
_gruppo_a = ZERO;
_gruppo_da_ordine = ZERO;
_gruppo_a_ordine = ZERO;
}
if (cambiato)
{
_add_file_avere = FALSE;
_add_file_dare = FALSE;
cambiato = FALSE;
}
if ( (s == 0) && (c != 0) ) //si tratta di un conto
{
compensa = _pcn->get_bool(PCN_COMPENS);
dettaglio = !_pcn->get_bool(PCN_STSOTTBIL);
tipo_conto = _pcn->get_char(PCN_TMCF);
indbil_conto = _pcn->get_int(PCN_INDBIL);
if (indbil_conto <= 0) // Warning per Roberto!
{
yesnofatal_box(FR("Indicatore di bilancio %d nel conto %03d %03d"), indbil_conto,
_pcn->get_int (PCN_GRUPPO), _pcn->get_int (PCN_CONTO));
indbil_conto = 1;
}
if ( (tipo_conto == 'C') || (tipo_conto == 'F') )
{
saldo = ZERO;
esiste_sc = ricerca_sottoc_clifo(g, c, compensa, indbil_conto, saldo);
if (esiste_sc)
{
_gp = g;
_cp = c;
}
TRecnotype recnum = _pcn->recno();
_pcn->next();
if (_pcn->eof())
{
if (esiste_sc)
{
scrivic_file_temp();
scrivig_file_temp();
}
else if (esiste_conto)
scrivig_file_temp();
}
_pcn->readat(recnum);
continue;
}
}
if ( (c == 0) || (s == 0) ) //si tratta di un conto o di un gruppo
{
esiste_sc = FALSE;
continue;
}
if (_tipo_stampa == 1) //bil. a sez. contrapposte per data limite
{
if (_cdc.not_empty())
movimentato = sld.data_limite_commessa(_bilancio,g,c,s,_cdc,_fsc,_dataini,_datalim,indbil_conto,_stampa_mov_prov);
else
movimentato = sld.data_limite_bilancio(_bilancio,g,c,s,_dataini,_datalim,indbil_conto,_stampa_mov_prov);
}
else
{
if (_tipo_stampa == 2) //bil. a sez. contrapposte all'ultima immissione es. in corso
movimentato = sld.ultima_immissione_bilancio(_annoes,g,c,s,indbil_conto,_stampa_mov_prov);
}
if (!movimentato)
if (!sld.esiste_saldo() || !sld.significativo())
{
next_c();
continue;
}
saldo = sld.saldo();
real app = sld.saldoini();
bool flag = sld.flagprec();
if (_saldo) //se richiesto di NON stampare i conti con saldo a zero
if (saldo == ZERO)
{
//modifica del 06/07/1995
if (indbil_conto == 1 || indbil_conto == 2 || indbil_conto == 5)
{
//real app = sld.saldoini();
//bool flag = sld.flagprec();
if (flag)
{
if (app > ZERO)
{
if (indbil_conto == 5)
_prg_inidare_ord += app;
else _prg_saldoini_dare += app;
}
else if (app < ZERO)
{
app = -app;
if (indbil_conto == 5)
_prg_iniavere_ord += app;
else _prg_saldoini_avere += app;
}
}
}
//fine
next_c();
continue;
}
esiste_sc = TRUE;
_indbil = indbil_conto;
//i due flag seguenti servono solo per i conti d'ordine
_sottoc_dare = FALSE;
_sottoc_avere = FALSE;
if (saldo != ZERO)
saldo = compensazione(compensa, indbil_conto, saldo);
if (_indbil == 1 || _indbil == 2)
{
if (flag)
{
if (app > ZERO)
_prg_saldoini_dare += app;
else if (app < ZERO)
{
app = -app;
_prg_saldoini_avere += app;
}
}
}
if (_indbil == 5)
{
//real app = sld.saldoini();
if (flag)
{
if (app > ZERO)
_prg_inidare_ord += app;
else if (app < ZERO)
{
app = -app;
_prg_iniavere_ord += app;
}
}
}
if ( _indbil==1 || _indbil==3 )
{
_gruppo_da += saldo;
_conto_da += saldo;
_add_file_dare = TRUE;
}
if ( _indbil==2 || _indbil==4 )
{
_gruppo_a += saldo;
_conto_a += saldo;
_add_file_avere = TRUE;
}
if (_indbil==5)
{
if ( saldo >= ZERO || compensa )
{
_gruppo_da_ordine += saldo;
_conto_da += saldo;
_add_file_dare = TRUE;
_sottoc_dare = TRUE;
}
else
{
saldo = -saldo;
_gruppo_a_ordine += saldo;
_conto_a += saldo;
_add_file_avere = TRUE;
_sottoc_avere = TRUE;
}
scrivig_file_temp();
}
if ( (dettaglio) && ( (tipo_conto != 'C') && (tipo_conto != 'F') ) )
scrivis_file_temp(g, c, s, saldo);
_gp = g;
_cp = c;
// } // da_considerare
TRecnotype recnum = _pcn->recno();
_pcn->next();
if (_pcn->eof())
{
scrivic_file_temp();
scrivig_file_temp();
}
_pcn->readat(recnum);
}
return TRUE;
}
bool TStampa_bilanci::ricerca_sottoc_clifo(int g,int c, bool compensa, int indbil_conto,real& saldo)
{
TSaldo_cdc sld;
int aep=0;
long s, items;
bool esiste_sc = FALSE;
bool movimentato = FALSE;
if (_annoes)
{
TEsercizi_contabili ese;
aep = ese.pred(_annoes);
}
sld.set_annoes(_annoes);
_listacf = new TSaldi_list(g, c, _annoes, aep);
items = _listacf->items();
for (int i = 0; i < items; i++)
{
const TRectype* r = _listacf->saldi();
if (r == NULL) break;
s = r->get_long(SLD_SOTTOCONTO);
if (_tipo_stampa == 1) //bil. a sez. contrapposte per data limite
{
if (_cdc.not_empty())
movimentato = sld.data_limite_commessa(_bilancio,g,c,s,_cdc,_fsc,_dataini,_datalim,indbil_conto,_stampa_mov_prov);
else
movimentato = sld.data_limite_bilancio(_bilancio,g,c,s,_dataini,_datalim,indbil_conto,_stampa_mov_prov);
}
else if (_tipo_stampa == 2) //bil. a sez. contrapposte all'ultima immissione es. in corso
movimentato = sld.ultima_immissione_bilancio(_annoes,g,c,s,indbil_conto,_stampa_mov_prov);
if (!movimentato)
if (!sld.esiste_saldo() || !sld.significativo())
continue;
saldo = sld.saldo();
real app = sld.saldoini();
bool flag = sld.flagprec();
if (_saldo) //se richiesto di non stampare i conti con saldo a zero
if (saldo == ZERO)
{
//modifica del 06/07/1995
if (indbil_conto == 1 || indbil_conto == 2 || indbil_conto == 5)
{
//real app = sld.saldoini();
if (flag)
{
if (app > ZERO)
{
if (indbil_conto == 5)
_prg_inidare_ord += app;
else _prg_saldoini_dare += app;
}
else if (app < ZERO)
{
app = -app;
if (indbil_conto == 5)
_prg_iniavere_ord += app;
else _prg_saldoini_avere += app;
}
}
}
//fine
continue;
}
esiste_sc = TRUE;
_indbil = indbil_conto;
//i due flag seguenti servono solo per i conti d'ordine
_sottoc_dare = FALSE;
_sottoc_avere = FALSE;
if (saldo != ZERO)
saldo = compensazione(compensa, indbil_conto, saldo);
if (_indbil == 1 || _indbil == 2)
{
if (flag)
{
if (app > ZERO)
_prg_saldoini_dare += app;
else if (app < ZERO)
{
app = -app;
_prg_saldoini_avere += app;
}
}
}
if (_indbil == 5)
{
//real app = sld.saldoini();
if (flag)
{
if (app > ZERO)
_prg_inidare_ord += app;
else if (app < ZERO)
{
app = -app;
_prg_iniavere_ord += app;
}
}
}
if ( (_indbil==1) || (_indbil==3) )
{
_gruppo_da += saldo;
_conto_da += saldo;
_add_file_dare = TRUE;
}
if ( (_indbil==2) || (_indbil==4) )
{
_gruppo_a += saldo;
_conto_a += saldo;
_add_file_avere = TRUE;
}
if (_indbil==5)
{
if ( (saldo >= ZERO) || (compensa) ) // il sottoconto ha saldo in dare
{
_gruppo_da_ordine += saldo;
_conto_da += saldo;
_add_file_dare = TRUE;
_sottoc_dare = TRUE;
}
else //il sottoconto ha saldo in avere
{
saldo = -saldo;
_gruppo_a_ordine += saldo;
_conto_a += saldo;
_add_file_avere = TRUE;
_sottoc_avere = TRUE;
}
scrivig_file_temp();
}
}
delete _listacf;
return esiste_sc;
}
bool TStampa_bilanci::bil_verifica()
{
TSaldo sld;
int g, c, indbil_conto = 0;
long s;
char tipo_conto = ' ';
real saldo_finale, saldo_conto, saldo_gruppo, saldo_iniziale;
real mov_conto_dare, mov_conto_avere, prg_conto_dare, prg_conto_avere;
real mov_gruppo_dare, mov_gruppo_avere, prg_gruppo_dare, prg_gruppo_avere;
bool esiste_conto = FALSE, esiste_sc = FALSE, movimentato = FALSE;
CHECK(_tmp_saldi_att == NULL, "Non posso riaprire cg01");
_tmp_saldi_att = new TIsamtempfile(LF_SALDI, "cg01", TRUE, TRUE);
_gp=-1;
_cp=-1;
_saldo_ini_conto_dare = ZERO;
_saldo_ini_conto_avere = ZERO;
_saldo_ini_gruppo_dare = ZERO;
_saldo_ini_gruppo_avere = ZERO;
_nuovo_tot_saldo_d = ZERO;
_nuovo_tot_saldo_a = ZERO;
saldo_conto = ZERO;
mov_conto_dare = ZERO;
mov_conto_avere = ZERO;
prg_conto_dare = ZERO;
prg_conto_avere = ZERO;
saldo_gruppo = ZERO;
mov_gruppo_dare = ZERO;
mov_gruppo_avere = ZERO;
prg_gruppo_dare = ZERO;
prg_gruppo_avere = ZERO;
_u_max = 0l;
//controllo sui gr/co/sc selezionati
if (_bill_from.gruppo() > 0) //se ho un gruppo iniziale valido...
{
_pcn->put(PCN_GRUPPO,_bill_from.gruppo()); //lo metto nel file del pianodeiconticorrente..
_pcn->put(PCN_CONTO,_bill_from.conto()); //un valore alla volta
_pcn->put(PCN_SOTTOCONTO,_bill_from.sottoconto());
_pcn->read(_isgteq); //..e la scansione del file _pcn parte da questo
}
else
_pcn->first(); //..se non e' stato selezionato nessun gruppo parto dal primo
for ( ; !_pcn->eof(); _pcn->next())
{
_prog->addstatus(1);
g = _pcn->get_int (PCN_GRUPPO);
c = _pcn->get_int (PCN_CONTO);
s = _pcn->get_long(PCN_SOTTOCONTO);
if ( (((_cp != -1) && (c != _cp)) || ((_gp != -1) && (g != _gp))) && esiste_sc )
{
if (_verifica == 2)
if (!((_stampav == 2) && (saldo_conto == 0)))
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_saldo_ini_gruppo_dare += _saldo_ini_conto_dare;
_saldo_ini_gruppo_avere += _saldo_ini_conto_avere;
}
else
//fine
{
const real app = _saldo_ini_conto_dare + _saldo_ini_conto_avere;
if (app < ZERO)
_saldo_ini_gruppo_avere += app;
else
_saldo_ini_gruppo_dare += app;
}
mov_gruppo_dare += mov_conto_dare;
mov_gruppo_avere += mov_conto_avere;
prg_gruppo_dare += prg_conto_dare;
prg_gruppo_avere += prg_conto_avere;
saldo_gruppo += saldo_conto;
}
//scrivo il record del conto;
if ( (_verifica == 1)||( (_verifica == 2)&&
(!((_stampav == 2)&&(saldo_conto == 0))) ) )
{
scrivi_record_conto(prg_conto_dare,prg_conto_avere,mov_conto_dare,
mov_conto_avere,saldo_conto);
esiste_conto = TRUE;
}
_cp = c;
_saldo_ini_conto_dare = ZERO;
_saldo_ini_conto_avere = ZERO;
saldo_conto = ZERO;
mov_conto_dare = ZERO;
mov_conto_avere = ZERO;
prg_conto_dare = ZERO;
prg_conto_avere = ZERO;
}
if (_verifica == 2)
if ( ((_gp != -1) && (g != _gp)) && (!esiste_conto) )
{
_gp = g;
_saldo_ini_gruppo_dare = ZERO;
_saldo_ini_gruppo_avere = ZERO;
saldo_gruppo = ZERO;
mov_gruppo_dare = ZERO;
mov_gruppo_avere = ZERO;
prg_gruppo_dare = ZERO;
prg_gruppo_avere = ZERO;
}
if (_verifica == 2)
if ( ((_gp != -1) && (g != _gp)) && esiste_conto )
{
//scrivo il record del gruppo
scrivi_record_gruppo(prg_gruppo_dare,prg_gruppo_avere,mov_gruppo_dare,
mov_gruppo_avere,saldo_gruppo);
_gp = g;
esiste_conto = FALSE;
_saldo_ini_gruppo_dare = ZERO;
_saldo_ini_gruppo_avere = ZERO;
saldo_gruppo = ZERO;
mov_gruppo_dare = ZERO;
mov_gruppo_avere = ZERO;
prg_gruppo_dare = ZERO;
prg_gruppo_avere = ZERO;
}
if ( (s == 0) && (c != 0) ) //si tratta di un conto
{
tipo_conto = _pcn->get_char(PCN_TMCF);
indbil_conto = _pcn->get_int(PCN_INDBIL);
if ( (tipo_conto == 'C') || (tipo_conto == 'F') )
{
esiste_sc = ricerca_cf(g,c,tipo_conto,indbil_conto,saldo_finale,saldo_iniziale,
mov_conto_dare,mov_conto_avere,prg_conto_dare,prg_conto_avere,
saldo_conto);
if (_verifica == 2 && _stampav == 2 && saldo_conto.is_zero())
continue;
if (esiste_sc)
{
_gp = g;
_cp = c;
const TRecnotype recnum = _pcn->recno();
_pcn->next();
if (_pcn->eof())
{
if (_verifica == 2)
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_saldo_ini_gruppo_dare += _saldo_ini_conto_dare;
_saldo_ini_gruppo_avere += _saldo_ini_conto_avere;
}
else
//fine
{
real app = _saldo_ini_conto_dare + _saldo_ini_conto_avere;
if (app < ZERO)
_saldo_ini_gruppo_avere += app;
else
_saldo_ini_gruppo_dare += app;
}
mov_gruppo_dare += mov_conto_dare;
mov_gruppo_avere += mov_conto_avere;
prg_gruppo_dare += prg_conto_dare;
prg_gruppo_avere += prg_conto_avere;
saldo_gruppo += saldo_conto;
scrivi_record_gruppo(prg_gruppo_dare,prg_gruppo_avere,
mov_gruppo_dare,mov_gruppo_avere,saldo_gruppo);
}
scrivi_record_conto(prg_conto_dare,prg_conto_avere,mov_conto_dare,
mov_conto_avere,saldo_conto);
}
_pcn->readat(recnum);
}
continue;
}
}
//controlla se e' arrivato all'ultimo gruppo/conto/sottoconto selezionato
const TBill curr_bill(g,c,s);
if (curr_bill > _bill_to)
break;
if ( (c == 0) || (s == 0) )
{
esiste_sc = FALSE;
continue;
}
saldo_finale = saldo_iniziale = ZERO; //saldi relativi a ciascun sottoconto
_indbil = indbil_conto;
if (_tipo_stampa1 == 1) //bil. di verifica per data limite
{
//modifica del 21/11/95
_mov_ap = FALSE;
//modifica del 19/06/95
movimentato = calcola(g,c,s);
if (_stampa_mov_prov != 3 && _cdc.empty())
{
if (movimentato)
{
//modifica del 21/11/95
if (_mov_ap)
saldo_iniziale = _saldo_ini_dare - _saldo_ini_avere;
else //discorso flag "movimentato" (video)
{
TLocalisamfile saldi(LF_SALDI); // W96SALDI
saldi.zero(); // Modifica SALDI per movimenti
saldi.put(SLD_ANNOES, _annoes); // scaricati del 05-06-96
saldi.put(SLD_FLSCA, FALSE); // Ho aggiunto saldi.put(SLD_FLSCA, FALSE);
saldi.put(SLD_GRUPPO, g); // In questo modo considero il record con
saldi.put(SLD_CONTO, c); // la somma fra progressivi normali e scaricati
saldi.put(SLD_SOTTOCONTO, s);
if (saldi.read() == NOERR)
{
const real ss = saldi.get_real(SLD_SALDO);
if (ss.is_zero())
{
if (_annoes != 0 && (indbil_conto == 1 || indbil_conto == 2 || indbil_conto == 5))
{
saldo_iniziale = sld.saldofin_esprec(_annoes,g,c,s,false,_stampa_mov_prov == 2);
//modifica del 21/11/95
if (saldo_iniziale > ZERO)
_saldo_ini_dare = saldo_iniziale;
else
_saldo_ini_avere = -saldo_iniziale;
//fine
}
}
else
{
const char fsi = saldi.get_char(SLD_FLAGSALINI);
if (fsi == 'D')
{
saldo_iniziale = ss;
_saldo_ini_dare = ss;
}
else
{
saldo_iniziale = -ss;
_saldo_ini_avere = ss;
}
}
}
}
}
else // !movimentato -> _mov_ap e' di sicuro FALSE
{
if (_annoes != 0 && (indbil_conto == 1 || indbil_conto == 2 || indbil_conto == 5))
{
saldo_iniziale = sld.saldofin_esprec(_annoes,g,c,s,false,_stampa_mov_prov == 2);
//modifica del 21/11/95
if (saldo_iniziale > ZERO)
_saldo_ini_dare = saldo_iniziale;
else _saldo_ini_avere = -saldo_iniziale;
//fine
if (_stampav == 1 && sld.significativo())
movimentato = TRUE;
}
}
}
if (movimentato || _stampav != 1)
{
_nuovo_tot_saldo_d += _mov_periodo_dare;
_nuovo_tot_saldo_a += _mov_periodo_avere;
_nuovo_tot_saldo_d += _saldo_ini_dare;
_nuovo_tot_saldo_a += _saldo_ini_avere;
if (_datada == _dataini)
saldo_finale = saldo_iniziale+_mov_periodo_dare-_mov_periodo_avere;
else if (_datada > _dataini)
{
if (saldo_iniziale > 0)
_prg_prec_dare += saldo_iniziale;
else _prg_prec_avere -= saldo_iniziale;
saldo_finale = _prg_prec_dare-_prg_prec_avere+_mov_periodo_dare-_mov_periodo_avere;
}
//if (saldo_finale == ZERO)
// if (_stampav == 2)
// continue;
}
//se saldo_finale < 0 verra' stampato con una A, se no con una D
}
else
{
movimentato = sld.ultima_immissione_verifica(_annoes,g,c,s,indbil_conto,_stampa_mov_prov);
if (_stampa_mov_prov != 3)
{
if (movimentato)
saldo_iniziale = sld.saldoini();
if (!movimentato)
{
if (indbil_conto == 1 || indbil_conto == 2 || indbil_conto == 5)
{
saldo_iniziale = sld.saldofin_esprec(_annoes,g,c,s,FALSE,_stampa_mov_prov == 2);
if (_stampav == 1 && sld.significativo())
movimentato = TRUE;
}
}
}
if (movimentato || _stampav != 1)
{
_mov_periodo_dare = sld.prgdare();
_mov_periodo_avere = sld.prgavere();
_prg_prec_dare = ZERO;
_prg_prec_avere = ZERO;
if (sld.sezsf() == 'A')
_mov_periodo_avere -= sld.saldofin();
else
_mov_periodo_dare += sld.saldofin();
saldo_finale = saldo_iniziale+_mov_periodo_dare-_mov_periodo_avere;
}
}
if ((movimentato || _stampav != 1) && !(saldo_finale.is_zero() && _stampav == 2))
{
esiste_sc = TRUE;
esiste_conto = TRUE;
if (_tipo_stampa1 == 2)
{
_nuovo_tot_saldo_d += _mov_periodo_dare;
_nuovo_tot_saldo_a += _mov_periodo_avere;
real nuovo = sld.saldoinisusaldi();
if (nuovo > ZERO)
_nuovo_tot_saldo_d += nuovo;
else
{
nuovo = -nuovo;
_nuovo_tot_saldo_a += nuovo;
}
}
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_saldo_ini_conto_dare += _saldo_ini_dare;
_saldo_ini_conto_avere += _saldo_ini_avere;
}
else //_tipo_stampa1 == 1 || _tipo_stampa1 == 2
{
if (saldo_iniziale < ZERO)
_saldo_ini_conto_avere += saldo_iniziale;
else
_saldo_ini_conto_dare += saldo_iniziale;
}
mov_conto_dare += _mov_periodo_dare;
mov_conto_avere += _mov_periodo_avere;
prg_conto_dare += _prg_prec_dare;
prg_conto_avere += _prg_prec_avere;
saldo_conto += saldo_finale; // somma pitagorica
//scrivo il record relat. al sottoconto se non e' richiesto saldi di mastro
if (_verifica != 2)
{
_tmp_saldi_att->zero();
_tmp_saldi_att->put(SLD_GRUPPO,g);
_tmp_saldi_att->put(SLD_CONTO,c);
_tmp_saldi_att->put(SLD_SOTTOCONTO,s);
_tmp_saldi_att->put(SLD_FLAGSALINI,tipo_conto);
if ( (_datada == _dataini) || (_tipo_stampa1 != 1) )
{
//modifica del 21/11/1995
if (_datada == _dataini && _tipo_stampa1 == 1)
{
_tmp_saldi_att->put(SLD_PDAREPRO,_saldo_ini_dare); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,_saldo_ini_avere);
}
else
{
if (saldo_iniziale > ZERO) //va stampato in Dare
_tmp_saldi_att->put(SLD_PDAREPRO,saldo_iniziale); // W96SALDI del 05-06-96
else if (saldo_iniziale < ZERO)
{
saldo_iniziale = -saldo_iniziale;
_tmp_saldi_att->put(SLD_PAVEREPRO,saldo_iniziale); // W96SALDI del 05-06-96
}
}
}
else if (_datada > _dataini)
{
_tmp_saldi_att->put(SLD_PDAREPRO,_prg_prec_dare); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,_prg_prec_avere);
}
_tmp_saldi_att->put(SLD_PDARE,_mov_periodo_dare);
_tmp_saldi_att->put(SLD_PAVERE,_mov_periodo_avere);
_tmp_saldi_att->put(SLD_SALDO,saldo_finale);
_tmp_saldi_att->put(SLD_DATAULMOV,_u_max);
_tmp_saldi_att->write();
}
_gp = g;
_cp = c;
}
TRecnotype recnum = _pcn->recno();
_pcn->next();
if (_pcn->eof())
{
if ( (_verifica == 2) && esiste_conto )
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_saldo_ini_gruppo_dare += _saldo_ini_conto_dare;
_saldo_ini_gruppo_avere += _saldo_ini_conto_avere;
}
else
//fine
{
real app = _saldo_ini_conto_dare + _saldo_ini_conto_avere;
if (app < ZERO)
_saldo_ini_gruppo_avere += app;
else
_saldo_ini_gruppo_dare += app;
}
mov_gruppo_dare += mov_conto_dare;
mov_gruppo_avere += mov_conto_avere;
prg_gruppo_dare += prg_conto_dare;
prg_gruppo_avere += prg_conto_avere;
saldo_gruppo += saldo_conto;
scrivi_record_gruppo(prg_gruppo_dare,prg_gruppo_avere,
mov_gruppo_dare,mov_gruppo_avere,saldo_gruppo);
}
if (esiste_sc)
if ( (_verifica == 1)||( (_verifica == 2)&&
(!((_stampav == 2)&&(saldo_conto == 0))) ) )
scrivi_record_conto(prg_conto_dare,prg_conto_avere,mov_conto_dare,
mov_conto_avere,saldo_conto);
}
_pcn->readat(recnum);
}
return TRUE;
}
// bilancio di verifica per data limite
// Calcola totali delle righe relative al g,c,s
bool TStampa_bilanci::calcola(int g, int c, long s)
{
int annoe;
long num_reg;
TDate data_reg, data;
bool conto_mov = FALSE;
TDecoder causali(LF_CAUSALI, CAU_MOVAP);
TRelation rel(LF_RMOV);
rel.add(LF_MOV, "NUMREG==NUMREG");
TRectype& rmov = rel.curr();
const TRectype& mov = rel.curr(LF_MOV);
_mov_periodo_dare = ZERO;
_mov_periodo_avere = ZERO;
_prg_prec_dare = ZERO;
_prg_prec_avere = ZERO;
_saldo_ini_dare = ZERO;
_saldo_ini_avere = ZERO;
_u_max = 0l;
TDate data_start = _dataini;
// Calcolo progressivi precedenti:
// e non <20> indicato l'anno esercizio, prende il primo giorno dell'anno indicato da _datada
if (_annoes == 0)
{
data_start = _datada;
data_start.set_day(1);
data_start.set_month(1);
}
rmov.zero();
rmov.put(RMV_GRUPPO,g);
if (c != 0)
{
rmov.put(RMV_CONTO,c);
if (s != 0)
rmov.put(RMV_SOTTOCONTO,s);
}
TString filter;
if (_cdc.not_empty())
{
filter << '(' << RMV_CODCMS << "=='" << _cdc << "')";
if (_fsc.not_empty())
filter << "&&(" << RMV_FASCMS << "=='" << _fsc << "')";
}
TCursor cur(&rel, filter, 2, &rmov, &rmov);
const long items = cur.items();
cur.freeze();
for (cur = 0L; cur.pos() < items; ++cur)
{
annoe = rmov.get_int(RMV_ANNOES);
data = rmov.get_date(RMV_DATAREG);
num_reg = rmov.get_long(RMV_NUMREG);
const char provvis = mov.get_char(MOV_PROVVIS);
const TDate datacomp = mov.get_date(MOV_DATACOMP);
if (_stampa_mov_prov == 1 && provvis != '\0') //bilancio normale (non comprende i provvisori)
continue;
if (_stampa_mov_prov == 3 && provvis == '\0') //bilancio dei soli provvisori
continue;
const TString& codcaus = mov.get(MOV_CODCAUS);
const char causap = causali.decode(codcaus)[0];
if (!_quadratura && causap == 'C')
{
// Si tratta di causale di chiusura:
// Non e' richiesta la quadratura con il Libro Giornale (Modifica
// del 18-06-96 richiesta da Patrizia in seguito alla modifica dei SALDI)
continue;
}
const char sezione = rmov.get_char(RMV_SEZIONE);
const real importo = rmov.get_real(RMV_IMPORTO);
if (_annoes == 0)
data_reg = data;
else
data_reg = datacomp;
if (importo.is_zero())
continue;
//calcolo i movimenti del periodo
if ( data_reg >= _datada && data_reg <= _dataa)
if ((causap == 'A' && _dataini.ok() && _dataini != _datada) || (causap != 'A'))
{
conto_mov = TRUE;
if (sezione == 'D')
_mov_periodo_dare += importo;
else
_mov_periodo_avere += importo;
_u_max = fnc_max(_u_max, data);
if (causap == 'A')
_mov_ap = TRUE;
}
//il saldo inizio es. e' dato dall'importo dare - importo avere di quei movimenti che hanno causale == apertura e data reg >= data inizio es. e <= data limite sup.
if (_datada == _dataini) //calcolo il saldo iniziale
{
if (causap == 'A')
{
if ( (data_reg >= _dataini) && (data_reg <= _dataa) )
{
if (sezione == 'D')
_saldo_ini_dare += importo;
else
_saldo_ini_avere += importo;
_u_max = fnc_max(_u_max, data);
conto_mov = _mov_ap = TRUE;
}
}
}
else if (_datada > _dataini) //calcolo i progressivi precedenti
if ( (data_reg >= data_start) && (data_reg < _datada) )
{
if (sezione == 'D')
_prg_prec_dare += importo;
else
_prg_prec_avere += importo;
_u_max = fnc_max(_u_max, data);
conto_mov = TRUE;
if (causap == 'A')
_mov_ap = TRUE;
}
}
return conto_mov;
}
bool TStampa_bilanci::ricerca_cf(int g,int c,char tipocf,int ib, real& saldo_finale,real& saldo_iniziale,
real& mov_conto_dare,real& mov_conto_avere,real& prg_conto_dare,real& prg_conto_avere,real& saldo_conto)
{
TSaldo sld;
bool esiste_sc = FALSE;
const int anno = _tipo_stampa1 == 1 ? _annoapp : _annoes;
_lista = new TSaldi_list(g, c, anno);
const TRecnotype items = _lista->items();
for (TRecnotype i = 0; i < items; i++)
{
const TRectype* r = _lista->saldi();
if (r == NULL) break;
const long s = r->get_long(SLD_SOTTOCONTO);
saldo_finale = saldo_iniziale = ZERO; //saldi relativi a ciascun sottoconto
if (_tipo_stampa1 == 1) //bil. di verifica per data limite
{
//modifica del 21/11/1995
_mov_ap = FALSE;
//modifica del 19/06. Vedi appunti per capire
bool movimentato = calcola(g,c,s);
if (_stampa_mov_prov != 3 && _cdc.empty())
{
if (movimentato)
{
if (_mov_ap)
{
saldo_iniziale = _saldo_ini_dare - _saldo_ini_avere;
}
else
{
TLocalisamfile saldi(LF_SALDI);
saldi.zero();
saldi.put(SLD_ANNOES,_annoes);
saldi.put(SLD_FLSCA, FALSE); // W96SALDI del 05-06-96
saldi.put(SLD_GRUPPO,g); // Ho aggiunto in chiave saldi.put(SLD_FLSCA, FALSE);
saldi.put(SLD_CONTO,c); // in questa maniera reperisco il record dei saldi
saldi.put(SLD_SOTTOCONTO,s); // contenente la somma degli scaricati e non scaricati
if (saldi.read() == NOERR)
{
//se il saldo iniziale e' diverso da zero non lo devo considerare
//perche' l'ho gia' considerato nella funzione calcola
const real ss = saldi.get_real(SLD_SALDO);
if (ss.is_zero())
{
if (_annoes != 0 && (ib == 1 || ib == 2 || ib == 5))
{
saldo_iniziale += sld.saldofin_esprec(_annoes,g,c,s,false,_stampa_mov_prov==2);
//modifica del 21/11/1995
if (saldo_iniziale > ZERO)
_saldo_ini_dare = saldo_iniziale;
else
_saldo_ini_avere = -saldo_iniziale;
//fine
}
}
else
{
const char fsi = saldi.get_char(SLD_FLAGSALINI);
if (fsi == 'D')
{
saldo_iniziale = ss;
_saldo_ini_dare = ss;
}
else
{
saldo_iniziale = -ss;
_saldo_ini_avere = ss;
}
}
}
}
}
else
{
if (_annoes != 0 && (ib == 1 || ib == 2 || ib == 5))
{
saldo_iniziale = sld.saldofin_esprec(_annoes,g,c,s,false,_stampa_mov_prov==2);
//modifica del 21/11/1995
if (saldo_iniziale > ZERO)
_saldo_ini_dare = saldo_iniziale;
else
_saldo_ini_avere = -saldo_iniziale;
//fine
movimentato = sld.significativo();
}
}
}
if (!movimentato)
continue;
//fine modifica
_nuovo_tot_saldo_d += _mov_periodo_dare;
_nuovo_tot_saldo_a += _mov_periodo_avere;
//modifica del 21/11/1995
_nuovo_tot_saldo_d += _saldo_ini_dare;
_nuovo_tot_saldo_a += _saldo_ini_avere;
//fine
if (_datada == _dataini)
saldo_finale = saldo_iniziale+_mov_periodo_dare-_mov_periodo_avere;
else if (_datada > _dataini)
{
if (saldo_iniziale > 0)
_prg_prec_dare += saldo_iniziale;
else
_prg_prec_avere -= saldo_iniziale;
saldo_finale = _prg_prec_dare-_prg_prec_avere+_mov_periodo_dare-
_mov_periodo_avere;
}
if (saldo_finale == ZERO)
if (_stampav == 2)
continue;
//se saldo_finale < 0 verra' stampato con una A, se no con una D
}
else // Bilancio di verifica all'ultima immissione
{
//Attenzione! Nel caso di "tutti i conti" devono scendere solo i cli/for movimentati!!!
//modifica del 31/03/1995
bool movimentato = sld.ultima_immissione_verifica(_annoes,g,c,s,ib,_stampa_mov_prov);
if (_stampa_mov_prov != 3)
{
saldo_iniziale = sld.saldoini();
if (!movimentato)
{
//vado sui saldi con l'anno precedente e calcolo saldo_finale es.prec
//se esiste tale record e almeno un valore e' significativo (indipendentemente dal valore
//del saldo iniziale calcolato, allora metto a TRUE il flag movimentato
//solo se e' un conto patrimoniale
if (ib == 1 || ib == 2 || ib == 5)
{
saldo_iniziale = sld.saldofin_esprec(_annoes,g,c,s,false,_stampa_mov_prov==2);
movimentato = sld.significativo();
}
}
}
if (!movimentato)
continue;
//fine modifica 31/03/1995
_mov_periodo_dare = sld.prgdare();
_mov_periodo_avere = sld.prgavere();
_prg_prec_dare = ZERO;
_prg_prec_avere = ZERO;
if (sld.sezsf() == 'A')
_mov_periodo_avere -= sld.saldofin();
else
_mov_periodo_dare += sld.saldofin();
saldo_finale = saldo_iniziale+_mov_periodo_dare-_mov_periodo_avere;
if (saldo_finale.is_zero() && _stampav == 2)
continue;
_nuovo_tot_saldo_d += _mov_periodo_dare;
_nuovo_tot_saldo_a += _mov_periodo_avere;
real nuovo = sld.saldoinisusaldi();
if (nuovo > ZERO)
_nuovo_tot_saldo_d += nuovo;
else
{
nuovo = -nuovo;
_nuovo_tot_saldo_a += nuovo;
}
}
esiste_sc = TRUE;
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_saldo_ini_conto_dare += _saldo_ini_dare;
_saldo_ini_conto_avere += _saldo_ini_avere;
}
else
//fine
{
if (saldo_iniziale < ZERO)
_saldo_ini_conto_avere += saldo_iniziale;
else
_saldo_ini_conto_dare += saldo_iniziale;
}
mov_conto_dare += _mov_periodo_dare;
mov_conto_avere += _mov_periodo_avere;
prg_conto_dare += _prg_prec_dare;
prg_conto_avere += _prg_prec_avere;
saldo_conto += saldo_finale; // somma algebrica!!!
//scrivo il record relat. al sottoconto se non e' richiesto saldi di mastro
if (_verifica != 2 && !_hide_clifo)
{
_tmp_saldi_att->zero();
_tmp_saldi_att->put(SLD_GRUPPO,g);
_tmp_saldi_att->put(SLD_CONTO,c);
_tmp_saldi_att->put(SLD_SOTTOCONTO,s);
_tmp_saldi_att->put(SLD_FLAGSALINI,tipocf);
if ( (_datada == _dataini) || (_tipo_stampa1 != 1) )
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_tmp_saldi_att->put(SLD_PDAREPRO,_saldo_ini_dare); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,_saldo_ini_avere);
}
else
{
if (saldo_iniziale > ZERO) //va stampato in Dare
_tmp_saldi_att->put(SLD_PDAREPRO,saldo_iniziale); // W96SALDI del 05-06-96
else if (saldo_iniziale < ZERO)
{
saldo_iniziale = -saldo_iniziale;
_tmp_saldi_att->put(SLD_PAVEREPRO,saldo_iniziale); // W96SALDI del 05-06-96
}
}
}
else if (_datada > _dataini)
{
_tmp_saldi_att->put(SLD_PDAREPRO,_prg_prec_dare); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,_prg_prec_avere);
}
_tmp_saldi_att->put(SLD_PDARE,_mov_periodo_dare);
_tmp_saldi_att->put(SLD_PAVERE,_mov_periodo_avere);
_tmp_saldi_att->put(SLD_SALDO,saldo_finale);
_tmp_saldi_att->put(SLD_DATAULMOV, _u_max);
_tmp_saldi_att->write();
}
}
delete _lista;
return esiste_sc;
}
void TStampa_bilanci::scrivi_record_gruppo(const real& prg_da,
const real& prg_a,const real& mov_da,const real& mov_a,const real& s)
{
_tmp_saldi_att->zero();
_tmp_saldi_att->put(SLD_GRUPPO,_gp);
_tmp_saldi_att->put(SLD_CONTO,0);
_tmp_saldi_att->put(SLD_SOTTOCONTO,0L);
if ( (_datada == _dataini) || (_tipo_stampa1 != 1) )
{
//modifica del 21/11/1995
if (_datada == _dataini && _tipo_stampa1 == 1)
{
_tmp_saldi_att->put(SLD_PDAREPRO,_saldo_ini_gruppo_dare); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,_saldo_ini_gruppo_avere);
}
else
{
real app = _saldo_ini_gruppo_dare + _saldo_ini_gruppo_avere;
if (app > ZERO) //va stampato in Dare
_tmp_saldi_att->put(SLD_PDAREPRO,app); // W96SALDI del 05-06-96
else if (app < ZERO)
{
app = -app;
_tmp_saldi_att->put(SLD_PAVEREPRO,app); // W96SALDI del 05-06-96
}
}
}
else if (_datada > _dataini)
{
_tmp_saldi_att->put(SLD_PDAREPRO,prg_da); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,prg_a);
}
_tmp_saldi_att->put(SLD_PDARE,mov_da);
_tmp_saldi_att->put(SLD_PAVERE,mov_a);
_tmp_saldi_att->put(SLD_SALDO,s);
_tmp_saldi_att->write();
}
void TStampa_bilanci::scrivi_record_conto(const real& prg_da, const real& prg_a,
const real& mov_da,const real& mov_a, const real& s)
{
_tmp_saldi_att->zero();
_tmp_saldi_att->put(SLD_GRUPPO,_gp);
_tmp_saldi_att->put(SLD_CONTO,_cp);
_tmp_saldi_att->put(SLD_SOTTOCONTO,0L);
if ( (_datada == _dataini) || (_tipo_stampa1 != 1) )
{
//modifica del 21/11/1995
if (_datada == _dataini && _tipo_stampa1 == 1)
{
_tmp_saldi_att->put(SLD_PDAREPRO,_saldo_ini_conto_dare); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,_saldo_ini_conto_avere);
}
else
{
real app = _saldo_ini_conto_dare + _saldo_ini_conto_avere;
if (app > ZERO) //va stampato in Dare
_tmp_saldi_att->put(SLD_PDAREPRO,app); // W96SALDI del 05-06-96
else if (app < ZERO)
{
app = -app;
_tmp_saldi_att->put(SLD_PAVEREPRO,app); // W96SALDI del 05-06-96
}
}
}
else if (_datada > _dataini)
{
_tmp_saldi_att->put(SLD_PDAREPRO,prg_da); // W96SALDI del 05-06-96
_tmp_saldi_att->put(SLD_PAVEREPRO,prg_a);
}
_tmp_saldi_att->put(SLD_PDARE,mov_da);
_tmp_saldi_att->put(SLD_PAVERE,mov_a);
_tmp_saldi_att->put(SLD_SALDO,s);
_tmp_saldi_att->write();
}
void TStampa_bilanci::init_sort()
{
cli_for cf;
_sort = new TSort(sizeof(cli_for));
_sort->addsortkey ((char*)&(cf.tipocf)-(char*)&(cf.tipocf),1);
_sort->addsortkey ((char*)&(cf.gruppo)-(char*)&(cf.tipocf),3);
_sort->addsortkey ((char*)&(cf.conto)-(char*)&(cf.tipocf),3);
if (_ordinamento == 1)
_sort->addsortkey ((char*)&(cf.codcf)-(char*)&(cf.tipocf),6);
else if (_ordinamento == 2)
_sort->addsortkey ((char*)&(cf.ragsoc)-(char*)&(cf.tipocf),50);
_sort->init();
}
void TStampa_bilanci::riempi_record(char t,int g,int c,long s,
const char* rs,const real& sd,const real& sa,
const real& md,const real& ma,const real& sf)
{
cli_for cf;
cf.tipocf = t;
sprintf(cf.gruppo, "%03d", g);
sprintf(cf.conto, "%03d", c);
sprintf(cf.codcf, "%06ld", s);
sprintf(cf.ragsoc, "%s", rs);
if ( s == 999999L )
{
if ( (_datada == _dataini)||(_tipo_stampa1 != 1) )
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
cf.saldodare = _saldo_ini_conto_dare;
cf.saldoavere = _saldo_ini_conto_avere;
}
else
//fine
{
real app = _saldo_ini_conto_dare + _saldo_ini_conto_avere;
if (app > ZERO) //va stampato in Dare
{
cf.saldoavere = ZERO;
cf.saldodare = app;
}
else if (app < ZERO)
{
app = -app;
cf.saldodare = ZERO;
cf.saldoavere = app;
}
}
}
else if (_datada > _dataini)
{
cf.saldodare = sd;
cf.saldoavere = sa;
}
}
else
{
cf.saldodare = sd;
cf.saldoavere = sa;
}
cf.movdare = md;
cf.movavere = ma;
cf.saldofinale = sf;
cf.udata = _u_max;
_sort->sort((const char*)&cf);
}
void TStampa_bilanci::leggi_clifo(const TArray& gccf)
{
TSaldo sld;
TLocalisamfile saldi(LF_SALDI);
// int g = 0, c=0;
long codcf=0l;
TString80 ragsoc;
char tipocf,tipocfp,tipoa;
real saldo_finale, saldo_conto, saldo_iniziale, saldodare, saldoavere,
movdare, movavere;
real mov_conto_dare, mov_conto_avere, prg_conto_dare, prg_conto_avere;
bool esiste_sc = FALSE, movimentato = FALSE;
TRecnotype items = _cur->items();
_gp=-1;
_cp=-1;
tipocfp = ' ';
_saldo_ini_conto_dare = ZERO;
_saldo_ini_conto_avere = ZERO;
saldo_conto = ZERO;
mov_conto_dare = ZERO;
mov_conto_avere = ZERO;
prg_conto_dare = ZERO;
prg_conto_avere = ZERO;
_u_max = 0l;
const int anno = _tipo_stampa1 == 1 ? _annoapp : _annoes;
for (int i=0; i < gccf.items(); i++)
{
int g = ((TToken_string&)gccf[i]).get_int(0);
int c = ((TToken_string&)gccf[i]).get_int(1);
*_cur = 0l;
for (int i = 0; i < items; i++,++(*_cur))
{
_prog->addstatus(1);
codcf = _cur->curr().get_long(CLI_CODCF);
tipocf = _cur->curr().get(CLI_TIPOCF)[0];
ragsoc = _cur->curr().get(CLI_RAGSOC);
tipoa = _cur->curr().get_char(CLI_TIPOAPER);
if (tipoa == 'F') //persona fisica
{
TString80 cognome, nome;
cognome = ragsoc.mid(0,30);
nome = ragsoc.mid(30,20);
cognome.trim(); nome.trim();
ragsoc = cognome;
ragsoc << ' ' << nome;
}
TEsercizi_contabili ese;
int aprec = ese.pred(anno);
saldi.zero();
saldi.put(SLD_ANNOES, anno); // W96SALDI del 05-06-96
saldi.put(SLD_FLSCA, FALSE);
saldi.put(SLD_GRUPPO, g);
saldi.put(SLD_CONTO, c);
saldi.put(SLD_SOTTOCONTO, codcf);
if (saldi.read() != NOERR)
{
//if (_tipo_stampa1 == 1) //bilancio per data limite
// continue;
//else
if (_stampac == 2) //se sono richiesti i conti movimentati
{ //esco, se no...
_indbil = cerca_indbil(g,c);
if (_indbil == 1 || _indbil == 2 || _indbil == 5)
{
saldi.zero();
saldi.put(SLD_ANNOES, aprec); // W96SALDI del 05-06-96
saldi.put(SLD_FLSCA, FALSE);
saldi.put(SLD_GRUPPO, g);
saldi.put(SLD_CONTO, c);
saldi.put(SLD_SOTTOCONTO, codcf);
if (saldi.read() != NOERR)
continue;
}
}
}
if ( (((_cp != -1) && (c != _cp)) || ((_gp != -1) && (g != _gp))) &&
esiste_sc )
{
//scrivo il record del conto;
riempi_record(tipocfp,_gp,_cp,999999L,"zzzz",prg_conto_dare,
prg_conto_avere,mov_conto_dare,mov_conto_avere,saldo_conto);
tipocfp = tipocf;
_cp = c;
esiste_sc = FALSE;
_saldo_ini_conto_dare = ZERO;
_saldo_ini_conto_avere = ZERO;
saldo_conto = ZERO;
mov_conto_dare = ZERO;
mov_conto_avere = ZERO;
prg_conto_dare = ZERO;
prg_conto_avere = ZERO;
}
saldo_finale = ZERO;
saldodare = ZERO;
saldoavere = ZERO;
movdare = ZERO;
movavere = ZERO;
saldo_iniziale = ZERO;
if (_tipo_stampa1 == 1) //bilancio di verifica per data limite
{
//modifica del 21/11/1995
_mov_ap = FALSE;
//modifica del 19/06/95
_indbil = cerca_indbil(g,c);
movimentato = calcola(g,c,codcf);
if (_stampa_mov_prov != 3)
if (!movimentato)
if (_indbil == 1 || _indbil == 2 || _indbil == 5)
if (_annoes != 0) //cioe' se sto ragionando per competenza
{
saldo_iniziale = sld.saldofin_esprec(_annoes,g,c,codcf,false,_stampa_mov_prov==2);
if (saldo_iniziale > ZERO)
_saldo_ini_dare = saldo_iniziale;
else _saldo_ini_avere = -saldo_iniziale;
}
if (movimentato)
{
//modifica del 21/11/1995
if (_mov_ap)
saldo_iniziale = _saldo_ini_dare - _saldo_ini_avere;
else
{
TLocalisamfile saldi(LF_SALDI);
saldi.zero();
saldi.put(SLD_ANNOES, _annoes); // W96SALDI del 05-06-96
saldi.put(SLD_FLSCA, FALSE);
saldi.put(SLD_GRUPPO, g);
saldi.put(SLD_CONTO, c);
saldi.put(SLD_SOTTOCONTO, codcf);
if (saldi.read() == NOERR)
{
const real s = saldi.get_real(SLD_SALDO);
if (_stampa_mov_prov != 3)
if (_indbil == 1 || _indbil == 2 || _indbil == 5)
if (s.is_zero() && _annoes != 0) //competenza!!!
{
saldo_iniziale += sld.saldofin_esprec(_annoes,g,c,codcf,false,_stampa_mov_prov==2);
//modifica del 21/11/1995
if (saldo_iniziale > ZERO)
_saldo_ini_dare = saldo_iniziale;
else _saldo_ini_avere = -saldo_iniziale;
//fine
}
}
}
}
//fine modifica del 19/06/95
//movimentato = calcola(g,c,codcf);
if (movimentato || _stampac != 1 || saldo_iniziale != ZERO)
{
if (_datada == _dataini)
saldo_finale = saldo_iniziale+_mov_periodo_dare-_mov_periodo_avere;
else if (_datada > _dataini)
{
//modifica del 19/06
if (saldo_iniziale > 0)
_prg_prec_dare += saldo_iniziale;
else _prg_prec_avere -= saldo_iniziale;
//fine modifica
saldo_finale = _prg_prec_dare-_prg_prec_avere+_mov_periodo_dare
-_mov_periodo_avere;
}
}
//se saldo_finale < 0 verra' stampato con una A, se no con una D
}
else //bilancio di verifica all'ultima immissione
{
_indbil = cerca_indbil(g,c);
movimentato = sld.ultima_immissione_verifica(anno,g,c,codcf,_indbil,_stampa_mov_prov);
if (_stampa_mov_prov != 3)
if (!movimentato /* && _stampac!=1 */ )
if (_indbil == 1 || _indbil == 2 || _indbil == 5)
saldo_iniziale = sld.saldofin_esprec(anno,g,c,codcf,false,_stampa_mov_prov==2);
if (movimentato)
saldo_iniziale = sld.saldoini();
if (movimentato || _stampac != 1 || saldo_iniziale != ZERO)
{
_mov_periodo_dare = sld.prgdare();
_mov_periodo_avere = sld.prgavere();
_prg_prec_dare = ZERO;
_prg_prec_avere = ZERO;
if (sld.sezsf() == 'A')
_mov_periodo_avere -= sld.saldofin();
else
_mov_periodo_dare += sld.saldofin();
saldo_finale = saldo_iniziale+_mov_periodo_dare-_mov_periodo_avere;
}
}
if (movimentato || _stampac != 1 || saldo_iniziale != ZERO)
if (!(saldo_finale.is_zero() && _stampac == 2))
{
esiste_sc = TRUE;
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
_saldo_ini_conto_dare += _saldo_ini_dare;
_saldo_ini_conto_avere += _saldo_ini_avere;
}
else
{
if (saldo_iniziale < ZERO)
_saldo_ini_conto_avere += saldo_iniziale;
else
_saldo_ini_conto_dare += saldo_iniziale;
}
//fine
mov_conto_dare += _mov_periodo_dare;
mov_conto_avere += _mov_periodo_avere;
prg_conto_dare += _prg_prec_dare;
prg_conto_avere += _prg_prec_avere;
saldo_conto += saldo_finale; // somma algebrica!!!
if ( (_datada == _dataini)||(_tipo_stampa1 != 1) )
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 1 && _datada == _dataini)
{
saldodare = _saldo_ini_dare;
saldoavere = _saldo_ini_avere;
}
else
//
{
if (saldo_iniziale > ZERO) //va stampato in Dare
saldodare = saldo_iniziale;
else if (saldo_iniziale < ZERO)
{
saldo_iniziale = -saldo_iniziale;
saldoavere = saldo_iniziale;
}
}
}
else if (_datada > _dataini)
{
saldodare = _prg_prec_dare;
saldoavere = _prg_prec_avere;
}
movdare = _mov_periodo_dare;
movavere = _mov_periodo_avere;
riempi_record(tipocf,g,c,codcf,ragsoc,saldodare,saldoavere,movdare,
movavere,saldo_finale);
tipocfp = tipocf;
_gp = g;
_cp = c;
}
}
}
if (esiste_sc)
riempi_record(tipocfp,_gp,_cp,999999L,"zzzz",prg_conto_dare,prg_conto_avere,
mov_conto_dare,mov_conto_avere,saldo_conto);
}
void TStampa_bilanci::crea_sort_clifo()
{
long ncur = _cur->items();
//serve solo per la progind: stima alla meno peggio
if (_situazione.empty()) ncur /= 2;
long nitems = ncur*(_clienti.items()+_fornitori.items());
_prog = new TProgind(nitems,TR("Elaborazione in corso... prego attendere"),FALSE);
_prog->addstatus(1);
init_sort();
if (_situazione == "C") leggi_clifo(_clienti);
else if (_situazione == "F") leggi_clifo(_fornitori);
else
{
_cur->setfilter("TIPOCF = \"C\"");
leggi_clifo(_clienti);
_cur->setfilter("TIPOCF = \"F\"");
leggi_clifo(_fornitori);
}
}
int TStampa_bilanci::cerca_indbil(int g, int c)
{
/*
TLocalisamfile pconti(LF_PCON);
pconti.zero();
pconti.put(PCN_GRUPPO,g);
if (c != 0)
pconti.put(PCN_CONTO,c);
pconti.put(PCN_SOTTOCONTO,0l);
pconti.read();
return pconti.get_int(PCN_INDBIL);
*/
TString8 key; key.format("%d|%d", g, c);
const int indbil = atoi(cache().get(LF_PCON, key, PCN_INDBIL));
CHECKD(indbil > 0, "Indicatore di bilancio strano: ", indbil);
return indbil;
}
void TStampa_bilanci::leggi_files_dare(TIsamtempfile* file)
{
_gruppo_dare = file->get_int(SLD_GRUPPO);
_conto_dare = file->get_int(SLD_CONTO);
_sottoconto_dare = file->get_long(SLD_SOTTOCONTO);
_saldo_dare = file->get_real(SLD_PDARE);
_descr_dare = DescrizioneConto(_gruppo_dare,_conto_dare,_sottoconto_dare,' ');
_gc_corr_dare = format("%3d%3d", _gruppo_dare, _conto_dare);
if (_gc_corr_dare != _gc_prec_dare)
{
_cambiato_conto_1 = TRUE;
_gc_prec_dare = _gc_corr_dare;
}
else if (_sottoconto_dare != 0l)
_cambiato_conto_1 = FALSE;
}
void TStampa_bilanci::leggi_files_avere(TIsamtempfile* file)
{
_gruppo_avere = file->get_int(SLD_GRUPPO);
_conto_avere = file->get_int(SLD_CONTO);
_sottoconto_avere = file->get_long(SLD_SOTTOCONTO);
_saldo_avere = file->get_real(SLD_PAVERE);
_descr_avere = DescrizioneConto(_gruppo_avere,_conto_avere,_sottoconto_avere,
' ');
_gc_corr_avere = format("%3d%3d", _gruppo_avere, _conto_avere);
if (_gc_corr_avere != _gc_prec_avere)
{
_cambiato_conto_2 = TRUE;
_gc_prec_avere = _gc_corr_avere;
}
else if (_sottoconto_avere != 0l)
_cambiato_conto_2 = FALSE;
}
#define TOTAL_PICTURE "###.###.###.###.###"
HIDDEN void total2string(const real& tot, TString& str)
{
TCurrency cur(tot);
str = cur.string(TRUE);
str.right_just(strlen(TOTAL_PICTURE));
}
bool TStampa_bilanci::preprocess_print(int file, int counter)
{
if (_bilancio == 1)
{
set_real_picture ("##.###.###.###.###");
set_print_zero();
_tmp_saldi_att->setkey(2);
_tmp_saldi_pass->setkey(2);
_tmp_saldi_costi->setkey(2);
_tmp_saldi_ricavi->setkey(2);
_tmp_saldi_conti_uno->setkey(2);
_tmp_saldi_conti_due->setkey(2);
_gc_prec_avere = "";
_prima_volta = _seconda_volta = TRUE;
_flag = _controlla = FALSE;
_salto_pagina = _salto_pagina1 = _stampato = FALSE;
_cambiato_conto_1 = TRUE;
_cambiato_conto_2 = TRUE;
_tot_dare = ZERO;
_tot_avere = ZERO;
}
else
{
if (_noseparator)
set_real_picture ("################");
else
set_real_picture ("####.###.###.###");
set_print_zero(FALSE);
_cambiato_conto_1 = FALSE;
_livello_conto = TRUE;
_saldo_dare_tot = ZERO;
_saldo_avere_tot = ZERO;
_mov_dare_tot = ZERO;
_mov_avere_tot = ZERO;
_saldo_finale_tot = ZERO;
}
set_magic_currency(TRUE);
return TRUE;
}
void TStampa_bilanci::leggi_file_tmp()
{
if (_livello_conto) // era meglio chiamarla _livello_conto_oppure_gruppo, perche' nel caso dei saldi di mastro _livello_conto==TRUE <=> si tratta di un gruppo, mentre nel caso del bilancio _livello_conto==TRUE <=> si tratta di un conto
{
_gruppo = _tmp_saldi_att->get_int(SLD_GRUPPO);
_conto = _tmp_saldi_att->get_int(SLD_CONTO);
_sottoconto = _tmp_saldi_att->get_long(SLD_SOTTOCONTO);
_tipo_conto = _tmp_saldi_att->get_char(SLD_FLAGSALINI);
_descr = DescrizioneConto(_gruppo,_conto,_sottoconto,_tipo_conto);
_saldoini_dare = _tmp_saldi_att->get_real(SLD_PDAREPRO); // W96SALDI del 05-06-96
_saldoini_avere = _tmp_saldi_att->get_real(SLD_PAVEREPRO);
_mov_dare = _tmp_saldi_att->get_real(SLD_PDARE);
_mov_avere = _tmp_saldi_att->get_real(SLD_PAVERE);
_saldofinale = _tmp_saldi_att->get_real(SLD_SALDO);
}
_eof1 = _tmp_saldi_att->next();
if (!_eof1)
{
_gruppo_succ = _tmp_saldi_att->get_int(SLD_GRUPPO);
_conto_succ = _tmp_saldi_att->get_int(SLD_CONTO);
_sottoconto_succ = _tmp_saldi_att->get_long(SLD_SOTTOCONTO);
_tipoc_succ = _tmp_saldi_att->get_char(SLD_FLAGSALINI);
if ( (_verifica != 2) && (_sottoconto_succ != 0) )
{
if (_tipo_stampa1 == 2)
_ultima_data = UltimaData(_gruppo_succ,_conto_succ, _sottoconto_succ,_annoes);
else
_ultima_data = _tmp_saldi_att->get_date(SLD_DATAULMOV);
}
_descr_succ = DescrizioneConto(_gruppo_succ,_conto_succ,
_sottoconto_succ,_tipoc_succ);
_saldoini_dare_succ = _tmp_saldi_att->get_real(SLD_PDAREPRO); // W96SALDI del 05-06-96
_saldoini_avere_succ = _tmp_saldi_att->get_real(SLD_PAVEREPRO);
_mov_dare_succ = _tmp_saldi_att->get_real(SLD_PDARE);
_mov_avere_succ = _tmp_saldi_att->get_real(SLD_PAVERE);
_saldofinale_succ = _tmp_saldi_att->get_real(SLD_SALDO);
_livello_conto = FALSE;
if ( ((_verifica != 2)&&(_sottoconto_succ == 0)) ||
((_verifica == 2)&&(_conto_succ == 0)) )
{
_livello_conto = TRUE;
_gruppo_succ = _gruppo;
_conto_succ = _conto;
_sottoconto_succ = _sottoconto;
_descr_succ = _descr;
_saldoini_dare_succ = _saldoini_dare;
_saldoini_avere_succ = _saldoini_avere;
_mov_dare_succ = _mov_dare;
_mov_avere_succ = _mov_avere;
_saldofinale_succ = _saldofinale;
}
}
}
bool TStampa_bilanci::preprocess_page(int file, int counter)
{
reset_print();
if (_bilancio == 1) //stampa bilancio a sez. contrapposte
{
if (counter)
{
if ( (!_eof1) && (_cambiato_conto_1) )
_eof1 = _tmp_saldi_att->next();
if ( (!_eof2) && (_cambiato_conto_2) )
_eof2 = _tmp_saldi_pass->next();
if (_eof1 && _eof2)
{
if (_prima_volta)
{
stampa_totali_uno(_prg_saldoini_dare,_prg_saldoini_avere);
_eof3 = _tmp_saldi_costi->first();
_eof4 = _tmp_saldi_ricavi->first();
}
else
{
_controlla = TRUE;
if (_salto_pagina)
{
if ( (!_eof3) && (_cambiato_conto_1) )
_eof3 = _tmp_saldi_costi->next();
if ( (!_eof4) && (_cambiato_conto_2) )
_eof4 = _tmp_saldi_ricavi->next();
}
}
if ( (!_eof3) && (_cambiato_conto_1) )
leggi_files_dare(_tmp_saldi_costi);
if ( (!_eof4) && (_cambiato_conto_2) )
leggi_files_avere(_tmp_saldi_ricavi);
if (_eof3 && _eof4 && _salto_pagina)
{
if (_seconda_volta)
{
stampa_totali();
_eof5 = _tmp_saldi_conti_uno->first();
_eof6 = _tmp_saldi_conti_due->first();
}
else
{
_flag = TRUE;
if (_salto_pagina1)
{
if ( (!_eof5) && (_cambiato_conto_1) )
_eof5 = _tmp_saldi_conti_uno->next();
if ( (!_eof6) && (_cambiato_conto_2) )
_eof6 = _tmp_saldi_conti_due->next();
}
}
if ( (!_eof5) && (_cambiato_conto_1) )
leggi_files_dare(_tmp_saldi_conti_uno);
if ( (!_eof6) && (_cambiato_conto_2) )
leggi_files_avere(_tmp_saldi_conti_due);
}
}
}
else //counter = 0
{
_gc_prec_dare = _gc_corr_avere = "";
_eof1 = _tmp_saldi_att->first();
_eof2 = _tmp_saldi_pass->first();
}
if ( (!_eof1) && (_cambiato_conto_1) )
leggi_files_dare(_tmp_saldi_att);
if ( (!_eof2) && (_cambiato_conto_2) )
leggi_files_avere(_tmp_saldi_pass);
}
else //stampa bilancio di verifica
{
if (_verifica == 3)
leggi_sort();
else
{
if (counter)
{
if (!_eof1)
leggi_file_tmp();
}
else
{
_eof1 = _tmp_saldi_att->first();
if (_eof1)
return FALSE;
else
leggi_file_tmp();
}
}
}
return TRUE;
}
void TStampa_bilanci::leggi_sort()
{
_buff = _sort->retrieve();
if (_buff != NULL)
{
struct cli_for* cf = (struct cli_for*)_buff;
_tipo_conto = cf->tipocf;
_gruppo = atoi(cf->gruppo);
_conto = atoi(cf->conto);
_sottoconto = atol(cf->codcf);
_descr = cf->ragsoc;
if ( (_ordinamento == 2 && _descr != "zzzz") || (_ordinamento == 1 && _sottoconto != 999999L) )
{
if (_tipo_stampa1 == 2)
_ultima_data = UltimaData(_gruppo,_conto,_sottoconto,_annoes);
else
_ultima_data = cf->udata;
}
_saldo_dare = cf->saldodare;
_saldo_avere = cf->saldoavere;
_mov_dare = cf->movdare;
_mov_avere = cf->movavere;
_saldofinale = cf->saldofinale;
}
}
void TStampa_bilanci::controlla_conto(int file1,int file2)
{
char dep = '*';
if (!file1)
if (_cambiato_conto_1)
{
set_row(_i,"@68g%c", dep);
_cambiato_conto_1 = FALSE;
}
else
{
stampa_prima_colonna(_gruppo_dare, _conto_dare, _sottoconto_dare,
_descr_dare,_saldo_dare);
_cambiato_conto_1 = TRUE;
if (!_totali)
if ( (_conto_dare == 0) && (_sottoconto_dare == 0) )
_tot_dare += _saldo_dare;
if (_totali)
if (_sottoconto_dare == 0)
_tot_dare += _saldo_dare;
}
if (!file2)
if (_cambiato_conto_2)
{
set_row(_i,"@68g%c", dep);
_cambiato_conto_2 = FALSE;
}
else
{
stampa_seconda_colonna(_gruppo_avere, _conto_avere, _sottoconto_avere,
_descr_avere, _saldo_avere);
_cambiato_conto_2 = TRUE;
if (!_totali)
if ( (_conto_avere == 0) && (_sottoconto_avere == 0) )
_tot_avere += _saldo_avere;
if (_totali)
if (_sottoconto_avere == 0)
_tot_avere += _saldo_avere;
}
}
void TStampa_bilanci::postclose_print()
{
if (_bilancio == 1)
{
delete _tmp_saldi_att; _tmp_saldi_att = NULL;
delete _tmp_saldi_pass; _tmp_saldi_pass = NULL;
delete _tmp_saldi_costi; _tmp_saldi_costi = NULL;
delete _tmp_saldi_ricavi; _tmp_saldi_ricavi = NULL;
delete _tmp_saldi_conti_uno; _tmp_saldi_conti_uno = NULL;
delete _tmp_saldi_conti_due; _tmp_saldi_conti_due = NULL;
}
else
{
if (_verifica == 3)
{
delete _sort; _sort = NULL;
}
else
{
delete _tmp_saldi_att; _tmp_saldi_att = NULL;
}
}
}
void TStampa_bilanci::set_page(int file, int counter)
{
const TString16 dep;
if (_bilancio == 1) //stampa bilancio a sezioni contrapposte
{
_i = 1;
if (!counter)
{
set_row(_i++,FR("@29gATTIVITA'@94gPASSIVITA'"));
set_row(_i++,"@29g---------@94g----------");
set_row(_i++, dep);
}
controlla_conto(_eof1,_eof2); //stampo una riga vuota tra un gruppo e un conto altrimenti no
if ( _eof1 && _eof2 && (!_prima_volta) && _controlla )
if (!_salto_pagina)
{
printer().formfeed();
set_row(_i++,FR("@29gCOSTI@94gRICAVI"));
set_row(_i++,"@29g-----@94g------");
set_row(_i++, dep);
_salto_pagina = TRUE;
}
if (_eof1 && _eof2 && _controlla)
{
controlla_conto(_eof3,_eof4);
if ( _eof3 && _eof4 && (!_seconda_volta) && _flag )
if (!_salto_pagina1)
{
if (!_tmp_saldi_conti_uno->empty() || !_tmp_saldi_conti_due->empty())
{
printer().formfeed();
set_row(_i++,FR("@59gCONTI D'ORDINE"));
set_row(_i++,"@59g--------------");
set_row(_i++, dep);
if (_eof5 && _eof6)
{
_stampato = TRUE;
stampa_totali_uno(_prg_inidare_ord,_prg_iniavere_ord);
}
}
_salto_pagina1 = TRUE;
}
if (_eof3 && _eof4 && _flag)
{
if (!_tmp_saldi_conti_uno->empty() || !_tmp_saldi_conti_due->empty())
{
controlla_conto(_eof5,_eof6);
if (_eof5 && _eof6)
if (!_stampato)
stampa_totali_uno(_prg_inidare_ord,_prg_iniavere_ord);
}
}
}
}
else //stampa bilancio di verifica
{
const TString16 udata = _ultima_data.string(brief,'/');
char app;
int r = 1;
if (_verifica == 3)
{
if (_buff != NULL)
{
*_d = (const char*) _descr;
if (_saldofinale > 0)
app = 'D';
else if (_saldofinale < 0)
{
_saldofinale = -_saldofinale;
app = 'A';
}
if ( (_ordinamento == 2 && _descr == "zzzz") ||
(_ordinamento == 1 && _sottoconto == 999999L) ) //devo stampare il conto
{
_descr = DescrizioneConto(_gruppo,_conto,0L,' ');
stampa_record_conto(_gruppo,_conto,_descr,_saldo_dare,_saldo_avere,
_mov_dare,_mov_avere,_saldofinale,app);
}
else
if (_stampa_width == 132)
{
set_row(r,"@1g%6ld",(const char*)_sottoconto);
if ((_saldo_dare != ZERO) || (_saldo_avere != ZERO) || (_mov_dare != ZERO) ||
(_mov_avere != ZERO) || (_saldofinale != ZERO))
set_row(r," %s",(const char*)udata);
set_row(r,"@17g#a@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r",_d,&_saldo_dare,
&_saldo_avere,&_mov_dare,&_mov_avere,&_saldofinale);
if (_saldofinale != ZERO)
set_row(r,"@131g%c", app);
if (_descr.len() > 30)
set_row(++r, "@46g!@80g!@114g!");
}
else if (app == 'D')
{
set_row(r,"@1g%6ld",(const char*)_sottoconto);
if ((_saldo_dare != ZERO) || (_saldo_avere != ZERO) || (_mov_dare != ZERO) ||
(_mov_avere != ZERO) || (_saldofinale != ZERO))
set_row(r," %s",(const char*)udata);
set_row(r,"@17g#a@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!",_d,
&_saldo_dare,&_saldo_avere,&_mov_dare,&_mov_avere,&_saldofinale);
if (_descr.len() > 30)
set_row(++r, "@46g!@80g!@114g!@148g!");
}
else
{
set_row(r,"@1g%6ld",(const char*)_sottoconto);
if ((_saldo_dare != ZERO) || (_saldo_avere != ZERO) || (_mov_dare != ZERO) ||
(_mov_avere != ZERO) || (_saldofinale != ZERO))
set_row(r," %s",(const char*)udata);
set_row(r,"@17g#a@46g!%r@64g%r@80g!%r@100g%r@114g!@132g%r@148g!",
_d,&_saldo_dare,&_saldo_avere,&_mov_dare,&_mov_avere,&_saldofinale);
if (_descr.len() > 30)
set_row(++r, "@46g!@80g!@114g!@148g!");
}
}
}
else //_verifica != 3
{
if (!_eof1)
{
if (_saldofinale_succ >= ZERO)
app = 'D';
else
{
_saldofinale_succ = -_saldofinale_succ;
app = 'A';
}
if (_livello_conto) //sto stampando un conto/gruppo
r = stampa_record_conto(_gruppo_succ,_conto_succ,_descr_succ,
_saldoini_dare_succ,_saldoini_avere_succ,_mov_dare_succ,
_mov_avere_succ,_saldofinale_succ,app);
else //sto stampando un sottoconto/conto
{
if (_verifica == 2)
{
if (_stampa_width == 132)
{
set_row(r,"%3d",_conto_succ);
set_row(r," @8g%-.40s@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r",
(const char*)_descr_succ,&_saldoini_dare_succ,&_saldoini_avere_succ,
&_mov_dare_succ,&_mov_avere_succ,&_saldofinale_succ);
if (_saldofinale_succ != ZERO)
set_row(r,"@131g%c", app);
}
else if (app == 'D')
{
set_row(r,"%3d",_conto_succ);
set_row(r," @8g%-.40s@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!",
(const char*)_descr_succ,&_saldoini_dare_succ,&_saldoini_avere_succ,
&_mov_dare_succ,&_mov_avere_succ,&_saldofinale_succ);
}
else
{
set_row(r,"%3d",_conto_succ);
set_row(r," @8g%-.40s@46g!%r@64g%r@80g!%r@98g%r@114g!@132g%r@148g!",
(const char*)_descr_succ,&_saldoini_dare_succ,&_saldoini_avere_succ,
&_mov_dare_succ,&_mov_avere_succ,&_saldofinale_succ);
}
} // _verifica != 2
else
{
*_d = (const char*) _descr_succ;
if (_stampa_width == 132)
{
set_row(r,"@1g%6ld",(const char*)_sottoconto_succ);
if ((_saldoini_dare_succ != ZERO) || (_saldoini_avere_succ != ZERO) ||
(_mov_dare_succ != ZERO) || (_mov_avere_succ != ZERO) ||
(_saldofinale_succ != ZERO))
set_row(r," %s",(const char*)udata);
set_row(r,"@17g#a@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r",
_d,&_saldoini_dare_succ,&_saldoini_avere_succ,
&_mov_dare_succ,&_mov_avere_succ,&_saldofinale_succ);
if (_saldofinale_succ != ZERO)
set_row(r,"@131g%c", app);
if (_descr_succ.len() > 30)
set_row(++r, "@46g!@80g!@114g!");
}
else // Stampa estesa
{
set_row(r,"@1g%6ld",(const char*)_sottoconto_succ);
if ((_saldoini_dare_succ != ZERO) || (_saldoini_avere_succ != ZERO) ||
(_mov_dare_succ != ZERO) || (_mov_avere_succ != ZERO) ||
(_saldofinale_succ != ZERO))
set_row(r," %s",(const char*)udata);
if (app == 'D')
{
set_row(r,"@17g#a@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!",
_d,&_saldoini_dare_succ,&_saldoini_avere_succ,
&_mov_dare_succ,&_mov_avere_succ,&_saldofinale_succ);
}
else
{
set_row(r,"@17g#a@46g!%r@64g%r@80g!%r@98g%r@114g!@132g%r@148g!",
_d,&_saldoini_dare_succ,&_saldoini_avere_succ,
&_mov_dare_succ,&_mov_avere_succ,&_saldofinale_succ);
}
if (_descr_succ.len() > 30)
set_row(++r, "@46g!@80g!@114g!@148g!");
}
}
}
}
else
{
if (_saldofinale >= ZERO)
app = 'D';
else
{
app = 'A';
_saldofinale = -_saldofinale;
}
r = stampa_record_conto(_gruppo,_conto,_descr,_saldoini_dare,
_saldoini_avere,_mov_dare,_mov_avere,_saldofinale,app);//per stampare l'ultimo conto
stampa_riga_totali(r);
}
}
}
}
int TStampa_bilanci::stampa_record_conto(int g,int c,const TString& d,
const real& r1,const real& r2,const real& r3,const real& r4,const real& r5,
const char app)
{
int r = 1;
if (_stampa_width != 132)
set_row(r,"@46g!@80g!@114g!@148g!"); //stampo una riga vuota
else
set_row(r,"@46g!@80g!@114g!"); //stampo una riga vuota
r++;
if (_verifica == 2)
{
if (_stampa_width == 132)
{
set_row(r,"%3d-",g);
set_row(r,"@8g%-.40s",(const char*)d);
set_row(r,"@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r",&r1,&r2,&r3,&r4,&r5);
if (r5 != ZERO)
set_row(r,"@131g%c", app);
r++;
}
else
if (app == 'D')
{
set_row(r,"%3d-",g);
set_row(r,"@8g%-.40s",(const char*)d);
set_row(r++,"@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!",&r1,&r2,&r3,&r4,&r5);
}
else
{
set_row(r,"%3d-",g);
set_row(r,"@8g%-.40s",(const char*)d);
set_row(r++,"@46g!%r@64g%r@80g!%r@98g%r@114g!@132g%r@148g!",&r1,&r2,&r3,&r4,&r5);
}
}
else
{
*_d = (const char*) d;
if (_stampa_width == 132)
{
set_row(r,"%3d-",g);
set_row(r,"%3d ********",c);
set_row(r,"@17g#a",_d);
set_row(r,"@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r",&r1,&r2,&r3,&r4,&r5);
if (r5 != ZERO)
set_row(r,"@131g%c", app);
r++;
if (d.len() > 30)
set_row(r+1, "@46g!@80g!@114g!");
}
else if (app == 'D')
{
set_row(r,"%3d-",g);
set_row(r,"%3d ********",c);
set_row(r,"@17g#a",_d);
set_row(r++,"@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!",&r1,&r2,&r3,&r4,&r5);
if (d.len() > 30)
set_row(r+1, "@46g!@80g!@114g!@148g!");
}
else
{
set_row(r,"%3d-",g);
set_row(r,"%3d ********",c);
set_row(r,"@17g#a",_d);
set_row(r++,"@46g!%r@64g%r@80g!%r@98g%r@114g!@132g%r@148g!",&r1,&r2,&r3,&r4,&r5);
if (d.len() > 30)
set_row(r+1, "@46g!@80g!@114g!@148g!");
}
}
set_row(r,"@46g!@80g!@114g!");
if (_stampa_width != 132)
set_row(r,"@148g!");
r++;
set_row(r,"@46g!@80g!@114g!");
if (_stampa_width != 132)
set_row(r,"@148g!");
r++;
if (app == 'D')
_saldo_finale_tot += r5;
else _saldo_finale_tot -= r5;
_saldo_dare_tot += r1;
_saldo_avere_tot += r2;
_mov_dare_tot += r3;
_mov_avere_tot += r4;
return r;
}
void TStampa_bilanci::stampa_riga_totali(int r)
{
const TString16 dep;
char app = ' ';
if (_saldo_finale_tot > 0)
app = 'D';
else if (_saldo_finale_tot < 0)
{
_saldo_finale_tot = -_saldo_finale_tot;
app = 'A';
}
//modifica del 21/11/1995
if (_tipo_stampa1 == 2)
{
real r = _saldo_dare_tot - _saldo_avere_tot;
if (r > ZERO)
{
_saldo_dare_tot = r;
_saldo_avere_tot = ZERO;
}
else
{
_saldo_avere_tot = -r;
_saldo_dare_tot = ZERO;
}
}
set_row(r, "@46g!@80g!@114g!");
if (_stampa_width != 132)
set_row(r, "@148g!");
r++;
if (_verifica == 2)
{
if (_stampa_width == 132)
{
set_row(r,FR("***@8gTOTALE GENERALE@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r"),&_saldo_dare_tot,&_saldo_avere_tot,&_mov_dare_tot,
&_mov_avere_tot,&_saldo_finale_tot);
if (_saldo_finale_tot != ZERO)
set_row(r,"@131g%c", app);
}
else
{
if (app == 'D')
set_row(r,FR("***@8gTOTALE GENERALE@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!"),&_saldo_dare_tot,&_saldo_avere_tot,
&_mov_dare_tot,&_mov_avere_tot,&_saldo_finale_tot);
else
set_row(r,FR("***@8gTOTALE GENERALE@46g!%r@64g%r@80g!%r@98g%r@114g!@132g%r@148g!"),&_saldo_dare_tot,&_saldo_avere_tot,
&_mov_dare_tot,&_mov_avere_tot,&_saldo_finale_tot);
}
}
else
{
if (_stampa_width == 132)
{
set_row(r,FR("@1g****** ********@17gTOTALE GENERALE@46g!%r@64g%r@80g!%r@98g%r@114g!@115g%r"),&_saldo_dare_tot,&_saldo_avere_tot,
&_mov_dare_tot,&_mov_avere_tot,&_saldo_finale_tot);
if (_saldo_finale_tot != ZERO)
set_row(r,"@131g%c", app);
r++;
if (_cdc.empty()) // Non ha senso parlare di saldi iniziali delle commesse
{
if ((_tipo_stampa1 == 1 && _datada == _dataini) || _tipo_stampa1 == 2)
{
//modifica del 21/11/1995
if (_tipo_stampa1 == 2)
set_row(r,FR("@1g****** ********@17gTOTALE CON SALDI INIZIALI@46g!@80g!%r@98g%r@114g!"),&_nuovo_tot_saldo_d,&_nuovo_tot_saldo_a);
else
set_row(r,FR("@1g****** ********@17gTOTALE CON MOVIM. DI APERTURA@46g!@80g!%r@98g%r@114g!"),&_nuovo_tot_saldo_d,&_nuovo_tot_saldo_a);
//fine
}
}
}
else
{
if (app == 'D')
{
set_row(r++,FR("@1g****** ********@17gTOTALE GENERALE@46g!%r@64g%r@80g!%r@98g%r@114g!%r@148g!"),&_saldo_dare_tot,
&_saldo_avere_tot,&_mov_dare_tot,&_mov_avere_tot, &_saldo_finale_tot);
}
else
{
set_row(r++,FR("@1g****** ********@17gTOTALE GENERALE@46g!%r@64g%r@80g!%r@98g%r@114g!@132g%r@148g!"),&_saldo_dare_tot,
&_saldo_avere_tot,&_mov_dare_tot,&_mov_avere_tot, &_saldo_finale_tot);
}
if (_cdc.empty()) // Non ha senso parlare di saldi iniziali delle commesse
{
if ((_tipo_stampa1 == 1 && _datada == _dataini) || _tipo_stampa1 == 2)
{
if (_tipo_stampa1 == 2)
set_row(r,FR("@1g****** ********@17gTOTALE CON SALDI INIZIALI@46g!@80g!%r@98g%r@114g!@148g!"),&_nuovo_tot_saldo_d,&_nuovo_tot_saldo_a);
else
set_row(r,FR("@1g****** ********@17gTOTALE CON MOVIM. DI APERTURA@46g!@80g!%r@98g%r@114g!@148g!"),&_nuovo_tot_saldo_d,&_nuovo_tot_saldo_a);
}
}
}
}
}
void TStampa_bilanci::stampa_totali()
{
const TString16 dep = "";
real pareggio;
real sbilancio = _tot_dare - _tot_avere;
if (sbilancio > ZERO) //_tot_dare > _tot_avere
pareggio = _tot_avere + sbilancio;
else
{
sbilancio = -sbilancio;
pareggio = _tot_dare + sbilancio;
}
if (_prima_volta) //ho finito di stampare le attivita'/passivita'
_prima_volta = FALSE;
else
_seconda_volta = FALSE;
const bool stato_patrimoniale = _seconda_volta; // cosa mi tocca fare
_gc_prec_dare = _gc_corr_avere = "";
_cambiato_conto_1 = TRUE;
_cambiato_conto_2 = TRUE;
set_row(_i++, (const char*)dep);
set_row(_i++, (const char*)dep);
set_row(_i++, (const char*)dep);
set_row(_i++, (const char*)dep);
TString pal; total2string(_tot_dare, pal);
TString bal; total2string(_tot_avere, bal);
set_row(_i++, FR("@39gTOTALE@48g%s@102gTOTALE@113g%s"),
(const char*)pal, (const char*)bal);
TString sb; total2string(sbilancio, sb);
TString pa; total2string(pareggio, pa);
if (_tot_dare > _tot_avere)
{
if (stato_patrimoniale)
set_row(_i++, FR("@79gUTILE DELL'ESERCIZIO IN CORSO@113g%s"), (const char*)sb);
else
set_row(_i++, FR("@77gPERDITA DELL'ESERCIZIO IN CORSO@113g%s"), (const char*)sb);
set_row(_i++, FR("@91gTOTALE A PAREGGIO@113g%s"),(const char*)pa);
}
if (_tot_dare < _tot_avere)
{
if (stato_patrimoniale)
set_row(_i++, FR("@14gPERDITA DELL'ESERCIZIO IN CORSO@48g%s"), (const char*)sb);
else
set_row(_i++, FR("@16gUTILE DELL'ESERCIZIO IN CORSO@48g%s"), (const char*)sb);
set_row(_i++, FR("@28gTOTALE A PAREGGIO@48g%s"),(const char*)pa);
}
_tot_dare = ZERO;
_tot_avere = ZERO;
}
//per i conti patrimoniali stampo anche lo sbilancio es. precedente
void TStampa_bilanci::stampa_totali_uno(const real& r1,const real& r2)
{
real pareggio;
real sbilancio = _tot_dare - r1 - (_tot_avere - r2);
real sbilprec = r2 - r1;
if (_prima_volta) //ho finito di stampare le attivita'/passivita'
_prima_volta = FALSE;
else
_seconda_volta = FALSE;
const bool stato_patrimoniale = _seconda_volta; // cosa mi tocca fare
_gc_prec_dare = _gc_corr_avere = "";
_cambiato_conto_1 = TRUE;
_cambiato_conto_2 = TRUE;
const char* dep = "";
set_row(_i++, (const char*)dep);
set_row(_i++, (const char*)dep);
set_row(_i++, (const char*)dep);
set_row(_i++, (const char*)dep);
TString pal; total2string(_tot_dare, pal);
TString bal; total2string(_tot_avere, bal);
set_row(_i++, FR("@39gTOTALE@48g%s@102gTOTALE@113g%s"),
(const char*)pal, (const char*)bal);
if (sbilancio > ZERO) //ho un utile => va stampato tra le passivita'
{
sbilprec = -sbilprec;
pareggio = _tot_avere + sbilancio + sbilprec;
if (sbilprec != ZERO)
{
TString sb; total2string(sbilprec, sb);
set_row(_i++, FR("@83gSBILANCIO ESERCIZIO PRECEDENTE@113g%s"),
(const char*)sb);
}
TString pal; total2string(sbilancio, pal);
TString bal; total2string(pareggio, bal);
if (stato_patrimoniale)
set_row(_i++, FR("@79gUTILE DELL'ESERCIZIO IN CORSO@113g%s"), (const char*)pal);
else
set_row(_i++, FR("@77gPERDITA DELL'ESERCIZIO IN CORSO@113g%s"), (const char*)pal);
set_row(_i++, FR("@91gTOTALE A PAREGGIO@113g%s"),(const char*)bal);
}
else if (sbilancio < ZERO) //ho una perdita => va stampato tra le attivita'
{
sbilancio = -sbilancio;
pareggio = _tot_dare + sbilancio + sbilprec;
if (sbilprec != ZERO)
{
TString sb; total2string(sbilprec, sb);
set_row(_i++, FR("@15gSBILANCIO ESERCIZIO PRECEDENTE@48g%s"),
(const char*)sb);
}
TString pal; total2string(sbilancio, pal);
TString bal; total2string(pareggio, bal);
if (stato_patrimoniale)
set_row(_i++, FR("@14gPERDITA DELL'ESERCIZIO IN CORSO@48g%s"), (const char*)pal);
else
set_row(_i++, FR("@16gUTILE DELL'ESERCIZIO IN CORSO@48g%s"), (const char*)pal);
set_row(_i++, FR("@28gTOTALE A PAREGGIO@48g%s"),(const char*)bal);
}
else //sbilancio es. in corso == 0
{
sbilprec = -sbilprec;
if (sbilprec > ZERO) //va stampato sotto le passivita'
{
TString pal; total2string(sbilprec, pal);
pareggio = _tot_avere + sbilprec;
TString bal; total2string(pareggio, bal);
set_row(_i++, FR("@83gSBILANCIO ESERCIZIO PRECEDENTE@113g%s"),
(const char*)pal);
set_row(_i++, FR("@96gTOTALE A PAREGGIO@113g%s"), (const char*)bal);
}
else if (sbilprec < ZERO)
{
sbilprec = -sbilprec;
pareggio = _tot_dare + sbilprec;
TString pal; total2string(sbilprec, pal);
TString bal; total2string(pareggio, bal);
set_row(_i++, FR("@15gSBILANCIO ESERCIZIO PRECEDENTE@48g%s"), (const char*)pal);
set_row(_i++, FR("@28gTOTALE A PAREGGIO@48g%s"), (const char*)bal);
}
}
_tot_dare = ZERO;
_tot_avere = ZERO;
}
// Guy: stampa la prima colonna del bilancio di raffronto
void TStampa_bilanci::stampa_prima_colonna(int g, int c, long s,
const char* desc, const real& saldo)
{
char dep = '*';
if (_codici) //sono stampate solo le descrizioni dei conti
{
if (!_totali)
{
if (c != 0 && s == 0)
set_row(_i, "%-.44s @44g @49g%r @68g%c", desc, &saldo, dep);
else
set_row(_i, "%-.48s @49g%r @68g%c", desc, &saldo, dep);
}
else if ( !(c == 0 && s == 0) ) //se cioe' non e' un gruppo
{
if (s == 0) //se e' un conto
set_row(_i, "%-.44s @44g @49g%r @68g%c", desc, &saldo, dep);
else
set_row(_i, "%-.48s @49g%r @68g%c", desc, &saldo, dep);
}
}
else
{
if (_totali && c == 0 && s == 0l)
return;
else if ( c == 0 && s == 0l )
{
set_row(_i, "%3d ", g);
set_row(_i, "@15g%-.31s @49g%r @68g%c", desc, &saldo, dep);
}
else if (s == 0l)
{
set_row(_i, "%3d ", g);
set_row(_i, "%3d ", c);
set_row(_i, "@15g%-.31s @49g%r @68g%c", desc, &saldo, dep);
}
else
{
set_row(_i, "%3d ", g);
set_row(_i, "%3d ", c);
set_row(_i, "%6ld ", s);
set_row(_i, "@15g%-.31s @49g%r @68g%c", desc, &saldo, dep);
}
}
}
// Guy: stampa la seconda colonna del bilancio di raffronto
void TStampa_bilanci::stampa_seconda_colonna(int g, int c, long s,
const char* desc, const real& saldo)
{
char dep = '*';
if (_codici) //sono stampate solo le descrizioni dei conti
{
if (!_totali)
{
set_row(_i, "@68g%c@69g%-.47s @114g%r", dep, desc, &saldo);
}
else
if ( !(c == 0 && s == 0) )
{
set_row(_i, "@68g%c @69g%-.47s @114g%r", dep, desc, &saldo);
}
}
else
{
if (_totali && c == 0 && s == 0l)
return;
else if ( c == 0 && s == 0l )
{
set_row(_i, "@68g%c@69g%3d ", dep, g);
set_row(_i, "@84g%-.30s @114g%r", desc, &saldo);
}
else if (s == 0l)
{
set_row(_i, "@68g%c@69g%3d ", dep, g);
set_row(_i, "%3d", c);
set_row(_i, "@84g%-.30s @114g%r", desc, &saldo);
}
else
{
set_row(_i, "@68g%c@69g%3d ", dep, g);
set_row(_i, "%3d ", c);
set_row(_i, "%6ld ",s);
set_row(_i, "@84g%-.30s @114g%r", desc, &saldo);
}
}
}
print_action TStampa_bilanci::postprocess_page(int file, int counter)
{
if (_bilancio == 1)
{
if ( _eof1 && _eof2 && _eof3 && _eof4 && _eof5 && _eof6 && _salto_pagina1 )
return NEXT_PAGE;
}
else //bilancio di verifica
{
if (_verifica == 3)
{
if (_buff == NULL)
return NEXT_PAGE;
}
else if (_eof1)
return NEXT_PAGE;
}
return REPEAT_PAGE;
}
TDate TStampa_bilanci::UltimaData(int g, int c, long s, int anno)
{
TDate uldata;
TLocalisamfile saldi(LF_SALDI);
saldi.zero();
if (_annoes != 0)
saldi.put(SLD_ANNOES, anno);
saldi.put(SLD_FLSCA, FALSE); // W96SALDI del 05-06-96
saldi.put(SLD_GRUPPO,g);
if (c != 0)
saldi.put(SLD_CONTO, c);
if (s != 0)
saldi.put(SLD_SOTTOCONTO, s);
saldi.read();
if (saldi.bad())
saldi.zero();
uldata = saldi.get(SLD_DATAULMOV);
return uldata;
}
// Non ho potuto usare quella di TConto!!! Chiedere a me!
// Guy: E tu chi sei?
const char* TStampa_bilanci::DescrizioneConto(int g, int c, long s, char tipocf)
{
static TString80 ragsoc;
const char* desc = NULL;
TString80 key; key << g;
if (c != 0)
key << "|" << c ;
if (s != 0)
key << "|" << s;
const TRectype & pconti = cache().get(LF_PCON, key);
if (!pconti.empty())
_tmp = pconti.get(PCN_DESCR);
else
{
key.format("%c|%ld", tipocf, s);
const TRectype & clifo = cache().get(LF_CLIFO, key);
if (!clifo.empty())
{
char tipoa = clifo.get_char("TIPOAPER");
if (tipoa == 'F') //persona fisica
{
TString80 cognome, nome;
ragsoc = clifo.get("RAGSOC");
cognome = ragsoc.mid(0,30);
nome = ragsoc.mid(30,20);
cognome.trim(); nome.trim();
ragsoc = cognome;
ragsoc << " " << nome;
desc = ragsoc;
}
else
desc = clifo.get("RAGSOC");
_tmp = desc;
}
else
_tmp = "";
}
return _tmp;
}
bool TStampa_bilanci::user_create()
{
open_files(LF_TAB, 0);
_stampa_width = 132;
_rel = new TRelation(LF_CLIFO);
_cur = new TCursor (_rel,"",3);
_mov = new TLocalisamfile(LF_MOV);
_rmov = new TLocalisamfile(LF_RMOV);
_clifo = new TLocalisamfile(LF_CLIFO);
_com = new TLocalisamfile(LF_COMUNI);
_pcn = new TLocalisamfile(LF_PCON);
_saldi = new TLocalisamfile(LF_SALDI);
_nditte = new TLocalisamfile(LF_NDITTE);
_anag = new TLocalisamfile(LF_ANAG);
_caus = new TLocalisamfile(LF_CAUSALI);
_d = new TParagraph_string("",29);
_sort = NULL;
_tmp_saldi_att = NULL;
_tmp_saldi_pass = NULL;
_tmp_saldi_costi = NULL;
_tmp_saldi_ricavi = NULL;
_tmp_saldi_conti_uno = NULL;
_tmp_saldi_conti_due = NULL;
return TRUE;
}
bool TStampa_bilanci::user_destroy()
{
delete _rel;
delete _cur;
delete _com;
delete _pcn;
delete _mov;
delete _rmov;
delete _clifo;
delete _saldi;
delete _nditte;
delete _anag;
delete _caus;
delete _d;
if (_tmp_saldi_att) delete _tmp_saldi_att;
if (_tmp_saldi_pass) delete _tmp_saldi_pass;
if (_tmp_saldi_costi) delete _tmp_saldi_costi;
if (_tmp_saldi_ricavi) delete _tmp_saldi_ricavi;
if (_tmp_saldi_conti_uno) delete _tmp_saldi_conti_uno;
if (_tmp_saldi_conti_due) delete _tmp_saldi_conti_due;
return TRUE;
}
void TStampa_bilanci::leggi_pcon()
{
TRelation rel(LF_PCON);
TCursor cur(&rel);
const TRectype& pconti = rel.curr();
const long items = cur.items();
cur.freeze();
TToken_string gc(10);
for (cur = 0L; cur.pos() < items; ++cur)
{
const int gruppo = pconti.get_int(PCN_GRUPPO);
const int conto = pconti.get_int(PCN_CONTO);
const long sottoconto = pconti.get_long(PCN_SOTTOCONTO);
if ( (sottoconto == 0l) && (conto != 0) ) //si tratta di un conto
{
const char tipocf = pconti.get_char(PCN_TMCF);
if ( tipocf == 'C' && (_situazione.empty() || _situazione == "C"))
{
gc.add(gruppo,0);
gc.add(conto,1);
_clienti.add(gc);
}
else if ( tipocf == 'F' && (_situazione.empty() || _situazione == "F"))
{
gc.add(gruppo,0);
gc.add(conto,1);
_fornitori.add(gc);
}
}
}
}
void TStampa_bilanci::stampa_un_bilancio(const TMask& m)
{
_prog = NULL;
if (_bilancio == 1) //bilancio a sezioni contrapposte
{
printer().footerlen(3);
_prog = new TProgind(_pcn->items(),TR("Elaborazione in corso..."),FALSE);
_totali = m.get_bool(F_TOTALI);
_codici = m.get_bool(F_CODICI);
_saldo = m.get_bool(F_SALDO);
_tipo_stampa = m.get_int(F_STAMPA);
if (_tipo_stampa == 1)
{
_datalim = m.get(F_DATALIM);
_print_exercise = TRUE;
if (_annoes == 0)
{
_print_exercise = FALSE;
_annoes = date2esc(_datalim);
}
if (_annoes != 0)
_dataini = InizioEsercizio(_annoes);
else
_dataini = _inizioEs;
}
bil_sez_contr();
}
else //bilancio di verifica (tipo 1,2,3)
{
printer().footerlen(5);
_stampa_width = (m.get_int(F_MODULO) == 1) ? 132 : 148; //perche' questo e' in realta' il margine dx (vedi es. di stampa AS/400)
_verifica = m.get_int(F_VERIFICA); //tipo di bilancio di verifica da stampare
if ( (_verifica == 1)||(_verifica == 2) )
_prog = new TProgind(_pcn->items(),TR("Elaborazione in corso..."),FALSE);
_tipo_stampa1 = m.get_int(F_STAMPA1);
if (_tipo_stampa1 == 1)
{
if (_annoes != 0)
_dataini = InizioEsercizio(_annoes);
else
_dataini = _inizioEs;
_datada = m.get(F_DATADA);
_dataa = m.get(F_DATAA);
}
if ((_verifica == 1)||(_verifica == 2)) //bilancio di verifica:1bilancio,2saldi mastro
{
_stampav = atoi(m.get(F_STAMPAV));
bil_verifica();
}
else
{
_situazione = m.get(F_SITUAZIONE);
_stampac = atoi(m.get(F_STAMPAC));
_ordinamento = atoi(m.get(F_ORDINAMENTO));
if (_situazione.not_empty())
_cur->setfilter(format("TIPOCF=\"%s\"",(const char*)_situazione));
else
_cur->setfilter("");
_clienti.destroy();
_fornitori.destroy();
leggi_pcon();
crea_sort_clifo(); // Crea la sua _prog
_sort->endsort();
}
}
if (_prog)
delete _prog;
print();
}
bool TStampa_bilanci::set_print(int)
{
TMask m ("cg1500a");
m.set_handler (F_VERIFICA, verifica_handler);
m.set_handler (F_BILANCIO, mask_bilancio);
m.set_handler (F_STAMPA1, mask_bilancio);
m.set_handler (F_STAMPA, mask_bilancio);
m.set_handler (F_DATALIM, mask_datalim);
m.set_handler (F_DATADA, mask_date);
m.set_handler (F_DATAA, mask_date);
m.set_handler (F_ANNO, mask_anno);
m.set_handler (F_DACDC, cdc_handler);
m.set_handler (F_ACDC, cdc_handler);
while (m.run() == K_ENTER)
{
_annoes = m.get_int(F_ANNO);
_bilancio = m.get_int(F_BILANCIO);
_data = m.get(F_DATASTAMPA);
_stampa_mov_prov = m.get_int(F_STAMPAMPROV);
_quadratura = m.get_bool(F_QUADRATURA);
_hide_clifo = m.get_bool(F_HIDE_CLIFO);
_noseparator = m.get_bool(F_SEPARATOR);
//qui getti le terne dei 2 conti da mettere in bill_from e bill_to con un metodo dei TBill
_bill_from.get(m, F_DA_GRUPPO, F_DA_CONTO, F_DA_SOTTOCONTO);
_bill_to.get(m, F_A_GRUPPO, F_A_CONTO, F_A_SOTTOCONTO);
//se non e' stato riempito il gruppo TO, si mette di default il max del gr/co/so
if (_bill_to.gruppo() == 0)
_bill_to.set(999, 999, 999999L);
else
{ //se invece il gruppo c'e' ma il conto no...
if (_bill_to.conto() == 0)
_bill_to.set(_bill_to.gruppo(), 999, 999999L); //il gruppo e' quello selezionato
else
{
if (_bill_to.sottoconto() == 0) //se mancasse solo il sottoconto..
_bill_to.set(_bill_to.gruppo(), _bill_to.conto(), 999999L);
}
}
if (m.field(F_DACDC).active() && (m.get(F_DACDC).not_empty() || m.get(F_ACDC).not_empty()))
{
TRelation cdcrel("CMS");
TRectype da_cdc(cdcrel.curr()), a_cdc(cdcrel.curr());
da_cdc.put("CODTAB", m.get(F_DACDC));
a_cdc.put("CODTAB", m.get(F_ACDC));
TCursor cdccur(&cdcrel, "", 1, &da_cdc, &a_cdc);
const TRecnotype cdc_items = cdccur.items();
cdccur.freeze();
TRelation fscrel("FSC");
TRectype da_fsc(fscrel.curr()), a_fsc(fscrel.curr());
da_fsc.put("CODTAB", m.get(F_DAFSC));
a_fsc.put("CODTAB", m.get(F_AFSC));
TCursor fsccur(&fscrel, "", 1, &da_fsc, &a_fsc);
const TRecnotype fsc_items = fsccur.items();
fsccur.freeze();
for (cdccur = 0L; cdccur.pos() < cdc_items; ++cdccur)
{
_cdc = cdccur.curr().get("CODTAB");
if (!da_fsc.empty() || !a_fsc.empty())
{
for (fsccur = 0L; fsccur.pos() < fsc_items; ++fsccur)
{
_fsc = fsccur.curr().get("CODTAB");
stampa_un_bilancio(m);
}
}
else
{
_fsc.cut(0);
stampa_un_bilancio(m);
}
}
}
else
{
_cdc.cut(0); _fsc.cut(0);
stampa_un_bilancio(m);
}
}
return FALSE;
}
TRectype& look_com (const char* cod, TLocalisamfile *comuni)
{
comuni->zero();
comuni->put(COM_COM, cod);
comuni->read();
if (comuni->bad())
comuni->zero();
return comuni->curr();
}
void TStampa_bilanci::get_dati_ditta()
{
TLocalisamfile nditte(LF_NDITTE);
TLocalisamfile anag(LF_ANAG);
TString codanagr;
TString tipoa;
nditte.zero();
nditte.put(NDT_CODDITTA, get_firm());
nditte.read();
if (nditte.bad()) nditte.zero();
codanagr = nditte.get(NDT_CODANAGR);
tipoa = nditte.get(NDT_TIPOA);
_ragsoc = nditte.get(NDT_RAGSOC);
anag.setkey(1);
anag.zero();
anag.put (ANA_TIPOA, tipoa);
anag.put (ANA_CODANAGR, codanagr);
anag.read();
if (anag.bad()) anag.zero();
_cofi = anag.get(ANA_COFI);
_paiva = anag.get(ANA_PAIV);
_comunefis = anag.get(ANA_COMRF);
if (_comunefis.empty())
_comunefis = anag.get(ANA_COMRES);
TRectype dep = look_com (_comunefis, _com);
_comunefis = dep.get(COM_DENCOM);
_provfis = dep.get(COM_PROVCOM);
_cap = dep.get(COM_CAPCOM);
if (_comunefis.empty())
{
_viafis = anag.get(ANA_INDRF);
_viafis.rtrim();
_viafis << " " << anag.get (ANA_CIVRF);
}
else
{
_viafis = anag.get(ANA_INDRES);
_viafis.rtrim();
_viafis << " " << anag.get (ANA_CIVRES);
}
}
int TStampa_bilanci::stampa_intestazione_ditta()
{
int r = 1;
TString codice_ditta;
TString riga(_stampa_width);
get_dati_ditta();
codice_ditta << get_firm();
set_header (r++, "%s %s %s %s %s %s %s", TR("Ditta"), (const char*)codice_ditta,
(const char*)_ragsoc, (const char*)_viafis,
(const char*)_cap, (const char*)_comunefis,
(const char*)_provfis);
printer().setdate(_data);
riga = TR("Data") ; riga << " @> " << TR("Pag.") << " @#";
riga.right_just(_stampa_width-10);
//_stampa_mov_provv(1=normale,2=globale,3=solo provvisori)
const char* tipoprovv = "";
if (_stampa_mov_prov == 2)
tipoprovv = TR("GLOBALE");
if (_stampa_mov_prov == 3)
tipoprovv = TR("PROVVISORIO");
//l'uso della overwrite e' una vera vaccata!
riga.overwrite (format("%s %s %s %s", TR("Partita iva"), (const char*)_paiva, TR("Codice fiscale"), (const char*)_cofi));
riga.overwrite (tipoprovv, 85);
set_header (r++, "%s", (const char*) riga);
return r;
}
void TStampa_bilanci::header_cdc(int& r)
{
if (_cdc.not_empty())
{
const TString& desc_cdc = cache().get("CMS", _cdc, "S0");
if (_fsc.not_empty())
{
const TString& desc_fsc = cache().get("FSC", _fsc, "S0");
set_header(r++, "@b%s %s %s - %s %s %s", TR("Commessa"),
(const char*)_cdc, (const char*)desc_cdc, TR("Fase"),
(const char*)_fsc, (const char*)desc_fsc);
}
else
set_header(r++, "@b%s %s %s", TR("Commessa"), (const char*)_cdc, (const char*)desc_cdc);
}
}
void TStampa_bilanci::preprocess_header()
{
int r;
reset_header();
r = stampa_intestazione_ditta();
if (_bilancio == 1) //bilancio a sezioni contrapposte
{
TString riga (132);
TDate data_da;
TString data;
TString data_lim = _datalim.string();
set_header(r, TR("STAMPA BILANCIO A SEZIONI CONTRAPPOSTE"));
if (_tipo_stampa == 1)
{
data_da = _dataini.string();
data = _datalim.string();
set_header(r,"@41g%s %s %s %s", TR("dalla data"), (const char*) data_da, TR("alla data"),
(const char*) data);
}
else if (_tipo_stampa == 2)
set_header(r,FR("@41gall'ultima immissione Es. %d"), _annoes);
//modifica del 20/04/1995
if (_print_exercise)
{
const TString16 d1(InizioEsercizio(_annoes).string());
const TString16 d2(FineEsercizio(_annoes).string());
set_header(r, "@84g%s %s %s", TR("Esercizio"), (const char*)d1, (const char*)d2); /**/
}
r++;
header_cdc(r);
riga.fill('_');
set_header(r, (const char*)riga);
r++;
riga = "";
set_header(r, (const char*)riga);
}
else // bilancio di verifica
{
TString riga (_stampa_width);
TString16 datada = _datada.string();
TString16 dataa = _dataa.string();
if (_verifica == 1)
set_header(r, TR("STAMPA BILANCIO DI VERIFICA"));
else if (_verifica == 2)
set_header(r, TR("STAMPA SALDI DI MASTRO"));
else
{
if (_situazione == "C")
set_header(r, TR("SITUAZIONE CONTABILE CLIENTI"));
else if (_situazione == "F")
set_header(r, TR("SITUAZIONE CONTABILE FORNITORI"));
else set_header(r,TR("SITUAZIONE CLIENTI/FORNITORI"));
}
if (_tipo_stampa1 == 1)
{
set_header(r,"@30g%s %s %s %s", TR("dalla data"), (const char*) datada, TR("alla data"),
(const char*) dataa);
//modifica del 20/04/1995
if (_annoes != 0) //se l'anno e' 0 non si considera la competenza
{
TString16 d1(InizioEsercizio(_annoes).string());
TString16 d2(FineEsercizio(_annoes).string());
set_header(r,"@74g%s %s %s", TR("Esercizio"), (const char*)d1, (const char*)d2); /**/
}
}
else if (_tipo_stampa1 == 2)
{
set_header(r,FR("@36gall'ultima immissione Es. %d"), _annoes);
//modifica del 20/04/1995
TString16 d1(InizioEsercizio(_annoes).string());
TString16 d2(FineEsercizio(_annoes).string());
set_header(r,"@72g%s %s %s", TR("Esercizio"), (const char*)d1, (const char*)d2); /**/
}
if ( (_verifica == 1)||(_verifica == 2) )
{
if (_stampav == 1)
set_header(r, "@107g%s", TR("Tutti i conti movimentati"));
else if (_stampav == 2)
set_header(r, "@107g%s", TR("Conti con saldo <> 0"));
else
set_header(r, "@107g%s", TR("Tutti i conti"));
}
else
{
if (_stampac == 1)
set_header(r, "@107g%s", TR("Tutti i conti movimentati"));
else
set_header(r, "@107g%s", TR("Conti con saldo <> 0"));
}
r++;
header_cdc(r);
riga.fill('_');
set_header(r, (const char*)riga);
r++;
TString h("@7g!@46g!@55g");
if ( ((_datada == _dataini)&&(_tipo_stampa1 == 1))||(_tipo_stampa1 != 1) )
{
if (_tipo_stampa1 == 1 && _datada == _dataini)
h << TR("MOVIMENTI DI APERTURA");
else
h << TR(" SALDO INIZIALE");
}
else
if (_tipo_stampa1 == 1)
h << TR("PROGRESSIVI PRECEDENTI");
h << "@80g!@88g";
h << TR("MOVIMENTI DEL PERIODO");
set_header(r, h);
if ( (_verifica == 1)||(_verifica == 3) )
set_header(r,"@16g!");
set_header(r,"@114g!");
if (_stampa_width != 132)
{
h = "@129g" ;
h << TR("SALDO");
h << "@148g!";
set_header(r, h);
}
r++;
if ( (_verifica == 1)||(_verifica == 3) )
{
set_header(r,FR("@2gcod. ! ultima !@46g!@47g%.67s@80g!@83g@114g!"),(const char*)riga);
if (_stampa_width == 132)
set_header(r,FR("@121gSALDO"));
else
set_header(r,"%.33s@148g!",(const char*)riga);
r++;
set_header(r,FR("@2gconto! data ! denominazione@46g!@53gDare@63g!@69gAvere@80g!@87gDare@97g!@103gAvere@114g!"));
if (_stampa_width != 132)
set_header(r,FR("@121gDare@131g!@137gAvere@148g!"));
r++;
}
else
{
set_header(r,FR("@2gcod. !@46g!@47g%.67s@80g!@83g@114g!"),(const char*)riga);
if (_stampa_width == 132)
set_header(r,FR("@121gSALDO"));
else
set_header(r,"%.33s@148g!",(const char*)riga);
r++;
set_header(r,FR("@1gmastro!descrizione@46g!@53gDare@63g!@69gAvere@80g!@87gDare@97g!@103gAvere@114g!"));
if (_stampa_width != 132)
set_header(r, FR("@121gDare@131g!@137gAvere@148g!"));
r++;
}
set_header(r, (const char*)riga);
if (_stampa_width != 132)
set_header(r,"@148g!");
}
}
int cg1500 (int argc, char* argv[])
{
TStampa_bilanci a;
a.run(argc, argv, TR("Stampa bilanci"));
return 0;
}