File: AspectIncludes.h

package info (click to toggle)
aspectc%2B%2B 1.0pre4~svn.20090918-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 117,308 kB
  • ctags: 410,601
  • sloc: cpp: 1,883,007; ansic: 17,279; sh: 2,190; makefile: 1,088
file content (98 lines) | stat: -rw-r--r-- 3,451 bytes parent folder | download | duplicates (2)
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
95
96
97
98
// 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                                            

#ifndef __AspectIncludes_h__
#define __AspectIncludes_h__

#include <set>
using std::set;
#include <map>
using std::map;
#include <string>
using std::string;

namespace Puma {
  class Unit;
  class CProject;
} // namespace Puma

using namespace Puma;

class AspectInfo;
#ifdef ACMODEL
class ACM_Aspect;
#else
class JPL_Aspect;
#endif
class BackEndProblems;

// this class manages all #includes and forward declarations, which have to be
// generated in order to make the aspects visible at the join points they affect

struct AspectRef {
  AspectInfo *_aspect;
  // Kind of dependency: the value defines the importance
  enum Kind { AR_UNKNOWN = 0, AR_DECL = 1, AR_ADVICE = 2 } _kind;
  bool operator < (const AspectRef &cmp) const {
    return _aspect < cmp._aspect;
  }
  bool operator == (const AspectRef &cmp) const {
    return _aspect == cmp._aspect;
  }
  AspectRef (AspectInfo *a, Kind k) : _aspect (a), _kind (k) {}
};

typedef set<AspectRef> AspectRefSet;

typedef map<Unit*, AspectRefSet> UnitAspectRefMap;

class AspectIncludes : private UnitAspectRefMap {
  // helper function that find the unit in which an aspect 'ai' is defined
#ifdef ACMODEL
  static Unit *aspect_unit (ACM_Aspect *a);
#else
  static Unit *aspect_unit (JPL_Aspect *a);
#endif
  
  // generate the #include directive for a given aspect header unit
#ifdef ACMODEL
  static string generate (CProject &project, ACM_Aspect *a);
#else
  static string generate (CProject &project, JPL_Aspect *a);
#endif
public:
  
  // this function declares that a unit 'iu' depends on the aspect 'a'
  // ('kind' specifies the kind of dependy, i.e. class def, decl, or advice)
  void insert (Unit *iu, AspectInfo *a, AspectRef::Kind kind);
  
  // interator type and functions to access the elements (only const access)
  typedef UnitAspectRefMap::const_iterator const_iterator;
  const_iterator begin () const { return UnitAspectRefMap::begin (); }
  const_iterator end () const { return UnitAspectRefMap::end (); }

  // searching ...
  using UnitAspectRefMap::find;
  // get the target unit associated with an entry
  Unit *unit (const_iterator entry) const { return (*entry).first; }
    
  // generate the #include directives for a given unit
  string generate (const_iterator entry, const BackEndProblems &bep) const;
};

#endif // __AspectIncludes_h__