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/xterm.h | |
| 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/xterm.h')
| -rw-r--r-- | src/xterm.h | 26 |
1 files changed, 22 insertions, 4 deletions
diff --git a/src/xterm.h b/src/xterm.h index cfc786632e5..c487ae4bd63 100644 --- a/src/xterm.h +++ b/src/xterm.h | |||
| @@ -433,9 +433,15 @@ struct x_output | |||
| 433 | if the menubar is turned off. */ | 433 | if the menubar is turned off. */ |
| 434 | int menubar_height; | 434 | int menubar_height; |
| 435 | 435 | ||
| 436 | /* Height of tool bar widget, in pixels. | 436 | /* Height of tool bar widget, in pixels. top_height is used if tool bar |
| 437 | Zero if not using an external tool bar. */ | 437 | at top, bottom_height if tool bar is at the bottom. |
| 438 | int toolbar_height; | 438 | Zero if not using an external tool bar or if tool bar is vertical. */ |
| 439 | int toolbar_top_height, toolbar_bottom_height; | ||
| 440 | |||
| 441 | /* Width of tool bar widget, in pixels. left_width is used if tool bar | ||
| 442 | at left, right_width if tool bar is at the right. | ||
| 443 | Zero if not using an external tool bar or if tool bar is horizontal. */ | ||
| 444 | int toolbar_left_width, toolbar_right_width; | ||
| 439 | 445 | ||
| 440 | /* The tiled border used when the mouse is out of the frame. */ | 446 | /* The tiled border used when the mouse is out of the frame. */ |
| 441 | Pixmap border_tile; | 447 | Pixmap border_tile; |
| @@ -480,6 +486,8 @@ struct x_output | |||
| 480 | GtkWidget *edit_widget; | 486 | GtkWidget *edit_widget; |
| 481 | /* The widget used for laying out widgets vertically. */ | 487 | /* The widget used for laying out widgets vertically. */ |
| 482 | GtkWidget *vbox_widget; | 488 | GtkWidget *vbox_widget; |
| 489 | /* The widget used for laying out widgets horizontally. */ | ||
| 490 | GtkWidget *hbox_widget; | ||
| 483 | /* The menubar in this frame. */ | 491 | /* The menubar in this frame. */ |
| 484 | GtkWidget *menubar_widget; | 492 | GtkWidget *menubar_widget; |
| 485 | /* The tool bar in this frame */ | 493 | /* The tool bar in this frame */ |
| @@ -488,6 +496,8 @@ struct x_output | |||
| 488 | GtkWidget *handlebox_widget; | 496 | GtkWidget *handlebox_widget; |
| 489 | /* Non-zero if the tool bar is detached. */ | 497 | /* Non-zero if the tool bar is detached. */ |
| 490 | int toolbar_detached; | 498 | int toolbar_detached; |
| 499 | /* Non-zero if tool bar is packed into the hbox widget (i.e. vertical). */ | ||
| 500 | int toolbar_in_hbox; | ||
| 491 | 501 | ||
| 492 | /* The last size hints set. */ | 502 | /* The last size hints set. */ |
| 493 | GdkGeometry size_hints; | 503 | GdkGeometry size_hints; |
| @@ -700,7 +710,15 @@ enum | |||
| 700 | #define FRAME_FONT(f) ((f)->output_data.x->font) | 710 | #define FRAME_FONT(f) ((f)->output_data.x->font) |
| 701 | #define FRAME_FONTSET(f) ((f)->output_data.x->fontset) | 711 | #define FRAME_FONTSET(f) ((f)->output_data.x->fontset) |
| 702 | #define FRAME_MENUBAR_HEIGHT(f) ((f)->output_data.x->menubar_height) | 712 | #define FRAME_MENUBAR_HEIGHT(f) ((f)->output_data.x->menubar_height) |
| 703 | #define FRAME_TOOLBAR_HEIGHT(f) ((f)->output_data.x->toolbar_height) | 713 | #define FRAME_TOOLBAR_TOP_HEIGHT(f) ((f)->output_data.x->toolbar_top_height) |
| 714 | #define FRAME_TOOLBAR_BOTTOM_HEIGHT(f) \ | ||
| 715 | ((f)->output_data.x->toolbar_bottom_height) | ||
| 716 | #define FRAME_TOOLBAR_HEIGHT(f) \ | ||
| 717 | (FRAME_TOOLBAR_TOP_HEIGHT (f) + FRAME_TOOLBAR_BOTTOM_HEIGHT (f)) | ||
| 718 | #define FRAME_TOOLBAR_LEFT_WIDTH(f) ((f)->output_data.x->toolbar_left_width) | ||
| 719 | #define FRAME_TOOLBAR_RIGHT_WIDTH(f) ((f)->output_data.x->toolbar_right_width) | ||
| 720 | #define FRAME_TOOLBAR_WIDTH(f) \ | ||
| 721 | (FRAME_TOOLBAR_LEFT_WIDTH (f) + FRAME_TOOLBAR_RIGHT_WIDTH (f)) | ||
| 704 | #define FRAME_BASELINE_OFFSET(f) ((f)->output_data.x->baseline_offset) | 722 | #define FRAME_BASELINE_OFFSET(f) ((f)->output_data.x->baseline_offset) |
| 705 | 723 | ||
| 706 | /* This gives the x_display_info structure for the display F is on. */ | 724 | /* This gives the x_display_info structure for the display F is on. */ |