Commit b9fdc4bdbd03219085227a9b6f7f8ae48839b933
1 parent
87cfcc55
Exists in
master
and in
5 other branches
Arquivos a transferir devem sempre ser abertos com modo binário no windows
Showing
4 changed files
with
29 additions
and
186 deletions
Show diff stats
Makefile.in
| ... | ... | @@ -52,7 +52,7 @@ BINDIR=.bin |
| 52 | 52 | EXEEXT=@EXEEXT@ |
| 53 | 53 | DBGLIB=-L../../$(BINDIR)/Debug@DLLDIR@ -l3270 |
| 54 | 54 | RLSLIB=-L../../$(BINDIR)/Release@DLLDIR@ -l3270 |
| 55 | -TMPDIR=.tmp | |
| 55 | +TMPDIR ?= .tmp | |
| 56 | 56 | GLOBAL_DEPS=$(PWD)/include/*.h $(PWD)/include/lib3270/*.h |
| 57 | 57 | LANG_FILES=$(wildcard po/*.po) |
| 58 | 58 | |
| ... | ... | @@ -116,6 +116,7 @@ po/%.po: $(PACKAGE_NAME).po |
| 116 | 116 | @cp $@ $(TMPDIR)/$@ 2> $(TMPDIR)/cp.err > $(TMPDIR)/cp.out || true |
| 117 | 117 | @touch $(TMPDIR)/$@ |
| 118 | 118 | @$(MSGMERGE) $(TMPDIR)/$@ $(PACKAGE_NAME).po --output-file=$@ |
| 119 | + @rm -fr $(TMPDIR)/po | |
| 119 | 120 | |
| 120 | 121 | $(BINDIR)/Release/$(localedir)/%/LC_MESSAGES/$(PACKAGE_NAME).mo: po/%.po |
| 121 | 122 | @echo " FMT `basename $@`" | ... | ... |
po/pt_BR.po
| ... | ... | @@ -5,7 +5,7 @@ msgid "" |
| 5 | 5 | msgstr "" |
| 6 | 6 | "Project-Id-Version: pw3270 5.0\n" |
| 7 | 7 | "Report-Msgid-Bugs-To: \n" |
| 8 | -"POT-Creation-Date: 2012-12-26 10:34-0200\n" | |
| 8 | +"POT-Creation-Date: 2012-12-26 11:20-0200\n" | |
| 9 | 9 | "PO-Revision-Date: 2012-12-26 10:36-0200\n" |
| 10 | 10 | "Last-Translator: Perry Werneck <perry.werneck@gmail.com>\n" |
| 11 | 11 | "Language-Team: Português <>\n" |
| ... | ... | @@ -268,7 +268,7 @@ msgstr "Não posso aceitar elemento %s sem nome" |
| 268 | 268 | msgid "Can't connect to %s:%d" |
| 269 | 269 | msgstr "Não foi possível conectar a %s:%d" |
| 270 | 270 | |
| 271 | -#: host.c:316 | |
| 271 | +#: host.c:154 | |
| 272 | 272 | msgid "Can't connect to host" |
| 273 | 273 | msgstr "Não foi possível conectar ao servidor" |
| 274 | 274 | |
| ... | ... | @@ -281,7 +281,7 @@ msgstr "Não foi possível converter a linha %d de %s para %s" |
| 281 | 281 | msgid "Can't cut rectangular regions" |
| 282 | 282 | msgstr "Recortar não permitido em seleção retangular" |
| 283 | 283 | |
| 284 | -#: ft.c:307 | |
| 284 | +#: ft.c:311 | |
| 285 | 285 | msgid "Can't get file size" |
| 286 | 286 | msgstr "Não foi possível obter o tamanho do arquivo" |
| 287 | 287 | |
| ... | ... | @@ -294,7 +294,7 @@ msgstr "Não foi possível carregar %s" |
| 294 | 294 | msgid "Can't load file" |
| 295 | 295 | msgstr "Não foi possível carregar arquivo" |
| 296 | 296 | |
| 297 | -#: ft.c:226 | |
| 297 | +#: ft.c:230 | |
| 298 | 298 | msgid "Can't open local file" |
| 299 | 299 | msgstr "Não foi possível abrir arquivo local" |
| 300 | 300 | |
| ... | ... | @@ -511,15 +511,15 @@ msgstr "EOR recebido fora do modo 3270, ignorado." |
| 511 | 511 | msgid "ET_A" |
| 512 | 512 | msgstr "ET_A" |
| 513 | 513 | |
| 514 | -#: host.c:340 | |
| 514 | +#: host.c:178 | |
| 515 | 515 | msgid "Empty LU name" |
| 516 | 516 | msgstr "Nome da LU está em branco" |
| 517 | 517 | |
| 518 | -#: host.c:267 host.c:394 | |
| 518 | +#: host.c:105 host.c:232 | |
| 519 | 519 | msgid "Empty hostname" |
| 520 | 520 | msgstr "Nome do servidor em branco" |
| 521 | 521 | |
| 522 | -#: host.c:447 | |
| 522 | +#: host.c:285 | |
| 523 | 523 | msgid "Empty port name" |
| 524 | 524 | msgstr "Porta em branco" |
| 525 | 525 | |
| ... | ... | @@ -675,7 +675,7 @@ msgstr "HTTP Proxy: Resposta desconhecida" |
| 675 | 675 | msgid "Help" |
| 676 | 676 | msgstr "Ajuda" |
| 677 | 677 | |
| 678 | -#: ft.c:524 | |
| 678 | +#: ft.c:528 | |
| 679 | 679 | msgid "Host disconnected, transfer cancelled" |
| 680 | 680 | msgstr "Servidor desconectou, transferência cancelada" |
| 681 | 681 | |
| ... | ... | @@ -707,8 +707,8 @@ msgstr "Tipo do sistema no servidor" |
| 707 | 707 | msgid "Host to connect" |
| 708 | 708 | msgstr "Servidor a conectar" |
| 709 | 709 | |
| 710 | -#: host.c:315 host.c:340 host.c:352 host.c:378 host.c:390 host.c:394 | |
| 711 | -#: host.c:447 host.c:462 | |
| 710 | +#: host.c:153 host.c:178 host.c:190 host.c:216 host.c:228 host.c:232 | |
| 711 | +#: host.c:285 host.c:300 | |
| 712 | 712 | msgid "Hostname syntax error" |
| 713 | 713 | msgstr "Formato inválido no nome do servidor" |
| 714 | 714 | |
| ... | ... | @@ -740,7 +740,7 @@ msgstr "Intensificado/Protegido" |
| 740 | 740 | msgid "Intensified/Unprotected" |
| 741 | 741 | msgstr "Intensificado/Desprotegido" |
| 742 | 742 | |
| 743 | -#: host.c:496 | |
| 743 | +#: host.c:334 | |
| 744 | 744 | msgid "Invalid (empty) hostname" |
| 745 | 745 | msgstr "Nome do host é invalido (vazio)" |
| 746 | 746 | |
| ... | ... | @@ -791,7 +791,7 @@ msgstr "Barra lateral" |
| 791 | 791 | msgid "Misc colors" |
| 792 | 792 | msgstr "Cores diversas" |
| 793 | 793 | |
| 794 | -#: host.c:390 | |
| 794 | +#: host.c:228 | |
| 795 | 795 | msgid "Missing ']'" |
| 796 | 796 | msgstr "Faltando ']'" |
| 797 | 797 | |
| ... | ... | @@ -812,7 +812,7 @@ msgstr "Monocromático" |
| 812 | 812 | msgid "Move action needs target & direction attributes" |
| 813 | 813 | msgstr "Ação \"move\" precisa dos atributos \"target\" e \"direction\"" |
| 814 | 814 | |
| 815 | -#: host.c:462 | |
| 815 | +#: host.c:300 | |
| 816 | 816 | msgid "Multiple port names" |
| 817 | 817 | msgstr "Múltiplos nomes de porta" |
| 818 | 818 | |
| ... | ... | @@ -852,7 +852,7 @@ msgstr "Normal/Desprotegido" |
| 852 | 852 | msgid "Not available" |
| 853 | 853 | msgstr "Não disponível" |
| 854 | 854 | |
| 855 | -#: ft.c:531 | |
| 855 | +#: ft.c:535 | |
| 856 | 856 | msgid "Not in 3270 mode, transfer cancelled" |
| 857 | 857 | msgstr "Não está no modo 3270, transferência cancelada" |
| 858 | 858 | |
| ... | ... | @@ -876,7 +876,7 @@ msgstr "Estado inválido na OIA" |
| 876 | 876 | msgid "OIA status ok" |
| 877 | 877 | msgstr "Estado normal na OIA" |
| 878 | 878 | |
| 879 | -#: host.c:317 | |
| 879 | +#: host.c:155 | |
| 880 | 880 | #, c-format |
| 881 | 881 | msgid "Option '%c:' is not supported" |
| 882 | 882 | msgstr "Opção não suportada: '%c:'" |
| ... | ... | @@ -1342,7 +1342,7 @@ msgstr "Erro de leitura SSL" |
| 1342 | 1342 | msgid "SSL connect failed!" |
| 1343 | 1343 | msgstr "Conexão SSL falhou" |
| 1344 | 1344 | |
| 1345 | -#: host.c:302 | |
| 1345 | +#: host.c:140 | |
| 1346 | 1346 | msgid "SSL error" |
| 1347 | 1347 | msgstr "Erro SSL" |
| 1348 | 1348 | |
| ... | ... | @@ -1491,7 +1491,7 @@ msgstr "Erro ao enviar dados para a rede" |
| 1491 | 1491 | msgid "Space allocation units" |
| 1492 | 1492 | msgstr "Space allocation units" |
| 1493 | 1493 | |
| 1494 | -#: host.c:352 | |
| 1494 | +#: host.c:190 | |
| 1495 | 1495 | msgid "Space in LU name" |
| 1496 | 1496 | msgstr "Espaço no nome da LU" |
| 1497 | 1497 | |
| ... | ... | @@ -1519,7 +1519,7 @@ msgstr "T_otal" |
| 1519 | 1519 | msgid "Terminal colors" |
| 1520 | 1520 | msgstr "Cores do terminal" |
| 1521 | 1521 | |
| 1522 | -#: host.c:378 | |
| 1522 | +#: host.c:216 | |
| 1523 | 1523 | msgid "Text before '['" |
| 1524 | 1524 | msgstr "Texto antes de '['" |
| 1525 | 1525 | |
| ... | ... | @@ -1565,7 +1565,7 @@ msgstr "" |
| 1565 | 1565 | msgid "This program requires GTK version %d.%d.%d" |
| 1566 | 1566 | msgstr "Este programa precisa do GTK versão %d.%d.%d" |
| 1567 | 1567 | |
| 1568 | -#: host.c:304 | |
| 1568 | +#: host.c:142 | |
| 1569 | 1569 | #, c-format |
| 1570 | 1570 | msgid "" |
| 1571 | 1571 | "This version of %s was built without support for secure sockets layer (SSL)." |
| ... | ... | @@ -1615,7 +1615,7 @@ msgstr "UTF-8" |
| 1615 | 1615 | msgid "Uknown DFT Open type from host" |
| 1616 | 1616 | msgstr "Servidor enviou código de abertura DFT desconhecido" |
| 1617 | 1617 | |
| 1618 | -#: host.c:303 | |
| 1618 | +#: host.c:141 | |
| 1619 | 1619 | msgid "Unable to connect to secure hosts" |
| 1620 | 1620 | msgstr "Não é possível conectar em servidores seguros" |
| 1621 | 1621 | |
| ... | ... | @@ -1623,7 +1623,7 @@ msgstr "Não é possível conectar em servidores seguros" |
| 1623 | 1623 | msgid "Unable to paste text" |
| 1624 | 1624 | msgstr "Incapaz de colar texto" |
| 1625 | 1625 | |
| 1626 | -#: ft.c:391 | |
| 1626 | +#: ft.c:395 | |
| 1627 | 1627 | msgid "Unable to send file-transfer request" |
| 1628 | 1628 | msgstr "Não foi possível enviar a requisição de transferência de arquivo" |
| 1629 | 1629 | |
| ... | ... | @@ -1766,11 +1766,11 @@ msgstr "WSAEventSelect falhou" |
| 1766 | 1766 | msgid "WSAStartup failed" |
| 1767 | 1767 | msgstr "WSAStartup falhou" |
| 1768 | 1768 | |
| 1769 | -#: ft.c:400 | |
| 1769 | +#: ft.c:404 | |
| 1770 | 1770 | msgid "Waiting for GET response" |
| 1771 | 1771 | msgstr "Aguardando resposta do pedido de download" |
| 1772 | 1772 | |
| 1773 | -#: ft.c:402 | |
| 1773 | +#: ft.c:406 | |
| 1774 | 1774 | msgid "Waiting for PUT response" |
| 1775 | 1775 | msgstr "Aguardando resposta do pedido de upload" |
| 1776 | 1776 | ... | ... |
src/lib3270/ft.c
| ... | ... | @@ -219,7 +219,11 @@ static void set_ft_state(H3270FT *session, LIB3270_FT_STATE state); |
| 219 | 219 | } |
| 220 | 220 | |
| 221 | 221 | // Open local file |
| 222 | +#ifdef _WIN32 | |
| 223 | + ft_local_file = fopen(local,(flags & LIB3270_FT_OPTION_RECEIVE) ? ((flags & LIB3270_FT_OPTION_APPEND) ? "ab" : "wb") : "rb"); | |
| 224 | +#else | |
| 222 | 225 | ft_local_file = fopen(local,(flags & LIB3270_FT_OPTION_RECEIVE) ? ((flags & LIB3270_FT_OPTION_APPEND) ? "a" : "w") : "r"); |
| 226 | +#endif // _WIN32 | |
| 223 | 227 | |
| 224 | 228 | if(!ft_local_file) |
| 225 | 229 | { | ... | ... |
src/lib3270/host.c
| ... | ... | @@ -60,168 +60,6 @@ |
| 60 | 60 | static void try_reconnect(H3270 *session); |
| 61 | 61 | |
| 62 | 62 | /* |
| 63 | -static char * stoken(char **s) | |
| 64 | -{ | |
| 65 | - char *r; | |
| 66 | - char *ss = *s; | |
| 67 | - | |
| 68 | - if (!*ss) | |
| 69 | - return NULL; | |
| 70 | - r = ss; | |
| 71 | - while (*ss && *ss != ' ' && *ss != '\t') | |
| 72 | - ss++; | |
| 73 | - if (*ss) { | |
| 74 | - *ss++ = '\0'; | |
| 75 | - while (*ss == ' ' || *ss == '\t') | |
| 76 | - ss++; | |
| 77 | - } | |
| 78 | - *s = ss; | |
| 79 | - return r; | |
| 80 | -} | |
| 81 | -*/ | |
| 82 | - | |
| 83 | -/* | |
| 84 | - * Read the host file | |
| 85 | - */ /* | |
| 86 | -void | |
| 87 | -hostfile_init(void) | |
| 88 | -{ | |
| 89 | - FILE *hf; | |
| 90 | - char buf[1024]; | |
| 91 | - static Boolean hostfile_initted = False; | |
| 92 | - struct host *h; | |
| 93 | - char *hostfile_name; | |
| 94 | - | |
| 95 | - if (hostfile_initted) | |
| 96 | - return; | |
| 97 | - | |
| 98 | - hostfile_initted = True; | |
| 99 | - hostfile_name = appres.hostsfile; | |
| 100 | - if (hostfile_name == CN) | |
| 101 | - hostfile_name = xs_buffer("%s/ibm_hosts", appres.conf_dir); | |
| 102 | - else | |
| 103 | - hostfile_name = do_subst(appres.hostsfile, True, True); | |
| 104 | - hf = fopen(hostfile_name, "r"); | |
| 105 | - if (hf != (FILE *)NULL) { | |
| 106 | - while (fgets(buf, sizeof(buf), hf)) { | |
| 107 | - char *s = buf; | |
| 108 | - char *name, *entry_type, *hostname; | |
| 109 | - char *slash; | |
| 110 | - | |
| 111 | - if (strlen(buf) > (unsigned)1 && | |
| 112 | - buf[strlen(buf) - 1] == '\n') { | |
| 113 | - buf[strlen(buf) - 1] = '\0'; | |
| 114 | - } | |
| 115 | - while (isspace(*s)) | |
| 116 | - s++; | |
| 117 | - if (!*s || *s == '#') | |
| 118 | - continue; | |
| 119 | - name = stoken(&s); | |
| 120 | - entry_type = stoken(&s); | |
| 121 | - hostname = stoken(&s); | |
| 122 | - if (!name || !entry_type || !hostname) { | |
| 123 | - popup_an_error("Bad %s syntax, entry skipped", | |
| 124 | - ResHostsFile); | |
| 125 | - continue; | |
| 126 | - } | |
| 127 | - h = (struct host *)lib3270_malloc(sizeof(*h)); | |
| 128 | - if (!split_hier(NewString(name), &h->name, | |
| 129 | - &h->parents)) { | |
| 130 | - lib3270_free(h); | |
| 131 | - continue; | |
| 132 | - } | |
| 133 | - h->hostname = NewString(hostname); | |
| 134 | - | |
| 135 | - // | |
| 136 | - // Quick syntax extension to allow the hosts file to | |
| 137 | - // specify a port as host/port. | |
| 138 | - // | |
| 139 | - if ((slash = strchr(h->hostname, '/'))) | |
| 140 | - *slash = ':'; | |
| 141 | - | |
| 142 | - if (!strcmp(entry_type, "primary")) | |
| 143 | - h->entry_type = PRIMARY; | |
| 144 | - else | |
| 145 | - h->entry_type = ALIAS; | |
| 146 | - if (*s) | |
| 147 | - h->loginstring = NewString(s); | |
| 148 | - else | |
| 149 | - h->loginstring = CN; | |
| 150 | - h->prev = last_host; | |
| 151 | - h->next = (struct host *)NULL; | |
| 152 | - if (last_host) | |
| 153 | - last_host->next = h; | |
| 154 | - else | |
| 155 | - hosts = h; | |
| 156 | - last_host = h; | |
| 157 | - } | |
| 158 | - (void) fclose(hf); | |
| 159 | - } else if (appres.hostsfile != CN) { | |
| 160 | - popup_an_errno(errno, "Cannot open " ResHostsFile " '%s'", | |
| 161 | - appres.hostsfile); | |
| 162 | - } | |
| 163 | - lib3270_free(hostfile_name); | |
| 164 | - | |
| 165 | -// #if defined(X3270_DISPLAY) | |
| 166 | -// save_recent(CN); | |
| 167 | -// #endif | |
| 168 | -} | |
| 169 | -*/ | |
| 170 | - | |
| 171 | -/* | |
| 172 | - * Look up a host in the list. Turns aliases into real hostnames, and | |
| 173 | - * finds loginstrings. | |
| 174 | - */ /* | |
| 175 | -static int | |
| 176 | -hostfile_lookup(const char *name, char **hostname, char **loginstring) | |
| 177 | -{ | |
| 178 | - struct host *h; | |
| 179 | - | |
| 180 | - hostfile_init(); | |
| 181 | - for (h = hosts; h != (struct host *)NULL; h = h->next) { | |
| 182 | - if (h->entry_type == RECENT) | |
| 183 | - continue; | |
| 184 | - if (!strcmp(name, h->name)) { | |
| 185 | - *hostname = h->hostname; | |
| 186 | - if (h->loginstring != CN) { | |
| 187 | - *loginstring = h->loginstring; | |
| 188 | - } else { | |
| 189 | - *loginstring = appres.login_macro; | |
| 190 | - } | |
| 191 | - return 1; | |
| 192 | - } | |
| 193 | - } | |
| 194 | - return 0; | |
| 195 | -} | |
| 196 | -*/ | |
| 197 | - | |
| 198 | -/* | |
| 199 | -#if defined(LOCAL_PROCESS) | |
| 200 | -// Recognize and translate "-e" options. | |
| 201 | -static const char * | |
| 202 | -parse_localprocess(const char *s) | |
| 203 | -{ | |
| 204 | - int sl = strlen(OptLocalProcess); | |
| 205 | - | |
| 206 | - if (!strncmp(s, OptLocalProcess, sl)) { | |
| 207 | - if (s[sl] == ' ') | |
| 208 | - return(s + sl + 1); | |
| 209 | - else if (s[sl] == '\0') { | |
| 210 | - char *r; | |
| 211 | - | |
| 212 | - r = getenv("SHELL"); | |
| 213 | - if (r != CN) | |
| 214 | - return r; | |
| 215 | - else | |
| 216 | - return "/bin/sh"; | |
| 217 | - } | |
| 218 | - } | |
| 219 | - return CN; | |
| 220 | -} | |
| 221 | -#endif | |
| 222 | -*/ | |
| 223 | - | |
| 224 | -/* | |
| 225 | 63 | * Strip qualifiers from a hostname. |
| 226 | 64 | * Returns the hostname part in a newly-malloc'd string. |
| 227 | 65 | * 'needed' is returned True if anything was actually stripped. | ... | ... |