*/
#include "tipo3.h"
+#include <unistd.h>
+#include <sys/types.h>
+#include <stdio.h>
+#include <string.h>
/** Leo un registro del archivo, devuelve cero si no lo encuentra.**/
void* emufs_tipo3_leer_registro(EMUFS *emu, EMUFS_REG_ID ID,
registro = (char*) malloc(emu->tam_reg);
if (registro == NULL) {
/* TODO Manejo de errores */
- free(bloque);
PERR("No hay memoria");
*err = 2; /* EMUFS_ERROR_OUT_OF_MEMORY */
return NULL;
/* TODO Manejo de errores, queda en el codigo de error lo que devolvio
* emufs_tipo3_leer_bloque() */
PERR("no se pudo leer el bloque");
+ free(registro);
return NULL; /*No se pudo leer el bloque*/
}
ID_aux = -1;
}
free(bloque);
}
-
+
return registro;
}
EMUFS_BLOCK_SIZE cant;
FILE *file;
char name_f[255];
- char* bloque;
+ char* bloque = NULL;
int cant_bloques, resto, i=0, lugar;
strcpy(name_f,emu->nombre);
/*grabo el bloque en el archivo*/
if ( emufs_tipo3_grabar_bloque(emu, bloque, num_bloque+i) != 0) {
PERR("error al grabar bloque");
+ if (bloque) free(bloque);
return -1; /* se produjo un error */
}
resto = emu->tam_reg;
if ( emufs_fsc_agregar(emu, num_bloque, fs - resto - sizeof(EMUFS_REG_ID) ) != 0 ) {
fclose(file);
- if (bloque != NULL) free(bloque);
+ if (bloque) free(bloque);
return -1;
}
} else {
resto = emu->tam_reg - i*(emu->tam_bloque - sizeof(EMUFS_REG_ID));
if ( emufs_fsc_agregar(emu, num_bloque+i, fs-resto) !=0 ){
fclose(file);
- if (bloque != NULL) free(bloque);
+ if (bloque) free(bloque);
return -1;
}
}
if ( i == 0 ){
if ( emufs_idx_agregar(emu, ID_aux, num_bloque) != 0 ){
- if (bloque != NULL) free(bloque);
+ if (bloque) free(bloque);
return -1;
}
}
}
}
- free(bloque);
+ if (bloque) free(bloque);
return ID_aux;
}
}
emufs_tipo3_borrar_registro(emu, i);
ID_aux = emufs_tipo3_grabar_registro(emu, reg, emu->tam_reg, &err);
+ free(reg);
i++;
}
/*tengo que truncar el archivo*/
if(emu->tam_bloque<emu->tam_reg-sizeof(EMUFS_REG_ID)) block_id = block_id/2;
if (emufs_fsc_truncate(emu, block_id)!= 0)
PERR("NO TURNQUE EL FSC");
- free(reg);
}
+
+void emufs_tipo3_leer_bloque_raw(EMUFS *efs, EMUFS_BLOCK_ID id, char **actual, char **anterior, char **siguiente, EMUFS_BLOCK_SIZE *size1, EMUFS_BLOCK_SIZE *size2, EMUFS_BLOCK_SIZE *size3)
+{
+ int err;
+ (*actual) = emufs_tipo3_leer_bloque(efs, id, &err);
+ (*anterior) = emufs_tipo3_leer_bloque(efs, id-1, &err);
+ (*siguiente) = emufs_tipo3_leer_bloque(efs, id+1, &err);
+ if (!(*anterior)) {
+ (*anterior) = (char *)malloc(efs->tam_bloque);
+ memset(*anterior, 0, efs->tam_bloque);
+ }
+ if (!(*siguiente)) {
+ (*siguiente) = (char *)malloc(efs->tam_bloque);
+ memset(*siguiente, 0, efs->tam_bloque);
+ }
+ (*size1) = (*size2) = (*size3) = efs->tam_bloque;
+}
+