]> git.llucax.com Git - z.facultad/75.06/emufs.git/commitdiff
Bugfix. En borrar_registro() se complica poner en cero la basura del final.
authorLeandro Lucarella <llucax@gmail.com>
Sun, 18 Apr 2004 22:24:15 +0000 (22:24 +0000)
committerLeandro Lucarella <llucax@gmail.com>
Sun, 18 Apr 2004 22:24:15 +0000 (22:24 +0000)
emufs/tipo1.c

index 73ea3e24a85d3bf42593434210cb3a66316b6eb5..a4f9de7932a2e528f2e863bd201a64ede6353038 100644 (file)
@@ -313,7 +313,9 @@ EMUFS_REG_ID emufs_tipo1_grabar_registro(EMUFS* efs, void* reg,
                emufs_tipo1_escribir_reg_chunk_en_memoria(block + efs->tam_bloque - fs,
                                header, chunk_ptr, chunk_size);
                /* rellena el espacio libre con ceros para la GUI */
                emufs_tipo1_escribir_reg_chunk_en_memoria(block + efs->tam_bloque - fs,
                                header, chunk_ptr, chunk_size);
                /* rellena el espacio libre con ceros para la GUI */
-               if (fs) memset(block + efs->tam_bloque - fs, 0, fs);
+               memset(block + efs->tam_bloque - fs + chunk_size
+                               + sizeof(EMUFS_TIPO1_REG_HEADER), 0,
+                               fs - chunk_size - sizeof(EMUFS_TIPO1_REG_HEADER));
                /* graba el bloque en el archivo */
                new_block_id = emufs_tipo1_grabar_bloque_fsc(efs, block, curr_block_id,
                                fs - sizeof(EMUFS_TIPO1_REG_HEADER) - chunk_size, err);
                /* graba el bloque en el archivo */
                new_block_id = emufs_tipo1_grabar_bloque_fsc(efs, block, curr_block_id,
                                fs - sizeof(EMUFS_TIPO1_REG_HEADER) - chunk_size, err);
@@ -429,8 +431,8 @@ int emufs_tipo1_borrar_registro(EMUFS* efs, EMUFS_REG_ID reg_id)
                                        memcpy(block + offset, block + offset_reg_end,
                                                efs->tam_bloque - offset_reg_end);
                                        /* rellena el espacio libre con ceros para la GUI */
                                        memcpy(block + offset, block + offset_reg_end,
                                                efs->tam_bloque - offset_reg_end);
                                        /* rellena el espacio libre con ceros para la GUI */
-                                       if (fs) memset(block + offset_reg_end, 0,
-                                                       efs->tam_bloque - offset_reg_end);
+                                       /* FIXME memset(block + offset_reg_end, 0,
+                                                       efs->tam_bloque - offset_reg_end);*/
                                }
                        }
                        /* guardo el bloque en disco (actualizando espacio libre) */
                                }
                        }
                        /* guardo el bloque en disco (actualizando espacio libre) */