Remove savefilefmt from config file; backing up the savefile

can now be done with per-game commands.


git-svn-id: svn://katsu.triplehelix.org/dgamelaunch/trunk@392 db0b04b0-f4d1-0310-9a6d-de3e77497b0e
This commit is contained in:
Pasi Kallinen 2008-01-01 17:36:46 +00:00
parent 24cb396d16
commit 0d509576d8
6 changed files with 9 additions and 82 deletions

View File

@ -77,7 +77,6 @@ COMMENT ^#.*
"rc_template" { return TYPE_PATH_CANNED; } "rc_template" { return TYPE_PATH_CANNED; }
"passwd" { return TYPE_PATH_PASSWD; } "passwd" { return TYPE_PATH_PASSWD; }
"lockfile" { return TYPE_PATH_LOCKFILE; } "lockfile" { return TYPE_PATH_LOCKFILE; }
"savefilefmt" { return TYPE_PATH_SAVEFILEFMT; }
"inprogressdir" { return TYPE_PATH_INPROGRESS; } "inprogressdir" { return TYPE_PATH_INPROGRESS; }
"game_args" { return TYPE_GAME_ARGS; } "game_args" { return TYPE_GAME_ARGS; }
"rc_fmt" { return TYPE_RC_FMT; } "rc_fmt" { return TYPE_RC_FMT; }

View File

@ -37,7 +37,7 @@ static const char* lookup_token (int t);
%token TYPE_ALLOW_REGISTRATION %token TYPE_ALLOW_REGISTRATION
%token TYPE_PATH_GAME TYPE_NAME_GAME TYPE_PATH_DGLDIR TYPE_PATH_SPOOL %token TYPE_PATH_GAME TYPE_NAME_GAME TYPE_PATH_DGLDIR TYPE_PATH_SPOOL
%token TYPE_PATH_BANNER TYPE_PATH_CANNED TYPE_PATH_CHROOT %token TYPE_PATH_BANNER TYPE_PATH_CANNED TYPE_PATH_CHROOT
%token TYPE_PATH_PASSWD TYPE_PATH_LOCKFILE TYPE_PATH_SAVEFILEFMT %token TYPE_PATH_PASSWD TYPE_PATH_LOCKFILE
%token TYPE_MALSTRING TYPE_PATH_INPROGRESS TYPE_GAME_ARGS TYPE_RC_FMT %token TYPE_MALSTRING TYPE_PATH_INPROGRESS TYPE_GAME_ARGS TYPE_RC_FMT
%token TYPE_CMDQUEUE %token TYPE_CMDQUEUE
%token <s> TYPE_VALUE %token <s> TYPE_VALUE
@ -280,11 +280,6 @@ game_definition : TYPE_CMDQUEUE
myconfig[ncnf]->mkdir = strdup ($3); myconfig[ncnf]->mkdir = strdup ($3);
break; break;
case TYPE_PATH_SAVEFILEFMT:
if (myconfig[ncnf]->savefilefmt) free(myconfig[ncnf]->savefilefmt);
myconfig[ncnf]->savefilefmt = strdup($3);
break;
case TYPE_RC_FMT: case TYPE_RC_FMT:
if (myconfig[ncnf]->rc_fmt) free(myconfig[ncnf]->rc_fmt); if (myconfig[ncnf]->rc_fmt) free(myconfig[ncnf]->rc_fmt);
myconfig[ncnf]->rc_fmt = strdup($3); myconfig[ncnf]->rc_fmt = strdup($3);
@ -404,7 +399,6 @@ KeyType : TYPE_SUSER { $$ = TYPE_SUSER; }
| TYPE_PATH_CANNED { $$ = TYPE_PATH_CANNED; } | TYPE_PATH_CANNED { $$ = TYPE_PATH_CANNED; }
| TYPE_PATH_PASSWD { $$ = TYPE_PATH_PASSWD; } | TYPE_PATH_PASSWD { $$ = TYPE_PATH_PASSWD; }
| TYPE_PATH_LOCKFILE { $$ = TYPE_PATH_LOCKFILE; } | TYPE_PATH_LOCKFILE { $$ = TYPE_PATH_LOCKFILE; }
| TYPE_PATH_SAVEFILEFMT { $$ = TYPE_PATH_SAVEFILEFMT; }
| TYPE_PATH_INPROGRESS { $$ = TYPE_PATH_INPROGRESS; } | TYPE_PATH_INPROGRESS { $$ = TYPE_PATH_INPROGRESS; }
| TYPE_GAME_ARGS { $$ = TYPE_GAME_ARGS; } | TYPE_GAME_ARGS { $$ = TYPE_GAME_ARGS; }
| TYPE_RC_FMT { $$ = TYPE_RC_FMT; } | TYPE_RC_FMT { $$ = TYPE_RC_FMT; }
@ -433,7 +427,6 @@ const char* lookup_token (int t)
case TYPE_PATH_SPOOL: return "spooldir"; case TYPE_PATH_SPOOL: return "spooldir";
case TYPE_PATH_BANNER: return "banner"; case TYPE_PATH_BANNER: return "banner";
case TYPE_PATH_CANNED: return "rc_template"; case TYPE_PATH_CANNED: return "rc_template";
case TYPE_PATH_SAVEFILEFMT: return "savefilefmt";
case TYPE_PATH_INPROGRESS: return "inprogressdir"; case TYPE_PATH_INPROGRESS: return "inprogressdir";
case TYPE_GAME_ARGS: return "game_args"; case TYPE_GAME_ARGS: return "game_args";
case TYPE_RC_FMT: return "rc_fmt"; case TYPE_RC_FMT: return "rc_fmt";

View File

@ -1581,67 +1581,6 @@ writefile (int requirenew)
/* ************************************************************* */ /* ************************************************************* */
/*
* Backup the savefile, if configured.
* Returns non-zero if successful, otherwise an error message has been
* given already.
*/
int
backup_savefile (int game)
{
/*char buf[1024];*/
char *f, *p, *end, *buf;
int ispercent = 0, n;
int in, out;
f = myconfig[game]->savefilefmt;
if (*f == '\0')
return 1;
if (me == NULL)
graceful_exit (147);
buf = dgl_format_str(game, me, f);
p = buf;
p += strlen(buf);
/*fprintf(stderr, "***\n[SAVEFILE=%s]\n***\n", buf);
sleep(3);*/
in = open (buf, O_RDONLY);
if (in == -1)
{
if (errno == ENOENT)
return 1; /* Nothing to back up */
else
{
fprintf (stderr, "Cannot open savefile '%s'\n", buf);
perror ("for input");
return 0;
}
}
strcpy (p, ".bak");
out = open (buf, O_WRONLY | O_CREAT | O_TRUNC, 0666);
if (out == -1)
{
close (in);
fprintf (stderr, "Cannot open backup savefile '%s'\n", buf);
perror ("for output");
return 0;
}
while ((n = read (in, buf, sizeof(buf))) > 0)
{
n = write (out, buf, n);
if (n < 0)
break;
}
close (out);
close (in);
if (n < 0)
perror ("I/O error while backing up savefile");
return n >= 0;
}
int int
purge_stale_locks (int game) purge_stale_locks (int game)
{ {
@ -2130,8 +2069,10 @@ main (int argc, char** argv)
/* then run the game-specific commands */ /* then run the game-specific commands */
dgl_exec_cmdqueue(myconfig[userchoice]->cmdqueue, userchoice, me); dgl_exec_cmdqueue(myconfig[userchoice]->cmdqueue, userchoice, me);
/*
if (!backup_savefile (userchoice)) if (!backup_savefile (userchoice))
graceful_exit (5); graceful_exit (5);
*/
/* environment */ /* environment */
if (myconfig[userchoice]->rcfile) { if (myconfig[userchoice]->rcfile) {

View File

@ -71,7 +71,7 @@ struct dg_config
char* mkdir; char* mkdir;
char* rcfile; char* rcfile;
char* spool; char* spool;
char* savefilefmt; /*char* savefilefmt;*/
char* inprogressdir; char* inprogressdir;
int num_args; /* # of bin_args */ int num_args; /* # of bin_args */
char **bin_args; /* args for game binary */ char **bin_args; /* args for game binary */

View File

@ -35,7 +35,7 @@ struct dg_config defconfig = {
/* shed_uid = *//* 5,*/ /* shed_uid = *//* 5,*/
/* shed_gid = */ /*60,*/ /* games:games in Debian */ /* shed_gid = */ /*60,*/ /* games:games in Debian */
/* max = */ /*64000,*/ /* max = */ /*64000,*/
/* savefilefmt = */ "", /* don't do this by default */ /* savefilefmt = */ /*"",*/ /* don't do this by default */
/* inprogressdir = */ "inprogress/", /* inprogressdir = */ "inprogress/",
/* num_args = */ 0, /* num_args = */ 0,
/* bin_args = */ NULL, /* bin_args = */ NULL,
@ -431,7 +431,7 @@ create_config ()
if (!myconfig[tmp]->shortname) myconfig[tmp]->shortname = defconfig.shortname; if (!myconfig[tmp]->shortname) myconfig[tmp]->shortname = defconfig.shortname;
if (!myconfig[tmp]->rcfile) myconfig[tmp]->rcfile = defconfig.rcfile; if (!myconfig[tmp]->rcfile) myconfig[tmp]->rcfile = defconfig.rcfile;
if (!myconfig[tmp]->spool) myconfig[tmp]->spool = defconfig.spool; if (!myconfig[tmp]->spool) myconfig[tmp]->spool = defconfig.spool;
if (!myconfig[tmp]->savefilefmt) myconfig[tmp]->savefilefmt = defconfig.savefilefmt; /*if (!myconfig[tmp]->savefilefmt) myconfig[tmp]->savefilefmt = defconfig.savefilefmt;*/
if (!myconfig[tmp]->inprogressdir) myconfig[tmp]->inprogressdir = defconfig.inprogressdir; if (!myconfig[tmp]->inprogressdir) myconfig[tmp]->inprogressdir = defconfig.inprogressdir;
} }

View File

@ -108,14 +108,6 @@ spooldir = "/var/mail/"
# From inside the jail, the default .nethackrc that is copied for new users. # From inside the jail, the default .nethackrc that is copied for new users.
# rc_template = "/dgl-default-rcfile" # rc_template = "/dgl-default-rcfile"
# From inside the jail, the path to the savefile. %u is replaced by the
# decimal representation of shed_uid, %n is replaced by the player's
# user name. Before starting the game, this file is copied to its name
# with ".bak" appended. Set to an empty string to disable this copying.
savefilefmt = "/var/games/nethack/save/%u%n.gz"
# make sure the inprogress dir actually exists. default is "inprogress/" # make sure the inprogress dir actually exists. default is "inprogress/"
# each game you define here must have it's own. # each game you define here must have it's own.
inprogressdir = "inprogress-nethackstub/" inprogressdir = "inprogress-nethackstub/"
@ -148,9 +140,11 @@ rc_template = "/dgl-default-rcfile"
# %r == dglroot # %r == dglroot
# %n == user name # %n == user name
rc_fmt = "%rrcfiles/%n.nethackrc" rc_fmt = "%rrcfiles/%n.nethackrc"
savefilefmt = "/var/games/nethack/save/%u%n.gz"
inprogressdir = "inprogress-nethack/" inprogressdir = "inprogress-nethack/"
# back up savefile
commands = cp "/var/games/nethack/save/%u%n.gz" "/var/games/nethack/save/%u%n.gz.bak"
} }
# #