- PERR("Proceso datos\n");
- for(i=0; i<indices_total; i++) {
- error = 0;
- save = old->leer_registro(old, indices[i], &size, &error);
- if (procesar_leer_articulo(&art, save, size, lst_articulos) == 1) {
+ /* vuelvo a crear el EMUFS y sus indices (esto deberia pisar lo actual) */
+ 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);
+ 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");
+ PERR("Agregando datos de nuevo")
+ while (!feof(fp)) {
+ if (fread(&articulo, sizeof(t_Articulo), 1, fp) != 1) continue;
+ save = procesar_guardar_articulo(&articulo, &size, lst_articulos);
+ if (save) {
+ error = 0;
+ emu->grabar_registro(emu, save, size, &error);