ladybird/Demos/DynamicLink/LinkLib/DynamicLib.cpp
2020-01-13 13:03:30 +01:00

54 lines
1.6 KiB
C++

#include <AK/kstdio.h>
#include <AK/String.h>
#include <assert.h>
#include <stdio.h>
char* __static_environ[] = { nullptr }; // We don't get the environment without some libc workarounds..
// FIXME: Because we need to call printf, and we don't have access to the stout file descriptor
// from the main executable. We need to call __libc_init....
extern "C" void __libc_init();
extern "C" bool __environ_is_malloced;
class Global {
public:
Global(int i)
: m_i(i)
{
__environ_is_malloced = false;
environ = __static_environ;
__libc_init();
}
int get_i() const { return m_i; }
private:
int m_i = 0;
};
// This object exists to call __stdio_init and __malloc_init. Also to show that global vars work
Global g_glob { 5 };
extern "C" {
int global_lib_variable = 1234;
void global_lib_function()
{
printf("Hello from Dynamic Lib! g_glob::m_i == %d\n", g_glob.get_i());
}
const char* other_lib_function(int my_argument)
{
dbgprintf("Hello from Dynamic Lib, now from the debug port! g_glob::m_i == %d\n", g_glob.get_i());
int sum = my_argument + global_lib_variable;
// FIXME: We can't just return AK::String::format across the lib boundary here.
// It will use malloc from our DSO's copy of LibC, and then probably be free'd into
// the malloc of the main program which would be what they call 'very crash'.
// Feels very Windows :)
static String s_string;
s_string = String::format("Here's your string! Sum of argument and global_lib_variable: %d", sum);
return s_string.characters();
}
}