mirror of
https://github.com/open-goal/jak-project.git
synced 2024-10-20 21:27:52 -04:00
9074a35b9b
* fix let prints and windows warnings * missing include for windows * windows again
44 lines
1.1 KiB
C++
44 lines
1.1 KiB
C++
#pragma once
|
|
#include <cassert>
|
|
#include <cstring>
|
|
#include <vector>
|
|
#include <string>
|
|
#include <stdexcept>
|
|
#include "common/common_types.h"
|
|
#include "decompiler/ObjectFile/LinkedWord.h"
|
|
|
|
namespace decompiler {
|
|
class LinkedWordReader {
|
|
public:
|
|
explicit LinkedWordReader(const std::vector<LinkedWord>* words) : m_words(words) {}
|
|
const std::string& get_type_tag() {
|
|
if (m_words->at(m_offset).kind == LinkedWord::TYPE_PTR) {
|
|
auto& result = m_words->at(m_offset).symbol_name;
|
|
m_offset++;
|
|
return result;
|
|
} else {
|
|
assert(false);
|
|
throw std::runtime_error("LinkedWordReader::get_type_tag failed");
|
|
}
|
|
}
|
|
|
|
template <typename T>
|
|
T get_word() {
|
|
static_assert(sizeof(T) == 4, "size of word in get_word");
|
|
T result;
|
|
assert(m_words->at(m_offset).kind == LinkedWord::PLAIN_DATA);
|
|
memcpy(&result, &m_words->at(m_offset).data, 4);
|
|
m_offset++;
|
|
return result;
|
|
}
|
|
|
|
u32 words_left() {
|
|
assert(m_words->size() >= m_offset);
|
|
return m_words->size() - m_offset;
|
|
}
|
|
|
|
private:
|
|
const std::vector<LinkedWord>* m_words = nullptr;
|
|
u32 m_offset = 0;
|
|
};
|
|
} // namespace decompiler
|