diff options
Diffstat (limited to '')
-rw-r--r-- | src/civetweb/Makefile | 332 | ||||
-rw-r--r-- | src/civetweb/Makefile.deprecated | 208 | ||||
-rw-r--r-- | src/civetweb/Makefile.osx | 42 |
3 files changed, 582 insertions, 0 deletions
diff --git a/src/civetweb/Makefile b/src/civetweb/Makefile new file mode 100644 index 00000000..fdc015f9 --- /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 00000000..288c15ba --- /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 00000000..44260e84 --- /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 |