summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/vcl/menu.hxx3
-rw-r--r--vcl/inc/vcleventlisteners.hxx12
-rw-r--r--vcl/source/app/vclevent.cxx40
-rw-r--r--vcl/source/window/menu.cxx56
-rw-r--r--vcl/unx/gtk/window/gtksalmenu.cxx9
5 files changed, 42 insertions, 78 deletions
diff --git a/include/vcl/menu.hxx b/include/vcl/menu.hxx
index 456608261de6..160ef8bc34f9 100644
--- a/include/vcl/menu.hxx
+++ b/include/vcl/menu.hxx
@@ -404,8 +404,7 @@ public:
namespace vcl { namespace MenuInvalidator {
-VCL_DLLPUBLIC void AddMenuInvalidateListener(const Link<>&);
-VCL_DLLPUBLIC void CallMenuInvalidateListeners(VclSimpleEvent* pEvent);
+VCL_DLLPUBLIC void AddMenuInvalidateListener(const Link<LinkParamNone*,void>&);
VCL_DLLPUBLIC void Invalidated();
}}
diff --git a/vcl/inc/vcleventlisteners.hxx b/vcl/inc/vcleventlisteners.hxx
index 8e3b026ca953..5be40e8634d2 100644
--- a/vcl/inc/vcleventlisteners.hxx
+++ b/vcl/inc/vcleventlisteners.hxx
@@ -41,18 +41,6 @@ private:
std::vector<Link<>> m_aListeners;
};
-class VCL_DLLPUBLIC VclEventListeners2 : public vcl::DeletionNotifier
-{
- std::vector<Link<>> m_aListeners;
-public:
- VclEventListeners2();
- ~VclEventListeners2();
-
- void addListener( const Link<>& );
- void removeListener( const Link<>& );
- void callListeners( VclSimpleEvent* );
-};
-
#endif // INCLUDED_VCL_INC_VCLEVENTLISTENERS_HXX
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/vcl/source/app/vclevent.cxx b/vcl/source/app/vclevent.cxx
index 7cb291d95eb5..6cc4523ba983 100644
--- a/vcl/source/app/vclevent.cxx
+++ b/vcl/source/app/vclevent.cxx
@@ -87,46 +87,6 @@ void VclEventListeners::removeListener( const Link<>& rListener )
m_aListeners.erase( std::remove(m_aListeners.begin(), m_aListeners.end(), rListener ), m_aListeners.end() );
}
-VclEventListeners2::VclEventListeners2()
-{
-}
-
-VclEventListeners2::~VclEventListeners2()
-{
-}
-
-void VclEventListeners2::addListener( const Link<>& rListener )
-{
- // ensure uniqueness
- if (std::find(m_aListeners.begin(), m_aListeners.end(), rListener) == m_aListeners.end())
- m_aListeners.push_back( rListener );
-}
-
-void VclEventListeners2::removeListener( const Link<>& rListener )
-{
- m_aListeners.erase( std::remove(m_aListeners.begin(), m_aListeners.end(), rListener ), m_aListeners.end() );
-}
-
-void VclEventListeners2::callListeners( VclSimpleEvent* pEvent )
-{
- vcl::DeletionListener aDel( this );
-
- // Copy the list, because this can be destroyed when calling a Link...
- std::vector<Link<>> aCopy( m_aListeners );
- std::vector<Link<>>::iterator aIter( aCopy.begin() );
- std::vector<Link<>>::const_iterator aEnd( aCopy.end() );
-
- while ( aIter != aEnd && ! aDel.isDeleted() )
- {
- Link<> &rLink = *aIter;
- // check this hasn't been removed in some re-enterancy scenario fdo#47368
- if( std::find(m_aListeners.begin(), m_aListeners.end(), rLink) != m_aListeners.end() )
- rLink.Call( pEvent );
- ++aIter;
- }
-}
-
-
VclWindowEvent::VclWindowEvent( vcl::Window* pWin, sal_uLong n, void* pDat ) : VclSimpleEvent(n)
{
pWindow = pWin; pData = pDat;
diff --git a/vcl/source/window/menu.cxx b/vcl/source/window/menu.cxx
index e5acc2eca589..23f857aa3273 100644
--- a/vcl/source/window/menu.cxx
+++ b/vcl/source/window/menu.cxx
@@ -3239,25 +3239,43 @@ ImplMenuDelData::~ImplMenuDelData()
}
namespace vcl { namespace MenuInvalidator {
- static VclEventListeners2* pMenuInvalidateListeners = NULL;
- void AddMenuInvalidateListener(const Link<>& rLink)
- {
- if(!pMenuInvalidateListeners)
- pMenuInvalidateListeners = new VclEventListeners2();
- pMenuInvalidateListeners->addListener(rLink);
- }
- void CallMenuInvalidateListeners(VclSimpleEvent* pEvent)
+
+struct MenuInvalidateListeners : public vcl::DeletionNotifier
+{
+ std::vector<Link<LinkParamNone*,void>> m_aListeners;
+};
+
+static MenuInvalidateListeners* pMenuInvalidateListeners = NULL;
+
+void AddMenuInvalidateListener(const Link<LinkParamNone*,void>& rLink)
+{
+ if(!pMenuInvalidateListeners)
+ pMenuInvalidateListeners = new MenuInvalidateListeners();
+ // ensure uniqueness
+ auto& rListeners = pMenuInvalidateListeners->m_aListeners;
+ if (std::find(rListeners.begin(), rListeners.end(), rLink) == rListeners.end())
+ rListeners.push_back( rLink );
+}
+
+void Invalidated()
+{
+ if(!pMenuInvalidateListeners)
+ return;
+
+ vcl::DeletionListener aDel( pMenuInvalidateListeners );
+
+ auto& rYieldListeners = pMenuInvalidateListeners->m_aListeners;
+ // Copy the list, because this can be destroyed when calling a Link...
+ std::vector<Link<LinkParamNone*,void>> aCopy( rYieldListeners );
+ for( Link<LinkParamNone*,void>& rLink : aCopy )
{
- if(pMenuInvalidateListeners)
- pMenuInvalidateListeners->callListeners(pEvent);
+ if (aDel.isDeleted()) break;
+ // check this hasn't been removed in some re-enterancy scenario fdo#47368
+ if( std::find(rYieldListeners.begin(), rYieldListeners.end(), rLink) != rYieldListeners.end() )
+ rLink.Call( nullptr );
}
- void Invalidated()
- {
- if(pMenuInvalidateListeners)
- {
- VclSimpleEvent aEvent(0);
- pMenuInvalidateListeners->callListeners(&aEvent);
- }
- };
-} }
+};
+
+} } // namespace vcl::MenuInvalidator
+
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/vcl/unx/gtk/window/gtksalmenu.cxx b/vcl/unx/gtk/window/gtksalmenu.cxx
index ba2c894a86db..bb53b14ff341 100644
--- a/vcl/unx/gtk/window/gtksalmenu.cxx
+++ b/vcl/unx/gtk/window/gtksalmenu.cxx
@@ -392,20 +392,19 @@ static gboolean RefreshMenusUnity(gpointer)
return FALSE;
}
-static long RefreshMenusUnity(void*, void*)
+static void RefreshMenusUnity(void*, LinkParamNone*)
{
if(!bInvalidMenus) {
g_timeout_add(10, &RefreshMenusUnity, NULL);
bInvalidMenus = true;
}
- return 0;
}
-static Link<>* getRefreshLinkInstance()
+static Link<LinkParamNone*,void>* getRefreshLinkInstance()
{
- static Link<>* pLink = NULL;
+ static Link<LinkParamNone*,void>* pLink = NULL;
if(!pLink) {
- pLink = new Link<>(NULL, &RefreshMenusUnity);
+ pLink = new Link<LinkParamNone*,void>(NULL, &RefreshMenusUnity);
}
return pLink;
}