X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/008189ea62c4d3800769f00a304f95cc454102b3..e71b2f6ba15c4035c6fb10526b4ffd29d44b0ba2:/emufs/emufs.c diff --git a/emufs/emufs.c b/emufs/emufs.c index e789fa7..3adab5e 100644 --- a/emufs/emufs.c +++ b/emufs/emufs.c @@ -54,9 +54,11 @@ typedef struct _data_indices_ { INDICE_TIPO_DATO tipo_dato; unsigned int offset; unsigned int tam_bloque; + int str_offset; } t_Indice; -int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO tipo, INDICE_TIPO_DATO tipo_dato, unsigned int offset, unsigned int tam_bloque); +int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO tipo, INDICE_TIPO_DATO tipo_dato, unsigned int offset, unsigned int tam_bloque, int str_offset); +int cargar_indices(EMUFS *emu); char *str_dup(const char *s); @@ -255,7 +257,7 @@ EMUFS *emufs_abrir(const char *filename) fread(&tipo, sizeof(EMUFS_Tipo), 1, fp); /* Si no es un tipo conocido, sale. */ - if ((tipo != T1) && (tipo != T2) && (tipo != T3)) { + if ((tipo != T1) && (tipo != T2) && (tipo != T3) && (tipo != T4) && (tipo != T5)) { fclose(fp); return NULL; } @@ -273,6 +275,7 @@ EMUFS *emufs_abrir(const char *filename) case T1: /* Lee cabeceras propias. */ if (!fread(&(efs->tam_bloque), sizeof(EMUFS_BLOCK_SIZE), 1, fp)) { + PERR("ERROR Tipo1 no se pudo leer cabecera"); free(efs->nombre); free(efs); fclose(fp); @@ -293,6 +296,7 @@ EMUFS *emufs_abrir(const char *filename) if ((!fread(&(efs->tam_bloque), sizeof(EMUFS_BLOCK_SIZE), 1, fp)) || (!fread(&(efs->tam_reg), sizeof(EMUFS_REG_SIZE), 1, fp))) { + PERR("ERROR Tipo3 no se pudo leer header"); free(efs->nombre); free(efs); fclose(fp); @@ -324,8 +328,12 @@ EMUFS *emufs_abrir(const char *filename) } /* Asigna punteros a funciones. */ emufs_tipo5_inicializar(efs); + default: + PERR("EMUFS TIPO NO SOPORTADO"); } + /* finalmente cargo la data de los indices */ + cargar_indices(efs); fclose(fp); return efs; } @@ -341,7 +349,7 @@ int emufs_destruir(EMUFS *e) while (cur) { del = cur; cur = cur->sig; - emufs_indice_destruir(e, cur); + emufs_indice_destruir(e, del); } free(e->nombre); @@ -425,7 +433,6 @@ int emufs_agregar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDIC /* y que no exista un indice primario */ PERR("Agregando indice"); tmp = emu->indices; - PERR("IGUALE"); while (tmp) { if (strcmp(tmp->nombre, nombre)==0) { error = 1; @@ -454,13 +461,14 @@ int emufs_agregar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDIC tmp = emufs_indice_crear(emu, nombre, funcion, tipo, tipo_dato, offset, tam_bloque, str_offset); /* Guardo la info del indice para poder abrir despues el archivo */ - guardar_indice(emu, nombre, funcion, tipo, tipo_dato, offset, tam_bloque); + guardar_indice(emu, nombre, funcion, tipo, tipo_dato, offset, tam_bloque, str_offset); if (tmp == NULL) { PERR("NO SE PUDO CREAR INDICE!!!"); return 0; } + tmp->sig = NULL; if (emu->indices==NULL) emu->indices = tmp; else { @@ -494,7 +502,7 @@ INDICE_DATO *emufs_buscar_registros(EMUFS *emu, char *indice, char *data, int *c return tmp->buscar_entradas(tmp, k, cant); } -int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO tipo, INDICE_TIPO_DATO tipo_dato, unsigned int offset, unsigned int tam_bloque) +int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO tipo, INDICE_TIPO_DATO tipo_dato, unsigned int offset, unsigned int tam_bloque, int str_offset) { char filename[100]; FILE *fp; @@ -520,6 +528,7 @@ int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO indices[cant].tipo_dato = tipo_dato; indices[cant].offset = offset; indices[cant].tam_bloque = tam_bloque; + indices[cant].str_offset = str_offset; fseek(fp, SEEK_SET, 0); cant++; @@ -530,6 +539,57 @@ int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO return 1; } +int cargar_indices(EMUFS *emu) +{ + char filename[100]; + FILE *fp; + int cant, i; /* cantidad de indices hasta el momento */ + t_Indice *indices; + + sprintf(filename, "%s.info", emu->nombre); + fp = fopen(filename, "r"); + PERR("Abri info"); + PERR(filename); + if (fp == NULL) { + PERR("No se pudo"); + return 0; + } + + emu->indices = NULL; + fread(&cant, 1, sizeof(int), fp); + if (cant == 0) { + PERR("NO HAY INDICES EN ESTE ARCHIVO"); + return 1; + } + indices = malloc(cant*sizeof(t_Indice)); + fread(indices, cant, sizeof(t_Indice), fp); + fclose(fp); + + /* Leo */ + for(i=0; iindices==NULL) + emu->indices = tmp; + else { + tmp->sig = emu->indices; + emu->indices = tmp; + } + } + + free(indices); + return 1; +} + /*crea un bloque y devuelve en numero del mismo*/ EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu) { @@ -551,9 +611,11 @@ EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu) memset(dummy, 0, emu->tam_bloque); fwrite(dummy, emu->tam_bloque, 1, fp); switch(emu->tipo){ - case T1: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; + case T4: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; + break; + case T5: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE)-sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; break; - case T3: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE)-sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; + default: num = 0; } fclose(fp); free(dummy); @@ -579,11 +641,13 @@ EMUFS_BLOCK_ID emufs_get_new_block_number(EMUFS *emu) return -1; } switch(emu->tipo){ - case T1: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE))/emu->tam_bloque; + case T4: 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; break; - case T3: num = (ftell(fp)-sizeof(EMUFS_Tipo)-sizeof(EMUFS_BLOCK_SIZE)-sizeof(EMUFS_REG_SIZE))/emu->tam_bloque; + case T5: 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; + break; + default: num = 0; } fclose(fp); return num;