Implementa inserção ordenada em lista
[cascardo/declara.git] / base.c
diff --git a/base.c b/base.c
index 0eec44c..52d8c31 100644 (file)
--- a/base.c
+++ b/base.c
@@ -28,25 +28,19 @@ SET_INT(ano);
 SET_STRING(cpf);
 SET_STRING(nome);
 SET_STRING(recibo);
-
-static int run_dump(struct declaracao *dec, char **args, int argc)
-{
-       printf("ano: %d\n", dec->ano);
-       printf("cpf: %s\n", dec->cpf);
-       printf("nome: %s\n", dec->nome);
-       printf("recibo: %s\n", dec->recibo);
-       rendimento_dump(dec);
-       printf("pago: %lld.%02d\n", dec->pago / 100, dec->pago % 100);
-       printf("devido: %lld.%02d\n", dec->devido / 100, dec->devido % 100);
-       printf("restituicao: %lld.%02d\n", dec->restituicao / 100, dec->restituicao % 100);
-       return 0;
-}
+SET_STRING(retifica);
 
 static int run_resumo(struct declaracao *dec, char **args, int argc)
 {
+       if (dec->retifica)
+               printf("retificadora\n");
        printf("pago: %lld.%02d\n", dec->pago / 100, dec->pago % 100);
+       printf("retido: %lld.%02d\n", dec->retido / 100, dec->retido % 100);
        printf("devido: %lld.%02d\n", dec->devido / 100, dec->devido % 100);
-       printf("restituicao: %lld.%02d\n", dec->restituicao / 100, dec->restituicao % 100);
+       if (dec->restituicao > 0)
+               printf("restituicao: %lld.%02d\n", dec->restituicao / 100, dec->restituicao % 100);
+       if (dec->pagar > 0)
+               printf("a pagar: %lld.%02d\n", dec->pagar / 100, dec->pagar % 100);
        return 0;
 }
 
@@ -59,6 +53,8 @@ static void salva(struct declaracao *dec, FILE *f)
                fprintf(f, "nome \"%s\"\n", dec->nome);
        if (dec->recibo)
                fprintf(f, "recibo \"%s\"\n", dec->recibo);
+       if (dec->retifica)
+               fprintf(f, "retifica \"%s\"\n", dec->retifica);
        contribuinte_salva(dec, f);
        rendimento_salva(dec, f);
 }
@@ -78,11 +74,6 @@ static int run_salva(struct declaracao *dec, char **args, int argc)
        return 0;
 }
 
-static struct cmd cmd_dump = {
-       .name = "dump",
-       .run = run_dump,
-};
-
 static struct cmd cmd_salva = {
        .name = "salva",
        .run = run_salva,
@@ -95,12 +86,12 @@ static struct cmd cmd_resumo = {
 
 int base_cmd_init(void)
 {
-       cmd_add(&cmd_dump);
        cmd_add(&cmd_salva);
        cmd_add(&cmd_resumo);
        cmd_add(&cmd_ano);
        cmd_add(&cmd_cpf);
        cmd_add(&cmd_recibo);
+       cmd_add(&cmd_retifica);
        cmd_add(&cmd_nome);
        return 0;
 }