annotate Libs/LibStub/LibStub.lua @ 29:aabec73640a0 v7

fixed bug with combat log code on entering combat
author yellowfive
date Fri, 17 Oct 2014 02:44:02 -0700
parents e75889a45130
children 01b63b8ed811
rev   line source
adam@3 1 -- $Id: LibStub.lua 76 2007-09-03 01:50:17Z mikk $
adam@3 2 -- LibStub is a simple versioning stub meant for use in Libraries. http://www.wowace.com/wiki/LibStub for more info
adam@3 3 -- LibStub is hereby placed in the Public Domain
adam@3 4 -- Credits: Kaelten, Cladhaire, ckknight, Mikk, Ammo, Nevcairiel, joshborke
adam@3 5 local LIBSTUB_MAJOR, LIBSTUB_MINOR = "LibStub", 2 -- NEVER MAKE THIS AN SVN REVISION! IT NEEDS TO BE USABLE IN ALL REPOS!
adam@3 6 local LibStub = _G[LIBSTUB_MAJOR]
adam@3 7
adam@3 8 -- Check to see is this version of the stub is obsolete
adam@3 9 if not LibStub or LibStub.minor < LIBSTUB_MINOR then
adam@3 10 LibStub = LibStub or {libs = {}, minors = {} }
adam@3 11 _G[LIBSTUB_MAJOR] = LibStub
adam@3 12 LibStub.minor = LIBSTUB_MINOR
adam@3 13
adam@3 14 -- LibStub:NewLibrary(major, minor)
adam@3 15 -- major (string) - the major version of the library
adam@3 16 -- minor (string or number ) - the minor version of the library
adam@3 17 --
adam@3 18 -- returns nil if a newer or same version of the lib is already present
adam@3 19 -- returns empty library object or old library object if upgrade is needed
adam@3 20 function LibStub:NewLibrary(major, minor)
adam@3 21 assert(type(major) == "string", "Bad argument #2 to `NewLibrary' (string expected)")
adam@3 22 minor = assert(tonumber(strmatch(minor, "%d+")), "Minor version must either be a number or contain a number.")
adam@3 23
adam@3 24 local oldminor = self.minors[major]
adam@3 25 if oldminor and oldminor >= minor then return nil end
adam@3 26 self.minors[major], self.libs[major] = minor, self.libs[major] or {}
adam@3 27 return self.libs[major], oldminor
adam@3 28 end
adam@3 29
adam@3 30 -- LibStub:GetLibrary(major, [silent])
adam@3 31 -- major (string) - the major version of the library
adam@3 32 -- silent (boolean) - if true, library is optional, silently return nil if its not found
adam@3 33 --
adam@3 34 -- throws an error if the library can not be found (except silent is set)
adam@3 35 -- returns the library object if found
adam@3 36 function LibStub:GetLibrary(major, silent)
adam@3 37 if not self.libs[major] and not silent then
adam@3 38 error(("Cannot find a library instance of %q."):format(tostring(major)), 2)
adam@3 39 end
adam@3 40 return self.libs[major], self.minors[major]
adam@3 41 end
adam@3 42
adam@3 43 -- LibStub:IterateLibraries()
adam@3 44 --
adam@3 45 -- Returns an iterator for the currently registered libraries
adam@3 46 function LibStub:IterateLibraries()
adam@3 47 return pairs(self.libs)
adam@3 48 end
adam@3 49
adam@3 50 setmetatable(LibStub, { __call = LibStub.GetLibrary })
adam@3 51 end