strcpy(name_f_idx, emu->nombre);
strcat(name_f_idx, EMUFS_IDX_EXT);
+ (*err) = 0;
if ((f_idx = fopen(name_f_idx, "rb")) == NULL) {
PERR("No se puede abrir archivo");
*err = 4; /* EMUFS_ERROR_CANT_OPEN_FILE */
}
/* busca el registro ID en el archivo ".idx" y devuelve el nro de bloque en el que se encuentra */
-EMUFS_BLOCK_ID emufs_idx_buscar_registro(EMUFS *emu, EMUFS_REG_ID n_IdReg)
+EMUFS_BLOCK_ID emufs_idx_buscar_registro(EMUFS *emu, EMUFS_REG_ID reg_id)
{
FILE* f_idx;
EMUFS_IDX reg;
char name_f_idx[255];
- unsigned short int b_Found = 0;
strcpy(name_f_idx,emu->nombre);
strcat(name_f_idx, EMUFS_IDX_EXT);
- if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
+ if ((f_idx = fopen(name_f_idx, "rb")) == NULL) {
+ PERR("No se puede abrir archivo");
+ /* *err = 4; * EMUFS_ERROR_CANT_OPEN_FILE */
+ return EMUFS_NOT_FOUND;
+ }
- while (!feof(f_idx) && !b_Found){
- if (fread(®,sizeof(EMUFS_IDX),1,f_idx) != 1) continue;
- if (reg.n_idreg == n_IdReg) b_Found = 1;
+ while (!feof(f_idx)) {
+ if (fread(®, sizeof(EMUFS_IDX), 1, f_idx) != 1) {
+ if (feof(f_idx)) break; /* No leyĆ³ por EOF */
+ PERR("Error al leer registros de idx");
+ /* *err = 3; * EMUFS_ERROR_FILE_READ */
+ return EMUFS_NOT_FOUND;
+ }
+ if (reg.n_idreg == reg_id) {
+ fclose(f_idx);
+ return reg.n_location;
+ }
}
-
fclose(f_idx);
-
- /* Sino lo encontre devuelvo uno, otherwise el offset o bloque */
- if (!b_Found)
- return(-1);
- else
- return(reg.n_location);
+
+ return EMUFS_NOT_FOUND;
}
/* agrega un registro al final del archivo */
/* Note: Location = Bloque para Tipo 1 y 3, Offset para Tipo 2 */
reg.n_idreg = n_idreg;
- reg.n_location = n_location;
+ reg.n_location = n_location;
fwrite(®,sizeof(EMUFS_IDX),1,f_idx);
fclose(f_idx);
return 0;
id = emufs_did_get_last(efs, err);
if (id == EMUFS_NOT_FOUND) {
- if (*err) {
- PERR("error al obtener ultimo id");
- return id;
- }
id = emufs_idx_buscar_mayor_id_libre(efs, err);
if (*err) {
PERR("error al obtener id mayor");