diff options
author | Markus Uhlin <markus@nifty-networks.net> | 2024-04-23 18:51:49 +0200 |
---|---|---|
committer | Markus Uhlin <markus@nifty-networks.net> | 2024-04-23 18:51:49 +0200 |
commit | 2ccd8739eb6b350094fc45a8511e1cc4688c12ec (patch) | |
tree | b6a930bef89c5c2ac49f2e65b5322d6a3ad5fdb8 | |
parent | 1dd27bc24de1e88362317f101d443ccc894a2fc3 (diff) |
Revised com_examine()
-rw-r--r-- | FICS/obsproc.c | 110 |
1 files changed, 62 insertions, 48 deletions
diff --git a/FICS/obsproc.c b/FICS/obsproc.c index a2bc47f..0f6d417 100644 --- a/FICS/obsproc.c +++ b/FICS/obsproc.c @@ -854,57 +854,71 @@ PRIVATE void ExamineJournal(int p,int p1,char slot) return; } -PUBLIC int com_examine(int p, param_list param) +PUBLIC int +com_examine(int p, param_list param) { - int p1, p2 = p, p1conn, p2conn = 1; - char* param2string; - char fname[MAX_FILENAME_SIZE]; + char *param2string; + char fname[MAX_FILENAME_SIZE] = { '\0' }; + int p1, p2 = p, p1conn, p2conn = 1; + + if (parray[p].game >= 0 && garray[parray[p].game].status == + GAME_EXAMINE) { + pprintf(p, "You are already examining a game.\n"); + } else if (parray[p].game >=0) { + pprintf(p, "You are playing a game.\n"); + } else if (param[0].type == TYPE_NULL) { + ExamineScratch(p, param); + } else if (param[0].type == TYPE_WORD) { + if (param[1].type == TYPE_WORD) { + msnprintf(fname, sizeof fname, "%s/%s/%s", board_dir, + param[0].val.word, param[1].val.word); + + if (file_exists(fname)) { + ExamineScratch(p, param); + return COM_OK; + } + } - if ((parray[p].game >=0) &&(garray[parray[p].game].status == GAME_EXAMINE)) { - pprintf(p, "You are already examining a game.\n"); - } else if (parray[p].game >=0) { - pprintf(p, "You are playing a game.\n"); - } else if (param[0].type == TYPE_NULL) { - ExamineScratch(p, param); - } else if (param[0].type == TYPE_WORD) { - if (param[1].type == TYPE_WORD) { - sprintf(fname, "%s/%s/%s", board_dir, param[0].val.word, param[1].val.word); - if (file_exists(fname)) { - ExamineScratch(p, param); - return COM_OK; - } - } - if (!FindPlayer(p, param[0].val.word, &p1, &p1conn)) - return COM_OK; + if (!FindPlayer(p, param[0].val.word, &p1, &p1conn)) + return COM_OK; - if (param[1].type == TYPE_INT) - ExamineHistory(p, p1, param[1].val.integer); - else { - if (param[1].type == TYPE_WORD) { - - /* Lets check the journal */ - param2string = param[1].val.word; - if ((strlen(param2string) == 1) && (isalpha(param2string[0]))) { - ExamineJournal(p,p1,param2string[0]); - if (!p1conn) - player_remove(p1); - return COM_OK; - } else { - if (!FindPlayer(p, param[1].val.word, &p2, &p2conn)) { - if (!p1conn) - player_remove(p1); - return COM_OK; - } - } - } - ExamineAdjourned(p, p1, p2); - if (!p2conn) - player_remove(p2); - } - if (!p1conn) - player_remove(p1); - } - return COM_OK; + if (param[1].type == TYPE_INT) + ExamineHistory(p, p1, param[1].val.integer); + else { + if (param[1].type == TYPE_WORD) { + /* + * Lets check the journal + */ + param2string = param[1].val.word; + + if (strlen(param2string) == 1 && + isalpha(param2string[0])) { + ExamineJournal(p, p1, param2string[0]); + + if (!p1conn) + player_remove(p1); + return COM_OK; + } else { + if (!FindPlayer(p, param[1].val.word, + &p2, &p2conn)) { + if (!p1conn) + player_remove(p1); + return COM_OK; + } + } + } + + ExamineAdjourned(p, p1, p2); + + if (!p2conn) + player_remove(p2); + } + + if (!p1conn) + player_remove(p1); + } + + return COM_OK; } PUBLIC int |