]> git.llucax.com Git - z.facultad/75.06/emufs.git/blob - emufs/b_plus_test.c
2acaee5cfbd1536dd232804c11379aedda3c4e87
[z.facultad/75.06/emufs.git] / emufs / b_plus_test.c
1
2 #include "indices.h"
3 #include "indice_bplus.h"
4
5 int main(int argc, char* argv[]) {
6
7 /* Locals */
8 INDEX_DAT querydata;
9 int i = 0;
10 int exitcode = 0;
11 /*NODO_B_PLUS *memnodo;*/
12
13 /* Creamos un handler EMUFS, luego un Indice B+ y testing... */
14 INDICE indice;
15 indice.tam_bloque = SIZE_B_PLUS_HEADER + sizeof(int)*5 + sizeof(int)*6;
16 indice.filename = "idxbplus_primary.idx";
17 printf("\nTam Nodo: %i  Size Claves: %i  Size_Hijos: %i\n",indice.tam_bloque,indice.size_claves,indice.size_hijos);
18 emufs_b_plus_crear(&indice);
19         
20 for (i=1;i<34;i = i*2)
21 {       
22 printf("Insertando clave %i\n",i);
23 querydata.num_bloque = floor(i/2)+3;
24 querydata.clave.i_clave = i;
25 emufs_b_plus_insertar(&indice,&querydata);
26 }
27
28 /* NOTA: Deberia devolver el mismo 104 y Exitcode = -1 */
29 querydata.num_bloque = 104;
30 querydata.clave.i_clave = 0;
31 exitcode = emufs_b_plus_get_bloque(&indice,&querydata,0);
32 printf("Numero de bloque donde grabar clave 0: %i\n",(int)(querydata.num_bloque));
33 printf("Exit Code del get bloque: %i\n",exitcode);
34
35 /* NOTA: Deberia devolver un numero de bloque X y Exitcode = 0 */
36 querydata.num_bloque = 104;
37 querydata.clave.i_clave = 25;
38 exitcode = emufs_b_plus_get_bloque(&indice,&querydata,0);
39 printf("Numero de bloque donde grabar clave 25: %i\n",(int)(querydata.num_bloque));
40 printf("Exit Code del get bloque: %i\n",exitcode);
41
42 /*
43 querydata.num_bloque = 2;
44 querydata.clave.i_clave = 7;
45 b_plus_insertar(&indice,&querydata);
46
47 querydata.num_bloque = 7;
48 querydata.clave.i_clave = 5;
49 b_plus_insertar(&indice,&querydata);
50
51 querydata.num_bloque = 5;
52 querydata.clave.i_clave = 3;
53 b_plus_insertar_clave(&indice,&querydata);
54
55 querydata.num_bloque = 8;
56 querydata.clave.i_clave = 63;
57 b_plus_insertar(&indice,&querydata);
58
59 num_node = 0;
60 memnodo = b_plus_leer_nodo(&indice, num_node);
61         printf("Dumping Node_%i\n",num_node);
62         printf("Nivel: %i  Cant Claves: %i\n",memnodo->nivel,memnodo->cant_claves);
63         printf("Claves:");
64         for (i = 0; i < indice.size_claves/sizeof(int); ++i) printf(" %i",memnodo->claves[i]);
65         printf("\nHijos:");
66         for (i = 0; i < indice.size_hijos/sizeof(int); ++i) printf(" %i",memnodo->hijos[i]);
67         printf("\nEnd Dump\n"); 
68 free(memnodo);
69         
70 querydata.num_bloque = 54;
71 querydata.clave.i_clave = 1;
72 b_plus_insertar(&indice, &querydata);
73
74 querydata.num_bloque = 12;
75 querydata.clave.i_clave = 2;
76 b_plus_insertar(&indice, &querydata);
77
78 querydata.num_bloque = 14;
79 querydata.clave.i_clave = 0;
80 b_plus_insertar(&indice, &querydata);
81
82 querydata.num_bloque = 22;
83 querydata.clave.i_clave = 4;
84 b_plus_insertar(&indice, &querydata);
85
86 querydata.num_bloque = 6;
87 querydata.clave.i_clave = 100;
88 b_plus_insertar(&indice, &querydata);*/
89 return 0;
90
91 }