2012-09-27 13:02:25 -07:00
|
|
|
|
|
|
|
// Processor.h
|
|
|
|
|
|
|
|
// Interfaces to the cProcessor class representing the overall processor engine that manages threads, calls callbacks etc.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// fwd:
|
|
|
|
class cCallback;
|
|
|
|
class cCallbackFactory;
|
|
|
|
class cParsedNBT;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class cProcessor
|
|
|
|
{
|
|
|
|
class cThread :
|
|
|
|
public cIsThread
|
|
|
|
{
|
|
|
|
typedef cIsThread super;
|
|
|
|
|
|
|
|
cCallback & m_Callback;
|
|
|
|
cProcessor & m_ParentProcessor;
|
|
|
|
|
|
|
|
// cIsThread override:
|
|
|
|
virtual void Execute(void) override;
|
|
|
|
|
|
|
|
void ProcessFile(const AString & a_FileName);
|
2012-09-28 05:44:06 -07:00
|
|
|
void ProcessFileData(const char * a_FileData, size_t a_Size, int a_ChunkBaseX, int a_ChunkBaseZ);
|
|
|
|
void ProcessChunk(const char * a_FileData, int a_ChunkX, int a_ChunkZ, unsigned a_SectorStart, unsigned a_SectorSize, unsigned a_TimeStamp);
|
2012-09-27 13:02:25 -07:00
|
|
|
void ProcessCompressedChunkData(int a_ChunkX, int a_ChunkZ, const char * a_CompressedData, int a_CompressedSize);
|
|
|
|
void ProcessParsedChunkData(int a_ChunkX, int a_ChunkZ, cParsedNBT & a_NBT);
|
2012-09-29 06:33:45 -07:00
|
|
|
|
|
|
|
// The following processing parts return true if they were interrupted by the callback, causing the processing of current chunk to abort
|
2012-09-27 13:02:25 -07:00
|
|
|
bool ProcessChunkSections(int a_ChunkX, int a_ChunkZ, cParsedNBT & a_NBT, int a_LevelTag);
|
2012-09-29 06:33:45 -07:00
|
|
|
bool ProcessChunkEntities(int a_ChunkX, int a_ChunkZ, cParsedNBT & a_NBT, int a_LevelTag);
|
|
|
|
bool ProcessChunkTileEntities(int a_ChunkX, int a_ChunkZ, cParsedNBT & a_NBT, int a_LevelTag);
|
|
|
|
bool ProcessChunkTileTicks(int a_ChunkX, int a_ChunkZ, cParsedNBT & a_NBT, int a_LevelTag);
|
2012-09-27 13:02:25 -07:00
|
|
|
|
|
|
|
public:
|
|
|
|
cThread(cCallback & a_Callback, cProcessor & a_ParentProcessor);
|
|
|
|
} ;
|
|
|
|
|
|
|
|
typedef std::vector<cThread *> cThreads;
|
|
|
|
|
|
|
|
public:
|
|
|
|
cProcessor(void);
|
|
|
|
~cProcessor();
|
|
|
|
|
|
|
|
void ProcessWorld(const AString & a_WorldFolder, cCallbackFactory & a_CallbackFactory);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
bool m_IsShuttingDown; // If true, the threads should stop ASAP
|
|
|
|
|
|
|
|
cCriticalSection m_CS;
|
|
|
|
AStringList m_FileQueue;
|
|
|
|
|
|
|
|
cThreads m_Threads;
|
2012-09-28 13:17:29 -07:00
|
|
|
cEvent m_ThreadsHaveStarted; // This is signalled by each thread to notify the parent thread that it can start waiting for those threads
|
2012-09-27 13:02:25 -07:00
|
|
|
|
|
|
|
void PopulateFileQueue(const AString & a_WorldFolder);
|
|
|
|
|
|
|
|
AString GetOneFileName(void);
|
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|