~louis/ubuntu/trusty/clamav/lp799623_fix_logrotate

« back to all changes in this revision

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

  • Committer: Bazaar Package Importer
  • Author(s): Scott Kitterman
  • Date: 2010-03-12 11:30:04 UTC
  • mfrom: (0.41.1 upstream)
  • Revision ID: james.westby@ubuntu.com-20100312113004-b0fop4bkycszdd0z
Tags: 0.96~rc1+dfsg-0ubuntu1
* New upstream RC - FFE (LP: #537636):
  - Add OfficialDatabaseOnly option to clamav-base.postinst.in
  - Add LocalSocketGroup option to clamav-base.postinst.in
  - Add LocalSocketMode option to clamav-base.postinst.in
  - Add CrossFilesystems option to clamav-base.postinst.in
  - Add ClamukoScannerCount option to clamav-base.postinst.in
  - Add BytecodeSecurity opiton to clamav-base.postinst.in
  - Add DetectionStatsHostID option to clamav-freshclam.postinst.in
  - Add Bytecode option to clamav-freshclam.postinst.in
  - Add MilterSocketGroup option to clamav-milter.postinst.in
  - Add MilterSocketMode option to clamav-milter.postinst.in
  - Add ReportHostname option to clamav-milter.postinst.in
  - Bump libclamav SO version to 6.1.0 in libclamav6.install
  - Drop clamdmon from clamav.examples (no longer shipped by upstream)
  - Drop libclamav.a from libclamav-dev.install (not built by upstream)
  - Update SO version for lintian override for libclamav6
  - Add new Bytecode Testing Tool, usr/bin/clambc, to clamav.install
  - Add build-depends on python and python-setuptools for new test suite
  - Update debian/copyright for the embedded copy of llvm (using the system
    llvm is not currently feasible)

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