From 5fc45bd3401b5348bbd23257662de3d5320a3c48 Mon Sep 17 00:00:00 2001 From: Eugene Sandulenko Date: Fri, 12 Aug 2016 08:42:41 +0200 Subject: DIRECTOR: Lingo: Sort test files before execution --- engines/director/lingo/lingo.cpp | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) (limited to 'engines/director/lingo/lingo.cpp') diff --git a/engines/director/lingo/lingo.cpp b/engines/director/lingo/lingo.cpp index 7076ac2bc3..f3faf975fe 100644 --- a/engines/director/lingo/lingo.cpp +++ b/engines/director/lingo/lingo.cpp @@ -20,6 +20,8 @@ * */ +#include "common/str-array.h" + #include "director/lingo/lingo.h" #include "director/lingo/lingo-gr.h" @@ -360,14 +362,19 @@ Common::String *Lingo::toLowercaseMac(Common::String *s) { void Lingo::runTests() { Common::File inFile; - Common::ArchiveMemberList fileList; - SearchMan.listMatchingMembers(fileList, "*.lingo"); + Common::ArchiveMemberList fsList; + SearchMan.listMatchingMembers(fsList, "*.lingo"); + Common::StringArray fileList; int counter = 1; - for (Common::ArchiveMemberList::iterator it = fileList.begin(); it != fileList.end(); ++it) { - Common::ArchiveMember const &m = **it; - Common::SeekableReadStream *const stream = m.createReadStream(); + for (Common::ArchiveMemberList::iterator it = fsList.begin(); it != fsList.end(); ++it) + fileList.push_back((*it)->getName()); + + Common::sort(fileList.begin(), fileList.end()); + + for (int i = 0; i < fileList.size(); i++) { + Common::SeekableReadStream *const stream = SearchMan.createReadStreamForMember(fileList[i]); if (stream) { uint size = stream->size(); @@ -375,7 +382,7 @@ void Lingo::runTests() { stream->read(script, size); - warning("Compiling file %s of size %d, id: %d", m.getName().c_str(), size, counter); + warning("Compiling file %s of size %d, id: %d", fileList[i].c_str(), size, counter); _hadError = false; addCode(script, kMovieScript, counter); -- cgit v1.2.3