aboutsummaryrefslogtreecommitdiffstats
path: root/src/frame.c
diff options
context:
space:
mode:
authorJan Djärv2010-07-29 18:49:59 +0200
committerJan Djärv2010-07-29 18:49:59 +0200
commitbfeabdc3d7568d08491eb3eab7249bc6c2c24af3 (patch)
tree8d91481669f60b8507911afe7182975c057d53fd /src/frame.c
parent063e52940d4d97fe372f226c895d6d0f9d87f5d4 (diff)
downloademacs-bfeabdc3d7568d08491eb3eab7249bc6c2c24af3.tar.gz
emacs-bfeabdc3d7568d08491eb3eab7249bc6c2c24af3.zip
Add ability to put Gtk+ tool bar on the left/right/bottom or top. Default top.
* lisp/menu-bar.el (menu-bar-showhide-tool-bar-menu-customize-enable-left) (menu-bar-showhide-tool-bar-menu-customize-disable) (menu-bar-showhide-tool-bar-menu-customize-enable-right) (menu-bar-showhide-tool-bar-menu-customize-enable-top) (menu-bar-showhide-tool-bar-menu-customize-enable-bottom): New functions (menu-bar-showhide-tool-bar-menu): If tool bar is moveable, make a menu for Options => toolbar that can move it. * src/frame.c (Qtool_bar_position): New variable. (make_frame): Set tool_bar_position to Qtop. (frame_parms): Add tool-bar-position. (x_report_frame_params): Store tool_bar_position. (x_set_fringe_width): Reset wm size hint after fringe changes. * src/frame.h (struct frame): Add tool_bar_position. (Qbottom): Declare. * src/gtkutil.c (FRAME_TOTAL_PIXEL_WIDTH): New macro. (xg_frame_set_char_size): Add FRAME_TOOLBAR_WIDTH to pixelwidth. (xg_height_or_width_changed): Use FRAME_TOTAL_PIXEL_WIDTH. (xg_create_frame_widgets): Create a hobox for placing widgets vertically. Use gtk_box_pack_start. (xg_height_or_width_changed): Renamed from xg_height_changed. (x_wm_set_size_hint): Add FRAME_TOOLBAR_WIDTH to base_width. (xg_update_frame_menubar, free_frame_menubar): Change to xg_height_or_width_changed. (xg_tool_bar_detach_callback): Update left/right/top/bottom tool bar size correctly. Remove hardcoded 4, instead use handlebox size - toolbar size. (xg_tool_bar_attach_callback): Update left/right/top/bottom tool bar size correctly. Use handlebox size + toolbar size as additional size. (xg_pack_tool_bar): POS is a new parameter. Set orientation of tool bar based on pos. Only make handlebox_widget if NULL. Check if tool bar goes to vbox or hbox depending on pos. (xg_update_tool_bar_sizes): New function. (update_frame_tool_bar): Remove old_req, new_req. Do not get tool bar height, call xg_update_tool_bar_sizes instead. (free_frame_tool_bar): Remove from hbox or vbox depending on toolbar_in_hbox, Set all FRAME_TOOLBAR_*_(WIDTH|HEIGHT) to zero. (xg_change_toolbar_position): New function. * src/gtkutil.h (xg_change_toolbar_position): Declare. * src/window.c (calc_absolute_offset): Check for FRAME_TOOLBAR_TOP_HEIGHT and FRAME_TOOLBAR_LEFT_WIDTH. * src/xfns.c (x_set_tool_bar_position): New function. (xic_set_statusarea): Use FRAME_TOOLBAR_TOP_HEIGHT. (x_frame_parm_handlers): Add x_set_tool_bar_position. (syms_of_xfns): if USE_GTK, provide move-toolbar. * src/xterm.c (x_set_window_size_1): Add FRAME_TOOLBAR_WIDTH to pixelwidth. * src/xterm.h (struct x_output): Add toolbar_top_height, toolbar_bottom_height, toolbar_left_width, toolbar_right_width. Remove toolbar_height. if USE_GTK: Add hbox_widget and toolbar_in_hbox. (FRAME_TOOLBAR_TOP_HEIGHT, FRAME_TOOLBAR_BOTTOM_HEIGHT) (FRAME_TOOLBAR_LEFT_WIDTH, FRAME_TOOLBAR_RIGHT_WIDTH): New macros. (FRAME_TOOLBAR_HEIGHT): Is now TOP_HEIGHT + BOTTOM_HEIGHT.
Diffstat (limited to 'src/frame.c')
-rw-r--r--src/frame.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/frame.c b/src/frame.c
index ae8fdff807d..809f660f1d9 100644
--- a/src/frame.c
+++ b/src/frame.c
@@ -119,7 +119,7 @@ Lisp_Object Qparent_id;
119Lisp_Object Qtitle, Qname; 119Lisp_Object Qtitle, Qname;
120Lisp_Object Qexplicit_name; 120Lisp_Object Qexplicit_name;
121Lisp_Object Qunsplittable; 121Lisp_Object Qunsplittable;
122Lisp_Object Qmenu_bar_lines, Qtool_bar_lines; 122Lisp_Object Qmenu_bar_lines, Qtool_bar_lines, Qtool_bar_position;
123Lisp_Object Vmenu_bar_mode, Vtool_bar_mode; 123Lisp_Object Vmenu_bar_mode, Vtool_bar_mode;
124Lisp_Object Qleft_fringe, Qright_fringe; 124Lisp_Object Qleft_fringe, Qright_fringe;
125Lisp_Object Qbuffer_predicate, Qbuffer_list, Qburied_buffer_list; 125Lisp_Object Qbuffer_predicate, Qbuffer_list, Qburied_buffer_list;
@@ -323,6 +323,7 @@ make_frame (int mini_p)
323 f->menu_bar_window = Qnil; 323 f->menu_bar_window = Qnil;
324 f->tool_bar_window = Qnil; 324 f->tool_bar_window = Qnil;
325 f->tool_bar_items = Qnil; 325 f->tool_bar_items = Qnil;
326 f->tool_bar_position = Qtop;
326 f->desired_tool_bar_string = f->current_tool_bar_string = Qnil; 327 f->desired_tool_bar_string = f->current_tool_bar_string = Qnil;
327 f->n_tool_bar_items = 0; 328 f->n_tool_bar_items = 0;
328 f->left_fringe_width = f->right_fringe_width = 0; 329 f->left_fringe_width = f->right_fringe_width = 0;
@@ -2816,6 +2817,7 @@ static struct frame_parm_table frame_parms[] =
2816 {"font-backend", &Qfont_backend}, 2817 {"font-backend", &Qfont_backend},
2817 {"alpha", &Qalpha}, 2818 {"alpha", &Qalpha},
2818 {"sticky", &Qsticky}, 2819 {"sticky", &Qsticky},
2820 {"tool-bar-position", &Qtool_bar_position},
2819}; 2821};
2820 2822
2821#ifdef HAVE_WINDOW_SYSTEM 2823#ifdef HAVE_WINDOW_SYSTEM
@@ -3209,6 +3211,7 @@ x_report_frame_params (struct frame *f, Lisp_Object *alistptr)
3209 XSETFASTINT (tem, FRAME_X_OUTPUT (f)->parent_desc); 3211 XSETFASTINT (tem, FRAME_X_OUTPUT (f)->parent_desc);
3210 store_in_alist (alistptr, Qexplicit_name, (f->explicit_name ? Qt : Qnil)); 3212 store_in_alist (alistptr, Qexplicit_name, (f->explicit_name ? Qt : Qnil));
3211 store_in_alist (alistptr, Qparent_id, tem); 3213 store_in_alist (alistptr, Qparent_id, tem);
3214 store_in_alist (alistptr, Qtool_bar_position, f->tool_bar_position);
3212} 3215}
3213 3216
3214 3217
@@ -3441,6 +3444,11 @@ void
3441x_set_fringe_width (struct frame *f, Lisp_Object new_value, Lisp_Object old_value) 3444x_set_fringe_width (struct frame *f, Lisp_Object new_value, Lisp_Object old_value)
3442{ 3445{
3443 compute_fringe_widths (f, 1); 3446 compute_fringe_widths (f, 1);
3447#ifdef HAVE_X_WINDOWS
3448 /* Must adjust this so window managers report correct number of columns. */
3449 if (FRAME_X_WINDOW (f) != 0)
3450 x_wm_set_size_hint (f, 0, 0);
3451#endif
3444} 3452}
3445 3453
3446void 3454void