Merge branch 'crashlog_improvements' into jgrpp
This commit is contained in:
		
							
								
								
									
										93
									
								
								config.lib
									
									
									
									
									
								
							
							
						
						
									
										93
									
								
								config.lib
									
									
									
									
									
								
							@@ -1442,6 +1442,34 @@ make_compiler_cflags() {
 | 
			
		||||
	eval "$5=\"$features\""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
test_compile_libbfd() {
 | 
			
		||||
	log 2 "executing $cc_host $CFLAGS $LDFLAGS -o tmp.config.bfd -x c++ - $1"
 | 
			
		||||
	"$cc_host" $CFLAGS $LDFLAGS -o tmp.config.bfd -x c++ - $1 2> /dev/null << EOL
 | 
			
		||||
		#define PACKAGE 1
 | 
			
		||||
		#define PACKAGE_VERSION 1
 | 
			
		||||
		#include <bfd.h>
 | 
			
		||||
		#include <unistd.h>
 | 
			
		||||
		int main() {
 | 
			
		||||
			bfd_init();
 | 
			
		||||
			bfd *abfd = bfd_openr("test", "test");
 | 
			
		||||
			bfd_check_format(abfd, bfd_object);
 | 
			
		||||
			bfd_get_file_flags(abfd);
 | 
			
		||||
			bfd_map_over_sections(abfd, (void (*)(bfd*, asection*, void*)) 0, (void *) 0);
 | 
			
		||||
			asymbol *syms = 0;
 | 
			
		||||
			long symcount = bfd_read_minisymbols(abfd, false, (void**) &syms, (unsigned int *) 0);
 | 
			
		||||
			bfd_get_section_flags(abfd, (asection*) 0);
 | 
			
		||||
			bfd_get_section_vma(abfd, (asection*) 0);
 | 
			
		||||
			bfd_section_size(abfd, (asection*) 0);
 | 
			
		||||
			bfd_find_nearest_line(abfd, (asection*) 0, (asymbol **) 0, (bfd_vma) 0, (const char **) 0, (const char **) 0, (unsigned int *) 0);
 | 
			
		||||
			return (int) symcount;
 | 
			
		||||
		}
 | 
			
		||||
EOL
 | 
			
		||||
	ret=$?
 | 
			
		||||
	rm -f tmp.config.bfd
 | 
			
		||||
	log 2 "  exit code $ret"
 | 
			
		||||
	return $ret
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
make_cflags_and_ldflags() {
 | 
			
		||||
	# General CFlags for BUILD
 | 
			
		||||
	CFLAGS_BUILD="$CFLAGS_BUILD"
 | 
			
		||||
@@ -1567,6 +1595,7 @@ make_cflags_and_ldflags() {
 | 
			
		||||
		LIBS="$LIBS -lpthread"
 | 
			
		||||
	fi
 | 
			
		||||
	if [ "$os" != "CYGWIN" ] && [ "$os" != "HAIKU" ] && [ "$os" != "MINGW" ] && [ "$os" != "MORPHOS" ] && [ "$os" != "OSX" ] && [ "$os" != "DOS" ] && [ "$os" != "WINCE" ] && [ "$os" != "PSP" ] && [ "$os" != "OS2" ]; then
 | 
			
		||||
		log 2 "executing $cc_host $CFLAGS $LDFLAGS -o tmp.config.libdl -x c++ - -ldl"
 | 
			
		||||
		"$cc_host" $CFLAGS $LDFLAGS -o tmp.config.libdl -x c++ - -ldl 2> /dev/null << EOL
 | 
			
		||||
			#include <dlfcn.h>
 | 
			
		||||
			int main() {
 | 
			
		||||
@@ -1574,43 +1603,42 @@ make_cflags_and_ldflags() {
 | 
			
		||||
				return dladdr(0, &info);
 | 
			
		||||
			}
 | 
			
		||||
EOL
 | 
			
		||||
		if [ $? -ne 0 ]; then
 | 
			
		||||
		ret=$?
 | 
			
		||||
		rm -f tmp.config.libdl
 | 
			
		||||
		log 2 "  exit code $ret"
 | 
			
		||||
		if [ $ret -ne 0 ]; then
 | 
			
		||||
			log 1 "checking libdl... no"
 | 
			
		||||
		else
 | 
			
		||||
			log 1 "checking libdl... found"
 | 
			
		||||
			LIBS="$LIBS -ldl"
 | 
			
		||||
			CFLAGS="$CFLAGS -DWITH_DL"
 | 
			
		||||
		fi
 | 
			
		||||
		rm -f tmp.config.libdl
 | 
			
		||||
 | 
			
		||||
		if [ "$with_libbfd" = "1" ]; then
 | 
			
		||||
			"$cc_host" $CFLAGS $LDFLAGS -o tmp.config.bfd -x c++ - -lbfd 2> /dev/null << EOL
 | 
			
		||||
				#define PACKAGE 1
 | 
			
		||||
				#define PACKAGE_VERSION 1
 | 
			
		||||
				#include <bfd.h>
 | 
			
		||||
				int main() {
 | 
			
		||||
					bfd_init();
 | 
			
		||||
					unsigned int size;
 | 
			
		||||
					asymbol *syms = 0;
 | 
			
		||||
					long symcount = bfd_read_minisymbols((bfd *) 0, false, (void**) &syms, &size);
 | 
			
		||||
					return 0;
 | 
			
		||||
				}
 | 
			
		||||
EOL
 | 
			
		||||
			if [ $? -ne 0 ]; then
 | 
			
		||||
				log 1 "checking libbfd... no"
 | 
			
		||||
			if test_compile_libbfd "-lbfd -lz"; then
 | 
			
		||||
				LIBBFD_LIBS="-lbfd -lz"
 | 
			
		||||
			elif test_compile_libbfd "-lbfd -liberty -lz"; then
 | 
			
		||||
				LIBBFD_LIBS="-lbfd -liberty -lz"
 | 
			
		||||
			elif test_compile_libbfd "-lbfd -liberty -lintl -lz"; then
 | 
			
		||||
				LIBBFD_LIBS="-lbfd -liberty -lintl -lz"
 | 
			
		||||
			else
 | 
			
		||||
				LIBBFD_LIBS=
 | 
			
		||||
			fi
 | 
			
		||||
			if [ -n "$LIBBFD_LIBS" ]; then
 | 
			
		||||
				log 1 "checking libbfd... found"
 | 
			
		||||
				LIBS="$LIBS -lbfd"
 | 
			
		||||
				LIBS="$LIBS $LIBBFD_LIBS"
 | 
			
		||||
				CFLAGS="$CFLAGS -DWITH_BFD"
 | 
			
		||||
				if [ $enable_debug -lt 1 ] && [ "$with_bfd_extra_debug" = "1" ]; then
 | 
			
		||||
					CFLAGS="$CFLAGS -g1"
 | 
			
		||||
				fi
 | 
			
		||||
			else
 | 
			
		||||
				log 1 "checking libbfd... no"
 | 
			
		||||
			fi
 | 
			
		||||
			rm -f tmp.config.bfd
 | 
			
		||||
		fi
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	if [ "$os" = "MINGW" ]; then
 | 
			
		||||
		log 2 "executing $cc_host $CFLAGS $LDFLAGS -o tmp.config.dbghelp -x c++ -"
 | 
			
		||||
		"$cc_host" $CFLAGS $LDFLAGS -o tmp.config.dbghelp -x c++ - 2> /dev/null << EOL
 | 
			
		||||
			#include <windows.h>
 | 
			
		||||
			#include <dbghelp.h>
 | 
			
		||||
@@ -1622,43 +1650,34 @@ EOL
 | 
			
		||||
				return 0;
 | 
			
		||||
			}
 | 
			
		||||
EOL
 | 
			
		||||
		if [ $? -ne 0 ]; then
 | 
			
		||||
		ret=$?
 | 
			
		||||
		rm -f tmp.config.dbghelp
 | 
			
		||||
		log 2 "  exit code $ret"
 | 
			
		||||
		if [ $ret -ne 0 ]; then
 | 
			
		||||
			log 1 "checking dbghelp... no"
 | 
			
		||||
		else
 | 
			
		||||
			log 1 "checking dbghelp... found"
 | 
			
		||||
			CFLAGS="$CFLAGS -DWITH_DBGHELP"
 | 
			
		||||
 | 
			
		||||
			if [ "$with_libbfd" = "1" ]; then
 | 
			
		||||
				"$cc_host" $CFLAGS $LDFLAGS -o tmp.config.bfd -x c++ - -lbfd -liberty -lintl 2> /dev/null << EOL
 | 
			
		||||
					#define PACKAGE 1
 | 
			
		||||
					#define PACKAGE_VERSION 1
 | 
			
		||||
					#include <bfd.h>
 | 
			
		||||
					int main() {
 | 
			
		||||
						bfd_init();
 | 
			
		||||
						unsigned int size;
 | 
			
		||||
						asymbol *syms = 0;
 | 
			
		||||
						long symcount = bfd_read_minisymbols((bfd *) 0, false, (void**) &syms, &size);
 | 
			
		||||
						return 0;
 | 
			
		||||
					}
 | 
			
		||||
EOL
 | 
			
		||||
				test_compile_libbfd "-lbfd -liberty -lintl -lz"
 | 
			
		||||
				if [ $? -ne 0 ]; then
 | 
			
		||||
					log 1 "checking libbfd... no"
 | 
			
		||||
				else
 | 
			
		||||
					log 1 "checking libbfd... found"
 | 
			
		||||
					LIBS="$LIBS -lbfd -liberty -lintl"
 | 
			
		||||
					LIBS="$LIBS -lbfd -liberty -lintl -lz"
 | 
			
		||||
					CFLAGS="$CFLAGS -DWITH_BFD"
 | 
			
		||||
 | 
			
		||||
					if [ $enable_debug -lt 1 ] && [ "$with_bfd_extra_debug" = "1" ]; then
 | 
			
		||||
						CFLAGS="$CFLAGS -g1"
 | 
			
		||||
					fi
 | 
			
		||||
				fi
 | 
			
		||||
				rm -f tmp.config.bfd
 | 
			
		||||
			fi
 | 
			
		||||
		fi
 | 
			
		||||
		rm -f tmp.config.dbghelp
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	if [ "$os" != "CYGWIN" ] && [ "$os" != "HAIKU" ] && [ "$os" != "MORPHOS" ] && [ "$os" != "OSX" ] && [ "$os" != "DOS" ] && [ "$os" != "WINCE" ] && [ "$os" != "PSP" ] && [ "$os" != "OS2" ]; then
 | 
			
		||||
		log 2 "executing $cc_host $CFLAGS $LDFLAGS -o tmp.config.demangle -x c++ - -lstdc++"
 | 
			
		||||
		"$cc_host" $CFLAGS $LDFLAGS -o tmp.config.demangle -x c++ - -lstdc++ 2> /dev/null << EOL
 | 
			
		||||
			#include <cxxabi.h>
 | 
			
		||||
			int main() {
 | 
			
		||||
@@ -1667,13 +1686,15 @@ EOL
 | 
			
		||||
				return 0;
 | 
			
		||||
			}
 | 
			
		||||
EOL
 | 
			
		||||
		if [ $? -ne 0 ]; then
 | 
			
		||||
		ret=$?
 | 
			
		||||
		rm -f tmp.config.demangle
 | 
			
		||||
		log 2 "  exit code $ret"
 | 
			
		||||
		if [ $ret -ne 0 ]; then
 | 
			
		||||
			log 1 "checking abi::__cxa_demangle... no"
 | 
			
		||||
		else
 | 
			
		||||
			log 1 "checking abi::__cxa_demangle... found"
 | 
			
		||||
			CFLAGS="$CFLAGS -DWITH_DEMANGLE"
 | 
			
		||||
		fi
 | 
			
		||||
		rm -f tmp.config.demangle
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	if [ "$os" != "CYGWIN" ] && [ "$os" != "HAIKU" ] && [ "$os" != "MINGW" ] && [ "$os" != "DOS" ] && [ "$os" != "WINCE" ]; then
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user