Library of Assembled Shared Sources
proxy_man.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/** @class lass::io::ProxyMan
45 * @brief manages the four proxy streams.
46 * @date 2003
47 *
48 * Lass has four proxy streams that replace the regular std streams and lass::io::ProxyMan owns them
49 * You can access these streams by three manners:
50 * - through the four member functions lass::io::ProxyMan::cout(), lass::io::ProxyMan::clog(),
51 * lass::io::ProxyMan::cerr() and lass::io::ProxyMan::cin() which return pointers to these streams.
52 * - through the four free functions lass::io::cout(), lass::io::cerr(), lass::io::clog() and
53 * lass::io::cin() which return references to these streams
54 * - by the four macros LASS_COUT, LASS_CERR, LASS_CLOG and LASS_CIN which return references too.
55 *
56 * ProxyMan is a singleton, you can access it through ProxyMan::instance() or proxyMan(), both
57 * returning a pointer to the singleton.
58 *
59 * The four proxy streams are created on first access of the ProxyMan singleton or any of its
60 * proxy streams and are automatically redirected to std::cout, std::cerr, std::clog and std::cin
61 * respectively.
62 */
63
64#ifndef LASS_GUARDIAN_OF_INCLUSION_IO_PROXY_MAN_H
65#define LASS_GUARDIAN_OF_INCLUSION_IO_PROXY_MAN_H
66
67#include "io_common.h"
68#include "proxy_o_stream.h"
69#include "proxy_i_stream.h"
71
72namespace lass
73{
74namespace io
75{
76
78{
79public:
80
81 ProxyMan();
82 ~ProxyMan();
83
84 ProxyOStream* cout() { return cout_; }
85 ProxyOStream* cerr() { return cerr_; }
86 ProxyOStream* clog() { return clog_; }
87 ProxyIStream* cin() { return cin_; }
88
89private:
90
91 ProxyOStream* cout_;
92 ProxyOStream* cerr_;
93 ProxyOStream* clog_;
94 ProxyIStream* cin_;
95};
96
97LASS_DLL ProxyMan* LASS_CALL proxyMan();
98
99}
100
101}
102
103#endif
manages the four proxy streams.
Definition proxy_man.h:78
A proxy output stream can distribute output to multiple destination streams.
use as base class if derived should not be copyable
#define LASS_DLL
DLL interface: import or export symbols?
streams, binary streams, vrmlstreams, ...
ProxyMan * proxyMan()
access the ProxyMan singleton
Definition proxy_man.cpp:74
Library for Assembled Shared Sources.
Definition config.h:53