Library of Assembled Shared Sources
process.h
Go to the documentation of this file.
1/** @file
2 * @author Bram de Greve (bram@cocamware.com)
3 * @author Tom De Muer (tom@cocamware.com)
4 *
5 * *** BEGIN LICENSE INFORMATION ***
6 *
7 * The contents of this file are subject to the Common Public Attribution License
8 * Version 1.0 (the "License"); you may not use this file except in compliance with
9 * the License. You may obtain a copy of the License at
10 * http://lass.sourceforge.net/cpal-license. The License is based on the
11 * Mozilla Public License Version 1.1 but Sections 14 and 15 have been added to cover
12 * use of software over a computer network and provide for limited attribution for
13 * the Original Developer. In addition, Exhibit A has been modified to be consistent
14 * with Exhibit B.
15 *
16 * Software distributed under the License is distributed on an "AS IS" basis, WITHOUT
17 * WARRANTY OF ANY KIND, either express or implied. See the License for the specific
18 * language governing rights and limitations under the License.
19 *
20 * The Original Code is LASS - Library of Assembled Shared Sources.
21 *
22 * The Initial Developer of the Original Code is Bram de Greve and Tom De Muer.
23 * The Original Developer is the Initial Developer.
24 *
25 * All portions of the code written by the Initial Developer are:
26 * Copyright (C) 2004-2011 the Initial Developer.
27 * All Rights Reserved.
28 *
29 * Contributor(s):
30 *
31 * Alternatively, the contents of this file may be used under the terms of the
32 * GNU General Public License Version 2 or later (the GPL), in which case the
33 * provisions of GPL are applicable instead of those above. If you wish to allow use
34 * of your version of this file only under the terms of the GPL and not to allow
35 * others to use your version of this file under the CPAL, indicate your decision by
36 * deleting the provisions above and replace them with the notice and other
37 * provisions required by the GPL License. If you do not delete the provisions above,
38 * a recipient may use your version of this file under either the CPAL or the GPL.
39 *
40 * *** END LICENSE INFORMATION ***
41 */
42
43
44
45#ifndef LASS_GUARDIAN_OF_INCLUSION_UTIL_PROCESS_H
46#define LASS_GUARDIAN_OF_INCLUSION_UTIL_PROCESS_H
47
48#include "util_common.h"
49#include "dictionary.h"
50#include "singleton.h"
51
52/** @defgroup Process
53 * @brief module concerning process settings
54 */
55
56namespace lass
57{
58namespace util
59{
60
61/** different process priority levels
62 * @ingroup Process
63 */
65{
66 ppLow,
67 ppBelowNormal,
68 ppNormal,
69 ppAboveNormal,
70 ppHigh,
71 numberOfProcessPriorities
72};
73
74/** type of dictionary that can translate strings to ProcessPriority values.
75 * @ingroup Process
76 * Its keys are strings, its values are ProcessPriority values.
77 */
79
80/** singleton with dictionary that can translate strings to ProcessPriority.
81 * @ingroup Process
82 * Valid keys are "low", "belownormal", "normal", "abovenormal" and "high".
83 * @code
84 * ProcessPriority priority = processPriorityDictionary()["normal"];
85 * @endcode
86 */
91
92/** set process priority by ProcessPriority value
93 * @ingroup Process
94 * @param iPriority
95 * One of the values of ProcessPriority except numberOfProcessPriorities!
96 * @throw Exception
97 * An exception is thrown if setting the process priority fails.
98 */
100
101/** set process priority by string
102 * @ingroup Process
103 * @param iPriority
104 * The key string which is looked up in processPriorityDictionary().
105 * The return is used to set the process priority.
106 * See TProcessPriorityDictionary for valid keys.
107 * @throw Exception
108 * An exception is thrown if @a iPriority is an invalid key or
109 * setting the process priority fails.
110 */
111LASS_DLL void LASS_CALL setProcessPriority(const std::string& iPriority);
112
113}
114
115}
116
117#endif
118
119// EOF
a wrapper around a std::map to translate keys in values and back.
Definition dictionary.h:150
static TInstance * instance()
Return pointer to singleton instance.
Definition singleton.inl:82
util::Dictionary< std::string, ProcessPriority > TProcessPriorityDictionary
type of dictionary that can translate strings to ProcessPriority values.
Definition process.h:78
ProcessPriority
different process priority levels
Definition process.h:65
TProcessPriorityDictionary & processPriorityDictionary()
singleton with dictionary that can translate strings to ProcessPriority.
Definition process.h:87
void setProcessPriority(const std::string &iPriority)
set process priority by string
Definition process.cpp:120
#define LASS_DLL
DLL interface: import or export symbols?
general utility, debug facilities, ...
Library for Assembled Shared Sources.
Definition config.h:53