diff options
author | Takeshi Abe <tabe@fixedpoint.jp> | 2018-02-01 00:00:06 +0900 |
---|---|---|
committer | Takeshi Abe <tabe@fixedpoint.jp> | 2018-02-01 01:37:15 +0100 |
commit | 1056f14525c5f2cf2e73d461b1aa5e7d763cd1d0 (patch) | |
tree | b49e83a2b9efb615ad944acf509523697f0e935f | |
parent | 21a53c857830414968a7acea4dc1f9b95676a6b1 (diff) |
starmath: Put GetDefaultFontName() in an unnamed namespace
Change-Id: I877e1c9b33ae240a2e8ac9972a6bc45e0848ee28
Reviewed-on: https://gerrit.libreoffice.org/49027
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Takeshi Abe <tabe@fixedpoint.jp>
-rw-r--r-- | starmath/inc/format.hxx | 2 | ||||
-rw-r--r-- | starmath/source/cfgitem.cxx | 71 | ||||
-rw-r--r-- | starmath/source/format.cxx | 64 |
3 files changed, 70 insertions, 67 deletions
diff --git a/starmath/inc/format.hxx b/starmath/inc/format.hxx index 362069900414..7b342a41195d 100644 --- a/starmath/inc/format.hxx +++ b/starmath/inc/format.hxx @@ -88,8 +88,6 @@ enum class SmHorAlign { Right }; -OUString GetDefaultFontName( LanguageType nLang, sal_uInt16 nIdent ); - class SmFormat : public SfxBroadcaster { SmFace vFont[FNT_END + 1]; diff --git a/starmath/source/cfgitem.cxx b/starmath/source/cfgitem.cxx index 170bfe84b796..883f6f6d120b 100644 --- a/starmath/source/cfgitem.cxx +++ b/starmath/source/cfgitem.cxx @@ -17,6 +17,7 @@ * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ +#include <cassert> #include <memory> #include <vector> @@ -24,6 +25,8 @@ #include <svl/intitem.hxx> #include <svl/itempool.hxx> #include <svl/eitem.hxx> +#include <svl/languageoptions.hxx> +#include <vcl/outdev.hxx> #include <vcl/svapp.hxx> #include <vcl/settings.hxx> @@ -796,6 +799,72 @@ void SmMathConfig::SaveOther() SetOtherModified( false ); } +namespace { + +// Latin default-fonts +const DefaultFontType aLatinDefFnts[FNT_END] = +{ + DefaultFontType::SERIF, // FNT_VARIABLE + DefaultFontType::SERIF, // FNT_FUNCTION + DefaultFontType::SERIF, // FNT_NUMBER + DefaultFontType::SERIF, // FNT_TEXT + DefaultFontType::SERIF, // FNT_SERIF + DefaultFontType::SANS, // FNT_SANS + DefaultFontType::FIXED // FNT_FIXED + //OpenSymbol, // FNT_MATH +}; + +// CJK default-fonts +//! we use non-asian fonts for variables, functions and numbers since they +//! look better and even in asia only latin letters will be used for those. +//! At least that's what I was told... +const DefaultFontType aCJKDefFnts[FNT_END] = +{ + DefaultFontType::SERIF, // FNT_VARIABLE + DefaultFontType::SERIF, // FNT_FUNCTION + DefaultFontType::SERIF, // FNT_NUMBER + DefaultFontType::CJK_TEXT, // FNT_TEXT + DefaultFontType::CJK_TEXT, // FNT_SERIF + DefaultFontType::CJK_DISPLAY, // FNT_SANS + DefaultFontType::CJK_TEXT // FNT_FIXED + //OpenSymbol, // FNT_MATH +}; + +// CTL default-fonts +const DefaultFontType aCTLDefFnts[FNT_END] = +{ + DefaultFontType::CTL_TEXT, // FNT_VARIABLE + DefaultFontType::CTL_TEXT, // FNT_FUNCTION + DefaultFontType::CTL_TEXT, // FNT_NUMBER + DefaultFontType::CTL_TEXT, // FNT_TEXT + DefaultFontType::CTL_TEXT, // FNT_SERIF + DefaultFontType::CTL_TEXT, // FNT_SANS + DefaultFontType::CTL_TEXT // FNT_FIXED + //OpenSymbol, // FNT_MATH +}; + + +OUString lcl_GetDefaultFontName( LanguageType nLang, sal_uInt16 nIdent ) +{ + assert(nIdent < FNT_END); + const DefaultFontType *pTable; + switch ( SvtLanguageOptions::GetScriptTypeOfLanguage( nLang ) ) + { + case SvtScriptType::LATIN : pTable = aLatinDefFnts; break; + case SvtScriptType::ASIAN : pTable = aCJKDefFnts; break; + case SvtScriptType::COMPLEX : pTable = aCTLDefFnts; break; + default : + pTable = aLatinDefFnts; + SAL_WARN("starmath", "unknown script-type"); + } + + return OutputDevice::GetDefaultFont(pTable[ nIdent ], nLang, + GetDefaultFontFlags::OnlyOne ).GetFamilyName(); +} + +} + + void SmMathConfig::LoadFormat() { if (!pFormat) @@ -863,7 +932,7 @@ void SmMathConfig::LoadFormat() if (bUseDefaultFont) { aFnt = pFormat->GetFont( i ); - aFnt.SetFamilyName( GetDefaultFontName( nLang, i ) ); + aFnt.SetFamilyName( lcl_GetDefaultFontName( nLang, i ) ); } else { diff --git a/starmath/source/format.cxx b/starmath/source/format.cxx index 0d0713f611dc..a4bf960fd583 100644 --- a/starmath/source/format.cxx +++ b/starmath/source/format.cxx @@ -17,71 +17,7 @@ * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ -#include <svl/languageoptions.hxx> #include <format.hxx> -#include <cassert> - - -// Latin default-fonts -static const DefaultFontType aLatinDefFnts[FNT_END] = -{ - DefaultFontType::SERIF, // FNT_VARIABLE - DefaultFontType::SERIF, // FNT_FUNCTION - DefaultFontType::SERIF, // FNT_NUMBER - DefaultFontType::SERIF, // FNT_TEXT - DefaultFontType::SERIF, // FNT_SERIF - DefaultFontType::SANS, // FNT_SANS - DefaultFontType::FIXED // FNT_FIXED - //OpenSymbol, // FNT_MATH -}; - -// CJK default-fonts -//! we use non-asian fonts for variables, functions and numbers since they -//! look better and even in asia only latin letters will be used for those. -//! At least that's what I was told... -static const DefaultFontType aCJKDefFnts[FNT_END] = -{ - DefaultFontType::SERIF, // FNT_VARIABLE - DefaultFontType::SERIF, // FNT_FUNCTION - DefaultFontType::SERIF, // FNT_NUMBER - DefaultFontType::CJK_TEXT, // FNT_TEXT - DefaultFontType::CJK_TEXT, // FNT_SERIF - DefaultFontType::CJK_DISPLAY, // FNT_SANS - DefaultFontType::CJK_TEXT // FNT_FIXED - //OpenSymbol, // FNT_MATH -}; - -// CTL default-fonts -static const DefaultFontType aCTLDefFnts[FNT_END] = -{ - DefaultFontType::CTL_TEXT, // FNT_VARIABLE - DefaultFontType::CTL_TEXT, // FNT_FUNCTION - DefaultFontType::CTL_TEXT, // FNT_NUMBER - DefaultFontType::CTL_TEXT, // FNT_TEXT - DefaultFontType::CTL_TEXT, // FNT_SERIF - DefaultFontType::CTL_TEXT, // FNT_SANS - DefaultFontType::CTL_TEXT // FNT_FIXED - //OpenSymbol, // FNT_MATH -}; - - -OUString GetDefaultFontName( LanguageType nLang, sal_uInt16 nIdent ) -{ - assert(nIdent < FNT_END); - const DefaultFontType *pTable; - switch ( SvtLanguageOptions::GetScriptTypeOfLanguage( nLang ) ) - { - case SvtScriptType::LATIN : pTable = aLatinDefFnts; break; - case SvtScriptType::ASIAN : pTable = aCJKDefFnts; break; - case SvtScriptType::COMPLEX : pTable = aCTLDefFnts; break; - default : - pTable = aLatinDefFnts; - SAL_WARN("starmath", "unknown script-type"); - } - - return OutputDevice::GetDefaultFont(pTable[ nIdent ], nLang, - GetDefaultFontFlags::OnlyOne ).GetFamilyName(); -} SmFormat::SmFormat() |