2010-06-28 14:48:19 +00:00
|
|
|
#include "literals.hpp"
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
namespace Compiler
|
|
|
|
{
|
|
|
|
int Literals::getIntegerSize() const
|
|
|
|
{
|
2021-05-02 06:43:44 +00:00
|
|
|
return static_cast<int>(mIntegers.size() * sizeof(Interpreter::Type_Integer));
|
2010-06-28 14:48:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int Literals::getFloatSize() const
|
|
|
|
{
|
2021-05-02 06:43:44 +00:00
|
|
|
return static_cast<int>(mFloats.size() * sizeof(Interpreter::Type_Float));
|
2010-06-28 14:48:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int Literals::getStringSize() const
|
|
|
|
{
|
|
|
|
int size = 0;
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
for (std::vector<std::string>::const_iterator iter(mStrings.begin()); iter != mStrings.end(); ++iter)
|
|
|
|
size += static_cast<int>(iter->size()) + 1;
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
if (size % 4) // padding
|
|
|
|
size += 4 - size % 4;
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
return size;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Literals::append(std::vector<Interpreter::Type_Code>& code) const
|
|
|
|
{
|
2020-10-22 21:57:53 +00:00
|
|
|
for (const int& mInteger : mIntegers)
|
|
|
|
code.push_back(*reinterpret_cast<const Interpreter::Type_Code*>(&mInteger));
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2020-10-22 21:57:53 +00:00
|
|
|
for (const float& mFloat : mFloats)
|
|
|
|
code.push_back(*reinterpret_cast<const Interpreter::Type_Code*>(&mFloat));
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
int stringBlockSize = getStringSize();
|
|
|
|
int size = static_cast<int>(code.size());
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
code.resize(size + stringBlockSize / 4);
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2021-05-02 06:43:44 +00:00
|
|
|
size_t offset = 0;
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2020-10-22 21:57:53 +00:00
|
|
|
for (const auto& mString : mStrings)
|
2010-06-28 14:48:19 +00:00
|
|
|
{
|
2021-05-02 06:43:44 +00:00
|
|
|
size_t stringSize = mString.size() + 1;
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2020-10-22 21:57:53 +00:00
|
|
|
std::copy(mString.c_str(), mString.c_str() + stringSize, reinterpret_cast<char*>(&code[size]) + offset);
|
2010-06-28 14:48:19 +00:00
|
|
|
offset += stringSize;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int Literals::addInteger(Interpreter::Type_Integer value)
|
|
|
|
{
|
|
|
|
int index = static_cast<int>(mIntegers.size());
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
mIntegers.push_back(value);
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
return index;
|
|
|
|
}
|
|
|
|
|
|
|
|
int Literals::addFloat(Interpreter::Type_Float value)
|
|
|
|
{
|
|
|
|
int index = static_cast<int>(mFloats.size());
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
mFloats.push_back(value);
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
return index;
|
|
|
|
}
|
|
|
|
|
|
|
|
int Literals::addString(const std::string& value)
|
|
|
|
{
|
|
|
|
int index = static_cast<int>(mStrings.size());
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
mStrings.push_back(value);
|
2022-09-22 18:26:05 +00:00
|
|
|
|
2010-06-28 14:48:19 +00:00
|
|
|
return index;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Literals::clear()
|
|
|
|
{
|
|
|
|
mIntegers.clear();
|
|
|
|
mFloats.clear();
|
|
|
|
mStrings.clear();
|
|
|
|
}
|
|
|
|
}
|