/**************************************************************************** ** ** Copyright (C) 2022 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtWidgets module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:COMM$ ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** $QT_END_LICENSE$ ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ******************************************************************************/ #include "qaction.h" #include #include #include "qaction_widgets_p.h" #if QT_CONFIG(menu) #include #endif #if QT_CONFIG(graphicsview) #include "qgraphicswidget.h" #endif QT_BEGIN_NAMESPACE QActionPrivate *QApplicationPrivate::createActionPrivate() const { return new QtWidgetsActionPrivate; } QtWidgetsActionPrivate::~QtWidgetsActionPrivate() = default; // we can't do this in the destructor, as it would only be called by ~QObject void QtWidgetsActionPrivate::destroy() { Q_Q(QAction); const auto objects = associatedObjects; for (int i = objects.size()-1; i >= 0; --i) { QObject *object = objects.at(i); if (QWidget *widget = qobject_cast(object)) widget->removeAction(q); #if QT_CONFIG(graphicsview) else if (QGraphicsWidget *graphicsWidget = qobject_cast(object)) graphicsWidget->removeAction(q); #endif } } #if QT_CONFIG(shortcut) QShortcutMap::ContextMatcher QtWidgetsActionPrivate::contextMatcher() const { return qWidgetShortcutContextMatcher; } #endif #if QT_CONFIG(menu) QObject *QtWidgetsActionPrivate::menu() const { return m_menu; } void QtWidgetsActionPrivate::setMenu(QObject *menu) { Q_Q(QAction); QMenu *theMenu = qobject_cast(menu); Q_ASSERT_X(!menu || theMenu, "QAction::setMenu", "QAction::setMenu expects a QMenu* in widget applications"); if (m_menu) m_menu->d_func()->setOverrideMenuAction(nullptr); //we reset the default action of any previous menu m_menu = theMenu; if (m_menu) m_menu->d_func()->setOverrideMenuAction(q); sendDataChanged(); } #endif // QT_CONFIG(menu) QT_END_NAMESPACE