Merge remote-tracking branch 'origin/libreoffice-3-4'
Conflicts: cui/source/options/optchart.cxx
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
*
|
*
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
@@ -25,29 +26,37 @@
|
|||||||
*
|
*
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
|
|
||||||
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
||||||
#include "precompiled_cui.hxx"
|
|
||||||
|
|
||||||
// include ---------------------------------------------------------------
|
// include ---------------------------------------------------------------
|
||||||
|
|
||||||
#include <vcl/svapp.hxx>
|
#include <vcl/svapp.hxx>
|
||||||
#include <vcl/msgbox.hxx>
|
#include <vcl/msgbox.hxx>
|
||||||
|
|
||||||
#include <tools/stream.hxx>
|
#include <tools/stream.hxx>
|
||||||
#include <tools/urlobj.hxx>
|
#include <tools/urlobj.hxx>
|
||||||
#include <rtl/bootstrap.hxx>
|
#include <rtl/bootstrap.hxx>
|
||||||
#include <unotools/configmgr.hxx>
|
#include <unotools/configmgr.hxx>
|
||||||
#include <unotools/bootstrap.hxx>
|
#include <unotools/bootstrap.hxx>
|
||||||
#include <com/sun/star/uno/Any.h>
|
#include <com/sun/star/uno/Any.h>
|
||||||
|
#include <unotools/configmgr.hxx>
|
||||||
|
#include <vcl/svapp.hxx>
|
||||||
#include <vcl/graph.hxx>
|
#include <vcl/graph.hxx>
|
||||||
#include <svtools/filter.hxx>
|
#include <svtools/filter.hxx>
|
||||||
|
|
||||||
|
#include "com/sun/star/system/SystemShellExecuteFlags.hpp"
|
||||||
|
#include "com/sun/star/system/XSystemShellExecute.hpp"
|
||||||
|
#include <comphelper/processfactory.hxx>
|
||||||
|
#include "comphelper/anytostring.hxx"
|
||||||
|
#include "cppuhelper/exc_hlp.hxx"
|
||||||
|
#include "cppuhelper/bootstrap.hxx"
|
||||||
|
|
||||||
#include <sfx2/sfxuno.hxx>
|
#include <sfx2/sfxuno.hxx>
|
||||||
|
#include <sfx2/sfxcommands.h>
|
||||||
#include "about.hxx"
|
#include "about.hxx"
|
||||||
|
#include "about.hrc"
|
||||||
#include <sfx2/sfxdefs.hxx>
|
#include <sfx2/sfxdefs.hxx>
|
||||||
#include <sfx2/app.hxx>
|
#include <sfx2/app.hxx>
|
||||||
#include <sfx2/sfxcommands.h>
|
|
||||||
#include "about.hrc"
|
using namespace ::com::sun::star;
|
||||||
#include <dialmgr.hxx>
|
|
||||||
#include <svtools/svtools.hrc>
|
|
||||||
|
|
||||||
// defines ---------------------------------------------------------------
|
// defines ---------------------------------------------------------------
|
||||||
|
|
||||||
@@ -55,26 +64,17 @@
|
|||||||
#define SPACE_OFFSET 5
|
#define SPACE_OFFSET 5
|
||||||
#define SCROLL_TIMER 30
|
#define SCROLL_TIMER 30
|
||||||
|
|
||||||
#define WELCOME_URL DEFINE_CONST_UNICODE( "http://www.openoffice.org/welcome/credits.html" )
|
/** loads the application logo as used in the about dialog and impress slideshow pause screen */
|
||||||
|
Image SfxApplication::GetApplicationLogo()
|
||||||
// class AboutDialog -----------------------------------------------------
|
|
||||||
static void layoutText( FixedInfo &rText, long &nY, long nTextWidth, Size a6Size )
|
|
||||||
{
|
{
|
||||||
Point aTextPos = rText.GetPosPixel();
|
BitmapEx aBitmap;
|
||||||
aTextPos.X() = a6Size.Width() * 2;
|
Application::LoadBrandBitmap ("about", aBitmap);
|
||||||
aTextPos.Y() = nY;
|
return Image( aBitmap );
|
||||||
rText.SetPosPixel( aTextPos );
|
|
||||||
|
|
||||||
Size aTxtSiz = rText.GetSizePixel();
|
|
||||||
aTxtSiz.Width() = nTextWidth;
|
|
||||||
Size aCalcSize = rText.CalcMinimumSize( nTextWidth );
|
|
||||||
aTxtSiz.Height() = aCalcSize.Height();
|
|
||||||
rText.SetSizePixel( aTxtSiz );
|
|
||||||
|
|
||||||
nY += aTxtSiz.Height();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String InitDevVersionStr()
|
/* intense magic to get strong version information */
|
||||||
|
static String
|
||||||
|
GetBuildId()
|
||||||
{
|
{
|
||||||
const String sCWSSchema( String::CreateFromAscii( "[CWS:" ) );
|
const String sCWSSchema( String::CreateFromAscii( "[CWS:" ) );
|
||||||
rtl::OUString sDefault;
|
rtl::OUString sDefault;
|
||||||
@@ -83,8 +83,7 @@ String InitDevVersionStr()
|
|||||||
if ( sBuildId.Len() > 0 && sBuildId.Search( sCWSSchema ) == STRING_NOTFOUND )
|
if ( sBuildId.Len() > 0 && sBuildId.Search( sCWSSchema ) == STRING_NOTFOUND )
|
||||||
{
|
{
|
||||||
// no cws part in brand buildid -> try basis buildid
|
// no cws part in brand buildid -> try basis buildid
|
||||||
rtl::OUString sBasisBuildId( DEFINE_CONST_OUSTRING(
|
rtl::OUString sBasisBuildId( DEFINE_CONST_OUSTRING("${$OOO_BASE_DIR/program/" SAL_CONFIGFILE("version") ":buildid}" ) );
|
||||||
"${$OOO_BASE_DIR/program/" SAL_CONFIGFILE("version") ":buildid}" ) );
|
|
||||||
rtl::Bootstrap::expandMacros( sBasisBuildId );
|
rtl::Bootstrap::expandMacros( sBasisBuildId );
|
||||||
sal_Int32 nIndex = sBasisBuildId.indexOf( sCWSSchema );
|
sal_Int32 nIndex = sBasisBuildId.indexOf( sCWSSchema );
|
||||||
if ( nIndex != -1 )
|
if ( nIndex != -1 )
|
||||||
@@ -100,7 +99,7 @@ String InitDevVersionStr()
|
|||||||
if ( sProductSource.Len() )
|
if ( sProductSource.Len() )
|
||||||
{
|
{
|
||||||
bool bMatchingUPD =
|
bool bMatchingUPD =
|
||||||
( sProductSource.Len() >= 3 )
|
( sProductSource.Len() >= 3 )
|
||||||
&& ( sBuildId.Len() >= 3 )
|
&& ( sBuildId.Len() >= 3 )
|
||||||
&& ( sProductSource.Copy( sProductSource.Len() - 3 ) == sBuildId.Copy( 0, 3 ) );
|
&& ( sProductSource.Copy( sProductSource.Len() - 3 ) == sBuildId.Copy( 0, 3 ) );
|
||||||
OSL_ENSURE( bMatchingUPD, "BUILDID and ProductSource do not match in their UPD" );
|
OSL_ENSURE( bMatchingUPD, "BUILDID and ProductSource do not match in their UPD" );
|
||||||
@@ -111,17 +110,15 @@ String InitDevVersionStr()
|
|||||||
sBuildId.Insert( sProductSource, 0 );
|
sBuildId.Insert( sProductSource, 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
// --> PB 2008-10-30 #i94693#
|
// Version information (in about box) (#i94693#)
|
||||||
// if the build ids of the basis or ure layer are different from the build id
|
/* if the build ids of the basis or ure layer are different from the build id
|
||||||
// of the brand layer then show them
|
* of the brand layer then show them */
|
||||||
rtl::OUString aBasisProductBuildId( DEFINE_CONST_OUSTRING(
|
rtl::OUString aBasisProductBuildId( DEFINE_CONST_OUSTRING("${$OOO_BASE_DIR/program/" SAL_CONFIGFILE("version") ":ProductBuildid}" ) );
|
||||||
"${$OOO_BASE_DIR/program/" SAL_CONFIGFILE("version") ":ProductBuildid}" ) );
|
|
||||||
rtl::Bootstrap::expandMacros( aBasisProductBuildId );
|
rtl::Bootstrap::expandMacros( aBasisProductBuildId );
|
||||||
rtl::OUString aUREProductBuildId( DEFINE_CONST_OUSTRING(
|
rtl::OUString aUREProductBuildId( DEFINE_CONST_OUSTRING("${$URE_BIN_DIR/" SAL_CONFIGFILE("version") ":ProductBuildid}" ) );
|
||||||
"${$URE_BIN_DIR/" SAL_CONFIGFILE("version") ":ProductBuildid}" ) );
|
|
||||||
rtl::Bootstrap::expandMacros( aUREProductBuildId );
|
rtl::Bootstrap::expandMacros( aUREProductBuildId );
|
||||||
if ( sBuildId.Search( String( aBasisProductBuildId ) ) == STRING_NOTFOUND
|
if ( sBuildId.Search( String( aBasisProductBuildId ) ) == STRING_NOTFOUND
|
||||||
|| sBuildId.Search( String( aUREProductBuildId ) ) == STRING_NOTFOUND )
|
|| sBuildId.Search( String( aUREProductBuildId ) ) == STRING_NOTFOUND )
|
||||||
{
|
{
|
||||||
String sTemp( '-' );
|
String sTemp( '-' );
|
||||||
sTemp += String( aBasisProductBuildId );
|
sTemp += String( aBasisProductBuildId );
|
||||||
@@ -129,7 +126,6 @@ String InitDevVersionStr()
|
|||||||
sTemp += String( aUREProductBuildId );
|
sTemp += String( aUREProductBuildId );
|
||||||
sBuildId.Insert( sTemp, sBuildId.Search( ')' ) );
|
sBuildId.Insert( sTemp, sBuildId.Search( ')' ) );
|
||||||
}
|
}
|
||||||
// <--
|
|
||||||
|
|
||||||
// the build id format is "milestone(build)[cwsname]". For readability, it would
|
// the build id format is "milestone(build)[cwsname]". For readability, it would
|
||||||
// be nice to have some more spaces in there.
|
// be nice to have some more spaces in there.
|
||||||
@@ -138,55 +134,51 @@ String InitDevVersionStr()
|
|||||||
sBuildId.Insert( sal_Unicode( ' ' ), nPos );
|
sBuildId.Insert( sal_Unicode( ' ' ), nPos );
|
||||||
if ( ( nPos = sBuildId.Search( sal_Unicode( '[' ) ) ) != STRING_NOTFOUND )
|
if ( ( nPos = sBuildId.Search( sal_Unicode( '[' ) ) ) != STRING_NOTFOUND )
|
||||||
sBuildId.Insert( sal_Unicode( ' ' ), nPos );
|
sBuildId.Insert( sal_Unicode( ' ' ), nPos );
|
||||||
|
|
||||||
return sBuildId;
|
return sBuildId;
|
||||||
}
|
}
|
||||||
|
|
||||||
AboutDialog::AboutDialog( Window* pParent, const ResId& rId ) :
|
AboutDialog::AboutDialog( Window* pParent, const ResId& rId) :
|
||||||
|
|
||||||
SfxModalDialog ( pParent, rId ),
|
SfxModalDialog ( pParent, rId ),
|
||||||
|
|
||||||
aOKButton ( this, ResId( ABOUT_BTN_OK, *rId.GetResMgr() ) ),
|
aOKButton ( this, ResId( ABOUT_BTN_OK, *rId.GetResMgr() ) ),
|
||||||
aVersionText ( this, ResId( ABOUT_FTXT_VERSION, *rId.GetResMgr() ) ),
|
aVersionText ( this, ResId( ABOUT_FTXT_VERSION, *rId.GetResMgr() ) ),
|
||||||
aCopyrightText ( this, ResId( ABOUT_FTXT_COPYRIGHT, *rId.GetResMgr() ) ),
|
aCopyrightText ( this, ResId( ABOUT_FTXT_COPYRIGHT, *rId.GetResMgr() ) ),
|
||||||
aBuildData ( this ),
|
aInfoLink ( this, ResId( ABOUT_FTXT_LINK, *rId.GetResMgr() ) ),
|
||||||
pDeveloperAry(0),
|
|
||||||
aAccelStr ( ResId( ABOUT_STR_ACCEL, *rId.GetResMgr() ) ),
|
aAccelStr ( ResId( ABOUT_STR_ACCEL, *rId.GetResMgr() ) ),
|
||||||
|
aVersionTextStr( ResId( ABOUT_STR_VERSION, *rId.GetResMgr() ) ),
|
||||||
|
aCopyrightTextStr( ResId( ABOUT_STR_COPYRIGHT, *rId.GetResMgr() ) ),
|
||||||
|
aLinkStr ( ResId( ABOUT_STR_LINK, *rId.GetResMgr() ) ),
|
||||||
aTimer (),
|
aTimer (),
|
||||||
nOff ( 0 ),
|
nOff ( 0 ),
|
||||||
m_nDeltaWidth ( 0 ),
|
m_nDeltaWidth ( 0 ),
|
||||||
m_nPendingScrolls( 0 ),
|
m_nPendingScrolls( 0 )
|
||||||
bNormal ( sal_True )
|
|
||||||
{
|
{
|
||||||
aDevVersionStr = InitDevVersionStr();
|
|
||||||
|
|
||||||
::com::sun::star::lang::Locale aLocale;
|
|
||||||
ResMgr* pResMgr = ResMgr::SearchCreateResMgr( "about", aLocale );
|
|
||||||
if ( pResMgr )
|
|
||||||
{
|
|
||||||
aCopyrightTextStr = String( ResId( ABOUT_STR_COPYRIGHT, *pResMgr ) );
|
|
||||||
// pDeveloperAry = new ResStringArray( ResId( ABOUT_STR_DEVELOPER_ARY, *pResMgr ) );
|
|
||||||
delete pResMgr;
|
|
||||||
}
|
|
||||||
|
|
||||||
rtl::OUString sProduct;
|
rtl::OUString sProduct;
|
||||||
utl::ConfigManager::GetDirectConfigProperty(utl::ConfigManager::PRODUCTNAME) >>= sProduct;
|
utl::ConfigManager::GetDirectConfigProperty(utl::ConfigManager::PRODUCTNAME) >>= sProduct;
|
||||||
|
|
||||||
// load image from module path
|
// load image from module path
|
||||||
aAppLogo = SfxApplication::GetApplicationLogo();
|
aAppLogo = SfxApplication::GetApplicationLogo();
|
||||||
|
|
||||||
// Transparenter Font
|
// Transparent Font
|
||||||
Font aFont = GetFont();
|
Font aFont = GetFont();
|
||||||
aFont.SetTransparent( sal_True );
|
aFont.SetTransparent( sal_True );
|
||||||
SetFont( aFont );
|
SetFont( aFont );
|
||||||
|
|
||||||
// if necessary more info
|
// if necessary more info
|
||||||
String sVersion = aVersionText.GetText();
|
String sVersion = aVersionTextStr;
|
||||||
sVersion.SearchAndReplaceAscii( "$(VER)", Application::GetDisplayName() );
|
sVersion.SearchAndReplaceAscii( "$(VER)", Application::GetDisplayName() );
|
||||||
sVersion += '\n';
|
sVersion += '\n';
|
||||||
sVersion += aDevVersionStr;
|
sVersion += GetBuildId();
|
||||||
|
#ifdef BUILD_VER_STRING
|
||||||
|
String aBuildString( DEFINE_CONST_UNICODE( BUILD_VER_STRING ) );
|
||||||
|
sVersion += '\n';
|
||||||
|
sVersion += aBuildString;
|
||||||
|
#endif
|
||||||
aVersionText.SetText( sVersion );
|
aVersionText.SetText( sVersion );
|
||||||
|
|
||||||
// Initialisierung fuer Aufruf Entwickler
|
// Initialization call for developers
|
||||||
if ( aAccelStr.Len() && ByteString(U2S(aAccelStr)).IsAlphaAscii() )
|
if ( aAccelStr.Len() && ByteString(U2S(aAccelStr)).IsAlphaAscii() )
|
||||||
{
|
{
|
||||||
Accelerator *pAccel = 0, *pPrevAccel = 0, *pFirstAccel = 0;
|
Accelerator *pAccel = 0, *pPrevAccel = 0, *pFirstAccel = 0;
|
||||||
@@ -196,7 +188,7 @@ AboutDialog::AboutDialog( Window* pParent, const ResId& rId ) :
|
|||||||
{
|
{
|
||||||
pPrevAccel = pAccel;
|
pPrevAccel = pAccel;
|
||||||
pAccel = new Accelerator;
|
pAccel = new Accelerator;
|
||||||
aAccelList.Insert( pAccel, LIST_APPEND );
|
aAccelList.push_back( pAccel );
|
||||||
sal_uInt16 nKey = aAccelStr.GetChar(i) - 'A' + KEY_A;
|
sal_uInt16 nKey = aAccelStr.GetChar(i) - 'A' + KEY_A;
|
||||||
pAccel->InsertItem( 1, KeyCode( nKey, KEY_MOD1 ) );
|
pAccel->InsertItem( 1, KeyCode( nKey, KEY_MOD1 ) );
|
||||||
if ( i > 0 )
|
if ( i > 0 )
|
||||||
@@ -221,58 +213,72 @@ AboutDialog::AboutDialog( Window* pParent, const ResId& rId ) :
|
|||||||
|
|
||||||
aVersionText.SetBackground();
|
aVersionText.SetBackground();
|
||||||
aCopyrightText.SetBackground();
|
aCopyrightText.SetBackground();
|
||||||
|
aInfoLink.SetURL( aLinkStr );
|
||||||
|
aInfoLink.SetBackground();
|
||||||
|
aInfoLink.SetClickHdl( LINK( this, AboutDialog, HandleHyperlink ) );
|
||||||
|
|
||||||
Color aTextColor( rSettings.GetWindowTextColor() );
|
Color aTextColor( rSettings.GetWindowTextColor() );
|
||||||
aVersionText.SetControlForeground( aTextColor );
|
aVersionText.SetControlForeground( aTextColor );
|
||||||
aCopyrightText.SetControlForeground( aTextColor );
|
aCopyrightText.SetControlForeground( aTextColor );
|
||||||
aBuildData.SetBackground( aWall );
|
|
||||||
|
|
||||||
Font aSmallFont = rSettings.GetInfoFont();
|
|
||||||
Size aSmaller = aNewFont.GetSize();
|
|
||||||
aSmaller.Width() = (long) (aSmaller.Width() * 0.75);
|
|
||||||
aSmaller.Height() = (long) (aSmaller.Height() * 0.75);
|
|
||||||
aNewFont.SetSize( aSmaller );
|
|
||||||
aBuildData.SetFont( aNewFont );
|
|
||||||
aBuildData.SetBackground( aWall );
|
|
||||||
#ifdef BUILD_VER_STRING
|
|
||||||
String aBuildString( DEFINE_CONST_UNICODE( BUILD_VER_STRING ) );
|
|
||||||
#else
|
|
||||||
String aBuildString;
|
|
||||||
#endif
|
|
||||||
aBuildData.SetText( aBuildString );
|
|
||||||
aBuildData.Show();
|
|
||||||
|
|
||||||
// determine size and position of the dialog & elements
|
|
||||||
Size aAppLogoSiz = aAppLogo.GetSizePixel();
|
|
||||||
Size aOutSiz = GetOutputSizePixel();
|
|
||||||
aOutSiz.Width() = aAppLogoSiz.Width();
|
|
||||||
|
|
||||||
Size a6Size = aVersionText.LogicToPixel( Size( 6, 6 ), MAP_APPFONT );
|
|
||||||
long nY = aAppLogoSiz.Height() + ( a6Size.Height() * 2 );
|
|
||||||
long nDlgMargin = a6Size.Width() * 4 ;
|
|
||||||
long nCtrlMargin = a6Size.Height() * 2;
|
|
||||||
long nTextWidth = aOutSiz.Width() - nDlgMargin;
|
|
||||||
|
|
||||||
aCopyrightText.SetText( aCopyrightTextStr );
|
aCopyrightText.SetText( aCopyrightTextStr );
|
||||||
|
|
||||||
layoutText( aVersionText, nY, nTextWidth, a6Size );
|
// determine size and position of the dialog & elements
|
||||||
|
Size aAppLogoSiz = aAppLogo.GetSizePixel();
|
||||||
|
|
||||||
|
if (aAppLogoSiz.Width() < 300)
|
||||||
|
aAppLogoSiz.Width() = 300;
|
||||||
|
|
||||||
|
Size aOutSiz = GetOutputSizePixel();
|
||||||
|
aOutSiz.Width() = aAppLogoSiz.Width();
|
||||||
|
|
||||||
|
// analyze size of the aVersionText widget
|
||||||
|
// character size
|
||||||
|
Size a6Size = aVersionText.LogicToPixel( Size( 6, 6 ), MAP_APPFONT );
|
||||||
|
// preferred Version widget size
|
||||||
|
Size aVTSize = aVersionText.CalcMinimumSize();
|
||||||
|
long nY = aAppLogoSiz.Height() + ( a6Size.Height() * 2 );
|
||||||
|
long nDlgMargin = a6Size.Width() * 3 ;
|
||||||
|
long nCtrlMargin = aVTSize.Height() + ( a6Size.Height() * 2 );
|
||||||
|
long nTextWidth = aOutSiz.Width() - nDlgMargin;
|
||||||
|
|
||||||
|
// finally set the aVersionText widget position and size
|
||||||
|
Size aVTCopySize = aVTSize;
|
||||||
|
Point aVTCopyPnt;
|
||||||
|
aVTCopySize.Width() = nTextWidth;
|
||||||
|
aVTCopyPnt.X() = ( aOutSiz.Width() - aVTCopySize.Width() ) / 2;
|
||||||
|
aVTCopyPnt.Y() = nY;
|
||||||
|
aVersionText.SetPosSizePixel( aVTCopyPnt, aVTCopySize );
|
||||||
|
|
||||||
nY += nCtrlMargin;
|
nY += nCtrlMargin;
|
||||||
|
|
||||||
// OK-Button-Position (at the bottom and centered)
|
// OK-Button-Position (at the bottom and centered)
|
||||||
Size aOKSiz = aOKButton.GetSizePixel();
|
Size aOKSiz = aOKButton.GetSizePixel();
|
||||||
Point aOKPnt = aOKButton.GetPosPixel();
|
Point aOKPnt = aOKButton.GetPosPixel();
|
||||||
|
|
||||||
|
// FixedHyperlink with more info link
|
||||||
|
Point aLinkPnt = aInfoLink.GetPosPixel();
|
||||||
|
Size aLinkSize = aInfoLink.GetSizePixel();
|
||||||
|
|
||||||
// Multiline edit with Copyright-Text
|
// Multiline edit with Copyright-Text
|
||||||
Point aCopyPnt = aCopyrightText.GetPosPixel();
|
Point aCopyPnt = aCopyrightText.GetPosPixel();
|
||||||
Size aCopySize = aCopyrightText.GetSizePixel();
|
Size aCopySize = aCopyrightText.GetSizePixel();
|
||||||
aCopySize.Width() = nTextWidth;
|
aCopySize.Width() = nTextWidth;
|
||||||
aCopySize.Height() = aOutSiz.Height() - nY - ( aOKSiz.Height() * 2 ) - nCtrlMargin;
|
aCopySize.Height() = aOutSiz.Height() - nY - ( aOKSiz.Height() * 2 ) - 3*aLinkSize.Height() - nCtrlMargin;
|
||||||
|
|
||||||
aCopyPnt.X() = ( aOutSiz.Width() - aCopySize.Width() ) / 2;
|
aCopyPnt.X() = ( aOutSiz.Width() - aCopySize.Width() ) / 2;
|
||||||
aCopyPnt.Y() = nY;
|
aCopyPnt.Y() = nY;
|
||||||
aCopyrightText.SetPosSizePixel( aCopyPnt, aCopySize );
|
aCopyrightText.SetPosSizePixel( aCopyPnt, aCopySize );
|
||||||
|
|
||||||
nY += aCopySize.Height() + nCtrlMargin;
|
nY += aCopySize.Height() + aLinkSize.Height();
|
||||||
|
|
||||||
|
aLinkSize.Width() = aInfoLink.CalcMinimumSize().Width();
|
||||||
|
aLinkPnt.X() = ( aOutSiz.Width() - aLinkSize.Width() ) / 2;
|
||||||
|
aLinkPnt.Y() = nY;
|
||||||
|
aInfoLink.SetPosSizePixel( aLinkPnt, aLinkSize );
|
||||||
|
|
||||||
|
nY += aLinkSize.Height() + nCtrlMargin;
|
||||||
|
|
||||||
aOKPnt.X() = ( aOutSiz.Width() - aOKSiz.Width() ) / 2;
|
aOKPnt.X() = ( aOutSiz.Width() - aOKSiz.Width() ) / 2;
|
||||||
aOKPnt.Y() = nY;
|
aOKPnt.Y() = nY;
|
||||||
aOKButton.SetPosPixel( aOKPnt );
|
aOKButton.SetPosPixel( aOKPnt );
|
||||||
@@ -282,6 +288,7 @@ AboutDialog::AboutDialog( Window* pParent, const ResId& rId ) :
|
|||||||
|
|
||||||
FreeResource();
|
FreeResource();
|
||||||
|
|
||||||
|
// explicit Help-Id
|
||||||
SetHelpId( CMD_SID_ABOUT );
|
SetHelpId( CMD_SID_ABOUT );
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -289,18 +296,14 @@ AboutDialog::AboutDialog( Window* pParent, const ResId& rId ) :
|
|||||||
|
|
||||||
AboutDialog::~AboutDialog()
|
AboutDialog::~AboutDialog()
|
||||||
{
|
{
|
||||||
// L"oschen des Entwickleraufrufs
|
// Clearing the developers call
|
||||||
delete pDeveloperAry;
|
if ( !aAccelList.empty() )
|
||||||
if ( aAccelList.Count() )
|
|
||||||
{
|
{
|
||||||
GetpApp()->RemoveAccel( aAccelList.First() );
|
GetpApp()->RemoveAccel( aAccelList.front() );
|
||||||
Accelerator* pAccel = aAccelList.Last();
|
|
||||||
|
|
||||||
while ( pAccel )
|
for ( size_t i = 0, n = aAccelList.size(); i < n; ++i )
|
||||||
{
|
delete aAccelList[ i ];
|
||||||
delete pAccel;
|
aAccelList.clear();
|
||||||
pAccel = aAccelList.Prev();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -318,11 +321,6 @@ IMPL_LINK( AboutDialog, TimerHdl, Timer *, pTimer )
|
|||||||
|
|
||||||
IMPL_LINK( AboutDialog, AccelSelectHdl, Accelerator *, pAccelerator )
|
IMPL_LINK( AboutDialog, AccelSelectHdl, Accelerator *, pAccelerator )
|
||||||
{
|
{
|
||||||
#ifdef YURI_DARIO
|
|
||||||
aCopyrightText.SetHelpText( DEFINE_CONST_UNICODE("Conoscere qualcuno ovunque egli sia, con cui comprendersi nonostante le distanze\n"
|
|
||||||
"e le differenze, puo' trasformare la terra in un giardino. baci Valeria") );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
(void)pAccelerator; //unused
|
(void)pAccelerator; //unused
|
||||||
// init Timer
|
// init Timer
|
||||||
aTimer.SetTimeoutHdl( LINK( this, AboutDialog, TimerHdl ) );
|
aTimer.SetTimeoutHdl( LINK( this, AboutDialog, TimerHdl ) );
|
||||||
@@ -331,7 +329,6 @@ IMPL_LINK( AboutDialog, AccelSelectHdl, Accelerator *, pAccelerator )
|
|||||||
nOff = GetOutputSizePixel().Height();
|
nOff = GetOutputSizePixel().Height();
|
||||||
MapMode aMapMode( MAP_PIXEL );
|
MapMode aMapMode( MAP_PIXEL );
|
||||||
SetMapMode( aMapMode );
|
SetMapMode( aMapMode );
|
||||||
bNormal = sal_False;
|
|
||||||
|
|
||||||
// start scroll Timer
|
// start scroll Timer
|
||||||
aTimer.SetTimeout( SCROLL_TIMER );
|
aTimer.SetTimeout( SCROLL_TIMER );
|
||||||
@@ -341,85 +338,47 @@ IMPL_LINK( AboutDialog, AccelSelectHdl, Accelerator *, pAccelerator )
|
|||||||
|
|
||||||
// -----------------------------------------------------------------------
|
// -----------------------------------------------------------------------
|
||||||
|
|
||||||
sal_Bool AboutDialog::Close()
|
IMPL_LINK( AboutDialog, HandleHyperlink, svt::FixedHyperlink*, pHyperlink )
|
||||||
{
|
{
|
||||||
// stop Timer and finish the dialog
|
rtl::OUString sURL=pHyperlink->GetURL();
|
||||||
aTimer.Stop();
|
rtl::OUString sTitle=GetText();
|
||||||
EndDialog( RET_OK );
|
|
||||||
return( sal_False );
|
|
||||||
}
|
|
||||||
|
|
||||||
// -----------------------------------------------------------------------
|
if ( ! sURL.getLength() ) // Nothing to do, when the URL is empty
|
||||||
|
return 1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
uno::Reference< com::sun::star::system::XSystemShellExecute > xSystemShellExecute(
|
||||||
|
::comphelper::getProcessServiceFactory()->createInstance(
|
||||||
|
DEFINE_CONST_UNICODE("com.sun.star.system.SystemShellExecute") ), uno::UNO_QUERY_THROW );
|
||||||
|
xSystemShellExecute->execute( sURL, rtl::OUString(), com::sun::star::system::SystemShellExecuteFlags::DEFAULTS );
|
||||||
|
}
|
||||||
|
catch ( uno::Exception& )
|
||||||
|
{
|
||||||
|
uno::Any exc( ::cppu::getCaughtException() );
|
||||||
|
rtl::OUString msg( ::comphelper::anyToString( exc ) );
|
||||||
|
const SolarMutexGuard guard;
|
||||||
|
ErrorBox aErrorBox( NULL, WB_OK, msg );
|
||||||
|
aErrorBox.SetText( sTitle );
|
||||||
|
aErrorBox.Execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
void AboutDialog::Paint( const Rectangle& rRect )
|
void AboutDialog::Paint( const Rectangle& rRect )
|
||||||
{
|
{
|
||||||
SetClipRegion( rRect );
|
SetClipRegion( rRect );
|
||||||
|
|
||||||
if ( bNormal ) // not in scroll mode
|
Point aPos( m_nDeltaWidth / 2, 0 );
|
||||||
{
|
DrawImage( aPos, aAppLogo );
|
||||||
Point aPos( m_nDeltaWidth / 2, 0 );
|
|
||||||
DrawImage( aPos, aAppLogo );
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// scroll the content
|
|
||||||
const int nDeltaY = -SCROLL_OFFSET * m_nPendingScrolls;
|
|
||||||
if( !nDeltaY )
|
|
||||||
return;
|
|
||||||
nOff += nDeltaY;
|
|
||||||
Scroll( 0, nDeltaY, SCROLL_NOERASE );
|
|
||||||
m_nPendingScrolls = 0;
|
|
||||||
|
|
||||||
// draw the credits text
|
|
||||||
const Font aOrigFont = GetFont();
|
|
||||||
const int nFullWidth = GetOutputSizePixel().Width();
|
|
||||||
|
|
||||||
int nY = nOff;
|
|
||||||
// const int nDevCnt = static_cast<int>( pDeveloperAry->Count() );
|
|
||||||
const int nDevCnt = 0;
|
|
||||||
for( int i = 0; i < nDevCnt; ++i )
|
|
||||||
{
|
|
||||||
if( nY >= rRect.Bottom() )
|
|
||||||
break;
|
|
||||||
|
|
||||||
int nPos2 = nY + GetTextHeight() + 3;
|
|
||||||
if( nPos2 >= rRect.Top() + nDeltaY )
|
|
||||||
{
|
|
||||||
const String aStr = pDeveloperAry->GetString(i);
|
|
||||||
const long nVal = pDeveloperAry->GetValue(i);
|
|
||||||
|
|
||||||
if ( nVal )
|
|
||||||
{
|
|
||||||
// emphasize the headers
|
|
||||||
Font aFont = aOrigFont;
|
|
||||||
aFont.SetWeight( (FontWeight)nVal );
|
|
||||||
SetFont( aFont );
|
|
||||||
nPos2 = nY + GetTextHeight() + 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
// clear text background
|
|
||||||
Rectangle aEraseRect( Point(0,nY), Size( nFullWidth, nPos2-nY));
|
|
||||||
Erase( aEraseRect );
|
|
||||||
|
|
||||||
// draw centered text
|
|
||||||
const long nTextWidth = GetTextWidth( aStr );
|
|
||||||
long nX = (nFullWidth - 5 - nTextWidth) / 2;
|
|
||||||
if( nX < 0 )
|
|
||||||
nX = SPACE_OFFSET;
|
|
||||||
const Point aPnt( nX, nY );
|
|
||||||
DrawText( aPnt, aStr );
|
|
||||||
|
|
||||||
// restore the font if needed
|
|
||||||
if( nVal )
|
|
||||||
SetFont( aOrigFont );
|
|
||||||
}
|
|
||||||
nY = nPos2;
|
|
||||||
}
|
|
||||||
|
|
||||||
// close dialog if the whole text has been scrolled
|
|
||||||
if ( nY <= 0 )
|
|
||||||
{
|
|
||||||
bNormal = sal_True;
|
|
||||||
Close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sal_Bool AboutDialog::Close()
|
||||||
|
{
|
||||||
|
// stop Timer and finish the dialog
|
||||||
|
aTimer.Stop();
|
||||||
|
EndDialog( RET_OK );
|
||||||
|
return sal_False;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
||||||
|
@@ -27,8 +27,12 @@
|
|||||||
|
|
||||||
#include <sfx2/sfx.hrc>
|
#include <sfx2/sfx.hrc>
|
||||||
|
|
||||||
#define ABOUT_BTN_OK 1
|
#define ABOUT_BTN_OK 1
|
||||||
#define ABOUT_FTXT_VERSION 1
|
#define ABOUT_FTXT_VERSION 2
|
||||||
#define ABOUT_STR_ACCEL 3
|
#define ABOUT_STR_ACCEL 3
|
||||||
#define ABOUT_FTXT_COPYRIGHT 4
|
#define ABOUT_FTXT_COPYRIGHT 4
|
||||||
|
|
||||||
|
#define ABOUT_FTXT_LINK 5
|
||||||
|
#define ABOUT_STR_VERSION 6
|
||||||
|
#define ABOUT_STR_COPYRIGHT 7
|
||||||
|
#define ABOUT_STR_LINK 8
|
||||||
|
@@ -29,39 +29,57 @@
|
|||||||
|
|
||||||
ModalDialog RID_DEFAULTABOUT
|
ModalDialog RID_DEFAULTABOUT
|
||||||
{
|
{
|
||||||
HelpID = "cui:ModalDialog:RID_DEFAULTABOUT";
|
|
||||||
OutputSize = TRUE ;
|
OutputSize = TRUE ;
|
||||||
Size = MAP_APPFONT ( 245 , 260 ) ;
|
Size = MAP_APPFONT ( 245 , 280 ) ;
|
||||||
Moveable = TRUE ;
|
Moveable = TRUE ;
|
||||||
SVLook = TRUE ;
|
SVLook = TRUE ;
|
||||||
Text [ x-comment ] = "PB: ; PB: only %PRODUCTNAME";
|
// TEXT_DEFAULTABOUT
|
||||||
Text [ en-US ] = "About %PRODUCTNAME" ;
|
|
||||||
OKButton ABOUT_BTN_OK
|
OKButton ABOUT_BTN_OK
|
||||||
{
|
{
|
||||||
DefButton = TRUE ;
|
DefButton = TRUE ;
|
||||||
Pos = MAP_APPFONT ( 174 , 6 ) ;
|
Pos = MAP_APPFONT ( 174 , 6 ) ;
|
||||||
Size = MAP_APPFONT ( 50 , 14 ) ;
|
Size = MAP_APPFONT ( 50 , 14 ) ;
|
||||||
};
|
};
|
||||||
FixedText ABOUT_FTXT_VERSION
|
MultiLineEdit ABOUT_FTXT_VERSION
|
||||||
{
|
{
|
||||||
|
Border = FALSE ;
|
||||||
Pos = MAP_APPFONT ( 54 , 6 ) ;
|
Pos = MAP_APPFONT ( 54 , 6 ) ;
|
||||||
Size = MAP_APPFONT ( 118 , 16 ) ;
|
Size = MAP_APPFONT ( 118 , 16 ) ;
|
||||||
WordBreak = TRUE ;
|
|
||||||
Text = "%PRODUCTNAME %ABOUTBOXPRODUCTVERSION %PRODUCTEXTENSION" ;
|
|
||||||
};
|
|
||||||
MultiLineEdit ABOUT_FTXT_COPYRIGHT
|
|
||||||
{
|
|
||||||
HelpID = "cui:MultiLineEdit:RID_DEFAULTABOUT:ABOUT_FTXT_COPYRIGHT";
|
|
||||||
Border = TRUE ;
|
|
||||||
Pos = MAP_APPFONT ( 54 , 25 ) ;
|
|
||||||
Size = MAP_APPFONT ( 168 , 51 ) ;
|
|
||||||
IgnoreTab = TRUE ;
|
IgnoreTab = TRUE ;
|
||||||
ReadOnly = TRUE ;
|
ReadOnly = TRUE ;
|
||||||
AutoVScroll = TRUE ;
|
AutoVScroll = TRUE ;
|
||||||
};
|
};
|
||||||
|
MultiLineEdit ABOUT_FTXT_COPYRIGHT
|
||||||
|
{
|
||||||
|
Border = FALSE ;
|
||||||
|
Pos = MAP_APPFONT ( 54 , 25 ) ;
|
||||||
|
Size = MAP_APPFONT ( 168 , 71 ) ;
|
||||||
|
IgnoreTab = TRUE ;
|
||||||
|
ReadOnly = TRUE ;
|
||||||
|
AutoVScroll = TRUE ;
|
||||||
|
};
|
||||||
|
FixedText ABOUT_FTXT_LINK
|
||||||
|
{
|
||||||
|
NoLabel = TRUE;
|
||||||
|
TabStop = TRUE;
|
||||||
|
Text [ en-US ] = "Contributor credits";
|
||||||
|
Pos = MAP_APPFONT ( 54 , 100 ) ;
|
||||||
|
Size = MAP_APPFONT ( 168 , 10 ) ;
|
||||||
|
};
|
||||||
|
String ABOUT_STR_VERSION
|
||||||
|
{
|
||||||
|
Text[ en-US ] = "%PRODUCTNAME %ABOUTBOXPRODUCTVERSION %PRODUCTEXTENSION";
|
||||||
|
};
|
||||||
|
String ABOUT_STR_COPYRIGHT
|
||||||
|
{
|
||||||
|
Text[ en-US ] = "Copyright © 2000, 2010 LibreOffice contributors and/or their affiliates. All rights reserved.\nThis product was created by %OOOVENDOR, based on OpenOffice.org, which is Copyright 2000, 2010 Oracle and/or its affiliates.\n%OOOVENDOR acknowledges all community members, please find more info at the link below:";
|
||||||
|
};
|
||||||
|
String ABOUT_STR_LINK
|
||||||
|
{
|
||||||
|
Text[ en-US ] = "http://www.libreoffice.org/credits.html";
|
||||||
|
};
|
||||||
String ABOUT_STR_ACCEL
|
String ABOUT_STR_ACCEL
|
||||||
{
|
{
|
||||||
Text = "SDT" ;
|
Text = "SDT" ;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
*
|
*
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
@@ -33,11 +34,12 @@
|
|||||||
#include <vcl/button.hxx>
|
#include <vcl/button.hxx>
|
||||||
#include <vcl/accel.hxx>
|
#include <vcl/accel.hxx>
|
||||||
#include <svtools/svmedit.hxx>
|
#include <svtools/svmedit.hxx>
|
||||||
#include <tools/list.hxx>
|
|
||||||
#include <svtools/stdctrl.hxx>
|
#include <svtools/stdctrl.hxx>
|
||||||
|
#include "svtools/fixedhyper.hxx"
|
||||||
#include <sfx2/basedlgs.hxx> // SfxModalDialog
|
#include <sfx2/basedlgs.hxx> // SfxModalDialog
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
DECLARE_LIST( AccelList, Accelerator* )
|
typedef ::std::vector< Accelerator* > AccelList;
|
||||||
|
|
||||||
// class AboutDialog -----------------------------------------------------
|
// class AboutDialog -----------------------------------------------------
|
||||||
|
|
||||||
@@ -47,15 +49,16 @@ private:
|
|||||||
OKButton aOKButton;
|
OKButton aOKButton;
|
||||||
Image aAppLogo;
|
Image aAppLogo;
|
||||||
|
|
||||||
FixedInfo aVersionText;
|
MultiLineEdit aVersionText;
|
||||||
MultiLineEdit aCopyrightText;
|
MultiLineEdit aCopyrightText;
|
||||||
FixedInfo aBuildData;
|
svt::FixedHyperlink aInfoLink;
|
||||||
|
|
||||||
ResStringArray* pDeveloperAry;
|
// ResStringArray aDeveloperAry; // RIP ...
|
||||||
String aDevVersionStr;
|
|
||||||
String aAccelStr;
|
String aAccelStr;
|
||||||
String aVersionData;
|
String aVersionData;
|
||||||
|
String aVersionTextStr;
|
||||||
String aCopyrightTextStr;
|
String aCopyrightTextStr;
|
||||||
|
String aLinkStr;
|
||||||
|
|
||||||
AccelList aAccelList;
|
AccelList aAccelList;
|
||||||
|
|
||||||
@@ -64,20 +67,20 @@ private:
|
|||||||
long m_nDeltaWidth;
|
long m_nDeltaWidth;
|
||||||
int m_nPendingScrolls;
|
int m_nPendingScrolls;
|
||||||
|
|
||||||
sal_Bool bNormal;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual sal_Bool Close();
|
virtual sal_Bool Close();
|
||||||
virtual void Paint( const Rectangle& );
|
virtual void Paint( const Rectangle& rRect );
|
||||||
|
|
||||||
public:
|
public:
|
||||||
AboutDialog( Window* pParent, const ResId& nId );
|
AboutDialog( Window* pParent, const ResId& rId);
|
||||||
~AboutDialog();
|
~AboutDialog();
|
||||||
|
|
||||||
DECL_LINK( TimerHdl, Timer * );
|
DECL_LINK( TimerHdl, Timer * );
|
||||||
DECL_LINK( AccelSelectHdl, Accelerator * );
|
DECL_LINK( AccelSelectHdl, Accelerator * );
|
||||||
|
DECL_LINK( HandleHyperlink, svt::FixedHyperlink * );
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // #ifndef _ABOUT_HXX
|
#endif // #ifndef _ABOUT_HXX
|
||||||
|
|
||||||
|
|
||||||
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
||||||
|
@@ -343,7 +343,7 @@ SAL_DLLPUBLIC_EXPORT void* SAL_CALL component_getFactory(const sal_Char* _pImplN
|
|||||||
sal_Int32 nClasses = s_aClassImplementationNames.getLength();
|
sal_Int32 nClasses = s_aClassImplementationNames.getLength();
|
||||||
OSL_ENSURE((s_aClassServiceNames.getLength() == nClasses) &&
|
OSL_ENSURE((s_aClassServiceNames.getLength() == nClasses) &&
|
||||||
(s_aFactories.getLength() == nClasses),
|
(s_aFactories.getLength() == nClasses),
|
||||||
"forms::component_writeInfo : invalid class infos !");
|
"forms::component_getFactory : invalid class infos !");
|
||||||
|
|
||||||
// loop through the sequences and register the service providers
|
// loop through the sequences and register the service providers
|
||||||
const ::rtl::OUString* pClasses = s_aClassImplementationNames.getConstArray();
|
const ::rtl::OUString* pClasses = s_aClassImplementationNames.getConstArray();
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
FindRegisteredExtensions
|
FindRegisteredExtensions
|
||||||
LookForRegisteredExtensions
|
LookForRegisteredExtensions
|
||||||
RegisterSomeExtensions
|
RegisterSomeExtensions
|
||||||
|
RestoreRegAllMSDoc
|
||||||
|
@@ -213,6 +213,9 @@ static LONG DeleteSubKeyTree( HKEY RootKey, LPCSTR lpKey )
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Unused
|
||||||
|
#if 0
|
||||||
|
|
||||||
//----------------------------------------------------------
|
//----------------------------------------------------------
|
||||||
static BOOL RemoveExtensionInRegistry( LPCSTR lpSubKey )
|
static BOOL RemoveExtensionInRegistry( LPCSTR lpSubKey )
|
||||||
{
|
{
|
||||||
@@ -263,6 +266,8 @@ static BOOL RemoveExtensionInRegistry( LPCSTR lpSubKey )
|
|||||||
return ( ERROR_SUCCESS == lResult );
|
return ( ERROR_SUCCESS == lResult );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
//----------------------------------------------------------
|
//----------------------------------------------------------
|
||||||
bool GetMsiProp( MSIHANDLE handle, LPCSTR name, /*out*/std::string& value )
|
bool GetMsiProp( MSIHANDLE handle, LPCSTR name, /*out*/std::string& value )
|
||||||
{
|
{
|
||||||
@@ -306,12 +311,60 @@ static void registerForExtension( MSIHANDLE handle, const int nIndex, bool bRegi
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------
|
||||||
|
static void saveOldRegistration( LPCSTR lpSubKey )
|
||||||
|
{
|
||||||
|
BOOL bRet = false;
|
||||||
|
HKEY hKey = NULL;
|
||||||
|
LONG lResult = RegOpenKeyExA( HKEY_CLASSES_ROOT, lpSubKey, 0,
|
||||||
|
KEY_QUERY_VALUE|KEY_SET_VALUE, &hKey );
|
||||||
|
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
CHAR szBuffer[1024];
|
||||||
|
DWORD nSize = sizeof( szBuffer );
|
||||||
|
|
||||||
|
lResult = RegQueryValueExA( hKey, "", NULL, NULL, (LPBYTE)szBuffer, &nSize );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
szBuffer[nSize] = '\0';
|
||||||
|
|
||||||
|
// No need to save assocations for our own types
|
||||||
|
if ( strncmp( szBuffer, "OpenOffice.org.", 15 ) != 0 )
|
||||||
|
{
|
||||||
|
// Save the old association
|
||||||
|
RegSetValueExA( hKey, "OOoBackupAssociation", 0,
|
||||||
|
REG_SZ, (LPBYTE)szBuffer, nSize );
|
||||||
|
// Also save what the old association means, just so we can try to verify
|
||||||
|
// if/when restoring it that the old application still exists
|
||||||
|
HKEY hKey2 = NULL;
|
||||||
|
lResult = RegOpenKeyExA( HKEY_CLASSES_ROOT, szBuffer, 0,
|
||||||
|
KEY_QUERY_VALUE, &hKey2 );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
nSize = sizeof( szBuffer );
|
||||||
|
lResult = RegQueryValueExA( hKey2, "", NULL, NULL, (LPBYTE)szBuffer, &nSize );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
RegSetValueExA( hKey, "OOoBackupAssociationDeref", 0,
|
||||||
|
REG_SZ, (LPBYTE)szBuffer, nSize );
|
||||||
|
}
|
||||||
|
RegCloseKey( hKey2 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
RegCloseKey( hKey );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------
|
//----------------------------------------------------------
|
||||||
static void registerForExtensions( MSIHANDLE handle, BOOL bRegisterAll )
|
static void registerForExtensions( MSIHANDLE handle, BOOL bRegisterAll )
|
||||||
{ // Check all file extensions
|
{ // Check all file extensions
|
||||||
int nIndex = 0;
|
int nIndex = 0;
|
||||||
while ( g_Extensions[nIndex] != 0 )
|
while ( g_Extensions[nIndex] != 0 )
|
||||||
{
|
{
|
||||||
|
saveOldRegistration( g_Extensions[nIndex] );
|
||||||
|
|
||||||
BOOL bRegister = bRegisterAll || CheckExtensionInRegistry( g_Extensions[nIndex] );
|
BOOL bRegister = bRegisterAll || CheckExtensionInRegistry( g_Extensions[nIndex] );
|
||||||
if ( bRegister )
|
if ( bRegister )
|
||||||
registerForExtension( handle, nIndex, true );
|
registerForExtension( handle, nIndex, true );
|
||||||
@@ -478,6 +531,10 @@ extern "C" UINT __stdcall RegisterSomeExtensions( MSIHANDLE handle )
|
|||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------
|
//----------------------------------------------------------
|
||||||
|
//
|
||||||
|
// This is the (slightly misleadinly named) entry point for the
|
||||||
|
// custom action called Regallmsdocdll.
|
||||||
|
//
|
||||||
extern "C" UINT __stdcall FindRegisteredExtensions( MSIHANDLE handle )
|
extern "C" UINT __stdcall FindRegisteredExtensions( MSIHANDLE handle )
|
||||||
{
|
{
|
||||||
if ( IsSetMsiProp( handle, "FILETYPEDIALOGUSED" ) )
|
if ( IsSetMsiProp( handle, "FILETYPEDIALOGUSED" ) )
|
||||||
@@ -514,7 +571,12 @@ extern "C" UINT __stdcall FindRegisteredExtensions( MSIHANDLE handle )
|
|||||||
return ERROR_SUCCESS;
|
return ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
|
||||||
//----------------------------------------------------------
|
//----------------------------------------------------------
|
||||||
|
//
|
||||||
|
// This entry is not called for any custom action.
|
||||||
|
//
|
||||||
extern "C" UINT __stdcall DeleteRegisteredExtensions( MSIHANDLE /*handle*/ )
|
extern "C" UINT __stdcall DeleteRegisteredExtensions( MSIHANDLE /*handle*/ )
|
||||||
{
|
{
|
||||||
OutputDebugStringFormat( "DeleteRegisteredExtensions\n" );
|
OutputDebugStringFormat( "DeleteRegisteredExtensions\n" );
|
||||||
@@ -530,4 +592,78 @@ extern "C" UINT __stdcall DeleteRegisteredExtensions( MSIHANDLE /*handle*/ )
|
|||||||
return ERROR_SUCCESS;
|
return ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//----------------------------------------------------------
|
||||||
|
static void restoreOldRegistration( LPCSTR lpSubKey )
|
||||||
|
{
|
||||||
|
BOOL bRet = false;
|
||||||
|
HKEY hKey = NULL;
|
||||||
|
LONG lResult = RegOpenKeyExA( HKEY_CLASSES_ROOT, lpSubKey, 0,
|
||||||
|
KEY_QUERY_VALUE|KEY_SET_VALUE, &hKey );
|
||||||
|
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
CHAR szBuffer[1024];
|
||||||
|
DWORD nSize = sizeof( szBuffer );
|
||||||
|
|
||||||
|
lResult = RegQueryValueExA( hKey, "OOoBackupAssociation", NULL, NULL,
|
||||||
|
(LPBYTE)szBuffer, &nSize );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
HKEY hKey2 = NULL;
|
||||||
|
lResult = RegOpenKeyExA( HKEY_CLASSES_ROOT, szBuffer, 0,
|
||||||
|
KEY_QUERY_VALUE, &hKey2 );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
CHAR szBuffer2[1024];
|
||||||
|
DWORD nSize2 = sizeof( szBuffer2 );
|
||||||
|
|
||||||
|
lResult = RegQueryValueExA( hKey2, "", NULL, NULL, (LPBYTE)szBuffer2, &nSize2 );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
CHAR szBuffer3[1024];
|
||||||
|
DWORD nSize3 = sizeof( szBuffer3 );
|
||||||
|
|
||||||
|
// Try to verify that the old association is OK to restore
|
||||||
|
lResult = RegQueryValueExA( hKey, "OOoBackupAssociationDeref", NULL, NULL,
|
||||||
|
(LPBYTE)szBuffer3, &nSize3 );
|
||||||
|
if ( ERROR_SUCCESS == lResult )
|
||||||
|
{
|
||||||
|
if ( nSize2 == nSize3 && strcmp (szBuffer2, szBuffer3) == 0)
|
||||||
|
{
|
||||||
|
// Yep. So restore it
|
||||||
|
RegSetValueExA( hKey, "", 0, REG_SZ, (LPBYTE)szBuffer, nSize );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
RegCloseKey( hKey2 );
|
||||||
|
}
|
||||||
|
RegDeleteValueA( hKey, "OOoBackupAssociation" );
|
||||||
|
}
|
||||||
|
RegDeleteValueA( hKey, "OOoBackupAssociationDeref" );
|
||||||
|
RegCloseKey( hKey );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------
|
||||||
|
//
|
||||||
|
// This function is not in OO.o. We call this from the
|
||||||
|
// Restoreregallmsdocdll custom action.
|
||||||
|
//
|
||||||
|
extern "C" UINT __stdcall RestoreRegAllMSDoc( MSIHANDLE /*handle*/ )
|
||||||
|
{
|
||||||
|
OutputDebugStringFormat( "RestoreRegAllMSDoc\n" );
|
||||||
|
|
||||||
|
int nIndex = 0;
|
||||||
|
while ( g_Extensions[nIndex] != 0 )
|
||||||
|
{
|
||||||
|
restoreOldRegistration( g_Extensions[nIndex] );
|
||||||
|
++nIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return ERROR_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
||||||
|
0
wizards/com/sun/star/wizards/letter/LetterWizardDialogConst.java
Executable file → Normal file
0
wizards/com/sun/star/wizards/letter/LetterWizardDialogConst.java
Executable file → Normal file
@@ -158,7 +158,7 @@ public class LocaleCodes extends Resource
|
|||||||
Ids[94] = "Slovenian;sl;1060";
|
Ids[94] = "Slovenian;sl;1060";
|
||||||
Ids[95] = "Slovak;sk;1051";
|
Ids[95] = "Slovak;sk;1051";
|
||||||
Ids[96] = "Sorbian;sb;1070";
|
Ids[96] = "Sorbian;sb;1070";
|
||||||
Ids[97] = "Spanish - Spain;es-es;1034";
|
Ids[97] = "Spanish - Spain;es-es;3082";
|
||||||
Ids[98] = "Spanish - Argentina;es-ar;11274";
|
Ids[98] = "Spanish - Argentina;es-ar;11274";
|
||||||
Ids[99] = "Spanish - Bolivia;es-bo;16394";
|
Ids[99] = "Spanish - Bolivia;es-bo;16394";
|
||||||
Ids[100] = "Spanish - Chile;es-cl;13322";
|
Ids[100] = "Spanish - Chile;es-cl;13322";
|
||||||
|
@@ -52,81 +52,6 @@ using namespace ::com::sun::star::registry;
|
|||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
|
|
||||||
sal_Bool SAL_CALL mscrypt_component_writeInfo( void* /*pServiceManager*/ , void* pRegistryKey )
|
|
||||||
{
|
|
||||||
sal_Bool result = sal_False;
|
|
||||||
sal_Int32 i ;
|
|
||||||
OUString sKeyName ;
|
|
||||||
Reference< XRegistryKey > xNewKey ;
|
|
||||||
Sequence< OUString > seqServices ;
|
|
||||||
Reference< XRegistryKey > xKey( reinterpret_cast< XRegistryKey* >( pRegistryKey ) ) ;
|
|
||||||
|
|
||||||
if( xKey.is() ) {
|
|
||||||
// XMLSignature_MSCryptImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += XMLSignature_MSCryptImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = XMLSignature_MSCryptImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// XMLEncryption_MSCryptImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += XMLEncryption_MSCryptImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = XMLEncryption_MSCryptImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// XMLSecurityContext_MSCryptImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += XMLSecurityContext_MSCryptImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = XMLSecurityContext_MSCryptImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// SecurityEnvironment_MSCryptImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += SecurityEnvironment_MSCryptImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = SecurityEnvironment_MSCryptImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// SEInitializer_MSCryptImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += SEInitializer_MSCryptImpl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = SEInitializer_MSCryptImpl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
return sal_True;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void* SAL_CALL mscrypt_component_getFactory( const sal_Char* pImplName , void* pServiceManager , void* /*pRegistryKey*/ )
|
void* SAL_CALL mscrypt_component_getFactory( const sal_Char* pImplName , void* pServiceManager , void* /*pRegistryKey*/ )
|
||||||
{
|
{
|
||||||
void* pRet = 0;
|
void* pRet = 0;
|
||||||
|
@@ -52,81 +52,6 @@ using namespace ::com::sun::star::registry;
|
|||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
|
|
||||||
sal_Bool SAL_CALL nss_component_writeInfo( void* /*pServiceManager*/ , void* pRegistryKey )
|
|
||||||
{
|
|
||||||
sal_Bool result = sal_False;
|
|
||||||
sal_Int32 i ;
|
|
||||||
OUString sKeyName ;
|
|
||||||
Reference< XRegistryKey > xNewKey ;
|
|
||||||
Sequence< OUString > seqServices ;
|
|
||||||
Reference< XRegistryKey > xKey( reinterpret_cast< XRegistryKey* >( pRegistryKey ) ) ;
|
|
||||||
|
|
||||||
if( xKey.is() ) {
|
|
||||||
// XMLSignature_NssImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += XMLSignature_NssImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = XMLSignature_NssImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// XMLEncryption_NssImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += XMLEncryption_NssImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = XMLEncryption_NssImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// XMLSecurityContext_NssImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += XMLSecurityContext_NssImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = XMLSecurityContext_NssImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// SecurityEnvironment_NssImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += SecurityEnvironment_NssImpl::impl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = SecurityEnvironment_NssImpl::impl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
// SEInitializer_NssImpl
|
|
||||||
sKeyName = OUString( RTL_CONSTASCII_USTRINGPARAM( "/" ) ) ;
|
|
||||||
sKeyName += SEInitializer_NssImpl_getImplementationName() ;
|
|
||||||
sKeyName += OUString(RTL_CONSTASCII_USTRINGPARAM("/UNO/SERVICES")) ;
|
|
||||||
|
|
||||||
xNewKey = xKey->createKey( sKeyName ) ;
|
|
||||||
if( xNewKey.is() ) {
|
|
||||||
seqServices = SEInitializer_NssImpl_getSupportedServiceNames() ;
|
|
||||||
for( i = seqServices.getLength() ; i -- ; )
|
|
||||||
xNewKey->createKey( seqServices.getConstArray()[i] ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
return sal_True;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void* SAL_CALL nss_component_getFactory( const sal_Char* pImplName , void* pServiceManager , void* /*pRegistryKey*/ )
|
void* SAL_CALL nss_component_getFactory( const sal_Char* pImplName , void* pServiceManager , void* /*pRegistryKey*/ )
|
||||||
{
|
{
|
||||||
void* pRet = 0;
|
void* pRet = 0;
|
||||||
|
Reference in New Issue
Block a user