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 | ... | ... |