]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs_gui/gui.c
* Arreglo un bug que hacia que se cuelgue la GUI.
[z.facultad/75.06/emufs.git] / emufs_gui / gui.c
index 7bebab5d98fe49876785050da4d1f080b6ab314c..ec90147567c7c9294ea0fce2de298ae85e9808ee 100644 (file)
@@ -22,7 +22,7 @@ void menu_articulos();
 WINDOW *msg_box(WINDOW *win, int w, int h, const char *format, ...);
 void msg_box_free(WINDOW *padre, WINDOW *win);
 
 WINDOW *msg_box(WINDOW *win, int w, int h, const char *format, ...);
 void msg_box_free(WINDOW *padre, WINDOW *win);
 
-typedef enum {PARAM_OK, SHOW_HELP, TIPO_NO_DEFINIDO, TIPO_INVALIDO} t_Param;
+typedef enum {PARAM_OK, SHOW_HELP, TIPO_NO_DEFINIDO, TIPO_INVALIDO, BLOQUE_NO_DEFINIDO} t_Param;
 
 /* Verifica Argumentos */
 t_Param param_ok(int argc, char *argv[])
 
 /* Verifica Argumentos */
 t_Param param_ok(int argc, char *argv[])
@@ -33,9 +33,11 @@ t_Param param_ok(int argc, char *argv[])
 
                if (strcmp(argv[i]+strlen(argv[i])-3, "xml") == 0) {
                        /* Luego del archivo XML debe seguir el tipo */
 
                if (strcmp(argv[i]+strlen(argv[i])-3, "xml") == 0) {
                        /* Luego del archivo XML debe seguir el tipo */
-                       if ((i+2)<argc) {
+                       if ((i+1)<argc) {
                                n = atoi(argv[i+1]);
                                if ((n < 1) || (n > 3)) return TIPO_INVALIDO;
                                n = atoi(argv[i+1]);
                                if ((n < 1) || (n > 3)) return TIPO_INVALIDO;
+                               if (((n == 1) || (n == 3)) && ((i+2)>=argc))
+                                       return BLOQUE_NO_DEFINIDO;
                        } else {
                                /* Ops, no hay mas parametros */
                                return TIPO_NO_DEFINIDO;
                        } else {
                                /* Ops, no hay mas parametros */
                                return TIPO_NO_DEFINIDO;
@@ -64,7 +66,10 @@ int main(int argc, char *argv[])
                        print_help(argv[0]);
                        return 0;
                case TIPO_NO_DEFINIDO:
                        print_help(argv[0]);
                        return 0;
                case TIPO_NO_DEFINIDO:
-                       printf("Falta parámetro requerido. Luego del nombre del archivo debe especificar el tipo de archivo\n");
+                       printf("Falta parámetro requerido.\nLuego del nombre del archivo debe especificar el tipo de archivo\n");
+                       return 1;
+               case BLOQUE_NO_DEFINIDO:
+                       printf("Falta parámetro requerido.\nLuego del tipo de archivo debe especificar el tamaño del bloque a utilizar\n");
                        return 1;
                case TIPO_INVALIDO:
                        printf("Tipo de archivo no valido. Los valores posibles para el tipo de archivo son:\n");
                        return 1;
                case TIPO_INVALIDO:
                        printf("Tipo de archivo no valido. Los valores posibles para el tipo de archivo son:\n");
@@ -127,11 +132,11 @@ int main(int argc, char *argv[])
        wrefresh(stdscr);
 
        dialog = msg_box(stdscr, COLS, LINES, "Generando archivos ...");
        wrefresh(stdscr);
 
        dialog = msg_box(stdscr, COLS, LINES, "Generando archivos ...");
-       if (argc == 3) {
-               art_cargar(argv[1], atoi(argv[2]));
+       if (argc == 4) {
+               art_cargar(argv[1], atoi(argv[2]), atoi(argv[3]));
                fact_cargar(argv[1]);
        } else
                fact_cargar(argv[1]);
        } else
-               art_cargar(NULL, -1);
+               art_cargar(NULL, -1, -1);
 
        msg_box_free(stdscr, dialog);
 
 
        msg_box_free(stdscr, dialog);