From 96697c3361b794f744ecc5c90113a41bfc431f5e Mon Sep 17 00:00:00 2001 From: Nathanne Isip Date: Sat, 5 Oct 2024 06:15:24 +0800 Subject: [PATCH] Multiplatform shared object/library loading with other functionalities. --- .../VariableDeclarationStatement.cpp | 36 +++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) diff --git a/src/ast/statement/VariableDeclarationStatement.cpp b/src/ast/statement/VariableDeclarationStatement.cpp index baf1e1c..eb5644c 100644 --- a/src/ast/statement/VariableDeclarationStatement.cpp +++ b/src/ast/statement/VariableDeclarationStatement.cpp @@ -21,7 +21,13 @@ #include #include -#include +#if defined(__unix__) || defined(__linux__) +# include +#elif defined(_WIN32) || defined(_WIN64) || defined(WIN32) || defined(WIN64) +# include +#else +# error "Unsupported architecture for shared objects or dynamic libraries." +#endif DynamicObject VariableDeclarationStatement::visit(SymbolTable& symbols) { if(!this->nativePath.empty()) { @@ -56,9 +62,20 @@ NativeFunction VariableDeclarationStatement::loadNativeFunction( ) { void* handle; if(Runtime::hasLoadedLibrary(libName)) + #if defined(__unix__) || defined(__linux__) handle = Runtime::getLoadedLibrary(libName); + #elif defined(_WIN32) || defined(_WIN64) || defined(WIN32) || defined(WIN64) + handle = static_cast( + Runtime::getLoadedLibrary(libName) + ); + #endif else { + #if defined(__unix__) || defined(__linux__) handle = dlopen(libName.c_str(), RTLD_LAZY); + #elif defined(_WIN32) || defined(_WIN64) || defined(WIN32) || defined(WIN64) + handle = LoadLibrary(libName.c_str()); + #endif + Runtime::addLoadedLibrary(libName, handle); } @@ -66,15 +83,30 @@ NativeFunction VariableDeclarationStatement::loadNativeFunction( throw ASTNodeException( std::move(address), "Failed to load library: " + libName + - "\r\n " + dlerror() + "\r\n " + + #if defined(__unix__) || defined(__linux__) + dlerror() + #elif defined(_WIN32) || defined(_WIN64) || defined(WIN32) || defined(WIN64) + std::string(GetLastError()) + #endif ); std::string name = funcName; std::replace(name.begin(), name.end(), '.', '_'); + #if defined(__unix__) || defined(__linux__) auto func = reinterpret_cast(dlsym(handle, name.c_str())); + #elif defined(_WIN32) || defined(_WIN64) || defined(WIN32) || defined(WIN64) + auto func = reinterpret_cast(GetProcAddress(handle, name.c_str())); + #endif + if(!func) { + #if defined(__unix__) || defined(__linux__) dlclose(handle); + #elif defined(_WIN32) || defined(_WIN64) || defined(WIN32) || defined(WIN64) + FreeLibrary(handle); + #endif + throw std::runtime_error("Failed to find function: " + funcName); }