source: XMLIO_V2/external/src/POCO/Foundation.save/Poco/AsyncChannel.h @ 80

Last change on this file since 80 was 80, checked in by ymipsl, 14 years ago

ajout lib externe

  • Property svn:eol-style set to native
File size: 3.7 KB
Line 
1//
2// AsyncChannel.h
3//
4// $Id: //poco/1.3/Foundation/include/Poco/AsyncChannel.h#2 $
5//
6// Library: Foundation
7// Package: Logging
8// Module:  AsyncChannel
9//
10// Definition of the AsyncChannel class.
11//
12// Copyright (c) 2004-2007, Applied Informatics Software Engineering GmbH.
13// and Contributors.
14//
15// Permission is hereby granted, free of charge, to any person or organization
16// obtaining a copy of the software and accompanying documentation covered by
17// this license (the "Software") to use, reproduce, display, distribute,
18// execute, and transmit the Software, and to prepare derivative works of the
19// Software, and to permit third-parties to whom the Software is furnished to
20// do so, all subject to the following:
21//
22// The copyright notices in the Software and this entire statement, including
23// the above license grant, this restriction and the following disclaimer,
24// must be included in all copies of the Software, in whole or in part, and
25// all derivative works of the Software, unless such copies or derivative
26// works are solely in the form of machine-executable object code generated by
27// a source language processor.
28//
29// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
30// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
31// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
32// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
33// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
34// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
35// DEALINGS IN THE SOFTWARE.
36//
37
38
39#ifndef Foundation_AsyncChannel_INCLUDED
40#define Foundation_AsyncChannel_INCLUDED
41
42
43#include "Poco/Foundation.h"
44#include "Poco/Channel.h"
45#include "Poco/Thread.h"
46#include "Poco/Mutex.h"
47#include "Poco/Runnable.h"
48#include "Poco/NotificationQueue.h"
49
50
51namespace Poco {
52
53
54class Foundation_API AsyncChannel: public Channel, public Runnable
55        /// A channel uses a separate thread for logging.
56        ///
57        /// Using this channel can help to improve the performance of
58        /// applications that produce huge amounts of log messages or
59        /// that write log messages to multiple channels simultaneously.
60        ///
61        /// All log messages are put into a queue and this queue is
62        /// then processed by a separate thread.
63{
64public:
65        AsyncChannel(Channel* pChannel = 0, Thread::Priority prio = Thread::PRIO_NORMAL);
66                /// Creates the AsyncChannel and connects it to
67                /// the given channel.
68
69        void setChannel(Channel* pChannel);
70                /// Connects the AsyncChannel to the given target channel.
71                /// All messages will be forwarded to this channel.
72               
73        Channel* getChannel() const;
74                /// Returns the target channel.
75
76        void open();
77                /// Opens the channel and creates the
78                /// background ;ogging thread.
79               
80        void close();
81                /// Closes the channel and stops the background
82                /// logging thread.
83
84        void log(const Message& msg);
85                /// Queues the message for processing by the
86                /// background thread.
87
88        void setProperty(const std::string& name, const std::string& value);
89                /// Sets or changes a configuration property.
90                ///
91                /// The "channel" property allows setting the target
92                /// channel via the LoggingRegistry.
93                /// The "channel" property is set-only.
94                ///
95                /// The "priority" property allows setting the thread
96                /// priority. The following values are supported:
97                ///    * lowest
98                ///    * low
99                ///    * normal (default)
100                ///    * high
101                ///    * highest
102                ///
103                /// The "priority" property is set-only.
104
105protected:
106        ~AsyncChannel();
107        void run();
108        void setPriority(const std::string& value);
109               
110private:
111        Channel*  _pChannel;
112        Thread    _thread;
113        FastMutex _mutex;
114        NotificationQueue _queue;
115};
116
117
118} // namespace Poco
119
120
121#endif // Foundation_AsyncChannel_INCLUDED
Note: See TracBrowser for help on using the repository browser.