/usr/include/cairo-dock/gldit/cairo-dock-menu.h is in libgldi-dev 3.4.1-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 | /*
* This file is a part of the Cairo-Dock project
*
* Copyright : (C) see the 'copyright' file.
* E-mail : see the 'copyright' file.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 3
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __GLDI_MENU__
#define __GLDI_MENU__
#include "cairo-dock-struct.h"
G_BEGIN_DECLS
/**
*@file cairo-dock-menu.h This class defines the Menu. They are classical menus, but with a custom looking.
*/
struct _GldiMenuParams {
Icon *pIcon;
gint iMarginPosition;
gint iAimedX, iAimedY;
gdouble fAlign;
gint iRadius; // actually it's more an horizontal padding/offset
gint iArrowHeight;
GtkCssProvider *cssProvider; // a css to define the margins of the menu
};
typedef struct _GldiMenuParams GldiMenuParams;
struct _GldiMenuItemParams {
guint iSidAnimation;
gint iStep;
gboolean bInside;
};
void _init_menu_style (void);
/** Creates a new menu that will point on a given Icon. If the Icon is NULL, it will be placed under the mouse.
* @param pIcon the icon, or NULL
* @return the new menu.
*/
GtkWidget *gldi_menu_new (Icon *pIcon);
/** Creates a new sub-menu. It's just a menu that doesn't point on an Icon/Container.
*/
#define gldi_submenu_new(...) gldi_menu_new (NULL)
/** Initialize a menu, so that it can be drawn and placed correctly.
* It's useful if the menu was created beforehand (like a DbusMenu).
* @param pIcon the icon, or NULL
*/
void gldi_menu_init (GtkWidget *pMenu, Icon *pIcon);
/** Pop-up a menu. The menu is placed above the icon, or above the container, or above the mouse, depending on how it has been initialized.
*@param menu the menu.
*/
void gldi_menu_popup (GtkWidget *menu);
/** Creates a menu-item, with a label and an image. The child widget of the menu-item is a gtk-label.
* If the label is NULL, the child widget will be NULL too (this is useful if the menu-item will hold a custom widget).
* @param cLabel the label, or NULL
* @param cImage the image path or name, or NULL
* @param bUseMnemonic whether to use the mnemonic inside the label or not
* @param iSize size of the image, or 0 to use the default size
* @return the new menu-item.
*/
GtkWidget *gldi_menu_item_new_full (const gchar *cLabel, const gchar *cImage, gboolean bUseMnemonic, GtkIconSize iSize);
/** A convenient function to create a menu-item with a label and an image.
* @param cLabel the label, or NULL
* @param cImage the image path or name, or NULL
* @return the new menu-item.
*/
#define gldi_menu_item_new(cLabel, cImage) gldi_menu_item_new_full (cLabel, cImage, FALSE, 0)
/** A convenient function to create a menu-item with a label, an image, and an associated action.
* @param cLabel the label, or NULL
* @param cImage the image path or name, or NULL
* @param pFunction the callback
* @param pData the data passed to the callback
* @return the new menu-item.
*/
GtkWidget *gldi_menu_item_new_with_action (const gchar *cLabel, const gchar *cImage, GCallback pFunction, gpointer pData);
/** A convenient function to create a menu-item with a label, an image, and an associated sub-menu.
* @param cLabel the label
* @param cImage the image path or name, or NULL
* @param pSubMenuPtr pointer that will contain the new sub-menu, or NULL
* @return the new menu-item.
*/
GtkWidget *gldi_menu_item_new_with_submenu (const gchar *cLabel, const gchar *cImage, GtkWidget **pSubMenuPtr);
/** Sets a gtk-image on a menu-item. This is useful if the image can't be given by a name or path (for instance, loaded from a cairo surface).
* @param pMenuItem the menu-item
* @param image the image
*/
void gldi_menu_item_set_image (GtkWidget *pMenuItem, GtkWidget *image);
/** Gets the image of a menu-item.
* @param pMenuItem the menu-item
* @return the gtk-image
*/
GtkWidget *gldi_menu_item_get_image (GtkWidget *pMenuItem);
/** A convenient function to add an item to a given menu.
* @param pMenu the menu
* @param cLabel the label, or NULL
* @param cImage the image path or name, or NULL
* @param pFunction the callback
* @param pData the data passed to the callback
* @return the new menu-entry that has been added.
*/
GtkWidget *gldi_menu_add_item (GtkWidget *pMenu, const gchar *cLabel, const gchar *cImage, GCallback pFunction, gpointer pData);
#define cairo_dock_add_in_menu_with_stock_and_data(cLabel, gtkStock, pFunction, pMenu, pData) gldi_menu_add_item (pMenu, cLabel, gtkStock, pFunction, pData)
/** A convenient function to add a sub-menu to a given menu.
* @param pMenu the menu
* @param cLabel the label, or NULL
* @param cImage the image path or name, or NULL
* @param pMenuItemPtr pointer that will contain the new menu-item, or NULL
* @return the new sub-menu that has been added.
*/
GtkWidget *gldi_menu_add_sub_menu_full (GtkWidget *pMenu, const gchar *cLabel, const gchar *cImage, GtkWidget **pMenuItemPtr);
/** A convenient function to add a sub-menu to a given menu.
* @param pMenu the menu
* @param cLabel the label, or NULL
* @param cImage the image path or name, or NULL
* @return the new sub-menu that has been added.
*/
#define gldi_menu_add_sub_menu(pMenu, cLabel, cImage) gldi_menu_add_sub_menu_full (pMenu, cLabel, cImage, NULL)
#define cairo_dock_create_sub_menu(cLabel, pMenu, cImage) gldi_menu_add_sub_menu (pMenu, cLabel, cImage)
/** A convenient function to add a separator to a given menu.
* @param pMenu the menu
*/
void gldi_menu_add_separator (GtkWidget *pMenu);
gboolean GLDI_IS_IMAGE_MENU_ITEM (GtkWidget *pMenuItem);
G_END_DECLS
#endif
|