File: Phoenix.cpp

package info (click to toggle)
libloki 0.1.7-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,608 kB
  • sloc: cpp: 30,475; ansic: 1,974; makefile: 365; php: 316; perl: 108
file content (94 lines) | stat: -rw-r--r-- 2,348 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
////////////////////////////////////////////////////////////////////////////////
// The Loki Library
// Copyright (c) 2005 by Curtis Krauskopf
// Copyright (c) 2005 by Peter Kuemmel
//
// Code covered by the MIT License
// The authors make no representations about the suitability of this software
// for any purpose. It is provided "as is" without express or implied warranty.
////////////////////////////////////////////////////////////////////////////////

// $Id: Phoenix.cpp 760 2006-10-17 20:36:13Z syntheticpp $


// A singleton LogClass object that resurrects itself after
// it has been automatically destroyed during program
// termination.  When a dead-reference to the LogClass
// singleton is detected, it is resurrected automatically.
//
// Expected output:
//   Example c'tor
//   LogClass c'tor
//   LogClass now instantiated.
//   LogClass d'tor
//   Example d'tor starting
//   LogClass c'tor
//   LogClass: inside Example d'tor
//   Example d'tor finished
//
// The last line of the output only appears when this
// program is compiled with the ATEXIT_FIXED symbol
// defined (see the Loki library and the CUJ article).
//

#include <iostream>
#include <loki/Singleton.h>   // for Loki::SingletonHolder

using namespace std;   // okay for small programs
using namespace Loki;  // okay for small programs

class LogClass
{
public:
    LogClass()
    {
        echo("LogClass c'tor");
    }
    ~LogClass()
    {
        echo("LogClass d'tor");
    }
    void echo(const char *s)
    {
        cout << s << endl;
    }
};

typedef SingletonHolder<LogClass, CreateUsingNew, PhoenixSingleton> LogBook;


// A generic example class that stores and echoes a const char.
//
class Example
{
public:
    Example()
    {
        echo("Example c'tor");
    }
    ~Example()
    {
        echo("Example d'tor starting");
        LogBook::Instance().echo("LogClass: inside Example d'tor");
        echo("Example d'tor finished");
    }
    void echo(const char *s)
    {
        cout << s << endl;
    }
};


int main(int argc, char* argv[])
{
    Example *example = new Example();
     SetLongevity<Example, void (*)(Example*)>(example, 1, &Loki::Private::Deleter<Example>::Delete);
    LogBook::Instance().echo("LogClass now instantiated.");
    
#if defined(__BORLANDC__) || defined(_MSC_VER)
    system("PAUSE");
#endif

    return 0;
}