X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/ecc9d27042d38e53309151e07c1c23cc6331efea..9b6d59d2a6f3ed7e0d2413c3730c29f1041dab2c:/emufs/idx.c?ds=sidebyside diff --git a/emufs/idx.c b/emufs/idx.c index 50f3d1c..701ba25 100644 --- a/emufs/idx.c +++ b/emufs/idx.c @@ -131,7 +131,6 @@ EMUFS_BLOCK_ID emufs_idx_buscar_registro(EMUFS *emu, EMUFS_REG_ID reg_id) return EMUFS_NOT_FOUND; } -/* agrega un registro al final del archivo */ int emufs_idx_agregar(EMUFS *emu, EMUFS_REG_ID id_reg, EMUFS_BLOCK_ID location) { FILE *f_idx; @@ -141,7 +140,7 @@ int emufs_idx_agregar(EMUFS *emu, EMUFS_REG_ID id_reg, EMUFS_BLOCK_ID location) strcpy(name_f_idx,emu->nombre); strcat(name_f_idx, EMUFS_IDX_EXT); - if ( (f_idx = fopen(name_f_idx,"r+"))==NULL ) return -1; + if ( (f_idx = fopen(name_f_idx,"a+"))==NULL ) return -1; fseek(f_idx, sizeof(EMUFS_IDX)*id_reg, SEEK_SET); reg.id_reg = id_reg; @@ -242,13 +241,13 @@ int emufs_idx_existe_id(EMUFS *emu, int ID) if (fseek(f_idx, sizeof(EMUFS_IDX)*ID, SEEK_SET) == 0) { fread(®, sizeof(EMUFS_IDX), 1, f_idx); - if (reg.location == EMUFS_NOT_FOUND) { + if (reg.location != EMUFS_NOT_FOUND) { fclose(f_idx); - return -1; + return 0; } } fclose(f_idx); - return 0;/*no existe el id*/ + return -1;/*no existe el id*/ } int emufs_idx_actualizar(EMUFS *emu, int ID, EMUFS_BLOCK_ID bloque) @@ -265,7 +264,7 @@ int emufs_idx_actualizar(EMUFS *emu, int ID, EMUFS_BLOCK_ID bloque) return -1; } printf("actualice el id = %d\n",ID); - /*fseek(f_idx,0,SEEK_SET);*/ + fseek(f_idx,0,SEEK_SET); fseek(f_idx,ID*sizeof(EMUFS_IDX),SEEK_SET); fread(®,sizeof(EMUFS_IDX),1,f_idx); reg.location = bloque;