X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/a8dad3d5bafadb9bca3335952462f05192a5059c..f84d04a91b1f48afe019f1477b87a22a516ef888:/emufs_gui/viewer.c?ds=sidebyside diff --git a/emufs_gui/viewer.c b/emufs_gui/viewer.c index bcae4bd..c2b2e1d 100644 --- a/emufs_gui/viewer.c +++ b/emufs_gui/viewer.c @@ -8,6 +8,7 @@ /* Se encarga de reemplazar los \0 un caracter visual, y segurar un \0 al final */ static char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); +static char *procesar_registro_articulo_tipo2(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); static char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); static char *procesar_registro_factura_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); @@ -72,9 +73,9 @@ char *juntar_memoria(char *s1, char *s2, char *s3, int size1, int size2, int siz return NULL; } - if (s1) memcpy(salida, s1, size1); - if (s2) memcpy(salida+size2, s2, size2); - if (s3) memcpy(salida+size2+size3, s3, size3); + if (s1) memcpy(salida, s1, size1); else size1 = 0; + if (s2) memcpy(salida+size1, s2, size2); else size2 = 0; + if (s3) memcpy(salida+size1+size2, s3, size3); if (s1) free(s1); if (s2) free(s2); if (s3) free(s3); @@ -285,13 +286,19 @@ void ver_registros(WINDOW *padre, int w, int h, int cual) wattroff(padre, COLOR_PAIR(COLOR_BLUE)); switch (fp->tipo) { case T1: - case T2: waddstr(padre, "Registro variable con bloque parametrizado."); if (cual == 0) procesar = procesar_registro_articulo_tipo1; else procesar = procesar_registro_factura_tipo1; break; + case T2: + waddstr(padre, "Registro variable con sin bloques."); + if (cual == 0) + procesar = procesar_registro_articulo_tipo2; + else + procesar = procesar_registro_factura_tipo1; + break; case T3: if (cual == 0) procesar = procesar_registro_articulo_tipo3; @@ -925,3 +932,56 @@ char *procesar_registro_factura_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *siz return salida; } +char *procesar_registro_articulo_tipo2(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho) +{ + char *salida, *tmp; + char *in; + int i; + EMUFS_REG_SIZE tam_data; + if (ptr == NULL) return NULL; + + (*size) = *size - sizeof(EMUFS_REG_SIZE) - sizeof(EMUFS_REG_ID) + 21; + (*ancho) = *size-101; + salida = (char *)malloc(*size); + memset(salida, '.', *size); + + PERR("Voy por el espacio antes"); + for(i=0; i < *pos_actual; i++) { + /* Los datos que tengo por ahora los pongo enmascarados! */ + salida[i] = ((*in)=='\0')?'*':(*in); + in++; + } + tmp = salida + *pos_actual; + in = ptr + *pos_actual; + + PERR("Voy por el header"); + /* ID de registro */ + sprintf(tmp, "(%08lu)", *((EMUFS_REG_ID *)in)); + tmp += 10; + in += sizeof(EMUFS_REG_ID); + /* TamaƱo de registro */ + sprintf(tmp, "{%08lu}", *((EMUFS_REG_SIZE *)in)); + tam_data = *((EMUFS_REG_SIZE *)in); + tmp += 10; + in += sizeof(EMUFS_REG_SIZE); + PERR("Voy por la data"); + i = 0; + while (i < tam_data) { + (*tmp) = ((*in)=='\0')?'*':(*in); + tmp++; + in++; + i++; + } + PERR("Voy por el espacio despues"); + for(i=0; i < 100-*pos_actual; i++) { + (*tmp) = ((*in)=='\0')?'*':(*in); + tmp++; + in++; + } + + free(ptr); + PERR("LISTO"); + salida[*size-1] = '\0'; + return salida; +} +