Just to make sure i wasn't doing anything wrong here is the output of how my tables are setup... trying to set pick lock to 40. Only thing I can find in the code so far is maxskill.h. The three skills that seem to have the problem are grouped. But I doubt thats it.
Also removing the 0's from skill_caps table has no effect.
mysql> SELECT skill_35, name FROM class_skill WHERE name = 'Bard';
+----------+------+
| skill_35 | name |
+----------+------+
| 40 | Bard |
+----------+------+
1 row in set (0.00 sec)
mysql> SELECT * FROM skill_caps WHERE class = 8 AND skillid = 35;
+---------+-------+-------+-----+--------+
| skillID | class | level | cap | class_ |
+---------+-------+-------+-----+--------+
| 35 | 8 | 1 | 0 | 8 |
| 35 | 8 | 2 | 0 | 8 |
| 35 | 8 | 3 | 0 | 8 |
| 35 | 8 | 4 | 0 | 8 |
| 35 | 8 | 5 | 0 | 8 |
| 35 | 8 | 6 | 0 | 8 |
| 35 | 8 | 7 | 0 | 8 |
| 35 | 8 | 8 | 0 | 8 |
| 35 | 8 | 9 | 0 | 8 |
| 35 | 8 | 10 | 0 | 8 |
| 35 | 8 | 11 | 0 | 8 |
| 35 | 8 | 12 | 0 | 8 |
| 35 | 8 | 13 | 0 | 8 |
| 35 | 8 | 14 | 0 | 8 |
| 35 | 8 | 15 | 0 | 8 |
| 35 | 8 | 16 | 0 | 8 |
| 35 | 8 | 17 | 0 | 8 |
| 35 | 8 | 18 | 0 | 8 |
| 35 | 8 | 19 | 0 | 8 |
| 35 | 8 | 20 | 0 | 8 |
| 35 | 8 | 21 | 0 | 8 |
| 35 | 8 | 22 | 0 | 8 |
| 35 | 8 | 23 | 0 | 8 |
| 35 | 8 | 24 | 0 | 8 |
| 35 | 8 | 25 | 0 | 8 |
| 35 | 8 | 26 | 0 | 8 |
| 35 | 8 | 27 | 0 | 8 |
| 35 | 8 | 28 | 0 | 8 |
| 35 | 8 | 29 | 0 | 8 |
| 35 | 8 | 30 | 0 | 8 |
| 35 | 8 | 31 | 0 | 8 |
| 35 | 8 | 32 | 0 | 8 |
| 35 | 8 | 33 | 0 | 8 |
| 35 | 8 | 34 | 0 | 8 |
| 35 | 8 | 35 | 0 | 8 |
| 35 | 8 | 36 | 0 | 8 |
| 35 | 8 | 37 | 0 | 8 |
| 35 | 8 | 38 | 0 | 8 |
| 35 | 8 | 39 | 0 | 8 |
| 35 | 8 | 40 | 100 | 8 |
| 35 | 8 | 41 | 100 | 8 |
| 35 | 8 | 42 | 100 | 8 |
| 35 | 8 | 43 | 100 | 8 |
| 35 | 8 | 44 | 100 | 8 |
| 35 | 8 | 45 | 100 | 8 |
| 35 | 8 | 46 | 100 | 8 |
| 35 | 8 | 47 | 100 | 8 |
| 35 | 8 | 48 | 100 | 8 |
| 35 | 8 | 49 | 100 | 8 |
| 35 | 8 | 50 | 100 | 8 |
| 35 | 8 | 51 | 100 | 8 |
| 35 | 8 | 52 | 100 | 8 |
| 35 | 8 | 53 | 100 | 8 |
| 35 | 8 | 54 | 100 | 8 |
| 35 | 8 | 55 | 100 | 8 |
| 35 | 8 | 56 | 100 | 8 |
| 35 | 8 | 57 | 100 | 8 |
| 35 | 8 | 58 | 100 | 8 |
| 35 | 8 | 59 | 100 | 8 |
| 35 | 8 | 60 | 100 | 8 |
| 35 | 8 | 61 | 248 | 8 |
| 35 | 8 | 62 | 251 | 8 |
| 35 | 8 | 63 | 254 | 8 |
| 35 | 8 | 64 | 257 | 8 |
| 35 | 8 | 65 | 260 | 8 |
| 35 | 8 | 66 | 263 | 8 |
| 35 | 8 | 67 | 266 | 8 |
| 35 | 8 | 68 | 269 | 8 |
| 35 | 8 | 69 | 272 | 8 |
| 35 | 8 | 70 | 275 | 8 |
| 35 | 8 | 71 | 278 | 8 |
| 35 | 8 | 72 | 281 | 8 |
| 35 | 8 | 73 | 284 | 8 |
| 35 | 8 | 74 | 287 | 8 |
| 35 | 8 | 75 | 290 | 8 |
| 35 | 8 | 76 | 293 | 8 |
| 35 | 8 | 77 | 296 | 8 |
| 35 | 8 | 78 | 299 | 8 |
| 35 | 8 | 79 | 302 | 8 |
| 35 | 8 | 80 | 305 | 8 |
| 35 | 8 | 81 | 308 | 8 |
| 35 | 8 | 82 | 311 | 8 |
| 35 | 8 | 83 | 314 | 8 |
| 35 | 8 | 84 | 317 | 8 |
| 35 | 8 | 85 | 320 | 8 |
+---------+-------+-------+-----+--------+
85 rows in set (0.00 sec)
|