Files
libreoffice/sc/source/core/tool/printopt.cxx
Jochen Nitschke 78404fe554 tdf#88205 use list ctor for uno::Sequence<OUString> in sc
Change-Id: Icda2d7a2f16fbcdf3a1e796026540bfa568be2d9
Reviewed-on: https://gerrit.libreoffice.org/28800
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Noel Grandin <noelgrandin@gmail.com>
2016-09-11 07:15:55 +00:00

177 lines
5.0 KiB
C++

/* -*- 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 <com/sun/star/uno/Any.hxx>
#include <com/sun/star/uno/Sequence.hxx>
#include <osl/diagnose.h>
#include "printopt.hxx"
#include "miscuno.hxx"
using namespace utl;
using namespace com::sun::star::uno;
ScPrintOptions::ScPrintOptions()
{
SetDefaults();
}
ScPrintOptions::ScPrintOptions( const ScPrintOptions& rCpy ) :
bSkipEmpty( rCpy.bSkipEmpty ),
bAllSheets( rCpy.bAllSheets ),
bForceBreaks( rCpy.bForceBreaks )
{
}
ScPrintOptions::~ScPrintOptions()
{
}
void ScPrintOptions::SetDefaults()
{
bSkipEmpty = true;
bAllSheets = false;
bForceBreaks = false;
}
ScPrintOptions& ScPrintOptions::operator=( const ScPrintOptions& rCpy )
{
bSkipEmpty = rCpy.bSkipEmpty;
bAllSheets = rCpy.bAllSheets;
bForceBreaks = rCpy.bForceBreaks;
return *this;
}
bool ScPrintOptions::operator==( const ScPrintOptions& rOpt ) const
{
return bSkipEmpty == rOpt.bSkipEmpty
&& bAllSheets == rOpt.bAllSheets
&& bForceBreaks == rOpt.bForceBreaks;
}
ScTpPrintItem::ScTpPrintItem( sal_uInt16 nWhichP, const ScPrintOptions& rOpt ) :
SfxPoolItem ( nWhichP ),
theOptions ( rOpt )
{
}
ScTpPrintItem::ScTpPrintItem( const ScTpPrintItem& rItem ) :
SfxPoolItem ( rItem ),
theOptions ( rItem.theOptions )
{
}
ScTpPrintItem::~ScTpPrintItem()
{
}
bool ScTpPrintItem::operator==( const SfxPoolItem& rItem ) const
{
assert(SfxPoolItem::operator==(rItem));
const ScTpPrintItem& rPItem = static_cast<const ScTpPrintItem&>(rItem);
return ( theOptions == rPItem.theOptions );
}
SfxPoolItem* ScTpPrintItem::Clone( SfxItemPool * ) const
{
return new ScTpPrintItem( *this );
}
#define CFGPATH_PRINT "Office.Calc/Print"
#define SCPRINTOPT_EMPTYPAGES 0
#define SCPRINTOPT_ALLSHEETS 1
#define SCPRINTOPT_FORCEBREAKS 2
Sequence<OUString> ScPrintCfg::GetPropertyNames()
{
return {"Page/EmptyPages", // SCPRINTOPT_EMPTYPAGES
"Other/AllSheets", // SCPRINTOPT_ALLSHEETS
"Page/ForceBreaks"}; // SCPRINTOPT_FORCEBREAKS;
}
ScPrintCfg::ScPrintCfg() :
ConfigItem( OUString( CFGPATH_PRINT ) )
{
Sequence<OUString> aNames = GetPropertyNames();
Sequence<Any> aValues = GetProperties(aNames);
const Any* pValues = aValues.getConstArray();
OSL_ENSURE(aValues.getLength() == aNames.getLength(), "GetProperties failed");
if(aValues.getLength() == aNames.getLength())
{
for(int nProp = 0; nProp < aNames.getLength(); nProp++)
{
OSL_ENSURE(pValues[nProp].hasValue(), "property value missing");
if(pValues[nProp].hasValue())
{
switch(nProp)
{
case SCPRINTOPT_EMPTYPAGES:
// reversed
SetSkipEmpty( !ScUnoHelpFunctions::GetBoolFromAny( pValues[nProp] ) );
break;
case SCPRINTOPT_ALLSHEETS:
SetAllSheets( ScUnoHelpFunctions::GetBoolFromAny( pValues[nProp] ) );
break;
case SCPRINTOPT_FORCEBREAKS:
SetForceBreaks( ScUnoHelpFunctions::GetBoolFromAny( pValues[nProp] ) );
break;
}
}
}
}
}
void ScPrintCfg::ImplCommit()
{
Sequence<OUString> aNames = GetPropertyNames();
Sequence<Any> aValues(aNames.getLength());
Any* pValues = aValues.getArray();
for(int nProp = 0; nProp < aNames.getLength(); nProp++)
{
switch(nProp)
{
case SCPRINTOPT_EMPTYPAGES:
// reversed
pValues[nProp] <<= !GetSkipEmpty();
break;
case SCPRINTOPT_ALLSHEETS:
pValues[nProp] <<= GetAllSheets();
break;
case SCPRINTOPT_FORCEBREAKS:
pValues[nProp] <<= GetForceBreaks();
break;
}
}
PutProperties(aNames, aValues);
}
void ScPrintCfg::SetOptions( const ScPrintOptions& rNew )
{
*static_cast<ScPrintOptions*>(this) = rNew;
SetModified();
}
void ScPrintCfg::Notify( const css::uno::Sequence< OUString >& ) {}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */