diff options
author | Khaled Hosny <khaled@aliftype.com> | 2022-09-11 06:27:23 +0200 |
---|---|---|
committer | خالد حسني <khaled@aliftype.com> | 2022-09-11 09:54:16 +0200 |
commit | 38db900c1f7b471dfdf575bbda522a792db51372 (patch) | |
tree | 003257fb312afbff2c81667110f3b2d9b3cd0509 /vcl/unx | |
parent | 4286e745bccc7393ecd8b06346306d13d23316b5 (diff) |
vcl: Move CreateFontSubset() to PhysicalFontFace
Having it in SalGraphics is not necessary as the code now depends on
PhysicalFontFace for accessing raw font data, and this consolidates all
the near identical copies of this code into one.
Change-Id: I8a411f102fd2188a456bdeb8a0d794078d74e47b
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/139762
Tested-by: Jenkins
Reviewed-by: خالد حسني <khaled@aliftype.com>
Diffstat (limited to 'vcl/unx')
-rw-r--r-- | vcl/unx/generic/fontmanager/fontmanager.cxx | 113 | ||||
-rw-r--r-- | vcl/unx/generic/gdi/font.cxx | 13 | ||||
-rw-r--r-- | vcl/unx/generic/gdi/freetypetextrender.cxx | 19 | ||||
-rw-r--r-- | vcl/unx/generic/print/genpspgraphics.cxx | 19 |
4 files changed, 0 insertions, 164 deletions
diff --git a/vcl/unx/generic/fontmanager/fontmanager.cxx b/vcl/unx/generic/fontmanager/fontmanager.cxx index 1aed1a37d1d4..d9151ecf19c0 100644 --- a/vcl/unx/generic/fontmanager/fontmanager.cxx +++ b/vcl/unx/generic/fontmanager/fontmanager.cxx @@ -22,7 +22,6 @@ #include <osl/thread.h> #include <unx/fontmanager.hxx> -#include <fontsubset.hxx> #include <impfontcharmap.hxx> #include <unx/gendata.hxx> #include <unx/helper.hxx> @@ -938,116 +937,4 @@ int PrintFontManager::getFontDescend( fontID nFontID ) return pFont ? pFont->m_nDescend : 0; } -// TODO: move most of this stuff into the central font-subsetting code -bool PrintFontManager::createFontSubset( - FontSubsetInfo& rInfo, - const vcl::font::PhysicalFontFace* pFace, - const OUString& rOutFile, - const sal_GlyphId* pGlyphIds, - const sal_uInt8* pNewEncoding, - int nGlyphs - ) -{ - psp::fontID nFont = pFace->GetFontId(); - PrintFont* pFont = getFont( nFont ); - if( !pFont ) - return false; - - rInfo.m_nFontType = FontType::SFNT_TTF; - - // reshuffle array of requested glyphs to make sure glyph0==notdef - sal_uInt8 pEnc[256]; - sal_uInt16 pGID[256]; - sal_uInt8 pOldIndex[256]; - memset( pEnc, 0, sizeof( pEnc ) ); - memset( pGID, 0, sizeof( pGID ) ); - memset( pOldIndex, 0, sizeof( pOldIndex ) ); - if( nGlyphs > 256 ) - return false; - int nChar = 1; - for( int i = 0; i < nGlyphs; i++ ) - { - if( pNewEncoding[i] == 0 ) - { - pOldIndex[ 0 ] = i; - } - else - { - SAL_WARN_IF( (pGlyphIds[i] & 0x007f0000), "vcl.fonts", "overlong glyph id" ); - SAL_WARN_IF( static_cast<int>(pNewEncoding[i]) >= nGlyphs, "vcl.fonts", "encoding wrong" ); - SAL_WARN_IF( pEnc[pNewEncoding[i]] != 0 || pGID[pNewEncoding[i]] != 0, "vcl.fonts", "duplicate encoded glyph" ); - pEnc[ pNewEncoding[i] ] = pNewEncoding[i]; - pGID[ pNewEncoding[i] ] = static_cast<sal_uInt16>(pGlyphIds[ i ]); - pOldIndex[ pNewEncoding[i] ] = i; - nChar++; - } - } - nGlyphs = nChar; // either input value or increased by one - - TrueTypeFace aSftFont(*pFace); - if (aSftFont.initialize() != SFErrCodes::Ok) - return false; - - // prepare system name for write access for subset file target - OUString aSysPath; - if( osl_File_E_None != osl_getSystemPathFromFileURL( rOutFile.pData, &aSysPath.pData ) ) - return false; - const rtl_TextEncoding aEncoding = osl_getThreadTextEncoding(); - const OString aToFile( OUStringToOString( aSysPath, aEncoding ) ); - - // do CFF subsetting if possible - sal_uInt32 nCffLength = 0; - const sal_uInt8* pCffBytes = aSftFont.table(vcl::O_CFF, nCffLength); - if (pCffBytes) - { - rInfo.LoadFont( FontType::CFF_FONT, pCffBytes, nCffLength ); -#if 1 // TODO: remove 16bit->long conversion when related methods handle non-16bit glyphids - sal_GlyphId aRequestedGlyphIds[256]; - for( int i = 0; i < nGlyphs; ++i ) - aRequestedGlyphIds[i] = pGID[i]; -#endif - // create subset file at requested path - FILE* pOutFile = fopen( aToFile.getStr(), "wb" ); - if (!pOutFile) - return false; - // create font subset - const char* const pGlyphSetName = nullptr; // TODO: better name? - const bool bOK = rInfo.CreateFontSubset( - FontType::TYPE1_PFB, - pOutFile, pGlyphSetName, - aRequestedGlyphIds, pEnc, nGlyphs); - fclose( pOutFile ); - // For OTC, values from hhea or OS2 are better - psp::PrintFontInfo aFontInfo; - if( getFontInfo( nFont, aFontInfo ) ) - { - rInfo.m_nAscent = aFontInfo.m_nAscend; - rInfo.m_nDescent = -aFontInfo.m_nDescend; - } - return bOK; - } - - // do TTF->Type42 or Type3 subsetting - // fill in font info - psp::PrintFontInfo aFontInfo; - if( ! getFontInfo( nFont, aFontInfo ) ) - return false; - - rInfo.m_nAscent = aFontInfo.m_nAscend; - rInfo.m_nDescent = aFontInfo.m_nDescend; - rInfo.m_aPSName = getPSName( nFont ); - - int xMin, yMin, xMax, yMax; - getFontBoundingBox( nFont, xMin, yMin, xMax, yMax ); - rInfo.m_aFontBBox = tools::Rectangle( Point( xMin, yMin ), Size( xMax-xMin, yMax-yMin ) ); - rInfo.m_nCapHeight = yMax; // Well ... - - bool bSuccess = ( SFErrCodes::Ok == CreateTTFromTTGlyphs(&aSftFont, - aToFile.getStr(), - pGID, - pEnc, - nGlyphs ) ); - return bSuccess; -} - /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/unx/generic/gdi/font.cxx b/vcl/unx/generic/gdi/font.cxx index bf0ca5c98ffb..1246d9b525f8 100644 --- a/vcl/unx/generic/gdi/font.cxx +++ b/vcl/unx/generic/gdi/font.cxx @@ -81,19 +81,6 @@ std::unique_ptr<GenericSalLayout> X11SalGraphics::GetTextLayout(int nFallbackLev return mxTextRenderImpl->GetTextLayout(nFallbackLevel); } -bool X11SalGraphics::CreateFontSubset( - const OUString& rToFile, - const vcl::font::PhysicalFontFace* pFont, - const sal_GlyphId* pGlyphIds, - const sal_uInt8* pEncoding, - int nGlyphCount, - FontSubsetInfo& rInfo - ) -{ - return mxTextRenderImpl->CreateFontSubset(rToFile, pFont, - pGlyphIds, pEncoding, nGlyphCount, rInfo); -} - const void* X11SalGraphics::GetEmbedFontData(const vcl::font::PhysicalFontFace* pFont, tools::Long* pDataLen) { return mxTextRenderImpl->GetEmbedFontData(pFont, pDataLen); diff --git a/vcl/unx/generic/gdi/freetypetextrender.cxx b/vcl/unx/generic/gdi/freetypetextrender.cxx index beff9f33e652..b1416721fea6 100644 --- a/vcl/unx/generic/gdi/freetypetextrender.cxx +++ b/vcl/unx/generic/gdi/freetypetextrender.cxx @@ -127,25 +127,6 @@ std::unique_ptr<GenericSalLayout> FreeTypeTextRenderImpl::GetTextLayout(int nFal return std::make_unique<GenericSalLayout>(*mpFreetypeFont[nFallbackLevel]); } -bool FreeTypeTextRenderImpl::CreateFontSubset( - const OUString& rToFile, - const vcl::font::PhysicalFontFace* pFont, - const sal_GlyphId* pGlyphIds, - const sal_uInt8* pEncoding, - int nGlyphCount, - FontSubsetInfo& rInfo - ) -{ - psp::PrintFontManager& rMgr = psp::PrintFontManager::get(); - bool bSuccess = rMgr.createFontSubset( rInfo, - pFont, - rToFile, - pGlyphIds, - pEncoding, - nGlyphCount ); - return bSuccess; -} - const void* FreeTypeTextRenderImpl::GetEmbedFontData(const vcl::font::PhysicalFontFace* pFont, tools::Long* pDataLen) { return GenPspGraphics::GetEmbedFontDataHelper(pFont, pDataLen); diff --git a/vcl/unx/generic/print/genpspgraphics.cxx b/vcl/unx/generic/print/genpspgraphics.cxx index 630a02bdb061..dcfdadc64cda 100644 --- a/vcl/unx/generic/print/genpspgraphics.cxx +++ b/vcl/unx/generic/print/genpspgraphics.cxx @@ -315,25 +315,6 @@ std::unique_ptr<GenericSalLayout> GenPspGraphics::GetTextLayout(int nFallbackLev return std::make_unique<PspSalLayout>(*m_pPrinterGfx, *m_pFreetypeFont[nFallbackLevel]); } -bool GenPspGraphics::CreateFontSubset( - const OUString& rToFile, - const vcl::font::PhysicalFontFace* pFont, - const sal_GlyphId* pGlyphIds, - const sal_uInt8* pEncoding, - int nGlyphCount, - FontSubsetInfo& rInfo - ) -{ - psp::PrintFontManager& rMgr = psp::PrintFontManager::get(); - bool bSuccess = rMgr.createFontSubset( rInfo, - pFont, - rToFile, - pGlyphIds, - pEncoding, - nGlyphCount ); - return bSuccess; -} - FontAttributes GenPspGraphics::Info2FontAttributes( const psp::FastPrintFontInfo& rInfo ) { FontAttributes aDFA; |