X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/9fe20770f27710e6d9133fd19c88250815738b35..e71b2f6ba15c4035c6fb10526b4ffd29d44b0ba2:/emufs_gui/articulos.c diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 74281fd..a555775 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -117,7 +117,12 @@ t_LstArticulos *art_cargar(t_Parametros *param) PERR("Voy a agregar un indice"); emufs_agregar_indice(tmp->fp, "presentacion", IND_EXAHUSTIVO, param->ind_art[2].tipo_arbol, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), param->ind_art[2].tam_bloque, 1); emufs_agregar_indice(tmp->fp, "desc", IND_EXAHUSTIVO, param->ind_art[1].tipo_arbol, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), param->ind_art[1].tam_bloque, 0); - emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, param->ind_art[0].tipo_arbol, IDX_INT, 0, param->ind_art[0].tam_bloque, 0); + + /* Para secuencial indexado el indice primario siempre es el B+ */ + if ((param->tipo_arch_art != T4) && (param->tipo_arch_art != T5)) + emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, param->ind_art[0].tipo_arbol, IDX_INT, 0, param->ind_art[0].tam_bloque, 0); + else + emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, IND_B_PLUS, IDX_INT, 0, param->ind_art[0].tam_bloque, 0); if (!tmp->fp) { PERR("NO SE PUDO CREAR ARCHIVO ARTICULOS"); free(tmp); @@ -135,17 +140,18 @@ t_LstArticulos *art_cargar(t_Parametros *param) prop = xml_get_prop(node, "NroArtículo"); art.numero = atoi(prop); xmlFree(prop); - strncpy(art.desc, prop = xml_get_prop(node, "Descripción"), 50); xmlFree(prop); - art.desc[50] = '\0'; /* Me aseguro de que este */ - strncpy(art.presentacion, prop = xml_get_prop(node, "Presentación"), 30); xmlFree(prop); - art.presentacion[30] = '\0'; /* Me aseguro de que este */ - strncpy(art.existencia, prop = xml_get_prop(node, "Existencia"), 8); xmlFree(prop); - art.existencia[8] = '\0'; /* Me aseguro de que este */ - strncpy(art.ubicacion, prop = xml_get_prop(node, "Ubicación"), 30); xmlFree(prop); - strncpy(art.pvu, prop = xml_get_prop(node, "PVU"), 8); xmlFree(prop); - art.pvu[8] = '\0'; /* Me aseguro de que este */ - strncpy(art.emin, prop = xml_get_prop(node, "Emín"), 8); xmlFree(prop); - art.emin[8] = '\0'; /* Me aseguro de que este */ + strcpy(art.desc, prop = xml_get_prop(node, "Descripción")); xmlFree(prop); + art.desc[50] = '\0'; + strcpy(art.presentacion, prop = xml_get_prop(node, "Presentación")); xmlFree(prop); + art.presentacion[30] = '\0'; + strcpy(art.existencia, prop = xml_get_prop(node, "Existencia")); xmlFree(prop); + art.existencia[8] = '\0'; + strcpy(art.ubicacion, prop = xml_get_prop(node, "Ubicación")); xmlFree(prop); + art.ubicacion[30] = '\0'; + strcpy(art.pvu, prop = xml_get_prop(node, "PVU")); xmlFree(prop); + art.pvu[8] = '\0'; + strcpy(art.emin, prop = xml_get_prop(node, "Emín")); xmlFree(prop); + art.emin[8] = '\0'; /* Ya leido el articulo ahora paso a guardarlo en el archivo y agregarlo a la lista */ save = procesar_guardar_articulo(&art, &size, lst_articulos); if (save != NULL) { @@ -161,7 +167,6 @@ t_LstArticulos *art_cargar(t_Parametros *param) } else { PERR("Voy a recuperar desde un archivo"); tmp->fp = emufs_abrir("articulos"); - fprintf(stderr, "PTR=%p %p\n", tmp, tmp->fp); if (tmp->fp == NULL) { PERR("No se pudo cargar archivo de articulos."); free(tmp); @@ -208,7 +213,7 @@ t_Articulo *art_obtener(t_LstArticulos *lst, int numero, EMUFS_REG_ID *id) error = 0; k = emufs_indice_generar_clave_desde_valor(lst->fp->indices, (char *)&numero); tmp = lst->fp->leer_registro(lst->fp, k, &size, &error); - if (error) { + if (tmp == NULL) { free(art); return NULL; } @@ -552,11 +557,15 @@ void art_reformatear(t_Parametros *param) PERR("Creando todo de nuevo") lst_articulos = (t_LstArticulos *)malloc(sizeof(t_LstArticulos)); + lst_articulos->primero = NULL; emu = lst_articulos->fp = emufs_crear("articulos", param->tipo_arch_art, param->tam_bloque_art, sizeof(t_Articulo)); emufs_agregar_indice(emu, "presentacion", IND_EXAHUSTIVO, param->ind_art[2].tipo_arbol, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), param->ind_art[2].tam_bloque, 1); emufs_agregar_indice(emu, "desc", IND_EXAHUSTIVO, param->ind_art[1].tipo_arbol, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), param->ind_art[1].tam_bloque, 0); - emufs_agregar_indice(emu, "codigo", IND_PRIMARIO, param->ind_art[0].tipo_arbol, IDX_INT, 0, param->ind_art[0].tam_bloque, 0); + if ((param->tipo_arch_art != T4) && (param->tipo_arch_art != T5)) + emufs_agregar_indice(emu, "codigo", IND_PRIMARIO, param->ind_art[0].tipo_arbol, IDX_INT, 0, param->ind_art[0].tam_bloque, 0); + else + emufs_agregar_indice(emu, "codigo", IND_PRIMARIO, IND_B_PLUS, IDX_INT, 0, param->ind_art[0].tam_bloque, 0); PERR("Listo"); /* Ahora solo resta volver a meter todos los datos en el archivo */ fp = fopen(tmpfile, "rb"); @@ -688,14 +697,14 @@ void art_consultas_codigos(char *s, t_Lista *lista) k = menor; if (k.i_clave > mayor.i_clave) hasta_codigo = mayor.i_clave; - fprintf(stderr, "k.i_clave = %d -- hasta_codigo = %d\n", k.i_clave, hasta_codigo); + while ((k.i_clave != -1) && (k.i_clave <= hasta_codigo)) { PERR("BUSCO ARTICULO"); + fprintf(stderr, "CLAVE = %d\n", k.i_clave); articulo = art_obtener(lst_articulos, k.i_clave, &dummy); PERR("LO TENGO"); if (articulo != NULL) { PERR("AGREGO A LA LISTA"); - fprintf(stderr, "%d - %s\n", articulo->numero, articulo->desc); lista_agregar_fila(lista, articulo->numero, articulo->desc, @@ -706,7 +715,6 @@ void art_consultas_codigos(char *s, t_Lista *lista) } PERR("OBTENGO SIGUIENTE CLAVE"); k = idx->obtener_sig_clave(idx, k); - fprintf(stderr, "k.i_clave = %d -- hasta_codigo = %d\n", k.i_clave, hasta_codigo); } curs_set(0); @@ -833,7 +841,6 @@ void art_consultas_cambiar_precio(char *s, t_Lista *lista) datos = idx->buscar_entradas(idx, k, &cant); else datos = emufs_buscar_registros(lst_articulos->fp, "desc", desc, &cant); - fprintf(stderr, "obtuve %d claves para %s\n", cant, desc); for(i=0; ifp->modificar_registro(lst_articulos->fp, k1, tmp, size, &error, datos[i]); PERR("=== FIN ==="); } @@ -1031,7 +1037,6 @@ void mostrar_art(WINDOW *win, CLAVE k, char *s, INDICE *idx) free(art); art = NULL; } else { - fprintf(stderr, "Tengo %d datos\n", cant); error = 1; k.i_clave = datos[0].id; PERR("Leo el primer dato"); @@ -1275,10 +1280,8 @@ void art_actualizar_stock(int numero, int cv) */ PERR("Guardando modificacion de Stock"); error = 0; - fprintf(stderr, "PTR=%p %p\n", lst_articulos, lst_articulos->fp); fp = lst_articulos->fp; PERR("Pase1"); - fprintf(stderr, "METODO : %p\n", fp->modificar_registro); fp->modificar_registro(fp, k, tmp, size, &error, dummy1); PERR("Pase2"); PERR("Listo");