diff options
author | Alexander Baldeck <alexander@archlinux.org> | 2004-11-26 16:39:21 +0000 |
---|---|---|
committer | Alexander Baldeck <alexander@archlinux.org> | 2004-11-26 16:39:21 +0000 |
commit | 93b7fabac8e250b89227d1d183081326da942ade (patch) | |
tree | 058f2bd0a762c4e9750339ba6d20731798af8279 /src | |
parent | 428c4cc8bba2e8a385a6f51d3788b7ab3c9ce4c7 (diff) | |
download | mana-93b7fabac8e250b89227d1d183081326da942ade.tar.gz mana-93b7fabac8e250b89227d1d183081326da942ade.tar.bz2 mana-93b7fabac8e250b89227d1d183081326da942ade.tar.xz mana-93b7fabac8e250b89227d1d183081326da942ade.zip |
fix for tmw crash in login() due to too long username in tmw.ini (>25chars) (kth5)
Diffstat (limited to 'src')
-rw-r--r-- | src/gui/login.cpp | 5 | ||||
-rw-r--r-- | src/main.cpp | 4 | ||||
-rw-r--r-- | src/main.h | 10 |
3 files changed, 16 insertions, 3 deletions
diff --git a/src/gui/login.cpp b/src/gui/login.cpp index 39a41d27..0fe00db0 100644 --- a/src/gui/login.cpp +++ b/src/gui/login.cpp @@ -43,7 +43,10 @@ DIALOG login_dialog[] = { if(get_config_int("login", "remember", 0)!=0) { login_dialog[7].flags = D_SELECTED; - if(get_config_string("login", "username", 0))strcpy(username, get_config_string("login", "username", 0)); + if(get_config_string("login", "username", 0)) { + strncpy(username, get_config_string("login", "username", 0), LEN_USERNAME); + username[LEN_USERNAME] = '\0'; + } else strcpy(username, "player\0"); } centre_dialog(login_dialog); diff --git a/src/main.cpp b/src/main.cpp index b9c501d3..87e1eb9e 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -81,8 +81,8 @@ PLAYER_INFO *char_info = new PLAYER_INFO; BITMAP *playerset, *hairset; DATAFILE *graphic, *emotions, *weaponset; -char username[25]; -char password[25]; +char username[LEN_USERNAME]; +char password[LEN_PASSWORD]; int map_address, char_ID; short map_port; char map_name[16]; @@ -59,6 +59,16 @@ #define CHAR_DEL 5 #define GAME 6 +/* length definitions for several char[]s in order + * to be able to use strncpy instead of strcpy for + * security and stability reasons + * + * best regards - kth5 */ +#define LEN_USERNAME 25 +#define LEN_PASSWORD 25 + + + typedef struct { int address; short port; |