comparison arogue5/wear.c @ 76:ad2cb9a07aaa

arogue5: fix player's typed responses getting put at the wrong place. Some sections of code that prompt the user for a string of input were calling get_str() with cw (the player-visible screen containing the map), which caused whatever the player typed to get printed starting at cw's idea of the cursor position, which was usually the Rogue's @-sign. This corrupted the map. The problem has been fixed by passing msgw (the message line at the top of the screen) to get_str(), so the player's typing appears where msgw thinks the cursor should be, which is in the sensible place right after the prompt. Some other get_str() invocations which used hw or stdscr have been left unmodified.
author John "Elwin" Edwards <elwin@sdf.org>
date Sat, 08 Sep 2012 22:05:05 -0700
parents c49f7927b0fa
children f2951c4e28d9
comparison
equal deleted inserted replaced
75:19903deed392 76:ad2cb9a07aaa
228 else if (!m_know[obj->o_which] && 228 else if (!m_know[obj->o_which] &&
229 askme && 229 askme &&
230 (obj->o_flags & ISKNOW) == 0 && 230 (obj->o_flags & ISKNOW) == 0 &&
231 m_guess[obj->o_which] == NULL) { 231 m_guess[obj->o_which] == NULL) {
232 msg(terse ? "Call it: " : "What do you want to call it? "); 232 msg(terse ? "Call it: " : "What do you want to call it? ");
233 if (get_str(buf, cw) == NORM) { 233 if (get_str(buf, msgw) == NORM) {
234 m_guess[obj->o_which] = new((unsigned int) strlen(buf) + 1); 234 m_guess[obj->o_which] = new((unsigned int) strlen(buf) + 1);
235 strcpy(m_guess[obj->o_which], buf); 235 strcpy(m_guess[obj->o_which], buf);
236 } 236 }
237 } 237 }
238 238