]> git.llucax.com Git - z.facultad/75.06/emufs.git/blob - emufs/idx.c
Se agregan cabeceras y se expanden keywords de svn.
[z.facultad/75.06/emufs.git] / emufs / idx.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:  jue abr  8 18:10:35 ART 2004
22  * Autores: Nicolás Dimov <sagardua@uolsinectis.com.ar>
23  *----------------------------------------------------------------------------
24  *
25  * $Id$
26  *
27  */
28
29 /** \file
30  *
31  * Manejo de archivos de índice de registros.
32  * 
33  * Implementación del manejo de archivos de índice de registros.
34  *
35  */
36
37 #include "idx.h"
38 #include "tipo3.h"
39
40 int emufs_idx_buscar_mayor_id(EMUFS *emu)
41 {
42         int id, max = -1;
43         FILE *f_idx;    
44         BLOCK_REG_T reg;
45         char name_f_idx[255];
46
47         strcpy(name_f_idx,emu->nombre);
48         strcat(name_f_idx,".idx");
49
50         if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
51         while ( !feof(f_idx) ){
52                 /* Me aseguro de leer la cantidad de bytes correcta */
53                 if (fread(&reg,sizeof(BLOCK_REG_T),1,f_idx) != 1) continue;
54                 if ( reg.id_reg >= max ) 
55                         max = reg.id_reg;
56         }
57         id = max+1;
58         fclose(f_idx);
59
60         return id;      
61 }