1
0
Fork 0
libreoffice/sc/source/core/tool/printopt.cxx
Daniel Baumann 8e63e14cf6
Adding upstream version 4:25.2.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 16:20:04 +02:00

131 lines
3.8 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 <sc.hrc>
using namespace utl;
using namespace com::sun::star::uno;
ScPrintOptions::ScPrintOptions()
{
SetDefaults();
}
void ScPrintOptions::SetDefaults()
{
bSkipEmpty = true;
bAllSheets = false;
bForceBreaks = false;
}
bool ScPrintOptions::operator==( const ScPrintOptions& rOpt ) const
{
return bSkipEmpty == rOpt.bSkipEmpty
&& bAllSheets == rOpt.bAllSheets
&& bForceBreaks == rOpt.bForceBreaks;
}
ScTpPrintItem::ScTpPrintItem( const ScPrintOptions& rOpt ) :
SfxPoolItem ( SID_SCPRINTOPTIONS ),
theOptions ( rOpt )
{
}
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 );
}
ScTpPrintItem* ScTpPrintItem::Clone( SfxItemPool * ) const
{
return new ScTpPrintItem( *this );
}
constexpr OUStringLiteral CFGPATH_PRINT = u"Office.Calc/Print";
#define SCPRINTOPT_EMPTYPAGES 0
#define SCPRINTOPT_ALLSHEETS 1
#define SCPRINTOPT_FORCEBREAKS 2
Sequence<OUString> ScPrintCfg::GetPropertyNames()
{
return {u"Page/EmptyPages"_ustr, // SCPRINTOPT_EMPTYPAGES
u"Other/AllSheets"_ustr, // SCPRINTOPT_ALLSHEETS
u"Page/ForceBreaks"_ustr}; // SCPRINTOPT_FORCEBREAKS;
}
ScPrintCfg::ScPrintCfg() :
ConfigItem( CFGPATH_PRINT )
{
Sequence<OUString> aNames = GetPropertyNames();
EnableNotification(aNames);
ReadCfg();
}
void ScPrintCfg::ReadCfg()
{
const Sequence<OUString> aNames = GetPropertyNames();
const Sequence<Any> aValues = GetProperties(aNames);
OSL_ENSURE(aValues.getLength() == aNames.getLength(), "GetProperties failed");
if(aValues.getLength() != aNames.getLength())
return;
if (bool bVal; aValues[SCPRINTOPT_EMPTYPAGES] >>= bVal)
SetSkipEmpty(!bVal); // reversed
if (bool bVal; aValues[SCPRINTOPT_ALLSHEETS] >>= bVal)
SetAllSheets(bVal);
if (bool bVal; aValues[SCPRINTOPT_FORCEBREAKS] >>= bVal)
SetForceBreaks(bVal);
}
void ScPrintCfg::ImplCommit()
{
Sequence<OUString> aNames = GetPropertyNames();
Sequence<Any> aValues(aNames.getLength());
Any* pValues = aValues.getArray();
pValues[SCPRINTOPT_EMPTYPAGES] <<= !GetSkipEmpty(); // reversed
pValues[SCPRINTOPT_ALLSHEETS] <<= GetAllSheets();
pValues[SCPRINTOPT_FORCEBREAKS] <<= GetForceBreaks();
PutProperties(aNames, aValues);
}
void ScPrintCfg::SetOptions( const ScPrintOptions& rNew )
{
*static_cast<ScPrintOptions*>(this) = rNew;
SetModified();
Commit();
}
void ScPrintCfg::Notify( const css::uno::Sequence< OUString >& ) { ReadCfg(); }
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */