2010-08-07 16:06:14 -04:00
|
|
|
$OpenBSD: patch-c4_c,v 1.3 2010/08/07 20:06:14 naddy Exp $
|
|
|
|
--- c4.c.orig Sat Aug 7 21:36:09 2010
|
|
|
|
+++ c4.c Sat Aug 7 21:37:10 2010
|
|
|
|
@@ -14,7 +14,10 @@
|
2001-08-10 23:17:12 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2010-08-07 16:06:14 -04:00
|
|
|
+#include <stdlib.h>
|
|
|
|
+#include <string.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
+#include <unistd.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <pwd.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
@@ -55,7 +58,6 @@ char **envp;
|
|
|
|
register int winner = DRAW;
|
|
|
|
int temp;
|
|
|
|
|
|
|
|
- envmesg(envp, "Connect Four");
|
|
|
|
do_args(argc, argv);
|
|
|
|
open_scorefile("a");
|
|
|
|
ask_help();
|
2001-08-10 23:17:12 -04:00
|
|
|
@@ -219,7 +221,7 @@ ask_turn()
|
|
|
|
register char *cp;
|
|
|
|
|
|
|
|
printf("Would you like to go first? (yes/no) -> ");
|
|
|
|
- if (!gets(line)){
|
2003-04-14 12:03:01 -04:00
|
|
|
+ if (!fgets(line, sizeof line, stdin)){
|
2001-08-10 23:17:12 -04:00
|
|
|
plot_finish();
|
|
|
|
fprintf(stderr, "Could not read input line.\n");
|
|
|
|
goodbye();
|
|
|
|
@@ -620,8 +622,8 @@ ask_help()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
- printf("Do you need help (n/y)? -> ");
|
|
|
|
- if (!gets(line)){
|
|
|
|
+ printf("Do you need help (y/n)? -> ");
|
2003-04-14 12:03:01 -04:00
|
|
|
+ if (!fgets(line, sizeof line, stdin)){
|
2001-08-10 23:17:12 -04:00
|
|
|
fprintf(stderr, "Could not read input line\n");
|
|
|
|
goodbye();
|
|
|
|
}
|
2010-08-07 16:06:14 -04:00
|
|
|
@@ -687,9 +689,11 @@ date()
|
|
|
|
struct timeval v;
|
|
|
|
struct timezone z;
|
|
|
|
char *nl;
|
|
|
|
+ time_t sec;
|
|
|
|
|
|
|
|
gettimeofday(&v, &z);
|
|
|
|
- sprintf(time,"%s", ctime(&v.tv_sec));
|
|
|
|
+ sec = v.tv_sec;
|
|
|
|
+ sprintf(time,"%s", ctime(&sec));
|
|
|
|
|
|
|
|
if ((nl = index(time, '\n')) == NULL){
|
|
|
|
fprintf(stderr,"date: ctime returned non-newline terminated string.\n");
|
|
|
|
@@ -813,34 +817,5 @@ debug_off()
|
|
|
|
save = d;
|
|
|
|
d = NULL;
|
|
|
|
accept_move(turn);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-/*
|
|
|
|
- * Modify the environment to put message in the right place for
|
|
|
|
- * the w and ps commands to find. Code stolen from MFCF lock
|
|
|
|
- * program, originally by Ian!
|
|
|
|
- *
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-void
|
|
|
|
-envmesg(environ, message)
|
|
|
|
-char **environ;
|
|
|
|
-char *message;
|
|
|
|
-{
|
|
|
|
- /*
|
|
|
|
- * Note that this clobbers the environment, so we have to
|
|
|
|
- * do it last, after all the getenv and termcap calls.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
- char *last, *address;
|
|
|
|
- while( environ[1] != 0 ) ++environ;
|
|
|
|
- last = environ[0] + strlen(environ[0]);/* address of '\0' */
|
|
|
|
- last = (char *)((int)last&(~03));/* word boundary */
|
|
|
|
- *(int *)last = 0; /* clean out last word */
|
|
|
|
- address = last +3 -strlen(message);
|
|
|
|
- address = (char *)((int)address&(~03));/* word boundary */
|
|
|
|
- *(int *)(address-4) = 0; /* clean out word below */
|
|
|
|
- *(int *)(address-8) = 0; /* clean out word below */
|
|
|
|
- strcpy( address, message );
|
|
|
|
}
|
|
|
|
|