Commit 82aa7d9f9e0f7bc8b1168ae504b4f5e0eb2506b6
1 parent
d43c374a
Exists in
master
and in
5 other branches
Incluindo configuração de charset
Showing
9 changed files
with
87 additions
and
34 deletions
Show diff stats
src/include/lib3270/charset.h
| ... | ... | @@ -33,6 +33,22 @@ |
| 33 | 33 | |
| 34 | 34 | #define LIB3270_CHARSET_H_INCLUDED 1 |
| 35 | 35 | |
| 36 | + struct lib3270_charset | |
| 37 | + { | |
| 38 | + const char * host; | |
| 39 | + const char * display; | |
| 40 | + | |
| 41 | + // Translation tables | |
| 42 | + unsigned short ebc2asc[256]; | |
| 43 | + unsigned short asc2ebc[256]; | |
| 44 | + | |
| 45 | + unsigned short asc2ft[256]; | |
| 46 | + unsigned short ft2asc[256]; | |
| 47 | + | |
| 48 | + unsigned short asc2uc[256]; | |
| 49 | + | |
| 50 | + }; | |
| 51 | + | |
| 36 | 52 | typedef enum |
| 37 | 53 | { |
| 38 | 54 | CS_ONLY, |
| ... | ... | @@ -40,7 +56,7 @@ |
| 40 | 56 | BOTH |
| 41 | 57 | } lib3270_remap_scope; |
| 42 | 58 | |
| 43 | - LIB3270_EXPORT struct lib3270_charset * lib3270_load_charset(H3270 *hSession, const char *name); | |
| 44 | - LIB3270_EXPORT void lib3270_remap(H3270 *hSession, unsigned short ebc, unsigned short iso, lib3270_remap_scope scope, unsigned char one_way); | |
| 59 | + LIB3270_EXPORT int lib3270_set_host_charset(H3270 *hSession, const char *name); | |
| 60 | + LIB3270_EXPORT void lib3270_remap(H3270 *hSession, unsigned short ebc, unsigned short iso, lib3270_remap_scope scope, unsigned char one_way); | |
| 45 | 61 | |
| 46 | 62 | #endif // LIB3270_CHARSET_H_INCLUDED | ... | ... |
src/include/lib3270/session.h
| ... | ... | @@ -34,6 +34,7 @@ |
| 34 | 34 | #define LIB3270_SESSION_H_INCLUDED 1 |
| 35 | 35 | #include <sys/time.h> |
| 36 | 36 | #include <lib3270/popup.h> |
| 37 | + #include <lib3270/charset.h> | |
| 37 | 38 | |
| 38 | 39 | #define LIB3270_LUNAME_LENGTH 16 |
| 39 | 40 | #define LIB3270_FULL_MODEL_NAME_LENGTH 13 |
| ... | ... | @@ -143,26 +144,7 @@ |
| 143 | 144 | char * proxy; /**< Proxy server (type:host[:port]) */ |
| 144 | 145 | char * termname; |
| 145 | 146 | |
| 146 | - struct lib3270_charset | |
| 147 | - { | |
| 148 | - const char * host; | |
| 149 | - const char * display; | |
| 150 | - | |
| 151 | - // Translation tables | |
| 152 | - unsigned short ebc2asc[256]; | |
| 153 | - unsigned short asc2ebc[256]; | |
| 154 | - | |
| 155 | - unsigned short asc2ft[256]; | |
| 156 | - unsigned short ft2asc[256]; | |
| 157 | - | |
| 158 | - unsigned short asc2uc[256]; | |
| 159 | - | |
| 160 | -// unsigned short ebc2cg[256]; | |
| 161 | -// unsigned short cg2ebc[256]; | |
| 162 | -// unsigned short asc2cg[256]; | |
| 163 | -// unsigned short cg2asc[256]; | |
| 164 | - | |
| 165 | - } charset; | |
| 147 | + struct lib3270_charset charset; | |
| 166 | 148 | |
| 167 | 149 | LIB3270_MESSAGE oia_status; |
| 168 | 150 | ... | ... |
src/include/pw3270.h
| ... | ... | @@ -87,6 +87,8 @@ |
| 87 | 87 | |
| 88 | 88 | LIB3270_EXPORT gchar * pw3270_file_chooser(GtkFileChooserAction action, const gchar *name, const gchar *title, const gchar *file, const gchar *ext); |
| 89 | 89 | |
| 90 | + LIB3270_EXPORT void pw3270_set_host_charset(GtkWidget *widget, const gchar *name); | |
| 91 | + | |
| 90 | 92 | typedef enum pw3270_src |
| 91 | 93 | { |
| 92 | 94 | PW3270_SRC_ALL, /**< Screen contents */ | ... | ... |
src/include/pw3270/v3270.h
| ... | ... | @@ -160,6 +160,8 @@ |
| 160 | 160 | LIB3270_EXPORT int v3270_connect(GtkWidget *widget, const gchar *host); |
| 161 | 161 | LIB3270_EXPORT void v3270_disconnect(GtkWidget *widget); |
| 162 | 162 | |
| 163 | + LIB3270_EXPORT int v3270_set_host_charset(GtkWidget *widget, const gchar *name); | |
| 164 | + | |
| 163 | 165 | // Clipboard |
| 164 | 166 | typedef enum _v3270_select_format |
| 165 | 167 | { | ... | ... |
src/lib3270/charset.c
| ... | ... | @@ -36,7 +36,7 @@ |
| 36 | 36 | |
| 37 | 37 | #include "globals.h" |
| 38 | 38 | #include "X11keysym.h" |
| 39 | -#include <lib3270/charset.h"> | |
| 39 | +#include <lib3270/charset.h> | |
| 40 | 40 | |
| 41 | 41 | /* |
| 42 | 42 | * EBCDIC-to-Unicode translation tables. |
| ... | ... | @@ -220,6 +220,20 @@ static const remap charset[] = |
| 220 | 220 | } |
| 221 | 221 | }, |
| 222 | 222 | |
| 223 | + { | |
| 224 | + "cp500", | |
| 225 | + (const unsigned short const []) | |
| 226 | + { | |
| 227 | + 0x004a, '[', | |
| 228 | + 0x004f, '!', | |
| 229 | + 0x005a, ']', | |
| 230 | + 0x005f, '^', | |
| 231 | + 0x00b0, XK_percent, | |
| 232 | + 0x00ba, XK_notsign, | |
| 233 | + 0x00bb, XK_bar | |
| 234 | + } | |
| 235 | + }, | |
| 236 | + | |
| 223 | 237 | // Terminate list |
| 224 | 238 | { |
| 225 | 239 | NULL |
| ... | ... | @@ -236,7 +250,7 @@ static void copy_charset(const unsigned short *from, unsigned short *to) |
| 236 | 250 | to[f+UT_OFFSET] = from[f]; |
| 237 | 251 | } |
| 238 | 252 | |
| 239 | -LIB3270_EXPORT struct lib3270_charset * lib3270_load_charset(H3270 *hSession, const char *name) | |
| 253 | +LIB3270_EXPORT int lib3270_set_host_charset(H3270 *hSession, const char *name) | |
| 240 | 254 | { |
| 241 | 255 | int f; |
| 242 | 256 | |
| ... | ... | @@ -259,7 +273,7 @@ LIB3270_EXPORT struct lib3270_charset * lib3270_load_charset(H3270 *hSession, co |
| 259 | 273 | #endif |
| 260 | 274 | |
| 261 | 275 | if(!(name && strcasecmp(name,hSession->charset.host))) |
| 262 | - return &hSession->charset; | |
| 276 | + return 0; | |
| 263 | 277 | |
| 264 | 278 | for(f=0;charset[f].name != NULL;f++) |
| 265 | 279 | { |
| ... | ... | @@ -272,14 +286,11 @@ LIB3270_EXPORT struct lib3270_charset * lib3270_load_charset(H3270 *hSession, co |
| 272 | 286 | |
| 273 | 287 | for(c=0;charset[f].chr[c];c+=2) |
| 274 | 288 | lib3270_remap(hSession,charset[f].chr[c],charset[f].chr[c+1], BOTH, 0); |
| 275 | - errno = 0; | |
| 276 | - return &hSession->charset; | |
| 289 | + return 0; | |
| 277 | 290 | } |
| 278 | 291 | } |
| 279 | 292 | |
| 280 | - errno = ENOENT; | |
| 281 | - | |
| 282 | - return NULL; | |
| 293 | + return ENOENT; | |
| 283 | 294 | |
| 284 | 295 | } |
| 285 | 296 | |
| ... | ... | @@ -358,7 +369,8 @@ LIB3270_ACTION( charsettable ) |
| 358 | 369 | // Process a single character definition. |
| 359 | 370 | LIB3270_EXPORT void lib3270_remap(H3270 *hSession, unsigned short ebc, unsigned short iso, lib3270_remap_scope scope, unsigned char one_way) |
| 360 | 371 | { |
| 361 | -// unsigned char cg; | |
| 372 | + // unsigned char cg; | |
| 373 | + CHECK_SESSION_HANDLE(hSession); | |
| 362 | 374 | |
| 363 | 375 | // Ignore mappings of EBCDIC control codes and the space character. |
| 364 | 376 | if (ebc <= 0x40) | ... | ... |
src/lib3270/session.c
| ... | ... | @@ -46,7 +46,7 @@ |
| 46 | 46 | #include "3270ds.h" |
| 47 | 47 | // #include "tablesc.h" |
| 48 | 48 | #include "popupsc.h" |
| 49 | -#include "charset.h" | |
| 49 | +//#include "charset.h" | |
| 50 | 50 | |
| 51 | 51 | /*---[ Globals ]--------------------------------------------------------------------------------------------------------------*/ |
| 52 | 52 | |
| ... | ... | @@ -187,7 +187,7 @@ static void lib3270_session_init(H3270 *hSession, const char *model, const char |
| 187 | 187 | memset(hSession,0,sizeof(H3270)); |
| 188 | 188 | hSession->sz = sizeof(H3270); |
| 189 | 189 | |
| 190 | - lib3270_load_charset(hSession,charset); | |
| 190 | + lib3270_set_host_charset(hSession,charset); | |
| 191 | 191 | |
| 192 | 192 | // Default calls |
| 193 | 193 | hSession->write = lib3270_sock_send; |
| ... | ... | @@ -321,7 +321,7 @@ H3270 * lib3270_session_new(const char *model) |
| 321 | 321 | |
| 322 | 322 | hSession = default_session = lib3270_malloc(sizeof(H3270)); |
| 323 | 323 | |
| 324 | - lib3270_session_init(hSession, model, "bracket"); | |
| 324 | + lib3270_session_init(hSession, model, _( "bracket" ) ); | |
| 325 | 325 | |
| 326 | 326 | if(screen_init(hSession)) |
| 327 | 327 | return NULL; | ... | ... |
src/pw3270/main.c
| ... | ... | @@ -60,6 +60,7 @@ |
| 60 | 60 | static const gchar * togglereset = NULL; |
| 61 | 61 | static const gchar * logfile = NULL; |
| 62 | 62 | static const gchar * tracefile = NULL; |
| 63 | + static const gchar * charset = NULL; | |
| 63 | 64 | |
| 64 | 65 | #ifdef HAVE_GTKMAC |
| 65 | 66 | GtkOSXApplication * osxapp = NULL; |
| ... | ... | @@ -403,6 +404,7 @@ int main(int argc, char *argv[]) |
| 403 | 404 | { "systype", 't', 0, G_OPTION_ARG_STRING, &system, N_( "Host system type" ), "S390" }, |
| 404 | 405 | { "toggleset", 'S', 0, G_OPTION_ARG_STRING, &toggleset, N_( "Set toggles ON" ), NULL }, |
| 405 | 406 | { "togglereset", 'R', 0, G_OPTION_ARG_STRING, &togglereset, N_( "Set toggles OFF" ), NULL }, |
| 407 | + { "charset", 'C', 0, G_OPTION_ARG_STRING, &charset, N_( "Set host charset" ), N_( "bracket" ) }, | |
| 406 | 408 | |
| 407 | 409 | #if defined( HAVE_SYSLOG ) |
| 408 | 410 | { "syslog", 'l', 0, G_OPTION_ARG_NONE, &log_to_syslog, N_( "Send messages to syslog" ), NULL }, |
| ... | ... | @@ -542,6 +544,10 @@ int main(int argc, char *argv[]) |
| 542 | 544 | g_strfreev(str); |
| 543 | 545 | } |
| 544 | 546 | |
| 547 | + if(charset) | |
| 548 | + { | |
| 549 | + pw3270_set_host_charset(toplevel,charset); | |
| 550 | + } | |
| 545 | 551 | |
| 546 | 552 | toplevel_setup(GTK_WINDOW(toplevel)); |
| 547 | 553 | ... | ... |
src/pw3270/tools.c
| ... | ... | @@ -28,6 +28,7 @@ |
| 28 | 28 | */ |
| 29 | 29 | |
| 30 | 30 | #include "globals.h" |
| 31 | + #include <lib3270/charset.h> | |
| 31 | 32 | |
| 32 | 33 | #if defined WIN32 |
| 33 | 34 | BOOL WINAPI DllMain(HANDLE hinst, DWORD dwcallpurpose, LPVOID lpvResvd); |
| ... | ... | @@ -196,3 +197,29 @@ LIB3270_EXPORT gchar * pw3270_get_datadir(const gchar *first_element, ...) |
| 196 | 197 | va_end(args); |
| 197 | 198 | return path; |
| 198 | 199 | } |
| 200 | + | |
| 201 | +LIB3270_EXPORT void pw3270_set_host_charset(GtkWidget *widget, const gchar *name) | |
| 202 | +{ | |
| 203 | + H3270 * hSession = pw3270_get_session(widget); | |
| 204 | + | |
| 205 | + if(!hSession) | |
| 206 | + return; | |
| 207 | + | |
| 208 | + if(!lib3270_set_host_charset(hSession,name)) | |
| 209 | + return; | |
| 210 | + | |
| 211 | + // Charset setup failed, notify user | |
| 212 | + GtkWidget * dialog = gtk_message_dialog_new( GTK_WINDOW(widget), | |
| 213 | + GTK_DIALOG_DESTROY_WITH_PARENT, | |
| 214 | + GTK_MESSAGE_ERROR, | |
| 215 | + GTK_BUTTONS_OK, | |
| 216 | + "%s", _( "Can't set host charset" ) ); | |
| 217 | + | |
| 218 | + | |
| 219 | + gtk_message_dialog_format_secondary_text(GTK_MESSAGE_DIALOG(dialog),_( "There's no available settings for charset \"%s\"" ),name); | |
| 220 | + gtk_window_set_title(GTK_WINDOW(dialog),_( "Charset error" )); | |
| 221 | + | |
| 222 | + gtk_dialog_run(GTK_DIALOG (dialog)); | |
| 223 | + gtk_widget_destroy(dialog); | |
| 224 | + | |
| 225 | +} | ... | ... |
src/pw3270/v3270/widget.c
| ... | ... | @@ -1528,6 +1528,12 @@ gboolean v3270_is_connected(GtkWidget *widget) |
| 1528 | 1528 | return lib3270_connected(GTK_V3270(widget)->host) ? TRUE : FALSE; |
| 1529 | 1529 | } |
| 1530 | 1530 | |
| 1531 | +int v3270_set_host_charset(GtkWidget *widget, const gchar *name) | |
| 1532 | +{ | |
| 1533 | + g_return_val_if_fail(GTK_IS_V3270(widget),FALSE); | |
| 1534 | + return lib3270_set_host_charset(GTK_V3270(widget)->host,name); | |
| 1535 | +} | |
| 1536 | + | |
| 1531 | 1537 | GtkWidget * v3270_get_default_widget(void) |
| 1532 | 1538 | { |
| 1533 | 1539 | H3270 * hSession = lib3270_get_default_session_handle(); | ... | ... |