BSD 4_3_Tahoe release
[unix-history] / usr / src / games / sail / dr_main.c
index 305d854..8176304 100644 (file)
@@ -1,6 +1,23 @@
+/*
+ * Copyright (c) 1983 Regents of the University of California.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms are permitted
+ * provided that the above copyright notice and this paragraph are
+ * duplicated in all such forms and that any documentation,
+ * advertising materials, and other materials related to such
+ * distribution and use acknowledge that the software was developed
+ * by the University of California, Berkeley.  The name of the
+ * University may not be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
+ * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
+ */
+
 #ifndef lint
 #ifndef lint
-static char *sccsid = "@(#)dr_main.c   2.1 85/03/04";
-#endif
+static char sccsid[] = "@(#)dr_main.c  5.4 (Berkeley) 6/18/88";
+#endif /* not lint */
 
 #include "driver.h"
 
 
 #include "driver.h"
 
@@ -9,6 +26,7 @@ dr_main()
        register int n;
        register struct ship *sp;
        int nat[NNATION];
        register int n;
        register struct ship *sp;
        int nat[NNATION];
+       int value = 0;
 
        (void) signal(SIGINT, SIG_IGN);
        (void) signal(SIGQUIT, SIG_IGN);
 
        (void) signal(SIGINT, SIG_IGN);
        (void) signal(SIGQUIT, SIG_IGN);
@@ -45,13 +63,15 @@ dr_main()
        }
        windspeed = cc->windspeed;
        winddir = cc->winddir;
        }
        windspeed = cc->windspeed;
        winddir = cc->winddir;
+       people = 0;
        for (;;) {
                sleep(7);
                if (Sync() < 0) {
        for (;;) {
                sleep(7);
                if (Sync() < 0) {
-                       sync_close(1);
-                       exit(1);
+                       value = 1;
+                       break;
                }
                }
-               next();
+               if (next() < 0)
+                       break;
                unfoul();
                checkup();
                prizecheck();
                unfoul();
                checkup();
                prizecheck();
@@ -63,8 +83,10 @@ dr_main()
                reload();
                checksails();
                if (Sync() < 0) {
                reload();
                checksails();
                if (Sync() < 0) {
-                       sync_close(1);
-                       exit(1);
+                       value = 1;
+                       break;
                }
        }
                }
        }
+       sync_close(1);
+       return value;
 }
 }