1 | Deliantra MORPG Server, Maps and Archetypes ChangeLog. |
1 | Deliantra MORPG Server, Maps and Archetypes ChangeLog. |
2 | |
2 | |
3 | TODO: "you get the distinctive feeling that <other> is nuts" |
3 | TODO: dragons should not be able to change their title via the settings tab in playerbook |
4 | TODO: logging/backtrace in non-main contexts cause crashes with glibc 2.7 |
4 | TODO: emergency swap mode is not working |
5 | TODO: perl exceptions inside coroutines exit, which is correct, but unwanted behaviour |
5 | 08:43:44 -cfbot:#cf- [Larvae] when I had a devourerbow equipped, and then readied |
6 | TODO: map->at: attempt to copy freed scalar b7d4b48 to b800c38 at warn "FOO$m { ".scalar (@a)." }\n"; |
6 | some spellcasting. if I then started using karate, I would get all the |
|
|
7 | stateffects from the bow |
|
|
8 | |
|
|
9 | 2.54 |
|
|
10 | - (maps) fixed the death certificate system in nimbus |
|
|
11 | - get rid of costly object_from_name conversion for altar effects. |
|
|
12 | - fix map difficulty calculation for generators. |
|
|
13 | |
|
|
14 | 2.53 Sun May 4 17:32:48 CEST 2008 |
|
|
15 | - bugfix: custom skill settings were not saved by the server. |
|
|
16 | - bugfix: remove did not actually remove items from the inventory, leaving |
|
|
17 | ghost items. |
|
|
18 | - bugfix: properly update items identified on the ground. |
|
|
19 | - bugfix: use localtime_r in the logger thread. |
|
|
20 | - bugfix: player starvation will now give the correct kill reason. |
|
|
21 | - bugfix: archetype reloads could crash the server. |
|
|
22 | - bugfix: the mailscrolls are now correctly handed out even when the destination |
|
|
23 | player is not logged in. |
|
|
24 | - bugfix: make list_logins non-blocking (glaring oversight). this caused the lag at |
|
|
25 | server startup. |
|
|
26 | - bugfix: fix the door surround check in the random map generator. |
|
|
27 | - (maps) fix heaven quest difficulty progression. |
|
|
28 | - (maps) fix some random map styles. |
|
|
29 | - dropping items a shop is not interested in won't sell them anymore. |
|
|
30 | - rods and horns with a too low maximum charge allow now at least one discharge. |
|
|
31 | - implement kill & death statistics. |
|
|
32 | - random map preparation is no longer synchronous. |
|
|
33 | - rewrite find_style in perl, no longer does synchronous I/O. |
|
|
34 | - improve random map specials placement. |
|
|
35 | - make the killer a real object pointer instead of a string, improved |
|
|
36 | kill reason messages. |
|
|
37 | - take advantage of new aio_close and aio_chmod. |
|
|
38 | - implement archetype::get, object::deep_clone and update callers. |
|
|
39 | - change_abil is much faster. |
|
|
40 | - update the floorbox more often to work around the reverses item order |
|
|
41 | display in clients. |
|
|
42 | - cleaned up object copying by encapsulating it to a single place. |
|
|
43 | - add hints to the invite messages. |
|
|
44 | - rewrote key<->value pair handling. |
|
|
45 | - use an independent random number generator for the random map generator. |
|
|
46 | |
|
|
47 | 2.52 Thu Apr 24 11:47:19 CEST 2008 |
|
|
48 | - completely automate the item add/delete on remove/insert. this should fix |
|
|
49 | all "ghost" item bugs caused by sloppy coding, as sloppy coding is now correct :) |
|
|
50 | - completely automate the weight handling, should fix all weight |
|
|
51 | accounting bugs caused by sloppy coding, as sloppy coding is now correct :) |
|
|
52 | - reloading archetypes while a user was in the character creation phase |
|
|
53 | could crash the server. |
|
|
54 | - fix a nontrivial number of cases of code commented similar |
|
|
55 | to "is this really correct?", as many of those cases are now handles |
|
|
56 | automatically by lower level code. |
|
|
57 | - replace many ad-hoc checks for client visibility by object::visible_to, |
|
|
58 | should result in broader applicability of functions using it. |
|
|
59 | - merge items with different arch pointers refering to the same arch |
|
|
60 | (due to archetype reloads). |
|
|
61 | - refactored the object remove/insert functions and most related |
|
|
62 | functions (decrease, split, merge_ob etc.). |
|
|
63 | - make it compile better on freebsd (reported by pippijn). |
|
|
64 | - remove GT_UPDATE_INV (no longer applicable). |
|
|
65 | - fix the longstanding "container stays open" bug. |
|
|
66 | - improved floorbox updating to be incremental and other protocol |
|
|
67 | optimisations. |
|
|
68 | - get rid of update_after_inventory_change and only do update stats |
|
|
69 | for weight once/tick/player at max. |
|
|
70 | - rewrite party commands, use party channel. |
|
|
71 | |
|
|
72 | 2.51 Sun Apr 20 21:27:37 CEST 2008 |
|
|
73 | - properly link against libgthread as that is needed to make the slice |
|
|
74 | allocator thread-safe. |
|
|
75 | - support perls not compiled with 64 bit support (though this is not a |
|
|
76 | recommended configuration) (reported by Samuel Gondouin). |
|
|
77 | - always put godgiven items into the player inventory, never any containers. |
|
|
78 | - (arch) |
|
|
79 | - (maps, arch) the scorn go club was founded! |
|
|
80 | - (arch) do no longer support player abilities, they didn't work anyways. |
|
|
81 | - (arch) the alchemy spell is now of the alchemy spell school, which |
|
|
82 | became a real spell-class. |
|
|
83 | - (arch) the alchemist class now get an alchemy spell book for new characters. |
|
|
84 | - (arch) considerably strengthened spark shower and destruction. |
|
|
85 | - match archetypes by name, not by ptr, in treasure.C, this makes archetypes |
|
|
86 | finally reloadable at runtime. |
|
|
87 | - changed archetype loading algorithm to only require one pass and |
|
|
88 | use delayed resolving of references. |
|
|
89 | - examine command now uses the examine infobox. |
|
|
90 | - implement an "incremental garbage collector" for archetypes. |
|
|
91 | - enable slice allocator again. |
|
|
92 | - implement optional free memory poisoning. |
|
|
93 | |
|
|
94 | 2.5 Wed Apr 16 15:06:53 CEST 2008 |
|
|
95 | - the two handed weapon skill can no longer be used as unarmed combat |
|
|
96 | skill. |
|
|
97 | - append [drop xxx coins] to altar/trigger_altar/identify_table/converter |
|
|
98 | names (also update all maps to use money instead of coins). |
|
|
99 | - add uuid accessors to perl. |
|
|
100 | - add coin names and archetype accessors to perl. |
|
|
101 | - fix runtime uuid file format to use "." instead of ",". |
|
|
102 | - change perl extensions to not use hardcoded coins and values. |
|
|
103 | - write uuids asynchronously (no hiccups due to uuid writes) |
|
|
104 | and be more parsimonous of uuid usage by the exact value out on exit. |
|
|
105 | - write log messages in another thread, removing another sync point. |
|
|
106 | - support multi-line log messages in a nicer way. |
|
|
107 | - be more portable w.r.t. uuids and format specifiers everywhere. |
|
|
108 | - fix a minor memleak in the random map generator. |
|
|
109 | - some parts of the random map generator are not coroutine-safe, |
|
|
110 | so only call it "single-threaded". |
|
|
111 | - major cleanup of memory management in random map generator. |
|
|
112 | - slight refactoring of the random map generator, faster too. |
|
|
113 | - solve the "slice_alloc becomes negative" mystery - no allocation bug, |
|
|
114 | bookkeeping bug. |
|
|
115 | - work around "player is on active list" problem by deactivating player |
|
|
116 | after loading. |
|
|
117 | - garbage collect shstr's more evenly and adaptively only when |
|
|
118 | there have in fact been allocations. |
|
|
119 | - fix object::insert to do as documented and insert into the env |
|
|
120 | if necessary. |
|
|
121 | - fix cf::map::unique_maps. |
|
|
122 | - fix nrof overflow check in can_merge_slow. |
|
|
123 | - fix converter code to handle >31 bit values. |
|
|
124 | - added support for the player_sold flag |
|
|
125 | - converters no longer accept unpaid items. |
|
|
126 | - canonicalize random map meta files for better unification. |
|
|
127 | |
|
|
128 | 2.43 Sun Apr 6 20:35:29 CEST 2008 |
|
|
129 | - work around a glibc bug that causes calloc to return non-zero memory |
|
|
130 | when mlockall has been used. |
|
|
131 | - pass environment to perl_sys_init3, as required by newer perls. |
|
|
132 | - use separate thread for ticker timing (and more in the future). |
|
|
133 | this greatly increases timing accuracy and gets rid of an enourmous |
|
|
134 | number of gettimeofday calls. |
|
|
135 | - use a separate thread to signal aio completion, for lower latency. |
|
|
136 | - require Coro 4.47, which fixes a data corruption bug with its C API. |
|
|
137 | |
|
|
138 | 2.42 Sat Mar 15 12:05:21 CET 2008 |
|
|
139 | - rebalanced default experience table to be more exponential |
|
|
140 | and much easier up to level ~40, then moderately harder. |
|
|
141 | - change attuned/repelled level boni to +-8 from +-2. |
|
|
142 | - use SvUPGRADE to avoid exception in sv_upgrade with perl 5.10. |
|
|
143 | - do not exit on reload/load errors but properly cleanup. |
|
|
144 | - fix a 32 bit uncleanlyness in the slice debugging wrapper. |
|
|
145 | |
|
|
146 | 2.41 Fri Jan 25 13:15:37 CET 2008 |
|
|
147 | - get rid of YAML::Syck, it's too buggy and misparses many files |
|
|
148 | (this fixes the jeweler skill). |
|
|
149 | - back-to-back perl_reloads don't freeze the ticker anymore. |
|
|
150 | - convert cfutil from Event to EV (forgot to do this earlier...). |
|
|
151 | - move tombstone to real map if player died due to cave-in (even if |
|
|
152 | it has reset, which is better than putting it on the savebed, also as |
|
|
153 | proof that the palyer didn't use a savebed). |
|
|
154 | |
|
|
155 | 2.4 Sun Jan 13 13:41:29 CET 2008 |
|
|
156 | - work around perl bug in configure perl module version check. |
7 | - fix bug in golem move code that would cause a crash at tiling borders. |
157 | - fix bug in golem move code that would cause a crash at tiling borders. |
8 | - fix a freeze bug when looking for an arrow in the inventory. |
158 | - fix a freeze bug when looking for an arrow in the inventory. |
|
|
159 | - fix a bug in animate_weapon, causing a crash. |
|
|
160 | - no longer exit when a coroutine throws an exception. |
|
|
161 | - fix a potential double free bug (nicely exploited by g++ 4.2). |
|
|
162 | - fix the "<player> is nuts" message. |
|
|
163 | - fix an exception at logout due to the json_coder being gone. |
9 | - upgrade to EV version 2.0 API. |
164 | - upgrade to EV version 2.0 API. |
10 | - when players don't apply a savebed correctly but stand above one, |
165 | - when players don't apply a savebed correctly but stand above one, |
11 | do not move or kill them. |
166 | do not move or kill them. |
12 | - implement client-side settings page in playerbook (0.9963+ required). |
167 | - implement client-side settings page in playerbook (0.9963+ required). |
13 | - implement generic framework for server-side resource files. |
168 | - implement generic framework for server-side resource files. |
… | |
… | |
15 | - hook experience table update into the framework. |
170 | - hook experience table update into the framework. |
16 | - move jeweler.yaml to resources (arch/). |
171 | - move jeweler.yaml to resources (arch/). |
17 | - switch from Crossfire to Deliantra perl module. |
172 | - switch from Crossfire to Deliantra perl module. |
18 | - implement json2json arch filter. |
173 | - implement json2json arch filter. |
19 | - implement widget protocol version 2, support for ui templates. |
174 | - implement widget protocol version 2, support for ui templates. |
|
|
175 | - mapinfo is now handled fully asynchronously. |
20 | - ext/irc: also log irc messages. |
176 | - ext/irc: also log irc messages. |
|
|
177 | - ext/schmorplog: write user stat files asynchronously. |
21 | |
178 | |
22 | 2.32 Sun Dec 2 18:11:01 CET 2007 |
179 | 2.32 Sun Dec 2 18:11:01 CET 2007 |
23 | - limited the number of items that can be picked up and dropped |
180 | - limited the number of items that can be picked up and dropped |
24 | as temporary measurement against bad performance or dropping things |
181 | as temporary measurement against bad performance or dropping things |
25 | (this lead to long freezes and triggered the watchdog). |
182 | (this lead to long freezes and triggered the watchdog). |