Add createwindow() for GtkWindow creation
Move there window creation from showview().
This commit is contained in:
parent
2e1fb87361
commit
bb1fc4195f
1 changed files with 37 additions and 27 deletions
64
surf.c
64
surf.c
|
@ -161,6 +161,7 @@ static Client *newclient(Client *c);
|
||||||
static WebKitWebView *newview(Client *c, WebKitWebView *rv);
|
static WebKitWebView *newview(Client *c, WebKitWebView *rv);
|
||||||
static void showview(WebKitWebView *v, Client *c);
|
static void showview(WebKitWebView *v, Client *c);
|
||||||
static void newwindow(Client *c, const Arg *arg, gboolean noembed);
|
static void newwindow(Client *c, const Arg *arg, gboolean noembed);
|
||||||
|
static GtkWidget *createwindow(Client *c);
|
||||||
static void pasteuri(GtkClipboard *clipboard, const char *text, gpointer d);
|
static void pasteuri(GtkClipboard *clipboard, const char *text, gpointer d);
|
||||||
static void print(Client *c, const Arg *arg);
|
static void print(Client *c, const Arg *arg);
|
||||||
static GdkFilterReturn processx(GdkXEvent *xevent, GdkEvent *event,
|
static GdkFilterReturn processx(GdkXEvent *xevent, GdkEvent *event,
|
||||||
|
@ -1017,33 +1018,7 @@ showview(WebKitWebView *v, Client *c)
|
||||||
GdkRGBA bgcolor = { 0 };
|
GdkRGBA bgcolor = { 0 };
|
||||||
GdkWindow *gwin;
|
GdkWindow *gwin;
|
||||||
|
|
||||||
/* Window */
|
c->win = createwindow(c);
|
||||||
if (embed) {
|
|
||||||
c->win = gtk_plug_new(embed);
|
|
||||||
} else {
|
|
||||||
c->win = gtk_window_new(GTK_WINDOW_TOPLEVEL);
|
|
||||||
|
|
||||||
/* TA: 20091214: Despite what the GNOME docs say, the ICCCM
|
|
||||||
* is always correct, so we should still call this function.
|
|
||||||
* But when doing so, we *must* differentiate between a
|
|
||||||
* WM_CLASS and a resource on the window. By convention, the
|
|
||||||
* window class (WM_CLASS) is capped, while the resource is in
|
|
||||||
* lowercase. Both these values come as a pair.
|
|
||||||
*/
|
|
||||||
gtk_window_set_wmclass(GTK_WINDOW(c->win), "surf", "Surf");
|
|
||||||
|
|
||||||
/* TA: 20091214: And set the role here as well -- so that
|
|
||||||
* sessions can pick this up.
|
|
||||||
*/
|
|
||||||
gtk_window_set_role(GTK_WINDOW(c->win), "Surf");
|
|
||||||
}
|
|
||||||
gtk_window_set_default_size(GTK_WINDOW(c->win), 800, 600);
|
|
||||||
g_signal_connect(G_OBJECT(c->win),
|
|
||||||
"destroy",
|
|
||||||
G_CALLBACK(destroywin), c);
|
|
||||||
g_signal_connect(G_OBJECT(c->win),
|
|
||||||
"leave_notify_event",
|
|
||||||
G_CALLBACK(titlechangeleave), c);
|
|
||||||
|
|
||||||
if (!kioskmode)
|
if (!kioskmode)
|
||||||
addaccelgroup(c);
|
addaccelgroup(c);
|
||||||
|
@ -1128,6 +1103,41 @@ newwindow(Client *c, const Arg *arg, gboolean noembed)
|
||||||
spawn(NULL, &a);
|
spawn(NULL, &a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GtkWidget *
|
||||||
|
createwindow(Client *c)
|
||||||
|
{
|
||||||
|
GtkWidget *w;
|
||||||
|
|
||||||
|
if (embed) {
|
||||||
|
w = gtk_plug_new(embed);
|
||||||
|
} else {
|
||||||
|
w = gtk_window_new(GTK_WINDOW_TOPLEVEL);
|
||||||
|
|
||||||
|
/* TA: 20091214: Despite what the GNOME docs say, the ICCCM
|
||||||
|
* is always correct, so we should still call this function.
|
||||||
|
* But when doing so, we *must* differentiate between a
|
||||||
|
* WM_CLASS and a resource on the window. By convention, the
|
||||||
|
* window class (WM_CLASS) is capped, while the resource is in
|
||||||
|
* lowercase. Both these values come as a pair.
|
||||||
|
*/
|
||||||
|
gtk_window_set_wmclass(GTK_WINDOW(w), "surf", "Surf");
|
||||||
|
|
||||||
|
/* TA: 20091214: And set the role here as well -- so that
|
||||||
|
* sessions can pick this up.
|
||||||
|
*/
|
||||||
|
gtk_window_set_role(GTK_WINDOW(w), "Surf");
|
||||||
|
|
||||||
|
gtk_window_set_default_size(GTK_WINDOW(w), 800, 600);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_signal_connect(G_OBJECT(w), "destroy",
|
||||||
|
G_CALLBACK(destroywin), c);
|
||||||
|
g_signal_connect(G_OBJECT(w), "leave_notify_event",
|
||||||
|
G_CALLBACK(titlechangeleave), c);
|
||||||
|
|
||||||
|
return w;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
pasteuri(GtkClipboard *clipboard, const char *text, gpointer d)
|
pasteuri(GtkClipboard *clipboard, const char *text, gpointer d)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue