LibreOffice Module sdext (master)  1
optimizationstats.cxx
Go to the documentation of this file.
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
5  * This Source Code Form is subject to the terms of the Mozilla Public
6  * License, v. 2.0. If a copy of the MPL was not distributed with this
7  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
11  * Licensed to the Apache Software Foundation (ASF) under one or more
12  * contributor license agreements. See the NOTICE file distributed
13  * with this work for additional information regarding copyright
14  * ownership. The ASF licenses this file to you under the Apache
15  * License, Version 2.0 (the "License"); you may not use this file
16  * except in compliance with the License. You may obtain a copy of
17  * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18  */
19 
20 
21 #include "optimizationstats.hxx"
22 #include <com/sun/star/awt/Size.hpp>
23 #include <com/sun/star/drawing/XShapes.hpp>
24 #include <com/sun/star/drawing/XDrawPagesSupplier.hpp>
25 
26 
27 using namespace ::com::sun::star;
28 using namespace ::com::sun::star::uno;
29 using namespace ::com::sun::star::frame;
30 using namespace ::com::sun::star::drawing;
31 using namespace ::com::sun::star::beans;
32 
33 
35 {
36 }
37 
38 
40 {
41  maStats[ eStat ] = rStatValue;
42 }
43 
44 
46 {
47  std::map< PPPOptimizerTokenEnum, uno::Any >::const_iterator aIter( maStats.find( eStat ) );
48  return aIter != maStats.end() ? &((*aIter).second) : nullptr;
49 }
50 
51 
52 css::beans::PropertyValues OptimizationStats::GetStatusSequence()
53 {
54  int i = 0;
55  uno::Sequence< PropertyValue > aStatsSequence( maStats.size() );
56  for( const auto& rEntry : maStats )
57  {
58  aStatsSequence[ i ].Name = TKGet( rEntry.first );
59  aStatsSequence[ i++ ].Value = rEntry.second;
60  }
61  return aStatsSequence;
62 }
63 
64 
65 void OptimizationStats::InitializeStatusValues( const uno::Sequence< PropertyValue >& rOptimizationStats )
66 {
67  for( const auto& rStat : rOptimizationStats )
68  maStats[ TKGet( rStat.Name ) ] = rStat.Value;
69 }
70 
71 
72 void OptimizationStats::InitializeStatusValuesFromDocument( const Reference< XModel >& rxModel )
73 {
74  try
75  {
76  Reference< XDrawPagesSupplier > xDrawPagesSupplier( rxModel, UNO_QUERY_THROW );
77  Reference< XDrawPages > xDrawPages( xDrawPagesSupplier->getDrawPages(), UNO_SET_THROW );
78  SetStatusValue( TK_Pages, Any( awt::Size( 0, xDrawPages->getCount() ) ) );
79  }
80  catch ( Exception& )
81  {
82  }
83 }
84 
85 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
const css::uno::Any * GetStatusValue(const PPPOptimizerTokenEnum eStat) const
void InitializeStatusValues(const css::uno::Sequence< css::beans::PropertyValue > &rOptimizationStats)
void SetStatusValue(const PPPOptimizerTokenEnum eStat, const css::uno::Any &rStatValue)
void InitializeStatusValuesFromDocument(const css::uno::Reference< css::frame::XModel > &rxModel)
PPPOptimizerTokenEnum
int i
std::map< PPPOptimizerTokenEnum, css::uno::Any > maStats
PPPOptimizerTokenEnum TKGet(const OUString &rToken)
css::beans::PropertyValues GetStatusSequence()