diff --git a/VC2008/MCServer.vcproj b/VC2008/MCServer.vcproj
index 504ffc9ae..9bc013b95 100644
--- a/VC2008/MCServer.vcproj
+++ b/VC2008/MCServer.vcproj
@@ -553,6 +553,14 @@
RelativePath="..\source\LeakFinder.h"
>
+
+
+
+
diff --git a/VC2010/MCServer.vcxproj b/VC2010/MCServer.vcxproj
index 620e3fb54..f4fb93398 100644
--- a/VC2010/MCServer.vcxproj
+++ b/VC2010/MCServer.vcxproj
@@ -399,6 +399,7 @@
NotUsing
true
+
@@ -572,6 +573,7 @@
+
diff --git a/VC2010/MCServer.vcxproj.filters b/VC2010/MCServer.vcxproj.filters
index 5aa4a95a0..e8d4574b5 100644
--- a/VC2010/MCServer.vcxproj.filters
+++ b/VC2010/MCServer.vcxproj.filters
@@ -911,6 +911,7 @@
+
@@ -1406,6 +1407,7 @@
+
diff --git a/source/LightingThread.cpp b/source/LightingThread.cpp
new file mode 100644
index 000000000..e70dc252e
--- /dev/null
+++ b/source/LightingThread.cpp
@@ -0,0 +1,114 @@
+
+// LightingThread.cpp
+
+// Implements the cLightingThread class representing the thread that processes requests for lighting
+
+#include "Globals.h"
+#include "LightingThread.h"
+
+
+
+
+
+///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
+// cLightingThread:
+
+cLightingThread::cLightingThread(void) :
+ super("cLightingThread")
+{
+}
+
+
+
+
+
+cLightingThread::~cLightingThread()
+{
+ Stop();
+}
+
+
+
+
+
+void cLightingThread::Stop(void)
+{
+ {
+ cCSLock Lock(m_CS);
+ for (cLightingBufferQueue::iterator itr = m_Queue.begin(); itr != m_Queue.end(); ++itr)
+ {
+ delete *itr;
+ } // for itr - m_Queue[]
+ }
+ mShouldTerminate = true;
+ m_Event.Set();
+
+ Wait();
+}
+
+
+
+
+
+void cLightingThread::QueueLighting(cWorld * a_World, int a_MinX, int a_MaxX, int a_MinY, int a_MaxY, int a_MinZ, int a_MaxZ)
+{
+ // TODO
+}
+
+
+
+
+
+void cLightingThread::Execute(void)
+{
+ // TODO
+}
+
+
+
+
+
+///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
+// cLightingThread::cLightingBuffer:
+
+cLightingThread::cLightingBuffer::cLightingBuffer(int a_MinX, int a_MaxX, int a_MinY, int a_MaxY, int a_MinZ, int a_MaxZ) :
+ m_MinX(a_MinX),
+ m_MaxX(a_MaxX),
+ m_MinY(a_MinY),
+ m_MaxY(a_MaxY),
+ m_MinZ(a_MinZ),
+ m_MaxZ(a_MaxZ)
+{
+ // TODO: initialize strides
+}
+
+
+
+
+
+void cLightingThread::cLightingBuffer::GetFromWorld(cWorld * a_World)
+{
+ // TODO: Set m_BlockData, m_SkyLight and m_BlockLight from the world's chunks
+}
+
+
+
+
+
+void cLightingThread::cLightingBuffer::SetToWorld (cWorld * a_World)
+{
+ // TODO: Set world's chunks from m_BlockData, m_SkyLight and m_BlockLight
+}
+
+
+
+
+
+void cLightingThread::cLightingBuffer::Process(void)
+{
+ // TODO: Does the actual lighting on this buffer
+}
+
+
+
+
diff --git a/source/LightingThread.h b/source/LightingThread.h
new file mode 100644
index 000000000..5b60d34bf
--- /dev/null
+++ b/source/LightingThread.h
@@ -0,0 +1,82 @@
+
+// LightingThread.h
+
+// Interfaces to the cLightingThread class representing the thread that processes requests for lighting
+// Note that the world generators need direct access to the lighting methods so that they can light the generated chunk
+
+
+
+
+#pragma once
+
+#include "cIsThread.h"
+
+
+
+
+
+// fwd:
+class cWorld;
+
+
+
+
+
+class cLightingThread :
+ public cIsThread
+{
+ typedef cIsThread super;
+
+public:
+
+ class cLightingBuffer
+ {
+ public:
+ cLightingBuffer(int m_MinX, int m_MaxX, int m_MinY, int m_MaxY, int m_MinZ, int m_MaxZ);
+
+ /// Copies the world's existing chunks into m_BlockData, m_Skylight and m_BlockLight
+ void GetFromWorld(cWorld * a_World);
+ void SetToWorld (cWorld * a_World);
+
+ void Process(void); // Does the actual lighting on this buffer
+
+ protected:
+
+ // Block coords:
+ int m_MinX, m_MaxX;
+ int m_MinY, m_MaxY;
+ int m_MinZ, m_MaxZ;
+
+ int m_StrideX; // = OffsetOfBlock(x, y, z) - OffsetOfBlock(x + 1, y, z)
+ int m_StrideZ; // = OffsetOfBlock(x, y, z) - OffsetOfBlock(x, y, z + 1)
+
+ // These buffers actually store 1 block in each direction more than is specified in the coords
+ // This way we can throw out a lot of conditions inside the processing cycles
+ // And it allows us to light a chunk with regard to its surrounding chunks without much work
+ // (So if m_MinX is 16 and m_MaxX is 32, the buffers actually contain data for X in range from 15 to 33 (18 items)
+ char * m_BlockData;
+ char * m_SkyLight;
+ char * m_BlockLight;
+ } ;
+
+ cLightingThread(void);
+ ~cLightingThread();
+
+ void Stop(void);
+
+ void QueueLighting(cWorld * a_World, int a_MinX, int a_MaxX, int a_MinY, int a_MaxY, int a_MinZ, int a_MaxZ); // queues the request
+
+protected:
+
+ typedef std::list cLightingBufferQueue;
+
+ cCriticalSection m_CS;
+ cLightingBufferQueue m_Queue;
+ cEvent m_Event; // Set when queue is appended or to stop the thread
+
+ virtual void Execute(void) override;
+} ;
+
+
+
+