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
|
// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_GTK_STANDARD_MENUS_H_
#define CHROME_BROWSER_GTK_STANDARD_MENUS_H_
#include "chrome/browser/gtk/menu_gtk.h"
class Menu;
class Profile;
enum MenuItemType {
MENU_NORMAL = 0,
MENU_CHECKBOX,
MENU_SEPARATOR,
MENU_RADIO,
// Speical value to stop processing this MenuCreateMaterial.
MENU_END
};
struct MenuCreateMaterial {
// This menu item type
MenuItemType type;
// The command id (an IDC_* value)
unsigned int id;
// The label id (an IDS_* value)
unsigned int label_id;
// An argument to GetStringF(menu_label_id, ...). When 0, the value of
// label_id is just passed to GetString(). If both are 0, the menu delegate
// is responsible for implementing GetLabel().
unsigned int label_argument;
// If non-NULL, a pointer to the struct we're supposed to use
MenuCreateMaterial* submenu;
// A gdk keysym that is used to activate this item from outside the menu.
unsigned int accel_key;
// GDK modifiers for the menu items (i.e., shift, ctrl, etc).
unsigned int accel_modifiers;
// If non-NULL, specifies a custom submenu to be used. MenuGtk will take
// ownership of this submenu.
MenuGtk* custom_submenu;
};
// Returns the menu construction data structure for the page menu.
// The parameters are used to construct the encodings menu.
const MenuCreateMaterial* GetStandardPageMenu(Profile* profile,
MenuGtk::Delegate* delegate);
// Returns the menu construction data structure for the app menu.
const MenuCreateMaterial* GetStandardAppMenu();
#endif // CHROME_BROWSER_GTK_STANDARD_MENUS_H_
|