diff options
Diffstat (limited to 'padmin/source/helper.cxx')
-rw-r--r-- | padmin/source/helper.cxx | 325 |
1 files changed, 325 insertions, 0 deletions
diff --git a/padmin/source/helper.cxx b/padmin/source/helper.cxx new file mode 100644 index 000000000000..0a1cee5e557f --- /dev/null +++ b/padmin/source/helper.cxx @@ -0,0 +1,325 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +#include <unistd.h> +#include <helper.hxx> +#include <padialog.hrc> +#include <osl/file.hxx> +#include <tools/urlobj.hxx> +#include <vcl/svapp.hxx> +#include <vcl/msgbox.hxx> +#include <tools/config.hxx> +#include <com/sun/star/ui/dialogs/ExecutableDialogResults.hpp> +#include <com/sun/star/ui/dialogs/XFolderPicker.hpp> +#include <com/sun/star/ui/dialogs/XControlAccess.hpp> +#include <com/sun/star/lang/XMultiServiceFactory.hpp> +#include <comphelper/processfactory.hxx> +#include <tools/urlobj.hxx> +#include <unotools/confignode.hxx> +#include <vcl/unohelp.hxx> +#include <i18npool/mslangid.hxx> +#include <rtl/ustrbuf.hxx> + + +using namespace osl; +using namespace padmin; +using namespace com::sun::star::uno; +using namespace com::sun::star::lang; +using namespace com::sun::star::ui::dialogs; + +using ::rtl::OUString; +using ::rtl::OUStringBuffer; + +#define MAX_PATH 1024 + +/* + * PaResId + */ + +ResId padmin::PaResId( sal_uInt32 nId ) +{ + static ResMgr* pPaResMgr = NULL; + if( ! pPaResMgr ) + { + ::com::sun::star::lang::Locale aLocale; + + utl::OConfigurationNode aNode = + utl::OConfigurationTreeRoot::tryCreateWithServiceFactory( + vcl::unohelper::GetMultiServiceFactory(), + OUString(RTL_CONSTASCII_USTRINGPARAM("org.openoffice.Setup/L10N")) ); + if ( aNode.isValid() ) + { + rtl::OUString aLoc; + Any aValue = aNode.getNodeValue( OUString(RTL_CONSTASCII_USTRINGPARAM("ooLocale")) ); + if( aValue >>= aLoc ) + { + sal_Int32 nIndex = 0; + aLocale.Language = aLoc.getToken( 0, '-', nIndex ); + aLocale.Country = aLoc.getToken( 0, '-', nIndex ); + aLocale.Variant = aLoc.getToken( 0, '-', nIndex ); + } + } + pPaResMgr = ResMgr::SearchCreateResMgr( "spa", aLocale ); + AllSettings aSettings = Application::GetSettings(); + aSettings.SetUILocale( aLocale ); + Application::SetSettings( aSettings ); + } + return ResId( nId, *pPaResMgr ); +} + +/* + * FindFiles + */ + +void padmin::FindFiles( const String& rDirectory, ::std::list< String >& rResult, const String& rSuffixes, bool bRecursive ) +{ + rResult.clear(); + + OUString aDirPath; + ::osl::FileBase::getFileURLFromSystemPath( rDirectory, aDirPath ); + Directory aDir( aDirPath ); + if( aDir.open() != FileBase::E_None ) + return; + DirectoryItem aItem; + while( aDir.getNextItem( aItem ) == FileBase::E_None ) + { + FileStatus aStatus( osl_FileStatus_Mask_FileName | + osl_FileStatus_Mask_Type + ); + if( aItem.getFileStatus( aStatus ) == FileBase::E_None ) + { + if( aStatus.getFileType() == FileStatus::Regular || + aStatus.getFileType() == FileStatus::Link ) + { + String aFileName = aStatus.getFileName(); + int nToken = rSuffixes.GetTokenCount( ';' ); + while( nToken-- ) + { + String aSuffix = rSuffixes.GetToken( nToken, ';' ); + if( aFileName.Len() > aSuffix.Len()+1 ) + { + String aExtension = aFileName.Copy( aFileName.Len()-aSuffix.Len() ); + if( aFileName.GetChar( aFileName.Len()-aSuffix.Len()-1 ) == '.' && + aExtension.EqualsIgnoreCaseAscii( aSuffix ) ) + { + rResult.push_back( aFileName ); + break; + } + } + } + } + else if( bRecursive && aStatus.getFileType() == FileStatus::Directory ) + { + OUStringBuffer aSubDir( rDirectory ); + aSubDir.appendAscii( "/", 1 ); + aSubDir.append( aStatus.getFileName() ); + std::list< String > subfiles; + FindFiles( aSubDir.makeStringAndClear(), subfiles, rSuffixes, bRecursive ); + for( std::list< String >::const_iterator it = subfiles.begin(); it != subfiles.end(); ++it ) + { + OUStringBuffer aSubFile( aStatus.getFileName() ); + aSubFile.appendAscii( "/", 1 ); + aSubFile.append( *it ); + rResult.push_back( aSubFile.makeStringAndClear() ); + } + } + } + } + aDir.close(); +} + +/* + * DelMultiListBox + */ + +long DelMultiListBox::Notify( NotifyEvent& rEvent ) +{ + long nRet = 0; + + if( rEvent.GetType() == EVENT_KEYINPUT && + rEvent.GetKeyEvent()->GetKeyCode().GetCode() == KEY_DELETE ) + { + m_aDelPressedLink.Call( this ); + nRet = 1; + } + else + nRet = MultiListBox::Notify( rEvent ); + + return nRet; +} + +/* + * DelListBox + */ + +long DelListBox::Notify( NotifyEvent& rEvent ) +{ + long nRet = 0; + + if( rEvent.GetType() == EVENT_KEYINPUT && + rEvent.GetKeyEvent()->GetKeyCode().GetCode() == KEY_DELETE ) + { + m_aDelPressedLink.Call( this ); + nRet = 1; + } + else + nRet = ListBox::Notify( rEvent ); + + return nRet; +} + +/* + * QueryString + */ + +QueryString::QueryString( Window* pParent, String& rQuery, String& rRet, const ::std::list< String >& rChoices ) : + ModalDialog( pParent, PaResId( RID_STRINGQUERYDLG ) ), + m_aOKButton( this, PaResId( RID_STRQRY_BTN_OK ) ), + m_aCancelButton( this, PaResId( RID_STRQRY_BTN_CANCEL ) ), + m_aFixedText( this, PaResId( RID_STRQRY_TXT_RENAME ) ), + m_aEdit( this, PaResId( RID_STRQRY_EDT_NEWNAME ) ), + m_aComboBox( this, PaResId( RID_STRQRY_BOX_NEWNAME ) ), + m_rReturnValue( rRet ) +{ + FreeResource(); + m_aOKButton.SetClickHdl( LINK( this, QueryString, ClickBtnHdl ) ); + m_aFixedText.SetText( rQuery ); + if( rChoices.begin() != rChoices.end() ) + { + m_aComboBox.SetText( m_rReturnValue ); + m_aComboBox.InsertEntry( m_rReturnValue ); + for( ::std::list<String>::const_iterator it = rChoices.begin(); it != rChoices.end(); ++it ) + m_aComboBox.InsertEntry( *it ); + m_aEdit.Show( sal_False ); + m_bUseEdit = false; + } + else + { + m_aEdit.SetText( m_rReturnValue ); + m_aComboBox.Show( sal_False ); + m_bUseEdit = true; + } + SetText( Application::GetDisplayName() ); +} + +QueryString::~QueryString() +{ +} + +IMPL_LINK( QueryString, ClickBtnHdl, Button*, pButton ) +{ + if( pButton == &m_aOKButton ) + { + m_rReturnValue = m_bUseEdit ? m_aEdit.GetText() : m_aComboBox.GetText(); + EndDialog( 1 ); + } + else + EndDialog(0); + return 0; +} + +/* + * AreYouSure + */ + +sal_Bool padmin::AreYouSure( Window* pParent, int nRid ) +{ + if( nRid == -1 ) + nRid = RID_YOU_SURE; + QueryBox aQueryBox( pParent, WB_YES_NO | WB_DEF_NO, + String( PaResId( nRid ) ) ); + return aQueryBox.Execute() == RET_NO ? sal_False : sal_True; +} + +/* + * getPadminRC + */ + +static Config* pRC = NULL; + +Config& padmin::getPadminRC() +{ + if( ! pRC ) + { + static const char* pEnv = getenv( "HOME" ); + String aFileName( pEnv ? pEnv : "", osl_getThreadTextEncoding() ); + aFileName.AppendAscii( "/.padminrc" ); + pRC = new Config( aFileName ); + } + return *pRC; +} + +void padmin::freePadminRC() +{ + if( pRC ) + delete pRC, pRC = NULL; +} + +bool padmin::chooseDirectory( String& rInOutPath ) +{ + bool bRet = false; + Reference< XMultiServiceFactory > xFactory( ::comphelper::getProcessServiceFactory() ); + if( xFactory.is() ) + { + Reference< XFolderPicker > xFolderPicker( xFactory->createInstance( OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.ui.dialogs.FolderPicker" ) ) ), UNO_QUERY ); + if( xFolderPicker.is() ) + { + Reference< XControlAccess > xCA( xFolderPicker, UNO_QUERY ); + if( xCA.is() ) + { + try + { + Any aState; + aState <<= sal_False; + xCA->setControlProperty( OUString( RTL_CONSTASCII_USTRINGPARAM( "HelpButton" ) ), + OUString( RTL_CONSTASCII_USTRINGPARAM( "Visible" ) ), + aState ); + + } + catch( ... ) + { + } + } + INetURLObject aObj( rInOutPath, INET_PROT_FILE, INetURLObject::ENCODE_ALL ); + xFolderPicker->setDisplayDirectory( aObj.GetMainURL(INetURLObject::DECODE_TO_IURI) ); + if( xFolderPicker->execute() == ExecutableDialogResults::OK ) + { + aObj = INetURLObject( xFolderPicker->getDirectory() ); + rInOutPath = aObj.PathToFileName(); + bRet = true; + } + } +#if OSL_DEBUG_LEVEL > 1 + else + fprintf( stderr, "could not get FolderPicker service\n" ); +#endif + } + return bRet; +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |