From 1eda57de45790b2b4cf41e0c6342219f6660eb6b Mon Sep 17 00:00:00 2001 From: Wolfgang Thaller Date: Sat, 8 Nov 2014 00:53:12 +0100 Subject: [PATCH] ResourceFiles library: support resource names --- ResourceFiles/ResourceFork.cc | 33 +++++++++++++++++++++++++++++---- ResourceFiles/ResourceFork.h | 1 + 2 files changed, 30 insertions(+), 4 deletions(-) diff --git a/ResourceFiles/ResourceFork.cc b/ResourceFiles/ResourceFork.cc index 1e38573dda..fc2d70d0fe 100644 --- a/ResourceFiles/ResourceFork.cc +++ b/ResourceFiles/ResourceFork.cc @@ -21,7 +21,7 @@ void Resources::writeFork(std::ostream& out) const for(int i = 0; i < 0x100 - 16; i++) byte(out, 0); - std::map< std::string, std::map > resourceInfos; + std::map< ResType, std::map > resourceInfos; std::streampos datastart = out.tellp(); for(auto& rr : resources) { @@ -42,7 +42,7 @@ void Resources::writeFork(std::ostream& out) const word(out,0); std::streampos typelist = out.tellp(); word(out,resourceInfos.size() - 1); - for(std::map< std::string, std::map >::iterator p = resourceInfos.begin(); + for(std::map< ResType, std::map >::iterator p = resourceInfos.begin(); p != resourceInfos.end(); ++p) { if(p->second.size()) @@ -53,7 +53,8 @@ void Resources::writeFork(std::ostream& out) const } } int typeIndex = 0; - for(std::map< std::string, std::map >::iterator p = resourceInfos.begin(); + int nameOffset = 0; + for(std::map< ResType, std::map >::iterator p = resourceInfos.begin(); p != resourceInfos.end(); ++p) { if(p->second.size()) @@ -66,8 +67,15 @@ void Resources::writeFork(std::ostream& out) const for(std::map::iterator q = p->second.begin(); q != p->second.end(); ++q) { + std::string name = resources.find(ResRef(p->first, q->first))->second.getName(); word(out,q->first); - word(out,-1); + if(name.size() == 0) + word(out,-1); + else + { + word(out, nameOffset); + nameOffset += (name.size() > 255 ? 255 : name.size()) + 1; + } longword(out,q->second); longword(out,0); } @@ -77,6 +85,23 @@ void Resources::writeFork(std::ostream& out) const out.seekp(resnameOffset); word(out, resnames - resmap); out.seekp(resnames); + + for(std::map< ResType, std::map >::iterator p = resourceInfos.begin(); + p != resourceInfos.end(); ++p) + { + for(std::map::iterator q = p->second.begin(); q != p->second.end(); ++q) + { + std::string name = resources.find(ResRef(p->first, q->first))->second.getName(); + if(name.size() > 0) + { + int sz = name.size() > 255 ? 255 : name.size(); + byte(out, sz); + for(int i = 0; i < sz; i++) + byte(out, name[i]); + } + } + } + std::streampos end = out.tellp(); out.seekp(start + std::streampos(4)); longword(out, resmap - start); diff --git a/ResourceFiles/ResourceFork.h b/ResourceFiles/ResourceFork.h index a06e513fd3..0c8bfaf165 100644 --- a/ResourceFiles/ResourceFork.h +++ b/ResourceFiles/ResourceFork.h @@ -21,6 +21,7 @@ public: inline ResType getType() const { return type; } inline int getID() const { return id; } inline ResRef getTypeAndID() const { return ResRef(type, id); } + std::string getName() const { return name; } }; class Fork