mirror of
https://github.com/vcmi/vcmi.git
synced 2025-06-15 00:05:02 +02:00
switch CMapService API to ResourceID
This commit is contained in:
@ -13,24 +13,16 @@
|
||||
#include "MapFormatJson.h"
|
||||
|
||||
|
||||
std::unique_ptr<CMap> CMapService::loadMap(const std::string & name)
|
||||
std::unique_ptr<CMap> CMapService::loadMap(const ResourceID & name)
|
||||
{
|
||||
auto stream = getStreamFromFS(name);
|
||||
std::unique_ptr<CMap> map(getMapLoader(stream)->loadMap());
|
||||
std::unique_ptr<CMapHeader> header(map.get());
|
||||
|
||||
getMapPatcher(name)->patchMapHeader(header);
|
||||
header.release();
|
||||
|
||||
return map;
|
||||
return getMapLoader(stream)->loadMap();
|
||||
}
|
||||
|
||||
std::unique_ptr<CMapHeader> CMapService::loadMapHeader(const std::string & name)
|
||||
std::unique_ptr<CMapHeader> CMapService::loadMapHeader(const ResourceID & name)
|
||||
{
|
||||
auto stream = getStreamFromFS(name);
|
||||
std::unique_ptr<CMapHeader> header = getMapLoader(stream)->loadMapHeader();
|
||||
getMapPatcher(name)->patchMapHeader(header);
|
||||
return header;
|
||||
return getMapLoader(stream)->loadMapHeader();
|
||||
}
|
||||
|
||||
std::unique_ptr<CMap> CMapService::loadMap(const ui8 * buffer, int size, const std::string & name)
|
||||
@ -39,6 +31,7 @@ std::unique_ptr<CMap> CMapService::loadMap(const ui8 * buffer, int size, const s
|
||||
std::unique_ptr<CMap> map(getMapLoader(stream)->loadMap());
|
||||
std::unique_ptr<CMapHeader> header(map.get());
|
||||
|
||||
//might be original campaign and require patch
|
||||
getMapPatcher(name)->patchMapHeader(header);
|
||||
header.release();
|
||||
|
||||
@ -49,6 +42,8 @@ std::unique_ptr<CMapHeader> CMapService::loadMapHeader(const ui8 * buffer, int s
|
||||
{
|
||||
auto stream = getStreamFromMem(buffer, size);
|
||||
std::unique_ptr<CMapHeader> header = getMapLoader(stream)->loadMapHeader();
|
||||
|
||||
//might be original campaign and require patch
|
||||
getMapPatcher(name)->patchMapHeader(header);
|
||||
return header;
|
||||
}
|
||||
@ -70,9 +65,9 @@ void CMapService::saveMap(const std::unique_ptr<CMap> & map, boost::filesystem::
|
||||
}
|
||||
}
|
||||
|
||||
std::unique_ptr<CInputStream> CMapService::getStreamFromFS(const std::string & name)
|
||||
std::unique_ptr<CInputStream> CMapService::getStreamFromFS(const ResourceID & name)
|
||||
{
|
||||
return CResourceHandler::get()->load(ResourceID(name, EResType::MAP));
|
||||
return CResourceHandler::get()->load(name);
|
||||
}
|
||||
|
||||
std::unique_ptr<CInputStream> CMapService::getStreamFromMem(const ui8 * buffer, int size)
|
||||
|
Reference in New Issue
Block a user