/* * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a * aplicativos mainframe. Registro no INPI sob o nome G3270. * * Copyright (C) <2008> * * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela * Free Software Foundation. * * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para * obter mais detalhes. * * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin * St, Fifth Floor, Boston, MA 02110-1301 USA * * Este programa está nomeado como - e possui - linhas de código. * * Contatos: * * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) * */ #include #include /*--[ Implement ]------------------------------------------------------------------------------------*/ /// @brief Get formatted contents as single text. gchar * v3270_get_selection_as_text(v3270 * terminal, const GList *selection, const gchar *encoding, gboolean all) { GString * string = g_string_new(""); while(selection) { lib3270_selection * block = ((lib3270_selection *) selection->data); unsigned int row, col, src = 0; for(row=0; row < block->bounds.height; row++) { for(col=0; colbounds.width; col++) { if( (block->contents[src].attribute.visual & LIB3270_ATTR_SELECTED) || all ) g_string_append_c(string,block->contents[src].chr); src++; } g_string_append_c(string,'\n'); } selection = g_list_next(selection); } g_autofree char * text = g_string_free(string,FALSE); return g_convert(text, -1, (encoding ? encoding : "UTF-8"), lib3270_get_display_charset(terminal->host), NULL, NULL, NULL); } gchar * v3270_get_copy_as_text(v3270 * terminal, const gchar *encoding) { if(terminal->selection.format == V3270_SELECT_TABLE) return v3270_get_copy_as_table(terminal,"\t",encoding); return v3270_get_selection_as_text(terminal, terminal->selection.blocks, encoding, FALSE); } LIB3270_EXPORT void v3270_input_text(GtkWidget *widget, const gchar *text, const gchar *encoding) { gchar * buffer = NULL; H3270 * session = v3270_get_session(widget); const gchar * charset = lib3270_get_display_charset(session); gboolean next; if(!text) return; else if(g_ascii_strcasecmp(encoding,charset)) buffer = g_convert(text, -1, charset, encoding, NULL, NULL, NULL); else buffer = g_strdup(text); if(!buffer) { /* Conversion failed, update special chars and try again */ size_t f; static const struct _xlat { const gchar *from; const gchar *to; } xlat[] = { { "–", "-" }, { "→", "->" }, { "←", "<-" }, { "©", "(c)" }, { "↔", "<->" }, { "™", "(TM)" }, { "®", "(R)" }, { "“", "\"" }, { "”", "\"" }, { "…", "..." }, { "•", "*" }, { "․", "." }, { "·", "*" }, }; gchar *string = g_strdup(text); // FIXME (perry#1#): Is there any better way for a "sed" here? for(f=0;fmessage, ln[f]); g_error_free(error); error = NULL; } gtk_dialog_run(GTK_DIALOG (dialog)); gtk_widget_destroy(dialog); break; } else { g_free(str); } } g_strfreev(ln); } g_free(string); } if(buffer) { /* Remove TABS */ gchar *ptr; for(ptr = buffer;*ptr;ptr++) { if(*ptr == '\t') *ptr = ' '; } } else { g_signal_emit(widget,v3270_widget_signal[V3270_SIGNAL_PASTENEXT], 0, FALSE); return; } next = lib3270_paste(session,(unsigned char *) buffer) ? TRUE : FALSE; g_free(buffer); g_signal_emit(widget,v3270_widget_signal[V3270_SIGNAL_PASTENEXT], 0, next); } LIB3270_EXPORT gchar * v3270_get_copy(GtkWidget *widget) { g_return_val_if_fail(GTK_IS_V3270(widget),NULL); return v3270_get_copy_as_text(GTK_V3270(widget),NULL); }