diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2015-04-17 16:16:41 +0200 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2015-04-17 16:16:41 +0200 |
commit | d457c25c491267999b1f82f2b4f76f7ccbe9cf37 (patch) | |
tree | b0da669a7fdf89a6c2234ea60e60d9659222acdb /vcl | |
parent | c9519a210523c732188a494c14ac212db43463e5 (diff) |
Blind fix for ImplPixelFormat16
As pointed out by tml on IRC, its implementation looks completely bogus, and
together with the previous 40a26be24bd64a6c7c8cc98228fd440c8b9323b5
"loplugin:implicitboolconversion gold" that gives rise to the suspicion that the
class is effectively unused anyway.
Change-Id: If5fa5cdd1dac51f10dba7c77ad9975ee61ccc8be
Diffstat (limited to 'vcl')
-rw-r--r-- | vcl/quartz/salbmp.cxx | 23 |
1 files changed, 14 insertions, 9 deletions
diff --git a/vcl/quartz/salbmp.cxx b/vcl/quartz/salbmp.cxx index a0e5ca4e8b2a..2bb7b290e8fc 100644 --- a/vcl/quartz/salbmp.cxx +++ b/vcl/quartz/salbmp.cxx @@ -334,12 +334,10 @@ namespace { class ImplPixelFormat { -protected: - sal_uInt8* pData; public: static ImplPixelFormat* GetFormat( sal_uInt16 nBits, const BitmapPalette& rPalette ); - virtual void StartLine( sal_uInt8* pLine ) { pData = pLine; } + virtual void StartLine( sal_uInt8* pLine ) = 0; virtual void SkipPixel( sal_uInt32 nPixel ) = 0; virtual ColorData ReadPixel() = 0; virtual void WritePixel( ColorData nColor ) = 0; @@ -349,7 +347,9 @@ public: class ImplPixelFormat32 : public ImplPixelFormat // currently ARGB-format for 32bit depth { + sal_uInt8* pData; public: + virtual void StartLine( sal_uInt8* pLine ) SAL_OVERRIDE { pData = pLine; } virtual void SkipPixel( sal_uInt32 nPixel ) SAL_OVERRIDE { pData += nPixel << 2; @@ -372,7 +372,9 @@ public: class ImplPixelFormat24 : public ImplPixelFormat // currently BGR-format for 24bit depth { + sal_uInt8* pData; public: + virtual void StartLine( sal_uInt8* pLine ) SAL_OVERRIDE { pData = pLine; } virtual void SkipPixel( sal_uInt32 nPixel ) SAL_OVERRIDE { pData += (nPixel << 1) + nPixel; @@ -394,13 +396,12 @@ public: class ImplPixelFormat16 : public ImplPixelFormat // currently R5G6B5-format for 16bit depth { -protected: - sal_uInt16* pData16; + sal_uInt16* pData; public: virtual void StartLine( sal_uInt8* pLine ) SAL_OVERRIDE { - pData16 = reinterpret_cast<sal_uInt16*>(pLine); + pData = reinterpret_cast<sal_uInt16*>(pLine); } virtual void SkipPixel( sal_uInt32 nPixel ) SAL_OVERRIDE { @@ -408,14 +409,14 @@ public: } virtual ColorData ReadPixel() SAL_OVERRIDE { - const ColorData c = RGB_COLORDATA( (*pData & 0x7c00) >> 7, (*pData & 0x03e0) >> 2 , (*pData & 0x001f) << 3 ); + const ColorData c = RGB_COLORDATA( (*pData & 0xf800) >> 8, (*pData & 0x07e0) >> 3 , (*pData & 0x001f) << 3 ); pData++; return c; } virtual void WritePixel( ColorData nColor ) SAL_OVERRIDE { - *pData++ = ((COLORDATA_RED( nColor ) & 0xf8 ) << 7 ) | - ((COLORDATA_GREEN( nColor ) & 0xf8 ) << 2 ) | + *pData++ = ((COLORDATA_RED( nColor ) & 0xf8 ) << 8 ) | + ((COLORDATA_GREEN( nColor ) & 0xfc ) << 3 ) | ((COLORDATA_BLUE( nColor ) & 0xf8 ) >> 3 ); } }; @@ -423,6 +424,7 @@ public: class ImplPixelFormat8 : public ImplPixelFormat { private: + sal_uInt8* pData; const BitmapPalette& mrPalette; public: @@ -430,6 +432,7 @@ public: : mrPalette( rPalette ) { } + virtual void StartLine( sal_uInt8* pLine ) SAL_OVERRIDE { pData = pLine; } virtual void SkipPixel( sal_uInt32 nPixel ) SAL_OVERRIDE { pData += nPixel; @@ -448,6 +451,7 @@ public: class ImplPixelFormat4 : public ImplPixelFormat { private: + sal_uInt8* pData; const BitmapPalette& mrPalette; sal_uInt32 mnX; sal_uInt32 mnShift; @@ -489,6 +493,7 @@ public: class ImplPixelFormat1 : public ImplPixelFormat { private: + sal_uInt8* pData; const BitmapPalette& mrPalette; sal_uInt32 mnX; |