Help

LibSink-2.0

Libraries Login to Add Favorites
  • 0 Likes
  • World of Warcraft
  • 278,322 Downloads
  • Supports: 4.2
  • 212 Average Daily Downloads
  • Created 9/26/2008 2:54:15 AM
  • Updated 6/30/2011 2:09:03 AM
  • 73 Favorites
  • Project Site
  • License: CC BY-NC-SA 3.0
  • Release Type: Release
  • Newest File: r79
or

About LibSink-2.0

LibSink-2.0 is a small library that you can throw in to easily get configuration options for your addon on where it should output any kind of messages.

By default, LibSink-2.0 supports several addons as output "sinks"; Blizzard floating combat text, MSBT, SCT, Parrot, BCF. And if that's not enough it can also route your output to any ingame channel, like raid warning, party chat, say. Or just to a local chatframe, UIErrorsFrame, etc.

In order to use LibSink-2.0 in your addon, you simply need to embed it into the addon object;

local addon = LibStub("AceAddon-3.0"):NewAddon("Bunnies!", "LibSink-2.0")

Then you get a few new methods on your addon object, most notably :Pour(...):

self:Pour(text, r, g, b, font, size, outline, sticky, location, icon)

The only ones you need to concern yourself with are usually text, r, g and b. These arguments say what text you want to output in and what color. RGB should be passed as decimal values ranging from 0.0 to 1.0.

The next thing you should note is that LibSink-2.0 provides a method on your addon object that you can invoke to produce options for configuring where, exactly, :Pour requests should be poured from your addon;

self:GetSinkAce3OptionsDataTable()
self:GetSinkAce2OptionsDataTable()

So obviously you use the one appropriate for your addon (probably Ace3 nowadays). If you already have an option table for your addon (which is very likely), you just insert the return value from this function into its own section in your config;

local options = {
    type = "group",
    name = "Bunny options!",
    args = {}
}
options.args.output = self:GetSinkAce3OptionsDataTable()

And, of course, LibSink-2.0 will need somewhere to store the users preferences about your addon, and since libraries can not have SavedVariables, you need to supply it;

self:SetSinkStorage(self.db.profile)

LibSink can potentially store a few different keys in your database, including sink20OutputSink, sink20Sticky and sink20ScrollArea.

------------------------------------------------------------------------
r79 | rabbit | 2011-06-30 07:08:58 +0000 (Thu, 30 Jun 2011) | 1 line
Changed paths:
   M /trunk/LibSink-2.0/LibSink-2.0.lua

Patch from Arrowmaster for ticket 3.
------------------------------------------------------------------------
r78 | rabbit | 2011-06-28 21:41:08 +0000 (Tue, 28 Jun 2011) | 1 line
Changed paths:
   M /trunk/LibSink-2.0.toc

toc bump
------------------------------------------------------------------------
r77 | ananhaid | 2011-04-14 02:14:02 +0000 (Thu, 14 Apr 2011) | 2 lines
Changed paths:
   M /trunk/LibSink-2.0.toc

LibSink-2.0:
- zhCN update.
------------------------------------------------------------------------

Learn how to disable ads
Learn how to disable ads
Login to Curse

Don't have an account? Create One.

Get an epic experience with Curse Premium
  • Faster Addon Downloads
  • Premium-Only Beta Giveaways
  • Ad-Free Curse.com Experience
  • Premium Curse Client
  • and many More Features
  • Learn More »

Minecraft 3D Print Giveaway

Enter Now!