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
|
// This file is part of the AspectC++ compiler 'ac++'.
// Copyright (C) 1999-2003 The 'ac++' developers (see aspectc.org)
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation; either version 2 of
// the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public
// License along with this program; if not, write to the Free
// Software Foundation, Inc., 59 Temple Place, Suite 330, Boston,
// MA 02111-1307 USA
#include "AspectInfo.h"
#include "AdviceInfo.h"
//
//#include "Puma/CFunctionInfo.h"
//
//// for workaround
//#include "Puma/CClassDatabase.h"
//#include "Puma/CTree.h"
//
//CFunctionInfo *AspectInfo::aspectof () {
// // make this better!
// CFunctionInfo *aof = ClassInfo ()->Function ("aspectof");
// if (!aof)
// aof = ClassInfo ()->Function ("aspectOf");
// return aof ? aof->DefObject () : (CFunctionInfo*)0;
//
//}
//
// generate the invocation function forward declarations
string AspectInfo::ifct_decls (const BackEndProblems &bep) const {
// name of this aspect
string me (name ());
string decls = string ("\n") +
"#ifndef __ac_fwd_" + me + "__\n"
"#define __ac_fwd_" + me + "__\n"
"class " + me + ";\n"
"namespace AC {\n";
stringstream ifct_decls;
for (list<AdviceInfo*>::const_iterator iter = _advice_infos.begin ();
iter != _advice_infos.end (); ++iter) {
(*iter)->gen_invocation_func (ifct_decls, false, bep);
}
decls += ifct_decls.str ();
decls += "}\n";
decls += "#endif\n\n";
return decls;
}
// generate the invocation function definitions
string AspectInfo::ifct_defs (const BackEndProblems &bep) const {
stringstream defs;
defs << endl;
defs << "namespace AC {" << endl;
for (list<AdviceInfo*>::const_iterator iter = _advice_infos.begin ();
iter != _advice_infos.end (); ++iter) {
(*iter)->gen_invocation_func (defs, true, bep);
}
defs << "} " << endl;
return defs.str ();
}
|