aboutsummaryrefslogtreecommitdiffstats
path: root/src/xterm.h
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/xterm.h
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/xterm.h')
-rw-r--r--src/xterm.h26
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. */