From: Ricardo Markiewicz Date: Mon, 19 Apr 2004 01:06:23 +0000 (+0000) Subject: * Ahroa tambien anda el buscar por ID de registro en Ver Registro. X-Git-Tag: svn_import_r684~329 X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/commitdiff_plain/da69961f13b90ec03adc37376cfbdad42f23df0c?ds=sidebyside * Ahroa tambien anda el buscar por ID de registro en Ver Registro. --- diff --git a/emufs_gui/viewer.c b/emufs_gui/viewer.c index 9d7d0f3..9e2e0ad 100644 --- a/emufs_gui/viewer.c +++ b/emufs_gui/viewer.c @@ -281,7 +281,7 @@ void ver_registros(WINDOW *padre, int w, int h, int cual) char *data; /* Registros a mostrar en pantalla */ char codigo[50]; /* Variable para guardar el codigo actual para mandar a modificar */ EMUFS *fp; - int pos_actual, ancho_registro, offset, pos; + int pos_actual, ancho_registro, offset, pos, n, i; if (cual == 0) fp = emufs_abrir("articulos"); @@ -345,9 +345,20 @@ void ver_registros(WINDOW *padre, int w, int h, int cual) case 'B': dlg = newwin(4, 50, h/2-2, w/2-25); box(dlg, 0, 0); - indices_actual = preguntar_id(dlg, fp); - if (indices_actual < 0) indices_actual = 0; - if (indices_actual >= indices_total) indices_actual = indices_total - 1; + n = preguntar_id(dlg, fp); + /* Busco la posicion dentro del id */ + for(i=0; i< indices_total; i++) { + if (indices[i] == n) { + n = -1; /* LO ENCONTRE! */ + indices_actual = i; + break; + } + } + if (n == -1) { + if (data) free(data); + data = (char *)fp->leer_registro_raw(fp, indices[indices_actual], &size, &pos_actual); + data = procesar(fp, data, &size, &pos_actual, &ancho_registro); + } werase(dlg); wrefresh(dlg); delwin(dlg);