diff --git a/src/include/internals.h b/src/include/internals.h index 0b0eee7..d982d5b 100644 --- a/src/include/internals.h +++ b/src/include/internals.h @@ -61,6 +61,7 @@ G_GNUC_INTERNAL GtkWidget * v3270_box_pack_frame(GtkWidget *box, GtkWidget *child, const gchar *title, GtkAlign align, gboolean expand, gboolean fill, guint padding); G_GNUC_INTERNAL GtkWidget * v3270_box_pack_frame(GtkWidget *box, GtkWidget *child, const gchar *title, GtkAlign align, gboolean expand, gboolean fill, guint padding); G_GNUC_INTERNAL GtkWidget * v3270_dialog_create_grid(GtkAlign align); + G_GNUC_INTERNAL GtkWidget * v3270_dialog_create_frame(GtkWidget * child, const gchar *title); G_END_DECLS diff --git a/src/include/v3270/filetransfer.h b/src/include/v3270/filetransfer.h index 4d6cc0a..215e4b0 100644 --- a/src/include/v3270/filetransfer.h +++ b/src/include/v3270/filetransfer.h @@ -94,6 +94,25 @@ LIB3270_EXPORT GtkWidget * v3270_ft_settings_new(); + // FT Activity widget + #define G_TYPE_V3270_FT_ACTIVITY (V3270FTActivity_get_type ()) + #define G_V3270_FT_ACTIVITY(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), G_TYPE_V3270_FT_ACTIVITY, V3270FTActivity)) + #define G_V3270_FT_ACTIVITY_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), G_TYPE_V3270_FT_ACTIVITY, V3270FTActivityClass)) + #define G_IS_V3270_FT_ACTIVITY(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), G_TYPE_V3270_FT_ACTIVITY)) + #define G_IS_V3270_FT_ACTIVITY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), G_TYPE_V3270_FT_ACTIVITY)) + #define G_V3270_FT_ACTIVITY_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), G_TYPE_V3270_FT_ACTIVITY, V3270FTActivityClass)) + + typedef struct _V3270FTActivity V3270FTActivity; + typedef struct _V3270FTActivityClass V3270FTActivityClass; + + LIB3270_EXPORT GObject * v3270_ft_activity_new(); + + LIB3270_EXPORT const gchar * v3270_ft_activity_get_local_filename(GObject *object); + LIB3270_EXPORT const gchar * v3270_ft_activity_get_remote_filename(GObject *object); + + LIB3270_EXPORT void v3270_ft_activity_set_local_filename(GObject *object, const gchar *filename); + LIB3270_EXPORT void v3270_ft_activity_set_remote_filename(GObject *object, const gchar *filename); + // FT Dialog widget #define GTK_TYPE_V3270_FT_DIALOG (V3270FTDialog_get_type ()) #define GTK_V3270_FT_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_V3270_FT_DIALOG, V3270FTDialog)) diff --git a/src/v3270ft/activity.c b/src/v3270ft/activity.c new file mode 100644 index 0000000..fd19586 --- /dev/null +++ b/src/v3270ft/activity.c @@ -0,0 +1,161 @@ +/* + * "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 + +/*--[ Widget definition ]----------------------------------------------------------------------------*/ + + struct _V3270FTActivityClass + { + GObjectClass parent_class; + + }; + + struct _V3270FTActivity + { + GObject parent; + + struct { + gchar * local; + gchar * remote; + } file; + + }; + + enum + { + PROP_0, + PROP_LOCAL, + PROP_REMOTE + }; + + G_DEFINE_TYPE(V3270FTActivity, V3270FTActivity, G_TYPE_OBJECT); + +/*--[ Implement ]------------------------------------------------------------------------------------*/ + + static void dispose(GObject *object) + { + debug("%s",__FUNCTION__); + + V3270FTActivity * activity = G_V3270_FT_ACTIVITY(object); + + g_free(activity->file.local); + g_free(activity->file.remote); + + } + + static void set_property(GObject *object, guint prop_id, const GValue *value, GParamSpec G_GNUC_UNUSED(*pspec)) + { + switch(prop_id) + { + case PROP_LOCAL: + v3270_ft_activity_set_local_filename(object,g_value_get_string(value)); + break; + + case PROP_REMOTE: + v3270_ft_activity_set_remote_filename(object,g_value_get_string(value)); + break; + } + + } + + static void get_property(GObject *object, guint prop_id, GValue *value, GParamSpec G_GNUC_UNUSED(*pspec)) + { + switch(prop_id) + { + case PROP_LOCAL: + g_value_set_string(value,v3270_ft_activity_get_local_filename(object)); + break; + + case PROP_REMOTE: + g_value_set_string(value,v3270_ft_activity_get_remote_filename(object)); + break; + } + } + + static void V3270FTActivity_class_init(V3270FTActivityClass *klass) + { + G_OBJECT_CLASS(klass)->dispose = dispose; + + G_OBJECT_CLASS(klass)->set_property = set_property; + G_OBJECT_CLASS(klass)->get_property = get_property; + + g_object_class_install_property( + G_OBJECT_CLASS(klass), + PROP_LOCAL, + g_param_spec_string ("local", "Local", + _( "Full path of local file" ), + FALSE, G_PARAM_READWRITE)); + + g_object_class_install_property( + G_OBJECT_CLASS(klass), + PROP_LOCAL, + g_param_spec_string ("remote", "remote", + _( "Full path of remote file" ), + FALSE, G_PARAM_READWRITE)); + + } + + static void V3270FTActivity_init(V3270FTActivity *widget) + { + } + + LIB3270_EXPORT GObject * v3270_ft_activity_new() + { + return g_object_new(G_TYPE_V3270_FT_ACTIVITY, NULL); + } + + LIB3270_EXPORT const gchar * v3270_ft_activity_get_local_filename(GObject *object) + { + gchar **ptr = & G_V3270_FT_ACTIVITY(object)->file.local; + return(*ptr ? *ptr : ""); + } + + LIB3270_EXPORT const gchar * v3270_ft_activity_get_remote_filename(GObject *object) + { + gchar **ptr = & G_V3270_FT_ACTIVITY(object)->file.remote; + return(*ptr ? *ptr : ""); + } + + LIB3270_EXPORT void v3270_ft_activity_set_local_filename(GObject *object, const gchar *filename) + { + gchar **ptr = & G_V3270_FT_ACTIVITY(object)->file.local; + + g_free(*ptr); + *ptr = g_strdup(filename); + } + + LIB3270_EXPORT void v3270_ft_activity_set_remote_filename(GObject *object, const gchar *filename) + { + gchar **ptr = & G_V3270_FT_ACTIVITY(object)->file.remote; + + g_free(*ptr); + *ptr = g_strdup(filename); + } diff --git a/src/v3270ft/dialog.c b/src/v3270ft/dialog.c index bfef7ed..8d9b594 100644 --- a/src/v3270ft/dialog.c +++ b/src/v3270ft/dialog.c @@ -27,7 +27,7 @@ * */ - #include + #include #include #include "private.h" @@ -107,6 +107,8 @@ static void V3270FTDialog_init(V3270FTDialog *widget) gtk_widget_set_tooltip_markup(files,_("Files to transfer")); gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(files),TRUE); + gtk_tree_view_set_reorderable(GTK_TREE_VIEW(files),TRUE); + gtk_tree_view_insert_column_with_attributes( GTK_TREE_VIEW(files), -1, -- libgit2 0.21.2