diff options
author | Caolán McNamara <caolanm@redhat.com> | 2011-02-06 13:47:35 +0000 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2011-02-09 14:33:20 +0000 |
commit | cea018b386018d32dd9a762dfddd5bf316f218aa (patch) | |
tree | 7555e13536d44e10d72babd69074b95bc2b2207b /vcl/unx | |
parent | 052a4a89ed6293298b930b52de9e53837dd908e3 (diff) |
Resolves: fdo#33510 A way to query about likely font layout capabilities
Diffstat (limited to 'vcl/unx')
-rw-r--r-- | vcl/unx/headless/svpgdi.hxx | 1 | ||||
-rw-r--r-- | vcl/unx/headless/svppspgraphics.cxx | 7 | ||||
-rw-r--r-- | vcl/unx/headless/svppspgraphics.hxx | 1 | ||||
-rw-r--r-- | vcl/unx/headless/svptext.cxx | 8 | ||||
-rw-r--r-- | vcl/unx/inc/pspgraphics.h | 1 | ||||
-rw-r--r-- | vcl/unx/inc/salgdi.h | 1 | ||||
-rw-r--r-- | vcl/unx/source/gdi/pspgraphics.cxx | 7 | ||||
-rw-r--r-- | vcl/unx/source/gdi/salgdi3.cxx | 7 |
8 files changed, 33 insertions, 0 deletions
diff --git a/vcl/unx/headless/svpgdi.hxx b/vcl/unx/headless/svpgdi.hxx index b2c579319046..4bd9b3a4b222 100644 --- a/vcl/unx/headless/svpgdi.hxx +++ b/vcl/unx/headless/svpgdi.hxx @@ -90,6 +90,7 @@ public: virtual void GetFontMetric( ImplFontMetricData*, int nFallbackLevel ); virtual ULONG GetKernPairs( ULONG nPairs, ImplKernPairData* pKernPairs ); virtual ImplFontCharMap* GetImplFontCharMap() const; + virtual bool GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const; virtual void GetDevFontList( ImplDevFontList* ); virtual void GetDevFontSubstList( OutputDevice* ); virtual bool AddTempDevFont( ImplDevFontList*, const String& rFileURL, const String& rFontName ); diff --git a/vcl/unx/headless/svppspgraphics.cxx b/vcl/unx/headless/svppspgraphics.cxx index 99a3eb3cffbc..07271edfcb15 100644 --- a/vcl/unx/headless/svppspgraphics.cxx +++ b/vcl/unx/headless/svppspgraphics.cxx @@ -696,6 +696,13 @@ ImplFontCharMap* PspGraphics::GetImplFontCharMap() const return new ImplFontCharMap( aCmapResult ); } +bool PspGraphics::GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const +{ + if (!m_pServerFont[0]) + return NULL; + return !m_pServerFont[0]->GetFontLayoutCapabilities(rGetImplFontLayoutCapabilities); +} + USHORT PspGraphics::SetFont( ImplFontSelectData *pEntry, int nFallbackLevel ) { // release all fonts that are to be overridden diff --git a/vcl/unx/headless/svppspgraphics.hxx b/vcl/unx/headless/svppspgraphics.hxx index df25696d5489..ca6bbc37d378 100644 --- a/vcl/unx/headless/svppspgraphics.hxx +++ b/vcl/unx/headless/svppspgraphics.hxx @@ -109,6 +109,7 @@ public: virtual void GetFontMetric( ImplFontMetricData*, int nFallbackLevel ); virtual ULONG GetKernPairs( ULONG nPairs, ImplKernPairData* pKernPairs ); virtual ImplFontCharMap* GetImplFontCharMap() const; + virtual bool GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const; virtual void GetDevFontList( ImplDevFontList* ); virtual void GetDevFontSubstList( OutputDevice* ); virtual bool AddTempDevFont( ImplDevFontList*, const String& rFileURL, const String& rFontName ); diff --git a/vcl/unx/headless/svptext.cxx b/vcl/unx/headless/svptext.cxx index d299d6816401..8667e5302df7 100644 --- a/vcl/unx/headless/svptext.cxx +++ b/vcl/unx/headless/svptext.cxx @@ -282,6 +282,14 @@ ImplFontCharMap* SvpSalGraphics::GetImplFontCharMap() const return new ImplFontCharMap( aCmapResult ); } +bool SvpSalGraphics::GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const +{ + if (!m_pServerFont[0]) + return NULL; + + return !m_pServerFont[0]->GetFontLayoutCapabilities( rGetImplFontLayoutCapabilities); +} + // --------------------------------------------------------------------------- void SvpSalGraphics::GetDevFontList( ImplDevFontList* pDevFontList ) diff --git a/vcl/unx/inc/pspgraphics.h b/vcl/unx/inc/pspgraphics.h index 25bd1933b8a9..7fc18eeba2c9 100644 --- a/vcl/unx/inc/pspgraphics.h +++ b/vcl/unx/inc/pspgraphics.h @@ -106,6 +106,7 @@ public: virtual void GetFontMetric( ImplFontMetricData*, int nFallbackLevel ); virtual ULONG GetKernPairs( ULONG nMaxPairs, ImplKernPairData* ); virtual ImplFontCharMap* GetImplFontCharMap() const; + virtual bool GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const; virtual void GetDevFontList( ImplDevFontList* ); virtual void GetDevFontSubstList( OutputDevice* ); virtual bool AddTempDevFont( ImplDevFontList*, const String& rFileURL, const String& rFontName ); diff --git a/vcl/unx/inc/salgdi.h b/vcl/unx/inc/salgdi.h index 333540d9b1fd..7b3841010a90 100644 --- a/vcl/unx/inc/salgdi.h +++ b/vcl/unx/inc/salgdi.h @@ -257,6 +257,7 @@ public: virtual void GetFontMetric( ImplFontMetricData*, int nFallbackLevel ); virtual ULONG GetKernPairs( ULONG nMaxPairs, ImplKernPairData* ); virtual ImplFontCharMap* GetImplFontCharMap() const; + virtual bool GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const; virtual void GetDevFontList( ImplDevFontList* ); virtual void GetDevFontSubstList( OutputDevice* ); virtual bool AddTempDevFont( ImplDevFontList*, const String& rFileURL, const String& rFontName ); diff --git a/vcl/unx/source/gdi/pspgraphics.cxx b/vcl/unx/source/gdi/pspgraphics.cxx index cb481be37b83..50f6586bbf58 100644 --- a/vcl/unx/source/gdi/pspgraphics.cxx +++ b/vcl/unx/source/gdi/pspgraphics.cxx @@ -780,6 +780,13 @@ ImplFontCharMap* PspGraphics::GetImplFontCharMap() const return new ImplFontCharMap( aCmapResult ); } +bool PspGraphics::GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const +{ + if (!m_pServerFont[0]) + return NULL; + return !m_pServerFont[0]->GetFontLayoutCapabilities(rGetImplFontLayoutCapabilities); +} + USHORT PspGraphics::SetFont( ImplFontSelectData *pEntry, int nFallbackLevel ) { // release all fonts that are to be overridden diff --git a/vcl/unx/source/gdi/salgdi3.cxx b/vcl/unx/source/gdi/salgdi3.cxx index 86daa8a4e463..fcc60964d101 100644 --- a/vcl/unx/source/gdi/salgdi3.cxx +++ b/vcl/unx/source/gdi/salgdi3.cxx @@ -1497,6 +1497,13 @@ ImplFontCharMap* X11SalGraphics::GetImplFontCharMap() const return new ImplFontCharMap( aCmapResult ); } +bool X11SalGraphics::GetImplFontLayoutCapabilities(FontLayoutCapabilities &rGetImplFontLayoutCapabilities) const +{ + if (!mpServerFont[0]) + return NULL; + return !mpServerFont[0]->GetFontLayoutCapabilities(rGetImplFontLayoutCapabilities); +} + // ---------------------------------------------------------------------------- // // SalGraphics |