aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCase, Matt <github@mattcase.com>2018-12-20 20:58:56 -0600
committerCase, Matt <github@mattcase.com>2018-12-20 20:58:56 -0600
commitb93a13ec4db4a160d784a5f3260ad2e56ab9e8c7 (patch)
tree66bf59baa9b5cd3556142abea3b017408cda301c
parenta83cc11abe4856a60d92ceba2d65af8236cc3500 (diff)
downloadgoogletest-b93a13ec4db4a160d784a5f3260ad2e56ab9e8c7.tar.gz
googletest-b93a13ec4db4a160d784a5f3260ad2e56ab9e8c7.tar.bz2
googletest-b93a13ec4db4a160d784a5f3260ad2e56ab9e8c7.zip
Improvements have been made to the example/sample makefiles for both googlemock
and googletest. Library files are now created and named like versions produced by Cmake.
-rw-r--r--googlemock/make/Makefile30
-rw-r--r--googletest/make/Makefile18
2 files changed, 35 insertions, 13 deletions
diff --git a/googlemock/make/Makefile b/googlemock/make/Makefile
index 7c13e05f..386293a0 100644
--- a/googlemock/make/Makefile
+++ b/googlemock/make/Makefile
@@ -19,6 +19,9 @@
# a copy of Google Test at a different location.
GTEST_DIR = ../../googletest
+# Points to the location of the Google Test libraries
+GTEST_LIB_DIR = .
+
# Points to the root of Google Mock, relative to where this file is.
# Remember to tweak this if you move this file.
GMOCK_DIR = ..
@@ -33,7 +36,10 @@ USER_DIR = ../test
CPPFLAGS += -isystem $(GTEST_DIR)/include -isystem $(GMOCK_DIR)/include
# Flags passed to the C++ compiler.
-CXXFLAGS += -g -Wall -Wextra -pthread
+CXXFLAGS += -g -Wall -Wextra -pthread -std=c++11
+
+# Google Test libraries
+GTEST_LIBS = libgtest.a libgtest_main.a libgmock.a libgmock_main.a
# All tests produced by this Makefile. Remember to add new tests you
# created to the list.
@@ -53,10 +59,10 @@ GMOCK_HEADERS = $(GMOCK_DIR)/include/gmock/*.h \
# House-keeping build targets.
-all : $(TESTS)
+all : $(GTEST_LIBS) $(TESTS)
clean :
- rm -f $(TESTS) gmock.a gmock_main.a *.o
+ rm -f $(GTEST_LIBS) $(TESTS) *.o
# Builds gmock.a and gmock_main.a. These libraries contain both
# Google Mock and Google Test. A test should link with either gmock.a
@@ -78,6 +84,10 @@ gtest-all.o : $(GTEST_SRCS_)
$(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
-c $(GTEST_DIR)/src/gtest-all.cc
+gtest_main.o : $(GTEST_SRCS_)
+ $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
+ -c $(GTEST_DIR)/src/gtest_main.cc
+
gmock-all.o : $(GMOCK_SRCS_)
$(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
-c $(GMOCK_DIR)/src/gmock-all.cc
@@ -86,10 +96,16 @@ gmock_main.o : $(GMOCK_SRCS_)
$(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
-c $(GMOCK_DIR)/src/gmock_main.cc
-gmock.a : gmock-all.o gtest-all.o
+libgtest.a : gtest-all.o
+ $(AR) $(ARFLAGS) $@ $^
+
+libgtest_main.a : gtest_main.o
+ $(AR) $(ARFLAGS) $@ $^
+
+libgmock.a : gmock-all.o
$(AR) $(ARFLAGS) $@ $^
-gmock_main.a : gmock-all.o gtest-all.o gmock_main.o
+libgmock_main.a : gmock_main.o
$(AR) $(ARFLAGS) $@ $^
# Builds a sample test.
@@ -97,5 +113,5 @@ gmock_main.a : gmock-all.o gtest-all.o gmock_main.o
gmock_test.o : $(USER_DIR)/gmock_test.cc $(GMOCK_HEADERS)
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(USER_DIR)/gmock_test.cc
-gmock_test : gmock_test.o gmock_main.a
- $(CXX) $(CPPFLAGS) $(CXXFLAGS) -lpthread $^ -o $@
+gmock_test : gmock_test.o $(GTEST_LIBS)
+ $(CXX) $(CPPFLAGS) $(CXXFLAGS) -L$(GTEST_LIB_DIR) -lgmock -lpthread $^ -o $@
diff --git a/googletest/make/Makefile b/googletest/make/Makefile
index 91eb68b5..b62da67a 100644
--- a/googletest/make/Makefile
+++ b/googletest/make/Makefile
@@ -16,6 +16,9 @@
# Remember to tweak this if you move this file.
GTEST_DIR = ..
+# Points to the location of the Google Test libraries
+GTEST_LIB_DIR = .
+
# Where to find user code.
USER_DIR = ../samples
@@ -27,6 +30,9 @@ CPPFLAGS += -isystem $(GTEST_DIR)/include
# Flags passed to the C++ compiler.
CXXFLAGS += -g -Wall -Wextra -pthread -std=c++11
+# Google Test libraries
+GTEST_LIBS = libgtest.a libgtest_main.a
+
# All tests produced by this Makefile. Remember to add new tests you
# created to the list.
TESTS = sample1_unittest
@@ -38,10 +44,10 @@ GTEST_HEADERS = $(GTEST_DIR)/include/gtest/*.h \
# House-keeping build targets.
-all : $(TESTS)
+all : $(GTEST_LIBS) $(TESTS)
clean :
- rm -f $(TESTS) gtest.a gtest_main.a *.o
+ rm -f $(GTEST_LIBS) $(TESTS) *.o
# Builds gtest.a and gtest_main.a.
@@ -61,10 +67,10 @@ gtest_main.o : $(GTEST_SRCS_)
$(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) -c \
$(GTEST_DIR)/src/gtest_main.cc
-gtest.a : gtest-all.o
+libgtest.a : gtest-all.o
$(AR) $(ARFLAGS) $@ $^
-gtest_main.a : gtest-all.o gtest_main.o
+libgtest_main.a : gtest-all.o gtest_main.o
$(AR) $(ARFLAGS) $@ $^
# Builds a sample test. A test should link with either gtest.a or
@@ -78,5 +84,5 @@ sample1_unittest.o : $(USER_DIR)/sample1_unittest.cc \
$(USER_DIR)/sample1.h $(GTEST_HEADERS)
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(USER_DIR)/sample1_unittest.cc
-sample1_unittest : sample1.o sample1_unittest.o gtest_main.a
- $(CXX) $(CPPFLAGS) $(CXXFLAGS) -lpthread $^ -o $@
+sample1_unittest : sample1.o sample1_unittest.o $(GTEST_LIBS)
+ $(CXX) $(CPPFLAGS) $(CXXFLAGS) -L$(GTEST_LIB_DIR) -lgtest_main -lpthread $^ -o $@