diff options
-rw-r--r-- | vcl/Library_vcl.mk | 1 | ||||
-rw-r--r-- | vcl/StaticLibrary_headless.mk | 1 | ||||
-rw-r--r-- | vcl/headless/svpbmp.cxx | 40 | ||||
-rw-r--r-- | vcl/headless/svpelement.cxx | 287 | ||||
-rw-r--r-- | vcl/headless/svpgdi.cxx | 2 | ||||
-rw-r--r-- | vcl/headless/svpvd.cxx | 1 | ||||
-rw-r--r-- | vcl/inc/headless/svpbmp.hxx | 13 | ||||
-rw-r--r-- | vcl/inc/headless/svpelement.hxx | 40 | ||||
-rw-r--r-- | vcl/inc/headless/svpframe.hxx | 9 | ||||
-rw-r--r-- | vcl/inc/headless/svpgdi.hxx | 1 | ||||
-rw-r--r-- | vcl/inc/headless/svpvd.hxx | 8 |
11 files changed, 57 insertions, 346 deletions
diff --git a/vcl/Library_vcl.mk b/vcl/Library_vcl.mk index 761f497a15f7..45bdcfd82550 100644 --- a/vcl/Library_vcl.mk +++ b/vcl/Library_vcl.mk @@ -496,7 +496,6 @@ vcl_generic_code= \ vcl_headless_code= \ vcl/headless/svpbmp \ vcl/headless/svpdummies \ - vcl/headless/svpelement \ vcl/headless/svpframe \ vcl/headless/svpgdi \ vcl/headless/svpinst \ diff --git a/vcl/StaticLibrary_headless.mk b/vcl/StaticLibrary_headless.mk index a64d9d41d9bb..1b6385157ec1 100644 --- a/vcl/StaticLibrary_headless.mk +++ b/vcl/StaticLibrary_headless.mk @@ -22,7 +22,6 @@ $(eval $(call gb_StaticLibrary_use_api,headless,\ $(eval $(call gb_StaticLibrary_add_exception_objects,headless,\ vcl/headless/svpbmp \ vcl/headless/svpdummies \ - vcl/headless/svpelement \ vcl/headless/svpframe \ vcl/headless/svpprn \ vcl/headless/svptext \ diff --git a/vcl/headless/svpbmp.cxx b/vcl/headless/svpbmp.cxx index 0b5eb52e7e72..cd5a2f9c4af5 100644 --- a/vcl/headless/svpbmp.cxx +++ b/vcl/headless/svpbmp.cxx @@ -349,5 +349,45 @@ bool SvpSalBitmap::GetSystemData( BitmapSystemData& ) return false; } +sal_uInt32 SvpSalBitmap::getBitCountFromScanlineFormat( sal_Int32 nFormat ) +{ + sal_uInt32 nBitCount = 1; + switch( nFormat ) + { + case Format::ONE_BIT_MSB_GREY: + case Format::ONE_BIT_LSB_GREY: + case Format::ONE_BIT_MSB_PAL: + case Format::ONE_BIT_LSB_PAL: + nBitCount = 1; + break; + case Format::FOUR_BIT_MSB_GREY: + case Format::FOUR_BIT_LSB_GREY: + case Format::FOUR_BIT_MSB_PAL: + case Format::FOUR_BIT_LSB_PAL: + nBitCount = 4; + break; + case Format::EIGHT_BIT_PAL: + case Format::EIGHT_BIT_GREY: + nBitCount = 8; + break; + case Format::SIXTEEN_BIT_LSB_TC_MASK: + case Format::SIXTEEN_BIT_MSB_TC_MASK: + nBitCount = 16; + break; + case Format::TWENTYFOUR_BIT_TC_MASK: + nBitCount = 24; + break; + case Format::THIRTYTWO_BIT_TC_MASK_BGRA: + case Format::THIRTYTWO_BIT_TC_MASK_ARGB: + case Format::THIRTYTWO_BIT_TC_MASK_ABGR: + case Format::THIRTYTWO_BIT_TC_MASK_RGBA: + nBitCount = 32; + break; + default: + OSL_FAIL( "unsupported basebmp format" ); + break; + } + return nBitCount; +} /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/headless/svpelement.cxx b/vcl/headless/svpelement.cxx deleted file mode 100644 index 8b6f3604ca41..000000000000 --- a/vcl/headless/svpelement.cxx +++ /dev/null @@ -1,287 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#include "headless/svpelement.hxx" - -#include <basebmp/scanlineformats.hxx> -#include <osl/diagnose.h> - -#if defined WITH_SVP_LISTENING -#include <osl/thread.h> -#include <vcl/svapp.hxx> -#include <rtl/strbuf.hxx> -#include <vcl/bitmap.hxx> -#include <tools/stream.hxx> - -#include "headless/svpvd.hxx" -#include "headless/svpbmp.hxx" -#include "headless/svpframe.hxx" - -#include <list> -#include <boost/unordered_map.hpp> - -#include <sys/types.h> -#include <sys/socket.h> -#include <netinet/ip.h> -#include <stdio.h> -#include <errno.h> - -using namespace basegfx; - -class SvpElementContainer -{ - std::list< SvpElement* > m_aElements; - int m_nSocket; - oslThread m_aThread; - - SvpElementContainer(); - ~SvpElementContainer(); - public: - void registerElement( SvpElement* pElement ) { m_aElements.push_back(pElement); } - void deregisterElement( SvpElement* pElement ) { m_aElements.remove(pElement); } - - void run(); - DECL_LINK(processRequest,void*); - - static SvpElementContainer& get(); -}; - -extern "C" void SAL_CALL SvpContainerThread( void* ); - -SvpElementContainer& SvpElementContainer::get() -{ - static SvpElementContainer* pInstance = new SvpElementContainer(); - return *pInstance; -} - -SvpElementContainer::SvpElementContainer() -{ - static const char* pEnv = getenv("SVP_LISTENER_PORT"); - int nPort = (pEnv && *pEnv) ? atoi(pEnv) : 8000; - m_nSocket = socket( PF_INET, SOCK_STREAM, 0 ); - if( m_nSocket >= 0) - { - int nOn = 1; - if( setsockopt(m_nSocket, SOL_SOCKET, SO_REUSEADDR, - (char*)&nOn, sizeof(nOn)) ) - { - perror( "SvpElementContainer: changing socket options failed" ); - close( m_nSocket ); - } - else - { - struct sockaddr_in addr; - memset(&addr, 0, sizeof(struct sockaddr_in)); - addr.sin_family = AF_INET; - addr.sin_port = htons(nPort); - addr.sin_addr.s_addr = INADDR_ANY; - if( bind(m_nSocket,(struct sockaddr*)&addr,sizeof(addr)) ) - { - perror( "SvpElementContainer: bind() failed" ); - close( m_nSocket ); - } - else - { - if( listen( m_nSocket, 0 ) ) - { - perror( "SvpElementContainer: listen() failed" ); - close(m_nSocket); - } - else - { - m_aThread = osl_createThread( SvpContainerThread, this ); - } - } - } - } - else - perror( "SvpElementContainer: socket() failed\n" ); -} - -SvpElementContainer::~SvpElementContainer() -{ -} - -void SAL_CALL SvpContainerThread(void* pSvpContainer) -{ - ((SvpElementContainer*)pSvpContainer)->run(); -} - -void SvpElementContainer::run() -{ - bool bRun = m_nSocket != 0; - while( bRun ) - { - int nLocalSocket = accept( m_nSocket, NULL, NULL ); - if( nLocalSocket < 0 ) - { - bRun = false; - perror( "accept() failed" ); - } - else - { - Application::PostUserEvent( LINK( this, SvpElementContainer, processRequest ), (void*)nLocalSocket ); - } - } - if( m_nSocket ) - close( m_nSocket ); -} - -static const char* matchType( SvpElement* pEle ) -{ - if( dynamic_cast<SvpSalBitmap*>(pEle) ) - return "Bitmap"; - else if( dynamic_cast<SvpSalFrame*>(pEle) ) - return "Frame"; - else if( dynamic_cast<SvpSalVirtualDevice*>(pEle) ) - return "VirtualDevice"; - return typeid(*pEle).name(); -} - -IMPL_LINK( SvpElementContainer, processRequest, void*, pSocket ) -{ - int nFile = (int)pSocket; - - OStringBuffer aBuf( 256 ), aAnswer( 256 ); - char c; - while( read( nFile, &c, 1 ) && c != '\n' ) - aBuf.append( sal_Char(c) ); - OString aCommand( aBuf.makeStringAndClear() ); - if( aCommand.startsWith( "list" ) ) - { - boost::unordered_map< OString, std::list<SvpElement*>, OStringHash > aMap; - for( std::list< SvpElement* >::const_iterator it = m_aElements.begin(); - it != m_aElements.end(); ++it ) - { - std::list<SvpElement*>& rList = aMap[matchType(*it)]; - rList.push_back( *it ); - } - for( boost::unordered_map< OString, std::list<SvpElement*>, OStringHash>::const_iterator hash_it = aMap.begin(); - hash_it != aMap.end(); ++hash_it ) - { - aAnswer.append( "ElementType: " ); - aAnswer.append( hash_it->first ); - aAnswer.append( '\n' ); - for( std::list<SvpElement*>::const_iterator it = hash_it->second.begin(); - it != hash_it->second.end(); ++it ) - { - aAnswer.append( sal_Int64(reinterpret_cast<sal_uInt32>(*it)), 16 ); - aAnswer.append( '\n' ); - } - } - } - else if( aCommand.startsWith( "get" ) ) - { - sal_IntPtr aId = aCommand.copy( 3 ).toInt64( 16 ); - SvpElement* pElement = reinterpret_cast<SvpElement*>(aId); - for( std::list< SvpElement* >::const_iterator it = m_aElements.begin(); - it != m_aElements.end(); ++it ) - { - if( *it == pElement ) - { - const basebmp::BitmapDeviceSharedPtr& rDevice = pElement->getDevice(); - if( rDevice.get() ) - { - SvpSalBitmap* pSalBitmap = new SvpSalBitmap(); - pSalBitmap->setBitmap( rDevice ); - Bitmap aBitmap( pSalBitmap ); - SvMemoryStream aStream( 256, 256 ); - aStream << aBitmap; - aStream.Seek( STREAM_SEEK_TO_END ); - int nBytes = aStream.Tell(); - aStream.Seek( STREAM_SEEK_TO_BEGIN ); - aAnswer.append( (const sal_Char*)aStream.GetData(), nBytes ); - } - break; - } - } - } - else if( aCommand.startsWith( "quit" ) ) - { - Application::Quit(); - close( m_nSocket ); - m_nSocket = 0; - } - write( nFile, aAnswer.getStr(), aAnswer.getLength() ); - close( nFile ); - - return 0; -} - -#endif - -using namespace basebmp; - -SvpElement::SvpElement() -{ - #if defined WITH_SVP_LISTENING - SvpElementContainer::get().registerElement( this ); - #endif -} - -SvpElement::~SvpElement() -{ - #if defined WITH_SVP_LISTENING - SvpElementContainer::get().deregisterElement( this ); - #endif -} - -sal_uInt32 SvpElement::getBitCountFromScanlineFormat( sal_Int32 nFormat ) -{ - sal_uInt32 nBitCount = 1; - switch( nFormat ) - { - case Format::ONE_BIT_MSB_GREY: - case Format::ONE_BIT_LSB_GREY: - case Format::ONE_BIT_MSB_PAL: - case Format::ONE_BIT_LSB_PAL: - nBitCount = 1; - break; - case Format::FOUR_BIT_MSB_GREY: - case Format::FOUR_BIT_LSB_GREY: - case Format::FOUR_BIT_MSB_PAL: - case Format::FOUR_BIT_LSB_PAL: - nBitCount = 4; - break; - case Format::EIGHT_BIT_PAL: - case Format::EIGHT_BIT_GREY: - nBitCount = 8; - break; - case Format::SIXTEEN_BIT_LSB_TC_MASK: - case Format::SIXTEEN_BIT_MSB_TC_MASK: - nBitCount = 16; - break; - case Format::TWENTYFOUR_BIT_TC_MASK: - nBitCount = 24; - break; - case Format::THIRTYTWO_BIT_TC_MASK_BGRA: - case Format::THIRTYTWO_BIT_TC_MASK_ARGB: - case Format::THIRTYTWO_BIT_TC_MASK_ABGR: - case Format::THIRTYTWO_BIT_TC_MASK_RGBA: - nBitCount = 32; - break; - default: - OSL_FAIL( "unsupported basebmp format" ); - break; - } - return nBitCount; -} - - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/headless/svpgdi.cxx b/vcl/headless/svpgdi.cxx index baab42e5d25d..5fd68ecf0e1f 100644 --- a/vcl/headless/svpgdi.cxx +++ b/vcl/headless/svpgdi.cxx @@ -131,7 +131,7 @@ void SvpSalGraphics::GetResolution( sal_Int32& rDPIX, sal_Int32& rDPIY ) sal_uInt16 SvpSalGraphics::GetBitCount() const { - return SvpElement::getBitCountFromScanlineFormat( m_aDevice->getScanlineFormat() ); + return SvpSalBitmap::getBitCountFromScanlineFormat( m_aDevice->getScanlineFormat() ); } long SvpSalGraphics::GetGraphicsWidth() const diff --git a/vcl/headless/svpvd.cxx b/vcl/headless/svpvd.cxx index 0ae794770537..990848553468 100644 --- a/vcl/headless/svpvd.cxx +++ b/vcl/headless/svpvd.cxx @@ -17,6 +17,7 @@ * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ +#include "headless/svpbmp.hxx" #include "headless/svpvd.hxx" #include "headless/svpgdi.hxx" diff --git a/vcl/inc/headless/svpbmp.hxx b/vcl/inc/headless/svpbmp.hxx index 9acc4b04d4e5..f769cf5e5687 100644 --- a/vcl/inc/headless/svpbmp.hxx +++ b/vcl/inc/headless/svpbmp.hxx @@ -20,10 +20,15 @@ #ifndef SVP_SVBMP_HXX #define SVP_SVBMP_HXX +#include "sal/config.h" + +#include "basebmp/bitmapdevice.hxx" + #include <salbmp.hxx> -#include "svpelement.hxx" -class SvpSalBitmap : public SalBitmap, public SvpElement +#define SVP_DEFAULT_BITMAP_FORMAT basebmp::Format::TWENTYFOUR_BIT_TC_MASK + +class SvpSalBitmap : public SalBitmap { basebmp::BitmapDeviceSharedPtr m_aBitmap; public: @@ -33,9 +38,6 @@ public: const basebmp::BitmapDeviceSharedPtr& getBitmap() const { return m_aBitmap; } void setBitmap( const basebmp::BitmapDeviceSharedPtr& rSrc ) { m_aBitmap = rSrc; } - // SvpElement - virtual const basebmp::BitmapDeviceSharedPtr& getDevice() const { return m_aBitmap; } - // SalBitmap virtual bool Create( const Size& rSize, sal_uInt16 nBitCount, @@ -56,6 +58,7 @@ public: virtual void ReleaseBuffer( BitmapBuffer* pBuffer, bool bReadOnly ); virtual bool GetSystemData( BitmapSystemData& rData ); + static sal_uInt32 getBitCountFromScanlineFormat( sal_Int32 nFormat ); }; #endif diff --git a/vcl/inc/headless/svpelement.hxx b/vcl/inc/headless/svpelement.hxx deleted file mode 100644 index 42c18812aa15..000000000000 --- a/vcl/inc/headless/svpelement.hxx +++ /dev/null @@ -1,40 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#ifndef _SVP_SVPELEMENT_HXX -#define _SVP_SVPELEMENT_HXX - -#include <basebmp/bitmapdevice.hxx> - -#define SVP_DEFAULT_BITMAP_FORMAT basebmp::Format::TWENTYFOUR_BIT_TC_MASK - -class SvpElement -{ - protected: - SvpElement(); - virtual ~SvpElement(); - public: - virtual const basebmp::BitmapDeviceSharedPtr& getDevice() const = 0; - - static sal_uInt32 getBitCountFromScanlineFormat( sal_Int32 nFormat ); -}; - -#endif - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/inc/headless/svpframe.hxx b/vcl/inc/headless/svpframe.hxx index 112e552298b9..4a052c079197 100644 --- a/vcl/inc/headless/svpframe.hxx +++ b/vcl/inc/headless/svpframe.hxx @@ -21,9 +21,9 @@ #include <vcl/sysdata.hxx> #include <basegfx/range/b2ibox.hxx> +#include <basebmp/bitmapdevice.hxx> #include <salframe.hxx> -#include "svpelement.hxx" #include <list> @@ -34,7 +34,7 @@ class SvpSalInstance; class SvpSalGraphics; -class SvpSalFrame : public SalFrame, public SvpElement +class SvpSalFrame : public SalFrame { SvpSalInstance* m_pInstance; SvpSalFrame* m_pParent; // pointer to parent frame @@ -69,8 +69,9 @@ public: void PostPaint(bool bImmediate) const; void AllocateFrame(); - // SvpElement - virtual const basebmp::BitmapDeviceSharedPtr& getDevice() const { return m_aFrame; } +#if defined IOS || defined ANDROID + const basebmp::BitmapDeviceSharedPtr& getDevice() const { return m_aFrame; } +#endif // SalFrame virtual SalGraphics* GetGraphics(); diff --git a/vcl/inc/headless/svpgdi.hxx b/vcl/inc/headless/svpgdi.hxx index be80d29f13b5..275789958c7f 100644 --- a/vcl/inc/headless/svpgdi.hxx +++ b/vcl/inc/headless/svpgdi.hxx @@ -104,7 +104,6 @@ public: SvpSalGraphics(); virtual ~SvpSalGraphics(); - const basebmp::BitmapDeviceSharedPtr& getDevice() const { return m_aDevice; } void setDevice( basebmp::BitmapDeviceSharedPtr& rDevice ); virtual void GetResolution( sal_Int32& rDPIX, sal_Int32& rDPIY ); diff --git a/vcl/inc/headless/svpvd.hxx b/vcl/inc/headless/svpvd.hxx index 8650a013e369..2bb850d10e50 100644 --- a/vcl/inc/headless/svpvd.hxx +++ b/vcl/inc/headless/svpvd.hxx @@ -21,7 +21,6 @@ #define _SVP_SVPVD_HXX #include <salvd.hxx> -#include "svpelement.hxx" #include <list> @@ -31,19 +30,16 @@ class SvpSalGraphics; -class SvpSalVirtualDevice : public SalVirtualDevice, public SvpElement +class SvpSalVirtualDevice : public SalVirtualDevice { sal_uInt16 m_nBitCount; basebmp::BitmapDeviceSharedPtr m_aDevice; std::list< SvpSalGraphics* > m_aGraphics; public: - SvpSalVirtualDevice( sal_uInt16 nBitCount ) : SvpElement(), m_nBitCount(nBitCount) {} + SvpSalVirtualDevice( sal_uInt16 nBitCount ) : m_nBitCount(nBitCount) {} virtual ~SvpSalVirtualDevice(); - // SvpElement - virtual const basebmp::BitmapDeviceSharedPtr& getDevice() const { return m_aDevice; } - // SalVirtualDevice virtual SalGraphics* GetGraphics(); virtual void ReleaseGraphics( SalGraphics* pGraphics ); |