2010-10-14 08:27:31 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2012-06-21 14:30:25 +01:00
|
|
|
/*
|
|
|
|
* 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 .
|
|
|
|
*/
|
2001-12-06 11:30:53 +00:00
|
|
|
|
2013-10-23 19:14:56 +02:00
|
|
|
#ifndef INCLUDED_SVTOOLS_TEMPLATEFOLDERCACHE_HXX
|
|
|
|
#define INCLUDED_SVTOOLS_TEMPLATEFOLDERCACHE_HXX
|
2001-12-06 11:30:53 +00:00
|
|
|
|
2013-11-09 15:40:46 -06:00
|
|
|
#include <svtools/svtdllapi.h>
|
2001-12-06 11:30:53 +00:00
|
|
|
#include <sal/types.h>
|
2017-08-25 11:09:38 +01:00
|
|
|
#include <o3tl/deleter.hxx>
|
2015-11-17 14:36:31 +02:00
|
|
|
#include <memory>
|
2001-12-06 11:30:53 +00:00
|
|
|
|
|
|
|
namespace svt
|
|
|
|
{
|
|
|
|
|
2014-02-25 19:06:16 +01:00
|
|
|
|
2001-12-06 11:30:53 +00:00
|
|
|
//= TemplateFolderCache
|
2014-02-25 19:06:16 +01:00
|
|
|
|
2001-12-06 11:30:53 +00:00
|
|
|
class TemplateFolderCacheImpl;
|
|
|
|
/** allows to cache the state of the template directories of OOo
|
|
|
|
<p>Usually, this class is used together with an instance of a the
|
|
|
|
<service scope="com.sun.star.frame">DocumentTemplates</service> service. It allows to scan the template folders
|
|
|
|
of the Office, and updates the configuration so that it reflects the most recent state of the folders.<br/>
|
|
|
|
As this is an expensive, the TemplateFolderCache has been introduced. It caches the state of the template
|
|
|
|
folders, and allows to determine if the DocumentTemplates service needs to be invoked to do the (much more expensive)
|
|
|
|
update.</p>
|
|
|
|
@example C++
|
|
|
|
<listing>
|
|
|
|
TemplateFolderCache aTemplateFolders;
|
|
|
|
if ( aTemplateFolders.needsUpdate() )
|
|
|
|
{
|
|
|
|
// store the current state
|
|
|
|
aCache.storeState();
|
|
|
|
|
|
|
|
// create the DocumentTemplates instance
|
|
|
|
Reference< XDocumentTemplates > xTemplates = ...;
|
|
|
|
|
|
|
|
// update the templates configuration
|
|
|
|
xTemplates->update();
|
|
|
|
}
|
|
|
|
|
|
|
|
// do anything which relies on a up-to-date template configuration
|
|
|
|
</listing>
|
|
|
|
*/
|
2005-04-13 09:37:20 +00:00
|
|
|
class SVT_DLLPUBLIC TemplateFolderCache
|
2001-12-06 11:30:53 +00:00
|
|
|
{
|
|
|
|
private:
|
2017-08-25 11:09:38 +01:00
|
|
|
std::unique_ptr<TemplateFolderCacheImpl, o3tl::default_delete<TemplateFolderCacheImpl>> m_pImpl;
|
2001-12-06 11:30:53 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
/** ctor.
|
|
|
|
@param _bAutoStoreState
|
|
|
|
Set this to <TRUE/> if you want the instance to automatically store the state of the template folders upon
|
|
|
|
destruction.<br/>
|
2016-01-09 22:55:28 +01:00
|
|
|
If set to <FALSE/>, you would explicitly need to call <method>storeState</method> to do this.<br/>
|
2001-12-06 11:30:53 +00:00
|
|
|
If the current state is not known (e.g. because you did not call needsUpdate, which retrieves it),
|
|
|
|
it is not retrieved in the dtor, regardless of the <arg>_bAutoStoreState</arg> flag.
|
|
|
|
*/
|
2014-03-24 12:47:49 +02:00
|
|
|
TemplateFolderCache( bool _bAutoStoreState = false );
|
2001-12-06 11:30:53 +00:00
|
|
|
~TemplateFolderCache( );
|
|
|
|
|
|
|
|
/** determines whether or not the template configuration needs to be updated
|
|
|
|
@return
|
|
|
|
<TRUE/> if the template configuration needs to be updated
|
|
|
|
*/
|
2016-03-01 08:30:03 +02:00
|
|
|
bool needsUpdate();
|
2001-12-06 11:30:53 +00:00
|
|
|
|
2016-03-01 08:30:03 +02:00
|
|
|
/** stores the current state of the template folders in the cache */
|
|
|
|
void storeState();
|
2001-12-06 11:30:53 +00:00
|
|
|
};
|
|
|
|
|
2014-02-25 19:06:16 +01:00
|
|
|
|
2005-04-13 09:37:20 +00:00
|
|
|
} // namespace svt
|
2014-02-25 19:06:16 +01:00
|
|
|
|
2001-12-06 11:30:53 +00:00
|
|
|
|
2013-10-23 19:14:56 +02:00
|
|
|
#endif // INCLUDED_SVTOOLS_TEMPLATEFOLDERCACHE_HXX
|
2010-10-14 08:27:31 +02:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|