#include #include #include #include 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(); } }