--- /dev/null
+cmake_minimum_required(VERSION 2.6)
+if(${CMAKE_VERSION} STREQUAL "2.8.2")
+ # bug http://vtk.org/Bug/view.php?id=11020
+ message( WARNING "CMake/CPack version 2.8.2 will not create working .deb packages!")
+endif(${CMAKE_VERSION} STREQUAL "2.8.2")
+
+set(CMAKE_BUILD_TYPE Debug)
+set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_SOURCE_DIR}/cmake/Modules/")
+
+# This is done here so that IRRDIR is relative to the typical cmake call directory
+find_package(Irrlicht)
+
+# This way the CMakeLists.txt file in src/ is processed
+add_subdirectory(src)
+
+++ /dev/null
-# Makefile for Irrlicht Examples\r
-# It's usually sufficient to change just the target name and source file list\r
-# and be sure that CXX is set to a valid compiler\r
-SOURCE_FILES = porting.cpp guiMessageMenu.cpp materials.cpp guiTextInputMenu.cpp guiInventoryMenu.cpp irrlichtwrapper.cpp guiPauseMenu.cpp defaultsettings.cpp mapnode.cpp tile.cpp voxel.cpp mapblockobject.cpp inventory.cpp debug.cpp serialization.cpp light.cpp filesys.cpp connection.cpp environment.cpp client.cpp server.cpp socket.cpp mapblock.cpp mapsector.cpp heightmap.cpp map.cpp player.cpp utility.cpp main.cpp test.cpp\r
-\r
-DEBUG_TARGET = debugtest\r
-DEBUG_SOURCES = $(addprefix src/, $(SOURCE_FILES))\r
-DEBUG_BUILD_DIR = debugbuild\r
-DEBUG_OBJECTS = $(addprefix $(DEBUG_BUILD_DIR)/, $(SOURCE_FILES:.cpp=.o))\r
-\r
-FAST_TARGET = fasttest\r
-FAST_SOURCES = $(addprefix src/, $(SOURCE_FILES))\r
-FAST_BUILD_DIR = fastbuild\r
-FAST_OBJECTS = $(addprefix $(FAST_BUILD_DIR)/, $(SOURCE_FILES:.cpp=.o))\r
-\r
-SERVER_TARGET = server\r
-SERVER_SOURCE_FILES = porting.cpp materials.cpp defaultsettings.cpp mapnode.cpp voxel.cpp mapblockobject.cpp inventory.cpp debug.cpp serialization.cpp light.cpp filesys.cpp connection.cpp environment.cpp server.cpp socket.cpp mapblock.cpp mapsector.cpp heightmap.cpp map.cpp player.cpp utility.cpp servermain.cpp test.cpp\r
-SERVER_SOURCES = $(addprefix src/, $(SERVER_SOURCE_FILES))\r
-SERVER_BUILD_DIR = serverbuild\r
-SERVER_OBJECTS = $(addprefix $(SERVER_BUILD_DIR)/, $(SERVER_SOURCE_FILES:.cpp=.o))\r
-\r
-IRRLICHTPATH = ../irrlicht/irrlicht-1.7.1\r
-JTHREADPATH = ../jthread/jthread-1.2.1\r
-\r
-\r
-all: fast\r
-\r
-ifeq ($(HOSTTYPE), x86_64)\r
-LIBSELECT=64\r
-endif\r
-\r
-debug: CXXFLAGS = -Wall -g -O1\r
-debug: CPPFLAGS = -I$(IRRLICHTPATH)/include -I/usr/X11R6/include -I$(JTHREADPATH)/src -DDEBUG -DRUN_IN_PLACE\r
-debug: LDFLAGS = -L/usr/X11R6/lib$(LIBSELECT) -L$(IRRLICHTPATH)/lib/Linux -L$(JTHREADPATH)/src/.libs -lIrrlicht -lGL -lXxf86vm -lXext -lX11 -ljthread -lz\r
-\r
-fast: CXXFLAGS = -O3 -ffast-math -Wall -fomit-frame-pointer -pipe -funroll-loops -mtune=i686\r
-fast: CPPFLAGS = -I$(IRRLICHTPATH)/include -I/usr/X11R6/include -I$(JTHREADPATH)/src -DUNITTEST_DISABLE -DRUN_IN_PLACE\r
-fast: LDFLAGS = -L/usr/X11R6/lib$(LIBSELECT) -L$(IRRLICHTPATH)/lib/Linux -L$(JTHREADPATH)/src/.libs -lIrrlicht -lGL -lXxf86vm -lXext -lX11 -ljthread -lz\r
-\r
-server: CXXFLAGS = -O3 -ffast-math -Wall -fomit-frame-pointer -pipe -funroll-loops -mtune=i686\r
-server: CPPFLAGS = -I$(IRRLICHTPATH)/include -I/usr/X11R6/include -I$(JTHREADPATH)/src -DSERVER -DUNITTEST_DISABLE -DRUN_IN_PLACE\r
-server: LDFLAGS = -L$(JTHREADPATH)/src/.libs -ljthread -lz -lpthread\r
-\r
-DEBUG_DESTPATH = bin/$(DEBUG_TARGET)\r
-FAST_DESTPATH = bin/$(FAST_TARGET)\r
-SERVER_DESTPATH = bin/$(SERVER_TARGET)\r
-\r
-# Build commands\r
-\r
-debug: $(DEBUG_BUILD_DIR) $(DEBUG_DESTPATH)\r
-fast: $(FAST_BUILD_DIR) $(FAST_DESTPATH)\r
-server: $(SERVER_BUILD_DIR) $(SERVER_DESTPATH)\r
-\r
-$(DEBUG_BUILD_DIR):\r
- mkdir -p $(DEBUG_BUILD_DIR)\r
-$(FAST_BUILD_DIR):\r
- mkdir -p $(FAST_BUILD_DIR)\r
-$(SERVER_BUILD_DIR):\r
- mkdir -p $(SERVER_BUILD_DIR)\r
-\r
-$(DEBUG_DESTPATH): $(DEBUG_OBJECTS)\r
- $(CXX) -o $@ $(DEBUG_OBJECTS) $(LDFLAGS)\r
-\r
-$(FAST_DESTPATH): $(FAST_OBJECTS)\r
- $(CXX) -o $@ $(FAST_OBJECTS) $(LDFLAGS)\r
-\r
-$(SERVER_DESTPATH): $(SERVER_OBJECTS)\r
- $(CXX) -o $@ $(SERVER_OBJECTS) $(LDFLAGS)\r
-\r
-$(DEBUG_BUILD_DIR)/%.o: src/%.cpp\r
- $(CXX) -c -o $@ $< $(CPPFLAGS) $(CXXFLAGS)\r
-\r
-$(FAST_BUILD_DIR)/%.o: src/%.cpp\r
- $(CXX) -c -o $@ $< $(CPPFLAGS) $(CXXFLAGS)\r
-\r
-$(SERVER_BUILD_DIR)/%.o: src/%.cpp\r
- $(CXX) -c -o $@ $< $(CPPFLAGS) $(CXXFLAGS)\r
-\r
-clean: clean_debug clean_fast clean_server\r
-\r
-clean_debug:\r
- @$(RM) $(DEBUG_OBJECTS) $(DEBUG_DESTPATH)\r
-\r
-clean_fast:\r
- @$(RM) $(FAST_OBJECTS) $(FAST_DESTPATH)\r
-\r
-clean_server:\r
- @$(RM) $(SERVER_OBJECTS) $(SERVER_DESTPATH)\r
-\r
-.PHONY: all all_win32 clean clean_debug clean_win32 clean_fast clean_server\r
--- /dev/null
+# Makefile for Irrlicht Examples\r
+# It's usually sufficient to change just the target name and source file list\r
+# and be sure that CXX is set to a valid compiler\r
+SOURCE_FILES = porting.cpp guiMessageMenu.cpp materials.cpp guiTextInputMenu.cpp guiInventoryMenu.cpp irrlichtwrapper.cpp guiPauseMenu.cpp defaultsettings.cpp mapnode.cpp tile.cpp voxel.cpp mapblockobject.cpp inventory.cpp debug.cpp serialization.cpp light.cpp filesys.cpp connection.cpp environment.cpp client.cpp server.cpp socket.cpp mapblock.cpp mapsector.cpp heightmap.cpp map.cpp player.cpp utility.cpp main.cpp test.cpp\r
+\r
+DEBUG_TARGET = debugtest\r
+DEBUG_SOURCES = $(addprefix src/, $(SOURCE_FILES))\r
+DEBUG_BUILD_DIR = debugbuild\r
+DEBUG_OBJECTS = $(addprefix $(DEBUG_BUILD_DIR)/, $(SOURCE_FILES:.cpp=.o))\r
+\r
+FAST_TARGET = fasttest\r
+FAST_SOURCES = $(addprefix src/, $(SOURCE_FILES))\r
+FAST_BUILD_DIR = fastbuild\r
+FAST_OBJECTS = $(addprefix $(FAST_BUILD_DIR)/, $(SOURCE_FILES:.cpp=.o))\r
+\r
+SERVER_TARGET = server\r
+SERVER_SOURCE_FILES = porting.cpp materials.cpp defaultsettings.cpp mapnode.cpp voxel.cpp mapblockobject.cpp inventory.cpp debug.cpp serialization.cpp light.cpp filesys.cpp connection.cpp environment.cpp server.cpp socket.cpp mapblock.cpp mapsector.cpp heightmap.cpp map.cpp player.cpp utility.cpp servermain.cpp test.cpp\r
+SERVER_SOURCES = $(addprefix src/, $(SERVER_SOURCE_FILES))\r
+SERVER_BUILD_DIR = serverbuild\r
+SERVER_OBJECTS = $(addprefix $(SERVER_BUILD_DIR)/, $(SERVER_SOURCE_FILES:.cpp=.o))\r
+\r
+IRRLICHTPATH = ../irrlicht/irrlicht-1.7.1\r
+JTHREADPATH = ../jthread/jthread-1.2.1\r
+\r
+\r
+all: fast\r
+\r
+ifeq ($(HOSTTYPE), x86_64)\r
+LIBSELECT=64\r
+endif\r
+\r
+debug: CXXFLAGS = -Wall -g -O1\r
+debug: CPPFLAGS = -I$(IRRLICHTPATH)/include -I/usr/X11R6/include -I$(JTHREADPATH)/src -DDEBUG -DRUN_IN_PLACE\r
+debug: LDFLAGS = -L/usr/X11R6/lib$(LIBSELECT) -L$(IRRLICHTPATH)/lib/Linux -L$(JTHREADPATH)/src/.libs -lIrrlicht -lGL -lXxf86vm -lXext -lX11 -ljthread -lz\r
+\r
+fast: CXXFLAGS = -O3 -ffast-math -Wall -fomit-frame-pointer -pipe -funroll-loops -mtune=i686\r
+fast: CPPFLAGS = -I$(IRRLICHTPATH)/include -I/usr/X11R6/include -I$(JTHREADPATH)/src -DUNITTEST_DISABLE -DRUN_IN_PLACE\r
+fast: LDFLAGS = -L/usr/X11R6/lib$(LIBSELECT) -L$(IRRLICHTPATH)/lib/Linux -L$(JTHREADPATH)/src/.libs -lIrrlicht -lGL -lXxf86vm -lXext -lX11 -ljthread -lz\r
+\r
+server: CXXFLAGS = -O3 -ffast-math -Wall -fomit-frame-pointer -pipe -funroll-loops -mtune=i686\r
+server: CPPFLAGS = -I$(IRRLICHTPATH)/include -I/usr/X11R6/include -I$(JTHREADPATH)/src -DSERVER -DUNITTEST_DISABLE -DRUN_IN_PLACE\r
+server: LDFLAGS = -L$(JTHREADPATH)/src/.libs -ljthread -lz -lpthread\r
+\r
+DEBUG_DESTPATH = bin/$(DEBUG_TARGET)\r
+FAST_DESTPATH = bin/$(FAST_TARGET)\r
+SERVER_DESTPATH = bin/$(SERVER_TARGET)\r
+\r
+# Build commands\r
+\r
+debug: $(DEBUG_BUILD_DIR) $(DEBUG_DESTPATH)\r
+fast: $(FAST_BUILD_DIR) $(FAST_DESTPATH)\r
+server: $(SERVER_BUILD_DIR) $(SERVER_DESTPATH)\r
+\r
+$(DEBUG_BUILD_DIR):\r
+ mkdir -p $(DEBUG_BUILD_DIR)\r
+$(FAST_BUILD_DIR):\r
+ mkdir -p $(FAST_BUILD_DIR)\r
+$(SERVER_BUILD_DIR):\r
+ mkdir -p $(SERVER_BUILD_DIR)\r
+\r
+$(DEBUG_DESTPATH): $(DEBUG_OBJECTS)\r
+ $(CXX) -o $@ $(DEBUG_OBJECTS) $(LDFLAGS)\r
+\r
+$(FAST_DESTPATH): $(FAST_OBJECTS)\r
+ $(CXX) -o $@ $(FAST_OBJECTS) $(LDFLAGS)\r
+\r
+$(SERVER_DESTPATH): $(SERVER_OBJECTS)\r
+ $(CXX) -o $@ $(SERVER_OBJECTS) $(LDFLAGS)\r
+\r
+$(DEBUG_BUILD_DIR)/%.o: src/%.cpp\r
+ $(CXX) -c -o $@ $< $(CPPFLAGS) $(CXXFLAGS)\r
+\r
+$(FAST_BUILD_DIR)/%.o: src/%.cpp\r
+ $(CXX) -c -o $@ $< $(CPPFLAGS) $(CXXFLAGS)\r
+\r
+$(SERVER_BUILD_DIR)/%.o: src/%.cpp\r
+ $(CXX) -c -o $@ $< $(CPPFLAGS) $(CXXFLAGS)\r
+\r
+clean: clean_debug clean_fast clean_server\r
+\r
+clean_debug:\r
+ @$(RM) $(DEBUG_OBJECTS) $(DEBUG_DESTPATH)\r
+\r
+clean_fast:\r
+ @$(RM) $(FAST_OBJECTS) $(FAST_DESTPATH)\r
+\r
+clean_server:\r
+ @$(RM) $(SERVER_OBJECTS) $(SERVER_DESTPATH)\r
+\r
+.PHONY: all all_win32 clean clean_debug clean_win32 clean_fast clean_server\r
--- /dev/null
+MESSAGE(STATUS "IRRDIR = $ENV{IRRDIR}")
+
+FIND_PATH(IRRLICHT_INCLUDE_DIR NAMES irrlicht.h
+ PATHS
+ $ENV{IRRDIR}/include
+ /usr/local/include/irrlicht
+ /usr/include/irrlicht
+)
+
+MESSAGE(STATUS "IRRLICHT_INCLUDE_DIR = ${IRRLICHT_INCLUDE_DIR}")
+
+FIND_LIBRARY(IRRLICHT_LIBRARY NAMES libIrrlicht.a Irrlicht
+ PATHS
+ $ENV{IRRDIR}/lib
+ $ENV{IRRDIR}/lib/Linux
+ $ENV{IRRDIR}/lib/MacOSX
+ $ENV{IRRDIR}/lib/Win32-gcc
+ $ENV{IRRDIR}/lib/Win32-visualstudio
+ $ENV{IRRDIR}/lib/Win64-visualstudio
+ /usr/local/lib
+ /usr/lib
+)
+
+MESSAGE(STATUS "IRRLICHT_LIBRARY = ${IRRLICHT_LIBRARY}")
+
+# handle the QUIETLY and REQUIRED arguments and set IRRLICHT_FOUND to TRUE if
+# all listed variables are TRUE
+INCLUDE(FindPackageHandleStandardArgs)
+FIND_PACKAGE_HANDLE_STANDARD_ARGS(IRRLICHT DEFAULT_MSG IRRLICHT_LIBRARY IRRLICHT_INCLUDE_DIR)
+
+IF(IRRLICHT_FOUND)
+ SET(IRRLICHT_LIBRARIES ${IRRLICHT_LIBRARY})
+ELSE(IRRLICHT_FOUND)
+ SET(IRRLICHT_LIBRARIES)
+ENDIF(IRRLICHT_FOUND)
+
+MARK_AS_ADVANCED(IRRLICHT_LIBRARY IRRLICHT_INCLUDE_DIR)
+
--- /dev/null
+project(minetest)
+cmake_minimum_required( VERSION 2.6 )
+set ( CMAKE_BUILD_TYPE Debug )
+add_definitions ( -Wall -DRUN_IN_PLACE -O2)
+find_package(ZLIB REQUIRED)
+find_package(X11 REQUIRED)
+find_package(OpenGL REQUIRED)
+find_package(JPEG REQUIRED)
+find_package(BZip2 REQUIRED)
+
+if( UNIX )
+ #set( platform_SRCS some_necessary_linux_file.cpp )
+else( UNIX )
+ #windows
+ #set( platform_SRCS dllmain.cpp stdafx.cpp )
+endif( UNIX )
+
+set(minetest_SRCS
+ porting.cpp
+ guiMessageMenu.cpp
+ materials.cpp
+ guiTextInputMenu.cpp
+ guiInventoryMenu.cpp
+ irrlichtwrapper.cpp
+ guiPauseMenu.cpp
+ defaultsettings.cpp
+ mapnode.cpp
+ tile.cpp
+ voxel.cpp
+ mapblockobject.cpp
+ inventory.cpp
+ debug.cpp
+ serialization.cpp
+ light.cpp
+ filesys.cpp
+ connection.cpp
+ environment.cpp
+ client.cpp
+ server.cpp
+ socket.cpp
+ mapblock.cpp
+ mapsector.cpp
+ heightmap.cpp
+ map.cpp
+ player.cpp
+ utility.cpp
+ main.cpp
+ test.cpp
+)
+
+include_directories(
+ ${ZLIB_INCLUDE_DIR}
+ ${IRRLICHT_INCLUDE_DIR}
+ "${PROJECT_SOURCE_DIR}/jthread"
+)
+
+set(EXECUTABLE_OUTPUT_PATH ../bin)
+
+add_executable(minetest ${minetest_SRCS})
+
+target_link_libraries(
+ minetest
+ ${ZLIB_LIBRARIES}
+ ${IRRLICHT_LIBRARY}
+ ${OPENGL_LIBRARIES}
+ ${JPEG_LIBRARIES}
+ ${BZIP2_LIBRARIES}
+ jthread
+)
+
+add_subdirectory(jthread)
+
+#END
--- /dev/null
+if( UNIX )
+ set(jthread_SRCS pthread/jmutex.cpp pthread/jthread.cpp)
+ set(jthread_platform_LIBS "")
+else( UNIX )
+ set(jthread_SRCS win32/jmutex.cpp win32/jthread.cpp)
+ set(jthread_platform_LIBS "")
+endif( UNIX )
+
+add_library(jthread ${jthread_SRCS})
+
+target_link_libraries(
+ jthread
+ ${jthread_platform_LIBS}
+)
+
+
--- /dev/null
+The license of JThread:
+
+Permission is hereby granted, free of charge, to any person obtaining a
+copy of this software and associated documentation files (the "Software"),
+to deal in the Software without restriction, including without limitation
+the rights to use, copy, modify, merge, publish, distribute, sublicense,
+and/or sell copies of the Software, and to permit persons to whom the
+Software is furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included
+in all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+IN THE SOFTWARE.
+
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#ifndef JMUTEX_H
+
+#define JMUTEX_H
+
+#if (defined(WIN32) || defined(_WIN32_WCE))
+ #ifndef _WIN32_WCE
+ #include <process.h>
+ #endif // _WIN32_WCE
+ #include <winsock2.h>
+ #include <windows.h>
+
+ #define JMUTEX_CRITICALSECTION
+#else // using pthread
+ #include <pthread.h>
+#endif // WIN32
+
+#define ERR_JMUTEX_ALREADYINIT -1
+#define ERR_JMUTEX_NOTINIT -2
+#define ERR_JMUTEX_CANTCREATEMUTEX -3
+
+class JMutex
+{
+public:
+ JMutex();
+ ~JMutex();
+ int Init();
+ int Lock();
+ int Unlock();
+ bool IsInitialized() { return initialized; }
+private:
+#if (defined(WIN32) || defined(_WIN32_WCE))
+#ifdef JMUTEX_CRITICALSECTION
+ CRITICAL_SECTION mutex;
+#else // Use standard mutex
+ HANDLE mutex;
+#endif // JMUTEX_CRITICALSECTION
+#else // pthread mutex
+ pthread_mutex_t mutex;
+#endif // WIN32
+ bool initialized;
+};
+
+#endif // JMUTEX_H
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#ifndef JMUTEXAUTOLOCK_H
+
+#define JMUTEXAUTOLOCK_H
+
+#include "jmutex.h"
+
+class JMutexAutoLock
+{
+public:
+ JMutexAutoLock(JMutex &m) : mutex(m) { mutex.Lock(); }
+ ~JMutexAutoLock() { mutex.Unlock(); }
+private:
+ JMutex &mutex;
+};
+
+#endif // JMUTEXAUTOLOCK_H
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#ifndef JTHREAD_H
+
+#define JTHREAD_H
+
+#include "jmutex.h"
+
+#define ERR_JTHREAD_CANTINITMUTEX -1
+#define ERR_JTHREAD_CANTSTARTTHREAD -2
+#define ERR_JTHREAD_THREADFUNCNOTSET -3
+#define ERR_JTHREAD_NOTRUNNING -4
+#define ERR_JTHREAD_ALREADYRUNNING -5
+
+class JThread
+{
+public:
+ JThread();
+ virtual ~JThread();
+ int Start();
+ int Kill();
+ virtual void *Thread() = 0;
+ bool IsRunning();
+ void *GetReturnValue();
+protected:
+ void ThreadStarted();
+private:
+
+#if (defined(WIN32) || defined(_WIN32_WCE))
+#ifdef _WIN32_WCE
+ DWORD threadid;
+ static DWORD WINAPI TheThread(void *param);
+#else
+ static UINT __stdcall TheThread(void *param);
+ UINT threadid;
+#endif // _WIN32_WCE
+ HANDLE threadhandle;
+#else // pthread type threads
+ static void *TheThread(void *param);
+
+ pthread_t threadid;
+#endif // WIN32
+ void *retval;
+ bool running;
+
+ JMutex runningmutex;
+ JMutex continuemutex,continuemutex2;
+ bool mutexinit;
+};
+
+#endif // JTHREAD_H
+
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#include "jmutex.h"
+
+JMutex::JMutex()
+{
+ initialized = false;
+}
+
+JMutex::~JMutex()
+{
+ if (initialized)
+ pthread_mutex_destroy(&mutex);
+}
+
+int JMutex::Init()
+{
+ if (initialized)
+ return ERR_JMUTEX_ALREADYINIT;
+
+ pthread_mutex_init(&mutex,NULL);
+ initialized = true;
+ return 0;
+}
+
+int JMutex::Lock()
+{
+ if (!initialized)
+ return ERR_JMUTEX_NOTINIT;
+
+ pthread_mutex_lock(&mutex);
+ return 0;
+}
+
+int JMutex::Unlock()
+{
+ if (!initialized)
+ return ERR_JMUTEX_NOTINIT;
+
+ pthread_mutex_unlock(&mutex);
+ return 0;
+}
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#include "jthread.h"
+#include <sys/time.h>
+#include <time.h>
+#include <stdlib.h>
+
+JThread::JThread()
+{
+ retval = NULL;
+ mutexinit = false;
+ running = false;
+}
+
+JThread::~JThread()
+{
+ Kill();
+}
+
+int JThread::Start()
+{
+ int status;
+
+ if (!mutexinit)
+ {
+ if (!runningmutex.IsInitialized())
+ {
+ if (runningmutex.Init() < 0)
+ return ERR_JTHREAD_CANTINITMUTEX;
+ }
+ if (!continuemutex.IsInitialized())
+ {
+ if (continuemutex.Init() < 0)
+ return ERR_JTHREAD_CANTINITMUTEX;
+ }
+ if (!continuemutex2.IsInitialized())
+ {
+ if (continuemutex2.Init() < 0)
+ return ERR_JTHREAD_CANTINITMUTEX;
+ }
+ mutexinit = true;
+ }
+
+ runningmutex.Lock();
+ if (running)
+ {
+ runningmutex.Unlock();
+ return ERR_JTHREAD_ALREADYRUNNING;
+ }
+ runningmutex.Unlock();
+
+ pthread_attr_t attr;
+ pthread_attr_init(&attr);
+ pthread_attr_setdetachstate(&attr,PTHREAD_CREATE_DETACHED);
+
+ continuemutex.Lock();
+ status = pthread_create(&threadid,&attr,TheThread,this);
+ pthread_attr_destroy(&attr);
+ if (status != 0)
+ {
+ continuemutex.Unlock();
+ return ERR_JTHREAD_CANTSTARTTHREAD;
+ }
+
+ /* Wait until 'running' is set */
+
+ runningmutex.Lock();
+ while (!running)
+ {
+ runningmutex.Unlock();
+
+ struct timespec req,rem;
+
+ req.tv_sec = 0;
+ req.tv_nsec = 1000000;
+ nanosleep(&req,&rem);
+
+ runningmutex.Lock();
+ }
+ runningmutex.Unlock();
+
+ continuemutex.Unlock();
+
+ continuemutex2.Lock();
+ continuemutex2.Unlock();
+ return 0;
+}
+
+int JThread::Kill()
+{
+ runningmutex.Lock();
+ if (!running)
+ {
+ runningmutex.Unlock();
+ return ERR_JTHREAD_NOTRUNNING;
+ }
+ pthread_cancel(threadid);
+ running = false;
+ runningmutex.Unlock();
+ return 0;
+}
+
+bool JThread::IsRunning()
+{
+ bool r;
+
+ runningmutex.Lock();
+ r = running;
+ runningmutex.Unlock();
+ return r;
+}
+
+void *JThread::GetReturnValue()
+{
+ void *val;
+
+ runningmutex.Lock();
+ if (running)
+ val = NULL;
+ else
+ val = retval;
+ runningmutex.Unlock();
+ return val;
+}
+
+void *JThread::TheThread(void *param)
+{
+ JThread *jthread;
+ void *ret;
+
+ jthread = (JThread *)param;
+
+ jthread->continuemutex2.Lock();
+ jthread->runningmutex.Lock();
+ jthread->running = true;
+ jthread->runningmutex.Unlock();
+
+ jthread->continuemutex.Lock();
+ jthread->continuemutex.Unlock();
+
+ ret = jthread->Thread();
+
+ jthread->runningmutex.Lock();
+ jthread->running = false;
+ jthread->retval = ret;
+ jthread->runningmutex.Unlock();
+
+ return NULL;
+}
+
+void JThread::ThreadStarted()
+{
+ continuemutex2.Unlock();
+}
+
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#include "jmutex.h"
+
+JMutex::JMutex()
+{
+ initialized = false;
+}
+
+JMutex::~JMutex()
+{
+ if (initialized)
+#ifdef JMUTEX_CRITICALSECTION
+ DeleteCriticalSection(&mutex);
+#else
+ CloseHandle(mutex);
+#endif // JMUTEX_CRITICALSECTION
+}
+
+int JMutex::Init()
+{
+ if (initialized)
+ return ERR_JMUTEX_ALREADYINIT;
+#ifdef JMUTEX_CRITICALSECTION
+ InitializeCriticalSection(&mutex);
+#else
+ mutex = CreateMutex(NULL,FALSE,NULL);
+ if (mutex == NULL)
+ return ERR_JMUTEX_CANTCREATEMUTEX;
+#endif // JMUTEX_CRITICALSECTION
+ initialized = true;
+ return 0;
+}
+
+int JMutex::Lock()
+{
+ if (!initialized)
+ return ERR_JMUTEX_NOTINIT;
+#ifdef JMUTEX_CRITICALSECTION
+ EnterCriticalSection(&mutex);
+#else
+ WaitForSingleObject(mutex,INFINITE);
+#endif // JMUTEX_CRITICALSECTION
+ return 0;
+}
+
+int JMutex::Unlock()
+{
+ if (!initialized)
+ return ERR_JMUTEX_NOTINIT;
+#ifdef JMUTEX_CRITICALSECTION
+ LeaveCriticalSection(&mutex);
+#else
+ ReleaseMutex(mutex);
+#endif // JMUTEX_CRITICALSECTION
+ return 0;
+}
+
--- /dev/null
+/*
+
+ This file is a part of the JThread package, which contains some object-
+ oriented thread wrappers for different thread implementations.
+
+ Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+ Permission is hereby granted, free of charge, to any person obtaining a
+ copy of this software and associated documentation files (the "Software"),
+ to deal in the Software without restriction, including without limitation
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ and/or sell copies of the Software, and to permit persons to whom the
+ Software is furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ DEALINGS IN THE SOFTWARE.
+
+*/
+
+#include "jthread.h"
+
+#ifndef _WIN32_WCE
+ #include <process.h>
+#endif // _WIN32_WCE
+
+JThread::JThread()
+{
+ retval = NULL;
+ mutexinit = false;
+ running = false;
+}
+
+JThread::~JThread()
+{
+ Kill();
+}
+
+int JThread::Start()
+{
+ if (!mutexinit)
+ {
+ if (!runningmutex.IsInitialized())
+ {
+ if (runningmutex.Init() < 0)
+ return ERR_JTHREAD_CANTINITMUTEX;
+ }
+ if (!continuemutex.IsInitialized())
+ {
+ if (continuemutex.Init() < 0)
+ return ERR_JTHREAD_CANTINITMUTEX;
+ }
+ if (!continuemutex2.IsInitialized())
+ {
+ if (continuemutex2.Init() < 0)
+ return ERR_JTHREAD_CANTINITMUTEX;
+ } mutexinit = true;
+ }
+
+ runningmutex.Lock();
+ if (running)
+ {
+ runningmutex.Unlock();
+ return ERR_JTHREAD_ALREADYRUNNING;
+ }
+ runningmutex.Unlock();
+
+ continuemutex.Lock();
+#ifndef _WIN32_WCE
+ threadhandle = (HANDLE)_beginthreadex(NULL,0,TheThread,this,0,&threadid);
+#else
+ threadhandle = CreateThread(NULL,0,TheThread,this,0,&threadid);
+#endif // _WIN32_WCE
+ if (threadhandle == NULL)
+ {
+ continuemutex.Unlock();
+ return ERR_JTHREAD_CANTSTARTTHREAD;
+ }
+
+ /* Wait until 'running' is set */
+
+ runningmutex.Lock();
+ while (!running)
+ {
+ runningmutex.Unlock();
+ Sleep(1);
+ runningmutex.Lock();
+ }
+ runningmutex.Unlock();
+
+ continuemutex.Unlock();
+
+ continuemutex2.Lock();
+ continuemutex2.Unlock();
+
+ return 0;
+}
+
+int JThread::Kill()
+{
+ runningmutex.Lock();
+ if (!running)
+ {
+ runningmutex.Unlock();
+ return ERR_JTHREAD_NOTRUNNING;
+ }
+ TerminateThread(threadhandle,0);
+ CloseHandle(threadhandle);
+ running = false;
+ runningmutex.Unlock();
+ return 0;
+}
+
+bool JThread::IsRunning()
+{
+ bool r;
+
+ runningmutex.Lock();
+ r = running;
+ runningmutex.Unlock();
+ return r;
+}
+
+void *JThread::GetReturnValue()
+{
+ void *val;
+
+ runningmutex.Lock();
+ if (running)
+ val = NULL;
+ else
+ val = retval;
+ runningmutex.Unlock();
+ return val;
+}
+
+#ifndef _WIN32_WCE
+UINT __stdcall JThread::TheThread(void *param)
+#else
+DWORD WINAPI JThread::TheThread(void *param)
+#endif // _WIN32_WCE
+{
+ JThread *jthread;
+ void *ret;
+
+ jthread = (JThread *)param;
+
+ jthread->continuemutex2.Lock();
+ jthread->runningmutex.Lock();
+ jthread->running = true;
+ jthread->runningmutex.Unlock();
+
+ jthread->continuemutex.Lock();
+ jthread->continuemutex.Unlock();
+
+ ret = jthread->Thread();
+
+ jthread->runningmutex.Lock();
+ jthread->running = false;
+ jthread->retval = ret;
+ CloseHandle(jthread->threadhandle);
+ jthread->runningmutex.Unlock();
+ return 0;
+}
+
+void JThread::ThreadStarted()
+{
+ continuemutex2.Unlock();
+}
+