aboutsummaryrefslogtreecommitdiff
path: root/core/objects.h
diff options
context:
space:
mode:
Diffstat (limited to 'core/objects.h')
-rw-r--r--core/objects.h191
1 files changed, 191 insertions, 0 deletions
diff --git a/core/objects.h b/core/objects.h
new file mode 100644
index 0000000..0c5a269
--- /dev/null
+++ b/core/objects.h
@@ -0,0 +1,191 @@
+/**
+ * Support of object hierarchy.
+ */
+
+#ifndef OBJECTS_H
+#define OBJECTS_H
+
+std::string string_format(const char *format, ...);
+
+// TODO: find more appropriate place for {
+enum OperandSize : uint8_t {
+ osByte,
+ osWord,
+ osDWord,
+ osQWord,
+ osTByte,
+ osOWord,
+ osXMMWord,
+ osYMMWord,
+ osFWord,
+ osDefault = 0xff
+};
+
+enum MessageType {
+ mtInformation,
+ mtWarning,
+ mtError,
+ mtAdded,
+ mtChanged,
+ mtDeleted,
+ mtScript,
+};
+// }
+
+class IObject
+{
+public:
+ virtual ~IObject() {}
+ virtual int CompareWith(const IObject &) const { throw std::runtime_error("Abstract method"); }
+};
+
+class AddressableObject : public IObject
+{
+public:
+ AddressableObject() : address_(0) {}
+ AddressableObject(const AddressableObject &src) : address_(src.address_) {}
+ AddressableObject &operator=(const AddressableObject &src) { address_ = src.address_; return *this; }
+
+ using IObject::CompareWith;
+ int CompareWith(const AddressableObject &other) const;
+ uint64_t address() const { return address_; }
+ void set_address(uint64_t address) { address_ = address; }
+
+protected:
+ uint64_t address_;
+};
+
+template <typename Object>
+class ObjectList : public IObject
+{
+ //not implemented
+ ObjectList &operator=(const ObjectList &);
+public:
+ explicit ObjectList() : IObject() {}
+ explicit ObjectList(const ObjectList &src) : IObject(src) {}
+ virtual ~ObjectList() { clear(); }
+ virtual void clear()
+ {
+ while (!v_.empty()) {
+ delete v_.back();
+ }
+ }
+ void Delete(size_t index)
+ {
+ if (index >= v_.size())
+ throw std::runtime_error("subscript out of range");
+ delete v_[index];
+ }
+ size_t count() const { return v_.size(); }
+ Object *item(size_t index) const
+ {
+ if (index >= v_.size())
+ throw std::runtime_error("subscript out of range");
+ return v_[index];
+ }
+ void resize(size_t size) {
+ v_.resize(size);
+ }
+ Object *last() const { return v_.empty() ? NULL : *v_.rbegin(); }
+ static bool CompareObjects(const Object *obj1, const Object *obj2) { return obj1->CompareWith(*obj2) < 0; }
+ void Sort() { std::sort(v_.begin(), v_.end(), CompareObjects); }
+ typedef typename std::vector<Object*>::const_iterator const_iterator;
+ typedef typename std::vector<Object*>::iterator iterator;
+ size_t IndexOf(const Object *obj) const
+ {
+ const_iterator it = std::find(v_.begin(), v_.end(), obj);
+ return (it == v_.end()) ? -1 : it - v_.begin();
+ }
+
+ size_t IndexOf(const Object *obj, size_t index) const
+ {
+ const_iterator it = std::find((v_.begin()+index), v_.end(), obj);
+ return (it == v_.end()) ? -1 : it - v_.begin();
+ }
+ void SwapObjects(size_t i, size_t j) { std::swap(v_[i], v_[j]); }
+ virtual void AddObject(Object *obj) { v_.push_back(obj); }
+ virtual void InsertObject(size_t index, Object *obj) { v_.insert(v_.begin() + index, obj); }
+ virtual void RemoveObject(Object *obj)
+ {
+ for (size_t i = count(); i > 0; i--) {
+ if (item(i - 1) == obj) {
+ erase(i - 1);
+ break;
+ }
+ }
+ }
+ void erase(size_t index) { v_.erase(v_.begin() + index); }
+ void assign(const std::list<Object*> &src)
+ {
+ v_.clear();
+ for (typename std::list<Object*>::const_iterator it = src.begin(); it != src.end(); it++) {
+ v_.push_back(*it);
+ }
+ }
+
+ const_iterator begin() const { return v_.begin(); }
+ const_iterator end() const { return v_.end(); }
+
+ iterator _begin() { return v_.begin(); }
+ iterator _end() { return v_.end(); }
+
+protected:
+ void Reserve(size_t count) { v_.reserve(count); }
+ std::vector<Object*> v_;
+};
+
+class Data
+{
+public:
+ Data() {}
+ Data(const std::vector<uint8_t> &src) { m_vData = src; }
+ void PushByte(uint8_t value) { m_vData.push_back(value); }
+ void PushDWord(uint32_t value) { PushBuff(&value, sizeof(value)); }
+ void PushQWord(uint64_t value) { PushBuff(&value, sizeof(value)); }
+ void PushWord(uint16_t value) { PushBuff(&value, sizeof(value)); }
+ void PushBuff(const void *value, size_t nCount) { m_vData.insert(m_vData.end(), reinterpret_cast<const uint8_t *>(value), reinterpret_cast<const uint8_t *>(value) + nCount); }
+ void InsertByte(size_t pos, uint8_t value) { m_vData.insert(m_vData.begin() + pos, value); }
+ void InsertBuff(size_t pos, const void *buff, size_t nCount) { m_vData.insert(m_vData.begin() + pos, reinterpret_cast<const uint8_t *>(buff), reinterpret_cast<const uint8_t *>(buff) + nCount); }
+ uint32_t ReadDWord(size_t nPosition) const { return *reinterpret_cast<const uint32_t *>(&m_vData[nPosition]); }
+ void WriteDWord(size_t nPosition, uint32_t dwValue) { *reinterpret_cast<uint32_t *>(&m_vData[nPosition]) = dwValue; }
+ size_t size() const { return m_vData.size(); }
+ void clear() { m_vData.clear(); }
+ bool empty() const { return m_vData.empty(); }
+ void resize(size_t size) { m_vData.resize(size); }
+ void resize(size_t size, uint8_t value) { m_vData.resize(size, value); }
+ const uint8_t *data() const { return m_vData.data(); }
+ const uint8_t &operator[](size_t pos) const
+ {
+ if (pos >= m_vData.size())
+ throw std::runtime_error("subscript out of range");
+ return m_vData[pos];
+ }
+ uint8_t &operator[](size_t pos)
+ {
+ if (pos >= m_vData.size())
+ throw std::runtime_error("subscript out of range");
+ return m_vData[pos];
+ }
+ bool operator < (const Data &right) const
+ {
+ return (size() != right.size()) ? (size() < right.size()) : (memcmp(data(), right.data(), size()) < 0);
+ }
+private:
+ std::vector<uint8_t> m_vData;
+};
+
+class canceled_error : public std::runtime_error
+{
+public:
+ explicit canceled_error(const std::string &message)
+ : runtime_error(message) {}
+};
+
+class abort_error : public std::runtime_error
+{
+public:
+ explicit abort_error(const std::string &message)
+ : runtime_error(message) {}
+};
+
+#endif