From 267c6f2ac71f92999e969232431ba04678e7437e Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 15 Apr 2024 07:54:39 +0200 Subject: Adding upstream version 4:24.2.0. Signed-off-by: Daniel Baumann --- include/svtools/templatefoldercache.hxx | 89 +++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 include/svtools/templatefoldercache.hxx (limited to 'include/svtools/templatefoldercache.hxx') diff --git a/include/svtools/templatefoldercache.hxx b/include/svtools/templatefoldercache.hxx new file mode 100644 index 0000000000..a7bcb785fe --- /dev/null +++ b/include/svtools/templatefoldercache.hxx @@ -0,0 +1,89 @@ +/* -*- 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 . + */ + +#pragma once + +#include +#include +#include +#include + +namespace svt +{ + + + //= TemplateFolderCache + + class TemplateFolderCacheImpl; + /** allows to cache the state of the template directories of OOo +

Usually, this class is used together with an instance of the + DocumentTemplates 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.
+ 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.

+ @example C++ + + 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 + + */ + class UNLESS_MERGELIBS(SVT_DLLPUBLIC) TemplateFolderCache + { + private: + std::unique_ptr> m_pImpl; + + public: + /** ctor. + @param _bAutoStoreState + Set this to if you want the instance to automatically store the state of the template folders upon + destruction.
+ If set to , you would explicitly need to call storeState to do this.
+ 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 _bAutoStoreState flag. + */ + TemplateFolderCache( bool _bAutoStoreState = false ); + ~TemplateFolderCache( ); + + /** determines whether or not the template configuration needs to be updated + @return + if the template configuration needs to be updated + */ + bool needsUpdate(); + + /** stores the current state of the template folders in the cache */ + void storeState(); + }; + + +} // namespace svt + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ -- cgit v1.2.3