[ooo-build-commit] Branch 'ooo-build-3-1-1' - patches/dev300
Petr Mladek
pmladek at kemper.freedesktop.org
Mon Sep 14 08:48:33 PDT 2009
patches/dev300/apply | 11
patches/dev300/optional-icon-themes.diff | 409 +++++++++++++++++++++++++++++++
2 files changed, 418 insertions(+), 2 deletions(-)
New commits:
commit 809fcd00f433a7d0637184ea91aa943ff33e8f95
Author: Petr Mladek <pmladek at suse.cz>
Date: Mon Sep 14 17:45:38 2009 +0200
Optional icon themes (i#105062, bnc#529404, bnc#537541)
* patches/dev300/optional-icon-themes.diff: add fallback to any installed icon
theme; show only the installed icon themes in
Tools/Options.../OpenOffice.org/View
* patches/dev300/apply: applied only for openSUSE-Factory; seems to work well
but I am not brave enough to put it into common section at this stage ;-)
diff --git a/patches/dev300/apply b/patches/dev300/apply
index 8e7a029..6880457 100644
--- a/patches/dev300/apply
+++ b/patches/dev300/apply
@@ -34,7 +34,8 @@ Experimental: VBAUntested, ArkOnlyExperimental, \
PostgreSQL, SELinux, VOSremoval, Glib2, \
UnitBootstrap, RadioButtons, UnstableLibwpd, WWInProgress, \
KDE4Experimental, MinGW, CalcExperimental, Mono24, \
- OOXMLExportExperimental, CrossWin32Patches, AutoLayout
+ OOXMLExportExperimental, CrossWin32Patches, AutoLayout, \
+ OptionalIconThemes
DebianLooseSections: DebianBaseNoHelpContent
# Optional sections
Optional : DejaVuFonts, NovellOnlyExtensionFixes, Win32OnlyExtensionFixes, Linux32OnlyExtensionFixes
@@ -66,7 +67,7 @@ SUSE-10.2 : NovellBase, BerkeleyDB43, EMFPlus, Java14, OpenGLTransitionsMesa703
SUSE-10.3 : NovellBase, BerkeleyDB43, EMFPlus, Java14, GCC41
SUSE-11.0 : NovellBase, BerkeleyDB43, EMFPlus, CairoFonts, PostgreSQL
SUSE-11.1 : NovellBase, BerkeleyDB43, EMFPlus, CairoFonts, ImpressFontSize, PostgreSQL
-SUSE : NovellBase, BerkeleyDB43, EMFPlus, CairoFonts, ImpressFontSize, PostgreSQL
+SUSE : NovellBase, BerkeleyDB43, EMFPlus, CairoFonts, ImpressFontSize, PostgreSQL, OptionalIconThemes
SUSE-reduced:NovellBase,BerkeleyDB43, ReducedDefaults
# Slackware
Slackware : LinuxCommon, SlackwareOnly, NotDebian, Mono, msaccess, CairoFonts
@@ -2154,6 +2155,12 @@ kde4-oxygen-icons.diff
# Not yet ported to co-exist with the KDE3 stuff
kde4-kab.diff
+[ OptionalIconThemes ]
+# FIXME: seems to work well but I am not brave enough to put it into common section at this stage
+# fallback to any installed icon theme
+# show only the installed icon themes in Tools/Options.../OpenOffice.org/View
+optional-icon-themes.diff, i#105062, bnc#529404, pmladek
+
[ ArkOnly ]
SectionOwner => brosenk
diff --git a/patches/dev300/optional-icon-themes.diff b/patches/dev300/optional-icon-themes.diff
new file mode 100644
index 0000000..961df15
--- /dev/null
+++ b/patches/dev300/optional-icon-themes.diff
@@ -0,0 +1,409 @@
+--- vcl/source/gdi/impimagetree.cxx.old 2009-08-26 10:25:02.000000000 +0000
++++ vcl/source/gdi/impimagetree.cxx 2009-09-11 14:53:46.000000000 +0000
+@@ -46,6 +46,7 @@
+ #include "com/sun/star/uno/RuntimeException.hpp"
+ #include "com/sun/star/uno/Sequence.hxx"
+ #include "comphelper/processfactory.hxx"
++#include "osl/file.hxx"
+ #include "osl/diagnose.h"
+ #include "rtl/bootstrap.hxx"
+ #include "rtl/string.h"
+@@ -123,12 +124,43 @@ ImplImageTree::ImplImageTree()
+
+ ImplImageTree::~ImplImageTree() {}
+
++bool ImplImageTree::checkStyle(rtl::OUString const & style)
++{
++ bool exists;
++
++ // using cache because setStyle is an expensive operation
++ // setStyle calls resetZips => closes any opened zip files with icons, cleans the icon cache, ...
++ if (checkStyleCacheLookup(style, exists)) {
++ return exists;
++ }
++
++ setStyle(style);
++
++ exists = false;
++ const rtl::OUString sBrandURLSuffix(RTL_CONSTASCII_USTRINGPARAM("_brand.zip"));
++ for (Zips::iterator i(m_zips.begin()); i != m_zips.end() && !exists;) {
++ ::rtl::OUString aZipURL = i->first;
++ sal_Int32 nFromIndex = aZipURL.getLength() - sBrandURLSuffix.getLength();
++ // skip brand-specific icon themes; they are incomplete and thus not useful for this check
++ if (nFromIndex < 0 || !aZipURL.match(sBrandURLSuffix, nFromIndex)) {
++ osl::File aZip(aZipURL);
++ if (aZip.open(OpenFlag_Read) == ::osl::FileBase::E_None) {
++ aZip.close();
++ exists = true;
++ }
++ }
++ ++i;
++ }
++ m_checkStyleCache[style] = exists;
++ return exists;
++}
++
+ bool ImplImageTree::loadImage(
+ rtl::OUString const & name, rtl::OUString const & style, BitmapEx & bitmap,
+ bool localized)
+ {
+ setStyle(style);
+- if (cacheLookup(name, localized, bitmap)) {
++ if (iconCacheLookup(name, localized, bitmap)) {
+ return true;
+ }
+ if (!bitmap.IsEmpty()) {
+@@ -169,7 +201,7 @@ bool ImplImageTree::loadImage(
+ rtl::OUStringToOString(e.Message, RTL_TEXTENCODING_UTF8).getStr());
+ }
+ if (found) {
+- m_cache[name.intern()] = std::make_pair(localized, bitmap);
++ m_iconCache[name.intern()] = std::make_pair(localized, bitmap);
+ }
+ return found;
+ }
+@@ -178,7 +210,8 @@ void ImplImageTree::shutDown() {
+ m_style = rtl::OUString();
+ // for safety; empty m_style means "not initialized"
+ m_zips.clear();
+- m_cache.clear();
++ m_iconCache.clear();
++ m_checkStyleCache.clear();
+ }
+
+ void ImplImageTree::setStyle(rtl::OUString const & style) {
+@@ -186,7 +219,7 @@ void ImplImageTree::setStyle(rtl::OUStri
+ if (style != m_style) {
+ m_style = style;
+ resetZips();
+- m_cache.clear();
++ m_iconCache.clear();
+ }
+ }
+
+@@ -243,6 +276,7 @@ void ImplImageTree::resetZips() {
+ OSL_ASSERT(ok); (void) ok;
+ addUrlToZips(u.GetMainURL(INetURLObject::NO_DECODE));
+ }
++ if ( m_style.equals(::rtl::OUString::createFromAscii("default")) )
+ {
+ rtl::OUString url(
+ RTL_CONSTASCII_USTRINGPARAM(
+@@ -252,11 +286,23 @@ void ImplImageTree::resetZips() {
+ }
+ }
+
+-bool ImplImageTree::cacheLookup(
++bool ImplImageTree::checkStyleCacheLookup(
++ rtl::OUString const & style, bool &exists)
++{
++ CheckStyleCache::iterator i(m_checkStyleCache.find(style));
++ if (i != m_checkStyleCache.end()) {
++ exists = i->second;
++ return true;
++ } else {
++ return false;
++ }
++}
++
++bool ImplImageTree::iconCacheLookup(
+ rtl::OUString const & name, bool localized, BitmapEx & bitmap)
+ {
+- Cache::iterator i(m_cache.find(name));
+- if (i != m_cache.end() && i->second.first == localized) {
++ IconCache::iterator i(m_iconCache.find(name));
++ if (i != m_iconCache.end() && i->second.first == localized) {
+ bitmap = i->second.second;
+ return true;
+ } else {
+--- vcl/source/app/settings.cxx.old 2009-08-26 10:25:12.000000000 +0000
++++ vcl/source/app/settings.cxx 2009-09-11 15:12:56.000000000 +0000
+@@ -41,6 +41,8 @@
+ #include "vcl/configsettings.hxx"
+ #include "vcl/gradient.hxx"
+ #include "vcl/unohelp.hxx"
++#include "vcl/bitmapex.hxx"
++#include "vcl/impimagetree.hxx"
+ #include "unotools/localedatawrapper.hxx"
+ #include "unotools/collatorwrapper.hxx"
+ #include "unotools/configmgr.hxx"
+@@ -770,12 +772,12 @@ ULONG StyleSettings::GetCurrentSymbolsSt
+ // style selected in Tools -> Options... -> OpenOffice.org -> View
+ ULONG nStyle = GetSymbolsStyle();
+
+- if ( nStyle == STYLE_SYMBOLS_AUTO )
++ if ( nStyle == STYLE_SYMBOLS_AUTO || ( !CheckSymbolStyle (nStyle) ) )
+ {
+ // the preferred style can be read from the desktop setting by the desktop native widgets modules
+ ULONG nPreferredStyle = GetPreferredSymbolsStyle();
+
+- if ( nPreferredStyle == STYLE_SYMBOLS_AUTO )
++ if ( nPreferredStyle == STYLE_SYMBOLS_AUTO || ( !CheckSymbolStyle (nPreferredStyle) ) )
+ {
+
+ // use a hardcoded desktop-specific fallback if no preferred style has been detected
+@@ -784,14 +786,17 @@ ULONG StyleSettings::GetCurrentSymbolsSt
+
+ if ( !sbFallbackDesktopChecked )
+ {
+- snFallbackDesktopStyle = GetAutoSymbolsStyle();
++ snFallbackDesktopStyle = GetAutoSymbolsStyle();
+ sbFallbackDesktopChecked = true;
+ }
+
+ nPreferredStyle = snFallbackDesktopStyle;
+ }
+
+- nStyle = GetHighContrastMode()? STYLE_SYMBOLS_HICONTRAST: nPreferredStyle;
++ if (GetHighContrastMode() && CheckSymbolStyle (STYLE_SYMBOLS_HICONTRAST) )
++ nStyle = STYLE_SYMBOLS_HICONTRAST;
++ else
++ nStyle = nPreferredStyle;
+ }
+
+ return nStyle;
+@@ -830,10 +835,43 @@ ULONG StyleSettings::GetAutoSymbolsStyle
+ nRet = STYLE_SYMBOLS_OXYGEN;
+ }
+
++ // falback to any existing style
++ if ( ! CheckSymbolStyle (nRet) )
++ {
++ for ( ULONG n = 0 ; n <= STYLE_SYMBOLS_THEMES_MAX ; n++ )
++ {
++ ULONG nStyleToCheck = n;
++
++ // auto is not a real theme => can't be fallback
++ if ( nStyleToCheck == STYLE_SYMBOLS_AUTO )
++ continue;
++
++ // will check hicontrast in the end
++ if ( nStyleToCheck == STYLE_SYMBOLS_HICONTRAST )
++ continue;
++ if ( nStyleToCheck == STYLE_SYMBOLS_THEMES_MAX )
++ nStyleToCheck = STYLE_SYMBOLS_HICONTRAST;
++
++ if ( CheckSymbolStyle ( nStyleToCheck ) )
++ {
++ nRet = nStyleToCheck;
++ n = STYLE_SYMBOLS_THEMES_MAX;
++ }
++ }
++ }
++
+ return nRet;
+ }
+
+ // -----------------------------------------------------------------------
++
++bool StyleSettings::CheckSymbolStyle( ULONG nStyle ) const
++{
++ static ImplImageTreeSingletonRef aImageTree;
++ return aImageTree->checkStyle( ImplSymbolsStyleToName( nStyle ) );
++}
++
++// -----------------------------------------------------------------------
+
+ void StyleSettings::SetStandardStyles()
+ {
+--- vcl/inc/vcl/settings.hxx.old 2009-08-26 10:25:12.000000000 +0000
++++ vcl/inc/vcl/settings.hxx 2009-09-10 15:27:10.000000000 +0000
+@@ -520,7 +520,7 @@ private:
+ #define STYLE_SYMBOLS_TANGO ((ULONG)5)
+ #define STYLE_SYMBOLS_CLASSIC ((ULONG)6)
+ #define STYLE_SYMBOLS_OXYGEN ((ULONG)7)
+-#define STYLE_SYMBOLS_THEMES_MAX ((ULONG)7)
++#define STYLE_SYMBOLS_THEMES_MAX ((ULONG)8)
+
+ #define STYLE_CURSOR_NOBLINKTIME ((ULONG)0xFFFFFFFF)
+
+@@ -944,6 +944,8 @@ public:
+ void SetPreferredSymbolsStyleName( const ::rtl::OUString &rName );
+ ULONG GetPreferredSymbolsStyle() const
+ { return mpData->mnPreferredSymbolsStyle; }
++ // check whether the symbols style is supported (icons are installed)
++ bool CheckSymbolStyle( ULONG nStyle ) const;
+ ULONG GetAutoSymbolsStyle() const;
+
+ ULONG GetCurrentSymbolsStyle() const;
+--- vcl/inc/vcl/impimagetree.hxx.old 2009-08-26 10:25:02.000000000 +0000
++++ vcl/inc/vcl/impimagetree.hxx 2009-09-11 14:53:11.000000000 +0000
+@@ -54,6 +54,9 @@ public:
+
+ ~ImplImageTree();
+
++ // check whether the icon style is installed
++ bool checkStyle(rtl::OUString const & style);
++
+ bool loadImage(
+ rtl::OUString const & name, rtl::OUString const & style,
+ BitmapEx & bitmap, bool localized = false);
+@@ -61,7 +64,7 @@ public:
+ void shutDown();
+ // a crude form of life cycle control (called from DeInitVCL; otherwise,
+ // if the ImplImageTree singleton were destroyed during exit that would
+- // be too late for the destructors of the bitmaps in m_cache)
++ // be too late for the destructors of the bitmaps in m_iconCache)
+
+ private:
+ typedef std::list<
+@@ -71,7 +74,9 @@ private:
+ com::sun::star::container::XNameAccess > > > Zips;
+
+ typedef std::hash_map<
+- rtl::OUString, std::pair< bool, BitmapEx >, rtl::OUStringHash > Cache;
++ rtl::OUString, bool, rtl::OUStringHash > CheckStyleCache;
++ typedef std::hash_map<
++ rtl::OUString, std::pair< bool, BitmapEx >, rtl::OUStringHash > IconCache;
+
+ // we want to search zip files (icons) also in /usr/share/
+ ::rtl::OUString m_datadir; // /usr/share/
+@@ -79,14 +84,17 @@ private:
+
+ rtl::OUString m_style;
+ Zips m_zips;
+- Cache m_cache;
++ CheckStyleCache m_checkStyleCache;
++ IconCache m_iconCache;
+
+ void setStyle(rtl::OUString const & style);
+
+ void addUrlToZips(const rtl::OUString &url);
+ void resetZips();
+
+- bool cacheLookup(
++ bool checkStyleCacheLookup(
++ rtl::OUString const & style, bool &exists);
++ bool iconCacheLookup(
+ rtl::OUString const & name, bool localized, BitmapEx & bitmap);
+
+ bool find(std::vector< rtl::OUString > const & paths, BitmapEx & bitmap);
+--- svx/source/dialog/optgdlg.cxx.old 2009-08-26 10:25:14.000000000 +0000
++++ svx/source/dialog/optgdlg.cxx 2009-09-11 15:20:42.000000000 +0000
+@@ -802,6 +802,31 @@ OfaViewTabPage::OfaViewTabPage(Window* p
+ m_aSystemFont.Enable( FALSE );
+ }
+
++ const StyleSettings& aStyleSettings = Application::GetSettings().GetStyleSettings();
++
++ // remove non-installed icon themes
++ if( aIconStyleLB.GetEntryCount() == STYLE_SYMBOLS_THEMES_MAX )
++ {
++ // do not check 0th item == auto; it is not a real theme
++ aIconStyleItemId[0] = 0;
++ ULONG nItem = 1;
++ for ( ULONG n=0; ++n < STYLE_SYMBOLS_THEMES_MAX; )
++ {
++ if ( aStyleSettings.CheckSymbolStyle( n ) )
++ {
++ // existing style => save the item id
++ aIconStyleItemId[n] = nItem++;
++ }
++ else
++ {
++ // non-existing style => remove item;
++ aIconStyleLB.RemoveEntry( nItem );
++ aIconStyleItemId[n] = 0;
++ }
++ }
++
++ }
++
+ // add real theme name to 'auto' theme, e.g. 'auto' => 'auto (classic)'
+ if( aIconStyleLB.GetEntryCount() > 1 )
+ {
+@@ -809,20 +834,14 @@ OfaViewTabPage::OfaViewTabPage(Window* p
+
+ aAutoStr += ::rtl::OUString::createFromAscii( " (" );
+
+- switch( Application::GetSettings().GetStyleSettings().GetAutoSymbolsStyle() )
+- {
+- case STYLE_SYMBOLS_DEFAULT: aAutoStr += aIconStyleLB.GetEntry( 1 ); break;
+- case STYLE_SYMBOLS_INDUSTRIAL: aAutoStr += aIconStyleLB.GetEntry( 2 ); break;
+- case STYLE_SYMBOLS_CRYSTAL: aAutoStr += aIconStyleLB.GetEntry( 3 ); break;
+- case STYLE_SYMBOLS_TANGO: aAutoStr += aIconStyleLB.GetEntry( 4 ); break;
+- case STYLE_SYMBOLS_CLASSIC: aAutoStr += aIconStyleLB.GetEntry( 5 ); break;
+- case STYLE_SYMBOLS_HICONTRAST: aAutoStr += aIconStyleLB.GetEntry( 6 ); break;
+- case STYLE_SYMBOLS_OXYGEN: aAutoStr += aIconStyleLB.GetEntry( 7 ); break;
+- }
++ ULONG nAutoStyle = aStyleSettings.GetAutoSymbolsStyle();
++ if ( aIconStyleItemId[nAutoStyle] )
++ aAutoStr += aIconStyleLB.GetEntry( aIconStyleItemId[nAutoStyle] );
+
+ aIconStyleLB.RemoveEntry( 0 );
+ aIconStyleLB.InsertEntry( aAutoStr += ::rtl::OUString::createFromAscii( ")" ), 0 );
+- aIconStyleLB.SetSeparatorPos( aIconStyleLB.GetEntryCount() - 2 );
++ // separate auto and other icon themes
++ aIconStyleLB.SetSeparatorPos( 0 );
+ }
+ }
+
+@@ -891,26 +910,18 @@ BOOL OfaViewTabPage::FillItemSet( SfxIte
+ UINT16 nStyleLB_NewSelection = aIconStyleLB.GetSelectEntryPos();
+ if( nStyleLB_InitialSelection != nStyleLB_NewSelection )
+ {
+- sal_Int16 eSet = SFX_SYMBOLS_STYLE_AUTO;
+- switch( nStyleLB_NewSelection )
+- {
+- case 0: eSet = SFX_SYMBOLS_STYLE_AUTO; break;
+- case 1: eSet = SFX_SYMBOLS_STYLE_DEFAULT; break;
+- case 2: eSet = SFX_SYMBOLS_STYLE_HICONTRAST; break;
+- case 3: eSet = SFX_SYMBOLS_STYLE_INDUSTRIAL; break;
+- case 4: eSet = SFX_SYMBOLS_STYLE_CRYSTAL; break;
+- case 5: eSet = SFX_SYMBOLS_STYLE_TANGO; break;
+- case 6: eSet = SFX_SYMBOLS_STYLE_CLASSIC; break;
+- case 7: eSet = SFX_SYMBOLS_STYLE_OXYGEN; break;
+- default:
+- DBG_ERROR( "OfaViewTabPage::FillItemSet(): This state of aIconStyleLB should not be possible!" );
+- }
+- aMiscOptions.SetSymbolsStyle( eSet );
++ // find the style name in the aIconStyleItemId table
++ // items from the non-installed icon themes were removed
++ for ( ULONG n=0; n < STYLE_SYMBOLS_THEMES_MAX; n++ )
++ if ( aIconStyleItemId[n] == nStyleLB_NewSelection )
++ {
++ aMiscOptions.SetSymbolsStyle( n );
++ n = STYLE_SYMBOLS_THEMES_MAX;
++ }
+ }
+
+ BOOL bAppearanceChanged = FALSE;
+
+-
+ // Screen Scaling
+ UINT16 nOldScale = pAppearanceCfg->GetScaleFactor();
+ UINT16 nNewScale = (UINT16)aWindowSizeMF.GetValue();
+@@ -1052,20 +1063,7 @@ void OfaViewTabPage::Reset( const SfxIte
+ aIconSizeLB.SaveValue();
+
+ if( aMiscOptions.GetSymbolsStyle() != SFX_SYMBOLS_STYLE_AUTO )
+- {
+- switch ( aMiscOptions.GetCurrentSymbolsStyle() )
+- {
+- case SFX_SYMBOLS_STYLE_DEFAULT: nStyleLB_InitialSelection = 1; break;
+- case SFX_SYMBOLS_STYLE_HICONTRAST: nStyleLB_InitialSelection = 2; break;
+- case SFX_SYMBOLS_STYLE_INDUSTRIAL: nStyleLB_InitialSelection = 3; break;
+- case SFX_SYMBOLS_STYLE_CRYSTAL: nStyleLB_InitialSelection = 4; break;
+- case SFX_SYMBOLS_STYLE_TANGO: nStyleLB_InitialSelection = 5; break;
+- case SFX_SYMBOLS_STYLE_CLASSIC: nStyleLB_InitialSelection = 6; break;
+- case SFX_SYMBOLS_STYLE_OXYGEN: nStyleLB_InitialSelection = 7; break;
+- default: nStyleLB_InitialSelection = 0; break;
+- }
+- }
+-
++ nStyleLB_InitialSelection = aIconStyleItemId[aMiscOptions.GetCurrentSymbolsStyle()];
+ aIconStyleLB.SelectEntryPos( nStyleLB_InitialSelection );
+ aIconStyleLB.SaveValue();
+
+--- svx/source/dialog/optgdlg.hxx.old 2009-08-26 10:25:14.000000000 +0000
++++ svx/source/dialog/optgdlg.hxx 2009-09-09 15:40:36.000000000 +0000
+@@ -136,6 +136,9 @@ private:
+ UINT16 nStyleLB_InitialSelection;
+ BOOL bSfxSymbolsAuto;
+
++ // item ID for the given icon theme
++ // might be zero when the theme is not installed and the item is removed
++ ULONG aIconStyleItemId[STYLE_SYMBOLS_THEMES_MAX];
+ SvtTabAppearanceCfg* pAppearanceCfg;
+ CanvasSettings* pCanvasSettings;
+ SvtOptionsDrawinglayer* mpDrawinglayerOpt;
More information about the ooo-build-commit
mailing list