X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/ed3be466d29841cfb0bdb317935f1c4e25a7b8dc..403576c36285b22fe2e727c17d134b2e1c728dc0:/emufs/tipo3.c diff --git a/emufs/tipo3.c b/emufs/tipo3.c index 8e40113..02c6495 100644 --- a/emufs/tipo3.c +++ b/emufs/tipo3.c @@ -439,81 +439,38 @@ EMUFS_REG_ID emufs_tipo3_modificar_registro(EMUFS *emu, EMUFS_REG_ID id, void *d void* emufs_tipo3_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE *size, int *pos) { - char* bloque, *tmp, *cur; + char* bloque; EMUFS_BLOCK_ID block; EMUFS_REG_ID ID_aux; EMUFS_BLOCK_SIZE iterador = 0; - int err, cant_bloques, i; + int err; bloque = NULL; - 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 ) { - return NULL; - } - if ((bloque = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) { - return NULL; - } - - 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; - } - } else { - /* Junto todos los bloques que ocupa el registro y agrego un separador de bloques */ - /* Busco el primer bloque */ - block = emufs_idx_buscar_registro(emu,ID); - if ( block == EMUFS_NOT_FOUND ){ - return NULL; - } - 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); - return NULL; - } - memcpy(cur, tmp, emu->tam_bloque); - cur += emu->tam_bloque; -/* memcpy(cur, "<>", 2); - cur += 2;*/ - free(tmp); + /* 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 ) { + return NULL; + } + if ((bloque = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) { + return NULL; + } - /* En resto de los bloques no pongo el ID porque ya esta en el primero */ - for(i=1; itam_bloque-sizeof(EMUFS_REG_ID)); - cur += emu->tam_bloque - sizeof(EMUFS_REG_ID); -/* memcpy(cur, "<>", 2); - cur += 2;*/ - free(tmp); + 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; } - (*cur) = '\0'; + iterador += sizeof(EMUFS_REG_ID); + iterador += emu->tam_reg; } return bloque; } @@ -545,9 +502,7 @@ void emufs_tipo3_compactar(EMUFS *emu) ID_aux = emufs_tipo3_grabar_registro(emu, reg, emu->tam_reg, &err); free(reg); } - /*tengo que truncar el archivo*/ - /*bloques_vacios = emufs_fsc_get_cant_bloques_vacios(emu)-1; - */ + /*trunco el archivo sacando los bloques vacios*/ block_id = emufs_fsc_buscar_lugar(emu, emu->tam_bloque, &fs); size = sizeof(EMUFS_Tipo)+sizeof(EMUFS_REG_SIZE)+sizeof(EMUFS_BLOCK_SIZE)+block_id*emu->tam_bloque; if (truncate(name, size)!=0)