SectionData.h revision 87f34658dec9097d987d254a990ea7f311bfc95f
1//===- SectionData.h ------------------------------------------------------===//
2//
3//                     The MCLinker Project
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9#ifndef MCLD_LD_SECTIONDATA_H
10#define MCLD_LD_SECTIONDATA_H
11#ifdef ENABLE_UNITTEST
12#include <gtest.h>
13#endif
14
15#include <llvm/ADT/ilist.h>
16#include <llvm/ADT/ilist_node.h>
17#include <llvm/Support/DataTypes.h>
18
19#include <mcld/Config/Config.h>
20#include <mcld/Support/Allocators.h>
21#include <mcld/Fragment/Fragment.h>
22
23namespace mcld {
24
25class LDSection;
26
27/** \class SectionData
28 *  \brief SectionData provides a container for all Fragments.
29 */
30class SectionData
31{
32private:
33  friend class Chunk<SectionData, MCLD_SECTIONS_PER_INPUT>;
34
35  SectionData();
36  explicit SectionData(LDSection &pSection);
37
38  SectionData(const SectionData &);            // DO NOT IMPLEMENT
39  SectionData& operator=(const SectionData &); // DO NOT IMPLEMENT
40
41public:
42  typedef llvm::iplist<Fragment> FragmentListType;
43
44  typedef FragmentListType::reference reference;
45  typedef FragmentListType::const_reference const_reference;
46
47  typedef FragmentListType::iterator iterator;
48  typedef FragmentListType::const_iterator const_iterator;
49
50  typedef FragmentListType::reverse_iterator reverse_iterator;
51  typedef FragmentListType::const_reverse_iterator const_reverse_iterator;
52
53public:
54  static SectionData* Create(LDSection& pSection);
55
56  static void Destroy(SectionData*& pSection);
57
58  static void Clear();
59
60  const LDSection& getSection() const { return *m_pSection; }
61  LDSection&       getSection()       { return *m_pSection; }
62
63  FragmentListType &getFragmentList() { return m_Fragments; }
64  const FragmentListType &getFragmentList() const { return m_Fragments; }
65
66  size_t size() const { return m_Fragments.size(); }
67
68  bool empty() const { return m_Fragments.empty(); }
69
70  reference              front ()       { return m_Fragments.front();  }
71  const_reference        front () const { return m_Fragments.front();  }
72  reference              back  ()       { return m_Fragments.back();   }
73  const_reference        back  () const { return m_Fragments.back();   }
74
75  const_iterator         begin () const { return m_Fragments.begin();  }
76  iterator               begin ()       { return m_Fragments.begin();  }
77  const_iterator         end   () const { return m_Fragments.end();    }
78  iterator               end   ()       { return m_Fragments.end();    }
79  const_reverse_iterator rbegin() const { return m_Fragments.rbegin(); }
80  reverse_iterator       rbegin()       { return m_Fragments.rbegin(); }
81  const_reverse_iterator rend  () const { return m_Fragments.rend();   }
82  reverse_iterator       rend  ()       { return m_Fragments.rend();   }
83
84private:
85  FragmentListType m_Fragments;
86  LDSection* m_pSection;
87
88};
89
90} // namespace of mcld
91
92#endif
93
94