From b5cba11bd3710039a62d57a7a1ce1687d356f4f7 Mon Sep 17 00:00:00 2001 From: PhatPhuckDave Date: Sun, 18 May 2025 15:12:37 +0200 Subject: [PATCH] Refactor API functions to improve parameter aliasing and enhance documentation clarity --- api/GetAutoCompleteResults.lua | 46 ++++++++++++++++++--------------- api/GetBarberShopStyleInfo.lua | 15 +++++------ api/GetBattlefieldTeamInfo.lua | 20 +++++++------- api/GetFunctionCPUUsage.lua | 10 +++---- api/GetGlyphLink.lua | 11 +++----- api/GetGlyphSocketInfo.lua | 19 ++++++-------- api/GetNumDeclensionSets.lua | 15 ++++++----- api/GetRaidBuffTrayAuraInfo.lua | 30 ++++++++++++++------- api/GetRuneCooldown.lua | 16 ++++-------- api/GetRuneCount.lua | 12 +++------ 10 files changed, 95 insertions(+), 99 deletions(-) diff --git a/api/GetAutoCompleteResults.lua b/api/GetAutoCompleteResults.lua index dc84810..9317c63 100644 --- a/api/GetAutoCompleteResults.lua +++ b/api/GetAutoCompleteResults.lua @@ -1,25 +1,29 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param inputString string ----@param includeBitfield AUTOCOMPLETE_FLAG_ALL ----@param 0x00000000 AUTOCOMPLETE_FLAG_NONE ----@param 0x00000001 AUTOCOMPLETE_FLAG_IN_GROUP ----@param 0x00000002 AUTOCOMPLETE_FLAG_IN_GUILD ----@param 0x00000004 AUTOCOMPLETE_FLAG_FRIEND ----@param 0x00000010 AUTOCOMPLETE_FLAG_INTERACTED_WITH ----@param 0x00000020 AUTOCOMPLETE_FLAG_ONLINE ----@param 0xffffffff AUTOCOMPLETE_FLAG_ALL ----@param excludeBitfield AUTOCOMPLETE_FLAG_ALL ----@param 0x00000000 AUTOCOMPLETE_FLAG_NONE ----@param 0x00000001 AUTOCOMPLETE_FLAG_IN_GROUP ----@param 0x00000002 AUTOCOMPLETE_FLAG_IN_GUILD ----@param 0x00000004 AUTOCOMPLETE_FLAG_FRIEND ----@param 0x00000010 AUTOCOMPLETE_FLAG_INTERACTED_WITH ----@param 0x00000020 AUTOCOMPLETE_FLAG_ONLINE ----@param 0xffffffff AUTOCOMPLETE_FLAG_ALL ----@param maxResults number ----@param cursorPosition number ----@return list ... +---@alias includeBitfield #One or more of the following flags (combined via bit.bor()), indicating which characters should be included in the result list: (number, bitfield) +---| 0x00000000 - AUTOCOMPLETE_FLAG_NONE: No characters +---| 0x00000001 - AUTOCOMPLETE_FLAG_IN_GROUP: Characters in the player's party or raid +---| 0x00000002 - AUTOCOMPLETE_FLAG_IN_GUILD: Characters in the player's guild +---| 0x00000004 - AUTOCOMPLETE_FLAG_FRIEND: Characters from the player's friends list +---| 0x00000010 - AUTOCOMPLETE_FLAG_INTERACTED_WITH: Characters with whom the player has recently interacted +---| 0x00000020 - AUTOCOMPLETE_FLAG_ONLINE: Currently online friends and guildmates +---| 0xffffffff - AUTOCOMPLETE_FLAG_ALL: All characters + +---@alias excludeBitfield #One or more of the following flags (combined via bit.bor()), indicating which characters should be excluded from the result list: (number, bitfield) +---| 0x00000000 - AUTOCOMPLETE_FLAG_NONE: No characters +---| 0x00000001 - AUTOCOMPLETE_FLAG_IN_GROUP: Characters in the player's party or raid +---| 0x00000002 - AUTOCOMPLETE_FLAG_IN_GUILD: Characters in the player's guild +---| 0x00000004 - AUTOCOMPLETE_FLAG_FRIEND: Characters from the player's friends list +---| 0x00000010 - AUTOCOMPLETE_FLAG_INTERACTED_WITH: Characters with whom the player has recently interacted +---| 0x00000020 - AUTOCOMPLETE_FLAG_ONLINE: Currently online friends and guildmates +---| 0xffffffff - AUTOCOMPLETE_FLAG_ALL: All characters + +---@param inputString string +---@param includeBitfield includeBitfield +---@param excludeBitfield excludeBitfield +---@param maxResults number +---@param cursorPosition number +---@return string[] results ---Returns a list of character names which complete a given partial name prefix -function GetAutoCompleteResults(inputString, includeBitfield, 0x00000000, 0x00000001, 0x00000002, 0x00000004, 0x00000010, 0x00000020, 0xffffffff, excludeBitfield, 0x00000000, 0x00000001, 0x00000002, 0x00000004, 0x00000010, 0x00000020, 0xffffffff, maxResults, cursorPosition) end \ No newline at end of file +function GetAutoCompleteResults(inputString, includeBitfield, excludeBitfield, maxResults, cursorPosition) end diff --git a/api/GetBarberShopStyleInfo.lua b/api/GetBarberShopStyleInfo.lua index 71b3e36..b4b91fa 100644 --- a/api/GetBarberShopStyleInfo.lua +++ b/api/GetBarberShopStyleInfo.lua @@ -1,13 +1,10 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param styleIndex 3 ----@param 1 ----@param 2 ----@param 3 ----@return string name ----@return string unused ----@return number cost ----@return 1nil isCurrent +---@param styleIndex barberShopStyleIndex +---@return string name +---@return string unused +---@return number cost +---@return 1nil isCurrent ---Returns information about the selected barber shop style option -function GetBarberShopStyleInfo(styleIndex, 1, 2, 3) end \ No newline at end of file +function GetBarberShopStyleInfo(styleIndex) end diff --git a/api/GetBattlefieldTeamInfo.lua b/api/GetBattlefieldTeamInfo.lua index 53a957e..0642865 100644 --- a/api/GetBattlefieldTeamInfo.lua +++ b/api/GetBattlefieldTeamInfo.lua @@ -1,13 +1,15 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param index 1 ----@param 0 ----@param 1 ----@return string teamName ----@return number teamRating ----@return number newTeamRating ----@return number teamMMR ----@return number numPlayers +---@alias battlegroundGroup +---| 0 - Green Team/Horde +---| 1 - Gold Team/Alliance + +---@param index battlegroundGroup +---@return string teamName +---@return number teamRating +---@return number newTeamRating +---@return number teamMMR +---@return number numPlayers ---Returns info about teams and their rating and MMR in a rated arena match. Usable following the UPDATE_BATTLEFIELD_SCORE event. -function GetBattlefieldTeamInfo(index, 0, 1) end \ No newline at end of file +function GetBattlefieldTeamInfo(index) end diff --git a/api/GetFunctionCPUUsage.lua b/api/GetFunctionCPUUsage.lua index 5413b3d..458bbb3 100644 --- a/api/GetFunctionCPUUsage.lua +++ b/api/GetFunctionCPUUsage.lua @@ -1,9 +1,9 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param function function ----@param includeSubroutines boolean ----@return number usage ----@return number calls +---@param func function +---@param includeSubroutines boolean #True to include time spent in other functions called by the given function; false to count only time spent in the function body (boolean) +---@return number usage #Amount of CPU time used by the function (in milliseconds) since the UI was loaded or ResetCPUUsage() was last called (number) +---@return number calls #Number of times the function has been called (number) ---Returns information about CPU usage by a function. Only returns valid data if the scriptProfile CVar is set to 1; returns 0 otherwise. -function GetFunctionCPUUsage(function, includeSubroutines) end \ No newline at end of file +function GetFunctionCPUUsage(func, includeSubroutines) end diff --git a/api/GetGlyphLink.lua b/api/GetGlyphLink.lua index a8784a5..f76f96f 100644 --- a/api/GetGlyphLink.lua +++ b/api/GetGlyphLink.lua @@ -1,11 +1,8 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param socket number ----@param talentGroup nil ----@param 1 ----@param 2 ----@param nil ----@return string link +---@param socket number +---@param talentGroup talentGroup +---@return string link ---Gets a hyperlink for the contents of a glyph socket. Glyph links are distinct from item and spell links: e.g. "|cff66bbff|Hglyph:21:361|h[Glyph of Hunter's Mark]|h|r". -function GetGlyphLink(socket, talentGroup, 1, 2, nil) end \ No newline at end of file +function GetGlyphLink(socket, talentGroup) end diff --git a/api/GetGlyphSocketInfo.lua b/api/GetGlyphSocketInfo.lua index 44dea34..1a4ec09 100644 --- a/api/GetGlyphSocketInfo.lua +++ b/api/GetGlyphSocketInfo.lua @@ -1,15 +1,12 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param socket number ----@param talentGroup nil ----@param 1 ----@param 2 ----@param nil ----@return boolean enabled ----@return number glyphType ----@return number glyphTooltipIndex ----@return number glyphSpell ----@return string icon +---@param socket number +---@param talentGroup talentGroup +---@return boolean enabled +---@return number glyphType +---@return number glyphTooltipIndex +---@return number glyphSpell +---@return string icon ---Returns information about a glyph socket and its contents. The spell ID referenced in the third return glyphSpell refers to the spell used to put the glyph in the socket -- not the Inscription spell that creates a glyph item, but the spell associated with that item's "Use:" effect. -function GetGlyphSocketInfo(socket, talentGroup, 1, 2, nil) end \ No newline at end of file +function GetGlyphSocketInfo(socket, talentGroup) end diff --git a/api/GetNumDeclensionSets.lua b/api/GetNumDeclensionSets.lua index 3c5afec..1ea0a6a 100644 --- a/api/GetNumDeclensionSets.lua +++ b/api/GetNumDeclensionSets.lua @@ -1,11 +1,12 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param name string ----@param gender 3 ----@param 1 or nil ----@param 2 ----@param 3 ----@return number numSets +---@alias gender +---| 1 or nil - Neuter +---| 2 - Male +---| 3 - Female + +---@param name string +---@param gender gender ---Returns the number of suggested declension sets for a name. Used in the Russian localized World of Warcraft client; see DeclineName for further details. Returns 0 in other locales. -function GetNumDeclensionSets(name, gender, 1 or nil, 2, 3) end \ No newline at end of file +function GetNumDeclensionSets(name, gender) end diff --git a/api/GetRaidBuffTrayAuraInfo.lua b/api/GetRaidBuffTrayAuraInfo.lua index 8ac9414..fdb2dc3 100644 --- a/api/GetRaidBuffTrayAuraInfo.lua +++ b/api/GetRaidBuffTrayAuraInfo.lua @@ -1,13 +1,23 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param nil number ----@return string name ----@return string rank ----@return string texture ----@return number duration ----@return number expiration ----@return number spellId ----@return number slot ----Returns the active buff for a given raid buff category. As of 5.0, the default BuffFrames aggregate standard raid buffs. GetRaidBuffTrayAuraInfo is used to determine which buff category is active. Current raid buff categories are: RAID_BUFF_1 Stats RAID_BUFF_2 Stamina RAID_BUFF_3 Attack Power RAID_BUFF_4 Haste RAID_BUFF_5 Spell Power RAID_BUFF_6 Critical Strike RAID_BUFF_7 Mastery RAID_BUFF_8 Multistrike RAID_BUFF_9 Versatility The highest raid buff category number is indicated by NUM_LE_RAID_BUFF_TYPES. -function GetRaidBuffTrayAuraInfo(nil) end \ No newline at end of file +---@param index number +---@return string name +---@return string rank +---@return string texture +---@return number duration +---@return number expiration +---@return number spellId +---@return number slot +--- Returns the active buff for a given raid buff category. As of 5.0, the default BuffFrames aggregate standard raid buffs. GetRaidBuffTrayAuraInfo is used to determine which buff category is active. Current raid buff categories are: +-- RAID_BUFF_1 Stats +-- RAID_BUFF_2 Stamina +-- RAID_BUFF_3 Attack Power +-- RAID_BUFF_4 Haste +-- RAID_BUFF_5 Spell Power +-- RAID_BUFF_6 Critical Strike +-- RAID_BUFF_7 Mastery +-- RAID_BUFF_8 Multistrike +-- RAID_BUFF_9 Versatility +-- The highest raid buff category number is indicated by NUM_LE_RAID_BUFF_TYPES. +function GetRaidBuffTrayAuraInfo(index) end diff --git a/api/GetRuneCooldown.lua b/api/GetRuneCooldown.lua index 09f9dfb..150110c 100644 --- a/api/GetRuneCooldown.lua +++ b/api/GetRuneCooldown.lua @@ -1,15 +1,9 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param slot 6 ----@param 1 ----@param 2 ----@param 3 ----@param 4 ----@param 5 ----@param 6 ----@return number start ----@return number duration ----@return boolean runeReady +---@param slot runeSlot +---@return number start +---@return number duration +---@return boolean runeReady ---Returns cooldown information about one of the player's rune resources. Note the placement of runes 3-4 (normally Unholy) and 5-6 (normally Frost) are reversed in the default UI. Also note the behavior of returned values differs slightly from most other GetXYZCooldown-style functions. -function GetRuneCooldown(slot, 1, 2, 3, 4, 5, 6) end \ No newline at end of file +function GetRuneCooldown(slot) end diff --git a/api/GetRuneCount.lua b/api/GetRuneCount.lua index 7fb281d..51c6e34 100644 --- a/api/GetRuneCount.lua +++ b/api/GetRuneCount.lua @@ -1,13 +1,7 @@ ---@diagnostic disable: missing-return, lowercase-global ---@meta ----@param slot 6 ----@param 1 ----@param 2 ----@param 3 ----@param 4 ----@param 5 ----@param 6 ----@return number count +---@param slot runeSlot +---@return number count ---Returns the number of available rune resources in one of the player's rune slots. Returns 1 if a rune is ready and 0 if a rune is on cooldown. -function GetRuneCount(slot, 1, 2, 3, 4, 5, 6) end \ No newline at end of file +function GetRuneCount(slot) end