Fix makefiles to build shared library tests on Windows.
authorZachary Turner <zturner@google.com>
Fri, 13 Mar 2015 21:51:11 +0000 (21:51 +0000)
committerZachary Turner <zturner@google.com>
Fri, 13 Mar 2015 21:51:11 +0000 (21:51 +0000)
Abstracted away some POSIX-isms that caused MAKE to issue invalid
commands on Windows.  Added a new force-include for the test
programs so that we can use platform-specific macros.

TestSharedLib now builds and cleans up on Windows, though the test
still fails some of the expectations.

Differential Revision: http://reviews.llvm.org/D8277
Patch by: Adrian McCarthy
Issue Tracker: http://llvm.org/pr21727

llvm-svn: 232220

lldb/test/lang/c/shared_lib/foo.h
lldb/test/lldbtest.py
lldb/test/make/Makefile.rules
lldb/test/make/test_common.h [new file with mode: 0644]
lldb/test/make/uncaught_exception.h [deleted file]
lldb/test/plugins/builder_base.py

index 78b3c12..78b9e3f 100644 (file)
@@ -6,7 +6,5 @@ struct sub_foo
   char *sub_2;
 };
 
-struct foo *GetMeAFoo();
-struct sub_foo *GetMeASubFoo (struct foo *in_foo);
-
-
+LLDB_TEST_API struct foo *GetMeAFoo();
+LLDB_TEST_API struct sub_foo *GetMeASubFoo(struct foo *in_foo);
index 714df94..71fb031 100644 (file)
@@ -1509,7 +1509,7 @@ class Base(unittest2.TestCase):
                  'FRAMEWORK_INCLUDES' : "-F%s" % self.lib_dir,
                  'LD_EXTRAS' : "%s -Wl,-rpath,%s -dynamiclib" % (dsym, self.lib_dir),
                 }
-        elif sys.platform.startswith('freebsd') or sys.platform.startswith("linux") or os.environ.get('LLDB_BUILD_TYPE') == 'Makefile':
+        elif sys.platform.startswith('freebsd') or sys.platform.startswith("linux") or sys.platform.startswith("win") or os.environ.get('LLDB_BUILD_TYPE') == 'Makefile':
             d = {'DYLIB_CXX_SOURCES' : sources,
                  'DYLIB_NAME' : lib_name,
                  'CFLAGS_EXTRAS' : "%s -I%s -fPIC" % (stdflag, os.path.join(os.environ["LLDB_SRC"], "include")),
index c0356c9..886698a 100644 (file)
@@ -118,6 +118,7 @@ endif
 
 CFLAGS ?= -g -O0
 CFLAGS += $(ARCHFLAG)$(ARCH) $(FRAMEWORK_INCLUDES) $(CFLAGS_EXTRAS) -I$(LLDB_BASE_DIR)include
+CFLAGS += -include $(THIS_FILE_DIR)test_common.h
 
 # Use this one if you want to build one part of the result without debug information:
 CFLAGS_NO_DEBUG = -O0 $(ARCHFLAG)$(ARCH) $(FRAMEWORK_INCLUDES) $(CFLAGS_EXTRAS)
@@ -152,6 +153,8 @@ EXE ?= a.out
 ifneq "$(DYLIB_NAME)" ""
        ifeq "$(OS)" "Darwin"
                DYLIB_FILENAME = lib$(DYLIB_NAME).dylib
+  else ifeq "$(OS)" "Windows_NT"
+    DYLIB_FILENAME = $(DYLIB_NAME).dll
        else
                DYLIB_FILENAME = lib$(DYLIB_NAME).so
        endif
@@ -188,7 +191,6 @@ ifeq "$(OS)" "Windows_NT"
        ifneq (,$(findstring clang,$(CC)))
                # Clang for Windows doesn't support C++ Exceptions
                CXXFLAGS += -fno-exceptions
-               CXXFLAGS += -include $(THIS_FILE_DIR)uncaught_exception.h
                CXXFLAGS += -D_HAS_EXCEPTIONS=0
                # The MSVC linker doesn't understand long section names
                # generated by the clang compiler.
@@ -377,6 +379,8 @@ endif
 #----------------------------------------------------------------------
 # Make the dylib
 #----------------------------------------------------------------------
+$(DYLIB_OBJECTS) : CFLAGS += -DCOMPILING_LLDB_TEST_DLL
+
 $(DYLIB_FILENAME) : $(DYLIB_OBJECTS)
 ifeq "$(OS)" "Darwin"
        $(LD) $(LDFLAGS) $(DYLIB_OBJECTS) -install_name "@executable_path/$(DYLIB_FILENAME)" -dynamiclib -o "$(DYLIB_FILENAME)"
@@ -395,7 +399,7 @@ endif
 
 #----------------------------------------------------------------------
 # Automatic variables based on items already entered. Below we create
-# an objects lists from the list of sources by replacing all entries
+# an object's lists from the list of sources by replacing all entries
 # that end with .c with .o, and we also create a list of prerequisite
 # files by replacing all .c files with .d.
 #----------------------------------------------------------------------
@@ -409,28 +413,36 @@ endif
 # the compiler -MM option. The -M option will list all system headers,
 # and the -MM option will list all non-system dependencies.
 #----------------------------------------------------------------------
+ifeq "$(OS)" "Windows_NT"
+       JOIN_CMD = &
+       QUOTE = "
+else
+       JOIN_CMD = ;
+       QUOTE = '
+endif
+
 %.d: %.c
-       @rm -f $@; \
+       @rm -f $@ $(JOIN_CMD) \
        $(CC) -M $(CFLAGS) $< > $@.tmp && \
-       sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.tmp > $@; \
+       sed $(QUOTE)s,\($*\)\.o[ :]*,\1.o $@ : ,g$(QUOTE) < $@.tmp > $@ $(JOIN_CMD) \
        rm -f $@.tmp
 
 %.d: %.cpp
-       @rm -f $@; \
+       @rm -f $@ $(JOIN_CMD) \
        $(CXX) -M $(CXXFLAGS) $< > $@.tmp && \
-       sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.tmp > $@; \
+       sed $(QUOTE)s,\($*\)\.o[ :]*,\1.o $@ : ,g$(QUOTE) < $@.tmp > $@ $(JOIN_CMD) \
        rm -f $@.tmp
 
 %.d: %.m
-       @rm -f $@; \
+       @rm -f $@ $(JOIN_CMD) \
        $(CC) -M $(CFLAGS) $< > $@.tmp && \
-       sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.tmp > $@; \
+       sed $(QUOTE)s,\($*\)\.o[ :]*,\1.o $@ : ,g$(QUOTE) < $@.tmp > $@ $(JOIN_CMD) \
        rm -f $@.tmp
 
 %.d: %.mm
-       @rm -f $@; \
+       @rm -f $@ $(JOIN_CMD) \
        $(CXX) -M $(CXXFLAGS) $< > $@.tmp && \
-       sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.tmp > $@; \
+       sed $(QUOTE)s,\($*\)\.o[ :]*,\1.o $@ : ,g$(QUOTE) < $@.tmp > $@ $(JOIN_CMD) \
        rm -f $@.tmp
 
 #----------------------------------------------------------------------
@@ -461,6 +473,10 @@ ifneq "$(DSYM)" ""
 endif
 ifeq "$(OS)" "Windows_NT"
        $(RM) "$(EXE).manifest" $(wildcard *.pdb *.ilk)
+  ifneq "$(DYLIB_NAME)" ""
+         $(RM) $(DYLIB_FILENAME).manifest
+         $(RM) $(DYLIB_NAME).lib $(DYLIB_NAME).exp
+  endif
 endif
 
 #----------------------------------------------------------------------
diff --git a/lldb/test/make/test_common.h b/lldb/test/make/test_common.h
new file mode 100644 (file)
index 0000000..6f81970
--- /dev/null
@@ -0,0 +1,19 @@
+// This header is included in all the test programs (C and C++) and provides a\r
+// hook for dealing with platform-specifics.\r
+#if defined(_WIN32) || defined(_WIN64)\r
+#ifdef COMPILING_LLDB_TEST_DLL\r
+#define LLDB_TEST_API __declspec(dllexport)\r
+#else\r
+#define LLDB_TEST_API __declspec(dllimport)\r
+#endif\r
+#else\r
+#define LLDB_TEST_API\r
+#endif\r
+\r
+#if defined(__cplusplus) && defined(_MSC_VER) && (_HAS_EXCEPTIONS == 0)\r
+// Compiling MSVC libraries with _HAS_EXCEPTIONS=0, eliminates most but not all\r
+// calls to __uncaught_exception.  Unfortunately, it does seem to eliminate\r
+// the delcaration of __uncaught_excpeiton.  Including <eh.h> ensures that it is\r
+// declared.  This may not be necessary after MSVC 12.\r
+#include <eh.h>\r
+#endif\r
diff --git a/lldb/test/make/uncaught_exception.h b/lldb/test/make/uncaught_exception.h
deleted file mode 100644 (file)
index 2d5d964..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-// MSVC header files have compilation issues when compiling with exceptions disabled.  Notably,
-// this function is compiled out when _HAS_EXCEPTIONS=0, but this function is called from another
-// place even when _HAS_EXCEPTIONS=0.  So we define a dummy implementation as a workaround and
-// force include this header file.
-static void *__uncaught_exception() { return nullptr; }
index 0ecce3d..2658927 100644 (file)
@@ -12,7 +12,7 @@ Same idea holds for LLDB_ARCH environment variable, which maps to the ARCH make
 variable.
 """
 
-import os
+import os, sys
 import platform
 import lldbtest
 
@@ -78,8 +78,8 @@ def getCmdLine(d):
     # If d is None or an empty mapping, just return an empty string.
     if not d:
         return ""
-
-    cmdline = " ".join(["%s='%s'" % (k, v) for k, v in d.items()])
+    pattern = '%s="%s"' if "win32" in sys.platform else "%s='%s'"
+    cmdline = " ".join([pattern % (k, v) for k, v in d.items()])
 
     return cmdline