X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/6726e0114193106e50efc3576109f03a65817f41..71026445ea6cd499c9f8d194ddbdc9607665a719:/emufs/tipo3.c diff --git a/emufs/tipo3.c b/emufs/tipo3.c index 8f56f84..c287cb4 100644 --- a/emufs/tipo3.c +++ b/emufs/tipo3.c @@ -400,7 +400,7 @@ void* emufs_tipo3_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE if (emu->tam_reg < emu->tam_bloque) { /* Aca estoy en el caso de que 1 registro entra en 1 solo bloque */ block = emufs_idx_buscar_registro(emu,ID); - if ( block == EMUFS_NOT_FOUND ){ + if ( block == EMUFS_NOT_FOUND ) { return NULL; } if ((bloque = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) { @@ -431,13 +431,14 @@ void* emufs_tipo3_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE if ( block == EMUFS_NOT_FOUND ){ return NULL; } - cant_bloques = emu->tam_reg / emu->tam_bloque + 1; + cant_bloques = emu->tam_reg / (emu->tam_bloque - sizeof(EMUFS_REG_ID))+1; *size = emu->tam_bloque*cant_bloques + cant_bloques*2 - sizeof(EMUFS_REG_ID)*(cant_bloques-1); bloque = (char *)malloc(*size); cur = bloque; *pos = 0; /* El bloque 0 va completo */ + err = 0; if ((tmp = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) { /* Oops! ... un bloque no existe, todo mal! */ free(bloque); @@ -451,6 +452,7 @@ void* emufs_tipo3_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE /* En resto de los bloques no pongo el ID porque ya esta en el primero */ for(i=1; i