Commit 03a2aca3d53b02bd726a8ce671d31be08f57707c
1 parent
b56426d3
Exists in
master
and in
1 other branch
Fixing windows load of the IPC library.
Showing
2 changed files
with
140 additions
and
5 deletions
Show diff stats
client/lib3270++.cbp
| @@ -2,7 +2,7 @@ | @@ -2,7 +2,7 @@ | ||
| 2 | <CodeBlocks_project_file> | 2 | <CodeBlocks_project_file> |
| 3 | <FileVersion major="1" minor="6" /> | 3 | <FileVersion major="1" minor="6" /> |
| 4 | <Project> | 4 | <Project> |
| 5 | - <Option title="C++ Bindings for lib3270" /> | 5 | + <Option title="IPC Client library for lib3270/pw3270" /> |
| 6 | <Option makefile_is_custom="1" /> | 6 | <Option makefile_is_custom="1" /> |
| 7 | <Option pch_mode="2" /> | 7 | <Option pch_mode="2" /> |
| 8 | <Option compiler="gcc" /> | 8 | <Option compiler="gcc" /> |
| @@ -53,10 +53,6 @@ | @@ -53,10 +53,6 @@ | ||
| 53 | <Unit filename="src/core/windows/resources.rc.in" /> | 53 | <Unit filename="src/core/windows/resources.rc.in" /> |
| 54 | <Unit filename="src/core/windows/session.cc" /> | 54 | <Unit filename="src/core/windows/session.cc" /> |
| 55 | <Unit filename="src/include/ipc-client-internals.h" /> | 55 | <Unit filename="src/include/ipc-client-internals.h" /> |
| 56 | - <Unit filename="src/os/linux/request.cc" /> | ||
| 57 | - <Unit filename="src/os/linux/session.cc" /> | ||
| 58 | - <Unit filename="src/os/windows/request.cc" /> | ||
| 59 | - <Unit filename="src/os/windows/session.cc" /> | ||
| 60 | <Unit filename="src/session/local/events.cc" /> | 56 | <Unit filename="src/session/local/events.cc" /> |
| 61 | <Unit filename="src/session/local/session.cc" /> | 57 | <Unit filename="src/session/local/session.cc" /> |
| 62 | <Unit filename="src/session/remote/session.cc" /> | 58 | <Unit filename="src/session/remote/session.cc" /> |
client/src/session/local/session.cc
| @@ -36,6 +36,15 @@ | @@ -36,6 +36,15 @@ | ||
| 36 | * | 36 | * |
| 37 | */ | 37 | */ |
| 38 | 38 | ||
| 39 | + #ifdef _WIN32 | ||
| 40 | + | ||
| 41 | + #include <winsock2.h> | ||
| 42 | + #include <windows.h> | ||
| 43 | + #include <lmcons.h> | ||
| 44 | + #include <libloaderapi.h> | ||
| 45 | + | ||
| 46 | + #endif // _WIN32 | ||
| 47 | + | ||
| 39 | #include <ipc-client-internals.h> | 48 | #include <ipc-client-internals.h> |
| 40 | #include <lib3270/actions.h> | 49 | #include <lib3270/actions.h> |
| 41 | #include <lib3270/properties.h> | 50 | #include <lib3270/properties.h> |
| @@ -45,6 +54,8 @@ | @@ -45,6 +54,8 @@ | ||
| 45 | 54 | ||
| 46 | extern "C" { | 55 | extern "C" { |
| 47 | #include <lib3270/session.h> | 56 | #include <lib3270/session.h> |
| 57 | + | ||
| 58 | + | ||
| 48 | } | 59 | } |
| 49 | 60 | ||
| 50 | using std::string; | 61 | using std::string; |
| @@ -53,10 +64,138 @@ | @@ -53,10 +64,138 @@ | ||
| 53 | 64 | ||
| 54 | namespace TN3270 { | 65 | namespace TN3270 { |
| 55 | 66 | ||
| 67 | + #ifdef _WIN32 | ||
| 68 | + static void write_log(const char *msg, int rc = (int) GetLastError()) { | ||
| 69 | + | ||
| 70 | + HANDLE hEventLog = RegisterEventSource(NULL, PACKAGE_NAME); | ||
| 71 | + | ||
| 72 | + if(hEventLog) { | ||
| 73 | + | ||
| 74 | + char username[UNLEN + 1]; | ||
| 75 | + DWORD szName = sizeof(username); | ||
| 76 | + | ||
| 77 | + memset(username,0,szName); | ||
| 78 | + | ||
| 79 | + if(!GetUserName(username, &szName)) { | ||
| 80 | + strncpy(username,"?",UNLEN); | ||
| 81 | + } | ||
| 82 | + | ||
| 83 | + char lasterror[1024]; | ||
| 84 | + snprintf(lasterror,sizeof(lasterror),"The error code was %d",rc); | ||
| 85 | + | ||
| 86 | + const char *outMsg[] = { | ||
| 87 | + username, | ||
| 88 | + msg, | ||
| 89 | + lasterror | ||
| 90 | + }; | ||
| 91 | + | ||
| 92 | + ReportEvent( | ||
| 93 | + hEventLog, | ||
| 94 | + EVENTLOG_ERROR_TYPE, | ||
| 95 | + 1, | ||
| 96 | + 0, | ||
| 97 | + NULL, | ||
| 98 | + 3, | ||
| 99 | + 0, | ||
| 100 | + outMsg, | ||
| 101 | + NULL | ||
| 102 | + ); | ||
| 103 | + | ||
| 104 | + DeregisterEventSource(hEventLog); | ||
| 105 | + | ||
| 106 | + } | ||
| 107 | + | ||
| 108 | + } | ||
| 109 | + #endif // _WIN32 | ||
| 110 | + | ||
| 56 | Local::Session::Session() : Abstract::Session() { | 111 | Local::Session::Session() : Abstract::Session() { |
| 57 | 112 | ||
| 58 | std::lock_guard<std::mutex> lock(sync); | 113 | std::lock_guard<std::mutex> lock(sync); |
| 59 | 114 | ||
| 115 | +#ifdef _WIN32 | ||
| 116 | + { | ||
| 117 | + static bool initialized = false; | ||
| 118 | + | ||
| 119 | + if(!initialized) { | ||
| 120 | + | ||
| 121 | + // Get application DATADIR | ||
| 122 | + | ||
| 123 | + // https://github.com/curl/curl/blob/master/lib/system_win32.c | ||
| 124 | + | ||
| 125 | + char datadir[4096]; | ||
| 126 | + HKEY hKey = 0; | ||
| 127 | + unsigned long datalen = sizeof(datadir); | ||
| 128 | + | ||
| 129 | + memset(datadir,0,sizeof(datadir)); | ||
| 130 | + | ||
| 131 | + LSTATUS rc = RegOpenKeyEx(HKEY_LOCAL_MACHINE,"Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\pw3270",0,KEY_QUERY_VALUE,&hKey); | ||
| 132 | + if(rc == ERROR_SUCCESS) { | ||
| 133 | + | ||
| 134 | + unsigned long datatype; // #defined in winnt.h (predefined types 0-11) | ||
| 135 | + | ||
| 136 | + if(RegQueryValueExA(hKey,"InstallLocation",NULL,&datatype,(LPBYTE) datadir,&datalen) != ERROR_SUCCESS) { | ||
| 137 | + | ||
| 138 | + // Can't get DATADIR | ||
| 139 | + | ||
| 140 | + *datadir = 0; | ||
| 141 | + } | ||
| 142 | + | ||
| 143 | + RegCloseKey(hKey); | ||
| 144 | + | ||
| 145 | + } else { | ||
| 146 | + | ||
| 147 | + write_log("Can't open HKLM\\Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\pw3270", (int) rc); | ||
| 148 | + | ||
| 149 | + } | ||
| 150 | + | ||
| 151 | + if(*datadir) { | ||
| 152 | + | ||
| 153 | + HMODULE kernel = | ||
| 154 | + LoadLibrary("kernel32.dll"); | ||
| 155 | + | ||
| 156 | + if(kernel) { | ||
| 157 | + | ||
| 158 | + HANDLE WINAPI (*AddDllDirectory)(PCWSTR) = | ||
| 159 | + (HANDLE WINAPI (*)(PCWSTR)) GetProcAddress(kernel,"AddDllDirectory"); | ||
| 160 | + | ||
| 161 | + //BOOL WINAPI (*RemoveDllDirectory)(HANDLE) = | ||
| 162 | + // (BOOL WINAPI (*)(HANDLE)) GetProcAddress(kernel,"RemoveDllDirectory"); | ||
| 163 | + | ||
| 164 | + if(AddDllDirectory) { | ||
| 165 | + | ||
| 166 | + wchar_t *path = (wchar_t *) malloc(sizeof(datadir)*sizeof(wchar_t)); | ||
| 167 | + mbstowcs(path, datadir, 4095); | ||
| 168 | + | ||
| 169 | + if(!AddDllDirectory(path)) { | ||
| 170 | + write_log("AddDllDirectory has failed"); | ||
| 171 | + } | ||
| 172 | + | ||
| 173 | + free(path); | ||
| 174 | + | ||
| 175 | + } else { | ||
| 176 | + | ||
| 177 | + write_log("Can't find AddDllDirectory@kernel32.dll"); | ||
| 178 | + | ||
| 179 | + } | ||
| 180 | + | ||
| 181 | + FreeLibrary(kernel); | ||
| 182 | + | ||
| 183 | + | ||
| 184 | + } else { | ||
| 185 | + | ||
| 186 | + write_log("Can't load kernel32.dll"); | ||
| 187 | + | ||
| 188 | + } | ||
| 189 | + | ||
| 190 | + } | ||
| 191 | + | ||
| 192 | + initialized = true; | ||
| 193 | + | ||
| 194 | + } | ||
| 195 | + | ||
| 196 | + } | ||
| 197 | +#endif // _WIN32 | ||
| 198 | + | ||
| 60 | this->hSession = lib3270_session_new(""); | 199 | this->hSession = lib3270_session_new(""); |
| 61 | lib3270_set_user_data(this->hSession,(void *) this); | 200 | lib3270_set_user_data(this->hSession,(void *) this); |
| 62 | setCharSet(lib3270_get_display_charset(this->hSession)); | 201 | setCharSet(lib3270_get_display_charset(this->hSession)); |