annotate Core.lua @ 113:52e8cad9ccc4 Release 2010-09-01

Ticket 35 - I found a better solution to prevent bag scanning from interfering with mailing, so both can be done at the same time now.
author Asa Ayers <Asa.Ayers@Gmail.com>
date Wed, 01 Sep 2010 23:36:23 -0700
parents 619ee0a1ff3b
children d94195157a6b
rev   line source
Asa@63 1 local ItemAuditor = select(2, ...)
Asa@63 2 ItemAuditor = LibStub("AceAddon-3.0"):NewAddon(ItemAuditor, "ItemAuditor", "AceEvent-3.0", "AceBucket-3.0")
Asa@65 3 --@debug@
Asa@65 4 _G['ItemAuditor'] = ItemAuditor
Asa@65 5 --@end-debug@
Asa@0 6
Asa@87 7 if not DevTools_Dump then
Asa@87 8 function DevTools_Dump()
Asa@87 9 end
Asa@87 10 end
Asa@87 11
Asa@98 12 local allMailboxes = {}
Asa@98 13 local myMailbox = {}
Asa@67 14
Asa@67 15 ItemAuditor.Options = {
Asa@67 16 handler = ItemAuditor,
Asa@67 17 name = "ItemAuditor @project-version@",
Asa@67 18 type = 'group',
Asa@67 19 args = {
Asa@67 20 options = {
Asa@67 21 type = "execute",
Asa@67 22 name = "options",
Asa@67 23 desc = "Show Blizzard's options GUI",
Asa@67 24 func = "ShowOptionsGUI",
Asa@67 25 guiHidden = true,
Asa@67 26 },
Asa@67 27 debug = {
Asa@67 28 type = "execute",
Asa@67 29 name = "debug",
Asa@67 30 desc = "Shows the debug frame",
Asa@67 31 func = function() ItemAuditor_DebugFrame:Show() end,
Asa@67 32 guiHidden = true,
Asa@67 33 },
Asa@67 34 suspend = {
Asa@67 35 type = "toggle",
Asa@67 36 name = "suspend",
Asa@67 37 desc = "Suspends ItemAuditor",
Asa@67 38 get = "IsEnabled",
Asa@67 39 set = "SetEnabled",
Asa@67 40 guiHidden = true,
Asa@67 41 },
Asa@67 42 },
Asa@67 43 }
Asa@67 44
Asa@100 45 ItemAuditor.DB_defaults = {
Asa@100 46 char = {
Asa@100 47 ah = 1,
Asa@100 48 use_quick_auctions = false,
Asa@101 49 profitable_threshold = 10000,
Asa@100 50 auction_threshold = 0.15,
Asa@111 51 auction_threshold_value = 0,
Asa@100 52 qa_extra = 0,
Asa@100 53 output_chat_frame = nil,
Asa@109 54 cod_warnings = true,
Asa@100 55 },
Asa@100 56 profile = {
Asa@100 57 messages = {
Asa@100 58 cost_updates = true,
Asa@100 59 queue_skip = false,
Asa@100 60 },
Asa@100 61 ItemAuditor_enabled = true,
Asa@100 62 queue_destination = nil,
Asa@100 63 disabled_deciders = {},
Asa@100 64 pricing_method = 'low',
Asa@100 65 },
Asa@100 66 factionrealm = {
Asa@100 67 item_account = {},
Asa@100 68 items = {},
Asa@100 69 outbound_cod = {},
Asa@100 70 mailbox = {},
Asa@100 71 },
Asa@100 72 }
Asa@100 73
Asa@63 74 function ItemAuditor:OnInitialize()
Asa@100 75 self.db = LibStub("AceDB-3.0"):New("ItemAuditorDB", ItemAuditor.DB_defaults, true)
Asa@98 76
Asa@98 77 allMailboxes = self.db.factionrealm.mailbox
Asa@98 78 if not allMailboxes[UnitName("player")] then
Asa@98 79 allMailboxes[UnitName("player")] = {}
Asa@98 80 end
Asa@98 81 myMailbox = allMailboxes[UnitName("player")]
Asa@98 82
Asa@67 83 self.optionsFrame = LibStub("AceConfigDialog-3.0"):AddToBlizOptions("ItemAuditor", "ItemAuditor")
Asa@67 84
Asa@67 85 LibStub("AceConfig-3.0"):RegisterOptionsTable("ItemAuditor", ItemAuditor.Options, {"ia"})
Asa@38 86 ItemAuditor:RegisterFrame(ItemAuditor_DebugFrame)
Asa@23 87
Asa@86 88 LibStub("AceConsole-3.0"):RegisterChatCommand('rl', ReloadUI)
Asa@100 89
Asa@101 90 if self.db.char.crafting_threshold then
Asa@101 91 local threshold = self.db.char.crafting_threshold
Asa@101 92 if threshold == 1 then
Asa@101 93 self.db.char.profitable_threshold = 5000
Asa@101 94 elseif threshold == 2 then
Asa@101 95 self.db.char.profitable_threshold = 10000
Asa@101 96 elseif threshold == 3 then
Asa@101 97 self.db.char.profitable_threshold = 50000
Asa@101 98 end
Asa@101 99
Asa@101 100 self.db.char.crafting_threshold = nil
Asa@101 101 end
Asa@101 102
Asa@112 103 ItemAuditor:IsQACompatible()
Asa@112 104
Asa@65 105 --@debug@
Asa@59 106 -- ItemAuditor_DebugFrame:Show()
Asa@59 107 -- self:CreateFrame('tab_crafting')
Asa@74 108 self:RegisterEvent("TRADE_SKILL_SHOW", function()
Asa@93 109 ItemAuditor:DisplayCrafting()
Asa@74 110 end)
Asa@65 111 --@end-debug@
Asa@0 112 end
Asa@0 113
Asa@67 114
Asa@67 115
Asa@38 116 local registeredEvents = {}
Asa@63 117 local originalRegisterEvent = ItemAuditor.RegisterEvent
Asa@63 118 function ItemAuditor:RegisterEvent(event, callback, arg)
Asa@38 119 registeredEvents[event] = true
Asa@38 120 if arg ~= nil then
Asa@38 121 return originalRegisterEvent(self, event, callback, arg)
Asa@38 122 elseif callback ~= nil then
Asa@38 123 return originalRegisterEvent(self, event, callback)
Asa@38 124 else
Asa@38 125 return originalRegisterEvent(self, event)
Asa@38 126 end
Asa@38 127 end
Asa@38 128
Asa@63 129 local originalUnregisterEvent = ItemAuditor.UnregisterEvent
Asa@63 130 function ItemAuditor:UnregisterEvent(event)
Asa@38 131 registeredEvents[event] = nil
Asa@38 132 return originalUnregisterEvent(self, event)
Asa@38 133 end
Asa@38 134
Asa@63 135 function ItemAuditor:UnregisterAllEvents()
Asa@38 136 for event in pairs(registeredEvents) do
Asa@38 137 self:UnregisterEvent(event)
Asa@38 138 end
Asa@38 139 end
Asa@38 140
Asa@38 141 local registeredFrames = {}
Asa@63 142 function ItemAuditor:RegisterFrame(frame)
Asa@38 143 tinsert(registeredFrames, frame)
Asa@38 144 end
Asa@38 145
Asa@63 146 function ItemAuditor:HideAllFrames()
Asa@38 147 for key, frame in pairs(registeredFrames) do
Asa@38 148 if frame then
Asa@38 149 frame:Hide()
Asa@38 150 end
Asa@38 151 end
Asa@38 152 end
Asa@38 153
Asa@63 154 function ItemAuditor:ConvertItems()
Asa@8 155 for itemName, value in pairs(self.db.factionrealm.item_account) do
Asa@15 156 local itemID = self:GetItemID(itemName)
Asa@8 157 if itemID ~= nil then
Asa@8 158 self:GetItem('item:' .. itemID)
Asa@8 159 end
Asa@8 160 if value == 0 then
Asa@8 161 self.db.factionrealm.item_account[itemName] = nil
Asa@8 162 end
Asa@8 163 end
Asa@8 164
Asa@8 165 for link, data in pairs(self.db.factionrealm.items) do
Asa@8 166 if self:GetItem(link).count == 0 or self:GetItem(link).invested == 0 then
Asa@8 167 self:RemoveItem(link)
Asa@8 168 end
Asa@10 169 end
Asa@10 170
Asa@12 171 self:RefreshQAGroups()
Asa@12 172 end
Asa@12 173
Asa@65 174 -- Options doesn't exist when this file is created the first time, so getOptions will
Asa@65 175 -- make one call to :GetModule and return the result and replace itself with a
Asa@65 176 -- function that simply returns the same object. The permanent solution will probably be
Asa@65 177 -- to move :Print to a different module.
Asa@65 178 local function getOptions()
Asa@65 179 local Options = ItemAuditor:GetModule("Options")
Asa@65 180 getOptions = function() return Options end
Asa@65 181 return Options
Asa@65 182 end
Asa@65 183
Asa@24 184 local printPrefix = "|cFFA3CEFFItemAuditor|r: "
Asa@63 185 function ItemAuditor:Print(message, ...)
Asa@24 186 message = format(message, ...)
Asa@65 187 getOptions().GetSelectedChatWindow():AddMessage( printPrefix .. tostring(message))
Asa@16 188 end
Asa@16 189
Asa@81 190 local bankOpen = false
Asa@81 191
Asa@81 192 function ItemAuditor:BankFrameChanged(event)
Asa@81 193 bankOpen = (event == 'BANKFRAME_OPENED')
Asa@81 194 ItemAuditor:UpdateCurrentInventory()
Asa@81 195 end
Asa@81 196
Asa@80 197 local function scanBag(bagID, i)
Asa@80 198 bagSize=GetContainerNumSlots(bagID)
Asa@80 199 for slotID = 0, bagSize do
Asa@80 200 local link= GetContainerItemLink(bagID, slotID);
Asa@80 201 link = link and ItemAuditor:GetSafeLink(link)
Asa@80 202
Asa@80 203 if link ~= nil and i[link] == nil then
Asa@81 204 i[link] = GetItemCount(link, bankOpen);
Asa@80 205 end
Asa@80 206 end
Asa@80 207 end
Asa@80 208
Asa@63 209 function ItemAuditor:GetCurrentInventory()
Asa@8 210 local i = {}
Asa@8 211 local bagID
Asa@8 212 local slotID
Asa@8 213
Asa@8 214 for bagID = 0, NUM_BAG_SLOTS do
Asa@80 215 scanBag(bagID, i)
Asa@8 216 end
Asa@80 217
Asa@81 218 if bankOpen then
Asa@81 219 scanBag(BANK_CONTAINER, i)
Asa@81 220 for bagID = NUM_BAG_SLOTS+1, NUM_BANKBAGSLOTS do
Asa@81 221 scanBag(bagID, i)
Asa@81 222 end
Asa@80 223 end
Asa@80 224
Asa@8 225 return {items = i, money = GetMoney()}
Asa@0 226 end
Asa@0 227
Asa@63 228 function ItemAuditor:GetInventoryDiff(pastInventory, current)
Asa@8 229 if current == nil then
Asa@8 230 current = self:GetCurrentInventory()
Asa@8 231 end
Asa@8 232 local diff = {}
Asa@8 233
Asa@8 234 for link, count in pairs(current.items) do
Asa@8 235 if pastInventory.items[link] == nil then
Asa@8 236 diff[link] = count
Asa@23 237 self:Debug("1 diff[" .. link .. "]=" .. diff[link])
Asa@8 238 elseif count - pastInventory.items[link] ~= 0 then
Asa@8 239 diff[link] = count - pastInventory.items[link]
Asa@23 240 self:Debug("2 diff[" .. link .. "]=" .. diff[link])
Asa@8 241 end
Asa@8 242 end
Asa@8 243
Asa@8 244 for link, count in pairs(pastInventory.items) do
Asa@8 245 if current.items[link] == nil then
Asa@8 246 diff[link] = -count
Asa@23 247 self:Debug("3 diff[" .. link .. "]=" .. diff[link])
Asa@8 248 elseif current.items[link] - count ~= 0 then
Asa@8 249 diff[link] = current.items[link] - pastInventory.items[link]
Asa@23 250 self:Debug("4 diff[" .. link .. "]=" .. diff[link])
Asa@8 251 end
Asa@8 252 end
Asa@8 253
Asa@8 254 local moneyDiff = current.money - pastInventory.money
Asa@23 255 if abs(moneyDiff) > 0 then
Asa@23 256 self:Debug("moneyDiff: " .. moneyDiff)
Asa@23 257 end
Asa@8 258
Asa@8 259 return {items = diff, money = moneyDiff}
Asa@0 260 end
Asa@0 261
Asa@39 262 local inboundCOD = {}
Asa@39 263 local skipMail = {}
Asa@63 264 function ItemAuditor:ScanMail()
Asa@0 265 local results = {}
Asa@39 266 local CODPaymentRegex = gsub(COD_PAYMENT, "%%s", "(.*)")
Asa@39 267
Asa@0 268 for mailIndex = 1, GetInboxNumItems() or 0 do
Asa@39 269 local sender, msgSubject, msgMoney, msgCOD, daysLeft, msgItem, _, _, msgText, _, isGM = select(3, GetInboxHeaderInfo(mailIndex))
Asa@15 270 local mailType = self:GetMailType(msgSubject)
Asa@6 271
Asa@39 272 local mailSignature = msgSubject .. '-' .. msgMoney .. '-' .. msgCOD .. '-' .. daysLeft
Asa@39 273
Asa@6 274 results[mailType] = (results[mailType] or {})
Asa@6 275
Asa@39 276 if skipMail[mailSignature] ~= nil then
Asa@39 277 -- do nothing
Asa@39 278 elseif mailType == "NonAHMail" and msgCOD > 0 then
Asa@6 279 mailType = 'COD'
Asa@6 280 results[mailType] = (results[mailType] or {})
Asa@5 281
Asa@5 282 local itemTypes = {}
Asa@5 283 for itemIndex = 1, ATTACHMENTS_MAX_RECEIVE do
Asa@5 284 local itemName, _, count, _, _= GetInboxItem(mailIndex, itemIndex)
Asa@5 285 if itemName ~= nil then
Asa@39 286 itemTypes[itemName] = (itemTypes[itemName] or 0) + count
Asa@5 287 end
Asa@5 288 end
Asa@5 289
Asa@15 290 if self:tcount(itemTypes) == 1 then
Asa@5 291 for itemName, count in pairs(itemTypes) do
Asa@39 292 results[mailType][itemName] = (results[mailType][itemName] or {total=0,count=0})
Asa@39 293 results[mailType][itemName].total = results[mailType][itemName].total + msgCOD
Asa@39 294
Asa@39 295 if inboundCOD[mailSignature] == nil then
Asa@39 296 results[mailType][itemName].count = results[mailType][itemName].count + count
Asa@39 297 inboundCOD[mailSignature] = (inboundCOD[mailSignature] or 0) + count
Asa@39 298 else
Asa@39 299 results[mailType][itemName].count = inboundCOD[mailSignature]
Asa@39 300 end
Asa@39 301
Asa@39 302
Asa@5 303 end
Asa@5 304 else
Asa@5 305 self:Debug("Don't know what to do with more than one item type on COD mail.")
Asa@5 306 end
Asa@6 307 elseif mailType == "CODPayment" then
Asa@39 308 -- /dump ItemAuditor.db.factionrealm.outbound_cod
Asa@39 309 self:Debug(msgSubject)
Asa@39 310 self:Debug(CODPaymentRegex)
Asa@39 311 local outboundSubject = select(3, msgSubject:find(CODPaymentRegex))
Asa@39 312 local trackID
Asa@39 313 if outboundSubject ~= nil then
Asa@39 314 self:Debug(outboundSubject)
Asa@45 315 trackID = select(3, outboundSubject:find('[[]IA: (%d*)[]]'))
Asa@39 316
Asa@39 317 if trackID ~= nil then
Asa@45 318 trackID = tonumber(trackID)
Asa@45 319 self:Debug('COD ID: %s', trackID)
Asa@39 320 local cod = self.db.factionrealm.outbound_cod[trackID]
Asa@39 321 if cod == nil then
Asa@39 322 skipMail[mailSignature] = true
Asa@39 323 self:Print("WARNING: {%s} has an invalid ItemAuditor tracking number.", msgSubject)
Asa@39 324 else
Asa@39 325 itemName = trackID .. "|" .. cod['link']
Asa@39 326
Asa@39 327
Asa@39 328 results[mailType][itemName] = (results[mailType][itemName] or {total=0,count=0})
Asa@39 329 results[mailType][itemName].total = results[mailType][itemName].total - msgMoney
Asa@39 330 results[mailType][itemName].count = results[mailType][itemName].count - cod.count
Asa@39 331 end
Asa@39 332 end
Asa@39 333 end
Asa@5 334
Asa@39 335 if trackID == nil then
Asa@39 336 skipMail[mailSignature] = true
Asa@39 337 self:Print("WARNING: {%s} is a COD payment but doesn't have an ItemAuditor tracking number.", msgSubject)
Asa@39 338 end
Asa@5 339
Asa@0 340 elseif mailType == "AHSuccess" then
Asa@0 341 local invoiceType, itemName, playerName, bid, buyout, deposit, consignment = GetInboxInvoiceInfo(mailIndex);
Asa@26 342 results[mailType][itemName] = (results[mailType][itemName] or {total=0,count=0})
Asa@26 343 results[mailType][itemName].total = results[mailType][itemName].total - deposit - buyout + consignment
Asa@26 344
Asa@0 345
Asa@0 346 elseif mailType == "AHWon" then
Asa@0 347 local invoiceType, itemName, playerName, bid, buyout, deposit, consignment = GetInboxInvoiceInfo(mailIndex);
Asa@26 348 results[mailType][itemName] = (results[mailType][itemName] or {total=0,count=0})
Asa@26 349 results[mailType][itemName].total = results[mailType][itemName].total + bid
Asa@26 350
Asa@98 351 local count = select(3, GetInboxItem(mailIndex,1))
Asa@26 352 results[mailType][itemName].count = results[mailType][itemName].count + count
Asa@5 353 elseif mailType == "AHExpired" or mailType == "AHCancelled" or mailType == "AHOutbid" then
Asa@0 354 -- These should be handled when you pay the deposit at the AH
Asa@0 355 else
Asa@24 356 -- self:Debug("Unhandled mail type: " .. mailType)
Asa@24 357 -- self:Debug(msgSubject)
Asa@0 358 end
Asa@0 359
Asa@0 360 end
Asa@98 361
Asa@98 362 wipe(myMailbox)
Asa@23 363 for mailType, collection in pairs(results) do
Asa@98 364 myMailbox[mailType] = {}
Asa@26 365 for item, data in pairs(collection) do
Asa@98 366 myMailbox[mailType][item] = {
Asa@98 367 total = data.total,
Asa@98 368 count = data.count,
Asa@98 369 }
Asa@98 370 -- self:Print(format("|cFF00FF00MailScan|r: %s - %s - %s x %s", mailType, item, data.total, data.count))
Asa@23 371 end
Asa@23 372 end
Asa@0 373 return results
Asa@0 374 end
Asa@0 375
Asa@105 376 local realm = GetRealmName()
Asa@105 377 local ds_account = 'Default'
Asa@82 378 function ItemAuditor:GetItemCount(searchID)
Asa@105 379 local count = 0
Asa@105 380 for _, character in pairs(DataStore:GetCharacters(realm, ds_account)) do
Asa@105 381 local bag, bank = DataStore:GetContainerItemCount(character, searchID)
Asa@105 382 count = count + (bag or 0) + (bank or 0)
Asa@105 383 count = count + (DataStore:GetAuctionHouseItemCount(character, searchID) or 0)
Asa@105 384 count = count + (DataStore:GetInventoryItemCount(character, searchID) or 0)
Asa@105 385 count = count + (DataStore:GetMailItemCount(character, searchID) or 0)
Asa@105 386 count = count + (DataStore:GetCurrencyItemCount(character, searchID) or 0)
Asa@105 387 end
Asa@98 388 local itemName = GetItemInfo(searchID)
Asa@98 389 for character, mailbox in pairs(allMailboxes) do
Asa@98 390 for type, items in pairs(mailbox) do
Asa@98 391 if type == 'AHWon' or type == 'COD' then
Asa@98 392 for name, data in pairs(items) do
Asa@98 393 if name == itemName then
Asa@98 394 count = count - data.count
Asa@82 395
Asa@98 396 end
Asa@98 397 end
Asa@98 398 end
Asa@98 399 end
Asa@82 400 end
Asa@82 401 return count
Asa@82 402 end
Asa@82 403
Asa@63 404 function ItemAuditor:GetItem(link, viewOnly)
Asa@9 405 if viewOnly == nil then
Asa@9 406 viewOnly = false
Asa@9 407 end
Asa@8 408
Asa@9 409 local itemName = nil
Asa@9 410 if self:GetSafeLink(link) == nil then
Asa@9 411 itemName = link
Asa@9 412 else
Asa@9 413 link = self:GetSafeLink(link)
Asa@9 414 itemName = GetItemInfo(link)
Asa@9 415 end
Asa@9 416
Asa@12 417
Asa@9 418 if self.db.factionrealm.item_account[itemName] ~= nil then
Asa@65 419 self.db.factionrealm.items[link] = {
Asa@82 420 count = ItemAuditor:GetItemCount(self:GetIDFromLink(link)),
Asa@8 421 invested = abs(self.db.factionrealm.item_account[itemName] or 0),
Asa@8 422 }
Asa@8 423 self.db.factionrealm.item_account[itemName] = nil
Asa@8 424 end
Asa@8 425
Asa@65 426 if viewOnly == false and self.db.factionrealm.items[link] == nil then
Asa@24 427
Asa@65 428 self.db.factionrealm.items[link] = {
Asa@82 429 count = ItemAuditor:GetItemCount(self:GetIDFromLink(link)),
Asa@9 430 invested = abs(self.db.factionrealm.item_account[itemName] or 0),
Asa@9 431 }
Asa@9 432
Asa@9 433 end
Asa@9 434
Asa@65 435 if self.db.factionrealm.items[link] ~= nil then
Asa@82 436 self.db.factionrealm.items[link].count = ItemAuditor:GetItemCount(self:GetIDFromLink(link))
Asa@45 437
Asa@65 438 if self.db.factionrealm.items[link].invested == nil then
Asa@65 439 self.db.factionrealm.items[link].invested = 0
Asa@45 440 end
Asa@37 441 end
Asa@37 442
Asa@65 443 if viewOnly == true and self.db.factionrealm.items[link] == nil then
Asa@9 444 return {count = 0, invested = 0}
Asa@9 445 elseif viewOnly == true then
Asa@28 446
Asa@65 447 return {count = self.db.factionrealm.items[link].count, invested = self.db.factionrealm.items[link].invested}
Asa@9 448 end
Asa@37 449
Asa@28 450
Asa@28 451
Asa@65 452 return self.db.factionrealm.items[link]
Asa@8 453 end
Asa@8 454
Asa@63 455 function ItemAuditor:RemoveItem(link)
Asa@9 456 self.db.factionrealm.item_account[link] = nil
Asa@9 457 link = self:GetSafeLink(link)
Asa@9 458 if link ~= nil then
Asa@63 459 local item = ItemAuditor:GetItem(link)
Asa@35 460 item.invested = 0
Asa@24 461 else
Asa@24 462 self:Debug('Failed to convert link' .. tostring(link))
Asa@9 463 end
Asa@8 464 end
Asa@8 465
Asa@63 466 function ItemAuditor:SaveValue(link, value, countChange)
Asa@26 467 self:Debug("SaveValue(%s, %s, %s)", tostring(link), value, (countChange or 'default'))
Asa@26 468 countChange = countChange or 0
Asa@9 469 local item = nil
Asa@9 470 local realLink = self:GetSafeLink(link)
Asa@9 471 local itemName = nil
Asa@9 472 if realLink == nil then
Asa@26 473 itemName = link
Asa@23 474 self:Debug('SaveValue: GetSafeLink failed, falling back to storing by name: ' .. tostring(itemName))
Asa@9 475 self.db.factionrealm.item_account[itemName] = (self.db.factionrealm.item_account[itemName] or 0) + value
Asa@9 476 item = {invested = self.db.factionrealm.item_account[itemName], count = 1}
Asa@9 477 else
Asa@23 478
Asa@9 479 item = self:GetItem(realLink)
Asa@9 480 item.invested = item.invested + value
Asa@9 481 itemName = GetItemInfo(realLink)
Asa@9 482 end
Asa@8 483
Asa@26 484 if value > 0 and countChange > 0 and item.invested == value and item.count ~= countChange then
Asa@26 485 local costPerItem = value / countChange
Asa@26 486 value = costPerItem * item.count
Asa@26 487 item.invested = value
Asa@26 488 self:Print("You already owned %s %s with an unknown price, so they have also been updated to %s each", (item.count - countChange), itemName, self:FormatMoney(costPerItem))
Asa@26 489 end
Asa@26 490
Asa@7 491 if abs(value) > 0 then
Asa@22 492 if item.invested < 0 then
Asa@16 493 if self.db.profile.messages.cost_updates then
Asa@103 494 self:Print(format("Updated price of %s from %s to %s. |cFF00FF00You just made a profit of %s.", itemName, self:FormatMoney(item.invested - value), self:FormatMoney(0), self:FormatMoney(abs(item.invested))))
Asa@16 495 end
Asa@12 496 self:RemoveItem(link)
Asa@12 497 -- This doesn't work when you mail the only copy of an item you have to another character.
Asa@12 498 --[[
Asa@82 499 elseif item.count == 0 and realLink and ItemAuditor:GetItemCount(self:GetIDFromLink(realLink)) then
Asa@15 500 self:Print("You ran out of " .. itemName .. " and never recovered " .. self:FormatMoney(item.invested))
Asa@12 501 self:RemoveItem(link)
Asa@12 502 ]]
Asa@16 503 else
Asa@16 504 if self.db.profile.messages.cost_updates then
Asa@16 505 self:Print(format("Updated price of %s from %s to %s. (total change:%s)", itemName, self:FormatMoney(item.invested - value), self:FormatMoney(item.invested), self:FormatMoney(value)))
Asa@16 506 end
Asa@12 507 end
Asa@0 508 end
Asa@10 509
Asa@10 510 if realLink ~= nil then
Asa@63 511 ItemAuditor:UpdateQAThreshold(realLink)
Asa@112 512 self:SendMessage("IA_COST_CHANGED", realLink, unpack({ItemAuditor:GetItemCost(realLink)}))
Asa@10 513 end
Asa@35 514 UpdateInvestedData()
Asa@10 515 end
Asa@12 516
Asa@0 517
Asa@63 518 function ItemAuditor:WatchBags()
Asa@4 519 if self.watch_handle == nil then
Asa@63 520 ItemAuditor:UpdateCurrentInventory()
Asa@23 521 self.watch_handle = self:RegisterBucketEvent({"BAG_UPDATE", "PLAYER_MONEY"}, 0.3, "UpdateAudit")
Asa@4 522 end
Asa@0 523 end
Asa@0 524
Asa@63 525 function ItemAuditor:UnwatchBags()
Asa@4 526 if self.watch_handle ~= nil then
Asa@4 527 self:UnregisterBucket(self.watch_handle)
Asa@4 528 self.watch_handle = nil
Asa@4 529 end
Asa@0 530 end
Asa@0 531
Asa@9 532
Asa@63 533 function ItemAuditor:GetSafeLink(link)
Asa@9 534 local newLink = nil
Asa@9 535
Asa@24 536 if link and link == string.match(link, '.-:[-0-9]+[:0-9]*') then
Asa@24 537 newLink = link
Asa@24 538 elseif link then
Asa@9 539 newLink = link and string.match(link, "|H(.-):([-0-9]+):([0-9]+)|h")
Asa@9 540 end
Asa@9 541 if newLink == nil then
Asa@9 542 local itemID = self:GetItemID(link)
Asa@9 543 if itemID ~= nil then
Asa@9 544 _, newLink = GetItemInfo(itemID)
Asa@9 545 return self:GetSafeLink(newLink)
Asa@9 546 end
Asa@9 547 end
Asa@9 548 return newLink and string.gsub(newLink, ":0:0:0:0:0:0", "")
Asa@9 549 end
Asa@9 550
Asa@63 551 function ItemAuditor:GetIDFromLink(link)
Asa@9 552 local _, _, _, _, Id = string.find(link, "|?c?f?f?(%x*)|?H?([^:]*):?(%d+):?(%d*):?(%d*):?(%d*):?(%d*):?(%d*):?(%-?%d*):?(%-?%d*):?(%d*)|?h?%[?([^%[%]]*)%]?|?h?|?r?")
Asa@9 553 return tonumber(Id)
Asa@9 554 end
Asa@9 555
Asa@63 556 function ItemAuditor:GetItemCost(link, countModifier)
Asa@9 557 local item = self:GetItem(link, true)
Asa@8 558
Asa@9 559 if item.invested > 0 then
Asa@9 560 local count = item.count
Asa@9 561
Asa@9 562 if countModifier ~= nil then
Asa@9 563 count = count - countModifier
Asa@0 564 end
Asa@9 565 if count > 0 then
Asa@45 566 return ceil(item.invested), ceil(item.invested/count), count
Asa@9 567 end
Asa@9 568
Asa@0 569 end
Asa@82 570 return 0, 0, ItemAuditor:GetItemCount(ItemAuditor:GetIDFromLink(link))
Asa@0 571 end