summaryrefslogtreecommitdiffstats
path: root/src/civetweb/Makefile
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/civetweb/Makefile332
-rw-r--r--src/civetweb/Makefile.deprecated208
-rw-r--r--src/civetweb/Makefile.osx42
3 files changed, 582 insertions, 0 deletions
diff --git a/src/civetweb/Makefile b/src/civetweb/Makefile
new file mode 100644
index 000000000..fdc015f9e
--- /dev/null
+++ b/src/civetweb/Makefile
@@ -0,0 +1,332 @@
+#
+# Copyright (c) 2013 No Face Press, LLC
+# License http://opensource.org/licenses/mit-license.php MIT License
+#
+
+#
+# For help try, "make help"
+#
+
+include resources/Makefile.in-os
+
+CPROG = civetweb
+#CXXPROG = civetweb
+UNIT_TEST_PROG = civetweb_test
+
+BUILD_DIR = out
+
+# Installation directories by convention
+# http://www.gnu.org/prep/standards/html_node/Directory-Variables.html
+PREFIX = /usr/local
+EXEC_PREFIX = $(PREFIX)
+BINDIR = $(EXEC_PREFIX)/bin
+DATAROOTDIR = $(PREFIX)/share
+DOCDIR = $(DATAROOTDIR)/doc/$(CPROG)
+SYSCONFDIR = $(PREFIX)/etc
+HTMLDIR = $(DOCDIR)
+
+# build tools
+MKDIR = mkdir -p
+RMF = rm -f
+RMRF = rm -rf
+
+# desired configuration of the document root
+# never assume that the document_root actually
+# exists on the build machine. When building
+# a chroot, PREFIX if just a directory which
+# later becomes /.
+DOCUMENT_ROOT = $(HTMLDIR)
+PORTS = 8080
+
+BUILD_DIRS = $(BUILD_DIR) $(BUILD_DIR)/src $(BUILD_DIR)/resources
+
+LIB_SOURCES = src/civetweb.c
+LIB_INLINE = src/mod_lua.inl src/md5.inl
+APP_SOURCES = src/main.c
+WINDOWS_RESOURCES = resources/res.rc
+UNIT_TEST_SOURCES = test/unit_test.c
+SOURCE_DIRS =
+
+OBJECTS = $(LIB_SOURCES:.c=.o) $(APP_SOURCES:.c=.o)
+BUILD_RESOURCES =
+
+# The unit tests include the source files directly to get visibility to the
+# static functions. So we clear OBJECTS so that we don't try to build or link
+# with any external object. Later if we find WITH_LUA=1, we'll add lua objects
+# to this variable so we can run lua-specific unit tests.
+ifeq ($(MAKECMDGOALS), unit_test)
+OBJECTS =
+BUILD_DIRS += $(BUILD_DIR)/test
+endif
+
+# only set main compile options if none were chosen
+CFLAGS += -Wall -Wextra -Wshadow -Wformat-security -Winit-self -Wmissing-prototypes -D$(TARGET_OS) -Iinclude $(COPT) -DUSE_STACK_SIZE=102400
+
+LIBS = -lpthread -lm
+
+ifdef WITH_DEBUG
+ CFLAGS += -g -DDEBUG
+else
+ CFLAGS += -O2 -DNDEBUG
+endif
+
+ifdef WITH_CPP
+ OBJECTS += src/CivetServer.o
+ LCC = $(CXX)
+else
+ LCC = $(CC)
+endif
+
+ifdef WITH_ALL
+ WITH_WEBSOCKET = 1
+ WITH_IPV6 = 1
+ WITH_LUA = 1
+ WITH_DUKTAPE = 1
+ WITH_SERVER_STATS = 1
+ #WITH_CPP is not defined, ALL means only real features, not wrappers
+endif
+
+ifdef WITH_LUA_SHARED
+ WITH_LUA = 1
+endif
+
+ifdef WITH_LUAJIT_SHARED
+ WITH_LUA_SHARED = 1
+ WITH_LUA = 1
+ WITH_LUA_VERSION = 501
+endif
+
+ifdef WITH_LUA
+ include resources/Makefile.in-lua
+endif
+
+ifdef WITH_SSJS
+ WITH_DUKTAPE = 1
+endif
+
+ifdef WITH_DUKTAPE_SHARED
+ WITH_DUKTAPE = 1
+endif
+
+ifdef WITH_DUKTAPE
+ include resources/Makefile.in-duktape
+endif
+
+ifdef WITH_IPV6
+ CFLAGS += -DUSE_IPV6
+endif
+
+ifdef WITH_WEBSOCKET
+ CFLAGS += -DUSE_WEBSOCKET
+endif
+ifdef WITH_WEBSOCKETS
+ CFLAGS += -DUSE_WEBSOCKET
+endif
+
+ifdef WITH_SERVER_STAT
+ CFLAGS += -DUSE_SERVER_STATS
+endif
+ifdef WITH_SERVER_STATS
+ CFLAGS += -DUSE_SERVER_STATS
+endif
+
+ifdef CONFIG_FILE
+ CFLAGS += -DCONFIG_FILE=\"$(CONFIG_FILE)\"
+endif
+
+ifdef CONFIG_FILE2
+ CFLAGS += -DCONFIG_FILE2=\"$(CONFIG_FILE2)\"
+endif
+
+ifdef SSL_LIB
+ CFLAGS += -DSSL_LIB=\"$(SSL_LIB)\"
+endif
+
+ifdef CRYPTO_LIB
+ CFLAGS += -DCRYPTO_LIB=\"$(CRYPTO_LIB)\"
+endif
+
+BUILD_DIRS += $(addprefix $(BUILD_DIR)/, $(SOURCE_DIRS))
+BUILD_OBJECTS = $(addprefix $(BUILD_DIR)/, $(OBJECTS))
+MAIN_OBJECTS = $(addprefix $(BUILD_DIR)/, $(APP_SOURCES:.c=.o))
+LIB_OBJECTS = $(filter-out $(MAIN_OBJECTS), $(BUILD_OBJECTS))
+
+ifeq ($(TARGET_OS),LINUX)
+ LIBS += -lrt -ldl
+ CAN_INSTALL = 1
+endif
+
+ifeq ($(TARGET_OS),WIN32)
+ MKDIR = mkdir
+ RMF = del /q
+ RMRF = rmdir /s /q
+endif
+
+ifdef WITH_LUAJIT_SHARED
+ LIBS += -lluajit-5.1
+else
+ifdef WITH_LUA_SHARED
+ LIBS += $(LUA_SHARED_LIB_FLAG)
+endif
+endif
+
+ifneq (, $(findstring mingw32, $(shell $(CC) -dumpmachine)))
+ BUILD_RESOURCES = $(BUILD_DIR)/$(WINDOWS_RESOURCES:.rc=.o)
+ LIBS += -lws2_32 -mwindows
+ SHARED_LIB = dll
+else
+ SHARED_LIB = so
+endif
+
+all: build
+
+help:
+ @echo "make help show this message"
+ @echo "make build compile"
+ @echo "make install install on the system"
+ @echo "make clean clean up the mess"
+ @echo "make lib build a static library"
+ @echo "make slib build a shared library"
+ @echo "make unit_test build unit tests executable"
+ @echo ""
+ @echo " Make Options"
+ @echo " WITH_LUA=1 build with Lua support; include Lua as static library"
+ @echo " WITH_LUA_SHARED=1 build with Lua support; use dynamic linking to liblua5.2.so"
+ @echo " WITH_LUA_VERSION=502 build with Lua 5.2.x (501 for Lua 5.1.x to 503 for 5.3.x)"
+ @echo " WITH_DUKTAPE=1 build with Duktape support; include as static library"
+ @echo " WITH_DUKTAPE_SHARED=1 build with Duktape support; use libduktape1.3.so"
+# @echo " WITH_DUKTAPE_VERSION=103 build with Duktape 1.3.x"
+ @echo " WITH_DEBUG=1 build with GDB debug support"
+ @echo " WITH_IPV6=1 with IPV6 support"
+ @echo " WITH_WEBSOCKET=1 build with web socket support"
+ @echo " WITH_SERVER_STATS=1 build includes support for server statistics"
+ @echo " WITH_CPP=1 build library with c++ classes"
+ @echo " CONFIG_FILE=file use 'file' as the config file"
+ @echo " CONFIG_FILE2=file use 'file' as the backup config file"
+ @echo " DOCUMENT_ROOT=/path document root override when installing"
+ @echo " PORTS=8080 listening ports override when installing"
+ @echo " SSL_LIB=libssl.so.0 use versioned SSL library"
+ @echo " CRYPTO_LIB=libcrypto.so.0 system versioned CRYPTO library"
+ @echo " PREFIX=/usr/local sets the install directory"
+ @echo " COPT='-DNO_SSL' method to insert compile flags"
+ @echo ""
+ @echo " Compile Flags"
+ @echo " NDEBUG strip off all debug code"
+ @echo " DEBUG build debug version (very noisy)"
+ @echo " NO_CGI disable CGI support"
+ @echo " NO_SSL disable SSL functionality"
+ @echo " NO_SSL_DL link against system libssl library"
+ @echo " NO_FILES do not serve files from a directory"
+ @echo " NO_CACHING disable caching (usefull for systems without timegm())"
+ @echo ""
+ @echo " Variables"
+ @echo " TARGET_OS='$(TARGET_OS)'"
+ @echo " CFLAGS='$(CFLAGS)'"
+ @echo " CXXFLAGS='$(CXXFLAGS)'"
+ @echo " LDFLAGS='$(LDFLAGS)'"
+ @echo " CC='$(CC)'"
+ @echo " CXX='$(CXX)'"
+
+build: $(CPROG) $(CXXPROG)
+
+unit_test: $(UNIT_TEST_PROG)
+
+ifeq ($(CAN_INSTALL),1)
+install: $(HTMLDIR)/index.html $(SYSCONFDIR)/civetweb.conf
+ install -d -m 755 "$(DOCDIR)"
+ install -m 644 *.md "$(DOCDIR)"
+ install -d -m 755 "$(BINDIR)"
+ install -m 755 $(CPROG) "$(BINDIR)/"
+
+# Install target we do not want to overwrite
+# as it may be an upgrade
+$(HTMLDIR)/index.html:
+ install -d -m 755 "$(HTMLDIR)"
+ install -m 644 resources/itworks.html $(HTMLDIR)/index.html
+ install -m 644 resources/civetweb_64x64.png $(HTMLDIR)/
+
+# Install target we do not want to overwrite
+# as it may be an upgrade
+$(SYSCONFDIR)/civetweb.conf:
+ install -d -m 755 "$(SYSCONFDIR)"
+ install -m 644 resources/civetweb.conf "$(SYSCONFDIR)/"
+ @sed -i 's#^document_root.*$$#document_root $(DOCUMENT_ROOT)#' "$(SYSCONFDIR)/civetweb.conf"
+ @sed -i 's#^listening_ports.*$$#listening_ports $(PORTS)#' "$(SYSCONFDIR)/civetweb.conf"
+
+else
+install:
+ @echo "Target not flagged for installation. Use CAN_INSTALL=1 to force"
+ @echo "As a precaution only LINUX targets are set as installable."
+ @echo "If the target is linux-like, use CAN_INSTALL=1 option."
+endif
+
+lib: lib$(CPROG).a
+
+slib: lib$(CPROG).$(SHARED_LIB)
+
+clean:
+ $(RMRF) $(BUILD_DIR)
+ $(eval version=$(shell grep -w "define CIVETWEB_VERSION" include/civetweb.h | sed 's|.*VERSION "\(.*\)"|\1|g'))
+ $(eval major=$(shell echo $(version) | cut -d'.' -f1))
+ $(RMRF) lib$(CPROG).a
+ $(RMRF) lib$(CPROG).so
+ $(RMRF) lib$(CPROG).so.$(major)
+ $(RMRF) lib$(CPROG).so.$(version).0
+ $(RMRF) $(CPROG)
+ $(RMF) $(UNIT_TEST_PROG)
+
+distclean: clean
+ @$(RMRF) VS2012/Debug VS2012/*/Debug VS2012/*/*/Debug
+ @$(RMRF) VS2012/Release VS2012/*/Release VS2012/*/*/Release
+ $(RMF) $(CPROG) lib$(CPROG).so lib$(CPROG).a *.dmg *.msi *.exe lib$(CPROG).dll lib$(CPROG).dll.a
+ $(RMF) $(UNIT_TEST_PROG)
+
+lib$(CPROG).a: CFLAGS += -fPIC
+lib$(CPROG).a: $(LIB_OBJECTS)
+ @$(RMF) $@
+ ar cq $@ $(LIB_OBJECTS)
+
+lib$(CPROG).so: CFLAGS += -fPIC
+lib$(CPROG).so: $(LIB_OBJECTS)
+ $(eval version=$(shell grep -w "define CIVETWEB_VERSION" include/civetweb.h | sed 's|.*VERSION "\(.*\)"|\1|g'))
+ $(eval major=$(shell echo $(version) | cut -d'.' -f1))
+ $(LCC) -shared -Wl,-soname,$@.$(major) -o $@.$(version).0 $(CFLAGS) $(LDFLAGS) $(LIB_OBJECTS)
+ ln -s -f $@.$(major) $@
+ ln -s -f $@.$(version).0 $@.$(major)
+
+lib$(CPROG).dll: CFLAGS += -fPIC
+lib$(CPROG).dll: $(LIB_OBJECTS)
+ $(LCC) -shared -o $@ $(CFLAGS) $(LDFLAGS) $(LIB_OBJECTS) $(LIBS) -Wl,--out-implib,lib$(CPROG).dll.a
+
+$(UNIT_TEST_PROG): CFLAGS += -Isrc -g
+$(UNIT_TEST_PROG): $(LIB_SOURCES) $(LIB_INLINE) $(UNIT_TEST_SOURCES) $(BUILD_OBJECTS)
+ $(LCC) -o $@ $(CFLAGS) $(LDFLAGS) $(UNIT_TEST_SOURCES) $(BUILD_OBJECTS) $(LIBS)
+
+$(CPROG): $(BUILD_OBJECTS) $(BUILD_RESOURCES)
+ $(LCC) -o $@ $(CFLAGS) $(LDFLAGS) $(BUILD_OBJECTS) $(BUILD_RESOURCES) $(LIBS)
+
+$(CXXPROG): $(BUILD_OBJECTS)
+ $(CXX) -o $@ $(CFLAGS) $(LDFLAGS) $(BUILD_OBJECTS) $(LIBS)
+
+$(BUILD_OBJECTS): $(BUILD_DIRS)
+
+$(BUILD_DIRS):
+ -@$(MKDIR) "$@"
+
+$(BUILD_DIR)/%.o : %.cpp
+ $(CXX) -c $(CFLAGS) $(CXXFLAGS) $< -o $@
+
+$(BUILD_DIR)/%.o : %.c
+ $(CC) -c $(CFLAGS) $< -o $@
+
+$(BUILD_RESOURCES) : $(WINDOWS_RESOURCES)
+ windres $(WINDRES_FLAGS) $< $@
+
+# This rules is used to keep the code formatted in a reasonable manor
+# For this to work astyle must be installed and in the path
+# http://sourceforge.net/projects/astyle
+indent:
+ astyle --suffix=none --style=linux --indent=spaces=4 --lineend=linux include/*.h src/*.c src/*.cpp src/*.inl examples/*/*.c examples/*/*.cpp
+
+.PHONY: all help build install clean lib so
+
diff --git a/src/civetweb/Makefile.deprecated b/src/civetweb/Makefile.deprecated
new file mode 100644
index 000000000..288c15ba8
--- /dev/null
+++ b/src/civetweb/Makefile.deprecated
@@ -0,0 +1,208 @@
+# This Makefile is part of Civetweb web server project,
+# https://github.com/valenok/civetweb
+#
+# Example custom build:
+# COPT="-g -O0 -DNO_SSL_DL -DUSE_LUA -llua -lcrypto -lssl" make linux
+#
+# Flags are:
+# -DHAVE_MD5 - use system md5 library (-2kb)
+# -DNDEBUG - strip off all debug code (-5kb)
+# -DDEBUG - build debug version (very noisy) (+7kb)
+# -DNO_CGI - disable CGI support (-5kb)
+# -DNO_SSL - disable SSL functionality (-2kb)
+# -DNO_SSL_DL - link against system libssl library (-1kb)
+# -DCONFIG_FILE=\"file\" - use `file' as the default config file
+# -DSSL_LIB=\"libssl.so.<version>\" - use system versioned SSL shared object
+# -DCRYPTO_LIB=\"libcrypto.so.<version>\" - use system versioned CRYPTO so
+# -DUSE_LUA - embed Lua in Civetweb (+100kb)
+
+PROG = civetweb
+CFLAGS = -std=c99 -O2 -W -Wall -pedantic -pthread -pipe -Iinclude $(COPT)
+
+# To build with Lua, download and unzip Lua 5.2.3 source code into the
+# civetweb directory, and then add $(LUA_SOURCES) to CFLAGS
+LUA = src/third_party/lua-5.2.3/src
+LUA_FLAGS = -I$(LUA) -DLUA_COMPAT_ALL
+LUA_SOURCES = $(LUA)/lapi.c $(LUA)/lcode.c $(LUA)/lctype.c \
+ $(LUA)/ldebug.c $(LUA)/ldo.c $(LUA)/ldump.c \
+ $(LUA)/lfunc.c $(LUA)/lgc.c $(LUA)/llex.c \
+ $(LUA)/lmem.c $(LUA)/lobject.c $(LUA)/lopcodes.c \
+ $(LUA)/lparser.c $(LUA)/lstate.c $(LUA)/lstring.c \
+ $(LUA)/ltable.c $(LUA)/ltm.c $(LUA)/lundump.c \
+ $(LUA)/lvm.c $(LUA)/lzio.c $(LUA)/lauxlib.c \
+ $(LUA)/lbaselib.c $(LUA)/lbitlib.c $(LUA)/lcorolib.c \
+ $(LUA)/ldblib.c $(LUA)/liolib.c $(LUA)/lmathlib.c \
+ $(LUA)/loslib.c $(LUA)/lstrlib.c $(LUA)/ltablib.c \
+ $(LUA)/loadlib.c $(LUA)/linit.c
+LUA_WINOBJS = $(LUA_SOURCES:%.c=%.obj)
+
+ifneq ($(OS), Windows_NT)
+ LUA_FLAGS += -DLUA_USE_DLOPEN
+endif
+
+LIB_SOURCES = src/civetweb.c
+
+ALL_SOURCES = src/main.c $(LIB_SOURCES) src/third_party/sqlite3.c src/third_party/lsqlite3.c src/third_party/lfs.c \
+ $(LUA_SOURCES) $(YASSL_SOURCES)
+
+SQLITE_FLAGS = -DTHREADSAFE=1 -DSQLITE_ENABLE_FTS3 -DSQLITE_ENABLE_FTS3_PARENTHESIS
+CIVETWEB_FLAGS = -DUSE_LUA -DUSE_LUA_SQLITE3 -DUSE_LUA_FILE_SYSTEM $(COPT)
+FLAGS = $(CIVETWEB_FLAGS) $(SQLITE_FLAGS) $(LUA_FLAGS)
+
+
+# Stock windows binary builds with Lua.
+# Yassl has a GPL license, so we will leave it out by default.
+
+ifeq ($(WITH_YASSL), 1)
+YASSL = ../cyassl-2.4.6
+YASSL_FLAGS = -I $(YASSL) -I $(YASSL)/cyassl \
+ -D _LIB -D OPENSSL_EXTRA -D HAVE_ERRNO_H \
+ -D HAVE_GETHOSTBYNAME -D HAVE_INET_NTOA -D HAVE_LIMITS_H \
+ -D HAVE_MEMSET -D HAVE_SOCKET -D HAVE_STDDEF_H -D HAVE_STDLIB_H \
+ -D HAVE_STRING_H -D HAVE_SYS_STAT_H -D HAVE_SYS_TYPES_H
+YASSL_SOURCES = \
+ $(YASSL)/src/internal.c $(YASSL)/src/io.c $(YASSL)/src/keys.c \
+ $(YASSL)/src/ssl.c $(YASSL)/src/tls.c $(YASSL)/ctaocrypt/src/hmac.c \
+ $(YASSL)/ctaocrypt/src/random.c $(YASSL)/ctaocrypt/src/sha.c \
+ $(YASSL)/ctaocrypt/src/sha256.c $(YASSL)/ctaocrypt/src/logging.c \
+ $(YASSL)/ctaocrypt/src/error.c $(YASSL)/ctaocrypt/src/rsa.c \
+ $(YASSL)/ctaocrypt/src/des3.c $(YASSL)/ctaocrypt/src/asn.c \
+ $(YASSL)/ctaocrypt/src/coding.c $(YASSL)/ctaocrypt/src/arc4.c \
+ $(YASSL)/ctaocrypt/src/md4.c $(YASSL)/ctaocrypt/src/md5.c \
+ $(YASSL)/ctaocrypt/src/dh.c $(YASSL)/ctaocrypt/src/dsa.c \
+ $(YASSL)/ctaocrypt/src/pwdbased.c $(YASSL)/ctaocrypt/src/aes.c \
+ $(YASSL)/ctaocrypt/src/md2.c $(YASSL)/ctaocrypt/src/ripemd.c \
+ $(YASSL)/ctaocrypt/src/sha512.c $(YASSL)/src/sniffer.c \
+ $(YASSL)/ctaocrypt/src/rabbit.c $(YASSL)/ctaocrypt/src/misc.c \
+ $(YASSL)/ctaocrypt/src/tfm.c $(YASSL)/ctaocrypt/src/integer.c \
+ $(YASSL)/ctaocrypt/src/ecc.c $(YASSL)/src/ocsp.c $(YASSL)/src/crl.c \
+ $(YASSL)/ctaocrypt/src/hc128.c $(YASSL)/ctaocrypt/src/memory.c
+
+ ALL_SOURCES += $(YASSL_SOURCES)
+ FLAGS += $(YASSL_FLAGS) -DNO_SSL_DL
+ CIVETWEB_FLAGS += -DNO_SSL_DL
+
+else
+# FLAGS += -DNO_SSL
+# CIVETWEB_FLAGS += -DNO_SSL
+endif
+
+ALL_OBJECTS = $(ALL_SOURCES:%.c=%.o)
+ALL_WINOBJS = $(ALL_SOURCES:%.c=%.obj)
+
+
+# Using Visual Studio 6.0. To build Civetweb:
+# Set MSVC variable below to where VS 6.0 is installed on your system
+# Run "PATH_TO_VC6\bin\nmake windows"
+MSVC = ../vc6
+#DBG = /Zi /Od
+DBG = /DNDEBUG /O1
+CL = $(MSVC)/bin/cl /MD /TC /nologo $(DBG) /W3 /GA /I$(MSVC)/include
+LINK = $(MSVC)/bin/link /incremental:no /libpath:$(MSVC)/lib /machine:IX86 \
+ user32.lib shell32.lib comdlg32.lib ws2_32.lib advapi32.lib
+
+all:
+ @echo "make (linux|bsd|solaris|mac|windows|mingw|cygwin)"
+
+%.obj: %.c
+ $(CL) /c $(FLAGS) /Fo$@ $<
+
+%.o: %.c
+ $(CC) -o $@ $< -c $(FLAGS) $(CFLAGS)
+
+# Lua library for Windows
+lua.lib: $(LUA_WINOBJS)
+ $(MSVC)/bin/lib /out:$@ $(LUA_WINOBJS)
+
+# To build with Lua, make sure you have Lua unpacked into src/third_party/lua-5.2.3 directory
+linux_lua: $(ALL_OBJECTS)
+ $(CC) $(ALL_OBJECTS) -o $(PROG) -ldl
+
+civetweb.o: src/mod_lua.inl
+
+# Make sure that the compiler flags come last in the compilation string.
+# If not so, this can break some on some Linux distros which use
+# "-Wl,--as-needed" turned on by default in cc command.
+# Also, this is turned in many other distros in static linkage builds.
+linux:
+ $(CC) $(LIB_SOURCES) src/main.c -o $(PROG) -ldl $(CFLAGS)
+
+mac: bsd
+bsd:
+ $(CC) $(LIB_SOURCES) src/main.c -o $(PROG) $(CFLAGS)
+
+bsd_lua: $(ALL_OBJECTS)
+ $(CC) $(ALL_OBJECTS) -o $@
+
+solaris:
+ $(CC) $(LIB_SOURCES) src/main.c -lnsl -lsocket -o $(PROG) $(CFLAGS)
+
+lib$(PROG).a: $(ALL_OBJECTS)
+ ar cr $@ $(ALL_OBJECTS)
+
+$(PROG).lib: $(ALL_WINOBJS)
+ $(MSVC)/bin/lib /out:$@ $(ALL_WINOBJS)
+
+# For codesign to work in non-interactive mode, unlock login keychain:
+# security unlock ~/Library/Keychains/login.keychain
+# See e.g. http://lists.apple.com/archives/apple-cdsa/2008/Jan/msg00027.html
+Civetweb: $(LIB_SOURCES) src/main.c
+ $(CC) $(LIB_SOURCES) src/main.c src/third_party/lsqlite3.c src/third_party/sqlite3.c src/third_party/lfs.c \
+ -DUSE_COCOA $(CFLAGS) $(FLAGS) -mmacosx-version-min=10.4 \
+ $(YASSL_SOURCES) $(LUA_SOURCES) \
+ -framework Cocoa -ObjC -arch i386 -arch x86_64 -o Civetweb
+
+cocoa: Civetweb
+ V=`perl -lne '/define\s+CIVETWEB_VERSION\s+"(\S+)"/ and print $$1' include/civetweb.h`; DIR=dmg/Civetweb.app && rm -rf $$DIR && mkdir -p $$DIR/Contents/{MacOS,Resources} && install -m 644 resources/civetweb_*.png resources/civetweb.icns $$DIR/Contents/Resources/ && install -m 644 resources/Info.plist $$DIR/Contents/ && install -m 755 Civetweb $$DIR/Contents/MacOS/ && ln -fs /Applications dmg/ ; hdiutil create Civetweb_$$V.dmg -volname "Civetweb $$V" -srcfolder dmg -ov #; rm -rf dmg
+
+un:
+ $(CC) test/unit_test.c -o unit_test -I. -I$(LUA) $(LUA_SOURCES) \
+ $(CFLAGS) -g -O0
+ ./unit_test
+
+wi:
+ $(CL) test/unit_test.c $(LUA_SOURCES) $(LUA_FLAGS) \
+ $(YASSL_SOURCES) $(YASSL_FLAGS) /I. /DNO_SSL_DL \
+ /link /libpath:$(MSVC)/lib advapi32.lib /out:unit_test.exe
+ ./unit_test.exe
+
+windows: $(ALL_WINOBJS)
+ $(MSVC)/bin/rc resources/res.rc
+ $(LINK) /nologo $(ALL_WINOBJS) resources/res.res /out:$(PROG).exe
+
+# Build for Windows under MinGW
+#MINGWDBG= -DDEBUG -O0 -ggdb
+MINGWDBG= -DNDEBUG -Os
+MINGWOPT= -W -Wall -mthreads -Wl,--subsystem,console $(MINGWDBG) -DHAVE_STDINT $(GCC_WARNINGS) $(COPT)
+mingw:
+ windres resources\res.rc resources\res.o
+ $(CC) $(MINGWOPT) $(LIB_SOURCES) -lws2_32 \
+ -shared -Wl,--out-implib=$(PROG).lib -o $(PROG).dll
+ $(CC) $(MINGWOPT) $(LIB_SOURCES) src/main.c resources\res.o \
+ -lws2_32 -ladvapi32 -lcomdlg32 -o $(PROG).exe
+
+# Build for Windows under Cygwin
+#CYGWINDBG= -DDEBUG -O0 -ggdb
+CYGWINDBG= -DNDEBUG -Os
+CYGWINOPT= -W -Wall -mthreads -Wl,--subsystem,console $(CYGWINDBG) -DHAVE_STDINT $(GCC_WARNINGS) $(COPT)
+cygwin:
+ windres ./resources/res.rc ./resources/res.o
+ $(CC) $(CYGWINOPT) $(LIB_SOURCES) -lws2_32 \
+ -shared -Wl,--out-implib=$(PROG).lib -o $(PROG).dll
+ $(CC) $(CYGWINOPT) -Iinclude $(LIB_SOURCES) src/main.c ./resources/res.o \
+ -lws2_32 -ladvapi32 -o $(PROG).exe
+
+tests:
+ perl test/test.pl $(TEST)
+
+tarball: clean
+ F=civetweb-`perl -lne '/define\s+CIVETWEB_VERSION\s+"(\S+)"/ and print $$1' include/civetweb.h`.tgz ; cd .. && tar -czf x civetweb/{LICENSE.md,Makefile,examples,test,resources,*.[ch],*.md} && mv x civetweb/$$F
+
+release: tarball cocoa
+ wine make windows
+ V=`perl -lne '/define\s+CIVETWEB_VERSION\s+"(\S+)"/ and print $$1' include/civetweb.h`; upx civetweb.exe; cp civetweb.exe civetweb-$$V.exe; cp civetweb.exe civetweb_php_bundle/; zip -r civetweb_php_bundle_$$V.zip civetweb_php_bundle/
+
+clean:
+ rm -rf *.o *.core $(PROG) *.obj *.so $(PROG).txt *.dSYM *.tgz \
+ $(PROG).exe *.dll *.lib resources/res.o resources/res.RES *.dSYM *.zip *.pdb \
+ *.exe *.dmg $(ALL_OBJECTS) $(ALL_WINOBJS)
diff --git a/src/civetweb/Makefile.osx b/src/civetweb/Makefile.osx
new file mode 100644
index 000000000..44260e84c
--- /dev/null
+++ b/src/civetweb/Makefile.osx
@@ -0,0 +1,42 @@
+#
+# Copyright (c) 2013 No Face Press, LLC
+# License http://opensource.org/licenses/mit-license.php MIT License
+#
+
+# For codesign to work in non-interactive mode, unlock login keychain:
+# security unlock ~/Library/Keychains/login.keychain
+# See e.g. http://lists.apple.com/archives/apple-cdsa/2008/Jan/msg00027.html
+
+# Civetweb features
+WITH_LUA = 1
+
+PACKAGE = Civetweb
+BUILD_DIR = out
+
+CFLAGS += -DUSE_COCOA -DENABLE_CREATE_CONFIG_FILE -mmacosx-version-min=10.4 -ObjC -arch i386 -arch x86_64
+LDFLAGS += -framework Cocoa
+
+DMG_DIR = $(BUILD_DIR)/dmg
+CONTENTS_DIR = $(DMG_DIR)/$(PACKAGE).app/Contents
+RESOURCES_DIR = $(CONTENTS_DIR)/Resources
+OSXBIN_DIR = $(CONTENTS_DIR)/MacOS
+
+CIVETWEB_VERSION = $(shell perl -lne '/define\s+CIVETWEB_VERSION\s+"(\S+)"/ and print $$1' include/civetweb.h)
+ZIPFILENAME = $(PACKAGE)-$(CIVETWEB_VERSION).zip
+
+include Makefile
+
+package: build
+ @rm -rf $(DMG_DIR)
+ install -d -m 755 $(CONTENTS_DIR) $(RESOURCES_DIR) $(OSXBIN_DIR)
+ install -m 644 resources/Info.plist $(CONTENTS_DIR)/
+ install -m 644 resources/civetweb_*.png resources/civetweb.icns $(RESOURCES_DIR)/
+ install -m 644 resources/itworks.html $(OSXBIN_DIR)/index.html
+ install -m 644 resources/civetweb_64x64.png $(OSXBIN_DIR)/
+ install -m 755 $(CPROG) $(OSXBIN_DIR)/$(PACKAGE)
+ install -m 644 docs/Installing.md $(DMG_DIR)/Installing.txt
+ install -m 644 LICENSE.md $(DMG_DIR)/License.txt
+ rm -rf $(ZIPFILENAME)
+ cd $(DMG_DIR) && zip -r ../../$(ZIPFILENAME) .
+
+.PHONY: package