]> git.llucax.com Git - z.facultad/75.06/emufs.git/blob - emufs/tipo2.c
* Actualizo API en la GUI
[z.facultad/75.06/emufs.git] / emufs / tipo2.c
1 /* vim: set noexpandtab tabstop=4 shiftwidth=4:
2  *----------------------------------------------------------------------------
3  *                                  emufs
4  *----------------------------------------------------------------------------
5  * This file is part of emufs.
6  *
7  * emufs is free software; you can redistribute it and/or modify it under the
8  * terms of the GNU General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option) any later
10  * version.
11  *
12  * emufs is distributed in the hope that it will be useful, but WITHOUT ANY
13  * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14  * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
15  * details.
16  *
17  * You should have received a copy of the GNU General Public License along
18  * with emufs; if not, write to the Free Software Foundation, Inc., 59 Temple
19  * Place, Suite 330, Boston, MA  02111-1307  USA
20  *----------------------------------------------------------------------------
21  * Creado:  Fri Apr 10 17:10:00 ART 2004
22  * Autores: Alan Kennedy <kennedya@3dgames.com.ar>
23  *----------------------------------------------------------------------------
24  *
25  * $Id: tipo3.c 85 2004-04-08 23:39:28Z sagar $
26  *
27  */
28
29 /***************************************************************/
30 /* Implementación del Tipo Archivo 2: Registros Variables, Sin */
31 /* Bloques at all.                                             */
32 /***************************************************************/
33
34 #include "tipo2.h"
35 #include "idx.h"
36 #include "fsc.h"
37 #include "did.h"
38
39 /**********************************************************************/
40 /* EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr,    */
41 /*                                 EMUFS_REG_SIZE n_RegSize)          */
42 /* Objetivo: Grabar un registro en un archivo del Tipo 2.             */
43 /* Parametros: EMUFS *efs // Struct con handlers + info del openfile. */
44 /*             void *ptr // Puntero al buffer (registro) a guardar    */
45 /*             EMUFS_REG_SIZE n_RegSize // Size del reg en cuestion   */
46 /**********************************************************************/
47 EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n_RegSize, int* err)
48 {
49         EMUFS_REG_ID n_IdReg;
50         EMUFS_FREE n_FreeSpace;
51         EMUFS_OFFSET n_WrtOffset,n_RegOffset;
52         unsigned long int n_FisicSize;
53         FILE *f_data;
54         char name_f[255];
55         
56         /* Armamos el filename del archivo de datos */
57         strcpy(name_f,efs->nombre);
58         strcat(name_f,".dat");
59         
60         if ( (f_data = fopen(name_f,"a+"))==NULL ) return -1; /*ERROR*/
61         
62         /* Obtengo un offset en donde iniciar la escritura de mi registro */
63         /* de manera segura (habra espacio suficiente) */
64         n_FisicSize = sizeof(EMUFS_REG_ID)+sizeof(EMUFS_REG_SIZE)+n_RegSize;
65         n_WrtOffset = emufs_fsc_buscar_lugar(efs,n_FisicSize,&n_FreeSpace);
66         printf("tipo2.c >> Searching FSC: Offset = %lu FSpace: %lu\n", n_WrtOffset, n_FreeSpace);
67         
68         /* Si no encontre un gap, entonces escribo el registro al final */
69         if (n_WrtOffset == -1) {                       
70                 
71                 /* Obtengo un ID libre para el registro y luego grabo a disco */
72         n_IdReg = emufs_tipo2_get_id(efs);
73                 fseek(f_data, 0, SEEK_END);
74                 n_RegOffset = ftell(f_data);
75
76                 /* Escribo [RegId]|[RegSize]|[RegData] */
77                 fwrite(&n_IdReg,sizeof(EMUFS_REG_ID),1,f_data);
78                 fwrite(&n_RegSize,sizeof(EMUFS_REG_SIZE),1,f_data);
79                 fwrite(ptr,n_RegSize,1,f_data);
80                                 
81                 /* Bye */
82                 printf("Tipo2.c >> RegNr: %lu with FisicSize: %lu inserted at Offset: %lu\n",n_IdReg,n_FisicSize,n_RegOffset);
83                 fclose(f_data);
84                 
85         } else {
86                 
87         }
88                 
89         /* Finalmente, actualizamos el indice de registros (offsets) */
90         emufs_idx_agregar(efs,n_IdReg,n_RegOffset);
91                 
92         return n_IdReg;
93 }
94
95 /**********************************************************************/
96 /* int emufs_tipo2_borrar_registro(EMUFS *efs, EMUFS_REG_ID n_IdReg)  */
97 /* Objetivo: Borra un registro determinado y actualiza los archivos   */
98 /*           de Posicion Relativa (Indice-Offset) y el de Gaps        */
99 /* Parametros: EMUFS *efs // Struct con handlers + info del openfile. */
100 /*             EMUFS_REG_ID n_IdReg // Id del registro a eliminar.    */
101 /**********************************************************************/
102 int emufs_tipo2_borrar_registro(EMUFS *efs, EMUFS_REG_ID n_IdReg)
103 {       
104         FILE *f_data;
105         char name_f[255];
106         EMUFS_OFFSET n_RegOffset,n_RegSize;
107          
108         /* Obtenemos el offset donde arranca el registro */
109         if ((n_RegOffset = emufs_idx_buscar_registro(efs,n_IdReg)) != -1)
110           printf("tipo2.c >> Searching Reg %lu...Found at offset: %lu\n",n_IdReg,n_RegOffset);
111         else 
112           return -1;
113         
114         /* Obtenemos el Size del Registro en cuestion y hacemos un dummfill*/
115         emufs_tipo2_get_regsize(efs,n_RegOffset,&n_RegSize);
116         printf ("tipo2.c >> About to delete Reg %lu of Size: %lu\n",n_IdReg,n_RegSize);
117         emufs_tipo2_dummyfill(efs,n_RegOffset,n_RegSize);
118         
119         /* Agregamos el GAP en el archivo de FSC, el cual hara un merge con */
120         /* otro GAP por delante y/o por detras en caso de hayarlo. */
121         emufs_fsc_agregar_gap(efs,n_RegOffset,n_RegSize+sizeof(EMUFS_REG_ID)+sizeof(EMUFS_REG_SIZE));
122         /* Borramos el registro del indice de posiciones relativas */
123         /*emufs_idx_borrar(efs,n_IdReg);*/
124         
125         return(0);
126 }
127
128 /**********************************************************************/
129 /* int emufs_tipo2_get_regsize(EMUFS *efs, EMUFS_OFFSET n_RegPos,     */
130 /*                             EMUFS_REG_SIZE *n_RegSize)             */
131 /* Objetivo: Devuelve el tamanio de un registro, dado su init offset  */
132 /* Parametros: EMUFS *efs // Struct con handlers + info del openfile. */
133 /*             EMUFS_OFFSET n_RegPos // Offset al inicio del registro */
134 /*             EMUFS_REG_SIZE *n_RegSize // Size to lookup and return */
135 /**********************************************************************/
136 int emufs_tipo2_get_regsize(EMUFS *efs, EMUFS_OFFSET n_RegPos, EMUFS_REG_SIZE *n_RegSize)
137 {
138     FILE *f_data;
139         char name_f[255];
140
141     /* Armamos el filename del archivo de datos */
142         strcpy(name_f,efs->nombre);
143         strcat(name_f,".dat");
144
145     if ((f_data = fopen(name_f,"r+")) == NULL) return -1; /* ERROR */
146         fseek(f_data,n_RegPos+sizeof(EMUFS_REG_ID),SEEK_SET);
147         fread(n_RegSize,sizeof(EMUFS_REG_SIZE),1,f_data);               
148         fclose(f_data);
149         
150         return (0);
151 }
152
153 /**********************************************************************/
154 /* int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET n_RegPos,       */
155 /*                           EMUFS_REG_SIZE n_Amount                  */
156 /* Objetivo: Pisa con basura lo que es hasta el momento un reg en     */
157 /*           el disco para indicar su borrado (Debug Purposes Only).  */
158 /* Parametros: EMUFS *efs // Struct con handlers + info del openfile. */
159 /*             EMUFS_OFFSET n_RegPos // Offset al inicio del registro */
160 /*             EMUFS_REG_SIZE *n_Amount // Size to lookup and return  */
161 /**********************************************************************/
162 int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET n_RegPos, EMUFS_REG_SIZE n_Amount)
163 {
164     FILE *f_data;
165         char name_f[255];
166     void *dummyfill;
167         void *ptr_cur;
168         unsigned long n_FillSize,n_count;
169         
170     /* Armamos el filename del archivo de datos */
171         strcpy(name_f,efs->nombre);
172         strcat(name_f,".dat");
173
174     if ((f_data = fopen(name_f,"r+")) == NULL) return -1; /* ERROR */
175         
176         /* Preparo el garbage y se lo tiro encima */
177         n_FillSize = n_Amount+sizeof(EMUFS_REG_ID)+sizeof(EMUFS_REG_SIZE);
178         dummyfill = (char*)malloc(n_FillSize);
179         ptr_cur = dummyfill;
180         for (n_count = 0; n_count < n_FillSize; ++n_count) memcpy(ptr_cur+n_count,"#",1);
181         fseek(f_data,n_RegPos,SEEK_SET);
182         fwrite(dummyfill,n_FillSize,1,f_data);
183         fclose(f_data);
184         
185         /* printf("Dummy Fill: %s\n",dummyfill); */ /*Uncomment to check */
186         
187         return (0);
188 }
189
190 /**********************************************************************/
191 /* EMUFS_REG_ID emufs_tipo2_get_id(EMUFS *efs)                        */
192 /* Objetivo: Devuelve un Id apropiado y disponible para un nuevo reg  */
193 /* Parametros: EMUFS *emu // Struct con handlers + info del openfile. */
194 /**********************************************************************/
195 EMUFS_REG_ID emufs_tipo2_get_id(EMUFS *efs)
196 {
197         EMUFS_REG_ID n_RegId;
198
199         /* Si no se hallo un id libre, entonces debo usar el maximo + 1 */
200         if ( (n_RegId = emufs_did_get_last(efs)) == -1 )
201                 n_RegId = emufs_idx_buscar_mayor_id(efs);
202         
203         return n_RegId; 
204 }