Compare commits

..

No commits in common. "ff2a0da2544a88216b130ba970f8eaa1b595ec9d" and "9d88498809ece4680317adc58f51450d62fd25e7" have entirely different histories.

15 changed files with 18 additions and 264 deletions

View File

@ -43,7 +43,6 @@ target_link_libraries(client
gx gx
model model
net net
sound
ui ui
util util
world world

View File

@ -18,7 +18,6 @@
#include "gx/Texture.hpp" #include "gx/Texture.hpp"
#include "model/Model2.hpp" #include "model/Model2.hpp"
#include "net/Poll.hpp" #include "net/Poll.hpp"
#include "sound/SI2.hpp"
#include "ui/FrameScript.hpp" #include "ui/FrameScript.hpp"
#include "ui/FrameXML.hpp" #include "ui/FrameXML.hpp"
#include "world/World.hpp" #include "world/World.hpp"
@ -729,7 +728,7 @@ void WowClientInit() {
FrameScript_Initialize(0); FrameScript_Initialize(0);
// TODO // TODO
SI2::Init(0); // SI2::Init(0);
// sub_6F66B0(); // sub_6F66B0();
FrameXML_RegisterDefault(); FrameXML_RegisterDefault();

View File

@ -8,13 +8,11 @@
#include "gameui/CGTabardModelFrame.hpp" #include "gameui/CGTabardModelFrame.hpp"
#include "gameui/CGQuestPOIFrame.hpp" #include "gameui/CGQuestPOIFrame.hpp"
#include "console/Console.hpp" #include "console/Console.hpp"
#include "console/CVar.hpp"
#include "gx/CGVideoOptions.hpp" #include "gx/CGVideoOptions.hpp"
#include "ui/FrameXML.hpp" #include "ui/FrameXML.hpp"
#include "ui/FrameScript.hpp" #include "ui/FrameScript.hpp"
#include "util/Lua.hpp" #include "util/Lua.hpp"
#include "util/Unimplemented.hpp" #include "util/Unimplemented.hpp"
#include "util/StringTo.hpp"
// External from "ui/ScriptFunctions.hpp" // External from "ui/ScriptFunctions.hpp"
void RegisterSimpleFrameScriptMethods(); void RegisterSimpleFrameScriptMethods();
@ -165,142 +163,31 @@ static int32_t Script_SetCVar(lua_State* L) {
} }
static int32_t Script_GetCVar(lua_State* L) { static int32_t Script_GetCVar(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVar(\"cvar\")");
}
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(lua_tolstring(L, 1, nullptr));
if (!cvar || (cvar->m_flags & 0x40)) {
lua_pushnil(L);
} else {
lua_pushstring(L, cvar->GetString());
}
return 1;
} }
static int32_t Script_GetCVarBool(lua_State* L) { static int32_t Script_GetCVarBool(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVarBool(\"cvar\")");
}
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(lua_tolstring(L, 1, nullptr));
if (cvar && (cvar->m_flags & 0x40) == 0 && StringToBOOL(cvar->GetString())) {
lua_pushnumber(L, 1.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_GetCVarDefault(lua_State* L) { static int32_t Script_GetCVarDefault(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVarDefault(\"cvar\")");
}
auto name = lua_tolstring(L, 1, nullptr);
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(name);
if (!cvar || (cvar->m_flags & 0x40)) {
return luaL_error(L, "Couldn't find CVar named '%s'", name);
} else {
lua_pushstring(L, cvar->m_defaultValue.GetString());
}
return 1;
} }
static int32_t Script_GetCVarMin(lua_State* L) { static int32_t Script_GetCVarMin(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVarMin(\"cvar\")");
}
auto name = lua_tolstring(L, 1, nullptr);
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(name);
if (!cvar || (cvar->m_flags & 0x40)) {
return luaL_error(L, "Couldn't find CVar named '%s'", name);
}
auto key = cvar->m_key.m_str;
if (!SStrCmpI(key, "extShadowQuality", STORM_MAX_STR)) {
lua_pushnumber(L, 0.0);
} else if (!SStrCmpI(key, "farclip", STORM_MAX_STR)) {
lua_pushnumber(L, 177.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_GetCVarMax(lua_State* L) { static int32_t Script_GetCVarMax(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVarMax(\"cvar\")");
}
auto name = lua_tolstring(L, 1, nullptr);
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(name);
if (!cvar || (cvar->m_flags & 0x40)) {
return luaL_error(L, "Couldn't find CVar named '%s'", name);
}
auto key = cvar->m_key.m_str;
if (!SStrCmpI(key, "extShadowQuality", STORM_MAX_STR)) {
// TODO
lua_pushnumber(L, 1.0);
} else if (!SStrCmpI(key, "farclip", STORM_MAX_STR)) {
lua_pushnumber(L, 1277.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_GetCVarAbsoluteMin(lua_State* L) { static int32_t Script_GetCVarAbsoluteMin(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVarAbsoluteMin(\"cvar\")");
}
auto name = lua_tolstring(L, 1, nullptr);
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(name);
if (!cvar || (cvar->m_flags & 0x40)) {
return luaL_error(L, "Couldn't find CVar named '%s'", name);
}
auto key = cvar->m_key.m_str;
if (!SStrCmpI(key, "extShadowQuality", STORM_MAX_STR)) {
lua_pushnumber(L, 0.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_GetCVarAbsoluteMax(lua_State* L) { static int32_t Script_GetCVarAbsoluteMax(lua_State* L) {
if (!lua_isstring(L, 1)) { WHOA_UNIMPLEMENTED(0);
return luaL_error(L, "Usage: GetCVarAbsoluteMax(\"cvar\")");
}
auto name = lua_tolstring(L, 1, nullptr);
// TODO: Use LookupRegistered
auto cvar = CVar::Lookup(name);
if (!cvar || (cvar->m_flags & 0x40)) {
return luaL_error(L, "Couldn't find CVar named '%s'", name);
}
auto key = cvar->m_key.m_str;
if (!SStrCmpI(key, "extShadowQuality", STORM_MAX_STR)) {
lua_pushnumber(L, 5.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_GetWaterDetail(lua_State* L) { static int32_t Script_GetWaterDetail(lua_State* L) {

View File

@ -30,8 +30,6 @@ void SI2::RegisterScriptFunctions() {
} }
int32_t SI2::Init(int32_t flag) { int32_t SI2::Init(int32_t flag) {
SI2::RegisterCVars();
Log_Init(); Log_Init();
SI2_LOG("=> Version %s (%s) %s", "1.0.0", "00000", "Feb 25 2024"); SI2_LOG("=> Version %s (%s) %s", "1.0.0", "00000", "Feb 25 2024");
SI2_LOG(" "); SI2_LOG(" ");

View File

@ -180,58 +180,11 @@ int32_t CSimpleFrame_HasScript(lua_State* L) {
} }
int32_t CSimpleFrame_GetScript(lua_State* L) { int32_t CSimpleFrame_GetScript(lua_State* L) {
int32_t type = CSimpleFrame::GetObjectType(); WHOA_UNIMPLEMENTED(0);
CSimpleFrame* frame = static_cast<CSimpleFrame*>(FrameScript_GetObjectThis(L, type));
if (!lua_isstring(L, 2)) {
return luaL_error(L, "Usage: %s:GetScript(\"type\")", frame->GetDisplayName());
}
auto scriptName = lua_tolstring(L, 2, nullptr);
FrameScript_Object::ScriptData scriptData;
auto script = frame->GetScriptByName(scriptName, scriptData);
if (!script) {
return luaL_error(L, "%s doesn't have a \"%s\" script", frame->GetDisplayName(), scriptName);
}
// TODO: if (script->unk && lua_taintexpected && !lua_taintedclosure )
if (script->luaRef <= 0) {
lua_pushnil(L);
} else {
lua_rawgeti(L, LUA_REGISTRYINDEX, script->luaRef);
}
return 1;
} }
int32_t CSimpleFrame_SetScript(lua_State* L) { int32_t CSimpleFrame_SetScript(lua_State* L) {
// WARNING: This implementation breaks the client
WHOA_UNIMPLEMENTED(0); WHOA_UNIMPLEMENTED(0);
int32_t type = CSimpleFrame::GetObjectType();
CSimpleFrame* frame = static_cast<CSimpleFrame*>(FrameScript_GetObjectThis(L, type));
if (!lua_isstring(L, 2) || (lua_type(L, 3) != LUA_TFUNCTION && lua_type(L, 3) != LUA_TNIL)) {
return luaL_error(L, "Usage: %s:SetScript(\"type\", function)", frame->GetDisplayName());
}
auto scriptName = lua_tolstring(L, 2, nullptr);
FrameScript_Object::ScriptData scriptData;
auto script = frame->GetScriptByName(scriptName, scriptData);
if (!script) {
return luaL_error(L, "%s doesn't have a \"%s\" script", frame->GetDisplayName(), scriptName);
}
if (script->luaRef) {
luaL_unref(L, LUA_REGISTRYINDEX, script->luaRef);
}
auto ref = luaL_ref(L, LUA_REGISTRYINDEX);
script->luaRef = ref <= 0 ? 0 : ref;
// TODO: script->unk = lua_tainted;
return 0;
} }
int32_t CSimpleFrame_HookScript(lua_State* L) { int32_t CSimpleFrame_HookScript(lua_State* L) {

View File

@ -20,10 +20,6 @@ class CSimpleMessageScrollFrame : public CSimpleHyperlinkedFrame {
// Virtual member functions // Virtual member functions
virtual bool IsA(int32_t type); virtual bool IsA(int32_t type);
virtual int32_t GetScriptMetaTable(); virtual int32_t GetScriptMetaTable();
// Member variables
int32_t m_atTop = 0;
int32_t m_atBottom = 1;
}; };
#endif #endif

View File

@ -108,25 +108,11 @@ static int32_t Script_SetScrollOffset(lua_State* L) {
} }
static int32_t Script_AtTop(lua_State* L) { static int32_t Script_AtTop(lua_State* L) {
auto type = CSimpleMessageScrollFrame::GetObjectType(); WHOA_UNIMPLEMENTED(0);
auto frame = static_cast<CSimpleMessageScrollFrame*>(FrameScript_GetObjectThis(L, type));
if (frame->m_atTop) {
lua_pushnumber(L, 1.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_AtBottom(lua_State* L) { static int32_t Script_AtBottom(lua_State* L) {
auto type = CSimpleMessageScrollFrame::GetObjectType(); WHOA_UNIMPLEMENTED(0);
auto frame = static_cast<CSimpleMessageScrollFrame*>(FrameScript_GetObjectThis(L, type));
if (frame->m_atBottom) {
lua_pushnumber(L, 1.0);
} else {
lua_pushnil(L);
}
return 1;
} }
static int32_t Script_UpdateColorByID(lua_State* L) { static int32_t Script_UpdateColorByID(lua_State* L) {

View File

@ -27,11 +27,6 @@ CSimpleStatusBar::CSimpleStatusBar(CSimpleFrame* parent)
: CSimpleFrame(parent) { : CSimpleFrame(parent) {
} }
void CSimpleStatusBar::SetOrientation(uint32_t orientation) {
this->m_flags |= 1;
this->m_orientation = orientation;
}
bool CSimpleStatusBar::IsA(int32_t type) { bool CSimpleStatusBar::IsA(int32_t type) {
return type == CSimpleStatusBar::s_objectType return type == CSimpleStatusBar::s_objectType
|| type == CSimpleFrame::s_objectType || type == CSimpleFrame::s_objectType

View File

@ -16,7 +16,6 @@ class CSimpleStatusBar : public CSimpleFrame {
// Member functions // Member functions
CSimpleStatusBar(CSimpleFrame* parent); CSimpleStatusBar(CSimpleFrame* parent);
void SetOrientation(uint32_t orientation);
// Virtual member functions // Virtual member functions
virtual bool IsA(int32_t type); virtual bool IsA(int32_t type);
@ -24,12 +23,6 @@ class CSimpleStatusBar : public CSimpleFrame {
virtual ScriptIx* GetScriptByName(const char* name, ScriptData& data); virtual ScriptIx* GetScriptByName(const char* name, ScriptData& data);
// Member variables // Member variables
uint32_t m_flags = 0;
float m_minValue = 0.0f;
float m_maxValue = 0.0f;
float m_value = 0.0f;
CSimpleTexture* m_barTexture = nullptr;
uint32_t m_orientation = 0;
ScriptIx m_onValueChanged; ScriptIx m_onValueChanged;
ScriptIx m_onMinMaxChanged; ScriptIx m_onMinMaxChanged;
}; };

View File

@ -1,40 +1,18 @@
#include "ui/CSimpleStatusBarScript.hpp" #include "ui/CSimpleStatusBarScript.hpp"
#include "ui/CSimpleStatusBar.hpp" #include "ui/CSimpleStatusBar.hpp"
#include "ui/Util.hpp"
#include "util/Lua.hpp" #include "util/Lua.hpp"
#include "util/Unimplemented.hpp" #include "util/Unimplemented.hpp"
#include "util/StringTo.hpp"
static int32_t Script_GetOrientation(lua_State* L) { static int32_t Script_GetOrientation(lua_State* L) {
auto type = CSimpleStatusBar::GetObjectType(); WHOA_UNIMPLEMENTED(0);
auto statusBar = static_cast<CSimpleStatusBar*>(FrameScript_GetObjectThis(L, type));
lua_pushstring(L, OrientationToString(statusBar->m_orientation));
return 1;
} }
static int32_t Script_SetOrientation(lua_State* L) { static int32_t Script_SetOrientation(lua_State* L) {
auto type = CSimpleStatusBar::GetObjectType(); WHOA_UNIMPLEMENTED(0);
auto statusBar = static_cast<CSimpleStatusBar*>(FrameScript_GetObjectThis(L, type));
if (!lua_isstring(L, 2)) {
return luaL_error(L, "Usage: %s:SetOrientation(\"orientation\")", statusBar->GetDisplayName());
}
auto string = lua_tolstring(L, 2, nullptr);
uint32_t orientation = 0;
if (!StringToOrientation(string, orientation)) {
return luaL_error(L, "%s:SetOrientation(): Unknown orientation: %s", statusBar->GetDisplayName(), string);
}
statusBar->SetOrientation(orientation);
return 0;
} }
static int32_t Script_GetMinMaxValues(lua_State* L) { static int32_t Script_GetMinMaxValues(lua_State* L) {
auto type = CSimpleStatusBar::GetObjectType(); WHOA_UNIMPLEMENTED(0);
auto statusBar = static_cast<CSimpleStatusBar*>(FrameScript_GetObjectThis(L, type));
lua_pushnumber(L, statusBar->m_minValue);
lua_pushnumber(L, statusBar->m_maxValue);
return 2;
} }
static int32_t Script_SetMinMaxValues(lua_State* L) { static int32_t Script_SetMinMaxValues(lua_State* L) {
@ -42,10 +20,7 @@ static int32_t Script_SetMinMaxValues(lua_State* L) {
} }
static int32_t Script_GetValue(lua_State* L) { static int32_t Script_GetValue(lua_State* L) {
auto type = CSimpleStatusBar::GetObjectType(); WHOA_UNIMPLEMENTED(0);
auto statusBar = static_cast<CSimpleStatusBar*>(FrameScript_GetObjectThis(L, type));
lua_pushnumber(L, statusBar->m_value);
return 1;
} }
static int32_t Script_SetValue(lua_State* L) { static int32_t Script_SetValue(lua_State* L) {

View File

@ -86,14 +86,3 @@ int32_t StringToFrameStrata(const char* string, FRAME_STRATA& strata) {
return 0; return 0;
} }
const char* OrientationToString(uint32_t orientation) {
switch (orientation) {
case 0:
return "HORIZONTAL";
case 1:
return "VERTICAL";
default:
return "UNKNOWN";
}
}

View File

@ -13,6 +13,4 @@ int32_t StringToFramePoint(const char* string, FRAMEPOINT& point);
int32_t StringToFrameStrata(const char* string, FRAME_STRATA& strata); int32_t StringToFrameStrata(const char* string, FRAME_STRATA& strata);
const char* OrientationToString(uint32_t orientation);
#endif #endif

View File

@ -159,14 +159,3 @@ int32_t StringToJustify(const char* string, uint32_t& justify) {
return 0; return 0;
} }
bool StringToOrientation(const char* string, uint32_t& orientation) {
if (!SStrCmpI(string, "HORIZONTAL", STORM_MAX_STR)) {
orientation = 0;
return true;
} else if (!SStrCmpI(string, "VERTICAL", STORM_MAX_STR)) {
orientation = 1;
return true;
}
return false;
}

View File

@ -17,6 +17,4 @@ int32_t StringToDrawLayer(const char*, int32_t&);
int32_t StringToJustify(const char*, uint32_t&); int32_t StringToJustify(const char*, uint32_t&);
bool StringToOrientation(const char* string, uint32_t& orientation);
#endif #endif

View File

@ -2,11 +2,10 @@
#define UTIL_UNIMPLEMENTED_HPP #define UTIL_UNIMPLEMENTED_HPP
#include <cstdio> #include <cstdio>
#include "os/Debug.hpp"
#define WHOA_UNIMPLEMENTED(...) \ #define WHOA_UNIMPLEMENTED(...) \
OsOutputDebugString("Function not yet implemented: %s in %s (line %i)\n", __FUNCTION__, __FILE__, __LINE__); \ fprintf(stderr, "Function not yet implemented: %s in %s (line %i)\n", __FUNCTION__, __FILE__, __LINE__); \
return __VA_ARGS__; \ return __VA_ARGS__; \
(void)0 (void)0
#endif #endif