]> git.llucax.com Git - z.facultad/75.06/emufs.git/commitdiff
pequeña reoganizacion
authorNicolás Dimov <ndimov@gmail.com>
Thu, 27 May 2004 04:54:55 +0000 (04:54 +0000)
committerNicolás Dimov <ndimov@gmail.com>
Thu, 27 May 2004 04:54:55 +0000 (04:54 +0000)
emufs/emufs.c
emufs/emufs.h
emufs/tipo1.c
emufs/tipo3.c
emufs/tipo3.h

index 0586999311cd71ebdad68700793712898567352f..685f091795290b29135a3c7391f138f06056d18d 100644 (file)
@@ -475,3 +475,56 @@ int guardar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO
        return 1;
 }
 
        return 1;
 }
 
+/*crea un bloque y devuelve en numero del mismo*/
+EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu)
+{
+       FILE *fp;
+       char name[255];
+       char *dummy;
+       EMUFS_BLOCK_ID num;
+       
+       /* obtengo nombre del archivo */
+       strcpy(name, emu->nombre);
+       strcat(name,".dat");
+       
+       if ( (fp=fopen(name,"a+")) == NULL ){
+               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);
+       switch(emu->tipo){
+               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;
+       }
+       fclose(fp);
+       free(dummy);
+       return num;
+}
+
+/*devuelve un numero de bloque siguiente al ultimo*/
+EMUFS_BLOCK_ID emufs_get_new_block_number(EMUFS *emu)
+{
+       FILE *fp;
+       char name[255];
+       EMUFS_BLOCK_ID num;
+       
+       /* obtengo nombre del archivo */
+       strcpy(name, emu->nombre);
+       strcat(name,".dat");
+
+       if ( (fp=fopen(name,"a+")) == NULL ){
+               PERR("NO SE PUDO ABRIR EL ARCHIVO");
+               return -1;
+       }
+       switch(emu->tipo){
+               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;
+       }
+       fclose(fp);
+       return num+1;
+}
index 5befe3638098bfa267ced5bbb7ed6f06644041c4..ad28d7075f4d269c0356f768a24ece2148094ce8 100644 (file)
@@ -177,4 +177,7 @@ int emufs_agregar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDIC
 
 INDICE_DATO *emufs_buscar_registros(EMUFS *emu, char *indice, char *data, int *cant);
 
 
 INDICE_DATO *emufs_buscar_registros(EMUFS *emu, char *indice, char *data, int *cant);
 
+EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu);
+
+EMUFS_BLOCK_ID emufs_get_new_block_number(EMUFS *emu);
 #endif /* _EMUFS_H_ */
 #endif /* _EMUFS_H_ */
index 0841612760627d344cfeeea4eec95a9dded6d5f9..049b47c036d7b405fdfb6bb205188a103cdab3b8 100644 (file)
@@ -727,53 +727,6 @@ int emufs_tipo1_block_jump(EMUFS* efs, FILE* fp, EMUFS_BLOCK_ID block_count)
        return EMUFS_OK;
 }
 
        return EMUFS_OK;
 }
 
-/*crea un bloque y devuelve en numero del mismo*/
-EMUFS_BLOCK_ID create_new_block(EMUFS *emu)
-{
-       FILE *fp;
-       char name[255];
-       char *dummy;
-       EMUFS_BLOCK_ID num;
-       
-       /* obtengo nombre del archivo */
-       strcpy(name, emu->nombre);
-       strcat(name,".dat");
-       
-       if ( (fp=fopen(name,"a+")) == NULL ){
-               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);
-       
-       num = (ftell(fp)-emufs_tipo1_header_size())/emu->tam_bloque;
-       fclose(fp);
-       free(dummy);
-       return num;
-}
-
-/*devuelve un numero de bloque siguiente al ultimo*/
-EMUFS_BLOCK_ID get_new_block_number(EMUFS *emu)
-{
-       FILE *fp;
-       char name[255];
-       EMUFS_BLOCK_ID num;
-       
-       /* obtengo nombre del archivo */
-       strcpy(name, emu->nombre);
-       strcat(name,".dat");
-
-       if ( (fp=fopen(name,"a+")) == NULL ){
-               PERR("NO SE PUDO ABRIR EL ARCHIVO");
-               return -1;
-       }
-       num = (ftell(fp)-emufs_tipo1_header_size())/emu->tam_bloque;
-       fclose(fp);
-       return num+1;
-}
-
 void emufs_tipo1_escribir_reg_chunk_en_memoria(char* dst,
                EMUFS_TIPO1_REG_HEADER header, char* reg, EMUFS_REG_SIZE reg_size)
 {
 void emufs_tipo1_escribir_reg_chunk_en_memoria(char* dst,
                EMUFS_TIPO1_REG_HEADER header, char* reg, EMUFS_REG_SIZE reg_size)
 {
@@ -797,7 +750,7 @@ void emufs_tipo1_leer_bloque_raw(EMUFS *efs, EMUFS_BLOCK_ID id, char **actual, c
 int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err)
 {
        CLAVE clave;
 int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err)
 {
        CLAVE clave;
-       EMUFS_BLOCK_ID num_bloque = get_new_block_number(emu); 
+       EMUFS_BLOCK_ID num_bloque = emufs_get_new_block_number(emu); 
        EMUFS_TIPO1_REG_HEADER header;
        EMUFS_REG_SIZE tam_reg, move_size;
        INDEX_DAT query;
        EMUFS_TIPO1_REG_HEADER header;
        EMUFS_REG_SIZE tam_reg, move_size;
        INDEX_DAT query;
@@ -847,7 +800,7 @@ int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, in
                        return -1;
                }
                /*hago lugar en el archivo para grabar*/
                        return -1;
                }
                /*hago lugar en el archivo para grabar*/
-               if ( num_bloque != create_new_block(emu) )      PERR("NUMEROS DE NUEVO BLOQUE DISTINTOS");
+               if ( num_bloque != emufs_create_new_block(emu) )        PERR("NUMEROS DE NUEVO BLOQUE DISTINTOS");
                /*grabo el bloque en el archivo*/ /* OJO CON LO DE FS = 0 */
                emufs_tipo1_grabar_bloque_fsc(emu, bloque, query.num_bloque, EMUFS_NOT_FOUND, err);
                /*agrego la clave al arbol*/
                /*grabo el bloque en el archivo*/ /* OJO CON LO DE FS = 0 */
                emufs_tipo1_grabar_bloque_fsc(emu, bloque, query.num_bloque, EMUFS_NOT_FOUND, err);
                /*agrego la clave al arbol*/
@@ -895,7 +848,7 @@ int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, in
                        memcpy(new_bloque+emu->tam_bloque, &dif, sizeof(int));
                        /*genero un nuevo espacio para un bloque en el archivo y lo cargo en query
                          la clave ya estaba en query desde antes*/
                        memcpy(new_bloque+emu->tam_bloque, &dif, sizeof(int));
                        /*genero un nuevo espacio para un bloque en el archivo y lo cargo en query
                          la clave ya estaba en query desde antes*/
-                       query.num_bloque = create_new_block(emu);
+                       query.num_bloque = emufs_create_new_block(emu);
                        /*inserto el nuevo registro en el nuevo bloque y obtengo la clave del menor*/
                        clave = grabar_ordenado_en_bloque(emu,ptr,size,new_bloque,query.num_bloque, emu->tam_bloque-move_size,err);
                        /*actualizo el arbol con la nueva clave*/
                        /*inserto el nuevo registro en el nuevo bloque y obtengo la clave del menor*/
                        clave = grabar_ordenado_en_bloque(emu,ptr,size,new_bloque,query.num_bloque, emu->tam_bloque-move_size,err);
                        /*actualizo el arbol con la nueva clave*/
index 24d2e72e5ea0e095615af0016df8d318a176b522..52e182df712aa7a659ef95b17d6d5e9a8ab9eec6 100644 (file)
@@ -585,7 +585,7 @@ void emufs_tipo3_leer_bloque_raw(EMUFS *efs, EMUFS_BLOCK_ID id, char **actual, c
        (*size1) = (*size2) = (*size3) = efs->tam_bloque;
 }
 
        (*size1) = (*size2) = (*size3) = efs->tam_bloque;
 }
 
-int emufs_tipo3_insertar_ordenado(EMUFS *emu, void *ptr, int *err)
+int emufs_tipo3_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err)
 {
        #ifdef ESTO_NO_ANDA_TODAVIA
        CLAVE clave, clave_aux;
 {
        #ifdef ESTO_NO_ANDA_TODAVIA
        CLAVE clave, clave_aux;
index cc005dde17fe17eab581812dc099fe239263791f..54fb03c2412d371c5217e2d8ea4d1e072ead00bc 100644 (file)
@@ -138,9 +138,9 @@ void emufs_tipo3_leer_bloque_raw(EMUFS *emu, EMUFS_BLOCK_ID block_id, char **act
 /** Inserta un registro ordenado segun el Arbol B+ lo indique
   * \param emu Esructura para manejar los archivos.
   * \param ptr Cadena de datos contenedora del registro.
 /** Inserta un registro ordenado segun el Arbol B+ lo indique
   * \param emu Esructura para manejar los archivos.
   * \param ptr Cadena de datos contenedora del registro.
-  * \param ind Indice del archivo.
   * \param err Codigo de error devuelto en caso de falla.
   */
   * \param err Codigo de error devuelto en caso de falla.
   */
-int emufs_tipo3_insertar_ordenado(EMUFS *emu, void *ptr, int *err);
+int emufs_tipo3_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err);
 
 
+int emufs_tipo3_eliminar_ordenado(EMUFS *emu, CLAVE clave, int *err);
 #endif /* _EMUFS_TIPO3_H_ */
 #endif /* _EMUFS_TIPO3_H_ */