diff options
author | Caolán McNamara <caolanm@redhat.com> | 2012-09-03 16:59:48 +0100 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2012-09-03 17:01:39 +0100 |
commit | a4196e56eb3560a2ec2199b87e5d7ff12d55a097 (patch) | |
tree | d94e77f1e9128ea95f20a23ef890b88ca5aab085 | |
parent | feddd3d87077abb2d5435804a9a4859286f6d86f (diff) |
adjust auto font installation
to happen on a 5 second timer and collect up as much missing
stuff in one go as we can
Change-Id: I79f5e70634684a2ef83e3090790531149baf529b
-rw-r--r-- | vcl/generic/fontmanager/fontconfig.cxx | 116 | ||||
-rw-r--r-- | vcl/generic/fontmanager/fontmanager.cxx | 4 | ||||
-rw-r--r-- | vcl/inc/vcl/fontmanager.hxx | 5 |
3 files changed, 71 insertions, 54 deletions
diff --git a/vcl/generic/fontmanager/fontconfig.cxx b/vcl/generic/fontmanager/fontconfig.cxx index a98e52949e15..f5f214514d3a 100644 --- a/vcl/generic/fontmanager/fontconfig.cxx +++ b/vcl/generic/fontmanager/fontconfig.cxx @@ -846,64 +846,71 @@ namespace return LanguageTag(OStringToOUString(aBuf.makeStringAndClear(), RTL_TEXTENCODING_UTF8)); } - int autoInstallFontLangSupport(const std::vector<OString> &rNewReqs, guint xid) + guint get_xid_for_dbus() { - GError *error = NULL; - /* get the DBUS session connection */ - DBusGConnection *session_connection = dbus_g_bus_get(DBUS_BUS_SESSION, &error); - if (error != NULL) - { - g_warning ("DBUS cannot connect : %s", error->message); - g_error_free (error); - return -1; - } + const Window *pTopWindow = Application::IsHeadlessModeEnabled() ? NULL : Application::GetActiveTopWindow(); + const SystemEnvData* pEnvData = pTopWindow ? pTopWindow->GetSystemData() : NULL; + return pEnvData ? pEnvData->aWindow : 0; + } +#endif +} - /* get the proxy with gnome-session-manager */ - DBusGProxy *proxy = dbus_g_proxy_new_for_name(session_connection, - "org.freedesktop.PackageKit", - "/org/freedesktop/PackageKit", - "org.freedesktop.PackageKit.Modify"); - if (proxy == NULL) - { - g_warning("Could not get DBUS proxy: org.freedesktop.PackageKit"); - return -1; - } +IMPL_LINK_NOARG(PrintFontManager, autoInstallFontLangSupport) +{ + guint xid = get_xid_for_dbus(); - gchar **fonts = (gchar**)g_malloc((rNewReqs.size() + 1) * sizeof(gchar*)); - gchar **font = fonts; - for (std::vector<OString>::const_iterator aI = rNewReqs.begin(); aI != rNewReqs.end(); ++aI) - *font++ = (gchar*)aI->getStr(); - *font = NULL; - gboolean res = dbus_g_proxy_call(proxy, "InstallFontconfigResources", &error, - G_TYPE_UINT, xid, /* xid */ - G_TYPE_STRV, fonts, /* data */ - G_TYPE_STRING, "hide-finished", /* interaction */ - G_TYPE_INVALID, - G_TYPE_INVALID); - /* check the return value */ - if (!res) - g_warning("InstallFontconfigResources method failed"); - - /* check the error value */ - if (error != NULL) - { - g_warning("InstallFontconfigResources problem : %s", error->message); - g_error_free(error); - } + if (!xid) + return -1; - g_free(fonts); - g_object_unref(G_OBJECT (proxy)); +#ifdef ENABLE_DBUS + GError *error = NULL; + /* get the DBUS session connection */ + DBusGConnection *session_connection = dbus_g_bus_get(DBUS_BUS_SESSION, &error); + if (error != NULL) + { + g_warning ("DBUS cannot connect : %s", error->message); + g_error_free (error); + return -1; + } - return 0; + /* get the proxy with gnome-session-manager */ + DBusGProxy *proxy = dbus_g_proxy_new_for_name(session_connection, + "org.freedesktop.PackageKit", + "/org/freedesktop/PackageKit", + "org.freedesktop.PackageKit.Modify"); + if (proxy == NULL) + { + g_warning("Could not get DBUS proxy: org.freedesktop.PackageKit"); + return -1; } - guint get_xid_for_dbus() + gchar **fonts = (gchar**)g_malloc((m_aCurrentRequests.size() + 1) * sizeof(gchar*)); + gchar **font = fonts; + for (std::vector<OString>::const_iterator aI = m_aCurrentRequests.begin(); aI != m_aCurrentRequests.end(); ++aI) + *font++ = (gchar*)aI->getStr(); + *font = NULL; + gboolean res = dbus_g_proxy_call(proxy, "InstallFontconfigResources", &error, + G_TYPE_UINT, xid, /* xid */ + G_TYPE_STRV, fonts, /* data */ + G_TYPE_STRING, "hide-finished", /* interaction */ + G_TYPE_INVALID, + G_TYPE_INVALID); + /* check the return value */ + if (!res) + g_warning("InstallFontconfigResources method failed"); + + /* check the error value */ + if (error != NULL) { - const Window *pTopWindow = Application::IsHeadlessModeEnabled() ? NULL : Application::GetActiveTopWindow(); - const SystemEnvData* pEnvData = pTopWindow ? pTopWindow->GetSystemData() : NULL; - return pEnvData ? pEnvData->aWindow : 0; + g_warning("InstallFontconfigResources problem : %s", error->message); + g_error_free(error); } + + g_free(fonts); + g_object_unref(G_OBJECT (proxy)); + m_aCurrentRequests.clear(); #endif + return 0; } bool PrintFontManager::Substitute( FontSelectPattern &rPattern, rtl::OUString& rMissingCodes ) @@ -1050,10 +1057,8 @@ bool PrintFontManager::Substitute( FontSelectPattern &rPattern, rtl::OUString& r } OUString sStillMissing(pRemainingCodes, nRemainingLen); #ifdef ENABLE_DBUS - guint xid = get_xid_for_dbus(); - if (xid) + if (get_xid_for_dbus()) { - std::vector<OString> aNewRequests; if (sStillMissing == rMissingCodes) //replaced nothing { //It'd be better if we could ask packagekit using the @@ -1071,13 +1076,16 @@ bool PrintFontManager::Substitute( FontSelectPattern &rPattern, rtl::OUString& r if (!sTag.isEmpty() && m_aPreviousLangSupportRequests.find(sTag) == m_aPreviousLangSupportRequests.end()) { OString sReq = OString(":lang=") + sTag; - aNewRequests.push_back(sReq); + m_aCurrentRequests.push_back(sReq); m_aPreviousLangSupportRequests.insert(sTag); } } } - if (!aNewRequests.empty()) - autoInstallFontLangSupport(aNewRequests, xid); + if (!m_aCurrentRequests.empty()) + { + m_aFontInstallerTimer.Stop(); + m_aFontInstallerTimer.Start(); + } } #endif rMissingCodes = sStillMissing; diff --git a/vcl/generic/fontmanager/fontmanager.cxx b/vcl/generic/fontmanager/fontmanager.cxx index 8199fc332d69..2a3d29ae8293 100644 --- a/vcl/generic/fontmanager/fontmanager.cxx +++ b/vcl/generic/fontmanager/fontmanager.cxx @@ -1018,12 +1018,16 @@ PrintFontManager::PrintFontManager() m_aAdobecodeToUnicode.insert( ::boost::unordered_multimap< sal_uInt8, sal_Unicode >::value_type( aAdobeCodes[i].aAdobeStandardCode, aAdobeCodes[i].aUnicode ) ); } } + + m_aFontInstallerTimer.SetTimeoutHdl(LINK(this, PrintFontManager, autoInstallFontLangSupport)); + m_aFontInstallerTimer.SetTimeout(5000); } // ------------------------------------------------------------------------- PrintFontManager::~PrintFontManager() { + m_aFontInstallerTimer.Stop(); deinitFontconfig(); for( ::boost::unordered_map< fontID, PrintFont* >::const_iterator it = m_aFonts.begin(); it != m_aFonts.end(); ++it ) delete (*it).second; diff --git a/vcl/inc/vcl/fontmanager.hxx b/vcl/inc/vcl/fontmanager.hxx index 4bd7a4d42264..6666f0ffda0d 100644 --- a/vcl/inc/vcl/fontmanager.hxx +++ b/vcl/inc/vcl/fontmanager.hxx @@ -36,6 +36,7 @@ #include "vcl/dllapi.h" #include "vcl/helper.hxx" +#include "vcl/timer.hxx" #include "vcl/vclenum.hxx" #include "com/sun/star/lang/Locale.hpp" @@ -354,6 +355,10 @@ class VCL_PLUGIN_PUBLIC PrintFontManager bool readOverrideMetrics(); std::set<OString> m_aPreviousLangSupportRequests; + std::vector<OString> m_aCurrentRequests; + Timer m_aFontInstallerTimer; + + DECL_LINK( autoInstallFontLangSupport, void* ); PrintFontManager(); ~PrintFontManager(); |