X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/c11646cc62f361d1bb7e9dd583f1ee9e11116082..c0e8d06063aac4b69ac6ba98a3e0e713a3a89b00:/emufs/tipo1.c diff --git a/emufs/tipo1.c b/emufs/tipo1.c index 0c3f32d..596f69a 100644 --- a/emufs/tipo1.c +++ b/emufs/tipo1.c @@ -184,41 +184,77 @@ void* emufs_tipo1_leer_registro(EMUFS* efs, EMUFS_REG_ID reg_id, return registro; } -/* @todo TODO hacer que soporte registros de más de un bloque */ -void* emufs_tipo1_leer_registro_raw(EMUFS *efs, EMUFS_REG_ID id, - EMUFS_REG_SIZE *size, int *pos) +void* emufs_tipo1_leer_registro_raw(EMUFS *efs, EMUFS_REG_ID id, EMUFS_REG_SIZE *size, int *pos) { + char *chunk_ptr; char* block; /* bloque leido (en donde está el registro a leer) */ + char* registro; /* registro a leer */ EMUFS_BLOCK_ID block_id; /* id del bloque en donde esta el registro a leer */ - EMUFS_BLOCK_SIZE offset; /* offset del bloque leído */ + EMUFS_BLOCK_SIZE offset, block_space; /* offset del bloque leído */ EMUFS_TIPO1_REG_HEADER curr_reg_header; /* cabecera del registro a leer */ - int err; + EMUFS_REG_SIZE cant_bloques; + int err, i; block_id = emufs_idx_buscar_registro(efs, id); if (block_id == EMUFS_NOT_FOUND) { + /* TODO Manejo de errores */ + PERR("Registro no encontrado"); + *pos = 0; + *size = 0; return NULL; } err = 0; if (!(block = (char*) emufs_tipo1_leer_bloque(efs, block_id, &err))) { + /* TODO Manejo de errores */ + PERR("no se pudo reservar memoria"); + *pos = 0; + *size = 0; return NULL; } /* Busco secuencialmente en el bloque el registro a leer */ offset = 0; do { - /* Copio la cabecera del registro. */ + /* Copio la cabecera del registro actual. */ memcpy(&curr_reg_header, block + offset, sizeof(EMUFS_TIPO1_REG_HEADER)); offset += sizeof(EMUFS_TIPO1_REG_HEADER); if (curr_reg_header.id == id) { - *pos = offset - sizeof(EMUFS_TIPO1_REG_HEADER); + /* tamaño máximo ultilizable para datos en un bloque */ + *pos = offset-sizeof(EMUFS_TIPO1_REG_HEADER); + block_space = efs->tam_bloque - sizeof(EMUFS_TIPO1_REG_HEADER); + /* tamaño de la porción de registro que se guarda */ + + cant_bloques = curr_reg_header.size / block_space + 1; + *size = cant_bloques*efs->tam_bloque; + registro = chunk_ptr = (char*) malloc(*size - (cant_bloques-1)*sizeof(EMUFS_TIPO1_REG_HEADER)); + if (registro == NULL) { + /* TODO Manejo de errores */ + free(block); + PERR("No hay memoria"); + *pos = 0; + *size = 0; + return NULL; + } + memcpy(registro, block, efs->tam_bloque); + chunk_ptr += efs->tam_bloque; + /* Copio los otros bloques, si los hay */ + free(block); + for(i=1; itam_bloque); + chunk_ptr += efs->tam_bloque; + free(block); + } + /* Todo listo! */ break; } /* Desplazo el offset */ offset += curr_reg_header.size; } while (offset < efs->tam_bloque); - (*size) = efs->tam_bloque; - return block; + return registro; } void* emufs_tipo1_leer_bloque(EMUFS* efs, EMUFS_BLOCK_ID block_id, int *err)