v18
Chomp Message Library
v18 (2021-05-10)
Full Changelog Previous Releases
- Corrected version
- Merge pull request #43 from wow-rp-addons/patch/linked-list-queues
Use doubly linked lists for queues and priorities - Merge pull request #41 from wow-rp-addons/feature/libstub
Use LibStub for versioning - Use doubly linked lists for queues and priorities
This is mostly a performance enhancement when dealing with message
queues for players that get fairly large.
The existing queue system uses an array from which queues and messages
are removed from the start which causes all remaining elements to be
down-shuffled. In the case of large data transfers send to lots of
people, this would stack up and could have a noticable impact on CPU
usage.
As the primary operation performed on our queue is either a pop-front
or push-back and random access is never needed, it makes more sense to
instead use a doubly linked list.
Mercifully Blizzard already has a mixin for this that implements an
intrusive form where the front/back/prev/next keys are all stored on
the inserted nodes directly; so this changeset just swaps our queue
implementation to using that behind the scenes. - Remove the "()" from all error strings
Mostly for consistency with error styles elsewhere such as in Blizzard's
newer code; the "()" for functions doesn't really add any clarity, so
might as well clean these up while we're here.
The error messages in the CTL compat section are unmodified
intentionally as these should be the same as the original lib. - Swap usages of AddOn_Chomp to Chomp internally
The old global should be considered deprecated in favour of LibStub
internally at least, even if not actually dead in the public API. - Use LibStub for versioning
This makes Chomp a Good Citizen (tm) and stops it from reinventing the
wheel of library versioning for no heckin' good reason.
Chomp now registers itself via LibStub with the major "Chomp" and the
same incrementing (minor) version number it always has. The internal
table is stored on our library instance as the "Internal" subkey
instead of as the "__chomp_internal" global, though for compatibility
with addons that might pull in older versions of the library the old
internal global is still exported until the PLAYER_LOGIN event has
fired.
This change is fully backwards compatible as far as the public API is
concerned; The AddOn_Chomp global is still defined and just points to
the same library table registered with LibStub. For addons that have
captured the old AddOn_Chomp as an upvalue this shouldn't cause an
issue as there's no state on the old table that's required by the
library, since the whole public API avoids use of "self".
Note that the internal table is accessible after PLAYER_LOGIN has
fired via "Internal" key of the API table; this is intentional to assist
with debugging.
No work has been done to make the library upgradable after PLAYER_LOGIN
has fired; this would be a substantial task and likely can't be done
until the older versions are no longer in circulation. - Don't populate Battle.net accounts before login
There's an edge case with the new Battle.net logic where the SameRealm
table can be queried before it exists, as it's not created until the
PLAYER_LOGIN event has fired - so we'll just not do it until said
event has fired and the table should exist. - Merge pull request #42 from wow-rp-addons/feature/is-prefix-registered
Add IsAddonPrefixRegistered function to API - Add IsAddonPrefixRegistered function to API
Useful for checking if something has been registered with Chomp or
not, since currently RegisterAddonPrefix will error upon a second
attempt to register a prefix. - Merge pull request #40 from wow-rp-addons/patch/improve-bnet-account-lookup
Improve Battle.net game account lookups - Fix NormalizeRealmName pattern and returns
- nil => false
- Make the CanExchange logic a bit clearer
Since the gsub looked a bit magical giving it a function name should
make it less of a "WTF" a few months down the line. Additionally added
a protection against an empty realm name string. - Improve Battle.net game account checks
The existing logic for checking if a smart message could be sent via
Battle.net whispers involved traversing the entire friends list each
time a message was sent. Previous work made this work use a cache,
but we can do better.
This reworks the logic to instead prebuild a mapping of merged player
names ("name-realm") to game account IDs whenever the player logs in
or zones through a login screen, or whenever a Battle.net event is
raised. The resulting mapping only contains accounts that we'd consider
valid for exchanging data with - so offline players, same-faction and
realm ones, etc. aren't present.
This should be a nice free performance boost and, from quick checks
by loading Elly's profile doesn't break anything. - Quick packager fixups
Use project version replacement in the TOC and make it build on
tags only. - Merge pull request #38 from wow-rp-addons/feature/add-callback-registry
Add Callback Registry and OnMessageReceived callbacks - Add generic callback registry support
This adds a callback registry (provided by CallbackHandler) to provide
a way to implement a few features that have been desirable for a small
while now.
The callback API exposed by the library is a sane combination of the
one offered by Blizzards' CallbackRegistryMixin and CallbackHandler:- AddOn_Chomp.RegisterCallback(event, func, owner)
- AddOn_Chomp.UnregisterCallback(event, owner)
- AddOn_Chomp.UnregisterAllCallbacks(owner)
RegisterCallback will register the callback (func) for the named event
and bind it to the given owner. The owner can be a string, table, or
thread and is synonymous with the "self" used by CallbackHandler.
The callback will be dispatched with the owner as the first parameter,
followed by all arguments supplied with the event. The event name isn't
passed.
UnregisterCallback and UnregisterAllCallbacks act the same as their
counterparts in CallbackHandler, unregistering either the single
handler associated with an event for a given owner, or all events for
a given owner.
With this in place, the events that have been defined are as follows: - OnError
- OnMessageReceived
The OnError event replaces the existing ErrorCallback mechanism and
acts as it does today. The existing error callback related APIs
internally register to this event now, so backward compatibility
is maintained.
The OnMessageReceived event is dispatched each time any callback for
a registered prefix would be executed, with the same arguments supplied
to the prefix callback. This solves a longstanding annoyance of not
being able to generically register multiple callbacks for a single
prefix, which was resolved in another branch but not merged in due to
other concerns.
Future callbacks might involve an OnMessageSent or notifications for
comms load, but we'll cross those bridges when we get there.
- Merge pull request #39 from wow-rp-addons/unfeature/remove-apidocumentation
Remove Ingame API Documentation - Merge pull request #37 from wow-rp-addons/chore/add-packager-support
Add initial packager support - Remove API documentation integrations
The ingame API documentation system is seldom actually used for anything
outside of Blizzard and we've not been keeping this documentation up
to date as-is, in addition to it being wrong in a few areas at this
point as well.
As it's not really adding any value this commit just yeets it. We can
possibly revisit shoving it in the README at a later date, but until
then no one is really using the library enough to justify maintaining
the documentation, and most authors are already perfectly acquainted
with the idea of just reading the implementation - which is always
accurate, up-to-date, and has self-documenting errors and assertions. - Add initial packager support
This implements support for the packager and uploading new zips to
GitHub releases, as well as packaging internal dependencies which
is going to be needed for a few upcoming changes to the library.
This is the minimal work for the packager as a standalone reviewable
unit.
Of note, Chomp now embeds ChatThrottleLib so that it can ensure 100%
of the time is loaded for its own redirection layer. I'm still hoping
that in the future we can just kill that part and have CTL do all the
backend comms.