1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-04 00:15:53 +02:00

- fixed seer hut issue (#1073)

- separate archive types in filesystem for lod\vid\snd
This commit is contained in:
Ivan Savenko 2012-09-17 17:25:54 +00:00
parent 2d6f17f3fa
commit 061ed69c63
7 changed files with 65 additions and 58 deletions

View File

@ -36,7 +36,7 @@ if(CMAKE_CXX_COMPILER MATCHES ".*clang")
endif() endif()
if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_COMPILER_IS_CLANGXX) if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_COMPILER_IS_CLANGXX)
set(CMAKE_CXX_FLAGS "-std=c++0x -Wall -Wextra -Wpointer-arith -Wno-switch -Wno-sign-compare -Wno-unused-parameter -Wno-overloaded-virtual") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x -Wall -Wextra -Wpointer-arith -Wno-switch -Wno-sign-compare -Wno-unused-parameter -Wno-overloaded-virtual")
endif() endif()
#define required constants #define required constants

View File

@ -3411,11 +3411,10 @@ SDL_Surface * CBattleInterface::imageOfObstacle(const CObstacleInstance &oi) con
return vstd::circularAt(smallForceField[forceField.casterSide]->ourImages, frameIndex).bitmap; return vstd::circularAt(smallForceField[forceField.casterSide]->ourImages, frameIndex).bitmap;
} }
case CObstacleInstance::MOAT: case CObstacleInstance::MOAT://moat is blitted by SiegeHelper, this shouldn't be called
//moat is blitted by SiegeHelper, this shouldn't be called
assert(0);
default: default:
assert(0); assert(0);
return nullptr;
} }
} }

View File

@ -338,8 +338,7 @@ void CGeneralTextHandler::load()
//skip header //skip header
parser.endLine(); parser.endLine();
parser.endLine();
while (parser.endLine());
for (int i = 0; i < 6; ++i) for (int i = 0; i < 6; ++i)
seerEmpty.push_back(parser.readString()); seerEmpty.push_back(parser.readString());

View File

@ -52,6 +52,13 @@ bool CFilesystemLoader::createEntry(std::string filename)
boost::unordered_map<ResourceID, std::string> CFilesystemLoader::listFiles(size_t depth, bool initial) const boost::unordered_map<ResourceID, std::string> CFilesystemLoader::listFiles(size_t depth, bool initial) const
{ {
std::set<EResType::Type> initialTypes;
initialTypes.insert(EResType::DIRECTORY);
initialTypes.insert(EResType::TEXT);
initialTypes.insert(EResType::ARCHIVE_LOD);
initialTypes.insert(EResType::ARCHIVE_VID);
initialTypes.insert(EResType::ARCHIVE_SND);
assert(boost::filesystem::is_directory(baseDirectory)); assert(boost::filesystem::is_directory(baseDirectory));
boost::unordered_map<ResourceID, std::string> fileList; boost::unordered_map<ResourceID, std::string> fileList;
@ -75,7 +82,7 @@ boost::unordered_map<ResourceID, std::string> CFilesystemLoader::listFiles(size_
else else
type = EResTypeHelper::getTypeFromExtension(boost::filesystem::extension(*it)); type = EResTypeHelper::getTypeFromExtension(boost::filesystem::extension(*it));
if (!initial || type == EResType::DIRECTORY || type == EResType::ARCHIVE || type == EResType::TEXT) if (!initial || vstd::contains(initialTypes, type))
{ {
//reconstruct relative filename (not possible via boost AFAIK) //reconstruct relative filename (not possible via boost AFAIK)
std::string filename; std::string filename;

View File

@ -244,10 +244,10 @@ EResType::Type EResTypeHelper::getTypeFromExtension(std::string extension)
(".MPG", EResType::VIDEO) (".MPG", EResType::VIDEO)
(".MP3", EResType::MUSIC) (".MP3", EResType::MUSIC)
(".OGG", EResType::MUSIC) (".OGG", EResType::MUSIC)
(".LOD", EResType::ARCHIVE) (".LOD", EResType::ARCHIVE_LOD)
(".PAC", EResType::ARCHIVE) (".PAC", EResType::ARCHIVE_LOD)
(".VID", EResType::ARCHIVE) (".VID", EResType::ARCHIVE_VID)
(".SND", EResType::ARCHIVE) (".SND", EResType::ARCHIVE_SND)
(".PAL", EResType::PALETTE) (".PAL", EResType::PALETTE)
(".VCGM1", EResType::CLIENT_SAVEGAME) (".VCGM1", EResType::CLIENT_SAVEGAME)
(".VLGM1", EResType::LIB_SAVEGAME) (".VLGM1", EResType::LIB_SAVEGAME)
@ -274,7 +274,9 @@ std::string EResTypeHelper::getEResTypeAsString(EResType::Type type)
MAP_ENUM(VIDEO) MAP_ENUM(VIDEO)
MAP_ENUM(SOUND) MAP_ENUM(SOUND)
MAP_ENUM(MUSIC) MAP_ENUM(MUSIC)
MAP_ENUM(ARCHIVE) MAP_ENUM(ARCHIVE_LOD)
MAP_ENUM(ARCHIVE_SND)
MAP_ENUM(ARCHIVE_VID)
MAP_ENUM(PALETTE) MAP_ENUM(PALETTE)
MAP_ENUM(CLIENT_SAVEGAME) MAP_ENUM(CLIENT_SAVEGAME)
MAP_ENUM(LIB_SAVEGAME) MAP_ENUM(LIB_SAVEGAME)
@ -333,6 +335,33 @@ void CResourceHandler::initialize()
recurseInDir("ALL/MODS", 2); // look for mods. Depth 2 is required for now but won't cause issues if no mods present recurseInDir("ALL/MODS", 2); // look for mods. Depth 2 is required for now but won't cause issues if no mods present
} }
void CResourceHandler::loadDirectory(const std::string mountPoint, const JsonNode & config)
{
std::string URI = config["path"].String();
bool writeable = config["writeable"].Bool();
int depth = 16;
if (!config["depth"].isNull())
depth = config["depth"].Float();
auto resources = initialLoader->getResourcesWithName(ResourceID(URI, EResType::DIRECTORY));
BOOST_FOREACH(const ResourceLocator & entry, resources)
{
std::string filename = entry.getLoader()->getOrigin() + '/' + entry.getResourceName();
resourceLoader->addLoader(mountPoint,
shared_ptr<ISimpleResourceLoader>(new CFilesystemLoader(filename, depth)), writeable);
}
}
void CResourceHandler::loadArchive(const std::string mountPoint, const JsonNode & config, EResType::Type archiveType)
{
std::string URI = config["path"].String();
std::string filename = initialLoader->getResourceName(ResourceID(URI, archiveType));
if (!filename.empty())
resourceLoader->addLoader(mountPoint,
shared_ptr<ISimpleResourceLoader>(new CLodArchiveLoader(filename)), false);
}
void CResourceHandler::loadFileSystem(const std::string fsConfigURI) void CResourceHandler::loadFileSystem(const std::string fsConfigURI)
{ {
auto fsConfigData = initialLoader->loadData(ResourceID(fsConfigURI, EResType::TEXT)); auto fsConfigData = initialLoader->loadData(ResourceID(fsConfigURI, EResType::TEXT));
@ -346,30 +375,20 @@ void CResourceHandler::loadFileSystem(const std::string fsConfigURI)
CStopWatch timer; CStopWatch timer;
tlog5 << "\t\tLoading resource at " << entry["path"].String(); tlog5 << "\t\tLoading resource at " << entry["path"].String();
std::string URI = entry["path"].String();
if (entry["type"].String() == "dir") if (entry["type"].String() == "dir")
{ loadDirectory(mountPoint.first, entry);
bool writeable = entry["writeable"].Bool(); if (entry["type"].String() == "lod")
int depth = 16; loadArchive(mountPoint.first, entry, EResType::ARCHIVE_LOD);
if (!entry["depth"].isNull()) if (entry["type"].String() == "snd")
depth = entry["depth"].Float(); loadArchive(mountPoint.first, entry, EResType::ARCHIVE_SND);
if (entry["type"].String() == "vid")
loadArchive(mountPoint.first, entry, EResType::ARCHIVE_VID);
auto resources = initialLoader->getResourcesWithName(ResourceID(URI, EResType::DIRECTORY)); if (entry["type"].String() == "file") // for some compatibility, will be removed for 0.90
BOOST_FOREACH(const ResourceLocator & entry, resources)
{ {
std::string filename = entry.getLoader()->getOrigin() + '/' + entry.getResourceName(); loadArchive(mountPoint.first, entry, EResType::ARCHIVE_LOD);
resourceLoader->addLoader(mountPoint.first, loadArchive(mountPoint.first, entry, EResType::ARCHIVE_SND);
shared_ptr<ISimpleResourceLoader>(new CFilesystemLoader(filename, depth)), writeable); loadArchive(mountPoint.first, entry, EResType::ARCHIVE_VID);
}
}
if (entry["type"].String() == "file")
{
std::string filename = initialLoader->getResourceName(ResourceID(URI, EResType::ARCHIVE));
if (!filename.empty())
resourceLoader->addLoader(mountPoint.first,
shared_ptr<ISimpleResourceLoader>(new CLodArchiveLoader(filename)), false);
} }
tlog5 << " took " << timer.getDiff() << " ms.\n"; tlog5 << " took " << timer.getDiff() << " ms.\n";

View File

@ -16,6 +16,7 @@
class CResourceLoader; class CResourceLoader;
class ResourceLocator; class ResourceLocator;
class ISimpleResourceLoader; class ISimpleResourceLoader;
class JsonNode;
/** /**
* Specifies the resource type. * Specifies the resource type.
@ -50,7 +51,9 @@ namespace EResType
VIDEO, VIDEO,
SOUND, SOUND,
MUSIC, MUSIC,
ARCHIVE, ARCHIVE_VID,
ARCHIVE_SND,
ARCHIVE_LOD,
PALETTE, PALETTE,
CLIENT_SAVEGAME, CLIENT_SAVEGAME,
LIB_SAVEGAME, LIB_SAVEGAME,
@ -187,28 +190,6 @@ inline size_t hash_value(const ResourceID & resourceIdent)
return stringHasher(resourceIdent.getName()) ^ intHasher(static_cast<int>(resourceIdent.getType())); return stringHasher(resourceIdent.getName()) ^ intHasher(static_cast<int>(resourceIdent.getType()));
} }
// namespace std
// {
// /**
// * Template specialization for std::hash.
// */
// template <>
// class hash<ResourceID>
// {
// public:
// /**
// * Generates a hash value for the resource identifier object.
// *
// * @param resourceIdent The object from which a hash value should be generated.
// * @return the generated hash value
// */
// size_t operator()(const ResourceID & resourceIdent) const
// {
// return hash<string>()(resourceIdent.getName()) ^ hash<int>()(static_cast<int>(resourceIdent.getType()));
// }
// };
// };
/** /**
* This class manages the loading of resources whether standard * This class manages the loading of resources whether standard
* or derived from several container formats and the file system. * or derived from several container formats and the file system.
@ -396,6 +377,8 @@ public:
* Will load all filesystem data from Json data at this path (config/filesystem.json) * Will load all filesystem data from Json data at this path (config/filesystem.json)
*/ */
static void loadFileSystem(const std::string fsConfigURI); static void loadFileSystem(const std::string fsConfigURI);
static void loadDirectory(const std::string mountPoint, const JsonNode & config);
static void loadArchive(const std::string mountPoint, const JsonNode & config, EResType::Type archiveType);
/** /**
* Experimental. Checks all subfolders of MODS directory for presence of ERA-style mods * Experimental. Checks all subfolders of MODS directory for presence of ERA-style mods

View File

@ -48,7 +48,7 @@ VCMI supports resolutions higher than original 800x600. Namely these are:
\item 1920x1080 \item 1920x1080
\end{itemize} \end{itemize}
Switching resolution may not only change visible area of map, but also alters some interface features such as \hyperref[Stack_Queue]{Stack Queue.}\\ Switching resolution may not only change visible area of map, but also alters some interface features such as \hyperref[Stack_Queue]{Stack Queue.}\\
To change resolution or full screen mode use interactive "settings" menu when in game. Changes in resolution will take place when you restart VCMI. \\ To change resolution or full screen mode use System Options menu when in game. Changes in resolution will take place when you restart VCMI. \\
Fullscreen mode can be toggled anytime using F4 hotkey. Fullscreen mode can be toggled anytime using F4 hotkey.
\end{itemize} \end{itemize}
\label{Mods} \label{Mods}