X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/9b22193b1d22efa0d41a313096a62666eddfb629..a666806d9361a2876a07941b8d2bb5c973e1557e:/emufs/tipo2.c diff --git a/emufs/tipo2.c b/emufs/tipo2.c index ad179bd..1fe6444 100644 --- a/emufs/tipo2.c +++ b/emufs/tipo2.c @@ -83,7 +83,6 @@ void *emufs_tipo2_leer_registro(EMUFS* efs, CLAVE clave, EMUFS_REG_SIZE* reg_siz reg_offset = dato.bloque; id_reg = dato.id; } else { - PERR("HAGO LECTURA DIRECTA"); id_reg = clave.i_clave; reg_offset = emufs_idx_buscar_registro(efs, id_reg); (*err) = 0; @@ -133,7 +132,6 @@ EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE r /* de manera segura (habra espacio suficiente) */ fisic_size = sizeof(EMUFS_REG_ID)+sizeof(EMUFS_REG_SIZE)+reg_size; wrt_offset = emufs_fsc_buscar_lugar(efs,fisic_size,&freespace); - fprintf(stderr, "tipo2.c >> Recording Reg > Searching FSC: Offset = %lu FSpace: %lu\n", wrt_offset, freespace); /* Si no encontre un gap, entonces escribo el registro al final */ if (wrt_offset == -1) { @@ -174,19 +172,16 @@ EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE r } /* Finalmente, actualizamos el indice de registros (offsets) */ - PERR("REGISTRO GRABADO; AGREGANDO A IDX"); emufs_idx_agregar(efs,id_reg,reg_offset); idx_data.id = id_reg; idx_data.bloque = reg_offset; - PERR("AGREGANDO A INDICES"); emufs_indice_agregar(efs->indices, (char *)ptr, idx_data); - PERR("LISTO"); return id_reg; } /* Borra un registro determinado y actualiza los archivos de Posicion Relativa (Indice-Offset) y el de Gaps */ -int emufs_tipo2_borrar_registro(EMUFS *efs, CLAVE k) +int emufs_tipo2_borrar_registro(EMUFS *efs, CLAVE k, INDICE_DATO dato1) { EMUFS_OFFSET reg_offset,reg_size; EMUFS_REG_ID id_reg; @@ -207,6 +202,7 @@ int emufs_tipo2_borrar_registro(EMUFS *efs, CLAVE k) if (id_reg == -1) return EMUFS_NOT_FOUND; + emufs_indice_borrar(efs->indices, k, dato1); /* Obtenemos el Size del Registro en cuestion y hacemos un dummyfill*/ emufs_tipo2_get_regsize(efs,reg_offset,®_size); emufs_tipo2_dummyfill(efs,reg_offset,reg_size); @@ -270,11 +266,9 @@ int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET reg_pos, EMUFS_REG_SIZE amoun } /* Realiza la actualizacin de un registro ya existente */ -EMUFS_REG_ID emufs_tipo2_modificar_registro(EMUFS *efs, EMUFS_REG_ID id, void *data, EMUFS_REG_SIZE size, int *error) +EMUFS_REG_ID emufs_tipo2_modificar_registro(EMUFS *efs, CLAVE k, void *data, EMUFS_REG_SIZE size, int *error, INDICE_DATO dato) { - CLAVE k; - k.i_clave = id; - emufs_tipo2_borrar_registro(efs, k); + emufs_tipo2_borrar_registro(efs, k, dato); return emufs_tipo2_grabar_registro(efs, data, size, error); }