SectionData.h revision 22add6ff3426df1a85089fe6a6e1597ee3b6f300
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_SECTION_DATA_H
10#define MCLD_LD_SECTION_DATA_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  const LDSection& getSection() const { return *m_pSection; }
59  LDSection&       getSection()       { return *m_pSection; }
60
61  FragmentListType &getFragmentList() { return m_Fragments; }
62  const FragmentListType &getFragmentList() const { return m_Fragments; }
63
64  size_t size() const { return m_Fragments.size(); }
65
66  bool empty() const { return m_Fragments.empty(); }
67
68  reference              front ()       { return m_Fragments.front();  }
69  const_reference        front () const { return m_Fragments.front();  }
70  reference              back  ()       { return m_Fragments.back();   }
71  const_reference        back  () const { return m_Fragments.back();   }
72
73  const_iterator         begin () const { return m_Fragments.begin();  }
74  iterator               begin ()       { return m_Fragments.begin();  }
75  const_iterator         end   () const { return m_Fragments.end();    }
76  iterator               end   ()       { return m_Fragments.end();    }
77  const_reverse_iterator rbegin() const { return m_Fragments.rbegin(); }
78  reverse_iterator       rbegin()       { return m_Fragments.rbegin(); }
79  const_reverse_iterator rend  () const { return m_Fragments.rend();   }
80  reverse_iterator       rend  ()       { return m_Fragments.rend();   }
81
82private:
83  FragmentListType m_Fragments;
84  LDSection* m_pSection;
85
86};
87
88} // namespace of mcld
89
90#endif
91
92