--- deliantra/server/Changes 2008/01/05 03:45:54 1.49 +++ deliantra/server/Changes 2008/04/24 00:38:52 1.108 @@ -1,10 +1,123 @@ Deliantra MORPG Server, Maps and Archetypes ChangeLog. -TODO: "you get the distinctive feeling that is nuts" -TODO: logging/backtrace in non-main contexts cause crashes with glibc 2.7 -TODO: perl exceptions inside coroutines exit, which is correct, but unwanted behaviour -TODO: map->at: attempt to copy freed scalar b7d4b48 to b800c38 at warn "FOO$m { ".scalar (@a)." }\n"; +TODO: ridify us from FLAG_NO_FIX_PLAYER +TODO: dragons should not be able to change their title via the settings tab in playerbook + + - completely automate the item add/delete on remove/insert. this should fix + all "ghost" item bugs caused by sloppy coding, as sloppy coding is now correct :) + - completely automate the weight handling, should fix all weight + accounting bugs caused by sloppy coding, as sloppy coding is now correct :) + - reloading archetypes while a user was in the character creation phase + could crash the server. + - fix a nontrivial number of cases of code commented similar + to "is this really correct?", as many of those cases are now handles + automatically by lower level code. + - replace many ad-hoc checks for client visibility by object::visible_to, + should result in broader applicability of functions using it. + - merge items with different arch pointers refering to the same arch + (due to archetype reloads). + - refactored the object remove/insert functions and most related + functions (decrease, split, merge_ob etc.). + - make it compile better on freebsd (reported by pippijn). + - remove GT_UPDATE_INV (no longer applicable). + - fix the longstanding "container stays open" bug. + - improved floorbox updating to be incremental and other protocol + optimisations. + - get rid of update_after_inventory_change and only do update stats + for weight once/tick/player at max. + +2.51 Sun Apr 20 21:27:37 CEST 2008 + - properly link against libgthread as that is needed to make the slice + allocator thread-safe. + - support perls not compiled with 64 bit support (though this is not a + recommended configuration) (reported by Samuel Gondouin). + - always put godgiven items into the player inventory, never any containers. + - (arch) + - (maps, arch) the scorn go club was founded! + - (arch) do no longer support player abilities, they didn't work anyways. + - (arch) the alchemy spell is now of the alchemy spell school, which + became a real spell-class. + - (arch) the alchemist class now get an alchemy spell book for new characters. + - (arch) considerably strengthened spark shower and destruction. + - match archetypes by name, not by ptr, in treasure.C, this makes archetypes + finally reloadable at runtime. + - changed archetype loading algorithm to only require one pass and + use delayed resolving of references. + - examine command now uses the examine infobox. + - implement an "incremental garbage collector" for archetypes. + - enable slice allocator again. + - implement optional free memory poisoning. + +2.5 Wed Apr 16 15:06:53 CEST 2008 + - the two handed weapon skill can no longer be used as unarmed combat + skill. + - append [drop xxx coins] to altar/trigger_altar/identify_table/converter + names (also update all maps to use money instead of coins). + - add uuid accessors to perl. + - add coin names and archetype accessors to perl. + - fix runtime uuid file format to use "." instead of ",". + - change perl extensions to not use hardcoded coins and values. + - write uuids asynchronously (no hiccups due to uuid writes) + and be more parsimonous of uuid usage by the exact value out on exit. + - write log messages in another thread, removing another sync point. + - support multi-line log messages in a nicer way. + - be more portable w.r.t. uuids and format specifiers everywhere. + - fix a minor memleak in the random map generator. + - some parts of the random map generator are not coroutine-safe, + so only call it "single-threaded". + - major cleanup of memory management in random map generator. + - slight refactoring of the random map generator, faster too. + - solve the "slice_alloc becomes negative" mystery - no allocation bug, + bookkeeping bug. + - work around "player is on active list" problem by deactivating player + after loading. + - garbage collect shstr's more evenly and adaptively only when + there have in fact been allocations. + - fix object::insert to do as documented and insert into the env + if necessary. + - fix cf::map::unique_maps. + - fix nrof overflow check in can_merge_slow. + - fix converter code to handle >31 bit values. + - added support for the player_sold flag + - converters no longer accept unpaid items. + - canonicalize random map meta files for better unification. + +2.43 Sun Apr 6 20:35:29 CEST 2008 + - work around a glibc bug that causes calloc to return non-zero memory + when mlockall has been used. + - pass environment to perl_sys_init3, as required by newer perls. + - use separate thread for ticker timing (and more in the future). + this greatly increases timing accuracy and gets rid of an enourmous + number of gettimeofday calls. + - use a separate thread to signal aio completion, for lower latency. + - require Coro 4.47, which fixes a data corruption bug with its C API. + +2.42 Sat Mar 15 12:05:21 CET 2008 + - rebalanced default experience table to be more exponential + and much easier up to level ~40, then moderately harder. + - change attuned/repelled level boni to +-8 from +-2. + - use SvUPGRADE to avoid exception in sv_upgrade with perl 5.10. + - do not exit on reload/load errors but properly cleanup. + - fix a 32 bit uncleanlyness in the slice debugging wrapper. + +2.41 Fri Jan 25 13:15:37 CET 2008 + - get rid of YAML::Syck, it's too buggy and misparses many files + (this fixes the jeweler skill). + - back-to-back perl_reloads don't freeze the ticker anymore. + - convert cfutil from Event to EV (forgot to do this earlier...). + - move tombstone to real map if player died due to cave-in (even if + it has reset, which is better than putting it on the savebed, also as + proof that the palyer didn't use a savebed). + +2.4 Sun Jan 13 13:41:29 CET 2008 + - work around perl bug in configure perl module version check. - fix bug in golem move code that would cause a crash at tiling borders. + - fix a freeze bug when looking for an arrow in the inventory. + - fix a bug in animate_weapon, causing a crash. + - no longer exit when a coroutine throws an exception. + - fix a potential double free bug (nicely exploited by g++ 4.2). + - fix the " is nuts" message. + - fix an exception at logout due to the json_coder being gone. - upgrade to EV version 2.0 API. - when players don't apply a savebed correctly but stand above one, do not move or kill them. @@ -16,7 +129,9 @@ - switch from Crossfire to Deliantra perl module. - implement json2json arch filter. - implement widget protocol version 2, support for ui templates. + - mapinfo is now handled fully asynchronously. - ext/irc: also log irc messages. + - ext/schmorplog: write user stat files asynchronously. 2.32 Sun Dec 2 18:11:01 CET 2007 - limited the number of items that can be picked up and dropped