~ubuntu-branches/ubuntu/maverick/clamav/maverick-backports

« back to all changes in this revision

Viewing changes to libclamav/c++/llvm/include/llvm/Support/GetElementPtrTypeIterator.h

  • Committer: Bazaar Package Importer
  • Author(s): Stephen Gran, Stephen Gran, Michael Tautschnig
  • Date: 2010-04-26 21:41:18 UTC
  • mfrom: (2.1.6 squeeze)
  • Revision ID: james.westby@ubuntu.com-20100426214118-i6lo606wnh7ywfj6
Tags: 0.96+dfsg-4
[ Stephen Gran ]
* Fixed typo in clamav-milter's postinst

[ Michael Tautschnig ]
* Fixed typo in clamav-freshclam's postinst (closes: #579271)
* Debconf translation updates
  - Portuguese (closes: #579068)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
//===- llvm/Support/GetElementPtrTypeIterator.h -----------------*- C++ -*-===//
 
2
//
 
3
//                     The LLVM Compiler Infrastructure
 
4
//
 
5
// This file is distributed under the University of Illinois Open Source
 
6
// License. See LICENSE.TXT for details.
 
7
//
 
8
//===----------------------------------------------------------------------===//
 
9
//
 
10
// This file implements an iterator for walking through the types indexed by
 
11
// getelementptr instructions.
 
12
//
 
13
//===----------------------------------------------------------------------===//
 
14
 
 
15
#ifndef LLVM_SUPPORT_GETELEMENTPTRTYPE_H
 
16
#define LLVM_SUPPORT_GETELEMENTPTRTYPE_H
 
17
 
 
18
#include "llvm/User.h"
 
19
#include "llvm/DerivedTypes.h"
 
20
 
 
21
namespace llvm {
 
22
  template<typename ItTy = User::const_op_iterator>
 
23
  class generic_gep_type_iterator
 
24
    : public std::iterator<std::forward_iterator_tag, const Type *, ptrdiff_t> {
 
25
    typedef std::iterator<std::forward_iterator_tag,
 
26
                          const Type *, ptrdiff_t> super;
 
27
 
 
28
    ItTy OpIt;
 
29
    const Type *CurTy;
 
30
    generic_gep_type_iterator() {}
 
31
  public:
 
32
 
 
33
    static generic_gep_type_iterator begin(const Type *Ty, ItTy It) {
 
34
      generic_gep_type_iterator I;
 
35
      I.CurTy = Ty;
 
36
      I.OpIt = It;
 
37
      return I;
 
38
    }
 
39
    static generic_gep_type_iterator end(ItTy It) {
 
40
      generic_gep_type_iterator I;
 
41
      I.CurTy = 0;
 
42
      I.OpIt = It;
 
43
      return I;
 
44
    }
 
45
 
 
46
    bool operator==(const generic_gep_type_iterator& x) const {
 
47
      return OpIt == x.OpIt;
 
48
    }
 
49
    bool operator!=(const generic_gep_type_iterator& x) const {
 
50
      return !operator==(x);
 
51
    }
 
52
 
 
53
    const Type *operator*() const {
 
54
      return CurTy;
 
55
    }
 
56
 
 
57
    const Type *getIndexedType() const {
 
58
      const CompositeType *CT = cast<CompositeType>(CurTy);
 
59
      return CT->getTypeAtIndex(getOperand());
 
60
    }
 
61
 
 
62
    // This is a non-standard operator->.  It allows you to call methods on the
 
63
    // current type directly.
 
64
    const Type *operator->() const { return operator*(); }
 
65
 
 
66
    Value *getOperand() const { return *OpIt; }
 
67
 
 
68
    generic_gep_type_iterator& operator++() {   // Preincrement
 
69
      if (const CompositeType *CT = dyn_cast<CompositeType>(CurTy)) {
 
70
        CurTy = CT->getTypeAtIndex(getOperand());
 
71
      } else {
 
72
        CurTy = 0;
 
73
      }
 
74
      ++OpIt;
 
75
      return *this;
 
76
    }
 
77
 
 
78
    generic_gep_type_iterator operator++(int) { // Postincrement
 
79
      generic_gep_type_iterator tmp = *this; ++*this; return tmp;
 
80
    }
 
81
  };
 
82
 
 
83
  typedef generic_gep_type_iterator<> gep_type_iterator;
 
84
 
 
85
  inline gep_type_iterator gep_type_begin(const User *GEP) {
 
86
    return gep_type_iterator::begin(GEP->getOperand(0)->getType(),
 
87
                                    GEP->op_begin()+1);
 
88
  }
 
89
  inline gep_type_iterator gep_type_end(const User *GEP) {
 
90
    return gep_type_iterator::end(GEP->op_end());
 
91
  }
 
92
  inline gep_type_iterator gep_type_begin(const User &GEP) {
 
93
    return gep_type_iterator::begin(GEP.getOperand(0)->getType(),
 
94
                                    GEP.op_begin()+1);
 
95
  }
 
96
  inline gep_type_iterator gep_type_end(const User &GEP) {
 
97
    return gep_type_iterator::end(GEP.op_end());
 
98
  }
 
99
 
 
100
  template<typename ItTy>
 
101
  inline generic_gep_type_iterator<ItTy>
 
102
  gep_type_begin(const Type *Op0, ItTy I, ItTy E) {
 
103
    return generic_gep_type_iterator<ItTy>::begin(Op0, I);
 
104
  }
 
105
 
 
106
  template<typename ItTy>
 
107
  inline generic_gep_type_iterator<ItTy>
 
108
  gep_type_end(const Type *Op0, ItTy I, ItTy E) {
 
109
    return generic_gep_type_iterator<ItTy>::end(E);
 
110
  }
 
111
} // end namespace llvm
 
112
 
 
113
#endif