X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/43e1e27b378dcf40321063e8c200894d4f47bb7c..866ee030a930b725a701bd35445b1bcd82506a87:/emufs_gui/articulos.c diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 4c69770..136bf96 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -112,9 +112,9 @@ t_LstArticulos *art_cargar(t_Parametros *param) tmp->fp = emufs_crear("articulos", param->tipo_arch_art, param->tam_bloque_art, sizeof(t_Articulo)); /* Agrego los indices */ PERR("Voy a agregar un indice"); - emufs_agregar_indice(tmp->fp, "presentacion", IND_EXAHUSTIVO, IND_B, IDX_STRING, STRUCT_OFFSET(un_articulo, presentacion), 512); - emufs_agregar_indice(tmp->fp, "desc", IND_EXAHUSTIVO, IND_B, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), 512); - emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, IND_B, IDX_INT, 0, 512); + emufs_agregar_indice(tmp->fp, "presentacion", IND_EXAHUSTIVO, IND_B, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), 512, 1); + emufs_agregar_indice(tmp->fp, "desc", IND_EXAHUSTIVO, IND_B, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), 512, 0); + emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, IND_B_ASC, IDX_INT, 0, 512, 0); if (!tmp->fp) { PERR("NO SE PUDO CREAR ARCHIVO ARTICULOS"); free(tmp); @@ -315,9 +315,13 @@ void art_modificar(char *s) tmp = procesar_guardar_articulo(articulo, &size, lst_articulos); if (tmp) { CLAVE k; + INDICE_DATO dummy1; error = 0; k = emufs_indice_generar_clave_desde_valor(lst_articulos->fp->indices, (char *)&articulo->numero); - lst_articulos->fp->modificar_registro(lst_articulos->fp, k, tmp, size, &error); + /* dummy se pasa porque esto se hace por clave primaria, y el INDICE_DATO que se + * pasa solo es requerido cuando son claves multiples + */ + lst_articulos->fp->modificar_registro(lst_articulos->fp, k, tmp, size, &error, dummy1); free(tmp); } @@ -355,8 +359,11 @@ void art_eliminar(char *s) wrefresh(win); getch(); } else { + INDICE_DATO dummy; k = emufs_indice_generar_clave_desde_valor(lst_articulos->fp->indices, (char *)&(articulo->numero)); - lst_articulos->fp->borrar_registro(lst_articulos->fp, k); + PERR("Borrando ARTICULO") + lst_articulos->fp->borrar_registro(lst_articulos->fp, k, dummy); + PERR("LISTO BORRADO"); free(articulo); } @@ -733,15 +740,14 @@ void art_consultas_codigos(char *s, t_Lista *lista) void art_consultas_stock(char *s, t_Lista *lista) { - EMUFS_REG_ID dummy; - int hasta_codigo; - CLAVE k, menor, mayor; - t_Articulo *articulo; + CLAVE k, menor; + t_Articulo articulo; t_Form *form; INDICE *idx; float por; - idx = lst_articulos->fp->indices; + idx = emufs_buscar_indice_por_nombre(lst_articulos->fp, "desc"); + if (idx == NULL) PERR("NO SE ENCUENTRA INDICE DESC!!!"); /* El usuario ingresa rango a listar */ form = form_crear(lista->win); @@ -756,23 +762,35 @@ void art_consultas_stock(char *s, t_Lista *lista) wrefresh(lista->win); menor = idx->obtener_menor_clave(idx); - mayor = idx->obtener_mayor_clave(idx); k = menor; - hasta_codigo = mayor.i_clave; - while ((k.i_clave != -1) && (k.i_clave <= hasta_codigo)) { - articulo = art_obtener(lst_articulos, k.i_clave, &dummy); - if (articulo != NULL) { - if (atof(articulo->existencia) <= (1.0f+por)*atof(articulo->emin)) { - lista_agregar_fila(lista, - articulo->numero, - articulo->desc, - articulo->existencia, - articulo->emin - ); + while (k.i_clave != -1) { + char *tmp; + EMUFS_REG_SIZE size; + int error, cant, i; + INDICE_DATO *datos; + CLAVE k1; + datos = idx->buscar_entradas(idx, k, &cant); + for(i=0; ifp->leer_registro(lst_articulos->fp, k1, &size, &error); + + if (tmp != NULL) { + procesar_leer_articulo(&articulo, tmp, size, lst_articulos); + + if (atof(articulo.existencia) <= (1.0f+por)*atof(articulo.emin)) { + lista_agregar_fila(lista, + articulo.numero, + articulo.desc, + articulo.existencia, + articulo.emin + ); + } + free(tmp); } - free(articulo); } + if (datos) free(datos); k = idx->obtener_sig_clave(idx, k); } @@ -781,10 +799,91 @@ void art_consultas_stock(char *s, t_Lista *lista) curs_set(1); } +void art_consultas_cambiar_precio(char *s, t_Lista *lista) +{ + CLAVE k, menor; + t_Articulo articulo; + t_Form *form; + INDICE *idx; + float por, pvu; + char desc[51], uno_solo; + + idx = emufs_buscar_indice_por_nombre(lst_articulos->fp, "desc"); + if (idx == NULL) PERR("NO SE ENCUENTRA INDICE DESC!!!"); + + /* El usuario ingresa rango a listar */ + form = form_crear(lista->win); + form_agregar_widget(form, INPUT, "Desc. Articulo (nulo==Todos)", 50, ""); + form_agregar_widget(form, INPUT, "Ingrese %", 8, "0"); + + werase(lista->win); + wrefresh(lista->win); + form_ejecutar(form, 2, 2); + + por = form_obtener_valor_float(form, "Ingrese %"); + strcpy(desc, form_obtener_valor_char(form, "Desc. Articulo (nulo==Todos)")); + + form_destruir(form); + werase(lista->win); + wrefresh(lista->win); + + uno_solo = 1; + if (strlen(desc) == 0) { + uno_solo = 0; + k = menor = idx->obtener_menor_clave(idx); + } else { + k.i_clave = 1; + } + + while (k.i_clave != -1) { + char *tmp; + EMUFS_REG_SIZE size; + int error, cant, i; + INDICE_DATO *datos; + CLAVE k1; + if (uno_solo == 0) + 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->leer_registro(lst_articulos->fp, k1, &size, &error); + + if (tmp != NULL) { + procesar_leer_articulo(&articulo, tmp, size, lst_articulos); + free(tmp); + + /* XXX */ + pvu = atof(articulo.pvu); + pvu += pvu*por; + + sprintf(articulo.pvu, "%.2f", pvu); + tmp = procesar_guardar_articulo(&articulo, &size, lst_articulos); + error = 0; + /* README : Aca si tengo que pasar el INDICE_DATO correcto, para que la funcion + * borrar sea capaz de eliminar solo el item que corresponde en las + * claves con repeticion + */ + PERR("=== MODIFICANDO ==="); + fprintf(stderr, "Desc=%s , PVU=%s, Codigo=%d\n", articulo.desc, articulo.pvu, articulo.numero); + lst_articulos->fp->modificar_registro(lst_articulos->fp, k1, tmp, size, &error, datos[i]); + PERR("=== FIN ==="); + } + } + if (datos) free(datos); + if (uno_solo == 0) + k = idx->obtener_sig_clave(idx, k); + else + k.i_clave = -1; + } +} + void art_consultas_varias(char *nombre_indice, char *titulo, t_Lista *lista) { int i, cant, error; - char *desc, *tmp; + char desc[51], *tmp; t_Articulo articulo; t_Form *form; INDICE_DATO *datos; @@ -802,7 +901,6 @@ void art_consultas_varias(char *nombre_indice, char *titulo, t_Lista *lista) form_ejecutar(form, 2, 2); tmp = form_obtener_valor_char(form, titulo); - desc = malloc(sizeof(char)*(strlen(tmp)+1)); strcpy(desc, tmp); form_destruir(form); @@ -828,7 +926,7 @@ void art_consultas_varias(char *nombre_indice, char *titulo, t_Lista *lista) PERR("NO SE PUDO RECUPERAR EL REGISTRO DE DATOS"); } } - + if (datos) free(datos); curs_set(0); lista_ejecutar(lista); curs_set(1); @@ -844,6 +942,7 @@ void art_consultas(char *s) MENU_OPCION("por Descripcion", "Consulta por descripcion"), MENU_OPCION("por Presentacion", "Consulta por Presentacion"), MENU_OPCION("por Sock Faltante", "Consulta de articulos por stock"), + MENU_OPCION("Modificar Precios", "Permite Modificar los PVU"), MENU_OPCION("Volver", "Volver al menu anterior.") }; int opt; @@ -864,7 +963,7 @@ void art_consultas(char *s) lista_agregar_columna(lista, "Existencia", DATO_STR, 55, 9); /* existencia */ lista_agregar_columna(lista, "S. Minimo", DATO_STR, 66, 9); /* enim */ - while ((opt = menu_ejecutar(mi_menu, 5, "Consulta de Articulos")) != 4) { + while ((opt = menu_ejecutar(mi_menu, 6, "Consulta de Articulos")) != 5) { switch (opt) { case 0: art_consultas_codigos(s, lista); @@ -877,6 +976,9 @@ void art_consultas(char *s) break; case 3: art_consultas_stock(s, lista); + break; + case 4: + art_consultas_cambiar_precio(s, lista); } lista_clear(lista); werase(win1);