X-Git-Url: http://git.cascardo.eti.br/?p=cascardo%2Fdeclara.git;a=blobdiff_plain;f=lib%2Fgera.c;h=214037c95883a87463efcc43626e865afe23d957;hp=a8c6f10c6e73946e2aaceff78f92caee6695afcd;hb=58291e53443f45fa03f600617eeb3bf93a234272;hpb=63ed5bdac6c578de89ba3937863d56a5a9bffeda diff --git a/lib/gera.c b/lib/gera.c index a8c6f10..214037c 100644 --- a/lib/gera.c +++ b/lib/gera.c @@ -33,6 +33,7 @@ #include "totais.h" #include "sistema.h" #include "ano.h" +#include "attr.h" static void gera_header(struct declaracao *dec, FILE *f) { @@ -51,6 +52,8 @@ static void gera_header(struct declaracao *dec, FILE *f) fprintf(f, "2800"); /* Código */ else if (dec->ano == 2019) fprintf(f, "2900"); /* Código */ + else if (dec->ano == 2020) + fprintf(f, "3000"); fprintf(f, "%s", dec->retifica ? "1" : "0"); /* Retificadora */ fprintf(f, "%s", dec->cpf); /* CPF: 11 dígitos */ fprintf(f, " "); /* Filler */ @@ -60,11 +63,13 @@ static void gera_header(struct declaracao *dec, FILE *f) else if (dec->ano == 2016) fprintf(f, "110"); /* Versão IRPF */ else if (dec->ano == 2017) - fprintf(f, "110"); /* Versão IRPF */ + fprintf(f, "130"); /* Versão IRPF */ else if (dec->ano == 2018) fprintf(f, "160"); /* Versão IRPF */ else if (dec->ano == 2019) fprintf(f, "150"); /* Versão IRPF */ + else if (dec->ano == 2020) + fprintf(f, "180"); /* Versão IRPF */ fprintf(f, "%-60.60s", dec->nome); fprintf(f, "%-2.2s", dec->contribuinte.uf ?: ""); fprintf(f, "%s", "0000000000"); /* FIXME: hash */ @@ -111,11 +116,12 @@ static void gera_header(struct declaracao *dec, FILE *f) fprintf(f, " "); /* RRA4 */ fprintf(f, "%-11.11s", ""); /* CPF RRA4 */ fprintf(f, "0000000000000"); /* TODO: Doacao ECA */ + fprintf(f, "0000000000000"); /* TODO: Doacao Idoso */ fprintf(f, "%-14.14s", rendimento_cnpj_ordenado(dec, 0)); /* CNPJ maior */ fprintf(f, "%-14.14s", rendimento_cnpj_ordenado(dec, 1)); /* CNPJ maior 2 */ fprintf(f, "%-14.14s", rendimento_cnpj_ordenado(dec, 2)); /* CNPJ maior 3 */ fprintf(f, "%-14.14s", rendimento_cnpj_ordenado(dec, 3)); /* CNPJ maior 4 */ - if (dec->ano < 2017) { + if (dec->ano < 2017 || dec->ano >= 2019) { /* CPF e DN de dependentes 1 a 6 */ for (i = 1; i <= 6; i++) { struct dependente *dependente = list_get(dec->dependentes, i - 1); @@ -207,6 +213,9 @@ static void gera_header(struct declaracao *dec, FILE *f) /* Fim das mudanças de 2016 */ + if (dec->ano >= 2020) + fprintf(f, "%-13.13s", dec->contribuinte.titulo_eleitor ?: ""); + fprintf(f, " "); /* Teste PGD, FILLER2 */ } @@ -240,6 +249,9 @@ static void gera_contribuinte(struct declaracao *dec, FILE *f) if (dec->ano <= 2017) { fprintf(f, "%-4.4s", dec->contribuinte.ddd ?: ""); fprintf(f, "%-9.9s", dec->contribuinte.telefone ?: ""); + } else if (dec->ano >= 2020) { + fprintf(f, "%-4.4s", dec->contribuinte.ddd ?: ""); + fprintf(f, "%-9.9s", ""); } else { fprintf(f, "%-13.13s", ""); /* FILLER */ } @@ -272,7 +284,9 @@ static void gera_contribuinte(struct declaracao *dec, FILE *f) fprintf(f, "%-11.11s", dec->contribuinte.celular ?: ""); /* celular */ fprintf(f, "%s", dec->conjuge.cpf ? "S" : "N"); } - if (dec->ano >= 2018) { + if (dec->ano >= 2020) { + fprintf(f, "%-11.11s", dec->contribuinte.telefone ?: ""); + } else if (dec->ano >= 2018) { fprintf(f, "%-2.2s%-9.9s", dec->contribuinte.ddd ?: "", dec->contribuinte.telefone ?: ""); } } @@ -574,6 +588,16 @@ static void gera_23_poupanca(struct declaracao *dec, FILE *f) gera_isentos2(dec, f, 12, "POUPANCA"); } +static void gera_23_lucrome(struct declaracao *dec, FILE *f) +{ + gera_isentos2(dec, f, 13, "LUCROME"); +} + +static void gera_23_outrosisentos(struct declaracao *dec, FILE *f) +{ + gera_isentos2(dec, f, 26, "OUTROSISENTOS"); +} + static void gera_exclusivos(struct declaracao *dec, FILE *f) { fprintf(f, "24"); @@ -712,7 +736,10 @@ static void gera_recibodetalhe(struct declaracao *dec, FILE *f) fprintf(f, "%-100.100s", ""); /* FILLER */ fprintf(f, "%-4.4s", ""); /* FILLER */ fprintf(f, "%-8.8s", ""); /* FILLER */ - if (dec->ano >= 2018) { + if (dec->ano >= 2020) { + fprintf(f, "%-4.4s", dec->contribuinte.ddd ?: ""); + fprintf(f, "%-9.9s", ""); + } else if (dec->ano >= 2018) { fprintf(f, "%-13.13s", ""); } else { fprintf(f, "%-4.4s", dec->contribuinte.ddd ?: ""); @@ -733,7 +760,9 @@ static void gera_recibodetalhe(struct declaracao *dec, FILE *f) fprintf(f, "%-13.13s", dec->contacorrente ? : ""); /* numero conta */ fprintf(f, "%-2.2s", dec->dvconta ? : ""); /* DV conta */ fprintf(f, "%013lld", 0); /* TODO: imposto alienacao moeda estrangeira em especie */ - if (dec->ano >= 2018) { + if (dec->ano >= 2020) { + fprintf(f, "%-11.11s", dec->contribuinte.telefone ?: ""); + } else if (dec->ano >= 2018) { fprintf(f, "%-2.2s%-9.9s", dec->contribuinte.ddd ?: "", dec->contribuinte.telefone ?: ""); } } @@ -844,8 +873,12 @@ static void gera_plr(struct declaracao *dec, FILE *f) static void gera_plr2(struct declaracao *dec, FILE *f) { - gera_isento2(dec, f, 96, 11, 88); - dec->linhas[96]++; + gera_isento2(dec, f, 11, 11, 88); +} + +static void gera_lucrome2(struct declaracao *dec, FILE *f) +{ + gera_isento2(dec, f, 13, 13, 84); } static void gera_outrosisentos(struct declaracao *dec, FILE *f) @@ -858,6 +891,14 @@ static void gera_outrosisentos(struct declaracao *dec, FILE *f) fprintf(f, "%-60.60s", i->descricao); } +static void gera_outrosisentos2(struct declaracao *dec, FILE *f) +{ + struct isento *i; + i = dec->ctx; + gera_isento2(dec, f, 26, 26, 86); + fprintf(f, "%-60.60s", i->descricao); +} + static void gera_poupanca(struct declaracao *dec, FILE *f) { gera_isento(dec, f, 98); @@ -865,8 +906,7 @@ static void gera_poupanca(struct declaracao *dec, FILE *f) static void gera_poupanca2(struct declaracao *dec, FILE *f) { - gera_isento2(dec, f, 98, 12, 84); - dec->linhas[98]++; + gera_isento2(dec, f, 12, 12, 84); } static void gera_aplicacoes(struct declaracao *dec, FILE *f) @@ -876,8 +916,7 @@ static void gera_aplicacoes(struct declaracao *dec, FILE *f) static void gera_aplicacoes2(struct declaracao *dec, FILE *f) { - gera_isento2(dec, f, 99, 6, 88); - dec->linhas[99]++; + gera_isento2(dec, f, 6, 6, 88); } static void gera_dependente(struct declaracao *dec, FILE *f) @@ -918,22 +957,22 @@ static void gera_bem(struct declaracao *dec, FILE *f) fprintf(f, "%013lld", b->valor); /* Imóvel */ - fprintf(f, "%-40.40s", b->logradouro ?: ""); - fprintf(f, "%-6.6s", b->numero ?: ""); - fprintf(f, "%-40.40s", b->complemento ?: ""); - fprintf(f, "%-40.40s", b->bairro ?: ""); - fprintf(f, "%-9.9s", b->cep ?: ""); - fprintf(f, "%-2.2s", b->uf ?: ""); - fprintf(f, "%04d", b->cd_municipio); - fprintf(f, "%-40.40s", b->municipio ?: ""); + attr_out(f, b->attr, "logradouro", 40); + attr_out(f, b->attr, "numero", 6); + attr_out(f, b->attr, "complemento", 40); + attr_out(f, b->attr, "bairro", 40); + attr_out(f, b->attr, "cep", 9); + attr_out(f, b->attr, "uf", 2); + attr_out(f, b->attr, "cd_municipio", 4); + attr_out(f, b->attr, "municipio", 40); /* FIXME: Registro de imóveis, Nao (0), Sim (1), Vazio (2) */ - fprintf(f, "%d", b->registro ? 1 : 2); - fprintf(f, "%-40.40s", b->matricula ?: ""); - fprintf(f, "%-40.40s", b->registro ?: ""); - fprintf(f, "%011lld", b->area); + fprintf(f, "%d", attr_get(b->attr, "registro") ? 1 : 2); + attr_out(f, b->attr, "matricula", 40); + attr_out(f, b->attr, "registro", 40); + attr_out(f, b->attr, "area", 11); /* FIXME: Area, M2 (0), Ha (1), Vazio (2) */ - fprintf(f, "%d", (b->area == 0) ? 2 : 0); - fprintf(f, "%-60.60s", b->cartorio ?: ""); + fprintf(f, "%d", attr_get(b->attr, "area") ? 0 : 2); + attr_out(f, b->attr, "cartorio", 60); /* Número de chave */ fprintf(f, "%05d", dec->linhas[27] + 1); @@ -941,7 +980,7 @@ static void gera_bem(struct declaracao *dec, FILE *f) /* Mudanças 2018 */ if (dec->ano >= 2018) { fprintf(f, "%-8.8s", "00000000"); /* TODO: Data de aquisição */ - fprintf(f, "%-20.20s", ""); /* TODO: IPTU */ + fprintf(f, "%-20.20s", ""); /* TODO: IPTU, 2019, filler */ fprintf(f, "%-8.8s", "00000000"); /* TODO: NIRF */ fprintf(f, "%-30.30s", ""); /* TODO: RENAVAN */ fprintf(f, "%-30.30s", ""); /* TODO: Registro aviação civil */ @@ -950,6 +989,10 @@ static void gera_bem(struct declaracao *dec, FILE *f) fprintf(f, "%-15.15s", ""); /* TODO: Conta bancária e dígito verificador */ fprintf(f, "%-14.14s", ""); /* TODO: CPF ou CNPJ */ } + + if (dec->ano >= 2019) { + attr_out(f, b->attr, "iptu", 30); + } } static void gera_carne(struct declaracao *dec, FILE *f) @@ -1101,6 +1144,8 @@ static int gera(struct declaracao *dec, char *filename) W(gera_exclusivos); } else { W(gera_23_poupanca); + W(gera_23_lucrome); + W(gera_23_outrosisentos); W(gera_24_decimoterceiro); W(gera_24_aplicacoes); W(gera_24_plr); @@ -1137,12 +1182,14 @@ static int gera(struct declaracao *dec, char *filename) IW(gera_poupanca, 98); IW(gera_aplicacoes, 99); } else { - IW(gera_poupanca2, 98); - dec->linhas[98] = 0; - IW(gera_aplicacoes2, 99); - dec->linhas[99] = 0; - IW(gera_plr2, 96); - dec->linhas[96] = 0; + IW(gera_poupanca2, 12); + //dec->linhas[12] = 0; + IW(gera_lucrome2, 13); + IW(gera_outrosisentos2, 26); + IW(gera_aplicacoes2, 6); + //dec->linhas[99] = 0; + IW(gera_plr2, 11); + //dec->linhas[96] = 0; } W(gera_trailler);