1 /* vim: set noexpandtab tabstop=4 shiftwidth=4 wrap:
2 *----------------------------------------------------------------------------
4 *----------------------------------------------------------------------------
5 * This file is part of emufs.
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
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
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: dom may 30 04:54:53 ART 2004
22 * Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 *----------------------------------------------------------------------------
31 * Archivo temporal con un fragmento ordenado del archivo original.
33 * Implementación de un archivo temporal con un fragmento ordenado del archivo
34 * original utilizado para hacer el ordenamiento por fusión (merge sort).
38 #include "mergefile.h"
44 MERGEFILE* mergefile_new(size_t reg_size)
48 mf = malloc(sizeof(MERGEFILE));
53 if (!(mf->fp = tmpfile())) {
59 mf->reg_size = reg_size;
63 void mergefile_delete(MERGEFILE* mf)
68 if (mf->next) free(mf->next);
72 int mergefile_switch_to_input(MERGEFILE* mf)
77 /* retrocede al principio del archivo y obtiene el primer dato */
78 if (fseek(mf->fp, 0L, SEEK_SET)) return 0;
79 /* aloco memoria para el próximo */
80 if (!(mf->next = malloc(mf->reg_size))) return 0;
81 /* leo primer valor */
82 if (!fread(mf->next, mf->reg_size, 1, mf->fp)) {
89 int mergefile_push(MERGEFILE* mf, void* data)
93 return fwrite(data, mf->reg_size, 1, mf->fp);
96 void* mergefile_pop(MERGEFILE* mf)
101 /* Si no hay más, devuelvo 0 */
102 if (!mf->next) return 0;
104 /* aloco memoria para el próximo */
105 if (!(mf->next = malloc(mf->reg_size))) {
109 /* obtiene dato, si no hay más, se activa el flag */
110 if (!fread(mf->next, mf->reg_size, 1, mf->fp)) {
117 void* mergefile_peek(MERGEFILE* mf)
124 int mergefile_has_more(MERGEFILE* mf)
128 return mf->next != 0;