Patches contributed by Armin Le-Grand #118898# Adapted ImpGraphic::ImplGetBitmap to correctly convert metafiles... http://svn.apache.org/viewvc?view=revision&revision=1293316 #118485# - Styles for OLEs are not saved. http://svn.apache.org/viewvc?view=revision&revision=1182166 Patches contributed by Andre Fischer http://svn.apache.org/viewvc?view=revision&revision=1172128 http://svn.apache.org/viewvc?view=revision&revision=1172133 Patch contributed by Ariel Constenla-Haile i#118505# - Remove MN_OLE_OBJECT menu item from Draw/Impress contextmenu - CWS contextmenu1 http://svn.apache.org/viewvc?view=revision&revision=1182915 Patch contributed by Zhang Jian Fang #118876#, Add check if the OutlinerParaObject is created successfully http://svn.apache.org/viewvc?view=revision&revision=1243381 restore a re-based rdbedit.
128 lines
4.2 KiB
C++
128 lines
4.2 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 .
|
|
*/
|
|
|
|
#ifndef SD_SLIDESORTER_REQUEST_QUEUE_HXX
|
|
#define SD_SLIDESORTER_REQUEST_QUEUE_HXX
|
|
|
|
#include "SlsRequestPriorityClass.hxx"
|
|
#include "cache/SlsCacheContext.hxx"
|
|
#include "taskpane/SlideSorterCacheDisplay.hxx"
|
|
#include <drawdoc.hxx>
|
|
#include "osl/mutex.hxx"
|
|
|
|
|
|
namespace sd { namespace slidesorter { namespace cache {
|
|
|
|
class RequestData;
|
|
|
|
/** The request queue stores requests that are described by the RequestData
|
|
sorted according to priority class and then priority.
|
|
*/
|
|
class RequestQueue
|
|
{
|
|
public:
|
|
RequestQueue (const SharedCacheContext& rpCacheContext);
|
|
~RequestQueue (void);
|
|
|
|
/** Insert a request with highest or lowest priority in its priority
|
|
class. When the request is already present then it is first
|
|
removed. This effect is then a re-prioritization.
|
|
@param aKey
|
|
The request.
|
|
@param eRequestClass
|
|
The priority class in which to insert the request with highest
|
|
or lowest priority.
|
|
@param bInsertWithHighestPriority
|
|
When this flag is <TRUE/> the request is inserted with highes
|
|
priority in its class. When <FALSE/> the request is inserted
|
|
with lowest priority.
|
|
*/
|
|
void AddRequest (
|
|
CacheKey aKey,
|
|
RequestPriorityClass eRequestClass,
|
|
bool bInsertWithHighestPriority = false);
|
|
|
|
/** Remove the specified request from the queue.
|
|
@param aKey
|
|
It is OK when the specified request is not a member of the
|
|
queue.
|
|
@return
|
|
Returns <TRUE/> when the request has been successfully been
|
|
removed from the queue. Otherwise, e.g. because the request was
|
|
not a member of the queue, <FALSE/> is returned.
|
|
*/
|
|
bool RemoveRequest (CacheKey aKey);
|
|
|
|
/** Change the priority class of the specified request.
|
|
*/
|
|
void ChangeClass (
|
|
CacheKey aKey,
|
|
RequestPriorityClass eNewRequestClass);
|
|
|
|
/** Get the request with the highest priority int the highest priority class.
|
|
*/
|
|
CacheKey GetFront (void);
|
|
|
|
// For debugging.
|
|
RequestPriorityClass GetFrontPriorityClass (void);
|
|
|
|
/** Really a synonym for RemoveRequest(GetFront());
|
|
*/
|
|
void PopFront (void);
|
|
|
|
/** Returns <TRUE/> when there is no element in the queue.
|
|
*/
|
|
bool IsEmpty (void);
|
|
|
|
/** Remove all requests from the queue. This resets the minimum and
|
|
maximum priorities to their default values.
|
|
*/
|
|
void Clear (void);
|
|
|
|
/** Return the mutex that guards the access to the priority queue.
|
|
*/
|
|
::osl::Mutex& GetMutex (void);
|
|
|
|
private:
|
|
::osl::Mutex maMutex;
|
|
class Container;
|
|
::boost::scoped_ptr<Container> mpRequestQueue;
|
|
SharedCacheContext mpCacheContext;
|
|
|
|
/** A lower bound of the lowest priority of all elements in the queues.
|
|
The start value is 0. It is assigned and then decreased every time
|
|
when an element is inserted or marked as the request with lowest
|
|
priority.
|
|
*/
|
|
int mnMinimumPriority;
|
|
/** An upper bound of the highest priority of all elements in the queues.
|
|
The start value is 1. It is assigned and then increased every time
|
|
when an element is inserted or marked as the request with highest
|
|
priority.
|
|
*/
|
|
int mnMaximumPriority;
|
|
};
|
|
|
|
|
|
} } } // end of namespace ::sd::slidesorter::cache
|
|
|
|
#endif
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|