From c05adac9229aad0683d2e75a8f8dcd5421c66b02 Mon Sep 17 00:00:00 2001
From: Noel Grandin <noelgrandin@gmail.com>
Date: Sat, 24 Jul 2021 22:56:15 +0200
Subject: use officecfg for print options

Change-Id: I2a85d802b9edda638da467e273ad3d24cbf2bcf1
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/119476
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
---
 include/svtools/printoptions.hxx       |  79 +----
 include/unotools/itemholderbase.hxx    |   2 -
 sfx2/source/dialog/printopt.cxx        |  11 +-
 svtools/source/config/itemholder2.cxx  |   8 -
 svtools/source/config/printoptions.cxx | 547 +++++++--------------------------
 5 files changed, 116 insertions(+), 531 deletions(-)

diff --git a/include/svtools/printoptions.hxx b/include/svtools/printoptions.hxx
index 72120306c5f5..6f2e86df3cf1 100644
--- a/include/svtools/printoptions.hxx
+++ b/include/svtools/printoptions.hxx
@@ -22,88 +22,15 @@
 #include <config_options.h>
 #include <svtools/svtdllapi.h>
 #include <sal/types.h>
-#include <unotools/options.hxx>
 
-namespace osl { class Mutex; }
-
-class SvtPrintOptions_Impl;
 class PrinterOptions;
 
-
-class UNLESS_MERGELIBS(SVT_DLLPUBLIC) SvtBasePrintOptions: public utl::detail::Options
+namespace svtools
 {
-
-    SvtPrintOptions_Impl* m_pDataContainer;
-
-protected:
-
-    void        SetDataContainer( SvtPrintOptions_Impl* pDataContainer ) { m_pDataContainer = pDataContainer; }
-
-public:
-
-    static ::osl::Mutex& GetOwnStaticMutex();
-
-public:
-
-                SvtBasePrintOptions();
-                virtual ~SvtBasePrintOptions() override;
-
-    static bool        IsReduceTransparency();
-    static sal_Int16   GetReducedTransparencyMode();
-    static bool        IsReduceGradients();
-    static sal_Int16   GetReducedGradientMode();
-    static sal_Int16   GetReducedGradientStepCount();
-    static bool        IsReduceBitmaps();
-    static sal_Int16   GetReducedBitmapMode();
-    static sal_Int16   GetReducedBitmapResolution();
-    static bool        IsReducedBitmapIncludesTransparency();
-    static bool        IsConvertToGreyscales();
-    static bool        IsPDFAsStandardPrintJobFormat();
-
-    void        SetReduceTransparency( bool bState );
-    void        SetReducedTransparencyMode( sal_Int16 nMode );
-    void        SetReduceGradients( bool bState );
-    void        SetReducedGradientMode( sal_Int16 nMode );
-    void        SetReducedGradientStepCount( sal_Int16 nStepCount );
-    void        SetReduceBitmaps( bool bState );
-    void        SetReducedBitmapMode( sal_Int16   bState );
-    void        SetReducedBitmapResolution( sal_Int16 nResolution );
-    void        SetReducedBitmapIncludesTransparency( bool bState );
-    void        SetConvertToGreyscales( bool bState );
-    void        SetPDFAsStandardPrintJobFormat( bool bState );
-
-public:
-
-    static void        GetPrinterOptions( PrinterOptions& rOptions );
-    void               SetPrinterOptions( const PrinterOptions& rOptions );
+    SVT_DLLPUBLIC void GetPrinterOptions( PrinterOptions& rOptions, bool bFile );
+    SVT_DLLPUBLIC void SetPrinterOptions( const PrinterOptions& rOptions, bool bFile );
 };
 
 
-class UNLESS_MERGELIBS(SVT_DLLPUBLIC) SvtPrinterOptions final : public SvtBasePrintOptions
-{
-private:
-
-    static SvtPrintOptions_Impl*    m_pStaticDataContainer;
-    static sal_Int32                m_nRefCount;
-
-public:
-
-    SvtPrinterOptions();
-    virtual ~SvtPrinterOptions() override;
-};
-
-
-class UNLESS_MERGELIBS(SVT_DLLPUBLIC) SvtPrintFileOptions final : public SvtBasePrintOptions
-{
-private:
-
-    static SvtPrintOptions_Impl*    m_pStaticDataContainer;
-    static sal_Int32                m_nRefCount;
-
-public:
-
-    SvtPrintFileOptions();
-    virtual ~SvtPrintFileOptions() override;
-};
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/include/unotools/itemholderbase.hxx b/include/unotools/itemholderbase.hxx
index 3546e5fd1478..676ed455484a 100644
--- a/include/unotools/itemholderbase.hxx
+++ b/include/unotools/itemholderbase.hxx
@@ -55,8 +55,6 @@ enum class EItem
     OptionsDialogOptions          ,
 
     PathOptions                   ,
-    PrintOptions                  ,   // 2
-    PrintFileOptions              ,   // 2
 
     SecurityOptions               ,
     SysLocaleOptions              ,   // 2
diff --git a/sfx2/source/dialog/printopt.cxx b/sfx2/source/dialog/printopt.cxx
index d6fe953c785b..f94b0204cd6f 100644
--- a/sfx2/source/dialog/printopt.cxx
+++ b/sfx2/source/dialog/printopt.cxx
@@ -91,9 +91,6 @@ std::unique_ptr<SfxTabPage> SfxCommonPrintOptionsTabPage::Create(weld::Container
 
 bool SfxCommonPrintOptionsTabPage::FillItemSet( SfxItemSet* /*rSet*/ )
 {
-    SvtPrinterOptions       aPrinterOptions;
-    SvtPrintFileOptions     aPrintFileOptions;
-
     std::shared_ptr<comphelper::ConfigurationChanges> batch(comphelper::ConfigurationChanges::create());
 
     if( m_xPaperSizeCB->get_state_changed_from_saved())
@@ -107,8 +104,8 @@ bool SfxCommonPrintOptionsTabPage::FillItemSet( SfxItemSet* /*rSet*/ )
 
     ImplSaveControls( m_xPrinterOutputRB->get_active() ? &maPrinterOptions : &maPrintFileOptions );
 
-    aPrinterOptions.SetPrinterOptions( maPrinterOptions );
-    aPrintFileOptions.SetPrinterOptions( maPrintFileOptions );
+    svtools::SetPrinterOptions(maPrinterOptions, /*bFile*/false);
+    svtools::SetPrinterOptions(maPrintFileOptions, /*bFile*/true);
 
     return false;
 }
@@ -123,8 +120,8 @@ void SfxCommonPrintOptionsTabPage::Reset( const SfxItemSet* /*rSet*/ )
     m_xPaperOrientationCB->save_state();
     m_xTransparencyCB->save_state();
 
-    SvtBasePrintOptions::GetPrinterOptions( maPrinterOptions );
-    SvtBasePrintOptions::GetPrinterOptions( maPrintFileOptions );
+    svtools::GetPrinterOptions( maPrinterOptions, /*bFile*/false );
+    svtools::GetPrinterOptions( maPrintFileOptions, /*bFile*/true );
     if(m_xPrintFileOutputRB->get_active()){
        m_xPrinterOutputRB->set_active(true);
     }
diff --git a/svtools/source/config/itemholder2.cxx b/svtools/source/config/itemholder2.cxx
index adb68024b020..52993547543f 100644
--- a/svtools/source/config/itemholder2.cxx
+++ b/svtools/source/config/itemholder2.cxx
@@ -132,14 +132,6 @@ void ItemHolder2::impl_newItem(TItemInfo& rItem)
             rItem.pItem.reset( new SvtMenuOptions() );
             break;
 
-        case EItem::PrintOptions :
-            rItem.pItem.reset( new SvtPrinterOptions() );
-            break;
-
-        case EItem::PrintFileOptions :
-            rItem.pItem.reset( new SvtPrintFileOptions() );
-            break;
-
         case EItem::MiscOptions :
             rItem.pItem.reset( new SvtMiscOptions() );
             break;
diff --git a/svtools/source/config/printoptions.cxx b/svtools/source/config/printoptions.cxx
index e7d7ce991429..4dd889186e6c 100644
--- a/svtools/source/config/printoptions.cxx
+++ b/svtools/source/config/printoptions.cxx
@@ -19,18 +19,7 @@
 
 #include <svtools/printoptions.hxx>
 #include <vcl/print.hxx>
-#include <com/sun/star/uno/Any.hxx>
-
-#include <com/sun/star/beans/XPropertySet.hpp>
-#include <com/sun/star/container/XNameAccess.hpp>
-
-#include <comphelper/configurationhelper.hxx>
-#include <comphelper/processfactory.hxx>
-
 #include <officecfg/Office/Common.hxx>
-
-#include "itemholder2.hxx"
-
 #include <sal/macros.h>
 #include <tools/diagnose_ex.h>
 
@@ -38,463 +27,145 @@ const sal_uInt16 aDPIArray[] = { 72, 96, 150, 200, 300, 600 };
 
 #define DPI_COUNT (SAL_N_ELEMENTS(aDPIArray))
 
-#define ROOTNODE_START                                  "Office.Common/Print/Option"
-#define ROOTNODE_PRINTOPTION                            "org.openoffice.Office.Common/Print/Option"
-
-#define PROPERTYNAME_REDUCETRANSPARENCY                 "ReduceTransparency"
-#define PROPERTYNAME_REDUCEDTRANSPARENCYMODE            "ReducedTransparencyMode"
-#define PROPERTYNAME_REDUCEGRADIENTS                    "ReduceGradients"
-#define PROPERTYNAME_REDUCEDGRADIENTMODE                "ReducedGradientMode"
-#define PROPERTYNAME_REDUCEDGRADIENTSTEPCOUNT           "ReducedGradientStepCount"
-#define PROPERTYNAME_REDUCEBITMAPS                      "ReduceBitmaps"
-#define PROPERTYNAME_REDUCEDBITMAPMODE                  "ReducedBitmapMode"
-#define PROPERTYNAME_REDUCEDBITMAPRESOLUTION            "ReducedBitmapResolution"
-#define PROPERTYNAME_REDUCEDBITMAPINCLUDESTRANSPARENCY  "ReducedBitmapIncludesTransparency"
-#define PROPERTYNAME_CONVERTTOGREYSCALES                "ConvertToGreyscales"
-#define PROPERTYNAME_PDFASSTANDARDPRINTJOBFORMAT        "PDFAsStandardPrintJobFormat"
-
-using namespace ::utl;
 using namespace ::osl;
 using namespace ::com::sun::star::uno;
 
-SvtPrintOptions_Impl*   SvtPrinterOptions::m_pStaticDataContainer = nullptr;
-sal_Int32               SvtPrinterOptions::m_nRefCount = 0;
-
-SvtPrintOptions_Impl*   SvtPrintFileOptions::m_pStaticDataContainer = nullptr;
-sal_Int32               SvtPrintFileOptions::m_nRefCount = 0;
-
-class SvtPrintOptions_Impl
+namespace svtools
 {
-public:
-    explicit SvtPrintOptions_Impl( const OUString& rConfigRoot );
-    ~SvtPrintOptions_Impl();
-
-    void        SetReduceTransparency( bool bState ) ;
-    void        SetReducedTransparencyMode( sal_Int16 nMode ) ;
-    void        SetReduceGradients( bool bState ) ;
-    void        SetReducedGradientMode( sal_Int16 nMode ) ;
-    void        SetReducedGradientStepCount( sal_Int16 nStepCount ) ;
-    void        SetReduceBitmaps( bool bState ) ;
-    void        SetReducedBitmapMode( sal_Int16 nMode ) ;
-    void        SetReducedBitmapResolution( sal_Int16 nResolution ) ;
-    void        SetReducedBitmapIncludesTransparency( bool bState ) ;
-    void        SetConvertToGreyscales( bool bState ) ;
-    void        SetPDFAsStandardPrintJobFormat( bool bState ) ;
-
-
-//  private API
 
-
-private:
-    void impl_setValue (const OUString& sProp, bool bNew );
-    void impl_setValue (const OUString& sProp, sal_Int16 nNew );
-
-
-//  private member
-
-
-private:
-       css::uno::Reference< css::container::XNameAccess > m_xCfg;
-    css::uno::Reference< css::container::XNameAccess > m_xNode;
-};
-
-SvtPrintOptions_Impl::SvtPrintOptions_Impl(const OUString& rConfigRoot)
+void GetPrinterOptions( PrinterOptions& rOptions, bool bFile )
 {
-    try
-    {
-        m_xCfg.set(
-            ::comphelper::ConfigurationHelper::openConfig(
-                comphelper::getProcessComponentContext(),
-                ROOTNODE_PRINTOPTION,
-                ::comphelper::EConfigurationModes::Standard),
-            css::uno::UNO_QUERY);
-
-        if (m_xCfg.is())
-        {
-            m_xCfg->getByName(rConfigRoot.copy(rConfigRoot.lastIndexOf('/')+1)) >>= m_xNode;
-        }
-    }
-    catch (const css::uno::Exception&)
+    if (bFile)
     {
-        DBG_UNHANDLED_EXCEPTION("svtools.config");
-        m_xNode.clear();
-        m_xCfg.clear();
+        rOptions.SetReduceTransparency( officecfg::Office::Common::Print::Option::File::ReduceTransparency::get() );
+        rOptions.SetReducedTransparencyMode( static_cast<PrinterTransparencyMode>(
+                officecfg::Office::Common::Print::Option::File::ReducedTransparencyMode::get() ) );
+        rOptions.SetReduceGradients( officecfg::Office::Common::Print::Option::File::ReduceGradients::get() );
+        rOptions.SetReducedGradientMode( static_cast<PrinterGradientMode>(
+                officecfg::Office::Common::Print::Option::File::ReducedGradientMode::get()) );
+        rOptions.SetReducedGradientStepCount( officecfg::Office::Common::Print::Option::File::ReducedGradientStepCount::get() );
+        rOptions.SetReduceBitmaps( officecfg::Office::Common::Print::Option::File::ReduceBitmaps::get() );
+        rOptions.SetReducedBitmapMode( static_cast<PrinterBitmapMode>(
+                officecfg::Office::Common::Print::Option::File::ReducedBitmapMode::get()) );
+        rOptions.SetReducedBitmapResolution( aDPIArray[ std::min( static_cast<sal_uInt16>(
+                officecfg::Office::Common::Print::Option::File::ReducedBitmapResolution::get()), sal_uInt16( DPI_COUNT - 1 ) ) ] );
+        rOptions.SetReducedBitmapIncludesTransparency(
+                officecfg::Office::Common::Print::Option::File::ReducedBitmapIncludesTransparency::get() );
+        rOptions.SetConvertToGreyscales( officecfg::Office::Common::Print::Option::File::ConvertToGreyscales::get() );
+        rOptions.SetPDFAsStandardPrintJobFormat( officecfg::Office::Common::Print::Option::File::PDFAsStandardPrintJobFormat::get() );
     }
-}
-
-void SvtPrintOptions_Impl::SetReduceTransparency(bool bState)
-{
-    impl_setValue(PROPERTYNAME_REDUCETRANSPARENCY, bState);
-}
-
-void SvtPrintOptions_Impl::SetReducedTransparencyMode(sal_Int16 nMode)
-{
-    impl_setValue(PROPERTYNAME_REDUCEDTRANSPARENCYMODE, nMode);
-}
-
-void SvtPrintOptions_Impl::SetReduceGradients(bool bState)
-{
-    impl_setValue(PROPERTYNAME_REDUCEGRADIENTS, bState);
-}
-
-void SvtPrintOptions_Impl::SetReducedGradientMode(sal_Int16 nMode)
-{
-    impl_setValue(PROPERTYNAME_REDUCEDGRADIENTMODE, nMode);
-}
-
-void SvtPrintOptions_Impl::SetReducedGradientStepCount(sal_Int16 nStepCount )
-{
-    impl_setValue(PROPERTYNAME_REDUCEDGRADIENTSTEPCOUNT, nStepCount);
-}
-
-void SvtPrintOptions_Impl::SetReduceBitmaps(bool bState )
-{
-    impl_setValue(PROPERTYNAME_REDUCEBITMAPS, bState);
-}
-
-void SvtPrintOptions_Impl::SetReducedBitmapMode(sal_Int16 nMode )
-{
-    impl_setValue(PROPERTYNAME_REDUCEDBITMAPMODE, nMode);
-}
-
-void SvtPrintOptions_Impl::SetReducedBitmapResolution(sal_Int16 nResolution )
-{
-    impl_setValue(PROPERTYNAME_REDUCEDBITMAPRESOLUTION, nResolution);
-}
-
-void SvtPrintOptions_Impl::SetReducedBitmapIncludesTransparency(bool bState )
-{
-    impl_setValue(PROPERTYNAME_REDUCEDBITMAPINCLUDESTRANSPARENCY, bState);
-}
-
-void SvtPrintOptions_Impl::SetConvertToGreyscales(bool bState)
-{
-    impl_setValue(PROPERTYNAME_CONVERTTOGREYSCALES, bState);
-}
-
-void SvtPrintOptions_Impl::SetPDFAsStandardPrintJobFormat(bool bState)
-{
-    impl_setValue(PROPERTYNAME_PDFASSTANDARDPRINTJOBFORMAT, bState);
-}
-
-SvtPrintOptions_Impl::~SvtPrintOptions_Impl()
-{
-    m_xNode.clear();
-    m_xCfg.clear();
-}
-
-void SvtPrintOptions_Impl::impl_setValue (const OUString& sProp, bool bNew )
-{
-    try
-    {
-        if ( ! m_xNode.is())
-            return;
-
-        css::uno::Reference<css::beans::XPropertySet> xSet(m_xNode, css::uno::UNO_QUERY);
-        if ( ! xSet.is())
-            return;
-
-        bool bOld = ! bNew;
-        if ( ! (xSet->getPropertyValue(sProp) >>= bOld))
-            return;
-
-        if (bOld != bNew)
-        {
-            xSet->setPropertyValue(sProp, css::uno::makeAny(bNew));
-            ::comphelper::ConfigurationHelper::flush(m_xCfg);
-        }
-    }
-    catch(const css::uno::Exception&)
+    else
     {
-        DBG_UNHANDLED_EXCEPTION("svtools.config");
+        rOptions.SetReduceTransparency( officecfg::Office::Common::Print::Option::Printer::ReduceTransparency::get() );
+        rOptions.SetReducedTransparencyMode( static_cast<PrinterTransparencyMode>(
+                officecfg::Office::Common::Print::Option::Printer::ReducedTransparencyMode::get() ) );
+        rOptions.SetReduceGradients( officecfg::Office::Common::Print::Option::Printer::ReduceGradients::get() );
+        rOptions.SetReducedGradientMode( static_cast<PrinterGradientMode>(
+                officecfg::Office::Common::Print::Option::Printer::ReducedGradientMode::get()) );
+        rOptions.SetReducedGradientStepCount( officecfg::Office::Common::Print::Option::Printer::ReducedGradientStepCount::get() );
+        rOptions.SetReduceBitmaps( officecfg::Office::Common::Print::Option::Printer::ReduceBitmaps::get() );
+        rOptions.SetReducedBitmapMode( static_cast<PrinterBitmapMode>(
+                officecfg::Office::Common::Print::Option::Printer::ReducedBitmapMode::get()) );
+        rOptions.SetReducedBitmapResolution( aDPIArray[ std::min( static_cast<sal_uInt16>(
+                officecfg::Office::Common::Print::Option::Printer::ReducedBitmapResolution::get()), sal_uInt16( DPI_COUNT - 1 ) ) ] );
+        rOptions.SetReducedBitmapIncludesTransparency(
+                officecfg::Office::Common::Print::Option::Printer::ReducedBitmapIncludesTransparency::get() );
+        rOptions.SetConvertToGreyscales( officecfg::Office::Common::Print::Option::Printer::ConvertToGreyscales::get() );
+        rOptions.SetPDFAsStandardPrintJobFormat( officecfg::Office::Common::Print::Option::Printer::PDFAsStandardPrintJobFormat::get() );
     }
 }
 
-void SvtPrintOptions_Impl::impl_setValue (const OUString& sProp,
-                                                ::sal_Int16      nNew )
+void SetPrinterOptions( const PrinterOptions& rOptions, bool bFile )
 {
-    try
+    std::shared_ptr<comphelper::ConfigurationChanges> batch(comphelper::ConfigurationChanges::create());
+    if (bFile)
     {
-        if ( ! m_xNode.is())
-            return;
-
-        css::uno::Reference<css::beans::XPropertySet> xSet(m_xNode, css::uno::UNO_QUERY);
-        if ( ! xSet.is())
-            return;
-
-        ::sal_Int16 nOld = nNew+1;
-        if ( ! (xSet->getPropertyValue(sProp) >>= nOld))
-            return;
-
-        if (nOld != nNew)
+        officecfg::Office::Common::Print::Option::File::ReduceTransparency::set(
+                rOptions.IsReduceTransparency(), batch );
+        officecfg::Office::Common::Print::Option::File::ReducedTransparencyMode::set(
+                static_cast<sal_Int16>(rOptions.GetReducedTransparencyMode()), batch );
+        officecfg::Office::Common::Print::Option::File::ReduceGradients::set(
+                rOptions.IsReduceGradients(), batch );
+        officecfg::Office::Common::Print::Option::File::ReducedGradientMode::set(
+                static_cast<sal_Int16>(rOptions.GetReducedGradientMode()), batch );
+        officecfg::Office::Common::Print::Option::File::ReducedGradientStepCount::set(
+                rOptions.GetReducedGradientStepCount(), batch );
+        officecfg::Office::Common::Print::Option::File::ReduceBitmaps::set(
+                rOptions.IsReduceBitmaps(), batch );
+        officecfg::Office::Common::Print::Option::File::ReducedBitmapMode::set(
+                static_cast<sal_Int16>(rOptions.GetReducedBitmapMode()), batch );
+        officecfg::Office::Common::Print::Option::File::ReducedBitmapIncludesTransparency::set(
+                rOptions.IsReducedBitmapIncludesTransparency(), batch );
+        officecfg::Office::Common::Print::Option::File::ConvertToGreyscales::set(
+                rOptions.IsConvertToGreyscales(), batch );
+        officecfg::Office::Common::Print::Option::File::PDFAsStandardPrintJobFormat::set(
+                rOptions.IsPDFAsStandardPrintJobFormat(), batch );
+
+        const sal_uInt16 nDPI = rOptions.GetReducedBitmapResolution();
+
+        if( nDPI < aDPIArray[ 0 ] )
+            officecfg::Office::Common::Print::Option::File::ReducedBitmapResolution::set( 0, batch );
+        else
         {
-            xSet->setPropertyValue(sProp, css::uno::makeAny(nNew));
-            ::comphelper::ConfigurationHelper::flush(m_xCfg);
+            for( tools::Long i = DPI_COUNT - 1; i >= 0; i-- )
+            {
+                if( nDPI >= aDPIArray[ i ] )
+                {
+                    officecfg::Office::Common::Print::Option::File::ReducedBitmapResolution::set(
+                            static_cast<sal_Int16>(i), batch );
+                    i = -1;
+                }
+            }
         }
     }
-    catch(const css::uno::Exception&)
-    {
-        DBG_UNHANDLED_EXCEPTION("svtools.config");
-    }
-}
-
-SvtBasePrintOptions::SvtBasePrintOptions()
-    : m_pDataContainer(nullptr)
-{
-}
-
-SvtBasePrintOptions::~SvtBasePrintOptions()
-{
-}
-
-Mutex& SvtBasePrintOptions::GetOwnStaticMutex()
-{
-    static Mutex ourMutex;
-
-    return ourMutex;
-}
-
-bool SvtBasePrintOptions::IsReduceTransparency()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReduceTransparency::get();
-}
-
-sal_Int16 SvtBasePrintOptions::GetReducedTransparencyMode()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReducedTransparencyMode::get();
-}
-
-bool SvtBasePrintOptions::IsReduceGradients()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReduceGradients::get();
-}
-
-sal_Int16 SvtBasePrintOptions::GetReducedGradientMode()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReducedGradientMode::get();
-}
-
-sal_Int16 SvtBasePrintOptions::GetReducedGradientStepCount()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReducedGradientStepCount::get();
-}
-
-bool SvtBasePrintOptions::IsReduceBitmaps()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReduceBitmaps::get();
-}
-
-sal_Int16 SvtBasePrintOptions::GetReducedBitmapMode()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReducedBitmapMode::get();
-}
-
-sal_Int16 SvtBasePrintOptions::GetReducedBitmapResolution()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReducedBitmapResolution::get();
-}
-
-bool SvtBasePrintOptions::IsReducedBitmapIncludesTransparency()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ReducedBitmapIncludesTransparency::get();
-}
-
-bool SvtBasePrintOptions::IsConvertToGreyscales()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::ConvertToGreyscales::get();
-}
-
-bool SvtBasePrintOptions::IsPDFAsStandardPrintJobFormat()
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    return officecfg::Office::Common::Print::Option::Printer::PDFAsStandardPrintJobFormat::get();
-}
-
-void SvtBasePrintOptions::SetReduceTransparency( bool bState )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReduceTransparency( bState ) ;
-}
-
-void SvtBasePrintOptions::SetReducedTransparencyMode( sal_Int16 nMode )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReducedTransparencyMode( nMode );
-}
-
-void SvtBasePrintOptions::SetReduceGradients( bool bState )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReduceGradients( bState );
-}
-
-void SvtBasePrintOptions::SetReducedGradientMode( sal_Int16 nMode )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReducedGradientMode( nMode );
-}
-
-void SvtBasePrintOptions::SetReducedGradientStepCount( sal_Int16 nStepCount )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReducedGradientStepCount( nStepCount );
-}
-
-void SvtBasePrintOptions::SetReduceBitmaps( bool bState )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReduceBitmaps( bState );
-}
-
-void SvtBasePrintOptions::SetReducedBitmapMode( sal_Int16 nMode )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReducedBitmapMode( nMode );
-}
-
-void SvtBasePrintOptions::SetReducedBitmapResolution( sal_Int16 nResolution )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReducedBitmapResolution( nResolution );
-}
-
-void SvtBasePrintOptions::SetReducedBitmapIncludesTransparency( bool bState )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetReducedBitmapIncludesTransparency( bState );
-}
-
-void SvtBasePrintOptions::SetConvertToGreyscales( bool bState )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetConvertToGreyscales( bState );
-}
-
-void SvtBasePrintOptions::SetPDFAsStandardPrintJobFormat( bool bState )
-{
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    m_pDataContainer->SetPDFAsStandardPrintJobFormat( bState );
-}
-
-void SvtBasePrintOptions::GetPrinterOptions( PrinterOptions& rOptions )
-{
-    rOptions.SetReduceTransparency( IsReduceTransparency() );
-    rOptions.SetReducedTransparencyMode( static_cast<PrinterTransparencyMode>(GetReducedTransparencyMode()) );
-    rOptions.SetReduceGradients( IsReduceGradients() );
-    rOptions.SetReducedGradientMode( static_cast<PrinterGradientMode>(GetReducedGradientMode()) );
-    rOptions.SetReducedGradientStepCount( GetReducedGradientStepCount() );
-    rOptions.SetReduceBitmaps( IsReduceBitmaps() );
-    rOptions.SetReducedBitmapMode( static_cast<PrinterBitmapMode>(GetReducedBitmapMode()) );
-    rOptions.SetReducedBitmapResolution( aDPIArray[ std::min( static_cast<sal_uInt16>(GetReducedBitmapResolution()), sal_uInt16( DPI_COUNT - 1 ) ) ] );
-    rOptions.SetReducedBitmapIncludesTransparency( IsReducedBitmapIncludesTransparency() );
-    rOptions.SetConvertToGreyscales( IsConvertToGreyscales() );
-    rOptions.SetPDFAsStandardPrintJobFormat( IsPDFAsStandardPrintJobFormat() );
-}
-
-void SvtBasePrintOptions::SetPrinterOptions( const PrinterOptions& rOptions )
-{
-    SetReduceTransparency( rOptions.IsReduceTransparency() );
-    SetReducedTransparencyMode(
-        sal::static_int_cast< sal_Int16 >(
-            rOptions.GetReducedTransparencyMode()) );
-    SetReduceGradients( rOptions.IsReduceGradients() );
-    SetReducedGradientMode(
-        sal::static_int_cast< sal_Int16 >(rOptions.GetReducedGradientMode()) );
-    SetReducedGradientStepCount( rOptions.GetReducedGradientStepCount() );
-    SetReduceBitmaps( rOptions.IsReduceBitmaps() );
-    SetReducedBitmapMode(
-        sal::static_int_cast< sal_Int16 >(rOptions.GetReducedBitmapMode()) );
-    SetReducedBitmapIncludesTransparency( rOptions.IsReducedBitmapIncludesTransparency() );
-    SetConvertToGreyscales( rOptions.IsConvertToGreyscales() );
-    SetPDFAsStandardPrintJobFormat( rOptions.IsPDFAsStandardPrintJobFormat() );
-
-    const sal_uInt16 nDPI = rOptions.GetReducedBitmapResolution();
-
-    if( nDPI < aDPIArray[ 0 ] )
-        SetReducedBitmapResolution( 0 );
     else
     {
-        for( tools::Long i = DPI_COUNT - 1; i >= 0; i-- )
+        officecfg::Office::Common::Print::Option::Printer::ReduceTransparency::set(
+                rOptions.IsReduceTransparency(), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReducedTransparencyMode::set(
+                static_cast<sal_Int16>(rOptions.GetReducedTransparencyMode()), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReduceGradients::set(
+                rOptions.IsReduceGradients(), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReducedGradientMode::set(
+                static_cast<sal_Int16>(rOptions.GetReducedGradientMode()), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReducedGradientStepCount::set(
+                rOptions.GetReducedGradientStepCount(), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReduceBitmaps::set(
+                rOptions.IsReduceBitmaps(), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReducedBitmapMode::set(
+                static_cast<sal_Int16>(rOptions.GetReducedBitmapMode()), batch );
+        officecfg::Office::Common::Print::Option::Printer::ReducedBitmapIncludesTransparency::set(
+                rOptions.IsReducedBitmapIncludesTransparency(), batch );
+        officecfg::Office::Common::Print::Option::Printer::ConvertToGreyscales::set(
+                rOptions.IsConvertToGreyscales(), batch );
+        officecfg::Office::Common::Print::Option::Printer::PDFAsStandardPrintJobFormat::set(
+                rOptions.IsPDFAsStandardPrintJobFormat(), batch );
+
+        const sal_uInt16 nDPI = rOptions.GetReducedBitmapResolution();
+
+        if( nDPI < aDPIArray[ 0 ] )
+            officecfg::Office::Common::Print::Option::Printer::ReducedBitmapResolution::set( 0, batch );
+        else
         {
-            if( nDPI >= aDPIArray[ i ] )
+            for( tools::Long i = DPI_COUNT - 1; i >= 0; i-- )
             {
-                SetReducedBitmapResolution( static_cast<sal_Int16>(i) );
-                i = -1;
+                if( nDPI >= aDPIArray[ i ] )
+                {
+                    officecfg::Office::Common::Print::Option::Printer::ReducedBitmapResolution::set(
+                            static_cast<sal_Int16>(i), batch );
+                    i = -1;
+                }
             }
         }
     }
+    batch->commit();
 }
 
-SvtPrinterOptions::SvtPrinterOptions()
-{
-    // Global access, must be guarded (multithreading!).
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    // Increase our refcount ...
-    ++m_nRefCount;
-    // ... and initialize our data container only if it not already!
-    if( m_pStaticDataContainer == nullptr )
-    {
-        m_pStaticDataContainer = new SvtPrintOptions_Impl( ROOTNODE_START "/Printer" );
-        svtools::ItemHolder2::holdConfigItem(EItem::PrintOptions);
-    }
+} // namespace svtools
 
-    SetDataContainer( m_pStaticDataContainer );
-}
 
-SvtPrinterOptions::~SvtPrinterOptions()
-{
-    // Global access, must be guarded (multithreading!)
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    // Decrease our refcount.
-    --m_nRefCount;
-    // If last instance was deleted ...
-    // we must destroy our static data container!
-    if( m_nRefCount <= 0 )
-    {
-        delete m_pStaticDataContainer;
-        m_pStaticDataContainer = nullptr;
-    }
-}
 
-SvtPrintFileOptions::SvtPrintFileOptions()
-{
-    // Global access, must be guarded (multithreading!).
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    // Increase our refcount ...
-    ++m_nRefCount;
-    // ... and initialize our data container only if it not already!
-    if( m_pStaticDataContainer == nullptr )
-    {
-        m_pStaticDataContainer = new SvtPrintOptions_Impl( ROOTNODE_START "/File" );
-        svtools::ItemHolder2::holdConfigItem(EItem::PrintFileOptions);
-    }
 
-    SetDataContainer( m_pStaticDataContainer );
-}
 
-SvtPrintFileOptions::~SvtPrintFileOptions()
-{
-    // Global access, must be guarded (multithreading!)
-    MutexGuard aGuard( GetOwnStaticMutex() );
-    // Decrease our refcount.
-    --m_nRefCount;
-    // If last instance was deleted ...
-    // we must destroy our static data container!
-    if( m_nRefCount <= 0 )
-    {
-        delete m_pStaticDataContainer;
-        m_pStaticDataContainer = nullptr;
-    }
-}
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
-- 
cgit