fprintf(f, "26");
fprintf(f, "%s", dec->cpf);
fprintf(f, "%02d", p->codigo);
- fprintf(f, "%05d", 0); /* TODO: chave dependente */
+ fprintf(f, "%05d", p->dependente);
fprintf(f, "%-14.14s", p->cnpj);
fprintf(f, "%-60.60s", p->nome);
fprintf(f, "%-11.11s", ""); /* TODO: NIT */
fprintf(f, "%013lld", 0);
}
fprintf(f, "%d", strlen(p->cnpj) == 11 ? 1 : 2);
- /* Titular (T), Dependente (D), Alimentando (A), FIXME */
- fprintf(f, "T");
+ /* Titular (T), Dependente (D), Alimentando (A), FIXME Alimentando */
+ fprintf(f, "%c", p->dependente ? 'D' : 'T');
}
static void gera_isento(struct declaracao *dec, FILE *f, int codigo)
return 0;
}
-static struct pagamento * pagamento_new(char **args)
+static struct pagamento * pagamento_new(char **args, int argc)
{
struct pagamento *pagamento;
int r = 0;
pagamento_free(pagamento);
return NULL;
}
+ if (argc == 7) {
+ r = set_int(&args[5], 2, &pagamento->dependente);
+ } else {
+ pagamento->dependente = 0;
+ }
+ if (r < 0 || pagamento->dependente < 0) {
+ pagamento_free(pagamento);
+ return NULL;
+ }
return pagamento;
}
{
struct pagamento *pagamento;
int r;
- if (argc != 6)
+ if (argc != 6 && argc != 7)
return -EINVAL;
- pagamento = pagamento_new(args);
+ pagamento = pagamento_new(args, argc);
if (!pagamento)
return -ENOMEM;
+ if (pagamento->dependente > list_size(dec->dependentes)) {
+ pagamento_free(pagamento);
+ return -EINVAL;
+ }
r = list_insert_ordered(&dec->pagamentos, pagamento, pagamento_cmp);
if (r < 0) {
pagamento_free(pagamento);
int i;
struct pagamento *j;
for (i = 0; j = list_get(dec->pagamentos, i); i++)
- fprintf(f, "pagamento %d \"%s\" \"%s\" %lld %lld\n",
- j->codigo, j->cnpj, j->nome, j->pagamento, j->reembolso);
+ fprintf(f, "pagamento %d \"%s\" \"%s\" %lld %lld %d\n",
+ j->codigo, j->cnpj, j->nome, j->pagamento, j->reembolso, j->dependente);
}
static struct cmd cmd_pagamento = {