/*
- * Copyright (C) 2015 Thadeu Lima de Souza Cascardo <cascardo@minaslivre.org>
+ * Copyright (C) 2015-2016 Thadeu Lima de Souza Cascardo <cascardo@minaslivre.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
fprintf(f, "1"); /* Tipo NI: Pessoa Física (1) */
fprintf(f, "130"); /* Versão IRPF */
fprintf(f, "%-60.60s", dec->nome);
- fprintf(f, "%s", dec->contribuinte.uf);
+ fprintf(f, "%-2.2s", dec->contribuinte.uf ?: "");
fprintf(f, "%s", "0000000000"); /* FIXME: hash */
fprintf(f, "1"); /* TODO: certificavel */
- fprintf(f, "%-8.8s", dec->contribuinte.dn);
+ fprintf(f, "%-8.8s", dec->contribuinte.dn ?: "");
fprintf(f, "%s", dec->tipo == COMPLETA ? "S" : "N");
/* TODO: resultado imposto, 1 - pagar, 2 - restituicao */
fprintf(f, "%s", dec->restituicao ? "2" : (dec->pagar ? "1" : "0"));
* outros. */
fprintf(f, "%d", dec->retido ? 1 : 0);
fprintf(f, "0"); /* TODO: mudanca endereco */
- fprintf(f, "%s", dec->contribuinte.cep);
+ fprintf(f, "%-8.8s", dec->contribuinte.cep ?: "");
fprintf(f, "0"); /* TODO: debito 1a quota */
fprintf(f, "%-3.3s", dec->banco ? : "000"); /* no banco */
fprintf(f, "%-4.4s", dec->agencia ? : "0000"); /* agencia */
fprintf(f, "%03d", dec->obrigatoria); /* criterio obrigatoriedade */
fprintf(f, "%013lld", totais_get(dec, "RENDPJ")); /* Total tributavel */
/* CNPJ previdencia */
- fprintf(f, "%-14.14s", pagamento_cnpj_ordenado(dec, 36, 0));
+ fprintf(f, "%-14.14s", inss_cnpj_ordenado(dec, 0));
/* CNPJ previdencia 2 */
- fprintf(f, "%-14.14s", pagamento_cnpj_ordenado(dec, 36, 1));
+ fprintf(f, "%-14.14s", inss_cnpj_ordenado(dec, 1));
/* Total isentos */
fprintf(f, "%013lld", totais_get(dec, "ISENTOS"));
/* Total exclusivo */
fprintf(f, "%-15.15s", dec->contribuinte.tipo_logradouro);
fprintf(f, "%-40.40s", dec->contribuinte.logradouro);
fprintf(f, "%-6.6s", dec->contribuinte.numero);
- fprintf(f, "%-21.21s", dec->contribuinte.complemento);
+ fprintf(f, "%-21.21s", dec->contribuinte.complemento ?: "");
fprintf(f, "%-19.19s", dec->contribuinte.bairro);
fprintf(f, "%-9.9s", dec->contribuinte.cep);
fprintf(f, "%04d", dec->contribuinte.cd_municipio);
fprintf(f, "%-100.100s", ""); /* TODO: FILLER3 */
fprintf(f, "%-4.4s", ""); /* TODO: FILLER1 */
fprintf(f, "%-8.8s", ""); /* TODO: FILLER2 */
- fprintf(f, "%-4.4s", dec->contribuinte.ddd);
- fprintf(f, "%-9.9s", dec->contribuinte.telefone);
+ fprintf(f, "%-4.4s", dec->contribuinte.ddd ?: "");
+ fprintf(f, "%-9.9s", dec->contribuinte.telefone ?: "");
fprintf(f, "%-8.8s", dec->contribuinte.dn);
- fprintf(f, "%-13.13s", dec->contribuinte.titulo_eleitor);
+ fprintf(f, "%-13.13s", dec->contribuinte.titulo_eleitor ?: "");
fprintf(f, "%03d", dec->contribuinte.ocupacao_principal);
fprintf(f, "%02d", dec->contribuinte.natureza_ocupacao);
fprintf(f, "%d", dec->pagar ? 1 : 0); /* TODO/FIXME: qnt quotas */
fprintf(f, "%-15.15s", dec->contribuinte.tipo_logradouro);
fprintf(f, "%-40.40s", dec->contribuinte.logradouro);
fprintf(f, "%-6.6s", dec->contribuinte.numero);
- fprintf(f, "%-21.21s", dec->contribuinte.complemento);
+ fprintf(f, "%-21.21s", dec->contribuinte.complemento ?: "");
fprintf(f, "%-19.19s", dec->contribuinte.bairro);
fprintf(f, "%-9.9s", dec->contribuinte.cep);
fprintf(f, "%04d", dec->contribuinte.cd_municipio);
fprintf(f, "%-100.100s", ""); /* FILLER */
fprintf(f, "%-4.4s", ""); /* FILLER */
fprintf(f, "%-8.8s", ""); /* FILLER */
- fprintf(f, "%-4.4s", dec->contribuinte.ddd);
- fprintf(f, "%-9.9s", dec->contribuinte.telefone);
+ fprintf(f, "%-4.4s", dec->contribuinte.ddd ?: "");
+ fprintf(f, "%-9.9s", dec->contribuinte.telefone ?: "");
fprintf(f, "%s", dec->retifica ? "S" : "N"); /* Retificadora */
fprintf(f, "%013lld", totais_get(dec, "RENDPJ")); /* Total tributavel */
fprintf(f, "%013lld", dec->devido); /* Imposto devido */
W(gera_rendimento);
}
- W(gera_isentos);
- W(gera_exclusivos);
+ if (totais_get(dec, "ISENTOS"))
+ W(gera_isentos);
+ if (totais_get(dec, "EXCLUSIVOS"))
+ W(gera_exclusivos);
for (i = 0; (dependente = list_get(dec->dependentes, i)); i++) {
W(gera_dependente);
W(gera_bem);
}
- W(gera_conjuge);
+ if (dec->conjuge.cpf)
+ W(gera_conjuge);
/* Rendimentos isentos e com tributação exclusiva */
/* Registros 82 a 89, e 92 a 99 */
{
if (argc != 2)
return -EINVAL;
+ if (dec->ano != 2015)
+ return -EINVAL;
return gera(dec, args[1]);
}