File: menu_utils.h

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (51 lines) | stat: -rw-r--r-- 1,711 bytes parent folder | download | duplicates (9)
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
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef UI_BASE_COCOA_MENU_UTILS_H_
#define UI_BASE_COCOA_MENU_UTILS_H_

#include <Foundation/Foundation.h>

#include "base/component_export.h"
#include "ui/base/interaction/element_identifier.h"

@class NSEvent;
@class NSMenu;
@class NSView;
@class NSWindow;

namespace gfx {
class Point;
}

namespace ui {

// Returns an appropriate event (with a location) suitable for showing a context
// menu. Uses [NSApp currentEvent] if it's a non-nil mouse click event,
// otherwise creates an autoreleased dummy event located at `anchor`, where
// `anchor` is in screen coordinates.
COMPONENT_EXPORT(UI_BASE)
NSEvent* EventForPositioningContextMenu(const gfx::Point& anchor,
                                        NSWindow* window);

// Same as above, but `position` is in window coordinates relative to `window`
// instead.
COMPONENT_EXPORT(UI_BASE)
NSEvent* EventForPositioningContextMenuRelativeToWindow(const NSPoint& position,
                                                        NSWindow* window);

// Pops up `menu` using `event`, targeting `view`. If `allow_nested_tasks` is
// true, tasks (such as IPCs) will be allowed to execute while the menu is being
// displayed. If specified, `context` is used to inform ElementTrackerMac of the
// menu being shown.
COMPONENT_EXPORT(UI_BASE)
void ShowContextMenu(NSMenu* menu,
                     NSEvent* event,
                     NSView* view,
                     bool allow_nested_tasks,
                     ElementContext context = ElementContext());

}  // namespace ui

#endif  // UI_BASE_COCOA_MENU_UTILS_H_