BSD: Build system fixes/improvements. DONT_BUILD.

git-svn-id: https://svn.eduke32.com/eduke32@5037 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2015-03-02 07:54:24 +00:00
parent 97c944a505
commit 17906349b4
8 changed files with 57 additions and 46 deletions

View file

@ -291,6 +291,10 @@ ifeq ($(SUBPLATFORM),LINUX)
LIBS += -lFLAC -lvorbisfile -lvorbis -logg LIBS += -lFLAC -lvorbisfile -lvorbis -logg
endif endif
ifeq ($(PLATFORM),BSD)
LIBS += -lFLAC -lvorbisfile -lvorbis -logg -lexecinfo
endif
ifeq ($(PLATFORM),DARWIN) ifeq ($(PLATFORM),DARWIN)
# LIBDIRS += -L$(AUDIOLIB_ROOT)/third-party/Apple/lib # LIBDIRS += -L$(AUDIOLIB_ROOT)/third-party/Apple/lib

View file

@ -102,39 +102,39 @@ SYSBITS=32
# the outside world. This allows cross-compilation by overriding # the outside world. This allows cross-compilation by overriding
# CC and giving us PLATFORM specifically. # CC and giving us PLATFORM specifically.
# #
ifndef HOST ifndef HOSTPLATFORM
uname:=$(strip $(shell uname -s)) uname:=$(strip $(shell uname -s))
HOST=UNKNOWN HOSTPLATFORM=UNKNOWN
ifeq ($(findstring Linux,$(uname)),Linux) ifeq ($(findstring Linux,$(uname)),Linux)
HOST=LINUX HOSTPLATFORM=LINUX
endif endif
ifeq ($(findstring BSD,$(uname)),BSD) ifeq ($(findstring BSD,$(uname)),BSD)
HOST=BSD HOSTPLATFORM=BSD
endif endif
ifeq ($(findstring MINGW,$(uname)),MINGW) ifeq ($(findstring MINGW,$(uname)),MINGW)
HOST=WINDOWS HOSTPLATFORM=WINDOWS
endif endif
ifeq ($(findstring Darwin,$(uname)),Darwin) ifeq ($(findstring Darwin,$(uname)),Darwin)
HOST=DARWIN HOSTPLATFORM=DARWIN
endif endif
ifeq ($(findstring BeOS,$(uname)),BeOS) ifeq ($(findstring BeOS,$(uname)),BeOS)
HOST=BEOS HOSTPLATFORM=BEOS
endif endif
ifeq ($(findstring skyos,$(uname)),skyos) ifeq ($(findstring skyos,$(uname)),skyos)
HOST=SKYOS HOSTPLATFORM=SKYOS
endif endif
ifeq ($(findstring QNX,$(uname)),QNX) ifeq ($(findstring QNX,$(uname)),QNX)
HOST=QNX HOSTPLATFORM=QNX
endif endif
ifeq ($(findstring SunOS,$(uname)),SunOS) ifeq ($(findstring SunOS,$(uname)),SunOS)
HOST=SUNOS HOSTPLATFORM=SUNOS
endif endif
ifeq ($(findstring syllable,$(uname)),syllable) ifeq ($(findstring syllable,$(uname)),syllable)
HOST=SYLLABLE HOSTPLATFORM=SYLLABLE
endif endif
endif endif
ifndef PLATFORM ifndef PLATFORM
PLATFORM=$(HOST) PLATFORM=$(HOSTPLATFORM)
endif endif
ifndef SUBPLATFORM ifndef SUBPLATFORM
@ -298,7 +298,7 @@ ifeq (1,$(strip $(shell expr $(GCC_MAJOR) \>= 4)))
W_STRICT_OVERFLOW := -Wno-strict-overflow W_STRICT_OVERFLOW := -Wno-strict-overflow
endif endif
ifeq ($(HOST),WINDOWS) ifeq ($(HOSTPLATFORM),WINDOWS)
# MSYS2 lets you create files named NUL but has a /dev/null. Go figure. # MSYS2 lets you create files named NUL but has a /dev/null. Go figure.
ifeq (,$(wildcard /dev/null)) ifeq (,$(wildcard /dev/null))
DONT_PRINT = > NUL 2>&1 DONT_PRINT = > NUL 2>&1
@ -786,7 +786,7 @@ ifeq ($(PLATFORM),WINDOWS)
COMMONFLAGS += -fno-pic COMMONFLAGS += -fno-pic
endif endif
ifeq ($(PLATFORM),BSD) ifeq ($(PLATFORM),BSD)
COMPILERFLAGS+= -I/usr/X11R6/include COMPILERFLAGS+= -I/usr/local/include
RENDERTYPE=SDL RENDERTYPE=SDL
MIXERTYPE=SDL MIXERTYPE=SDL
@ -995,7 +995,9 @@ endif
ifneq ($(PLATFORM),WINDOWS) ifneq ($(PLATFORM),WINDOWS)
ifneq ($(PLATFORM),WII) ifneq ($(PLATFORM),WII)
ifneq ($(PLATFORM),BSD)
LIBS+= -ldl LIBS+= -ldl
endif
ifneq ($(PLATFORM),DARWIN) ifneq ($(PLATFORM),DARWIN)
LIBS+= -pthread LIBS+= -pthread
endif endif

View file

@ -28,7 +28,7 @@ typedef int64_t inthi_t;
#if !defined(NOASM) && (defined(_MSC_VER) || (defined(__GNUC__) && defined(__i386__))) #if !defined(NOASM) && (defined(_MSC_VER) || (defined(__GNUC__) && defined(__i386__)))
#if defined(__linux) || defined(__APPLE__) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__SYLLABLE__) #if defined __linux || defined __APPLE__ || defined EDUKE32_BSD || defined __SYLLABLE__
#define __cdecl #define __cdecl
#endif #endif

View file

@ -69,7 +69,7 @@
#define max(x,y) ((x) > (y) ? (x) : (y)) #define max(x,y) ((x) > (y) ? (x) : (y))
#endif #endif
#ifndef __APPLE__ #if !defined __APPLE__ && (!defined EDUKE32_BSD || !__STDC__)
# include <malloc.h> # include <malloc.h>
#endif #endif
@ -91,6 +91,10 @@
# endif # endif
#endif #endif
#if defined __FreeBSD__ || defined __NetBSD__ || defined __OpenBSD__ || defined __bsdi__ || defined __DragonFly__
# define EDUKE32_BSD
#endif
#if defined __ANDROID__ || defined EDUKE32_IOS #if defined __ANDROID__ || defined EDUKE32_IOS
# define EDUKE32_TOUCH_DEVICES # define EDUKE32_TOUCH_DEVICES
# define EDUKE32_GLES # define EDUKE32_GLES
@ -264,7 +268,7 @@
# define B_SWAP32(x) __swap32(x) # define B_SWAP32(x) __swap32(x)
# define B_SWAP16(x) __swap16(x) # define B_SWAP16(x) __swap16(x)
#elif defined(__FreeBSD__) || defined(__NetBSD__) #elif defined EDUKE32_BSD
# include <sys/endian.h> # include <sys/endian.h>
# if _BYTE_ORDER == _LITTLE_ENDIAN # if _BYTE_ORDER == _LITTLE_ENDIAN
# define B_LITTLE_ENDIAN 1 # define B_LITTLE_ENDIAN 1
@ -860,7 +864,7 @@ FORCE_INLINE void *xaligned_malloc(const bsize_t alignment, const bsize_t size)
{ {
#ifdef _WIN32 #ifdef _WIN32
void *ptr = _aligned_malloc(size, alignment); void *ptr = _aligned_malloc(size, alignment);
#elif defined __APPLE__ #elif defined __APPLE__ || defined EDUKE32_BSD
void *ptr = NULL; void *ptr = NULL;
posix_memalign(&ptr, alignment, size); posix_memalign(&ptr, alignment, size);
#else #else

View file

@ -156,7 +156,7 @@ void readjoybstatus(int32_t *b)
#if defined _WIN32 #if defined _WIN32
# define WIN32_LEAN_AND_MEAN # define WIN32_LEAN_AND_MEAN
# include <windows.h> # include <windows.h>
#elif defined __linux || defined __FreeBSD__ || defined __NetBSD__ || defined __OpenBSD__ || defined __APPLE__ #elif defined __linux || defined EDUKE32_BSD || defined __APPLE__
# include <sys/mman.h> # include <sys/mman.h>
#endif #endif
@ -181,7 +181,7 @@ int32_t nx_unprotect(intptr_t beg, intptr_t end)
initprintf("VirtualProtect() error! Crashing in 3... 2... 1...\n"); initprintf("VirtualProtect() error! Crashing in 3... 2... 1...\n");
return 1; return 1;
} }
# elif defined __linux || defined __FreeBSD__ || defined __NetBSD__ || defined __OpenBSD__ || defined __APPLE__ # elif defined __linux || defined EDUKE32_BSD || defined __APPLE__
int32_t pagesize; int32_t pagesize;
size_t dep_begin_page; size_t dep_begin_page;
pagesize = sysconf(_SC_PAGE_SIZE); pagesize = sysconf(_SC_PAGE_SIZE);

View file

@ -27,10 +27,11 @@
# include <dirent.h> # include <dirent.h>
#endif #endif
#if defined(__linux) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) #if defined __linux || defined EDUKE32_BSD
# include <libgen.h> // for dirname() # include <libgen.h> // for dirname()
#endif #endif
#if defined(__FreeBSD__) #if defined __FreeBSD__
# include <limits.h> // for PATH_MAX
# include <sys/sysctl.h> // for sysctl() to get path to executable # include <sys/sysctl.h> // for sysctl() to get path to executable
#endif #endif
@ -304,7 +305,19 @@ char *Bgetappdir(void)
#elif defined EDUKE32_OSX #elif defined EDUKE32_OSX
dir = osx_getappdir(); dir = osx_getappdir();
#elif defined(__linux) || defined(__NetBSD__) || defined(__OpenBSD__) #elif defined __FreeBSD__
// the sysctl should also work when /proc/ is not mounted (which seems to
// be common on FreeBSD), so use it..
char buf[PATH_MAX] = {0};
int name[4] = {CTL_KERN, KERN_PROC, KERN_PROC_PATHNAME, -1};
size_t len = sizeof(buf)-1;
int ret = sysctl(name, sizeof(name)/sizeof(name[0]), buf, &len, NULL, 0);
if(ret == 0 && buf[0] != '\0') {
// again, remove executable name with dirname()
// on FreeBSD dirname() seems to use some internal buffer
dir = strdup(dirname(buf));
}
#elif defined __linux || defined EDUKE32_BSD
char buf[PATH_MAX] = {0}; char buf[PATH_MAX] = {0};
char buf2[PATH_MAX] = {0}; char buf2[PATH_MAX] = {0};
# ifdef __linux # ifdef __linux
@ -319,18 +332,6 @@ char *Bgetappdir(void)
// on FreeBSD it seems to use some internal buffer instead.. anyway, just strdup() // on FreeBSD it seems to use some internal buffer instead.. anyway, just strdup()
dir = Bstrdup(dirname(buf2)); dir = Bstrdup(dirname(buf2));
} }
#elif defined(__FreeBSD__)
// the sysctl should also work when /proc/ is not mounted (which seems to
// be common on FreeBSD), so use it..
char buf[PATH_MAX] = {0};
int name[4] = {CTL_KERN, KERN_PROC, KERN_PROC_PATHNAME, -1};
size_t len = sizeof(buf)-1;
int ret = sysctl(name, sizeof(name)/sizeof(name[0]), buf, &len, NULL, 0);
if(ret == 0 && buf[0] != '\0') {
// again, remove executable name with dirname()
// on FreeBSD dirname() seems to use some internal buffer
dir = strdup(dirname(buf));
}
#endif #endif
return dir; return dir;

View file

@ -599,7 +599,7 @@ static void G_LoadAddon(void)
} }
} }
#if defined EDUKE32_OSX || defined __linux__ || defined __FreeBSD__ || defined __NetBSD__ || defined __OpenBSD__ #if defined EDUKE32_OSX || defined __linux__ || defined EDUKE32_BSD
static void G_AddSteamPaths(const char *basepath) static void G_AddSteamPaths(const char *basepath)
{ {
char buf[BMAX_PATH]; char buf[BMAX_PATH];
@ -803,7 +803,7 @@ static void G_ParseSteamKeyValuesForPaths(const char *vdf)
void G_AddSearchPaths(void) void G_AddSearchPaths(void)
{ {
#if defined(__linux__) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) #if defined __linux__ || defined EDUKE32_BSD
char buf[BMAX_PATH]; char buf[BMAX_PATH];
char *homepath = Bgethomedir(); char *homepath = Bgethomedir();