Commit 2ea451a5a1b3ba885c91c7a64be1fa41a6651b06
1 parent
1e84a9de
Exists in
master
and in
1 other branch
Writing the FT Worker widget.
Showing
5 changed files
with
55 additions
and
5 deletions
Show diff stats
src/filetransfer/activity.c
| @@ -71,7 +71,7 @@ | @@ -71,7 +71,7 @@ | ||
| 71 | 71 | ||
| 72 | static void dispose(GObject *object) | 72 | static void dispose(GObject *object) |
| 73 | { | 73 | { |
| 74 | - debug("%s",__FUNCTION__); | 74 | + debug("activity::%s(%p)",__FUNCTION__,object); |
| 75 | 75 | ||
| 76 | V3270FTActivity * activity = G_V3270_FT_ACTIVITY(object); | 76 | V3270FTActivity * activity = G_V3270_FT_ACTIVITY(object); |
| 77 | 77 |
src/filetransfer/worker.c
| @@ -45,9 +45,10 @@ | @@ -45,9 +45,10 @@ | ||
| 45 | { | 45 | { |
| 46 | GtkGrid parent; | 46 | GtkGrid parent; |
| 47 | 47 | ||
| 48 | - GtkProgressBar * pbar; ///< @brief Progress bar. | 48 | + GtkProgressBar * pbar; ///< @brief Progress bar. |
| 49 | + GObject * activity; ///< @brief File transfer activity; | ||
| 49 | 50 | ||
| 50 | - GtkEntry * field[PROGRESS_FIELD_COUNT]; ///< @brief Transfer information widgets. | 51 | + GtkEntry * field[PROGRESS_FIELD_COUNT]; ///< @brief Transfer information widgets. |
| 51 | 52 | ||
| 52 | 53 | ||
| 53 | }; | 54 | }; |
| @@ -60,8 +61,13 @@ | @@ -60,8 +61,13 @@ | ||
| 60 | { | 61 | { |
| 61 | debug("%s",__FUNCTION__); | 62 | debug("%s",__FUNCTION__); |
| 62 | 63 | ||
| 63 | - // V3270FTWorker * worker = GTK_V3270_FT_WORKER(object); | 64 | + V3270FTWorker * worker = GTK_V3270_FT_WORKER(object); |
| 64 | 65 | ||
| 66 | + if(worker->activity) | ||
| 67 | + { | ||
| 68 | + g_object_unref(worker->activity); | ||
| 69 | + worker->activity = NULL; | ||
| 70 | + } | ||
| 65 | 71 | ||
| 66 | G_OBJECT_CLASS(V3270FTWorker_parent_class)->finalize(object); | 72 | G_OBJECT_CLASS(V3270FTWorker_parent_class)->finalize(object); |
| 67 | 73 | ||
| @@ -115,7 +121,7 @@ | @@ -115,7 +121,7 @@ | ||
| 115 | gtk_box_set_homogeneous(GTK_BOX(views),TRUE); | 121 | gtk_box_set_homogeneous(GTK_BOX(views),TRUE); |
| 116 | gtk_grid_attach(GTK_GRID(widget),views,0,2,10,1); | 122 | gtk_grid_attach(GTK_GRID(widget),views,0,2,10,1); |
| 117 | g_object_set(G_OBJECT(views),"margin-top",8,NULL); | 123 | g_object_set(G_OBJECT(views),"margin-top",8,NULL); |
| 118 | - g_object_set(G_OBJECT(views),"margin-botton",8,NULL); | 124 | + g_object_set(G_OBJECT(views),"margin-bottom",8,NULL); |
| 119 | 125 | ||
| 120 | { | 126 | { |
| 121 | // Left options | 127 | // Left options |
| @@ -168,3 +174,37 @@ | @@ -168,3 +174,37 @@ | ||
| 168 | return GTK_WIDGET(g_object_new(GTK_TYPE_V3270_FT_WORKER, NULL)); | 174 | return GTK_WIDGET(g_object_new(GTK_TYPE_V3270_FT_WORKER, NULL)); |
| 169 | } | 175 | } |
| 170 | 176 | ||
| 177 | + LIB3270_EXPORT void v3270_ft_worker_set_activity(GtkWidget *widget, GObject *activity) | ||
| 178 | + { | ||
| 179 | + size_t ix; | ||
| 180 | + | ||
| 181 | + V3270FTWorker * worker = GTK_V3270_FT_WORKER(widget); | ||
| 182 | + | ||
| 183 | + if(worker->activity) | ||
| 184 | + { | ||
| 185 | + g_object_unref(worker->activity); | ||
| 186 | + worker->activity = NULL; | ||
| 187 | + } | ||
| 188 | + | ||
| 189 | + if(activity) | ||
| 190 | + { | ||
| 191 | + worker->activity = activity; | ||
| 192 | + g_object_ref(worker->activity); | ||
| 193 | + | ||
| 194 | + gtk_entry_set_text(worker->field[PROGRESS_FIELD_LOCAL],v3270_ft_activity_get_local_filename(activity)); | ||
| 195 | + gtk_entry_set_text(worker->field[PROGRESS_FIELD_REMOTE],v3270_ft_activity_get_remote_filename(activity)); | ||
| 196 | + | ||
| 197 | + } | ||
| 198 | + else | ||
| 199 | + { | ||
| 200 | + gtk_entry_set_text(worker->field[PROGRESS_FIELD_LOCAL],""); | ||
| 201 | + gtk_entry_set_text(worker->field[PROGRESS_FIELD_REMOTE],""); | ||
| 202 | + } | ||
| 203 | + | ||
| 204 | + for(ix = PROGRESS_FIELD_TOTAL; ix < PROGRESS_FIELD_COUNT; ix++) | ||
| 205 | + { | ||
| 206 | + gtk_entry_set_text(worker->field[ix],""); | ||
| 207 | + } | ||
| 208 | + | ||
| 209 | + } | ||
| 210 | + |
src/include/v3270/filetransfer.h
| @@ -158,5 +158,6 @@ | @@ -158,5 +158,6 @@ | ||
| 158 | typedef struct _V3270FTWorkerClass V3270FTWorkerClass; | 158 | typedef struct _V3270FTWorkerClass V3270FTWorkerClass; |
| 159 | 159 | ||
| 160 | LIB3270_EXPORT GtkWidget * v3270_ft_worker_new(); | 160 | LIB3270_EXPORT GtkWidget * v3270_ft_worker_new(); |
| 161 | + LIB3270_EXPORT void v3270_ft_worker_set_activity(GtkWidget *widget, GObject *activity); | ||
| 161 | 162 | ||
| 162 | #endif // V3270FT_H_INCLUDED | 163 | #endif // V3270FT_H_INCLUDED |
src/testprogram/testprogram.c
| @@ -153,6 +153,12 @@ static void ft_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *terminal) | @@ -153,6 +153,12 @@ static void ft_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *terminal) | ||
| 153 | GtkWidget * worker = v3270_ft_worker_new(); | 153 | GtkWidget * worker = v3270_ft_worker_new(); |
| 154 | gtk_box_pack_start(GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dialog))),worker,TRUE,TRUE,2); | 154 | gtk_box_pack_start(GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dialog))),worker,TRUE,TRUE,2); |
| 155 | 155 | ||
| 156 | + GObject * activity = v3270_ft_activity_new(); | ||
| 157 | + v3270_ft_activity_set_local_filename(activity,"local_file"); | ||
| 158 | + v3270_ft_activity_set_remote_filename(activity,"remove_file"); | ||
| 159 | + v3270_ft_worker_set_activity(worker,activity); | ||
| 160 | + g_object_unref(activity); | ||
| 161 | + | ||
| 156 | // GtkWidget * dialog = v3270ftprogress_new(); | 162 | // GtkWidget * dialog = v3270ftprogress_new(); |
| 157 | // GtkWidget * dialog = v3270_ft_dialog_new(terminal); | 163 | // GtkWidget * dialog = v3270_ft_dialog_new(terminal); |
| 158 | 164 |
v3270.cbp
| @@ -121,6 +121,9 @@ | @@ -121,6 +121,9 @@ | ||
| 121 | <Unit filename="src/filetransfer/v3270ftprogress.c"> | 121 | <Unit filename="src/filetransfer/v3270ftprogress.c"> |
| 122 | <Option compilerVar="CC" /> | 122 | <Option compilerVar="CC" /> |
| 123 | </Unit> | 123 | </Unit> |
| 124 | + <Unit filename="src/filetransfer/worker.c"> | ||
| 125 | + <Option compilerVar="CC" /> | ||
| 126 | + </Unit> | ||
| 124 | <Unit filename="src/include/config.h" /> | 127 | <Unit filename="src/include/config.h" /> |
| 125 | <Unit filename="src/include/config.h.in" /> | 128 | <Unit filename="src/include/config.h.in" /> |
| 126 | <Unit filename="src/include/hostselect.h" /> | 129 | <Unit filename="src/include/hostselect.h" /> |