Fuse prints

This commit is contained in:
jl777
2019-03-13 06:39:21 -11:00
parent e5d33bab93
commit 5b32b491b6
4 changed files with 22 additions and 8 deletions

View File

@@ -83,7 +83,7 @@ void
waste_time(struct rogue_state *rs)
{
do_daemons(rs,BEFORE);
do_fuses(rs,BEFORE);
do_fuses(rs,BEFORE,0);
do_daemons(rs,AFTER);
do_fuses(rs,AFTER);
do_fuses(rs,AFTER,0);
}

View File

@@ -32,7 +32,7 @@ command(struct rogue_state *rs)
* Let the daemons start up
*/
do_daemons(rs,BEFORE);
do_fuses(rs,BEFORE);
do_fuses(rs,BEFORE,0);
while (ntimes--)
{
if ( rs->replaydone != 0 )
@@ -479,7 +479,7 @@ over:
fprintf(fp2,"after daemons (%c).%d seed.%llu isring.%d teleport.%d || search.%d teleport.%d\n",ch,ch,(long long)seed,ISRING(LEFT, R_SEARCH),ISRING(LEFT, R_TELEPORT),ISRING(RIGHT, R_SEARCH),ISRING(RIGHT, R_TELEPORT));
fflush(fp2);
}
do_fuses(rs,AFTER);
do_fuses(rs,AFTER,fp2);
if ( fp2 != 0 )
{
fprintf(fp2,"after fuses (%c).%d seed.%llu isring.%d teleport.%d || search.%d teleport.%d\n",ch,ch,(long long)seed,ISRING(LEFT, R_SEARCH),ISRING(LEFT, R_TELEPORT),ISRING(RIGHT, R_SEARCH),ISRING(RIGHT, R_TELEPORT));

View File

@@ -160,10 +160,22 @@ extinguish(void (*func)(struct rogue_state *rs,int))
* do_fuses:
* Decrement counters and start needed fuses
*/
void
do_fuses(struct rogue_state *rs,int flag)
char *actionfunc_str(char *str,void *ptr)
{
register struct delayed_action *wire;
if ( ptr == (void *)runners )
strcpy(str,"runners");
else if ( ptr == (void *)doctor )
strcpy(str,"doctor");
else if ( ptr == (void *)stomach )
strcpy(str,"stomach");
else strcpy(str,"no match");
return(str);
}
void
do_fuses(struct rogue_state *rs,int flag,FILE *fp)
{
register struct delayed_action *wire; char str[64];
/*
* Step though the list
@@ -175,6 +187,8 @@ do_fuses(struct rogue_state *rs,int flag)
*/
if (flag == wire->d_type && wire->d_time > 0 && --wire->d_time == 0)
{
if ( fp != 0 )
fprintf(fp,"t.%d %d %s, ",wire->d_type,wire->d_time,actionfunc_str(str,wire->d_func));
wire->d_type = EMPTY;
(*wire->d_func)(rs,wire->d_arg);
}

View File

@@ -619,7 +619,7 @@ int dist(int y1, int x1, int y2, int x2);
int dist_cp(coord *c1, coord *c2);
int do_chase(struct rogue_state *rs,THING *th);
void do_daemons(struct rogue_state *rs,int flag);
void do_fuses(struct rogue_state *rs,int flag);
void do_fuses(struct rogue_state *rs,int flag,FILE *fp);
void do_maze(struct rogue_state *rs,struct room *rp);
void do_motion(struct rogue_state *rs,THING *obj, int ydelta, int xdelta);
void do_move(struct rogue_state *rs,int dy, int dx);