]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/tipo3.c
* Se agrega un caracter (el .) para denotar el espacio libre en el registro
[z.facultad/75.06/emufs.git] / emufs / tipo3.c
index 24153cb43484eee962d0f96df17bac1baea89cb5..0e428e1e128305a6970ce7593ce9194052f5da16 100644 (file)
@@ -141,6 +141,7 @@ EMUFS_REG_ID emufs_tipo3_grabar_registro(EMUFS *emu, void *ptr, EMUFS_REG_SIZE t
                if ( (file = fopen(name_f,"a+"))==NULL ) return -1; /*ERROR*/
                /*crear un nuevo bloque en memoria */
                bloque = (char*)malloc(emu->tam_bloque);
+               memset(bloque, 0, emu->tam_bloque);
                /* grabar el registro al principio del bloque */
                /*tengo que buscar un ID valido para el nuevo registro*/
                ID_aux = emufs_idx_get_new_id(emu, err);
@@ -250,8 +251,10 @@ int emufs_tipo3_borrar_registro(EMUFS *emu, EMUFS_REG_ID ID)
        /*apunto al registro que voy a mover*/
        ptr_mov = ptr_elim + emu->tam_reg + sizeof(EMUFS_REG_ID);
        
-       while ( ptr_mov < emu->tam_bloque ){
+       while ( (ptr_mov+sizeof(EMUFS_REG_ID)+emu->tam_reg) < emu->tam_bloque ){
                memcpy(bloque+ptr_elim, bloque+ptr_mov, sizeof(EMUFS_REG_ID)+emu->tam_reg);
+               /* Blanqueo el area que movi */
+               memset(bloque+ptr_mov, 0, sizeof(EMUFS_REG_ID)+emu->tam_reg);
                ptr_elim = ptr_mov;
                ptr_mov += sizeof(EMUFS_REG_ID) + emu->tam_reg;
        }
@@ -308,3 +311,43 @@ EMUFS_REG_ID emufs_tipo3_modificar_registro(EMUFS *emu, EMUFS_REG_ID id, void *d
        return emufs_tipo3_grabar_registro(emu, data, size, error);
 }
 
+void* emufs_tipo3_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE *size, int *pos)
+{
+       char* bloque;
+       EMUFS_BLOCK_ID block;
+       EMUFS_REG_ID ID_aux;
+       EMUFS_BLOCK_SIZE iterador = 0;
+       int err;
+       
+       /*si existe, lo busco en el archivo de bloques*/
+       block = emufs_idx_buscar_registro(emu,ID); /*me devuelve el nro de bloque al que pertenece el registro*/
+       if ( block == EMUFS_NOT_FOUND ){
+               PERR("No se encontro el bloque");
+               return NULL;
+       }
+       if ((bloque = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) {
+               /* TODO Manejo de errores, queda en el codigo de error lo que devolvio
+                * emufs_tipo3_leer_bloque() */
+               PERR("no se pudo leer el bloque");
+               return NULL; /*No se pudo leer el bloque*/
+       }
+
+       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;
+       }
+       
+       return bloque;
+}
+