X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/15bf403f66891d89987a3a429b83a632fca74c5b..4c9396d05ddc6c73873d21f175e6b5bbd6f25993:/emufs/tipo3.c diff --git a/emufs/tipo3.c b/emufs/tipo3.c index 24153cb..0e428e1 100644 --- a/emufs/tipo3.c +++ b/emufs/tipo3.c @@ -141,6 +141,7 @@ EMUFS_REG_ID emufs_tipo3_grabar_registro(EMUFS *emu, void *ptr, EMUFS_REG_SIZE t if ( (file = fopen(name_f,"a+"))==NULL ) return -1; /*ERROR*/ /*crear un nuevo bloque en memoria */ bloque = (char*)malloc(emu->tam_bloque); + memset(bloque, 0, emu->tam_bloque); /* grabar el registro al principio del bloque */ /*tengo que buscar un ID valido para el nuevo registro*/ ID_aux = emufs_idx_get_new_id(emu, err); @@ -250,8 +251,10 @@ int emufs_tipo3_borrar_registro(EMUFS *emu, EMUFS_REG_ID ID) /*apunto al registro que voy a mover*/ ptr_mov = ptr_elim + emu->tam_reg + sizeof(EMUFS_REG_ID); - while ( ptr_mov < emu->tam_bloque ){ + while ( (ptr_mov+sizeof(EMUFS_REG_ID)+emu->tam_reg) < emu->tam_bloque ){ memcpy(bloque+ptr_elim, bloque+ptr_mov, sizeof(EMUFS_REG_ID)+emu->tam_reg); + /* Blanqueo el area que movi */ + memset(bloque+ptr_mov, 0, sizeof(EMUFS_REG_ID)+emu->tam_reg); ptr_elim = ptr_mov; ptr_mov += sizeof(EMUFS_REG_ID) + emu->tam_reg; } @@ -308,3 +311,43 @@ EMUFS_REG_ID emufs_tipo3_modificar_registro(EMUFS *emu, EMUFS_REG_ID id, void *d return emufs_tipo3_grabar_registro(emu, data, size, error); } +void* emufs_tipo3_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE *size, int *pos) +{ + char* bloque; + EMUFS_BLOCK_ID block; + EMUFS_REG_ID ID_aux; + EMUFS_BLOCK_SIZE iterador = 0; + int err; + + /*si existe, lo busco en el archivo de bloques*/ + block = emufs_idx_buscar_registro(emu,ID); /*me devuelve el nro de bloque al que pertenece el registro*/ + if ( block == EMUFS_NOT_FOUND ){ + PERR("No se encontro el bloque"); + return NULL; + } + if ((bloque = emufs_tipo3_leer_bloque(emu, block, &err)) == 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"); + return NULL; /*No se pudo leer el bloque*/ + } + + ID_aux = -1; + iterador = 0; + /* Busco el offset desde el comienzo desde donde arranca el registro + * buscado, para luego resaltarlo en al GUI + */ + while ( iterador < emu->tam_bloque ) { + memcpy(&ID_aux, bloque+iterador, sizeof(EMUFS_REG_ID)); + if ( ID_aux == ID ){ + *pos = iterador; + *size = emu->tam_bloque; + break; + } + iterador += sizeof(EMUFS_REG_ID); + iterador += emu->tam_reg; + } + + return bloque; +} +