DSPTool: Get rid of raw new and delete

We can just use a vector of a vector, which also has the benefit of
keeping the size accounted for as well, allowing us to get rid of a
count parameter for CodesToHeader().
This commit is contained in:
Lioncash 2018-06-22 16:56:57 -04:00
parent d81e3fddce
commit 83dab8dd36

View File

@ -73,46 +73,46 @@ static std::string CodeToHeader(const std::vector<u16>& code, const std::string&
return header; return header;
} }
static std::string CodesToHeader(const std::vector<u16>* codes, static std::string CodesToHeader(const std::vector<std::vector<u16>>& codes,
const std::vector<std::string>* filenames, u32 num_codes) const std::vector<std::string>& filenames)
{ {
std::vector<std::vector<u16>> codes_padded; std::vector<std::vector<u16>> codes_padded;
std::size_t reserveSize = 0; std::size_t reserve_size = 0;
for (u32 i = 0; i < num_codes; i++) for (std::size_t i = 0; i < codes.size(); i++)
{ {
codes_padded.push_back(codes[i]); codes_padded.push_back(codes[i]);
// Pad with nops to 32byte boundary // Pad with nops to 32byte boundary
while (codes_padded.at(i).size() & 0x7f) while (codes_padded[i].size() & 0x7f)
codes_padded.at(i).push_back(0); codes_padded[i].push_back(0);
reserveSize += codes_padded.at(i).size(); reserve_size += codes_padded[i].size();
} }
std::string header; std::string header;
header.reserve(reserveSize * 4); header.reserve(reserve_size * 4);
header.append(StringFromFormat("#define NUM_UCODES %u\n\n", num_codes)); header.append(StringFromFormat("#define NUM_UCODES %zu\n\n", codes.size()));
header.append("const char* UCODE_NAMES[NUM_UCODES] = {\n"); header.append("const char* UCODE_NAMES[NUM_UCODES] = {\n");
for (u32 i = 0; i < num_codes; i++) for (const std::string& in_filename : filenames)
{ {
std::string filename; std::string filename;
if (!SplitPath(filenames->at(i), nullptr, &filename, nullptr)) if (!SplitPath(in_filename, nullptr, &filename, nullptr))
filename = filenames->at(i); filename = in_filename;
header.append(StringFromFormat("\t\"%s\",\n", filename.c_str())); header.append(StringFromFormat("\t\"%s\",\n", filename.c_str()));
} }
header.append("};\n\n"); header.append("};\n\n");
header.append("const unsigned short dsp_code[NUM_UCODES][0x1000] = {\n"); header.append("const unsigned short dsp_code[NUM_UCODES][0x1000] = {\n");
for (u32 i = 0; i < num_codes; i++) for (std::size_t i = 0; i < codes.size(); i++)
{ {
if (codes[i].size() == 0) if (codes[i].empty())
continue; continue;
header.append("\t{\n\t\t"); header.append("\t{\n\t\t");
for (u32 j = 0; j < codes_padded.at(i).size(); j++) for (std::size_t j = 0; j < codes_padded[i].size(); j++)
{ {
if (j && ((j & 15) == 0)) if (j && ((j & 15) == 0))
header.append("\n\t\t"); header.append("\n\t\t");
header.append(StringFromFormat("0x%04x, ", codes_padded.at(i).at(j))); header.append(StringFromFormat("0x%04x, ", codes_padded[i][j]));
} }
header.append("\n\t},\n"); header.append("\n\t},\n");
} }
@ -290,7 +290,7 @@ static bool PerformAssembly(const std::string& input_name, const std::string& ou
return false; return false;
} }
std::vector<u16>* codes = new std::vector<u16>[lines]; std::vector<std::vector<u16>> codes(lines);
for (int i = 0; i < lines; i++) for (int i = 0; i < lines; i++)
{ {
@ -313,10 +313,8 @@ static bool PerformAssembly(const std::string& input_name, const std::string& ou
} }
} }
const std::string header = CodesToHeader(codes, &files, lines); const std::string header = CodesToHeader(codes, files);
File::WriteStringToFile(header, output_header_name + ".h"); File::WriteStringToFile(header, output_header_name + ".h");
delete[] codes;
} }
else else
{ {