|  | @@ -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)
 |