Commit edfb6f9262d061f53b52c107b96d6c55b2a831f8
1 parent
9a7ea73f
Exists in
master
and in
4 other branches
Implementing build of menus using standard xml files.
Showing
5 changed files
with
72 additions
and
37 deletions
Show diff stats
src/objects/window/application.ui
@@ -1,23 +0,0 @@ | @@ -1,23 +0,0 @@ | ||
1 | -<?xml version="1.0" encoding="UTF-8"?> | ||
2 | -<interface> | ||
3 | - <requires lib="gtk+" version="3.0"/> | ||
4 | - <menu id="app-menu"> | ||
5 | - <section> | ||
6 | - <item> | ||
7 | - <attribute name="label" translatable="yes">About</attribute> | ||
8 | - <attribute name="action">app.about</attribute> | ||
9 | - </item> | ||
10 | - <item> | ||
11 | - <attribute name="label" translatable="yes">Help</attribute> | ||
12 | - <attribute name="action">app.help</attribute> | ||
13 | - <attribute name="accel">F1</attribute> | ||
14 | - </item> | ||
15 | - <item> | ||
16 | - <attribute name="label" translatable="yes">Quit</attribute> | ||
17 | - <attribute name="action">app.quit</attribute> | ||
18 | - <attribute name="accel"><Primary>q</attribute> | ||
19 | - </item> | ||
20 | - </section> | ||
21 | - </menu> | ||
22 | -</interface> | ||
23 | - |
@@ -0,0 +1,53 @@ | @@ -0,0 +1,53 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<interface> | ||
3 | + <requires lib="gtk+" version="3.0"/> | ||
4 | + <menu id="app-menu"> | ||
5 | + <section> | ||
6 | + <item> | ||
7 | + <attribute name="label" translatable="yes">About PW3270</attribute> | ||
8 | + <attribute name="action">app.about</attribute> | ||
9 | + </item> | ||
10 | + <item> | ||
11 | + <attribute name="label" translatable="yes">Preferences</attribute> | ||
12 | + <attribute name="action">app.help</attribute> | ||
13 | + </item> | ||
14 | + <item> | ||
15 | + <attribute name="label" translatable="yes">Quit</attribute> | ||
16 | + <attribute name="action">app.quit</attribute> | ||
17 | + </item> | ||
18 | + </section> | ||
19 | + </menu> | ||
20 | + <menu id='menubar'> | ||
21 | + | ||
22 | + <submenu> | ||
23 | + <attribute name='label' translatable='yes'>_Edit</attribute> | ||
24 | + <section> | ||
25 | + <item> | ||
26 | + <attribute name='label' translatable='yes'>_Copy</attribute> | ||
27 | + <attribute name='action'>app.quit</attribute> | ||
28 | + </item> | ||
29 | + <item> | ||
30 | + <attribute name='label' translatable='yes'>_Paste</attribute> | ||
31 | + <attribute name='action'>app.quit</attribute> | ||
32 | + </item> | ||
33 | + </section> | ||
34 | + <section> | ||
35 | + <item> | ||
36 | + <attribute name='label' translatable='yes'>Plugins</attribute> | ||
37 | + <attribute name='action'>app.quit</attribute> | ||
38 | + </item> | ||
39 | + </section> | ||
40 | + </submenu> | ||
41 | + | ||
42 | + <submenu> | ||
43 | + <attribute name='label' translatable='yes'>_View</attribute> | ||
44 | + <section> | ||
45 | + <item> | ||
46 | + <attribute name='label' translatable='yes'>_Fullscreen</attribute> | ||
47 | + <attribute name='action'>app.quit</attribute> | ||
48 | + </item> | ||
49 | + </section> | ||
50 | + </submenu> | ||
51 | + | ||
52 | + </menu> | ||
53 | +</interface> |
src/objects/window/init.c
@@ -50,8 +50,8 @@ | @@ -50,8 +50,8 @@ | ||
50 | gtk_box_pack_start(vBox,GTK_WIDGET(widget->toolbar),FALSE,TRUE,0); | 50 | gtk_box_pack_start(vBox,GTK_WIDGET(widget->toolbar),FALSE,TRUE,0); |
51 | gtk_box_pack_start(vBox,GTK_WIDGET(widget->notebook),TRUE,TRUE,0); | 51 | gtk_box_pack_start(vBox,GTK_WIDGET(widget->notebook),TRUE,TRUE,0); |
52 | 52 | ||
53 | + gtk_widget_show_all(GTK_WIDGET(vBox)); | ||
53 | gtk_container_add(GTK_CONTAINER(widget),GTK_WIDGET(vBox)); | 54 | gtk_container_add(GTK_CONTAINER(widget),GTK_WIDGET(vBox)); |
54 | - gtk_widget_show_all(GTK_WIDGET(widget)); | ||
55 | 55 | ||
56 | } | 56 | } |
57 | 57 |
src/objects/window/terminal.c
@@ -72,6 +72,9 @@ | @@ -72,6 +72,9 @@ | ||
72 | g_signal_connect(G_OBJECT(terminal), "focus-in-event", G_CALLBACK(on_terminal_focus), widget); | 72 | g_signal_connect(G_OBJECT(terminal), "focus-in-event", G_CALLBACK(on_terminal_focus), widget); |
73 | g_signal_connect(G_OBJECT(terminal), "session_changed", G_CALLBACK(session_changed),label); | 73 | g_signal_connect(G_OBJECT(terminal), "session_changed", G_CALLBACK(session_changed),label); |
74 | 74 | ||
75 | + gtk_widget_show_all(terminal); | ||
76 | + gtk_widget_show_all(label); | ||
77 | + | ||
75 | gtk_notebook_append_page(GTK_NOTEBOOK(window->notebook),terminal,label); | 78 | gtk_notebook_append_page(GTK_NOTEBOOK(window->notebook),terminal,label); |
76 | gtk_notebook_set_show_tabs(GTK_NOTEBOOK(window->notebook),gtk_notebook_get_n_pages(GTK_NOTEBOOK(window->notebook)) > 1); | 79 | gtk_notebook_set_show_tabs(GTK_NOTEBOOK(window->notebook),gtk_notebook_get_n_pages(GTK_NOTEBOOK(window->notebook)) > 1); |
77 | 80 |
src/objects/window/testprogram/testprogram.c
@@ -41,6 +41,8 @@ | @@ -41,6 +41,8 @@ | ||
41 | 41 | ||
42 | GtkWidget * window = pw3270_application_window_new(app); | 42 | GtkWidget * window = pw3270_application_window_new(app); |
43 | 43 | ||
44 | + gtk_application_window_set_show_menubar(GTK_APPLICATION_WINDOW(window),TRUE); | ||
45 | + | ||
44 | // Create terminal widget | 46 | // Create terminal widget |
45 | pw3270_terminal_new(window); | 47 | pw3270_terminal_new(window); |
46 | pw3270_terminal_new(window); | 48 | pw3270_terminal_new(window); |
@@ -48,7 +50,9 @@ | @@ -48,7 +50,9 @@ | ||
48 | // Setup and show main window | 50 | // Setup and show main window |
49 | gtk_window_set_position(GTK_WINDOW(window),GTK_WIN_POS_CENTER); | 51 | gtk_window_set_position(GTK_WINDOW(window),GTK_WIN_POS_CENTER); |
50 | gtk_window_set_default_size (GTK_WINDOW (window), 800, 500); | 52 | gtk_window_set_default_size (GTK_WINDOW (window), 800, 500); |
51 | - gtk_widget_show_all(window); | 53 | + |
54 | + // gtk_widget_show_all(window); | ||
55 | + gtk_window_present(GTK_WINDOW(window)); | ||
52 | 56 | ||
53 | } | 57 | } |
54 | 58 | ||
@@ -85,7 +89,7 @@ GtkWidget * pw3270_toolbar_new(void) { | @@ -85,7 +89,7 @@ GtkWidget * pw3270_toolbar_new(void) { | ||
85 | return toolbar; | 89 | return toolbar; |
86 | } | 90 | } |
87 | 91 | ||
88 | -static void preferences_activated(GSimpleAction * action, GtkApplication *application) { | 92 | +static void preferences_activated(GSimpleAction * action, GVariant *parameter, gpointer application) { |
89 | 93 | ||
90 | debug("%s",__FUNCTION__); | 94 | debug("%s",__FUNCTION__); |
91 | 95 | ||
@@ -97,7 +101,7 @@ static void quit_activated(GSimpleAction * action, GVariant *parameter, gpointer | @@ -97,7 +101,7 @@ static void quit_activated(GSimpleAction * action, GVariant *parameter, gpointer | ||
97 | 101 | ||
98 | } | 102 | } |
99 | 103 | ||
100 | -void startup(GtkApplication *application, gpointer user_data) { | 104 | +void startup(GtkApplication *app) { |
101 | 105 | ||
102 | static GActionEntry app_entries[] = { | 106 | static GActionEntry app_entries[] = { |
103 | { | 107 | { |
@@ -131,32 +135,30 @@ void startup(GtkApplication *application, gpointer user_data) { | @@ -131,32 +135,30 @@ void startup(GtkApplication *application, gpointer user_data) { | ||
131 | }; | 135 | }; |
132 | 136 | ||
133 | g_action_map_add_action_entries( | 137 | g_action_map_add_action_entries( |
134 | - G_ACTION_MAP(application), | 138 | + G_ACTION_MAP(app), |
135 | app_entries, | 139 | app_entries, |
136 | G_N_ELEMENTS(app_entries), | 140 | G_N_ELEMENTS(app_entries), |
137 | - application | 141 | + app |
138 | ); | 142 | ); |
139 | 143 | ||
140 | - GtkBuilder * builder = gtk_builder_new_from_file("application.ui"); | 144 | + GtkBuilder * builder = gtk_builder_new_from_file("application.xml"); |
141 | 145 | ||
142 | debug("Builder: %p",builder); | 146 | debug("Builder: %p",builder); |
143 | 147 | ||
144 | - GMenuModel * app_menu = G_MENU_MODEL(gtk_builder_get_object(builder, "app-menu")); | ||
145 | - debug("app-menu: %p", app_menu); | ||
146 | - gtk_application_set_app_menu(application, app_menu); | ||
147 | - | ||
148 | - | ||
149 | - // gtk_application_set_menubar(application, G_MENU_MODEL(gtk_builder_get_object(builder, "app-menubar"))); | 148 | + gtk_application_set_app_menu(GTK_APPLICATION (app), G_MENU_MODEL (gtk_builder_get_object (builder, "app-menu"))); |
149 | + gtk_application_set_menubar(GTK_APPLICATION (app), G_MENU_MODEL (gtk_builder_get_object (builder, "menubar"))); | ||
150 | 150 | ||
151 | g_object_unref(builder); | 151 | g_object_unref(builder); |
152 | + | ||
152 | } | 153 | } |
153 | 154 | ||
155 | + | ||
154 | int main (int argc, char **argv) { | 156 | int main (int argc, char **argv) { |
155 | 157 | ||
156 | GtkApplication *app; | 158 | GtkApplication *app; |
157 | int status; | 159 | int status; |
158 | 160 | ||
159 | - app = gtk_application_new ("br.com.bb.pw3270",G_APPLICATION_FLAGS_NONE); | 161 | + app = gtk_application_new("br.com.bb.pw3270",G_APPLICATION_HANDLES_OPEN); |
160 | 162 | ||
161 | g_signal_connect (app, "activate", G_CALLBACK(activate), NULL); | 163 | g_signal_connect (app, "activate", G_CALLBACK(activate), NULL); |
162 | g_signal_connect (app, "startup", G_CALLBACK(startup), NULL); | 164 | g_signal_connect (app, "startup", G_CALLBACK(startup), NULL); |