… | |
… | |
399 | { |
399 | { |
400 | ns->sound = atoi (param); |
400 | ns->sound = atoi (param); |
401 | safe_strcat (cmdback, param, &slen, HUGE_BUF); |
401 | safe_strcat (cmdback, param, &slen, HUGE_BUF); |
402 | } |
402 | } |
403 | else if (!strcmp (cmd, "exp64")) |
403 | else if (!strcmp (cmd, "exp64")) |
404 | { |
|
|
405 | ns->exp64 = atoi (param); |
|
|
406 | safe_strcat (cmdback, param, &slen, HUGE_BUF); |
404 | safe_strcat (cmdback, param, &slen, HUGE_BUF); |
407 | } |
|
|
408 | else if (!strcmp (cmd, "spellmon")) |
405 | else if (!strcmp (cmd, "spellmon")) |
409 | { |
406 | { |
410 | ns->monitor_spells = atoi (param); |
407 | ns->monitor_spells = atoi (param); |
411 | safe_strcat (cmdback, param, &slen, HUGE_BUF); |
408 | safe_strcat (cmdback, param, &slen, HUGE_BUF); |
412 | } |
409 | } |
… | |
… | |
1033 | AddIfShort (pl->last_stats.Wis, pl->ob->stats.Wis, CS_STAT_WIS); |
1030 | AddIfShort (pl->last_stats.Wis, pl->ob->stats.Wis, CS_STAT_WIS); |
1034 | AddIfShort (pl->last_stats.Pow, pl->ob->stats.Pow, CS_STAT_POW); |
1031 | AddIfShort (pl->last_stats.Pow, pl->ob->stats.Pow, CS_STAT_POW); |
1035 | AddIfShort (pl->last_stats.Cha, pl->ob->stats.Cha, CS_STAT_CHA); |
1032 | AddIfShort (pl->last_stats.Cha, pl->ob->stats.Cha, CS_STAT_CHA); |
1036 | } |
1033 | } |
1037 | |
1034 | |
1038 | if (pl->ns->exp64) |
|
|
1039 | for (int s = 0; s < NUM_SKILLS; s++) |
1035 | for (int s = 0; s < NUM_SKILLS; s++) |
1040 | if (pl->last_skill_ob[s] && pl->last_skill_exp[s] != pl->last_skill_ob[s]->stats.exp) |
1036 | if (pl->last_skill_ob[s] && pl->last_skill_exp[s] != pl->last_skill_ob[s]->stats.exp) |
1041 | { |
1037 | { |
1042 | /* Always send along the level if exp changes. This is only |
1038 | /* Always send along the level if exp changes. This is only |
1043 | * 1 extra byte, but keeps processing simpler. |
1039 | * 1 extra byte, but keeps processing simpler. |
1044 | */ |
1040 | */ |
1045 | sl << uint8 (s + CS_STAT_SKILLINFO) |
1041 | sl << uint8 (s + CS_STAT_SKILLINFO) |
1046 | << uint8 (pl->last_skill_ob[s]->level) |
1042 | << uint8 (pl->last_skill_ob[s]->level) |
1047 | << uint64 (pl->last_skill_ob[s]->stats.exp); |
1043 | << uint64 (pl->last_skill_ob[s]->stats.exp); |
1048 | |
1044 | |
1049 | pl->last_skill_exp[s] = pl->last_skill_ob[s]->stats.exp; |
1045 | pl->last_skill_exp[s] = pl->last_skill_ob[s]->stats.exp; |
1050 | } |
1046 | } |
1051 | |
1047 | |
1052 | if (pl->ns->exp64) |
|
|
1053 | { AddIfInt64 (pl->last_stats.exp, pl->ob->stats.exp, CS_STAT_EXP64) } |
1048 | AddIfInt64 (pl->last_stats.exp, pl->ob->stats.exp, CS_STAT_EXP64); |
1054 | else |
|
|
1055 | { AddIfInt (pl->last_stats.exp, (int) pl->ob->stats.exp, CS_STAT_EXP) } |
|
|
1056 | |
|
|
1057 | AddIfShort (pl->last_level, (char) pl->ob->level, CS_STAT_LEVEL); |
1049 | AddIfShort (pl->last_level, (char) pl->ob->level, CS_STAT_LEVEL); |
1058 | AddIfShort (pl->last_stats.wc, pl->ob->stats.wc, CS_STAT_WC); |
1050 | AddIfShort (pl->last_stats.wc, pl->ob->stats.wc, CS_STAT_WC); |
1059 | AddIfShort (pl->last_stats.ac, pl->ob->stats.ac, CS_STAT_AC); |
1051 | AddIfShort (pl->last_stats.ac, pl->ob->stats.ac, CS_STAT_AC); |
1060 | AddIfShort (pl->last_stats.dam, pl->ob->stats.dam, CS_STAT_DAM); |
1052 | AddIfShort (pl->last_stats.dam, pl->ob->stats.dam, CS_STAT_DAM); |
1061 | AddIfFloat (pl->last_speed, pl->ob->speed, CS_STAT_SPEED); |
1053 | AddIfFloat (pl->last_speed, pl->ob->speed, CS_STAT_SPEED); |