Commit 4fd901ecbc84455db09a1d7b3f6e14abe555d566
1 parent
ca836b43
Exists in
master
and in
3 other branches
Implementing windows connect.
Showing
6 changed files
with
172 additions
and
10 deletions
Show diff stats
lib3270.cbp
| ... | ... | @@ -228,6 +228,9 @@ |
| 228 | 228 | <Unit filename="src/core/windows/connect.c"> |
| 229 | 229 | <Option compilerVar="CC" /> |
| 230 | 230 | </Unit> |
| 231 | + <Unit filename="src/core/windows/download.c"> | |
| 232 | + <Option compilerVar="CC" /> | |
| 233 | + </Unit> | |
| 231 | 234 | <Unit filename="src/core/windows/event_dispatcher.c"> |
| 232 | 235 | <Option compilerVar="CC" /> |
| 233 | 236 | </Unit> |
| ... | ... | @@ -237,6 +240,7 @@ |
| 237 | 240 | <Unit filename="src/core/windows/log.c"> |
| 238 | 241 | <Option compilerVar="CC" /> |
| 239 | 242 | </Unit> |
| 243 | + <Unit filename="src/core/windows/private.h" /> | |
| 240 | 244 | <Unit filename="src/core/windows/registry.c"> |
| 241 | 245 | <Option compilerVar="CC" /> |
| 242 | 246 | </Unit> | ... | ... |
src/core/windows/connect.c
| ... | ... | @@ -53,7 +53,13 @@ |
| 53 | 53 | if(!connect(sock,address,address_len)) |
| 54 | 54 | return 0; |
| 55 | 55 | |
| 56 | - debug("WSAGetLastError=%d",(int) WSAGetLastError()); | |
| 56 | + /* | |
| 57 | + if(WSAGetLastError() != WSAEINPROGRESS) { | |
| 58 | + debug("Can't connect WSAGetLastError=%d",(int) WSAGetLastError()); | |
| 59 | + errno = ENOTCONN; | |
| 60 | + return -1; | |
| 61 | + } | |
| 62 | + */ | |
| 57 | 63 | |
| 58 | 64 | unsigned int timer; |
| 59 | 65 | for(timer = 0; timer < hSession->connection.timeout; timer += 10) { |
| ... | ... | @@ -64,7 +70,7 @@ |
| 64 | 70 | struct timeval tm; |
| 65 | 71 | |
| 66 | 72 | tm.tv_sec = 0; |
| 67 | - tm.tv_usec = 10; | |
| 73 | + tm.tv_usec = 10000; | |
| 68 | 74 | |
| 69 | 75 | fd_set wfds; |
| 70 | 76 | FD_ZERO(&wfds); |
| ... | ... | @@ -81,6 +87,7 @@ |
| 81 | 87 | |
| 82 | 88 | } |
| 83 | 89 | |
| 90 | + debug("Timeout! WSAGetLastError=%d",(int) WSAGetLastError()); | |
| 84 | 91 | return errno = ETIMEDOUT; |
| 85 | 92 | |
| 86 | 93 | } |
| ... | ... | @@ -173,6 +180,10 @@ |
| 173 | 180 | if(sock_connect(hSession, sock, rp->ai_addr, rp->ai_addrlen)) |
| 174 | 181 | { |
| 175 | 182 | // Can't connect to host |
| 183 | + state->winerror = WSAGetLastError(); | |
| 184 | + if(state->winerror == WSAEWOULDBLOCK) { | |
| 185 | + state->winerror = 0; | |
| 186 | + } | |
| 176 | 187 | state->syserror = errno; |
| 177 | 188 | closesocket(sock); |
| 178 | 189 | sock = -1; |
| ... | ... | @@ -286,20 +297,45 @@ |
| 286 | 297 | } |
| 287 | 298 | |
| 288 | 299 | lib3270_autoptr(char) syserror = NULL; |
| 289 | - if(state.syserror) | |
| 300 | + | |
| 301 | +#ifdef _WIN32 | |
| 302 | + if(state.winerror) | |
| 290 | 303 | { |
| 291 | 304 | syserror = lib3270_strdup_printf( |
| 305 | + _("The system error was \"%s\""), | |
| 306 | + lib3270_win32_strerror(state.winerror) | |
| 307 | + ); | |
| 308 | + } else if(state.syserror == ETIMEDOUT) { | |
| 309 | + | |
| 310 | + syserror = lib3270_strdup_printf( | |
| 311 | + _("The system error was \"%s\" (rc=%d)"), | |
| 312 | + _("Timeout conneting to host"), | |
| 313 | + state.syserror | |
| 314 | + ); | |
| 315 | + | |
| 316 | + } else if(state.syserror == ENOTCONN) { | |
| 317 | + | |
| 318 | + syserror = lib3270_strdup_printf( | |
| 319 | + _("The system error was \"%s\" (rc=%d)"), | |
| 320 | + _("Not connected to host"), | |
| 321 | + state.syserror | |
| 322 | + ); | |
| 323 | + | |
| 324 | + } else if(state.syserror) { | |
| 325 | + syserror = lib3270_strdup_printf( | |
| 292 | 326 | _("The system error was \"%s\" (rc=%d)"), |
| 293 | 327 | strerror(state.syserror), |
| 294 | 328 | state.syserror |
| 295 | 329 | ); |
| 296 | 330 | } |
| 297 | -#ifdef _WIN32 | |
| 298 | - else if(state.winerror) | |
| 331 | + | |
| 332 | +#else | |
| 333 | + if(state.syserror) | |
| 299 | 334 | { |
| 300 | 335 | syserror = lib3270_strdup_printf( |
| 301 | - _("The system error was \"%s\""), | |
| 302 | - lib3270_win32_strerror(WSAGetLastError()) | |
| 336 | + _("The system error was \"%s\" (rc=%d)"), | |
| 337 | + strerror(state.syserror), | |
| 338 | + state.syserror | |
| 303 | 339 | ); |
| 304 | 340 | } |
| 305 | 341 | #endif // _WIN32 | ... | ... |
| ... | ... | @@ -0,0 +1,70 @@ |
| 1 | +/* | |
| 2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
| 3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
| 4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
| 5 | + * | |
| 6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
| 7 | + * | |
| 8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
| 9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
| 10 | + * Free Software Foundation. | |
| 11 | + * | |
| 12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
| 13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
| 14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
| 15 | + * obter mais detalhes. | |
| 16 | + * | |
| 17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
| 18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
| 19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
| 20 | + * | |
| 21 | + * Este programa está nomeado como - e possui - linhas de código. | |
| 22 | + * | |
| 23 | + * Contatos: | |
| 24 | + * | |
| 25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
| 26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
| 27 | + * | |
| 28 | + */ | |
| 29 | + | |
| 30 | +#include "private.h" | |
| 31 | +#include <utilc.h> | |
| 32 | + | |
| 33 | +/*--[ Implement ]------------------------------------------------------------------------------------*/ | |
| 34 | + | |
| 35 | + char * lib3270_url_get(H3270 *hSession, const char *u, const char **error) { | |
| 36 | + | |
| 37 | + lib3270_autoptr(char) url = lib3270_unescape(u); | |
| 38 | + | |
| 39 | + if(strncasecmp(url,"file://",7) == 0) { | |
| 40 | + | |
| 41 | + // Load local file contents. | |
| 42 | + char *rc = lib3270_file_get_contents(hSession,url+7); | |
| 43 | + if(!rc) | |
| 44 | + *error = strerror(errno); | |
| 45 | + return rc; | |
| 46 | + } | |
| 47 | + | |
| 48 | + if(strncasecmp(url,"http://",7) == 0 || strncasecmp(url,"https://",8)) { | |
| 49 | + | |
| 50 | + // Use WinHTTP | |
| 51 | + return lib3270_url_get_using_http(hSession, url, error); | |
| 52 | + | |
| 53 | + } | |
| 54 | + | |
| 55 | +#if defined(HAVE_LIBCURL) | |
| 56 | + | |
| 57 | + return lib3270_url_get_using_curl(hSession,url,error); | |
| 58 | + | |
| 59 | +#else | |
| 60 | + | |
| 61 | + // Can't get contents | |
| 62 | + *error = _("No handler for URL scheme."); | |
| 63 | + errno = EINVAL; | |
| 64 | + return NULL; | |
| 65 | + | |
| 66 | + | |
| 67 | +#endif // HAVE_LIBCURL | |
| 68 | + | |
| 69 | + | |
| 70 | + } | ... | ... |
src/core/windows/http.c
| ... | ... | @@ -52,7 +52,7 @@ static void lib3270_autoptr_cleanup_HINTERNET(HINTERNET **hInternet) |
| 52 | 52 | *hInternet = 0; |
| 53 | 53 | } |
| 54 | 54 | |
| 55 | -char * lib3270_get_from_url(H3270 *hSession, const char *url, size_t *length, const char **error_message) | |
| 55 | +char * lib3270_url_get_using_http(H3270 *hSession, const char *url, const char **error_message) | |
| 56 | 56 | { |
| 57 | 57 | wchar_t wHostname[4096]; |
| 58 | 58 | wchar_t wPath[4096]; |
| ... | ... | @@ -185,8 +185,6 @@ char * lib3270_get_from_url(H3270 *hSession, const char *url, size_t *length, co |
| 185 | 185 | return NULL; |
| 186 | 186 | } |
| 187 | 187 | |
| 188 | - if(length) | |
| 189 | - *length = (size_t) szResponse; | |
| 190 | 188 | |
| 191 | 189 | lib3270_write_nettrace(hSession,"Got %u bytes from %s\n",(unsigned int) szResponse, url); |
| 192 | 190 | ... | ... |
| ... | ... | @@ -0,0 +1,48 @@ |
| 1 | +/* | |
| 2 | + * "Software G3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
| 3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
| 4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
| 5 | + * | |
| 6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
| 7 | + * | |
| 8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
| 9 | + * os termos da GPL v.2 - Licença Pública Geral ', conforme publicado pela | |
| 10 | + * Free Software Foundation. | |
| 11 | + * | |
| 12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
| 13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
| 14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
| 15 | + * obter mais detalhes. | |
| 16 | + * | |
| 17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
| 18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
| 19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
| 20 | + * | |
| 21 | + * Este programa está nomeado como private.h e possui - linhas de código. | |
| 22 | + * | |
| 23 | + * Contatos: | |
| 24 | + * | |
| 25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
| 26 | + * erico.mendonca@gmail.com (Erico Mascarenhas de Mendonça) | |
| 27 | + * | |
| 28 | + */ | |
| 29 | + | |
| 30 | +#ifndef PRIVATE_H_INCLUDED | |
| 31 | + | |
| 32 | + #define PRIVATE_H_INCLUDED | |
| 33 | + | |
| 34 | + #include <config.h> | |
| 35 | + | |
| 36 | + #include <winsock2.h> | |
| 37 | + #include <windows.h> | |
| 38 | + | |
| 39 | + #include <internals.h> | |
| 40 | + | |
| 41 | + #include <lib3270.h> | |
| 42 | + #include <lib3270/log.h> | |
| 43 | + | |
| 44 | + LIB3270_INTERNAL char * lib3270_url_get_using_ldap(H3270 *hSession, const char *u, const char **error); | |
| 45 | + LIB3270_INTERNAL char * lib3270_url_get_using_http(H3270 *hSession, const char *url, const char **error); | |
| 46 | + | |
| 47 | + | |
| 48 | +#endif // !PRIVATE_H_INCLUDED | ... | ... |
src/include/internals.h
| ... | ... | @@ -902,3 +902,9 @@ LIB3270_INTERNAL void set_ssl_state(H3270 *session, LIB3270_SSL_STATE state); |
| 902 | 902 | */ |
| 903 | 903 | LIB3270_INTERNAL X509_CRL * lib3270_crl_get_using_ldap(H3270 *hSession, const char *url, const char **error); |
| 904 | 904 | #endif // HAVE_LDAP |
| 905 | + | |
| 906 | +#ifdef _WIN32 | |
| 907 | + | |
| 908 | + LIB3270_INTERNAL char * lib3270_get_from_url(H3270 *hSession, const char *url, const char **error_message); | |
| 909 | + | |
| 910 | +#endif // _WIN32 | ... | ... |