Fastfile component
This commit is contained in:
parent
d7e3d1d45f
commit
d9a0a15172
49
src/client/component/fastfiles.cpp
Normal file
49
src/client/component/fastfiles.cpp
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
#include <std_include.hpp>
|
||||||
|
#include "loader/component_loader.hpp"
|
||||||
|
#include "fastfiles.hpp"
|
||||||
|
|
||||||
|
#include "command.hpp"
|
||||||
|
#include "console.hpp"
|
||||||
|
|
||||||
|
#include <utils/hook.hpp>
|
||||||
|
#include <utils/concurrency.hpp>
|
||||||
|
|
||||||
|
namespace fastfiles
|
||||||
|
{
|
||||||
|
static utils::concurrency::container<std::string> current_fastfile;
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
utils::hook::detour db_try_load_x_file_internal_hook;
|
||||||
|
|
||||||
|
void db_try_load_x_file_internal(const char* zone_name, const int flags)
|
||||||
|
{
|
||||||
|
printf("Loading fastfile %s\n", zone_name);
|
||||||
|
current_fastfile.access([&](std::string& fastfile)
|
||||||
|
{
|
||||||
|
fastfile = zone_name;
|
||||||
|
});
|
||||||
|
db_try_load_x_file_internal_hook.invoke<void>(zone_name, flags);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string get_current_fastfile()
|
||||||
|
{
|
||||||
|
return current_fastfile.access<std::string>([&](std::string& fastfile)
|
||||||
|
{
|
||||||
|
return fastfile;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
class component final : public component_interface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
void post_unpack() override
|
||||||
|
{
|
||||||
|
db_try_load_x_file_internal_hook.create(
|
||||||
|
SELECT_VALUE(0x1401CDDD0, 0x1402BFFE0), &db_try_load_x_file_internal);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
REGISTER_COMPONENT(fastfiles::component)
|
8
src/client/component/fastfiles.hpp
Normal file
8
src/client/component/fastfiles.hpp
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "game/game.hpp"
|
||||||
|
|
||||||
|
namespace fastfiles
|
||||||
|
{
|
||||||
|
std::string get_current_fastfile();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user