diff srogue/main.c @ 112:ee250e3646fd

Don't truncate player name in savefile name or log message. The player name is stored in whoami[], which is length 80 in most games (1024 in rogue5). Only the first 10 chars were used to create file_name, because that buffer is the same length. Increasing the size of file_name to 256 permits using all of whoami. The name is also no longer truncated to 20 chars when writing the log. All games should now be able to handle 79-character names without collisions. Anything more would break save compatibility.
author John "Elwin" Edwards
date Sun, 23 Mar 2014 21:27:14 -0700
parents f2951c4e28d9
children 458df24e973d
line wrap: on
line diff
--- a/srogue/main.c	Wed Jan 08 16:44:16 2014 -0500
+++ b/srogue/main.c	Sun Mar 23 21:27:14 2014 -0700
@@ -119,8 +119,8 @@
 		strncpy(whoami, argv[2], LINLEN);
 		whoami[LINLEN - 1] = '\0';
 		use_savedir = TRUE;
-		if (snprintf(file_name, LINLEN, "%s/%d-%.10s.srsav", SAVEDIR, 
-			playuid, whoami) >= LINLEN) {
+		if (snprintf(file_name, 256, "%s/%d-%s.srsav", SAVEDIR, 
+			playuid, whoami) >= 256) {
 			/* Just in case it doesn't fit */
 			strcpy(file_name, "srogue.save");
 			use_savedir = FALSE;