Browse Source

Projucer: Cleaned up the generated BinaryData code and added a BinaryData::originalFilenames array

tags/2021-05-28
ed 7 years ago
parent
commit
dd7d3c41d0
1 changed files with 43 additions and 18 deletions
  1. +43
    -18
      extras/Projucer/Source/ProjectSaving/jucer_ResourceFile.cpp

+ 43
- 18
extras/Projucer/Source/ProjectSaving/jucer_ResourceFile.cpp View File

@@ -142,15 +142,22 @@ Result ResourceFile::writeHeader (MemoryOutputStream& header)
} }
} }
header << " // Points to the start of a list of resource names." << newLine
<< " extern const char* namedResourceList[];" << newLine
header << " // Number of elements in the namedResourceList and originalFileNames arrays." << newLine
<< " const int namedResourceListSize = " << files.size() << ";" << newLine
<< newLine << newLine
<< " // Number of elements in the namedResourceList array." << newLine
<< " const int namedResourceListSize = " << files.size() << ";" << newLine
<< " // Points to the start of a list of resource names." << newLine
<< " extern const char* namedResourceList[];" << newLine
<< newLine << newLine
<< " // If you provide the name of one of the binary resource variables above, this function will" << newLine
<< " // return the corresponding data and its size (or a null pointer if the name isn't found)." << newLine
<< " const char* getNamedResource (const char* resourceNameUTF8, int& dataSizeInBytes) throw();" << newLine
<< " // Points to the start of a list of resource filenames." << newLine
<< " extern const char* originalFilenames[];" << newLine
<< newLine
<< " // If you provide the name of one of the binary resource variables above, this function will" << newLine
<< " // return the corresponding data and its size (or a null pointer if the name isn't found)." << newLine
<< " const char* getNamedResource (const char* resourceNameUTF8, int& dataSizeInBytes) noexcept;" << newLine
<< newLine
<< " // If you provide the name of one of the binary resource variables above, this function will" << newLine
<< " // return the corresponding original, non-mangled filename (or a null pointer if the name isn't found)." << newLine
<< " const char* getNamedResourceOriginalFilename (const char* resourceNameUTF8) noexcept;" << newLine
<< "}" << newLine; << "}" << newLine;
return Result::ok(); return Result::ok();
@@ -215,35 +222,53 @@ Result ResourceFile::writeCpp (MemoryOutputStream& cpp, const File& headerFile,
cpp << newLine cpp << newLine
<< newLine << newLine
<< "const char* getNamedResource (const char*, int&) throw();" << newLine
<< "const char* getNamedResource (const char* resourceNameUTF8, int& numBytes) throw()" << newLine
<< "const char* getNamedResource (const char* resourceNameUTF8, int& numBytes) noexcept" << newLine
<< "{" << newLine; << "{" << newLine;
StringArray returnCodes; StringArray returnCodes;
for (int j = 0; j < files.size(); ++j)
for (auto& file : files)
{ {
auto& file = files.getReference(j);
auto dataSize = file.getSize(); auto dataSize = file.getSize();
returnCodes.add ("numBytes = " + String (dataSize) + "; return " + variableNames[j] + ";");
returnCodes.add ("numBytes = " + String (dataSize) + "; return " + variableNames[files.indexOf (file)] + ";");
} }
CodeHelpers::createStringMatcher (cpp, "resourceNameUTF8", variableNames, returnCodes, 4); CodeHelpers::createStringMatcher (cpp, "resourceNameUTF8", variableNames, returnCodes, 4);
cpp << " numBytes = 0;" << newLine cpp << " numBytes = 0;" << newLine
<< " return 0;" << newLine
<< " return nullptr;" << newLine
<< "}" << newLine << "}" << newLine
<< newLine
<< "const char* namedResourceList[] =" << newLine
<< newLine;
cpp << "const char* namedResourceList[] =" << newLine
<< "{" << newLine; << "{" << newLine;
for (int j = 0; j < files.size(); ++j) for (int j = 0; j < files.size(); ++j)
cpp << " " << variableNames[j].quoted() << (j < files.size() - 1 ? "," : "") << newLine; cpp << " " << variableNames[j].quoted() << (j < files.size() - 1 ? "," : "") << newLine;
cpp << "};" << newLine;
cpp << "};" << newLine << newLine;
cpp << "const char* originalFilenames[] =" << newLine
<< "{" << newLine;
for (auto& f : files)
cpp << " " << f.getFileName().quoted() << (files.indexOf (f) < files.size() - 1 ? "," : "") << newLine;
cpp << "};" << newLine << newLine;
cpp << "const char* getNamedResourceOriginalFilename (const char* resourceNameUTF8) noexcept" << newLine
<< "{" << newLine
<< " for (unsigned int i = 0; i < (sizeof (namedResourceList) / sizeof (namedResourceList[0])); ++i)" << newLine
<< " {" << newLine
<< " if (namedResourceList[i] == resourceNameUTF8)" << newLine
<< " return originalFilenames[i];" << newLine
<< " }" << newLine
<< newLine
<< " return nullptr;" << newLine
<< "}" << newLine
<< newLine;
} }
cpp << newLine
<< "}" << newLine;
cpp << "}" << newLine;
return Result::ok(); return Result::ok();
} }


Loading…
Cancel
Save