X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/8637995cdbd1c7d71825cc2e5e8d874de10135f6..d93ae34d3fee76767f36b232969d6810634ffc69:/emufs/emufs.c diff --git a/emufs/emufs.c b/emufs/emufs.c index 685f091..cd59b39 100644 --- a/emufs/emufs.c +++ b/emufs/emufs.c @@ -472,6 +472,7 @@ int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO fwrite(&cant, 1, sizeof(int), fp); fwrite(indices, cant, sizeof(t_Indice), fp); fclose(fp); + free(indices); return 1; } @@ -491,18 +492,19 @@ EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu) PERR("NO SE PUDO ABRIR EL ARCHIVO"); return -1; } - + dummy = (char*)malloc(emu->tam_bloque); memset(dummy, 0, emu->tam_bloque); fwrite(dummy, emu->tam_bloque, 1, fp); + printf("new_block ftell = %d\n", ftell(fp)); switch(emu->tipo){ - case T1: num = (ftell(fp)-sizeof(EMUFS_Tipo)+sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; + case T1: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; break; - case T3: num = (ftell(fp)-sizeof(EMUFS_Tipo)+sizeof(EMUFS_BLOCK_SIZE)+sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; + case T3: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE)-sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; } fclose(fp); free(dummy); - return num; + return num-1; } /*devuelve un numero de bloque siguiente al ultimo*/ @@ -510,21 +512,39 @@ EMUFS_BLOCK_ID emufs_get_new_block_number(EMUFS *emu) { FILE *fp; char name[255]; - EMUFS_BLOCK_ID num; + EMUFS_BLOCK_ID num=0; /* obtengo nombre del archivo */ strcpy(name, emu->nombre); strcat(name,".dat"); - - if ( (fp=fopen(name,"a+")) == NULL ){ + if ( (fp=fopen(name,"r")) == NULL ){ PERR("NO SE PUDO ABRIR EL ARCHIVO"); return -1; } + if ( fseek(fp, 0, SEEK_END)!=0 ){ + PERR("NO PUDE HACER EL SEEK"); + return -1; + } switch(emu->tipo){ - case T1: num = (ftell(fp)-sizeof(EMUFS_Tipo)+sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; + case T1: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; + if (ftell(fp) == sizeof(EMUFS_Tipo)+sizeof(EMUFS_BLOCK_SIZE)) num = 0; + PERR("PASE"); break; - case T3: num = (ftell(fp)-sizeof(EMUFS_Tipo)+sizeof(EMUFS_BLOCK_SIZE)+sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; + case T3: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE)-sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; + if (ftell(fp) == sizeof(EMUFS_Tipo)+sizeof(EMUFS_BLOCK_SIZE)+sizeof(EMUFS_REG_SIZE)) num = 0; } fclose(fp); - return num+1; + return num; +} + +INDICE *emufs_buscar_indice_por_nombre(EMUFS *emu, const char *nombre) +{ + INDICE *tmp; + + tmp = emu->indices; + while (tmp) { + if (strcmp(tmp->nombre, nombre) == 0) break; + tmp = tmp->sig; + } + return tmp; }