diff options
| author | Jan Djärv | 2010-07-29 18:49:59 +0200 |
|---|---|---|
| committer | Jan Djärv | 2010-07-29 18:49:59 +0200 |
| commit | bfeabdc3d7568d08491eb3eab7249bc6c2c24af3 (patch) | |
| tree | 8d91481669f60b8507911afe7182975c057d53fd /src/frame.c | |
| parent | 063e52940d4d97fe372f226c895d6d0f9d87f5d4 (diff) | |
| download | emacs-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.c | 10 |
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; | |||
| 119 | Lisp_Object Qtitle, Qname; | 119 | Lisp_Object Qtitle, Qname; |
| 120 | Lisp_Object Qexplicit_name; | 120 | Lisp_Object Qexplicit_name; |
| 121 | Lisp_Object Qunsplittable; | 121 | Lisp_Object Qunsplittable; |
| 122 | Lisp_Object Qmenu_bar_lines, Qtool_bar_lines; | 122 | Lisp_Object Qmenu_bar_lines, Qtool_bar_lines, Qtool_bar_position; |
| 123 | Lisp_Object Vmenu_bar_mode, Vtool_bar_mode; | 123 | Lisp_Object Vmenu_bar_mode, Vtool_bar_mode; |
| 124 | Lisp_Object Qleft_fringe, Qright_fringe; | 124 | Lisp_Object Qleft_fringe, Qright_fringe; |
| 125 | Lisp_Object Qbuffer_predicate, Qbuffer_list, Qburied_buffer_list; | 125 | Lisp_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 | |||
| 3441 | x_set_fringe_width (struct frame *f, Lisp_Object new_value, Lisp_Object old_value) | 3444 | x_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 | ||
| 3446 | void | 3454 | void |