X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=lib%2Fcalcula.c;h=e9fe3d89e4856280447df8cdc2131bb5d210c497;hb=b7a2c963abfd1f41ebe6c3793e1a18467e53067d;hp=8507a50ecebd4fed6226aaa44cf677534ccffef8;hpb=6a6d939cc6bc010ef81d5e69d8832b731f5cff9a;p=cascardo%2Fdeclara.git diff --git a/lib/calcula.c b/lib/calcula.c index 8507a50..e9fe3d8 100644 --- a/lib/calcula.c +++ b/lib/calcula.c @@ -25,9 +25,17 @@ #include "totais.h" #include "util.h" #include "ano.h" +#include "dependente.h" +#include "pagamento.h" static const long long dependente[ANO(MAX_ANOS)] = { [ANO(2015)] = 215652, + [ANO(2016)] = 227508, +}; + +static const long long instrucao[ANO(MAX_ANOS)] = { + [ANO(2015)] = 337583, + [ANO(2016)] = 356150, }; long long deducao_dependente(struct declaracao *dec) @@ -37,23 +45,67 @@ long long deducao_dependente(struct declaracao *dec) return 0; } +static void calculo_instrucao(struct declaracao *dec) +{ + int i, j; + struct dependente *d; + struct pagamento *p; + long long instrucao_titular = 0; + /* Instrução do titular */ + for (i = 0; (p = list_get(dec->pagamentos, i)); i++) { + if (p->dependente == 0 && pagamento_instrucao(p)) { + instrucao_titular += (p->pagamento - p->reembolso); + } + } + if (instrucao_titular > instrucao[ANO(dec->ano)]) { + totais_add(dec, "INSTRUCAO", instrucao[ANO(dec->ano)]); + } else { + totais_add(dec, "INSTRUCAO", instrucao_titular); + } + /* Dependentes com instrução */ + for (i = 0; (d = list_get(dec->dependentes, i)); i++) { + long long instrucao_dependente = 0; + for (j = 0; (p = list_get(dec->pagamentos, j)); j++) { + if (p->dependente == (i + 1) && pagamento_instrucao(p)) { + instrucao_dependente += (p->pagamento - p->reembolso); + } + } + if (instrucao_dependente) { + totais_add(dec, "DEPSINSTRUCAO", 1); + if (dec->verbose) { + printf("Dependente %s (%d) tem instrução\n", d->nome, i); + } + } + if (instrucao_dependente > instrucao[ANO(dec->ano)]) { + totais_add(dec, "INSTRUCAO", instrucao[ANO(dec->ano)]); + } else { + totais_add(dec, "INSTRUCAO", instrucao_dependente); + } + } +} + /* Alguns totais precisam ser limitados. Portanto, um total de decuções * precisa ser ajustado para tais limites. Esta função considerará tais * limites no futuro. */ static long long total_deducao(struct declaracao *dec) { int i; + + calculo_instrucao(dec); + if (dec->verbose) { printf("Dedução:\n"); printf("\tDependentes: "FMT_R"\n", R(totais_get(dec, "DEPENDENTES"))); printf("\tINSS: "FMT_R"\n", R(totais_get(dec, "INSS"))); + printf("\tInstrução: "FMT_R"\n", R(totais_get(dec, "INSTRUCAO"))); printf("\tPagamentos: "FMT_R"\n", R(totais_get(dec, "PAGAMENTOS"))); printf("\tReembolsos: -"FMT_R"\n", R(totais_get(dec, "REEMBOLSOS"))); } return totais_get(dec, "DEPENDENTES") + totais_get(dec, "INSS") + - totais_get(dec, "PAGAMENTOS") - - totais_get(dec, "REEMBOLSOS"); + totais_get(dec, "INSTRUCAO") + + totais_get(dec, "MEDICAS") + + totais_get(dec, "PREVIDENCIA"); } static void total_pago(struct declaracao *dec) @@ -86,16 +138,28 @@ static struct taxtable table2015[] = { { 9999999999999LL, 0, 0, }, }; +static struct taxtable table2016[] = { + { 0, 0, 0, }, + { 2249914, 750, 168743, }, + { 3347773, 1500, 419826, }, + { 4447675, 2250, 753402, }, + { 5537355, 2750, 1030270, }, + { 9999999999999LL, 0, 0, }, +}; + static struct taxtable *table[ANO(MAX_ANOS)] = { [ANO(2015)] = table2015, + [ANO(2016)] = table2016, }; static const long long simples[ANO(MAX_ANOS)] = { [ANO(2015)] = 1588089, + [ANO(2016)] = 1675434, }; static const long long obrigatoriedade[ANO(MAX_ANOS)] = { [ANO(2015)] = 2681655, + [ANO(2016)] = 2812391, }; static long long imposto(struct taxtable *tt, long long tr, int verbose) @@ -122,6 +186,8 @@ static long long imposto_simples(struct declaracao *dec) td = simples[ANO(dec->ano)]; totais_add(dec, "DESCONTO", td); tr -= td; + if (tr < 0) + tr = 0; totais_add(dec, "BASESIMPLES", tr); if (dec->verbose) { printf("Desconto simplificado é "FMT_R"\n", R(td)); @@ -138,6 +204,8 @@ static long long imposto_completa(struct declaracao *dec) td = total_deducao(dec); totais_add(dec, "DEDUCOES", td); tr -= td; + if (tr < 0) + tr = 0; totais_add(dec, "BASECOMPLETA", tr); if (dec->verbose) { printf("Desconto completa é "FMT_R"\n", R(td));