office-gobmx/vcl/qt5/QtAccessibleRegistry.cxx
Noel Grandin 193207c5ab improve loplugin passparamsbyref
I think I managed to disable this when I converted it to
use the shared plugin infrastructure.

So fix that, and then make it much smarter to avoid various
false positives.

Change-Id: I0a4657cff3b40a00434924bf764d024dbfd7d5b3
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/176646
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
2024-11-19 07:46:25 +01:00

45 lines
1.4 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
#include <QtAccessibleRegistry.hxx>
#include <QtXAccessible.hxx>
#include <cassert>
std::map<XAccessible*, QObject*> QtAccessibleRegistry::m_aMapping = {};
QObject* QtAccessibleRegistry::getQObject(const css::uno::Reference<XAccessible>& xAcc)
{
if (!xAcc.is())
return nullptr;
// look for existing entry in the map
auto entry = m_aMapping.find(xAcc.get());
if (entry != m_aMapping.end())
return entry->second;
// create a new object and remember it in the map
QtXAccessible* pQtAcc = new QtXAccessible(xAcc);
m_aMapping.emplace(xAcc.get(), pQtAcc);
return pQtAcc;
}
void QtAccessibleRegistry::insert(const css::uno::Reference<XAccessible>& xAcc, QObject* pQObject)
{
assert(pQObject);
m_aMapping.emplace(xAcc.get(), pQObject);
}
void QtAccessibleRegistry::remove(const css::uno::Reference<XAccessible>& xAcc)
{
assert(xAcc.is());
m_aMapping.erase(xAcc.get());
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */