- /* 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) + (cant_bloques-1)*2);
- 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; i<cant_bloques; i++) {
- err = 0;
- block = (char*)emufs_tipo1_leer_bloque(efs, block_id+i, &err);
- /* Solo grabo el header del primer pedazo! */
- memcpy(chunk_ptr, "<>", 2);
- chunk_ptr += 2;
- memcpy(chunk_ptr, block+sizeof(EMUFS_TIPO1_REG_HEADER), efs->tam_bloque-sizeof(EMUFS_TIPO1_REG_HEADER));
- chunk_ptr += efs->tam_bloque-sizeof(EMUFS_TIPO1_REG_HEADER);
- free(block);
- }
- /* Todo listo! */
- break;
+ /* posición del comienzo del registro, incluye cabecera */
+ *pos = offset - sizeof(EMUFS_TIPO1_REG_HEADER);
+ *size = efs->tam_bloque; /* tamaño del bloque leido */
+ return block; /* devuelvo el puntero al bloque */