From e18e244dd7f352817116cfdc8720d684d55679ee Mon Sep 17 00:00:00 2001 From: Stephan Bergmann Date: Mon, 18 Nov 2019 23:10:28 +0100 Subject: Improved loplugin:external, handling class types ...plus follow-up loplugin:fakebool and renaming the non-external (moved to unnamed namespace) three-parameter load_icon_by_name overload to load_icon_by_name_theme_lang, because it would otherwise hide the one-parameter load_icon_by_name Change-Id: Ie01151c1b4648bd797cc455ec092281448ed4637 Reviewed-on: https://gerrit.libreoffice.org/83134 Tested-by: Jenkins Reviewed-by: Stephan Bergmann --- vcl/unx/gtk3/gtk3gtkinst.cxx | 98 ++++++++++++++++++++++++++++++-------------- 1 file changed, 67 insertions(+), 31 deletions(-) diff --git a/vcl/unx/gtk3/gtk3gtkinst.cxx b/vcl/unx/gtk3/gtk3gtkinst.cxx index 398a194230b6..61ba40b9fa1c 100644 --- a/vcl/unx/gtk3/gtk3gtkinst.cxx +++ b/vcl/unx/gtk3/gtk3gtkinst.cxx @@ -605,6 +605,8 @@ sal_Bool SAL_CALL GtkTransferable::isDataFlavorSupported(const css::datatransfer return std::any_of(aAll.begin(), aAll.end(), DataFlavorEq(rFlavor)); } +namespace { + class GtkClipboardTransferable : public GtkTransferable { private: @@ -739,6 +741,8 @@ public: void OwnerPossiblyChanged(GtkClipboard *clipboard); }; +} + OUString VclGtkClipboard::getImplementationName() { return "com.sun.star.datatransfer.VclGtkClipboard"; @@ -1338,6 +1342,8 @@ Reference< XInterface > GtkInstance::CreateDragSource() return Reference< XInterface >( static_cast(new GtkDragSource()) ); } +namespace { + class GtkOpenGLContext : public OpenGLContext { GLWindow m_aGLWin; @@ -1598,6 +1604,8 @@ private: } }; +} + OpenGLContext* GtkInstance::CreateOpenGLContext() { return new GtkOpenGLContext; @@ -1620,10 +1628,11 @@ bool DLSYM_GDK_IS_X11_DISPLAY(GdkDisplay* pDisplay) return G_TYPE_CHECK_INSTANCE_TYPE(pDisplay, get_type()); } -class GtkInstanceBuilder; - namespace { + +class GtkInstanceBuilder; + void set_help_id(const GtkWidget *pWidget, const OString& rHelpId) { gchar *helpid = g_strdup(rHelpId.getStr()); @@ -1778,6 +1787,8 @@ namespace } } +namespace { + class GtkInstanceWidget : public virtual weld::Widget { protected: @@ -2609,7 +2620,7 @@ public: m_aSizeAllocateHdl.Call(Size(nWidth, nHeight)); } - gboolean signal_key(const GdkEventKey* pEvent) + bool signal_key(const GdkEventKey* pEvent) { if (pEvent->type == GDK_KEY_PRESS && m_aKeyPressHdl.IsSet()) { @@ -2790,6 +2801,8 @@ public: } }; +} + IMPL_LINK_NOARG(GtkInstanceWidget, async_signal_focus_in, void*, void) { m_pFocusInEvent = nullptr; @@ -2886,7 +2899,7 @@ namespace return pixbuf; } - GdkPixbuf* load_icon_by_name(const OUString& rIconName, const OUString& rIconTheme, const OUString& rUILang) + GdkPixbuf* load_icon_by_name_theme_lang(const OUString& rIconName, const OUString& rIconTheme, const OUString& rUILang) { auto xMemStm = ImageTree::get().getImageStream(rIconName, rIconTheme, rUILang); if (!xMemStm) @@ -2899,7 +2912,7 @@ GdkPixbuf* load_icon_by_name(const OUString& rIconName) { OUString sIconTheme = Application::GetSettings().GetStyleSettings().DetermineIconTheme(); OUString sUILang = Application::GetSettings().GetUILanguageTag().getBcp47(); - return load_icon_by_name(rIconName, sIconTheme, sUILang); + return load_icon_by_name_theme_lang(rIconName, sIconTheme, sUILang); } namespace @@ -2973,7 +2986,6 @@ namespace } return pImage; } -} class MenuHelper { @@ -3212,8 +3224,6 @@ public: } }; -namespace -{ class ChildFrame : public WorkWindow { public: @@ -3228,7 +3238,6 @@ namespace pChild->SetPosSizePixel(Point(0, 0), GetSizePixel()); } }; -} class GtkInstanceContainer : public GtkInstanceWidget, public virtual weld::Container { @@ -3302,6 +3311,8 @@ public: } }; +} + std::unique_ptr GtkInstanceWidget::weld_parent() const { GtkWidget* pParent = gtk_widget_get_parent(m_pWidget); @@ -3310,6 +3321,8 @@ std::unique_ptr GtkInstanceWidget::weld_parent() const return std::make_unique(GTK_CONTAINER(pParent), m_pBuilder, false); } +namespace { + class GtkInstanceBox : public GtkInstanceContainer, public virtual weld::Box { private: @@ -3331,8 +3344,6 @@ public: } }; -namespace -{ void set_cursor(GtkWidget* pWidget, const char *pName) { if (!gtk_widget_get_realized(pWidget)) @@ -3466,7 +3477,6 @@ namespace if (GTK_IS_CONTAINER(pItem)) gtk_container_forall(GTK_CONTAINER(pItem), do_collect_screenshot_data, data); } -} class GtkInstanceWindow : public GtkInstanceContainer, public virtual weld::Window { @@ -3882,6 +3892,8 @@ struct DialogRunner } }; +} + typedef std::set winset; namespace @@ -3908,7 +3920,6 @@ namespace } g_list_free(pChildren); } -} class GtkInstanceButton; @@ -4318,6 +4329,8 @@ public: } }; +} + void DialogRunner::signal_response(GtkDialog*, gint nResponseId, gpointer data) { DialogRunner* pThis = static_cast(data); @@ -4341,6 +4354,8 @@ void DialogRunner::signal_cancel(GtkAssistant*, gpointer data) pThis->m_pInstance->close(false); } +namespace { + class GtkInstanceMessageDialog : public GtkInstanceDialog, public virtual weld::MessageDialog { private: @@ -4818,6 +4833,8 @@ public: virtual std::unique_ptr weld_label_widget() const override; }; +} + static GType crippled_viewport_get_type(); #define CRIPPLED_TYPE_VIEWPORT (crippled_viewport_get_type ()) @@ -4826,6 +4843,8 @@ static GType crippled_viewport_get_type(); # define CRIPPLED_IS_VIEWPORT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CRIPPLED_TYPE_VIEWPORT)) #endif +namespace { + struct CrippledViewport { GtkViewport viewport; @@ -4834,6 +4853,8 @@ struct CrippledViewport GtkAdjustment *vadjustment; }; +} + enum { PROP_0, @@ -5068,6 +5089,8 @@ static GtkSelectionMode VclToGtk(SelectionMode eType) return eRet; } +namespace { + class GtkInstanceScrolledWindow final : public GtkInstanceContainer, public virtual weld::ScrolledWindow { private: @@ -6130,6 +6153,8 @@ public: } }; +} + void GtkInstanceDialog::asyncresponse(gint ret) { if (ret == GTK_RESPONSE_HELP) @@ -6260,6 +6285,8 @@ GtkInstanceButton* GtkInstanceDialog::has_click_handler(int nResponse) return pButton; } +namespace { + class GtkInstanceToggleButton : public GtkInstanceButton, public virtual weld::ToggleButton { private: @@ -6916,8 +6943,6 @@ public: } }; -namespace -{ vcl::ImageType GtkToVcl(GtkIconSize eSize) { vcl::ImageType eRet; @@ -6952,6 +6977,8 @@ void GtkInstanceMenuButton::set_menu(weld::Menu* pMenu) gtk_menu_button_set_popup(m_pMenuButton, pMenuWidget); } +namespace { + class GtkInstanceToolbar : public GtkInstanceWidget, public virtual weld::Toolbar { private: @@ -7457,8 +7484,6 @@ public: } }; -namespace -{ PangoAttrList* create_attr_list(const vcl::Font& rFont) { PangoAttrList* pAttrList = pango_attr_list_new(); @@ -7545,7 +7570,6 @@ namespace else gtk_entry_set_icon_from_icon_name(pEntry, GTK_ENTRY_ICON_SECONDARY, nullptr); } -} class GtkInstanceEntry : public GtkInstanceWidget, public virtual weld::Entry { @@ -7761,8 +7785,6 @@ public: } }; -namespace -{ struct Search { OString str; @@ -7812,7 +7834,7 @@ namespace else { const AllSettings& rSettings = Application::GetSettings(); - pixbuf = load_icon_by_name(rIconName, + pixbuf = load_icon_by_name_theme_lang(rIconName, rSettings.GetStyleSettings().DetermineIconTheme(), rSettings.GetUILanguageTag().getBcp47()); } @@ -7911,7 +7933,6 @@ namespace return -1; } -} struct GtkInstanceTreeIter : public weld::TreeIter { @@ -7935,8 +7956,12 @@ struct GtkInstanceTreeIter : public weld::TreeIter class GtkInstanceTreeView; +} + static GtkInstanceTreeView* g_DragSource; +namespace { + class GtkInstanceTreeView : public GtkInstanceContainer, public virtual weld::TreeView { private: @@ -9855,6 +9880,8 @@ public: } }; +} + IMPL_LINK_NOARG(GtkInstanceTreeView, async_signal_changed, void*, void) { m_pChangeEvent = nullptr; @@ -9866,6 +9893,8 @@ IMPL_LINK_NOARG(GtkInstanceTreeView, async_stop_cell_editing, void*, void) end_editing(); } +namespace { + class GtkInstanceIconView : public GtkInstanceContainer, public virtual weld::IconView { private: @@ -10225,12 +10254,16 @@ public: } }; +} + IMPL_LINK_NOARG(GtkInstanceIconView, async_signal_selection_changed, void*, void) { m_pSelectionChangeEvent = nullptr; signal_selection_changed(); } +namespace { + class GtkInstanceSpinButton : public GtkInstanceEntry, public virtual weld::SpinButton { private: @@ -10630,6 +10663,8 @@ public: } }; +} + std::unique_ptr GtkInstanceFrame::weld_label_widget() const { GtkWidget* pLabel = gtk_frame_get_label_widget(m_pFrame); @@ -10638,6 +10673,8 @@ std::unique_ptr GtkInstanceFrame::weld_label_widget() const return std::make_unique(GTK_LABEL(pLabel), m_pBuilder, false); } +namespace { + class GtkInstanceTextView : public GtkInstanceContainer, public virtual weld::TextView { private: @@ -10822,10 +10859,7 @@ public: } }; -namespace -{ AtkObject* (*default_drawing_area_get_accessible)(GtkWidget *widget); -} class GtkInstanceDrawingArea : public GtkInstanceWidget, public virtual weld::DrawingArea { @@ -11072,6 +11106,8 @@ public: } }; +} + #define g_signal_handlers_block_by_data(instance, data) \ g_signal_handlers_block_matched ((instance), G_SIGNAL_MATCH_DATA, 0, 0, nullptr, nullptr, (data)) @@ -11095,6 +11131,8 @@ static void disable_area_apply_attributes_cb(GtkWidget* pItem, gpointer userdata g_signal_handlers_block_by_data(pCellArea, userdata); } +namespace { + class GtkInstanceComboBox : public GtkInstanceContainer, public vcl::ISearchableStringList, public virtual weld::ComboBox { private: @@ -12228,8 +12266,6 @@ public: } }; -namespace -{ gboolean signalTooltipQuery(GtkWidget* pWidget, gint /*x*/, gint /*y*/, gboolean /*keyboard_mode*/, GtkTooltip *tooltip) { @@ -12298,8 +12334,6 @@ void ensure_intercept_drawing_area_accessibility() } } -} - class GtkInstanceBuilder : public weld::Builder { private: @@ -12332,7 +12366,7 @@ private: if (icon_name) { OUString aIconName(icon_name, strlen(icon_name), RTL_TEXTENCODING_UTF8); - GdkPixbuf* pixbuf = load_icon_by_name(aIconName, m_aIconTheme, m_aUILang); + GdkPixbuf* pixbuf = load_icon_by_name_theme_lang(aIconName, m_aIconTheme, m_aUILang); if (pixbuf) { gtk_image_set_from_pixbuf(pImage, pixbuf); @@ -12347,7 +12381,7 @@ private: if (icon_name) { OUString aIconName(icon_name, strlen(icon_name), RTL_TEXTENCODING_UTF8); - GdkPixbuf* pixbuf = load_icon_by_name(aIconName, m_aIconTheme, m_aUILang); + GdkPixbuf* pixbuf = load_icon_by_name_theme_lang(aIconName, m_aIconTheme, m_aUILang); if (pixbuf) { GtkWidget* pImage = gtk_image_new_from_pixbuf(pixbuf); @@ -12961,6 +12995,8 @@ public: } }; +} + void GtkInstanceWindow::help() { //show help for widget with keyboard focus -- cgit