#include "isento.h"
#include "pagamento.h"
#include "bem.h"
+#include "dependente.h"
#include "totais.h"
#include "sistema.h"
fprintf(f, "%-9.9s", sistema_get_jvm_versao(dec));
fprintf(f, "%-10.10s", ""); /* TODO: última declaração transmitida (pode ser vazio?) */
fprintf(f, "%04d", dec->contribuinte.cd_municipio);
- fprintf(f, " "); /* TODO: CPF conjuge */
+ fprintf(f, "%-11.11s", dec->conjuge.cpf ? : ""); /* TODO: CPF conjuge */
fprintf(f, "%d", dec->obrigatoria ? 1 : 0); /* obrigatoria entrega */
fprintf(f, "%013lld", dec->devido); /* imposto devido, carne-leao, complementar dos dependentes */
fprintf(f, "%-10.10s", dec->recibo ?: ""); /* recibo ex. anterior */
fprintf(f, "%013lld", 0); /* TODO: rendimentos PF ext. depend. */
fprintf(f, "%013lld", 0); /* TODO: carnê-leão PF? */
fprintf(f, "%013lld", 0); /* TODO: carnê-leão dependentes */
- fprintf(f, "%013lld", 0); /* TODO: dedução dependentes */
+ fprintf(f, "%013lld", totais_get(dec, "DEPENDENTES")); /* TODO: dedução dependentes */
fprintf(f, "%013lld", 0); /* TODO: previdência RRA */
fprintf(f, "%013lld", 0); /* TODO: previdência RRA dependentes */
fprintf(f, "%013lld", 0); /* TODO: pensão RRA */
fprintf(f, "%013lld", 0); /* TODO: valor quota */
fprintf(f, "%013lld", totais_get(dec, "ISENTOS")); /* rendimentos isentos */
fprintf(f, "%013lld", totais_get(dec, "EXCLUSIVOS")); /* rendimentos tributação exclusiva */
- fprintf(f, "%013lld", 0); /* TODO: conjuge */
+ fprintf(f, "%013lld", dec->conjuge.total); /* TODO: conjuge */
fprintf(f, "%013lld", 0); /* TODO: rendimento PJ dependente */
fprintf(f, "%013lld", 0); /* TODO: imposto retido dependente */
fprintf(f, "%013lld", 0); /* TODO: imposto ganhos de capital */
fprintf(f, "%013lld", totais_get(dec, "DECIMOTERCEIRO"));
fprintf(f, "%013lld", 0); /* TODO: ganho de capital */
fprintf(f, "%013lld", 0); /* TODO: ganho líquido renda variável */
- fprintf(f, "%013lld", 0); /* TODO: aplicações financeiras */
+ fprintf(f, "%013lld", totais_get(dec, "APLICACOES")); /* TODO: aplicações financeiras */
fprintf(f, "%013lld", 0); /* TODO: outros */
fprintf(f, "%-60.60s", ""); /* FILLER1 */
fprintf(f, "%013lld", 0); /* TODO: ganhos de capital alienação de bens */
fprintf(f, "%013lld", totais_get(dec, "PLR"));
}
+static void gera_conjuge(struct declaracao *dec, FILE *f)
+{
+ fprintf(f, "29");
+ fprintf(f, "%-11.11s", dec->cpf);
+ fprintf(f, "%-11.11s", dec->conjuge.cpf);
+ fprintf(f, "%013lld", dec->conjuge.base);
+ fprintf(f, "%013lld", dec->conjuge.imposto);
+ fprintf(f, "%013lld", dec->conjuge.isento);
+ fprintf(f, "%013lld", dec->conjuge.exclusivo);
+ fprintf(f, "%013lld", dec->conjuge.rendpj_exigibilidade_suspensa);
+ fprintf(f, "%013lld", dec->conjuge.total);
+ fprintf(f, "%c", dec->conjuge.entregou ? 'S' : 'N');
+}
+
static void gera_trailler(struct declaracao *dec, FILE *f)
{
int i;
gera_isento(dec, f, 98);
}
+static void gera_aplicacoes(struct declaracao *dec, FILE *f)
+{
+ gera_isento(dec, f, 99);
+}
+
+static void gera_dependente(struct declaracao *dec, FILE *f)
+{
+ struct dependente *d;
+ d = list_get(dec->dependentes, dec->linhas[25]);
+
+ fprintf(f, "25");
+ fprintf(f, "%s", dec->cpf);
+ fprintf(f, "%05d", dec->linhas[25] + 1);
+ fprintf(f, "%02d", d->codigo);
+ fprintf(f, "%-60.60s", d->nome);
+ fprintf(f, "%-8.8s", d->dn);
+ fprintf(f, "%-11.11s", d->cpf);
+ /* TODO: Indicador de saída */
+ fprintf(f, " ");
+}
+
static void gera_bem(struct declaracao *dec, FILE *f)
{
struct bem *b;
struct isento *isento;
struct pagamento *pagamento;
struct bem *bem;
+ struct dependente *dependente;
struct list *linhas;
char *buf;
W(gera_isentos);
W(gera_exclusivos);
+ for (i = 0; (dependente = list_get(dec->dependentes, i)); i++) {
+ W(gera_dependente);
+ }
for (i = 0; (pagamento = list_get(dec->pagamentos, i)); i++) {
W(gera_pagamento);
}
W(gera_bem);
}
+ W(gera_conjuge);
+
/* Rendimentos isentos e com tributação exclusiva */
/* Registros 82 a 89, e 92 a 99 */
#define IW(fn, codigo) \
}
IW(gera_plr, 96);
IW(gera_poupanca, 98);
+ IW(gera_aplicacoes, 99);
W(gera_trailler);
W(gera_reciboheader);