Mercurial > hg > early-roguelike
view rogue4/findpw.c @ 114:a5433ba4cabf
arogue5: fix some daemon-related pointer/int casting.
Daemons and fuses take a single argument, nominally an int but either
ignored or unsafely cast to a pointer. Its type has now been changed
to void*.
The save/restore code no longer tries to store this argument in the
savefile. For doctor(), this is not a problem, because player is the
only argument it is ever given as a daemon. However, alchemy() will
fail to do anything when passed NULL. Fixing this would be complicated
but possible.
Summary: the code is slightly safer, but alchemy jugs are guaranteed to
stop working after save and restore, instead of just extremely likely.
author | John "Elwin" Edwards |
---|---|
date | Fri, 28 Mar 2014 10:57:03 -0700 |
parents | 9535a08ddc39 |
children |
line wrap: on
line source
/* * print out an encrypted password on the standard output * * @(#)findpw.c 1.1 (Berkeley) 12/20/81 * * Rogue: Exploring the Dungeons of Doom * Copyright (C) 1980, 1981, 1982 Michael Toy, Ken Arnold and Glenn Wichman * All rights reserved. * * See the file LICENSE.TXT for full copyright and licensing information. */ #include <stdio.h> main() { char buf[80]; fprintf(stderr, "Password: "); fgets(buf, 80, stdin); buf[strlen(buf) - 1] = '\0'; printf("%s\n", xcrypt(buf, "mT")); }