X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/c7eb11f923b2c6b0b7bddce01177d381511e0e8f..b7e442a0e29d6f54ce1287a9fe407fedb52de949:/emufs/tipo1.c diff --git a/emufs/tipo1.c b/emufs/tipo1.c index 0381d3b..ffca191 100644 --- a/emufs/tipo1.c +++ b/emufs/tipo1.c @@ -462,10 +462,7 @@ int emufs_tipo1_borrar_registro(EMUFS* efs, CLAVE k, INDICE_DATO dato1) /* si es necesario desplazar */ if (offset < offset_reg_end) { /* muevo la porción de bloque a izquierda */ - /* XXX Este memcpy() puede copiar regiones de memoria que - * se superponen, si copia de principio a fin y byte a byte - * no debería haber problema */ - memcpy(block + offset, block + offset_reg_end, + memmove(block + offset, block + offset_reg_end, efs->tam_bloque - offset_reg_end); /* rellena el espacio libre con ceros para la GUI */ memset(block + efs->tam_bloque - offset_reg_end - orig_fs + offset, @@ -756,7 +753,7 @@ int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, in EMUFS_REG_SIZE tam_reg, move_size; INDEX_DAT query; EMUFS_FREE fs; - char *bloque, *aux, *new_bloque; + char *bloque = 0, *aux, *new_bloque = 0; int cant_reg, i, result, dif; /*le asigno un posible numero de bloque para el caso en que no encuentre donde meterlo*/ @@ -870,6 +867,8 @@ int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, in clave = grabar_ordenado_en_bloque(emu,ptr,size,new_bloque,query.num_bloque, emu->tam_bloque-move_size,err); if(*err != 0){ PERR("NO SE PUDO GRABAR ORDENADO"); + free(new_bloque); + free(bloque); return -1; } /*actualizo el arbol con la nueva clave*/ @@ -879,6 +878,8 @@ int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, in return 0; } } + if (new_bloque) free(new_bloque); + if (bloque) free(bloque); return 0; }