From fb21f3cca06e9ff367795ed47e6bb93a9cfcfcba Mon Sep 17 00:00:00 2001
From: Photonios
Date: Fri, 22 Nov 2013 17:31:07 +0100
Subject: [PATCH 01/94] Added Git ignore file to prevent build files being seen
as changed files
---
.gitignore | 6 ++++++
1 file changed, 6 insertions(+)
create mode 100644 .gitignore
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..6b65910
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,6 @@
+Debug
+ipch
+*.vcxproj.user
+*.opensdf
+*.sdf
+*.suo
\ No newline at end of file
From d0882077b352991124f398280395a5bc2e6d3faa Mon Sep 17 00:00:00 2001
From: Photonios
Date: Fri, 22 Nov 2013 17:32:40 +0100
Subject: [PATCH 02/94] Added configuration options for x64 to vs2010
solution/project file
---
gflags-vs2010.sln | 14 ++-
.../gflags_unittest-vs2010.vcxproj | 73 ++++++++++++++++
vsprojects/libgflags/libgflags-vs2010.vcxproj | 87 +++++++++++++++++++
3 files changed, 172 insertions(+), 2 deletions(-)
diff --git a/gflags-vs2010.sln b/gflags-vs2010.sln
index 5c34be4..f195d66 100644
--- a/gflags-vs2010.sln
+++ b/gflags-vs2010.sln
@@ -1,23 +1,33 @@
Microsoft Visual Studio Solution File, Format Version 11.00
# Visual Studio 2010
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libgflags", "vsprojects\libgflags\libgflags-vs2010.vcxproj", "{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}"
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libgflags-vs2010", "vsprojects\libgflags\libgflags-vs2010.vcxproj", "{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}"
EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gflags_unittest", "vsprojects\gflags_unittest\gflags_unittest-vs2010.vcxproj", "{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}"
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gflags_unittest-vs2010", "vsprojects\gflags_unittest\gflags_unittest-vs2010.vcxproj", "{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Win32 = Debug|Win32
+ Debug|x64 = Debug|x64
Release|Win32 = Release|Win32
+ Release|x64 = Release|x64
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Debug|Win32.ActiveCfg = Debug|Win32
{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Debug|Win32.Build.0 = Debug|Win32
+ {FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Debug|x64.ActiveCfg = Debug|x64
+ {FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Debug|x64.Build.0 = Debug|x64
{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Release|Win32.ActiveCfg = Release|Win32
{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Release|Win32.Build.0 = Release|Win32
+ {FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Release|x64.ActiveCfg = Release|x64
+ {FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}.Release|x64.Build.0 = Release|x64
{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Debug|Win32.ActiveCfg = Debug|Win32
{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Debug|Win32.Build.0 = Debug|Win32
+ {4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Debug|x64.ActiveCfg = Debug|x64
+ {4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Debug|x64.Build.0 = Debug|x64
{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Release|Win32.ActiveCfg = Release|Win32
{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Release|Win32.Build.0 = Release|Win32
+ {4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Release|x64.ActiveCfg = Release|x64
+ {4B263748-5F0F-468C-8C5C-ED2682BB6BE3}.Release|x64.Build.0 = Release|x64
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
diff --git a/vsprojects/gflags_unittest/gflags_unittest-vs2010.vcxproj b/vsprojects/gflags_unittest/gflags_unittest-vs2010.vcxproj
index 77bd3f5..6624350 100644
--- a/vsprojects/gflags_unittest/gflags_unittest-vs2010.vcxproj
+++ b/vsprojects/gflags_unittest/gflags_unittest-vs2010.vcxproj
@@ -5,10 +5,18 @@
DebugWin32
+
+ Debug
+ x64
+ ReleaseWin32
+
+ Release
+ x64
+ {4B263748-5F0F-468C-8C5C-ED2682BB6BE3}
@@ -19,34 +27,60 @@
ApplicationMultiByte
+
+ Application
+ MultiByte
+ ApplicationMultiByte
+
+ Application
+ MultiByte
+
+
+
+
+
+
+
<_ProjectFileVersion>10.0.30319.1
$(SolutionDir)$(Configuration)\
+ $(SolutionDir)$(Configuration)\$(Configuration)\
+ $(Configuration)\true
+ true$(SolutionDir)$(Configuration)\
+ $(SolutionDir)$(Configuration)\$(Configuration)\
+ $(Configuration)\false
+ falseAllRules.ruleset
+ AllRules.ruleset
+
+ AllRules.ruleset
+ AllRules.ruleset
+
+
@@ -68,6 +102,24 @@
MachineX86
+
+
+ Disabled
+ WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ EnableFastChecks
+ MultiThreadedDebug
+
+
+ Level3
+ ProgramDatabase
+
+
+ $(OutDir)gflags_unittest.exe
+ true
+ $(OutDir)gflags_unittest.pdb
+ Console
+
+ WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
@@ -86,12 +138,33 @@
MachineX86
+
+
+ WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ MultiThreaded
+
+
+ Level3
+ ProgramDatabase
+
+
+ $(OutDir)gflags_unittest.exe
+ true
+ Console
+ true
+ true
+
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDebugDLL
+ MultiThreadedDebugDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDLL
+ MultiThreadedDLL
diff --git a/vsprojects/libgflags/libgflags-vs2010.vcxproj b/vsprojects/libgflags/libgflags-vs2010.vcxproj
index 7b9d36c..2e9f397 100644
--- a/vsprojects/libgflags/libgflags-vs2010.vcxproj
+++ b/vsprojects/libgflags/libgflags-vs2010.vcxproj
@@ -5,10 +5,18 @@
DebugWin32
+
+ Debug
+ x64
+ ReleaseWin32
+
+ Release
+ x64
+ {FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}
@@ -20,34 +28,60 @@
DynamicLibraryMultiByte
+
+ DynamicLibrary
+ MultiByte
+ DynamicLibraryMultiByte
+
+ DynamicLibrary
+ MultiByte
+
+
+
+
+
+
+
<_ProjectFileVersion>10.0.30319.1
$(SolutionDir)$(Configuration)\
+ $(SolutionDir)$(Configuration)\$(Configuration)\
+ $(Configuration)\true
+ true$(SolutionDir)$(Configuration)\
+ $(SolutionDir)$(Configuration)\$(Configuration)\
+ $(Configuration)\false
+ falseAllRules.ruleset
+ AllRules.ruleset
+
+ AllRules.ruleset
+ AllRules.ruleset
+
+
@@ -70,6 +104,25 @@
MachineX86
+
+
+ Disabled
+ WIN32;_DEBUG;_WINDOWS;_USRDLL;LIBGFLAGS_EXPORTS;%(PreprocessorDefinitions)
+ EnableFastChecks
+ MultiThreadedDebug
+
+
+ Level3
+ ProgramDatabase
+
+
+ $(OutDir)libgflags-debug.dll
+ true
+ $(OutDir)libgflags-debug.pdb
+ Windows
+ $(OutDir)libgflags-debug.lib
+
+ WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBGFLAGS_EXPORTS;%(PreprocessorDefinitions)
@@ -89,30 +142,64 @@
MachineX86
+
+
+ WIN32;NDEBUG;_WINDOWS;_USRDLL;LIBGFLAGS_EXPORTS;%(PreprocessorDefinitions)
+ MultiThreaded
+
+
+ Level3
+ ProgramDatabase
+
+
+ $(OutDir)libgflags.dll
+ true
+ Windows
+ true
+ true
+ $(OutDir)libgflags.lib
+
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDebugDLL
+ MultiThreadedDebugDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDLL
+ MultiThreadedDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDebugDLL
+ MultiThreadedDebugDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDLL
+ MultiThreadedDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDebugDLL
+ MultiThreadedDebugDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDLL
+ MultiThreadedDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDebugDLL
+ MultiThreadedDebugDLL..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)
+ ..\..\src\windows; ..\..\src;%(AdditionalIncludeDirectories)MultiThreadedDLL
+ MultiThreadedDLL
From 2bd1aeeeb7829c232d5bb7a0ed94a82767f3b5a6 Mon Sep 17 00:00:00 2001
From: Swen Kooij
Date: Wed, 27 Nov 2013 18:04:40 +0100
Subject: [PATCH 03/94] Renamed projects in VS2012 solution file to match the
filename
---
gflags-vs2012.sln | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/gflags-vs2012.sln b/gflags-vs2012.sln
index dea7012..eb15d17 100644
--- a/gflags-vs2012.sln
+++ b/gflags-vs2012.sln
@@ -1,8 +1,8 @@
Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Express 2012 for Windows Desktop
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libgflags", "vsprojects\libgflags\libgflags-vs2012.vcxproj", "{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}"
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libgflags-vs2012", "vsprojects\libgflags\libgflags-vs2012.vcxproj", "{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}"
EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gflags_unittest", "vsprojects\gflags_unittest\gflags_unittest-vs2012.vcxproj", "{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}"
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gflags_unittest-vs2012", "vsprojects\gflags_unittest\gflags_unittest-vs2012.vcxproj", "{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
From 38b662ab07be9a32dd1d0c644b8ac2ae591bb0a4 Mon Sep 17 00:00:00 2001
From: Swen Kooij
Date: Wed, 27 Nov 2013 18:05:06 +0100
Subject: [PATCH 04/94] Renamed projects in VS2003 solution file to match the
filename
---
gflags-vs2003.sln | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/gflags-vs2003.sln b/gflags-vs2003.sln
index ec25b09..bff7f6d 100644
--- a/gflags-vs2003.sln
+++ b/gflags-vs2003.sln
@@ -1,9 +1,9 @@
Microsoft Visual Studio Solution File, Format Version 8.00
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libgflags", "vsprojects\libgflags\libgflags-vs2003.vcproj", "{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}"
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libgflags-vs2003", "vsprojects\libgflags\libgflags-vs2003.vcproj", "{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}"
ProjectSection(ProjectDependencies) = postProject
EndProjectSection
EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gflags_unittest", "vsprojects\gflags_unittest\gflags_unittest-vs2003.vcproj", "{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}"
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gflags_unittest-vs2003", "vsprojects\gflags_unittest\gflags_unittest-vs2003.vcproj", "{4B263748-5F0F-468C-8C5C-ED2682BB6BE3}"
ProjectSection(ProjectDependencies) = postProject
{FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC} = {FB27FBDB-E6C0-4D00-A7F8-1EEEF1B48ABC}
EndProjectSection
From 41181669d15b8630e63a449388401d16fc1c2741 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Wed, 19 Mar 2014 16:46:56 +0000
Subject: [PATCH 05/94] Use OS_WINDOWS #define instead of _WIN32 and WINDOWS.
The OS_WINDOWS #define has previously been used in gflags.cc before the CMake migration.
---
CMakeLists.txt | 10 +++++-----
src/config.h.in | 7 +++++--
src/gflags.cc | 2 +-
src/mutex.h | 4 ++--
src/util.h | 2 +-
src/windows_port.h | 2 +-
6 files changed, 15 insertions(+), 12 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index acb8b44..ae24799 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -1,9 +1,9 @@
cmake_minimum_required(VERSION 2.8.4 FATAL_ERROR)
if (WIN32 AND NOT CYGWIN)
- set (WINDOWS 1)
+ set (OS_WINDOWS 1)
else ()
- set (WINDOWS 0)
+ set (OS_WINDOWS 0)
endif ()
# ----------------------------------------------------------------------------
@@ -34,7 +34,7 @@ version_numbers (
# configure options
option (BUILD_SHARED_LIBS "Request build of shared libraries." OFF)
-if (WINDOWS AND BUILD_SHARED_LIBS)
+if (OS_WINDOWS AND BUILD_SHARED_LIBS)
set (GFLAGS_IS_A_DLL 1)
else ()
set (GFLAGS_IS_A_DLL 0)
@@ -184,7 +184,7 @@ set (GFLAGS_SRCS
"gflags_completions.cc"
)
-if (WINDOWS)
+if (OS_WINDOWS)
list (APPEND PRIVATE_HDRS "windows_port.h")
list (APPEND GFLAGS_SRCS "windows_port.cc")
endif ()
@@ -226,7 +226,7 @@ endif ()
# ----------------------------------------------------------------------------
# installation
-if (WINDOWS)
+if (OS_WINDOWS)
set (RUNTIME_INSTALL_DIR Bin)
set (LIBRARY_INSTALL_DIR Lib)
set (INCLUDE_INSTALL_DIR Include)
diff --git a/src/config.h.in b/src/config.h.in
index 24b513e..3f94663 100644
--- a/src/config.h.in
+++ b/src/config.h.in
@@ -5,6 +5,9 @@
// ---------------------------------------------------------------------------
// System checks
+// Define if you build this library for a MS Windows OS.
+#cmakedefine OS_WINDOWS
+
// Define if you have the header file.
#cmakedefine HAVE_STDINT_H
@@ -73,7 +76,7 @@
// ---------------------------------------------------------------------------
// Path separator
#ifndef PATH_SEPARATOR
-# if _WIN32
+# ifdef OS_WINDOWS
# define PATH_SEPARATOR '\\'
# else
# define PATH_SEPARATOR '/'
@@ -101,7 +104,7 @@
# define GFLAGS_DLL_DEFINE_FLAG GFLAGS_DLL_DECL
#endif
-#ifdef _WIN32
+#ifdef OS_WINDOWS
// The unittests import the symbols of the shared gflags library
# if GFLAGS_IS_A_DLL && defined(_MSC_VER)
# define GFLAGS_DLL_DECL_FOR_UNITTESTS __declspec(dllimport)
diff --git a/src/gflags.cc b/src/gflags.cc
index bd1b130..b314f08 100644
--- a/src/gflags.cc
+++ b/src/gflags.cc
@@ -1494,7 +1494,7 @@ const char* ProgramInvocationName() { // like the GNU libc fn
}
const char* ProgramInvocationShortName() { // like the GNU libc fn
const char* slash = strrchr(argv0, '/');
-#ifdef _WINDOWS
+#ifdef OS_WINDOWS
if (!slash) slash = strrchr(argv0, '\\');
#endif
return slash ? slash + 1 : argv0;
diff --git a/src/mutex.h b/src/mutex.h
index 3e2f28e..0bdd9d5 100644
--- a/src/mutex.h
+++ b/src/mutex.h
@@ -110,7 +110,7 @@
#if defined(NO_THREADS)
typedef int MutexType; // to keep a lock-count
-#elif defined(_WIN32) || defined(__CYGWIN32__) || defined(__CYGWIN64__)
+#elif defined(OS_WINDOWS)
# ifndef WIN32_LEAN_AND_MEAN
# define WIN32_LEAN_AND_MEAN // We only need minimal includes
# endif
@@ -227,7 +227,7 @@ bool Mutex::TryLock() { if (mutex_) return false; Lock(); return true; }
void Mutex::ReaderLock() { assert(++mutex_ > 0); }
void Mutex::ReaderUnlock() { assert(mutex_-- > 0); }
-#elif defined(_WIN32) || defined(__CYGWIN32__) || defined(__CYGWIN64__)
+#elif defined(OS_WINDOWS)
Mutex::Mutex() : destroy_(true) {
InitializeCriticalSection(&mutex_);
diff --git a/src/util.h b/src/util.h
index 6991c37..de94091 100644
--- a/src/util.h
+++ b/src/util.h
@@ -65,7 +65,7 @@ extern GFLAGS_DLL_DECL void (*gflags_exitfunc)(int);
#elif defined(HAVE_STRTOQ)
# define strto64 strtoq
# define strtou64 strtouq
-#elif defined(_WIN32) && !defined(__MINGW32__) && !defined(__MINGW64__)
+#elif defined(OS_WINDOWS)
# define strto64 _strtoi64
# define strtou64 _strtoui64
// Neither strtoll nor strtoq are defined. I hope strtol works!
diff --git a/src/windows_port.h b/src/windows_port.h
index 246f715..c8ff24f 100644
--- a/src/windows_port.h
+++ b/src/windows_port.h
@@ -112,7 +112,7 @@ inline void setenv(const char* name, const char* value, int) {
#define PRId64 "I64d"
#define PRIu64 "I64u"
-#ifndef __MINGW32__
+#if !defined(__MINGW32__) && !defined(__MINGW64__)
#define strtoq _strtoi64
#define strtouq _strtoui64
#define strtoll _strtoi64
From acb460af9e66d83401341d9af04984ce53eed0f0 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Wed, 19 Mar 2014 16:53:19 +0000
Subject: [PATCH 06/94] Use strtoll as defined by windows_port.h for strto64.
---
src/util.h | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/src/util.h b/src/util.h
index de94091..366e1be 100644
--- a/src/util.h
+++ b/src/util.h
@@ -58,16 +58,13 @@ namespace GFLAGS_NAMESPACE {
// This is used for unittests for death-testing. It is defined in gflags.cc.
extern GFLAGS_DLL_DECL void (*gflags_exitfunc)(int);
-// Work properly if either strtoll or strtoq is on this system
-#if defined(HAVE_STRTOLL)
+// Work properly if either strtoll or strtoq is on this system.
+#if defined(strtoll) || defined(HAVE_STRTOLL)
# define strto64 strtoll
# define strtou64 strtoull
#elif defined(HAVE_STRTOQ)
# define strto64 strtoq
# define strtou64 strtouq
-#elif defined(OS_WINDOWS)
-# define strto64 _strtoi64
-# define strtou64 _strtoui64
// Neither strtoll nor strtoq are defined. I hope strtol works!
#else
# define strto64 strtol
From 9242578bc18a220c41ce07e024d620465ec9e434 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Wed, 19 Mar 2014 17:15:36 +0000
Subject: [PATCH 07/94] Look for shlwapi.h also in case of MinGW.
---
CMakeLists.txt | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)
mode change 100644 => 100755 CMakeLists.txt
diff --git a/CMakeLists.txt b/CMakeLists.txt
old mode 100644
new mode 100755
index ae24799..fa456ea
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -82,11 +82,11 @@ if (MSVC)
set (HAVE_INTTYPES_H 0)
set (HAVE_UNISTD_H 0)
set (HAVE_SYS_STAT_H 1)
- check_include_file_cxx ("shlwapi.h" HAVE_SHLWAPI_H)
+ set (HAVE_SHLWAPI_H 1)
else ()
foreach (fname IN ITEMS unistd stdint inttypes sys/types sys/stat fnmatch)
string (TOUPPER "${fname}" FNAME)
- string (REGEX REPLACE "/" "_" FNAME "${FNAME}")
+ string (REPLACE "/" "_" FNAME "${FNAME}")
if (NOT HAVE_${FNAME}_H)
check_include_file_cxx ("${fname}.h" HAVE_${FNAME}_H)
endif ()
@@ -95,6 +95,9 @@ else ()
bool_to_int (HAVE_STDINT_H)
bool_to_int (HAVE_SYS_TYPES_H)
bool_to_int (HAVE_INTTYPES_H)
+ if (NOT HAVE_FNMATCH_H AND OS_WINDOWS)
+ check_include_file_cxx ("shlwapi.h" HAVE_SHLWAPI_H)
+ endif ()
endif ()
set (GFLAGS_INTTYPES_FORMAT "" CACHE STRING "Format of integer types: \"C99\" (uint32_t), \"BSD\" (u_int32_t), \"VC7\" (__int32)")
From ddc535741996b5ed42bb4d2c1bbcd371573a5bfd Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Wed, 19 Mar 2014 17:32:23 +0000
Subject: [PATCH 08/94] Add link dependency on shlwapi.lib during build
configuration instead of #pragma comment statement. Use this library also on
MinGW.
---
CMakeLists.txt | 8 +++++++-
src/gflags.cc | 5 ++---
test/gflags_unittest.cc | 4 ++--
3 files changed, 11 insertions(+), 6 deletions(-)
mode change 100644 => 100755 src/gflags.cc
diff --git a/CMakeLists.txt b/CMakeLists.txt
index fa456ea..66bbd4c 100755
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -91,7 +91,7 @@ else ()
check_include_file_cxx ("${fname}.h" HAVE_${FNAME}_H)
endif ()
endforeach ()
- # the following are used in #if not #ifdef
+ # the following are used in #if directives not #ifdef
bool_to_int (HAVE_STDINT_H)
bool_to_int (HAVE_SYS_TYPES_H)
bool_to_int (HAVE_INTTYPES_H)
@@ -219,11 +219,17 @@ include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}")
set (LIB_TARGETS)
if (BUILD_gflags_LIB)
add_library (gflags ${GFLAGS_SRCS} ${PRIVATE_HDRS} ${PUBLIC_HDRS})
+ if (HAVE_SHLWAPI_H)
+ target_link_libraries (gflags shlwapi.lib)
+ endif ()
list (APPEND LIB_TARGETS gflags)
endif ()
if (BUILD_gflags_nothreads_LIB)
add_library (gflags_nothreads ${GFLAGS_SRCS} ${PRIVATE_HDRS} ${PUBLIC_HDRS})
set_target_properties (gflags_nothreads PROPERTIES COMPILE_DEFINITIONS NO_THREADS)
+ if (HAVE_SHLWAPI_H)
+ target_link_libraries (gflags_nothreads shlwapi.lib)
+ endif ()
list (APPEND LIB_TARGETS gflags_nothreads)
endif ()
diff --git a/src/gflags.cc b/src/gflags.cc
old mode 100644
new mode 100755
index b314f08..285050f
--- a/src/gflags.cc
+++ b/src/gflags.cc
@@ -95,9 +95,8 @@
#include
#if defined(HAVE_FNMATCH_H)
# include
-#elif defined(_MSC_VER) && defined(HAVE_SHLWAPI_H)
+#elif defined(HAVE_SHLWAPI_H)
# include
-# pragma comment(lib, "shlwapi.lib")
#endif
#include // For va_list and related operations
#include
@@ -1310,7 +1309,7 @@ string CommandLineFlagParser::ProcessOptionsFromStringLocked(
#if defined(HAVE_FNMATCH_H)
|| fnmatch(glob.c_str(), ProgramInvocationName(), FNM_PATHNAME) == 0
|| fnmatch(glob.c_str(), ProgramInvocationShortName(), FNM_PATHNAME) == 0
-#elif defined(_MSC_VER) && defined(HAVE_SHLWAPI_H)
+#elif defined(HAVE_SHLWAPI_H)
|| PathMatchSpec(glob.c_str(), ProgramInvocationName())
|| PathMatchSpec(glob.c_str(), ProgramInvocationShortName())
#endif
diff --git a/test/gflags_unittest.cc b/test/gflags_unittest.cc
index 7a44f64..80f7398 100644
--- a/test/gflags_unittest.cc
+++ b/test/gflags_unittest.cc
@@ -408,7 +408,7 @@ TEST(FlagFileTest, FilenamesOurfileFirst) {
-1.0);
}
-#if defined(HAVE_FNMATCH_H) || (defined(_MSC_VER) && defined(HAVE_SHLWAPI_H)) // otherwise glob isn't supported
+#if defined(HAVE_FNMATCH_H) || defined(HAVE_SHLWAPI_H) // otherwise glob isn't supported
TEST(FlagFileTest, FilenamesOurfileGlob) {
FLAGS_test_string = "initial";
FLAGS_test_bool = false;
@@ -460,7 +460,7 @@ TEST(FlagFileTest, FilenamesOurfileInBigList) {
1,
-1.0);
}
-#endif // defined(HAVE_FNMATCH_H) || (defined(_MSC_VER) && defined(HAVE_SHLWAPI_H))
+#endif // defined(HAVE_FNMATCH_H) || defined(HAVE_SHLWAPI_H)
// Tests that a failed flag-from-string read keeps flags at default values
TEST(FlagFileTest, FailReadFlagsFromString) {
From ec4ddb403a61e958fc2620878b26453676049b82 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Wed, 19 Mar 2014 17:56:32 +0000
Subject: [PATCH 09/94] Revert "Added Git ignore file to prevent build files
being seen as changed files"
This reverts commit fb21f3cca06e9ff367795ed47e6bb93a9cfcfcba.
---
.gitignore | 6 ------
1 file changed, 6 deletions(-)
delete mode 100644 .gitignore
diff --git a/.gitignore b/.gitignore
deleted file mode 100644
index 6b65910..0000000
--- a/.gitignore
+++ /dev/null
@@ -1,6 +0,0 @@
-Debug
-ipch
-*.vcxproj.user
-*.opensdf
-*.sdf
-*.suo
\ No newline at end of file
From 9ecc4cab3b9a72264ff3ce9be8c3e2661c56e9ab Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 02:11:44 +0000
Subject: [PATCH 10/94] Enable packaging of library using CPack.
---
AUTHORS => AUTHORS.txt | 0
CMakeLists.txt | 276 ++++++++++++++++++++++++++-----------
COPYING => COPYING.txt | 0
ChangeLog => ChangeLog.txt | 0
INSTALL => INSTALL.txt | 6 +-
NEWS => NEWS.txt | 0
README | 5 -
README.txt | 8 ++
cmake/README_runtime.txt | 4 +
cmake/package.cmake.in | 54 ++++++++
src/config.h.in | 6 +-
test/CMakeLists.txt | 20 ++-
12 files changed, 281 insertions(+), 98 deletions(-)
rename AUTHORS => AUTHORS.txt (100%)
rename COPYING => COPYING.txt (100%)
rename ChangeLog => ChangeLog.txt (100%)
rename INSTALL => INSTALL.txt (91%)
rename NEWS => NEWS.txt (100%)
delete mode 100644 README
create mode 100644 README.txt
create mode 100644 cmake/README_runtime.txt
create mode 100644 cmake/package.cmake.in
diff --git a/AUTHORS b/AUTHORS.txt
similarity index 100%
rename from AUTHORS
rename to AUTHORS.txt
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 66bbd4c..ff5d476 100755
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -1,27 +1,19 @@
-cmake_minimum_required(VERSION 2.8.4 FATAL_ERROR)
-
-if (WIN32 AND NOT CYGWIN)
- set (OS_WINDOWS 1)
-else ()
- set (OS_WINDOWS 0)
-endif ()
+cmake_minimum_required (VERSION 2.8.4 FATAL_ERROR)
# ----------------------------------------------------------------------------
# includes
set (CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
-
include (utils)
# ----------------------------------------------------------------------------
# package information
-set (PROJECT_NAME "gflags")
-set (PACKAGE_NAME "${PROJECT_NAME}")
-set (PACKAGE_VERSION "2.1.0")
-set (PACKAGE_STRING "${PROJECT_NAME} ${PACKAGE_VERSION}")
-set (PACKAGE_TARNAME "${PROJECT_NAME}-${PACKAGE_VERSION}")
+set (PACKAGE_NAME "gflags")
+set (PACKAGE_VERSION "2.1")
+set (PACKAGE_STRING "${PACKAGE_NAME} ${PACKAGE_VERSION}")
+set (PACKAGE_TARNAME "${PACKAGE_NAME}-${PACKAGE_VERSION}")
set (PACKAGE_BUGREPORT "https://code.google.com/p/gflags/issues/")
-project (${PROJECT_NAME} CXX)
+project (${PACKAGE_NAME} CXX)
version_numbers (
${PACKAGE_VERSION}
@@ -31,50 +23,53 @@ version_numbers (
)
# ----------------------------------------------------------------------------
-# configure options
-option (BUILD_SHARED_LIBS "Request build of shared libraries." OFF)
+# options
+set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
-if (OS_WINDOWS AND BUILD_SHARED_LIBS)
- set (GFLAGS_IS_A_DLL 1)
-else ()
- set (GFLAGS_IS_A_DLL 0)
-endif ()
-
-option (BUILD_gflags_LIB "Request build of the multi-threaded gflags library." ON)
-option (BUILD_gflags_nothreads_LIB "Request build of the single-threaded gflags library." ON)
-
-if (NOT BUILD_gflags_LIB AND NOT BUILD_gflags_nothreads_LIB)
- message (FATAL_ERROR "At least one of BUILD_gflags_LIB and BUILD_gflags_nothreads_LIB must be ON.")
-endif ()
-
-option (BUILD_NEGATIVE_COMPILATION_TESTS "Request addition of negative compilation tests." OFF)
-mark_as_advanced (BUILD_NEGATIVE_COMPILATION_TESTS)
-
-set (GFLAGS_NAMESPACE "gflags" CACHE STRING "C++ namespace identifier of gflags library.")
-mark_as_advanced (GFLAGS_NAMESPACE)
+option (BUILD_SHARED_LIBS "Request build of shared libraries." OFF)
+option (BUILD_STATIC_LIBS "Request build of static libraries (default if BUILD_SHARED_LIBS is OFF)." OFF)
+option (BUILD_gflags_LIB "Request build of the multi-threaded gflags library." ON)
+option (BUILD_gflags_nothreads_LIB "Request build of the single-threaded gflags library." ON)
+option (BUILD_PACKAGING "Enable build of distribution packages using CPack." OFF)
+option (BUILD_TESTING "Enable build of the unit tests and their execution using CTest." OFF)
+option (BUILD_NC_TESTS "Request addition of negative compilation tests." OFF)
+option (INSTALL_HEADERS "Request packaging of headers and other development files." ON)
mark_as_advanced (CLEAR CMAKE_INSTALL_PREFIX)
-mark_as_advanced (CMAKE_CONFIGURATION_TYPES)
-if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CXX_FLAGS AND NOT CMAKE_C_FLAGS)
- set (
- CMAKE_BUILD_TYPE "Release"
- CACHE STRING "Choose the type of build, options are: None (CMAKE_C_FLAGS and CMAKE_CXX_FLAGS used) Debug Release RelWithDebInfo MinSizeRel."
- FORCE
- )
-endif ()
-
+mark_as_advanced (CMAKE_CONFIGURATION_TYPES
+ GFLAGS_NAMESPACE
+ BUILD_STATIC_LIBS
+ BUILD_NC_TESTS
+ INSTALL_HEADERS)
if (APPLE)
mark_as_advanced(CMAKE_OSX_ARCHITECTURES
CMAKE_OSX_DEPLOYMENT_TARGET
CMAKE_OSX_SYSROOT)
endif ()
+if (NOT BUILD_SHARED_LIBS AND NOT BUILD_STATIC_LIBS)
+ set (BUILD_STATIC_LIBS ON)
+endif ()
+if (NOT BUILD_gflags_LIB AND NOT BUILD_gflags_nothreads_LIB)
+ message (FATAL_ERROR "At least one of BUILD_gflags_LIB and BUILD_gflags_nothreads_LIB must be ON.")
+endif ()
+
+if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CXX_FLAGS)
+ set_property (CACHE CMAKE_BUILD_TYPE PROPERTY VALUE Release)
+endif ()
+
# ----------------------------------------------------------------------------
# system checks
include (CheckTypeSize)
include (CheckIncludeFileCXX)
include (CheckCXXSymbolExists)
+if (WIN32 AND NOT CYGWIN)
+ set (OS_WINDOWS 1)
+else ()
+ set (OS_WINDOWS 0)
+endif ()
+
if (MSVC)
set (HAVE_SYS_TYPES_H 1)
set (HAVE_STDINT_H 1)
@@ -179,6 +174,8 @@ set (PUBLIC_HDRS
set (PRIVATE_HDRS
"config.h"
+ "util.h"
+ "mutex.h"
)
set (GFLAGS_SRCS
@@ -204,6 +201,10 @@ configure_headers (PUBLIC_HDRS ${PUBLIC_HDRS})
configure_sources (PRIVATE_HDRS ${PRIVATE_HDRS})
configure_sources (GFLAGS_SRCS ${GFLAGS_SRCS})
+include_directories ("${PROJECT_SOURCE_DIR}/src")
+include_directories ("${PROJECT_BINARY_DIR}/include")
+include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}")
+
# ----------------------------------------------------------------------------
# output directories
set (CMAKE_RUNTIME_OUTPUT_DIRECTORY "bin")
@@ -211,27 +212,43 @@ set (CMAKE_LIBRARY_OUTPUT_DIRECTORY "lib")
set (CMAKE_ARCHIVE_OUTPUT_DIRECTORY "lib")
# ----------------------------------------------------------------------------
-# add library target
-include_directories ("${PROJECT_SOURCE_DIR}/src")
-include_directories ("${PROJECT_BINARY_DIR}/include")
-include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}")
-
-set (LIB_TARGETS)
-if (BUILD_gflags_LIB)
- add_library (gflags ${GFLAGS_SRCS} ${PRIVATE_HDRS} ${PUBLIC_HDRS})
- if (HAVE_SHLWAPI_H)
- target_link_libraries (gflags shlwapi.lib)
+# add library targets
+set (TARGETS)
+# static vs. shared
+foreach (TYPE IN ITEMS STATIC SHARED)
+ if (BUILD_${TYPE}_LIBS)
+ # whether or not targets are a DLL
+ if (OS_WINDOWS AND "^${TYPE}$" STREQUAL "^SHARED$")
+ set (GFLAGS_IS_A_DLL 1)
+ else ()
+ set (GFLAGS_IS_A_DLL 0)
+ endif ()
+ string (TOLOWER "${TYPE}" type)
+ # multi-threaded vs. single-threaded
+ foreach (opts IN ITEMS "" _nothreads)
+ if (BUILD_gflags${opts}_LIB)
+ add_library (gflags${opts}-${type} ${TYPE} ${GFLAGS_SRCS} ${PRIVATE_HDRS} ${PUBLIC_HDRS})
+ if (opts MATCHES "nothreads")
+ set (defines "GFLAGS_IS_A_DLL=${GFLAGS_IS_A_DLL};NOTHREADS")
+ else ()
+ set (defines "GFLAGS_IS_A_DLL=${GFLAGS_IS_A_DLL}")
+ endif ()
+ set_target_properties (
+ gflags${opts}-${type} PROPERTIES COMPILE_DEFINITIONS "${defines}"
+ OUTPUT_NAME "gflags${opts}"
+ )
+ if (HAVE_SHLWAPI_H)
+ target_link_libraries (gflags${opts}-${type} shlwapi.lib)
+ endif ()
+ if (NOT TARGET gflags${opts})
+ add_custom_target (gflags${opts})
+ endif ()
+ add_dependencies (gflags${opts} gflags${opts}-${type})
+ list (APPEND TARGETS gflags${opts}-${type})
+ endif ()
+ endforeach ()
endif ()
- list (APPEND LIB_TARGETS gflags)
-endif ()
-if (BUILD_gflags_nothreads_LIB)
- add_library (gflags_nothreads ${GFLAGS_SRCS} ${PRIVATE_HDRS} ${PUBLIC_HDRS})
- set_target_properties (gflags_nothreads PROPERTIES COMPILE_DEFINITIONS NO_THREADS)
- if (HAVE_SHLWAPI_H)
- target_link_libraries (gflags_nothreads shlwapi.lib)
- endif ()
- list (APPEND LIB_TARGETS gflags_nothreads)
-endif ()
+endforeach ()
# ----------------------------------------------------------------------------
# installation
@@ -247,41 +264,134 @@ else ()
set (CONFIG_INSTALL_DIR lib/cmake/${PACKAGE_NAME})
endif ()
-install (TARGETS ${LIB_TARGETS} DESTINATION ${LIBRARY_INSTALL_DIR} EXPORT gflags-lib)
-install (FILES ${PUBLIC_HDRS} DESTINATION ${INCLUDE_INSTALL_DIR}/${GFLAGS_NAMESPACE})
-
file (RELATIVE_PATH INSTALL_PREFIX_REL2CONFIG_DIR "${CMAKE_INSTALL_PREFIX}/${CONFIG_INSTALL_DIR}" "${CMAKE_INSTALL_PREFIX}")
configure_file (cmake/config.cmake.in "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-install.cmake" @ONLY)
configure_file (cmake/version.cmake.in "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-version.cmake" @ONLY)
-install (
- FILES "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-install.cmake"
- RENAME ${PACKAGE_NAME}-config.cmake
- DESTINATION ${CONFIG_INSTALL_DIR}
-)
-
-install (
- FILES "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-version.cmake"
- DESTINATION ${CONFIG_INSTALL_DIR}
-)
-
-install (EXPORT gflags-lib DESTINATION ${CONFIG_INSTALL_DIR} FILE ${PACKAGE_NAME}-export.cmake)
-
-if (UNIX)
- install (PROGRAMS src/gflags_completions.sh DESTINATION ${RUNTIME_INSTALL_DIR})
+install (TARGETS ${TARGETS} DESTINATION ${LIBRARY_INSTALL_DIR} EXPORT gflags-lib)
+if (INSTALL_HEADERS)
+ install (FILES ${PUBLIC_HDRS} DESTINATION ${INCLUDE_INSTALL_DIR}/${GFLAGS_NAMESPACE})
+ install (
+ FILES "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-install.cmake"
+ RENAME ${PACKAGE_NAME}-config.cmake
+ DESTINATION ${CONFIG_INSTALL_DIR}
+ )
+ install (
+ FILES "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-version.cmake"
+ DESTINATION ${CONFIG_INSTALL_DIR}
+ )
+ install (EXPORT gflags-lib DESTINATION ${CONFIG_INSTALL_DIR} FILE ${PACKAGE_NAME}-export.cmake)
+ if (UNIX)
+ install (PROGRAMS src/gflags_completions.sh DESTINATION ${RUNTIME_INSTALL_DIR})
+ endif ()
endif ()
# ----------------------------------------------------------------------------
# support direct use of build tree
set (INSTALL_PREFIX_REL2CONFIG_DIR .)
-export (TARGETS ${LIB_TARGETS} FILE "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-export.cmake")
+export (TARGETS ${TARGETS} FILE "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-export.cmake")
export (PACKAGE gflags)
configure_file (cmake/config.cmake.in "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config.cmake" @ONLY)
# ----------------------------------------------------------------------------
# testing - MUST follow the generation of the build tree config file
-include (CTest)
if (BUILD_TESTING)
+ include (CTest)
enable_testing ()
add_subdirectory (test)
endif ()
+
+# ----------------------------------------------------------------------------
+# packaging
+if (BUILD_PACKAGING)
+
+ if (NOT BUILD_SHARED_LIBS AND NOT INSTALL_HEADERS)
+ message (WARNING "Package will contain static libraries without headers!"
+ "\nRecommended options for generation of runtime package:"
+ "\n BUILD_SHARED_LIBS=ON"
+ "\n BUILD_STATIC_LIBS=OFF"
+ "\n INSTALL_HEADERS=OFF"
+ "\nRecommended options for generation of development package:"
+ "\n BUILD_SHARED_LIBS=ON"
+ "\n BUILD_STATIC_LIBS=ON"
+ "\n INSTALL_HEADERS=ON")
+ endif ()
+
+ # default package generators
+ if (APPLE)
+ set (PACKAGE_GENERATOR "PackageMaker")
+ set (PACKAGE_SOURCE_GENERATOR "TGZ;ZIP")
+ elseif (UNIX)
+ set (PACKAGE_GENERATOR "DEB;RPM")
+ set (PACKAGE_SOURCE_GENERATOR "TGZ;ZIP")
+ else ()
+ set (PACKAGE_GENERATOR "ZIP")
+ set (PACKAGE_SOURCE_GENERATOR "ZIP")
+ endif ()
+
+ # used package generators
+ set (CPACK_GENERATOR "${PACKAGE_GENERATOR}" CACHE STRING "List of binary package generators (CPack).")
+ set (CPACK_SOURCE_GENERATOR "${PACKAGE_SOURCE_GENERATOR}" CACHE STRING "List of source package generators (CPack).")
+ mark_as_advanced (CPACK_GENERATOR CPACK_SOURCE_GENERATOR)
+
+ # common package information
+ set (CPACK_PACKAGE_VENDOR "Open Source by Andreas Schuh")
+ set (CPACK_PACKAGE_CONTACT "google-gflags@googlegroups.com")
+ set (CPACK_PACKAGE_NAME "${PACKAGE_NAME}")
+ set (CPACK_PACKAGE_VERSION "${PACKAGE_VERSION}")
+ set (CPACK_PACKAGE_VERSION_MAJOR "${PACKAGE_VERSION_MAJOR}")
+ set (CPACK_PACKAGE_VERSION_MINOR "${PACKAGE_VERSION_MINOR}")
+ set (CPACK_PACKAGE_VERSION_PATCH "${PACKAGE_VERSION_PATCH}")
+ set (CPACK_PACKAGE_DESCRIPTION_SUMMARY "A commandline flags library that allows for distributed flags.")
+ set (CPACK_RESOURCE_FILE_WELCOME "${CMAKE_CURRENT_LIST_DIR}/README.txt")
+ set (CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_LIST_DIR}/COPYING.txt")
+ set (CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_LIST_DIR}/INSTALL.txt")
+ set (CPACK_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}")
+ set (CPACK_OUTPUT_FILE_PREFIX packages)
+ set (CPACK_PACKAGE_RELOCATABLE TRUE)
+ set (CPACK_MONOLITHIC_INSTALL TRUE)
+
+ if (INSTALL_HEADERS)
+ set (CPACK_RESOURCE_FILE_README "${CMAKE_CURRENT_LIST_DIR}/doc/gflags.html")
+ else ()
+ set (CPACK_RESOURCE_FILE_README "${CMAKE_CURRENT_LIST_DIR}/cmake/README_runtime.txt")
+ endif ()
+
+ # system name used for binary package file name
+ if (WINDOWS)
+ if (CMAKE_CL_64)
+ set (CPACK_SYSTEM_NAME "win64")
+ else ()
+ set (CPACK_SYSTEM_NAME "win32")
+ endif ()
+ else ()
+ string (TOLOWER "${CMAKE_SYSTEM_NAME}" CPACK_SYSTEM_NAME)
+ endif ()
+
+ # source package settings
+ set (CPACK_SOURCE_TOPLEVEL_TAG "source")
+ set (CPACK_SOURCE_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}-${CPACK_PACKAGE_VERSION}")
+ set (CPACK_SOURCE_IGNORE_FILES "/\\\\.git/;\\\\.swp$;\\\\.#;/#;\\\\.*~;cscope\\\\.*;/[Bb]uild[.+-_a-zA-Z0-9]*/")
+
+ # default binary package settings
+ set (CPACK_INCLUDE_TOPLEVEL_DIRECTORY TRUE)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}-${CPACK_PACKAGE_VERSION}-${CPACK_SYSTEM_NAME}")
+ if (CMAKE_SYSTEM_PROCESSOR)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CMAKE_SYSTEM_PROCESSOR}")
+ endif ()
+
+ # generator specific configuration file
+ #
+ # allow package maintainers to use their own configuration file
+ # $ cmake -DCPACK_PROJECT_CONFIG_FILE:FILE=/path/to/package/config
+ if (NOT CPACK_PROJECT_CONFIG_FILE)
+ configure_file (
+ "${CMAKE_CURRENT_LIST_DIR}/cmake/package.cmake.in"
+ "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-package.cmake" @ONLY
+ )
+ set (CPACK_PROJECT_CONFIG_FILE "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-package.cmake")
+ endif ()
+
+ include (CPack)
+
+endif () # BUILD_PACKAGING
diff --git a/COPYING b/COPYING.txt
similarity index 100%
rename from COPYING
rename to COPYING.txt
diff --git a/ChangeLog b/ChangeLog.txt
similarity index 100%
rename from ChangeLog
rename to ChangeLog.txt
diff --git a/INSTALL b/INSTALL.txt
similarity index 91%
rename from INSTALL
rename to INSTALL.txt
index 78683ac..a96a772 100644
--- a/INSTALL
+++ b/INSTALL.txt
@@ -3,9 +3,9 @@ INSTALLING A BINARY DISTRIBUTION PACKAGE
========================================
No official binary distribution packages are provided by the gflags developers.
-There may, however, be binary packages available for your OS, in particular
-for various flavors of Linux. Please consult the package repositories of your
-Linux distribution to see if a binary package is available.
+There may, however, be binary packages available for your OS at
+https://code.google.com/p/gflags/downloads/list. Please consult also the
+package repositories of your Linux distribution.
For example on Debian/Ubuntu Linux, gflags can be installed using the
following command:
diff --git a/NEWS b/NEWS.txt
similarity index 100%
rename from NEWS
rename to NEWS.txt
diff --git a/README b/README
deleted file mode 100644
index 9935d3a..0000000
--- a/README
+++ /dev/null
@@ -1,5 +0,0 @@
-This repository contains the C++ implementation of the commandline flags module
-originally developed at Google. Documentation for this module is in doc/.
-The python version of gflags is now a separate project.
-
-See INSTALL for (generic) installation instructions.
diff --git a/README.txt b/README.txt
new file mode 100644
index 0000000..bda07ef
--- /dev/null
+++ b/README.txt
@@ -0,0 +1,8 @@
+A commandline flags library that allows for distributed flags.
+
+This package contains a library that implements commandline flags
+processing. As such it's a replacement for getopt(). It has increased
+flexibility, including built-in support for C++ types like string, and
+the ability to define flags in the source file in which they're used.
+The devel package contains static and debug libraries and header files
+for developing applications that use the gflags package.
diff --git a/cmake/README_runtime.txt b/cmake/README_runtime.txt
new file mode 100644
index 0000000..d2556b2
--- /dev/null
+++ b/cmake/README_runtime.txt
@@ -0,0 +1,4 @@
+This package contains runtime libraries only which are required
+by applications that use these libraries for the commandline flags
+processing. If you want to develop such application, download
+and install the development package instead.
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
new file mode 100644
index 0000000..05f378f
--- /dev/null
+++ b/cmake/package.cmake.in
@@ -0,0 +1,54 @@
+# Per-generator CPack configuration file. See CPACK_PROJECT_CONFIG_FILE documented at
+# http://www.cmake.org/cmake/help/v2.8.12/cpack.html#variable:CPACK_PROJECT_CONFIG_FILE
+#
+# All common CPACK_* variables are set in CMakeLists.txt already. This file only
+# overrides some of these to provide package generator specific settings.
+
+# whether package contains all development files or only runtime files
+set (DEVEL @INSTALL_HEADERS@)
+
+# ------------------------------------------------------------------------------
+# Mac OS X package
+if (CPACK_GENERATOR MATCHES "PackageMaker|DragNDrop")
+
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}")
+ if (DEVEL)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-devel")
+ endif ()
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_VERSION}")
+
+# ------------------------------------------------------------------------------
+# Debian package
+elseif ("^${CPACK_GENERATOR}$" STREQUAL "DEB")
+
+ set (CPACK_PACKAGE_FILE_NAME "lib${CPACK_PACKAGE_NAME}")
+ if (DEVEL)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-dev")
+ else ()
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}0")
+ endif ()
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}_${CPACK_PACKAGE_VERSION}-1_${CMAKE_SYSTEM_PROCESSOR}")
+
+ execute_process (
+ COMMAND dpkg --print-architecture
+ RESULT_VARIABLE RV
+ OUTPUT_VARIABLE CPACK_DEBIAN_PACKAGE_ARCHITECTURE
+ )
+ if (NOT RV EQUAL 0)
+ set (CPACK_DEBIAN_PACKAGE_ARCHITECTURE i386)
+ endif ()
+ set (CPACK_DEBIAN_PACKAGE_DEPENDS)
+ set (CPACK_DEBIAN_PACKAGE_SECTION devel)
+ set (CPACK_DEBIAN_PACKAGE_PRIORITY optional)
+
+# ------------------------------------------------------------------------------
+# RPM package
+elseif ("^${CPACK_GENERATOR}$" STREQUAL "RPM")
+
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}")
+ if (DEVEL)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-devel")
+ endif ()
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_VERSION}-1_${CMAKE_SYSTEM_PROCESSOR}")
+
+endif ()
diff --git a/src/config.h.in b/src/config.h.in
index 3f94663..c033dee 100644
--- a/src/config.h.in
+++ b/src/config.h.in
@@ -86,8 +86,10 @@
// ---------------------------------------------------------------------------
// Windows
-// Whether gflags library is shared.
-#define GFLAGS_IS_A_DLL @GFLAGS_IS_A_DLL@
+// Whether gflags library is a DLL.
+#ifndef GFLAGS_IS_A_DLL
+# define GFLAGS_IS_A_DLL 0
+#endif
// Always export symbols when compiling a shared library as this file is only
// included by internal modules when building the gflags library itself.
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 3f7f17e..49c97ea 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -12,7 +12,17 @@ set (GFLAGS_FLAGFILES_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
# ----------------------------------------------------------------------------
# common include directories and link libraries
include_directories ("${CMAKE_CURRENT_SOURCE_DIR}")
-link_libraries (gflags_nothreads)
+
+if (BUILD_SHARED_LIBS)
+ set (type shared)
+else ()
+ set (type static)
+endif ()
+if (BUILD_gflags_LIB)
+ link_libraries (gflags-${type})
+else ()
+ link_libraries (gflags_nothreads-${type})
+endif ()
# ----------------------------------------------------------------------------
# STRIP_FLAG_HELP
@@ -35,7 +45,7 @@ add_executable (gflags_unittest gflags_unittest.cc)
add_executable (gflags_unittest-main gflags_unittest-main.cc)
add_executable (gflags_unittest_main gflags_unittest_main.cc)
-if (WIN32 AND NOT CYGWIN)
+if (OS_WINDOWS)
set (SLASH "\\\\")
else ()
set (SLASH "/")
@@ -146,11 +156,11 @@ add_gflags_test(always_fail 1 "ERROR: failed validation of new value 'true' for
# ----------------------------------------------------------------------------
# (negative) compilation tests
-if (BUILD_NEGATIVE_COMPILATION_TESTS)
+if (BUILD_NC_TESTS)
find_package (PythonInterp)
if (NOT PYTHON_EXECUTABLE)
message (FATAL_ERROR "No Python installation found! It is required by the negative compilation tests."
- " Either install Python or set NEGATIVE_COMPILATION_TESTS to FALSE and try again.")
+ " Either install Python or set BUILD_NC_TESTS to FALSE and try again.")
endif ()
set (SRCDIR "${CMAKE_CURRENT_SOURCE_DIR}/nc")
configure_file (gflags_nc.py.in "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/nc.py" @ONLY)
@@ -165,4 +175,4 @@ if (BUILD_NEGATIVE_COMPILATION_TESTS)
add_gflags_nc_test (int_instead_of_bool)
add_gflags_nc_test (bool_in_quotes)
add_gflags_nc_test (define_string_with_0)
-endif ()
\ No newline at end of file
+endif ()
From cb62c003548ce9ee30840113fa03c031556c7345 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 02:13:13 +0000
Subject: [PATCH 11/94] Change mode of text file.
---
CMakeLists.txt | 0
src/gflags.cc | 0
2 files changed, 0 insertions(+), 0 deletions(-)
mode change 100755 => 100644 CMakeLists.txt
mode change 100755 => 100644 src/gflags.cc
diff --git a/CMakeLists.txt b/CMakeLists.txt
old mode 100755
new mode 100644
diff --git a/src/gflags.cc b/src/gflags.cc
old mode 100755
new mode 100644
From bf139ea0a8e31b0b54ad35b7f3ffef90ed6c7ee3 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:04:44 +0000
Subject: [PATCH 12/94] Fix build of threaded library on Unix by adding the
appropriate link library.
---
CMakeLists.txt | 3 +++
1 file changed, 3 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index ff5d476..acc38f8 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -232,6 +232,9 @@ foreach (TYPE IN ITEMS STATIC SHARED)
set (defines "GFLAGS_IS_A_DLL=${GFLAGS_IS_A_DLL};NOTHREADS")
else ()
set (defines "GFLAGS_IS_A_DLL=${GFLAGS_IS_A_DLL}")
+ if (CMAKE_USE_PTHREADS_INIT)
+ target_link_libraries (gflags${opts}-${type} ${CMAKE_THREAD_LIBS_INIT})
+ endif ()
endif ()
set_target_properties (
gflags${opts}-${type} PROPERTIES COMPILE_DEFINITIONS "${defines}"
From 13fe86b8fe9a46bdffa540eda9aa594ecbad33bb Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:22:57 +0000
Subject: [PATCH 13/94] Correct CPack package description file.
---
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index acc38f8..46e8b68 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -348,7 +348,7 @@ if (BUILD_PACKAGING)
set (CPACK_PACKAGE_DESCRIPTION_SUMMARY "A commandline flags library that allows for distributed flags.")
set (CPACK_RESOURCE_FILE_WELCOME "${CMAKE_CURRENT_LIST_DIR}/README.txt")
set (CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_LIST_DIR}/COPYING.txt")
- set (CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_LIST_DIR}/INSTALL.txt")
+ set (CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_LIST_DIR}/README.txt")
set (CPACK_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}")
set (CPACK_OUTPUT_FILE_PREFIX packages)
set (CPACK_PACKAGE_RELOCATABLE TRUE)
From 516e028901c9bead498ff40f53fa6fe405d20689 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:23:08 +0000
Subject: [PATCH 14/94] Set RPM generator specific variables.
---
CMakeLists.txt | 1 +
cmake/package.cmake.in | 5 +++++
2 files changed, 6 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 46e8b68..f93c1f7 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -349,6 +349,7 @@ if (BUILD_PACKAGING)
set (CPACK_RESOURCE_FILE_WELCOME "${CMAKE_CURRENT_LIST_DIR}/README.txt")
set (CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_LIST_DIR}/COPYING.txt")
set (CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_LIST_DIR}/README.txt")
+ set (CPACK_RESOURCE_FILE_CHANGELOG "${CMAKE_CURRENT_LIST_DIR}/ChangeLog.txt")
set (CPACK_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}")
set (CPACK_OUTPUT_FILE_PREFIX packages)
set (CPACK_PACKAGE_RELOCATABLE TRUE)
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
index 05f378f..3414d21 100644
--- a/cmake/package.cmake.in
+++ b/cmake/package.cmake.in
@@ -51,4 +51,9 @@ elseif ("^${CPACK_GENERATOR}$" STREQUAL "RPM")
endif ()
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_VERSION}-1_${CMAKE_SYSTEM_PROCESSOR}")
+ set (CPACK_RPM_PACKAGE_GROUP "Development/Libraries")
+ set (CPACK_RPM_PACKAGE_LICENSE "BSD")
+ set (CPACK_RPM_PACKAGE_URL "http://code.google.com/p/gflags")
+ set (CPACK_RPM_CHANGELOG_FILE "@CPACK_RESOURCE_FILE_CHANGELOG@")
+
endif ()
From 37a9a90d1db73964d54a9ed0d10f21000af5711a Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:27:13 +0000
Subject: [PATCH 15/94] Set RPM CPack variables already in CMakeList.txt.
---
CMakeLists.txt | 7 ++++++-
cmake/package.cmake.in | 5 -----
2 files changed, 6 insertions(+), 6 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index f93c1f7..8aec4b8 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -349,12 +349,17 @@ if (BUILD_PACKAGING)
set (CPACK_RESOURCE_FILE_WELCOME "${CMAKE_CURRENT_LIST_DIR}/README.txt")
set (CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_LIST_DIR}/COPYING.txt")
set (CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_LIST_DIR}/README.txt")
- set (CPACK_RESOURCE_FILE_CHANGELOG "${CMAKE_CURRENT_LIST_DIR}/ChangeLog.txt")
set (CPACK_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}")
set (CPACK_OUTPUT_FILE_PREFIX packages)
set (CPACK_PACKAGE_RELOCATABLE TRUE)
set (CPACK_MONOLITHIC_INSTALL TRUE)
+ # RPM specification
+ set (CPACK_RPM_PACKAGE_GROUP "Development/Libraries")
+ set (CPACK_RPM_PACKAGE_LICENSE "BSD")
+ set (CPACK_RPM_PACKAGE_URL "http://code.google.com/p/gflags")
+ set (CPACK_RPM_CHANGELOG_FILE "${CMAKE_CURRENT_LIST_DIR}/ChangeLog.txt")
+
if (INSTALL_HEADERS)
set (CPACK_RESOURCE_FILE_README "${CMAKE_CURRENT_LIST_DIR}/doc/gflags.html")
else ()
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
index 3414d21..05f378f 100644
--- a/cmake/package.cmake.in
+++ b/cmake/package.cmake.in
@@ -51,9 +51,4 @@ elseif ("^${CPACK_GENERATOR}$" STREQUAL "RPM")
endif ()
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_VERSION}-1_${CMAKE_SYSTEM_PROCESSOR}")
- set (CPACK_RPM_PACKAGE_GROUP "Development/Libraries")
- set (CPACK_RPM_PACKAGE_LICENSE "BSD")
- set (CPACK_RPM_PACKAGE_URL "http://code.google.com/p/gflags")
- set (CPACK_RPM_CHANGELOG_FILE "@CPACK_RESOURCE_FILE_CHANGELOG@")
-
endif ()
From 26a35dd2e4802997e90808e963a96cf1652c5c2c Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:35:15 +0000
Subject: [PATCH 16/94] Convert ChangeLog to format allowed in RPM spec.
---
ChangeLog.txt | 302 +++++++++++++++++++++++++-------------------------
1 file changed, 151 insertions(+), 151 deletions(-)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index f9ef935..84a9b4e 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,193 +1,193 @@
-Wed Jan 25 15:09:14 2012 Google Inc.
+* Wed Jan 25 15:09:14 2012 Google Inc.
- * gflags: version 2.0
- * Changed the 'official' gflags email in setup.py/etc
- * Renamed google-gflags.sln to gflags.sln
- * Changed copyright text to reflect Google's relinquished ownership
+ - gflags: version 2.0
+ - Changed the 'official' gflags email in setup.py/etc
+ - Renamed google-gflags.sln to gflags.sln
+ - Changed copyright text to reflect Google's relinquished ownership
-Tue Dec 20 19:48:57 2011 Google Inc.
+* Tue Dec 20 19:48:57 2011 Google Inc.
- * google-gflags: version 1.7
- * Add CommandLineFlagInfo::flag_ptr pointing to current storage (musji)
- * PORTING: flush after writing to stderr, needed on cygwin
- * PORTING: Clean up the GFLAGS_DLL_DECL stuff better
- * Fix a bug in StringPrintf() that affected large strings (csilvers)
- * Die at configure-time when g++ isn't installed
+ - google-gflags: version 1.7
+ - Add CommandLineFlagInfo::flag_ptr pointing to current storage (musji)
+ - PORTING: flush after writing to stderr, needed on cygwin
+ - PORTING: Clean up the GFLAGS_DLL_DECL stuff better
+ - Fix a bug in StringPrintf() that affected large strings (csilvers)
+ - Die at configure-time when g++ isn't installed
-Fri Jul 29 19:05:21 2011 Google Inc.
+* Fri Jul 29 19:05:21 2011 Google Inc.
- * google-gflags: version 1.6
- * BUGFIX: Fix a bug where we were leaving out a required $(top_srcdir)
- * Fix definition of clstring (jyrki)
- * Split up flag declares into its own file (jyrki)
- * Add --version support (csilvers)
- * Update the README for gflags with static libs
- * Update acx_pthread.m4 for nostdlib
- * Change ReparseCommandLineFlags to return void (csilvers)
- * Some doc typofixes and example augmentation (various)
+ - google-gflags: version 1.6
+ - BUGFIX: Fix a bug where we were leaving out a required $(top_srcdir)
+ - Fix definition of clstring (jyrki)
+ - Split up flag declares into its own file (jyrki)
+ - Add --version support (csilvers)
+ - Update the README for gflags with static libs
+ - Update acx_pthread.m4 for nostdlib
+ - Change ReparseCommandLineFlags to return void (csilvers)
+ - Some doc typofixes and example augmentation (various)
-Mon Jan 24 16:11:35 2011 Google Inc.
+* Mon Jan 24 16:11:35 2011 Google Inc.
- * google-gflags: version 1.5
- * Better reporting of current vs default value (handler)
- * Add API for cleaning up of memory at program-exit (jmarantz)
- * Fix macros to work inside namespaces (csilvers)
- * Use our own string typedef in case string is redefined (csilvers)
- * Updated to autoconf 2.65
+ - google-gflags: version 1.5
+ - Better reporting of current vs default value (handler)
+ - Add API for cleaning up of memory at program-exit (jmarantz)
+ - Fix macros to work inside namespaces (csilvers)
+ - Use our own string typedef in case string is redefined (csilvers)
+ - Updated to autoconf 2.65
-Wed Oct 13 17:40:12 2010 Google Inc.
+* Wed Oct 13 17:40:12 2010 Google Inc.
- * google-gflags: version 1.4
- * Add a check to prevent passing 0 to DEFINE_string (jorg)
- * Reduce compile (.o) size (jyrki)
- * Some small changes to quiet debug compiles (alexk)
- * PORTING: better support static linking on windows (csilvers)
- * DOCUMENTATION: change default values, use validators, etc.
- * Update the NEWS file to be non-empty
- * Add pkg-config (.pc) files for libgflags and libgflags_nothreads
+ - google-gflags: version 1.4
+ - Add a check to prevent passing 0 to DEFINE_string (jorg)
+ - Reduce compile (.o) size (jyrki)
+ - Some small changes to quiet debug compiles (alexk)
+ - PORTING: better support static linking on windows (csilvers)
+ - DOCUMENTATION: change default values, use validators, etc.
+ - Update the NEWS file to be non-empty
+ - Add pkg-config (.pc) files for libgflags and libgflags_nothreads
-Mon Jan 4 18:09:30 2010 Google Inc.
+* Mon Jan 4 18:09:30 2010 Google Inc.
- * google-gflags: version 1.3
- * PORTABILITY: can now build and run tests under MSVC (csilvers)
- * Remove the python gflags code, which is now its own package (tansell)
- * Clarify that "last flag wins" in the docs (csilvers)
- * Comment danger of using GetAllFlags in validators (wojtekm)
- * PORTABILITY: Some fixes necessary for c++0x (mboerger)
- * Makefile fix: $(srcdir) -> $(top_srcdir) in one place (csilvres)
- * INSTALL: autotools to autoconf v2.64 + automake v1.11 (csilvers)
+ - google-gflags: version 1.3
+ - PORTABILITY: can now build and run tests under MSVC (csilvers)
+ - Remove the python gflags code, which is now its own package (tansell)
+ - Clarify that "last flag wins" in the docs (csilvers)
+ - Comment danger of using GetAllFlags in validators (wojtekm)
+ - PORTABILITY: Some fixes necessary for c++0x (mboerger)
+ - Makefile fix: $(srcdir) -> $(top_srcdir) in one place (csilvres)
+ - INSTALL: autotools to autoconf v2.64 + automake v1.11 (csilvers)
-Thu Sep 10 12:53:04 2009 Google Inc.
+* Thu Sep 10 12:53:04 2009 Google Inc.
- * google-gflags: version 1.2
- * PORTABILITY: can now build and run tests under mingw (csilvers)
- * Using a string arg for a bool flag is a compile-time error (rbayardo)
- * Add --helpxml to gflags.py (salcianu)
- * Protect against a hypothetical global d'tor mutex problem (csilvers)
- * BUGFIX: can now define a flag after 'using namespace google' (hamaji)
+ - google-gflags: version 1.2
+ - PORTABILITY: can now build and run tests under mingw (csilvers)
+ - Using a string arg for a bool flag is a compile-time error (rbayardo)
+ - Add --helpxml to gflags.py (salcianu)
+ - Protect against a hypothetical global d'tor mutex problem (csilvers)
+ - BUGFIX: can now define a flag after 'using namespace google' (hamaji)
-Tue Apr 14 12:35:25 2009 Google Inc.
+* Tue Apr 14 12:35:25 2009 Google Inc.
- * google-gflags: version 1.1
- * Add both foo and nofoo for boolean flags, with --undefok (andychu)
- * Better document how validators work (wojtekm)
- * Improve binary-detection for bash-completion (mtamsky)
- * Python: Add a concept of "key flags", used with --help (salcianu)
- * Python: Robustify flag_values (salcianu)
- * Python: Add a new DEFINE_bool alias (keir, andrewliu)
- * Python: Do module introspection based on module name (dsturtevant)
- * Fix autoconf a bit better, especially on windows and solaris (ajenjo)
- * BUG FIX: gflags_nothreads was linking against the wrong lib (ajenjo)
- * BUG FIX: threads-detection failed on FreeBSD; replace it (ajenjo)
- * PORTABILITY: Quiet an internal compiler error with SUSE 10 (csilvers)
- * PORTABILITY: Update deb.sh for more recenty debuilds (csilvers)
- * PORTABILITY: #include more headers to satify new gcc's (csilvers)
- * INSTALL: Updated to autoconf 2.61 and libtool 1.5.26 (csilvers)
+ - google-gflags: version 1.1
+ - Add both foo and nofoo for boolean flags, with --undefok (andychu)
+ - Better document how validators work (wojtekm)
+ - Improve binary-detection for bash-completion (mtamsky)
+ - Python: Add a concept of "key flags", used with --help (salcianu)
+ - Python: Robustify flag_values (salcianu)
+ - Python: Add a new DEFINE_bool alias (keir, andrewliu)
+ - Python: Do module introspection based on module name (dsturtevant)
+ - Fix autoconf a bit better, especially on windows and solaris (ajenjo)
+ - BUG FIX: gflags_nothreads was linking against the wrong lib (ajenjo)
+ - BUG FIX: threads-detection failed on FreeBSD; replace it (ajenjo)
+ - PORTABILITY: Quiet an internal compiler error with SUSE 10 (csilvers)
+ - PORTABILITY: Update deb.sh for more recenty debuilds (csilvers)
+ - PORTABILITY: #include more headers to satify new gcc's (csilvers)
+ - INSTALL: Updated to autoconf 2.61 and libtool 1.5.26 (csilvers)
-Fri Oct 3 15:16:46 2008 Google Inc.
+* Fri Oct 3 15:16:46 2008 Google Inc.
- * google-gflags: version 1.0
- * Add a missing newline to an error string (bcmills)
- * (otherwise exactly the same as gflags 1.0rc2)
+ - google-gflags: version 1.0
+ - Add a missing newline to an error string (bcmills)
+ - (otherwise exactly the same as gflags 1.0rc2)
-Thu Sep 18 12:58:05 2008 Google Inc.
+* Thu Sep 18 12:58:05 2008 Google Inc.
- * google-gflags: version 1.0rc2
- * Report current flag values in --helpxml (hdn)
- * Fix compilation troubles with gcc 4.3.3 (simonb)
- * BUG FIX: I was missing a std:: in DECLARE_string (csilvers)
- * BUG FIX: Clarify in docs how to specify --bool flags (csilvers)
- * BUG FIX: Fix --helpshort for source files not in a subdir (csilvers)
- * BUG FIX: Fix python unittest for 64-bit builds (bcmills)
+ - google-gflags: version 1.0rc2
+ - Report current flag values in --helpxml (hdn)
+ - Fix compilation troubles with gcc 4.3.3 (simonb)
+ - BUG FIX: I was missing a std:: in DECLARE_string (csilvers)
+ - BUG FIX: Clarify in docs how to specify --bool flags (csilvers)
+ - BUG FIX: Fix --helpshort for source files not in a subdir (csilvers)
+ - BUG FIX: Fix python unittest for 64-bit builds (bcmills)
-Tue Aug 19 16:15:48 2008
+* Tue Aug 19 16:15:48 2008
- * google-gflags: version 1.0rc1
- * Move #include files from google/ to gflags/ (csilvers)
- * Small optimizations to reduce binary (library) size (jyrki)
- * BUGFIX: forgot a std:: in one of the .h files (csilvers)
- * Speed up locking by making sure calls are inlined (ajenjo)
- * 64-BIT COMPATIBILITY: Use %PRId64 instead of %lld (csilvers)
- * PORTABILITY: fix Makefile to work with Cygwin (ajenjo)
- * PORTABILITY: fix code to compile under Visual Studio (ajenjo)
- * PORTABILITY: fix code to compile under Solaris 10 with CC (csilvers)
+ - google-gflags: version 1.0rc1
+ - Move #include files from google/ to gflags/ (csilvers)
+ - Small optimizations to reduce binary (library) size (jyrki)
+ - BUGFIX: forgot a std:: in one of the .h files (csilvers)
+ - Speed up locking by making sure calls are inlined (ajenjo)
+ - 64-BIT COMPATIBILITY: Use %PRId64 instead of %lld (csilvers)
+ - PORTABILITY: fix Makefile to work with Cygwin (ajenjo)
+ - PORTABILITY: fix code to compile under Visual Studio (ajenjo)
+ - PORTABILITY: fix code to compile under Solaris 10 with CC (csilvers)
-Mon Jul 21 23:01:38 2008 Google Inc.
+* Mon Jul 21 23:01:38 2008 Google Inc.
- * google-gflags: version 0.9
- * Add the ability to validate a command-line flag (csilvers)
- * Add completion support for commandline flags in bash (daven)
- * Add -W compile flags to Makefile, when using gcc (csilvers)
- * Allow helpstring to be NULL (cristianoc)
- * Improved documentation of classes in the .cc file (csilvers)
- * Fix python bug with AppendFlagValues + shortnames (jjtswan)
- * Use bool instead of int for boolean flags in gflags.py (bcmills)
- * Simplify the way we declare flags, now more foolproof (csilvers)
- * Better error messages when bool flags collide (colohan)
- * Only evaluate DEFINE_foo macro args once (csilvers)
+ - google-gflags: version 0.9
+ - Add the ability to validate a command-line flag (csilvers)
+ - Add completion support for commandline flags in bash (daven)
+ - Add -W compile flags to Makefile, when using gcc (csilvers)
+ - Allow helpstring to be NULL (cristianoc)
+ - Improved documentation of classes in the .cc file (csilvers)
+ - Fix python bug with AppendFlagValues + shortnames (jjtswan)
+ - Use bool instead of int for boolean flags in gflags.py (bcmills)
+ - Simplify the way we declare flags, now more foolproof (csilvers)
+ - Better error messages when bool flags collide (colohan)
+ - Only evaluate DEFINE_foo macro args once (csilvers)
-Wed Mar 26 15:20:18 2008 Google Inc.
+* Wed Mar 26 15:20:18 2008 Google Inc.
- * google-gflags: version 0.8
- * Export DescribeOneFlag() in the API
- * Add support for automatic line wrapping at 80 cols for gflags.py
- * Bugfix: do not treat an isolated "-" the same as an isolated "--"
- * Update rpm spec to point to Google Code rather than sourceforge (!)
- * Improve documentation (including documenting thread-safety)
- * Improve #include hygiene
- * Improve testing
+ - google-gflags: version 0.8
+ - Export DescribeOneFlag() in the API
+ - Add support for automatic line wrapping at 80 cols for gflags.py
+ - Bugfix: do not treat an isolated "-" the same as an isolated "--"
+ - Update rpm spec to point to Google Code rather than sourceforge (!)
+ - Improve documentation (including documenting thread-safety)
+ - Improve #include hygiene
+ - Improve testing
-Thu Oct 18 11:33:20 2007 Google Inc.
+* Thu Oct 18 11:33:20 2007 Google Inc.
- * google-gflags: version 0.7
- * Deal even more correctly with libpthread not linked in (csilvers)
- * Add STRIP_LOG, an improved DO_NOT_SHOW_COMMANDLINE_HELP (sioffe)
- * Be more accurate printing default flag values in --help (dsturtevant)
- * Reduce .o file size a bit by using shorter namespace names (jeff)
- * Use relative install path, so 'setup.py --home' works (csilvers)
- * Notice when a boolean flag has a non-boolean default (bnmouli)
- * Broaden --helpshort to match foo-main.cc and foo_main.cc (hendrie)
- * Fix "no modules match" message for --helpshort, etc (hendrie)
+ - google-gflags: version 0.7
+ - Deal even more correctly with libpthread not linked in (csilvers)
+ - Add STRIP_LOG, an improved DO_NOT_SHOW_COMMANDLINE_HELP (sioffe)
+ - Be more accurate printing default flag values in --help (dsturtevant)
+ - Reduce .o file size a bit by using shorter namespace names (jeff)
+ - Use relative install path, so 'setup.py --home' works (csilvers)
+ - Notice when a boolean flag has a non-boolean default (bnmouli)
+ - Broaden --helpshort to match foo-main.cc and foo_main.cc (hendrie)
+ - Fix "no modules match" message for --helpshort, etc (hendrie)
-Wed Aug 15 07:35:51 2007 Google Inc.
+* Wed Aug 15 07:35:51 2007 Google Inc.
- * google-gflags: version 0.6
- * Deal correctly with case that libpthread is not linked in (csilvers)
- * Update Makefile/tests so we pass "make distcheck" (csilvers)
- * Document and test that last assignment to a flag wins (wan)
+ - google-gflags: version 0.6
+ - Deal correctly with case that libpthread is not linked in (csilvers)
+ - Update Makefile/tests so we pass "make distcheck" (csilvers)
+ - Document and test that last assignment to a flag wins (wan)
-Tue Jun 12 15:23:42 2007 Google Inc.
+* Tue Jun 12 15:23:42 2007 Google Inc.
- * google-gflags: version 0.5
- * Include all m4 macros in the distribution (csilvers)
- * Python: Fix broken data_files field in setup.py (sidlon)
- * Python: better string serliaizing and unparsing (abo, csimmons)
- * Fix checks for NaN and inf to work with Mac OS X (csilvers)
+ - google-gflags: version 0.5
+ - Include all m4 macros in the distribution (csilvers)
+ - Python: Fix broken data_files field in setup.py (sidlon)
+ - Python: better string serliaizing and unparsing (abo, csimmons)
+ - Fix checks for NaN and inf to work with Mac OS X (csilvers)
-Thu Apr 19 15:15:07 2007 Google Inc.
+* Thu Apr 19 15:15:07 2007 Google Inc.
- * google-gflags: version 0.4
- * Remove is_default from GetCommandLineFlagInfo (csilvers)
- * Portability fixes: includes, strtoll, gcc4.3 errors (csilvers)
- * A few doc typo cleanups (csilvers)
+ - google-gflags: version 0.4
+ - Remove is_default from GetCommandLineFlagInfo (csilvers)
+ - Portability fixes: includes, strtoll, gcc4.3 errors (csilvers)
+ - A few doc typo cleanups (csilvers)
-Wed Mar 28 12:15:56 2007 Google Inc.
+* Wed Mar 28 12:15:56 2007 Google Inc.
- * google-gflags: version 0.3
- * python portability fix: use popen instead of subprocess (csilvers)
- * Add is_default to CommandLineFlagInfo (pchien)
- * Make docs a bit prettier (csilvers)
- * Actually include the python files in the distribution! :-/ (csilvers)
+ - google-gflags: version 0.3
+ - python portability fix: use popen instead of subprocess (csilvers)
+ - Add is_default to CommandLineFlagInfo (pchien)
+ - Make docs a bit prettier (csilvers)
+ - Actually include the python files in the distribution! :-/ (csilvers)
-Mon Jan 22 15:33:06 2007 Google Inc.
+* Mon Jan 22 15:33:06 2007 Google Inc.
- * google-gflags: version 0.2
- * added support for python commandlineflags, as well as c++
- * gflags2man, a script to turn flags into a man page (dchristian)
+ - google-gflags: version 0.2
+ - added support for python commandlineflags, as well as c++
+ - gflags2man, a script to turn flags into a man page (dchristian)
-Wed Dec 13 12:37:19 2006 Google Inc.
+* Wed Dec 13 12:37:19 2006 Google Inc.
- * google-gflags: initial release:
+ - google-gflags: initial release:
The gflags package contains a library that implements commandline
flags processing. As such it's a replacement for getopt(). It
has increased flexibility, including built-in support for C++
From b6f61ab0ce802ca3f88cf497be5e91bcb64d5658 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:38:59 +0000
Subject: [PATCH 17/94] Fix bugs in package configuration file.
---
cmake/package.cmake.in | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
index 05f378f..d4419a1 100644
--- a/cmake/package.cmake.in
+++ b/cmake/package.cmake.in
@@ -19,7 +19,7 @@ if (CPACK_GENERATOR MATCHES "PackageMaker|DragNDrop")
# ------------------------------------------------------------------------------
# Debian package
-elseif ("^${CPACK_GENERATOR}$" STREQUAL "DEB")
+elseif (CPACK_GENERATOR MATCHES "DEB")
set (CPACK_PACKAGE_FILE_NAME "lib${CPACK_PACKAGE_NAME}")
if (DEVEL)
@@ -43,7 +43,7 @@ elseif ("^${CPACK_GENERATOR}$" STREQUAL "DEB")
# ------------------------------------------------------------------------------
# RPM package
-elseif ("^${CPACK_GENERATOR}$" STREQUAL "RPM")
+elseif (CPACK_GENERATOR MATCHES "RPM")
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}")
if (DEVEL)
From dc9674ee46a16b0b7fb3596e641434908bd8abe9 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:42:22 +0000
Subject: [PATCH 18/94] Remove time fields from ChangeLog entries which are not
compatible with RPM spec.
---
ChangeLog.txt | 40 ++++++++++++++++++++--------------------
1 file changed, 20 insertions(+), 20 deletions(-)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index 84a9b4e..e05a538 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,11 +1,11 @@
-* Wed Jan 25 15:09:14 2012 Google Inc.
+* Wed Jan 25 2012 Google Inc.
- gflags: version 2.0
- Changed the 'official' gflags email in setup.py/etc
- Renamed google-gflags.sln to gflags.sln
- Changed copyright text to reflect Google's relinquished ownership
-* Tue Dec 20 19:48:57 2011 Google Inc.
+* Tue Dec 20 2011 Google Inc.
- google-gflags: version 1.7
- Add CommandLineFlagInfo::flag_ptr pointing to current storage (musji)
@@ -14,7 +14,7 @@
- Fix a bug in StringPrintf() that affected large strings (csilvers)
- Die at configure-time when g++ isn't installed
-* Fri Jul 29 19:05:21 2011 Google Inc.
+* Fri Jul 29 2011 Google Inc.
- google-gflags: version 1.6
- BUGFIX: Fix a bug where we were leaving out a required $(top_srcdir)
@@ -26,7 +26,7 @@
- Change ReparseCommandLineFlags to return void (csilvers)
- Some doc typofixes and example augmentation (various)
-* Mon Jan 24 16:11:35 2011 Google Inc.
+* Mon Jan 24 2011 Google Inc.
- google-gflags: version 1.5
- Better reporting of current vs default value (handler)
@@ -35,7 +35,7 @@
- Use our own string typedef in case string is redefined (csilvers)
- Updated to autoconf 2.65
-* Wed Oct 13 17:40:12 2010 Google Inc.
+* Wed Oct 13 2010 Google Inc.
- google-gflags: version 1.4
- Add a check to prevent passing 0 to DEFINE_string (jorg)
@@ -46,7 +46,7 @@
- Update the NEWS file to be non-empty
- Add pkg-config (.pc) files for libgflags and libgflags_nothreads
-* Mon Jan 4 18:09:30 2010 Google Inc.
+* Mon Jan 4 2010 Google Inc.
- google-gflags: version 1.3
- PORTABILITY: can now build and run tests under MSVC (csilvers)
@@ -57,7 +57,7 @@
- Makefile fix: $(srcdir) -> $(top_srcdir) in one place (csilvres)
- INSTALL: autotools to autoconf v2.64 + automake v1.11 (csilvers)
-* Thu Sep 10 12:53:04 2009 Google Inc.
+* Thu Sep 10 2009 Google Inc.
- google-gflags: version 1.2
- PORTABILITY: can now build and run tests under mingw (csilvers)
@@ -66,7 +66,7 @@
- Protect against a hypothetical global d'tor mutex problem (csilvers)
- BUGFIX: can now define a flag after 'using namespace google' (hamaji)
-* Tue Apr 14 12:35:25 2009 Google Inc.
+* Tue Apr 14 2009 Google Inc.
- google-gflags: version 1.1
- Add both foo and nofoo for boolean flags, with --undefok (andychu)
@@ -84,13 +84,13 @@
- PORTABILITY: #include more headers to satify new gcc's (csilvers)
- INSTALL: Updated to autoconf 2.61 and libtool 1.5.26 (csilvers)
-* Fri Oct 3 15:16:46 2008 Google Inc.
+* Fri Oct 3 2008 Google Inc.
- google-gflags: version 1.0
- Add a missing newline to an error string (bcmills)
- (otherwise exactly the same as gflags 1.0rc2)
-* Thu Sep 18 12:58:05 2008 Google Inc.
+* Thu Sep 18 2008 Google Inc.
- google-gflags: version 1.0rc2
- Report current flag values in --helpxml (hdn)
@@ -100,7 +100,7 @@
- BUG FIX: Fix --helpshort for source files not in a subdir (csilvers)
- BUG FIX: Fix python unittest for 64-bit builds (bcmills)
-* Tue Aug 19 16:15:48 2008
+* Tue Aug 19 2008
- google-gflags: version 1.0rc1
- Move #include files from google/ to gflags/ (csilvers)
@@ -112,7 +112,7 @@
- PORTABILITY: fix code to compile under Visual Studio (ajenjo)
- PORTABILITY: fix code to compile under Solaris 10 with CC (csilvers)
-* Mon Jul 21 23:01:38 2008 Google Inc.
+* Mon Jul 21 2008 Google Inc.
- google-gflags: version 0.9
- Add the ability to validate a command-line flag (csilvers)
@@ -126,7 +126,7 @@
- Better error messages when bool flags collide (colohan)
- Only evaluate DEFINE_foo macro args once (csilvers)
-* Wed Mar 26 15:20:18 2008 Google Inc.
+* Wed Mar 26 Google Inc.
- google-gflags: version 0.8
- Export DescribeOneFlag() in the API
@@ -137,7 +137,7 @@
- Improve #include hygiene
- Improve testing
-* Thu Oct 18 11:33:20 2007 Google Inc.
+* Thu Oct 18 2007 Google Inc.
- google-gflags: version 0.7
- Deal even more correctly with libpthread not linked in (csilvers)
@@ -149,14 +149,14 @@
- Broaden --helpshort to match foo-main.cc and foo_main.cc (hendrie)
- Fix "no modules match" message for --helpshort, etc (hendrie)
-* Wed Aug 15 07:35:51 2007 Google Inc.
+* Wed Aug 15 2007 Google Inc.
- google-gflags: version 0.6
- Deal correctly with case that libpthread is not linked in (csilvers)
- Update Makefile/tests so we pass "make distcheck" (csilvers)
- Document and test that last assignment to a flag wins (wan)
-* Tue Jun 12 15:23:42 2007 Google Inc.
+* Tue Jun 12 2007 Google Inc.
- google-gflags: version 0.5
- Include all m4 macros in the distribution (csilvers)
@@ -164,14 +164,14 @@
- Python: better string serliaizing and unparsing (abo, csimmons)
- Fix checks for NaN and inf to work with Mac OS X (csilvers)
-* Thu Apr 19 15:15:07 2007 Google Inc.
+* Thu Apr 19 2007 Google Inc.
- google-gflags: version 0.4
- Remove is_default from GetCommandLineFlagInfo (csilvers)
- Portability fixes: includes, strtoll, gcc4.3 errors (csilvers)
- A few doc typo cleanups (csilvers)
-* Wed Mar 28 12:15:56 2007 Google Inc.
+* Wed Mar 28 2007 Google Inc.
- google-gflags: version 0.3
- python portability fix: use popen instead of subprocess (csilvers)
@@ -179,13 +179,13 @@
- Make docs a bit prettier (csilvers)
- Actually include the python files in the distribution! :-/ (csilvers)
-* Mon Jan 22 15:33:06 2007 Google Inc.
+* Mon Jan 22 2007 Google Inc.
- google-gflags: version 0.2
- added support for python commandlineflags, as well as c++
- gflags2man, a script to turn flags into a man page (dchristian)
-* Wed Dec 13 12:37:19 2006 Google Inc.
+* Wed Dec 13 2006 Google Inc.
- google-gflags: initial release:
The gflags package contains a library that implements commandline
From 313e39e323cc0a72bcca10ce93690b6c818d1c45 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:49:21 +0000
Subject: [PATCH 19/94] Add missing name to ChangeLog entry and further format
changes.
---
ChangeLog.txt | 333 ++++++++++++++++++++++++++------------------------
1 file changed, 174 insertions(+), 159 deletions(-)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index e05a538..cddca1c 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,195 +1,210 @@
-* Wed Jan 25 2012 Google Inc.
+-------------------------------------------------------------------
+* Wed Jan 25 2012 - Google Inc.
- - gflags: version 2.0
- - Changed the 'official' gflags email in setup.py/etc
- - Renamed google-gflags.sln to gflags.sln
- - Changed copyright text to reflect Google's relinquished ownership
+- gflags: version 2.0
+- Changed the 'official' gflags email in setup.py/etc
+- Renamed google-gflags.sln to gflags.sln
+- Changed copyright text to reflect Google's relinquished ownership
-* Tue Dec 20 2011 Google Inc.
+-------------------------------------------------------------------
+* Tue Dec 20 2011 - Google Inc.
- - google-gflags: version 1.7
- - Add CommandLineFlagInfo::flag_ptr pointing to current storage (musji)
- - PORTING: flush after writing to stderr, needed on cygwin
- - PORTING: Clean up the GFLAGS_DLL_DECL stuff better
- - Fix a bug in StringPrintf() that affected large strings (csilvers)
- - Die at configure-time when g++ isn't installed
+- google-gflags: version 1.7
+- Add CommandLineFlagInfo::flag_ptr pointing to current storage (musji)
+- PORTING: flush after writing to stderr, needed on cygwin
+- PORTING: Clean up the GFLAGS_DLL_DECL stuff better
+- Fix a bug in StringPrintf() that affected large strings (csilvers)
+- Die at configure-time when g++ isn't installed
-* Fri Jul 29 2011 Google Inc.
+-------------------------------------------------------------------
+* Fri Jul 29 2011 - Google Inc.
- - google-gflags: version 1.6
- - BUGFIX: Fix a bug where we were leaving out a required $(top_srcdir)
- - Fix definition of clstring (jyrki)
- - Split up flag declares into its own file (jyrki)
- - Add --version support (csilvers)
- - Update the README for gflags with static libs
- - Update acx_pthread.m4 for nostdlib
- - Change ReparseCommandLineFlags to return void (csilvers)
- - Some doc typofixes and example augmentation (various)
+- google-gflags: version 1.6
+- BUGFIX: Fix a bug where we were leaving out a required $(top_srcdir)
+- Fix definition of clstring (jyrki)
+- Split up flag declares into its own file (jyrki)
+- Add --version support (csilvers)
+- Update the README for gflags with static libs
+- Update acx_pthread.m4 for nostdlib
+- Change ReparseCommandLineFlags to return void (csilvers)
+- Some doc typofixes and example augmentation (various)
-* Mon Jan 24 2011 Google Inc.
+-------------------------------------------------------------------
+* Mon Jan 24 2011 - Google Inc.
- - google-gflags: version 1.5
- - Better reporting of current vs default value (handler)
- - Add API for cleaning up of memory at program-exit (jmarantz)
- - Fix macros to work inside namespaces (csilvers)
- - Use our own string typedef in case string is redefined (csilvers)
- - Updated to autoconf 2.65
+- google-gflags: version 1.5
+- Better reporting of current vs default value (handler)
+- Add API for cleaning up of memory at program-exit (jmarantz)
+- Fix macros to work inside namespaces (csilvers)
+- Use our own string typedef in case string is redefined (csilvers)
+- Updated to autoconf 2.65
-* Wed Oct 13 2010 Google Inc.
+-------------------------------------------------------------------
+* Wed Oct 13 2010 - Google Inc.
- - google-gflags: version 1.4
- - Add a check to prevent passing 0 to DEFINE_string (jorg)
- - Reduce compile (.o) size (jyrki)
- - Some small changes to quiet debug compiles (alexk)
- - PORTING: better support static linking on windows (csilvers)
- - DOCUMENTATION: change default values, use validators, etc.
- - Update the NEWS file to be non-empty
- - Add pkg-config (.pc) files for libgflags and libgflags_nothreads
+- google-gflags: version 1.4
+- Add a check to prevent passing 0 to DEFINE_string (jorg)
+- Reduce compile (.o) size (jyrki)
+- Some small changes to quiet debug compiles (alexk)
+- PORTING: better support static linking on windows (csilvers)
+- DOCUMENTATION: change default values, use validators, etc.
+- Update the NEWS file to be non-empty
+- Add pkg-config (.pc) files for libgflags and libgflags_nothreads
-* Mon Jan 4 2010 Google Inc.
+-------------------------------------------------------------------
+* Mon Jan 4 2010 - Google Inc.
- - google-gflags: version 1.3
- - PORTABILITY: can now build and run tests under MSVC (csilvers)
- - Remove the python gflags code, which is now its own package (tansell)
- - Clarify that "last flag wins" in the docs (csilvers)
- - Comment danger of using GetAllFlags in validators (wojtekm)
- - PORTABILITY: Some fixes necessary for c++0x (mboerger)
- - Makefile fix: $(srcdir) -> $(top_srcdir) in one place (csilvres)
- - INSTALL: autotools to autoconf v2.64 + automake v1.11 (csilvers)
+- google-gflags: version 1.3
+- PORTABILITY: can now build and run tests under MSVC (csilvers)
+- Remove the python gflags code, which is now its own package (tansell)
+- Clarify that "last flag wins" in the docs (csilvers)
+- Comment danger of using GetAllFlags in validators (wojtekm)
+- PORTABILITY: Some fixes necessary for c++0x (mboerger)
+- Makefile fix: $(srcdir) -> $(top_srcdir) in one place (csilvres)
+- INSTALL: autotools to autoconf v2.64 + automake v1.11 (csilvers)
-* Thu Sep 10 2009 Google Inc.
+-------------------------------------------------------------------
+* Thu Sep 10 2009 - Google Inc.
- - google-gflags: version 1.2
- - PORTABILITY: can now build and run tests under mingw (csilvers)
- - Using a string arg for a bool flag is a compile-time error (rbayardo)
- - Add --helpxml to gflags.py (salcianu)
- - Protect against a hypothetical global d'tor mutex problem (csilvers)
- - BUGFIX: can now define a flag after 'using namespace google' (hamaji)
+- google-gflags: version 1.2
+- PORTABILITY: can now build and run tests under mingw (csilvers)
+- Using a string arg for a bool flag is a compile-time error (rbayardo)
+- Add --helpxml to gflags.py (salcianu)
+- Protect against a hypothetical global d'tor mutex problem (csilvers)
+- BUGFIX: can now define a flag after 'using namespace google' (hamaji)
-* Tue Apr 14 2009 Google Inc.
+-------------------------------------------------------------------
+* Tue Apr 14 2009 - Google Inc.
- - google-gflags: version 1.1
- - Add both foo and nofoo for boolean flags, with --undefok (andychu)
- - Better document how validators work (wojtekm)
- - Improve binary-detection for bash-completion (mtamsky)
- - Python: Add a concept of "key flags", used with --help (salcianu)
- - Python: Robustify flag_values (salcianu)
- - Python: Add a new DEFINE_bool alias (keir, andrewliu)
- - Python: Do module introspection based on module name (dsturtevant)
- - Fix autoconf a bit better, especially on windows and solaris (ajenjo)
- - BUG FIX: gflags_nothreads was linking against the wrong lib (ajenjo)
- - BUG FIX: threads-detection failed on FreeBSD; replace it (ajenjo)
- - PORTABILITY: Quiet an internal compiler error with SUSE 10 (csilvers)
- - PORTABILITY: Update deb.sh for more recenty debuilds (csilvers)
- - PORTABILITY: #include more headers to satify new gcc's (csilvers)
- - INSTALL: Updated to autoconf 2.61 and libtool 1.5.26 (csilvers)
+- google-gflags: version 1.1
+- Add both foo and nofoo for boolean flags, with --undefok (andychu)
+- Better document how validators work (wojtekm)
+- Improve binary-detection for bash-completion (mtamsky)
+- Python: Add a concept of "key flags", used with --help (salcianu)
+- Python: Robustify flag_values (salcianu)
+- Python: Add a new DEFINE_bool alias (keir, andrewliu)
+- Python: Do module introspection based on module name (dsturtevant)
+- Fix autoconf a bit better, especially on windows and solaris (ajenjo)
+- BUG FIX: gflags_nothreads was linking against the wrong lib (ajenjo)
+- BUG FIX: threads-detection failed on FreeBSD; replace it (ajenjo)
+- PORTABILITY: Quiet an internal compiler error with SUSE 10 (csilvers)
+- PORTABILITY: Update deb.sh for more recenty debuilds (csilvers)
+- PORTABILITY: #include more headers to satify new gcc's (csilvers)
+- INSTALL: Updated to autoconf 2.61 and libtool 1.5.26 (csilvers)
-* Fri Oct 3 2008 Google Inc.
+-------------------------------------------------------------------
+* Fri Oct 3 2008 - Google Inc.
- - google-gflags: version 1.0
- - Add a missing newline to an error string (bcmills)
- - (otherwise exactly the same as gflags 1.0rc2)
+- google-gflags: version 1.0
+- Add a missing newline to an error string (bcmills)
+- (otherwise exactly the same as gflags 1.0rc2)
-* Thu Sep 18 2008 Google Inc.
+-------------------------------------------------------------------
+* Thu Sep 18 2008 - Google Inc.
- - google-gflags: version 1.0rc2
- - Report current flag values in --helpxml (hdn)
- - Fix compilation troubles with gcc 4.3.3 (simonb)
- - BUG FIX: I was missing a std:: in DECLARE_string (csilvers)
- - BUG FIX: Clarify in docs how to specify --bool flags (csilvers)
- - BUG FIX: Fix --helpshort for source files not in a subdir (csilvers)
- - BUG FIX: Fix python unittest for 64-bit builds (bcmills)
-
-* Tue Aug 19 2008
+- google-gflags: version 1.0rc2
+- Report current flag values in --helpxml (hdn)
+- Fix compilation troubles with gcc 4.3.3 (simonb)
+- BUG FIX: I was missing a std:: in DECLARE_string (csilvers)
+- BUG FIX: Clarify in docs how to specify --bool flags (csilvers)
+- BUG FIX: Fix --helpshort for source files not in a subdir (csilvers)
+- BUG FIX: Fix python unittest for 64-bit builds (bcmills)
- - google-gflags: version 1.0rc1
- - Move #include files from google/ to gflags/ (csilvers)
- - Small optimizations to reduce binary (library) size (jyrki)
- - BUGFIX: forgot a std:: in one of the .h files (csilvers)
- - Speed up locking by making sure calls are inlined (ajenjo)
- - 64-BIT COMPATIBILITY: Use %PRId64 instead of %lld (csilvers)
- - PORTABILITY: fix Makefile to work with Cygwin (ajenjo)
- - PORTABILITY: fix code to compile under Visual Studio (ajenjo)
- - PORTABILITY: fix code to compile under Solaris 10 with CC (csilvers)
+-------------------------------------------------------------------
+* Tue Aug 19 2008 - Google Inc.
-* Mon Jul 21 2008 Google Inc.
+- google-gflags: version 1.0rc1
+- Move #include files from google/ to gflags/ (csilvers)
+- Small optimizations to reduce binary (library) size (jyrki)
+- BUGFIX: forgot a std:: in one of the .h files (csilvers)
+- Speed up locking by making sure calls are inlined (ajenjo)
+- 64-BIT COMPATIBILITY: Use %PRId64 instead of %lld (csilvers)
+- PORTABILITY: fix Makefile to work with Cygwin (ajenjo)
+- PORTABILITY: fix code to compile under Visual Studio (ajenjo)
+- PORTABILITY: fix code to compile under Solaris 10 with CC (csilvers)
- - google-gflags: version 0.9
- - Add the ability to validate a command-line flag (csilvers)
- - Add completion support for commandline flags in bash (daven)
- - Add -W compile flags to Makefile, when using gcc (csilvers)
- - Allow helpstring to be NULL (cristianoc)
- - Improved documentation of classes in the .cc file (csilvers)
- - Fix python bug with AppendFlagValues + shortnames (jjtswan)
- - Use bool instead of int for boolean flags in gflags.py (bcmills)
- - Simplify the way we declare flags, now more foolproof (csilvers)
- - Better error messages when bool flags collide (colohan)
- - Only evaluate DEFINE_foo macro args once (csilvers)
+-------------------------------------------------------------------
+* Mon Jul 21 2008 - Google Inc.
-* Wed Mar 26 Google Inc.
+- google-gflags: version 0.9
+- Add the ability to validate a command-line flag (csilvers)
+- Add completion support for commandline flags in bash (daven)
+- Add -W compile flags to Makefile, when using gcc (csilvers)
+- Allow helpstring to be NULL (cristianoc)
+- Improved documentation of classes in the .cc file (csilvers)
+- Fix python bug with AppendFlagValues + shortnames (jjtswan)
+- Use bool instead of int for boolean flags in gflags.py (bcmills)
+- Simplify the way we declare flags, now more foolproof (csilvers)
+- Better error messages when bool flags collide (colohan)
+- Only evaluate DEFINE_foo macro args once (csilvers)
- - google-gflags: version 0.8
- - Export DescribeOneFlag() in the API
- - Add support for automatic line wrapping at 80 cols for gflags.py
- - Bugfix: do not treat an isolated "-" the same as an isolated "--"
- - Update rpm spec to point to Google Code rather than sourceforge (!)
- - Improve documentation (including documenting thread-safety)
- - Improve #include hygiene
- - Improve testing
-
-* Thu Oct 18 2007 Google Inc.
+-------------------------------------------------------------------
+* Wed Mar 26 - Google Inc.
- - google-gflags: version 0.7
- - Deal even more correctly with libpthread not linked in (csilvers)
- - Add STRIP_LOG, an improved DO_NOT_SHOW_COMMANDLINE_HELP (sioffe)
- - Be more accurate printing default flag values in --help (dsturtevant)
- - Reduce .o file size a bit by using shorter namespace names (jeff)
- - Use relative install path, so 'setup.py --home' works (csilvers)
- - Notice when a boolean flag has a non-boolean default (bnmouli)
- - Broaden --helpshort to match foo-main.cc and foo_main.cc (hendrie)
- - Fix "no modules match" message for --helpshort, etc (hendrie)
+- google-gflags: version 0.8
+- Export DescribeOneFlag() in the API
+- Add support for automatic line wrapping at 80 cols for gflags.py
+- Bugfix: do not treat an isolated "-" the same as an isolated "--"
+- Update rpm spec to point to Google Code rather than sourceforge (!)
+- Improve documentation (including documenting thread-safety)
+- Improve #include hygiene
+- Improve testing
-* Wed Aug 15 2007 Google Inc.
+-------------------------------------------------------------------
+* Thu Oct 18 2007 - Google Inc.
- - google-gflags: version 0.6
- - Deal correctly with case that libpthread is not linked in (csilvers)
- - Update Makefile/tests so we pass "make distcheck" (csilvers)
- - Document and test that last assignment to a flag wins (wan)
+- google-gflags: version 0.7
+- Deal even more correctly with libpthread not linked in (csilvers)
+- Add STRIP_LOG, an improved DO_NOT_SHOW_COMMANDLINE_HELP (sioffe)
+- Be more accurate printing default flag values in --help (dsturtevant)
+- Reduce .o file size a bit by using shorter namespace names (jeff)
+- Use relative install path, so 'setup.py --home' works (csilvers)
+- Notice when a boolean flag has a non-boolean default (bnmouli)
+- Broaden --helpshort to match foo-main.cc and foo_main.cc (hendrie)
+- Fix "no modules match" message for --helpshort, etc (hendrie)
-* Tue Jun 12 2007 Google Inc.
+-------------------------------------------------------------------
+* Wed Aug 15 2007 - Google Inc.
- - google-gflags: version 0.5
- - Include all m4 macros in the distribution (csilvers)
- - Python: Fix broken data_files field in setup.py (sidlon)
- - Python: better string serliaizing and unparsing (abo, csimmons)
- - Fix checks for NaN and inf to work with Mac OS X (csilvers)
-
-* Thu Apr 19 2007 Google Inc.
+- google-gflags: version 0.6
+- Deal correctly with case that libpthread is not linked in (csilvers)
+- Update Makefile/tests so we pass "make distcheck" (csilvers)
+- Document and test that last assignment to a flag wins (wan)
- - google-gflags: version 0.4
- - Remove is_default from GetCommandLineFlagInfo (csilvers)
- - Portability fixes: includes, strtoll, gcc4.3 errors (csilvers)
- - A few doc typo cleanups (csilvers)
+-------------------------------------------------------------------
+* Tue Jun 12 2007 - Google Inc.
-* Wed Mar 28 2007 Google Inc.
+- google-gflags: version 0.5
+- Include all m4 macros in the distribution (csilvers)
+- Python: Fix broken data_files field in setup.py (sidlon)
+- Python: better string serliaizing and unparsing (abo, csimmons)
+- Fix checks for NaN and inf to work with Mac OS X (csilvers)
- - google-gflags: version 0.3
- - python portability fix: use popen instead of subprocess (csilvers)
- - Add is_default to CommandLineFlagInfo (pchien)
- - Make docs a bit prettier (csilvers)
- - Actually include the python files in the distribution! :-/ (csilvers)
+-------------------------------------------------------------------
+* Thu Apr 19 2007 - Google Inc.
-* Mon Jan 22 2007 Google Inc.
+- google-gflags: version 0.4
+- Remove is_default from GetCommandLineFlagInfo (csilvers)
+- Portability fixes: includes, strtoll, gcc4.3 errors (csilvers)
+- A few doc typo cleanups (csilvers)
- - google-gflags: version 0.2
- - added support for python commandlineflags, as well as c++
- - gflags2man, a script to turn flags into a man page (dchristian)
+-------------------------------------------------------------------
+* Wed Mar 28 2007 - Google Inc.
-* Wed Dec 13 2006 Google Inc.
+- google-gflags: version 0.3
+- python portability fix: use popen instead of subprocess (csilvers)
+- Add is_default to CommandLineFlagInfo (pchien)
+- Make docs a bit prettier (csilvers)
+- Actually include the python files in the distribution! :-/ (csilvers)
- - google-gflags: initial release:
- The gflags package contains a library that implements commandline
- flags processing. As such it's a replacement for getopt(). It
- has increased flexibility, including built-in support for C++
- types like string, and the ability to define flags in the source
- file in which they're used.
+-------------------------------------------------------------------
+* Mon Jan 22 2007 - Google Inc.
+
+- google-gflags: version 0.2
+- added support for python commandlineflags, as well as c++
+- gflags2man, a script to turn flags into a man page (dchristian)
+
+-------------------------------------------------------------------
+* Wed Dec 13 2006 - Google Inc.
+
+- google-gflags: version 0.1
From 4258af12b715570a3ef29ffd1f75b72a430aa40a Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:51:30 +0000
Subject: [PATCH 20/94] Remove separating lines from ChangeLog again.
---
ChangeLog.txt | 20 --------------------
1 file changed, 20 deletions(-)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index cddca1c..da3187d 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,4 +1,3 @@
--------------------------------------------------------------------
* Wed Jan 25 2012 - Google Inc.
- gflags: version 2.0
@@ -6,7 +5,6 @@
- Renamed google-gflags.sln to gflags.sln
- Changed copyright text to reflect Google's relinquished ownership
--------------------------------------------------------------------
* Tue Dec 20 2011 - Google Inc.
- google-gflags: version 1.7
@@ -16,7 +14,6 @@
- Fix a bug in StringPrintf() that affected large strings (csilvers)
- Die at configure-time when g++ isn't installed
--------------------------------------------------------------------
* Fri Jul 29 2011 - Google Inc.
- google-gflags: version 1.6
@@ -29,7 +26,6 @@
- Change ReparseCommandLineFlags to return void (csilvers)
- Some doc typofixes and example augmentation (various)
--------------------------------------------------------------------
* Mon Jan 24 2011 - Google Inc.
- google-gflags: version 1.5
@@ -39,7 +35,6 @@
- Use our own string typedef in case string is redefined (csilvers)
- Updated to autoconf 2.65
--------------------------------------------------------------------
* Wed Oct 13 2010 - Google Inc.
- google-gflags: version 1.4
@@ -51,7 +46,6 @@
- Update the NEWS file to be non-empty
- Add pkg-config (.pc) files for libgflags and libgflags_nothreads
--------------------------------------------------------------------
* Mon Jan 4 2010 - Google Inc.
- google-gflags: version 1.3
@@ -63,7 +57,6 @@
- Makefile fix: $(srcdir) -> $(top_srcdir) in one place (csilvres)
- INSTALL: autotools to autoconf v2.64 + automake v1.11 (csilvers)
--------------------------------------------------------------------
* Thu Sep 10 2009 - Google Inc.
- google-gflags: version 1.2
@@ -73,7 +66,6 @@
- Protect against a hypothetical global d'tor mutex problem (csilvers)
- BUGFIX: can now define a flag after 'using namespace google' (hamaji)
--------------------------------------------------------------------
* Tue Apr 14 2009 - Google Inc.
- google-gflags: version 1.1
@@ -92,14 +84,12 @@
- PORTABILITY: #include more headers to satify new gcc's (csilvers)
- INSTALL: Updated to autoconf 2.61 and libtool 1.5.26 (csilvers)
--------------------------------------------------------------------
* Fri Oct 3 2008 - Google Inc.
- google-gflags: version 1.0
- Add a missing newline to an error string (bcmills)
- (otherwise exactly the same as gflags 1.0rc2)
--------------------------------------------------------------------
* Thu Sep 18 2008 - Google Inc.
- google-gflags: version 1.0rc2
@@ -110,7 +100,6 @@
- BUG FIX: Fix --helpshort for source files not in a subdir (csilvers)
- BUG FIX: Fix python unittest for 64-bit builds (bcmills)
--------------------------------------------------------------------
* Tue Aug 19 2008 - Google Inc.
- google-gflags: version 1.0rc1
@@ -123,7 +112,6 @@
- PORTABILITY: fix code to compile under Visual Studio (ajenjo)
- PORTABILITY: fix code to compile under Solaris 10 with CC (csilvers)
--------------------------------------------------------------------
* Mon Jul 21 2008 - Google Inc.
- google-gflags: version 0.9
@@ -138,7 +126,6 @@
- Better error messages when bool flags collide (colohan)
- Only evaluate DEFINE_foo macro args once (csilvers)
--------------------------------------------------------------------
* Wed Mar 26 - Google Inc.
- google-gflags: version 0.8
@@ -150,7 +137,6 @@
- Improve #include hygiene
- Improve testing
--------------------------------------------------------------------
* Thu Oct 18 2007 - Google Inc.
- google-gflags: version 0.7
@@ -163,7 +149,6 @@
- Broaden --helpshort to match foo-main.cc and foo_main.cc (hendrie)
- Fix "no modules match" message for --helpshort, etc (hendrie)
--------------------------------------------------------------------
* Wed Aug 15 2007 - Google Inc.
- google-gflags: version 0.6
@@ -171,7 +156,6 @@
- Update Makefile/tests so we pass "make distcheck" (csilvers)
- Document and test that last assignment to a flag wins (wan)
--------------------------------------------------------------------
* Tue Jun 12 2007 - Google Inc.
- google-gflags: version 0.5
@@ -180,7 +164,6 @@
- Python: better string serliaizing and unparsing (abo, csimmons)
- Fix checks for NaN and inf to work with Mac OS X (csilvers)
--------------------------------------------------------------------
* Thu Apr 19 2007 - Google Inc.
- google-gflags: version 0.4
@@ -188,7 +171,6 @@
- Portability fixes: includes, strtoll, gcc4.3 errors (csilvers)
- A few doc typo cleanups (csilvers)
--------------------------------------------------------------------
* Wed Mar 28 2007 - Google Inc.
- google-gflags: version 0.3
@@ -197,14 +179,12 @@
- Make docs a bit prettier (csilvers)
- Actually include the python files in the distribution! :-/ (csilvers)
--------------------------------------------------------------------
* Mon Jan 22 2007 - Google Inc.
- google-gflags: version 0.2
- added support for python commandlineflags, as well as c++
- gflags2man, a script to turn flags into a man page (dchristian)
--------------------------------------------------------------------
* Wed Dec 13 2006 - Google Inc.
- google-gflags: version 0.1
From 4b1ca7d5f147dfdd8a845a5ea2749220ff9e6eb1 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 03:53:50 +0000
Subject: [PATCH 21/94] Add missing year to ChangeLog entry. RPM is now
generated successfully.
---
ChangeLog.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index da3187d..4476a99 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -126,7 +126,7 @@
- Better error messages when bool flags collide (colohan)
- Only evaluate DEFINE_foo macro args once (csilvers)
-* Wed Mar 26 - Google Inc.
+* Wed Mar 26 2008 - Google Inc.
- google-gflags: version 0.8
- Export DescribeOneFlag() in the API
From 52bf642cf8c9c0f662fc613fb840178e3074edcd Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 04:06:13 +0000
Subject: [PATCH 22/94] Remove brief description from README to avoid duplicate
appearance in RPM and other packages.
---
README.txt | 2 --
1 file changed, 2 deletions(-)
diff --git a/README.txt b/README.txt
index bda07ef..b5ecbbb 100644
--- a/README.txt
+++ b/README.txt
@@ -1,5 +1,3 @@
-A commandline flags library that allows for distributed flags.
-
This package contains a library that implements commandline flags
processing. As such it's a replacement for getopt(). It has increased
flexibility, including built-in support for C++ types like string, and
From fc6e079cfce76fa3a5dfdbbf356d6e7187a56129 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 04:09:02 +0000
Subject: [PATCH 23/94] Change package vendor to just a name.
---
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 8aec4b8..4fa4603 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -338,7 +338,7 @@ if (BUILD_PACKAGING)
mark_as_advanced (CPACK_GENERATOR CPACK_SOURCE_GENERATOR)
# common package information
- set (CPACK_PACKAGE_VENDOR "Open Source by Andreas Schuh")
+ set (CPACK_PACKAGE_VENDOR "Andreas Schuh")
set (CPACK_PACKAGE_CONTACT "google-gflags@googlegroups.com")
set (CPACK_PACKAGE_NAME "${PACKAGE_NAME}")
set (CPACK_PACKAGE_VERSION "${PACKAGE_VERSION}")
From e8890f274af67c6e6f6f3a98bb3641baced364e4 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 04:20:15 +0000
Subject: [PATCH 24/94] Set additional DEB CPack variables in package.cmake.in.
---
CMakeLists.txt | 2 +-
cmake/package.cmake.in | 6 ++++--
2 files changed, 5 insertions(+), 3 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 4fa4603..759fcb2 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -354,7 +354,7 @@ if (BUILD_PACKAGING)
set (CPACK_PACKAGE_RELOCATABLE TRUE)
set (CPACK_MONOLITHIC_INSTALL TRUE)
- # RPM specification
+ # RPM package information -- used in cmake/package.cmake.in also for DEB
set (CPACK_RPM_PACKAGE_GROUP "Development/Libraries")
set (CPACK_RPM_PACKAGE_LICENSE "BSD")
set (CPACK_RPM_PACKAGE_URL "http://code.google.com/p/gflags")
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
index d4419a1..c3ebdc9 100644
--- a/cmake/package.cmake.in
+++ b/cmake/package.cmake.in
@@ -38,8 +38,10 @@ elseif (CPACK_GENERATOR MATCHES "DEB")
set (CPACK_DEBIAN_PACKAGE_ARCHITECTURE i386)
endif ()
set (CPACK_DEBIAN_PACKAGE_DEPENDS)
- set (CPACK_DEBIAN_PACKAGE_SECTION devel)
- set (CPACK_DEBIAN_PACKAGE_PRIORITY optional)
+ set (CPACK_DEBIAN_PACKAGE_SECTION "devel")
+ set (CPACK_DEBIAN_PACKAGE_PRIORITY "optional")
+ set (CPACK_DEBIAN_PACKAGE_HOMEPAGE "${CPACK_RPM_PACKAGE_URL}")
+ set (CPACK_DEBIAN_PACKAGE_MAINTAINER "${CPACK_PACKAGE_VENDOR}")
# ------------------------------------------------------------------------------
# RPM package
From a49a656f1e2664811f8aa2dc1305210f9e74832f Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 04:24:57 +0000
Subject: [PATCH 25/94] Use dpkg --print-architecture also for RPM generator.
---
cmake/package.cmake.in | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
index c3ebdc9..f0b9fd0 100644
--- a/cmake/package.cmake.in
+++ b/cmake/package.cmake.in
@@ -37,6 +37,7 @@ elseif (CPACK_GENERATOR MATCHES "DEB")
if (NOT RV EQUAL 0)
set (CPACK_DEBIAN_PACKAGE_ARCHITECTURE i386)
endif ()
+
set (CPACK_DEBIAN_PACKAGE_DEPENDS)
set (CPACK_DEBIAN_PACKAGE_SECTION "devel")
set (CPACK_DEBIAN_PACKAGE_PRIORITY "optional")
@@ -47,6 +48,15 @@ elseif (CPACK_GENERATOR MATCHES "DEB")
# RPM package
elseif (CPACK_GENERATOR MATCHES "RPM")
+ execute_process (
+ COMMAND dpkg --print-architecture
+ RESULT_VARIABLE RV
+ OUTPUT_VARIABLE CPACK_RPM_PACKAGE_ARCHITECTURE
+ )
+ if (NOT RV EQUAL 0)
+ set (CPACK_RPM_PACKAGE_ARCHITECTURE i386)
+ endif ()
+
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}")
if (DEVEL)
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-devel")
From 978c567d02835e197d2f15dd4187160249da5951 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 04:43:01 +0000
Subject: [PATCH 26/94] Ignore packages subdirectory (if it exists).
---
.gitignore | 1 +
1 file changed, 1 insertion(+)
diff --git a/.gitignore b/.gitignore
index 737f962..39cb957 100644
--- a/.gitignore
+++ b/.gitignore
@@ -11,3 +11,4 @@ CMakeFiles/
/lib/
/test/gflags_unittest_main.cc
/test/gflags_unittest-main.cc
+/packages/
From 76f2ffadb4f393ed0c850f8cdd83307a680b97f2 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 16:02:15 +0000
Subject: [PATCH 27/94] Add ChangeLog entries for v2.1 release.
---
ChangeLog.txt | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index 4476a99..347b701 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,3 +1,13 @@
+* Thu Mar 20 2014 - Andreas Schuh
+
+- gflags: version 2.1.0
+- Build system configuration using CMake instead of autotools
+- CPack packaging support for Debian/Ubuntu, Red Hat, and Mac OS X
+- Fixed issue 54: Fix "invalid suffix on literal" (C++11)
+- Fixed issue 57: Use _strdup instead of strdup on Windows
+- Fixed issue 62: Change all preprocessor include guards to start with GFLAGS_
+- Fixed issue 64: Add DEFINE_validator macro
+
* Wed Jan 25 2012 - Google Inc.
- gflags: version 2.0
From 0100be50ece23f5708f54246a132051168526f3c Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 16:15:10 +0000
Subject: [PATCH 28/94] Add missing entry to ChangeLog for v2.1 release.
---
ChangeLog.txt | 1 +
1 file changed, 1 insertion(+)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index 347b701..9771549 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -7,6 +7,7 @@
- Fixed issue 57: Use _strdup instead of strdup on Windows
- Fixed issue 62: Change all preprocessor include guards to start with GFLAGS_
- Fixed issue 64: Add DEFINE_validator macro
+- Fixed issue 73: Warnings in Visual Studio 2010 and unable to compile unit test
* Wed Jan 25 2012 - Google Inc.
From 3e96a19026c384dae208f2d4db95b938a987772d Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 16:19:00 +0000
Subject: [PATCH 29/94] Change version to 2.1.0, i.e., use common semantic
versioning system including patch number for bug fix releases.
---
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 759fcb2..34dc4b4 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -8,7 +8,7 @@ include (utils)
# ----------------------------------------------------------------------------
# package information
set (PACKAGE_NAME "gflags")
-set (PACKAGE_VERSION "2.1")
+set (PACKAGE_VERSION "2.1.0")
set (PACKAGE_STRING "${PACKAGE_NAME} ${PACKAGE_VERSION}")
set (PACKAGE_TARNAME "${PACKAGE_NAME}-${PACKAGE_VERSION}")
set (PACKAGE_BUGREPORT "https://code.google.com/p/gflags/issues/")
From 33e2cbe2c63bdc94b5e5add7ccf7d38f3cca35e1 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 16:32:54 +0000
Subject: [PATCH 30/94] Add release notes.
---
NEWS.txt | 34 ++++++++++++++++++++++++++++++++++
1 file changed, 34 insertions(+)
diff --git a/NEWS.txt b/NEWS.txt
index f049345..4d976d7 100644
--- a/NEWS.txt
+++ b/NEWS.txt
@@ -1,3 +1,37 @@
+=== 20 March 2014 ===
+
+I've just released gflags 2.1.0.
+
+The major changes are the use of CMake for the build configuration instead
+of the autotools and packaging support through CPack. This release compiles
+with all major compilers without warnings and passed the unit tests on
+Ubuntu 12.04, Windows 7 (Visual Studio 2008 and 2010, Cygwin, MinGW), and
+Mac OS X (Xcode 5.1).
+
+The SVN repository on Google Code is now frozen and replaced by a Git
+repository such that it can be used as Git submodule by projects. The main
+hosting of this project remains at Google Code. Thanks to the distributed
+character of Git, I can push (and pull) changes from both GitHub and Google Code
+in order to keep the two public repositories in sync.
+When fixing an issue for a pull request through either of these hosting
+platforms, please reference the issue number as
+[https://code.google.com/p/support/wiki/IssueTracker#Integration_with_version_control described here].
+
+Binary and source distribution packages can be downloaded from
+[https://github.com/schuhschuh/gflags GitHub] as Google Code no longer
+permits the upload of such download packages.
+
+
+=== 14 January 2013 ===
+
+The migration of the build system to CMake is almost complete.
+What remains to be done is rewriting the tests in Python such they can be
+executed on non-Unix platforms and splitting them up into separate CTest tests.
+Though merging these changes into the master branch yet remains to be done,
+it is recommended to already start using the
+[https://github.com/schuhschuh/gflags/tree/cmake-migration cmake-migration] branch.
+
+
=== 20 April 2013 ===
More than a year has past since I (Andreas) took over the maintenance for
From 882db5d018c813cf8f037de4d4d6d9e876dd8804 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 16:35:30 +0000
Subject: [PATCH 31/94] Mention Git branching model in NEWS.
---
NEWS.txt | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/NEWS.txt b/NEWS.txt
index 4d976d7..b9a68f3 100644
--- a/NEWS.txt
+++ b/NEWS.txt
@@ -16,6 +16,10 @@ in order to keep the two public repositories in sync.
When fixing an issue for a pull request through either of these hosting
platforms, please reference the issue number as
[https://code.google.com/p/support/wiki/IssueTracker#Integration_with_version_control described here].
+For the further development, I am following the
+[http://nvie.com/posts/a-successful-git-branching-model/ Git branching model]
+with feature branch names prefixed by "feature/" and bugfix branch names
+prefixed by "bugfix/", respectively.
Binary and source distribution packages can be downloaded from
[https://github.com/schuhschuh/gflags GitHub] as Google Code no longer
From d699559081ff610f905f512b3a923bd9cabc19f0 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 20:21:30 +0000
Subject: [PATCH 32/94] Fix architecture used for RPM packages and DEB/RPM
package file names.
---
CMakeLists.txt | 26 +++++++++++++++++++++-----
cmake/package.cmake.in | 31 +++++++------------------------
2 files changed, 28 insertions(+), 29 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 34dc4b4..93d3a73 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -366,15 +366,31 @@ if (BUILD_PACKAGING)
set (CPACK_RESOURCE_FILE_README "${CMAKE_CURRENT_LIST_DIR}/cmake/README_runtime.txt")
endif ()
- # system name used for binary package file name
+ # system/architecture
if (WINDOWS)
if (CMAKE_CL_64)
set (CPACK_SYSTEM_NAME "win64")
else ()
set (CPACK_SYSTEM_NAME "win32")
endif ()
+ set (CPACK_PACKAGE_ARCHITECTURE)
else ()
string (TOLOWER "${CMAKE_SYSTEM_NAME}" CPACK_SYSTEM_NAME)
+ execute_process (
+ COMMAND dpkg --print-architecture
+ RESULT_VARIABLE RV
+ OUTPUT_VARIABLE CPACK_PACKAGE_ARCHITECTURE
+ )
+ if (RV EQUAL 0)
+ string (STRIP "${CPACK_PACKAGE_ARCHITECTURE}" CPACK_PACKAGE_ARCHITECTURE)
+ else ()
+ execute_process (COMMAND uname -m OUTPUT_VARIABLE CPACK_PACKAGE_ARCHITECTURE)
+ if (CPACK_PACKAGE_ARCHITECTURE MATCHES "x86_64")
+ set (CPACK_PACKAGE_ARCHITECTURE amd64)
+ else ()
+ set (CPACK_PACKAGE_ARCHITECTURE i386)
+ endif ()
+ endif ()
endif ()
# source package settings
@@ -383,10 +399,10 @@ if (BUILD_PACKAGING)
set (CPACK_SOURCE_IGNORE_FILES "/\\\\.git/;\\\\.swp$;\\\\.#;/#;\\\\.*~;cscope\\\\.*;/[Bb]uild[.+-_a-zA-Z0-9]*/")
# default binary package settings
- set (CPACK_INCLUDE_TOPLEVEL_DIRECTORY TRUE)
- set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}-${CPACK_PACKAGE_VERSION}-${CPACK_SYSTEM_NAME}")
- if (CMAKE_SYSTEM_PROCESSOR)
- set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CMAKE_SYSTEM_PROCESSOR}")
+ set (CPACK_INCLUDE_TOPLEVEL_DIRECTORY TRUE)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}-${CPACK_PACKAGE_VERSION}-${CPACK_SYSTEM_NAME}")
+ if (CPACK_PACKAGE_ARCHITECTURE)
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_ARCHITECTURE}")
endif ()
# generator specific configuration file
diff --git a/cmake/package.cmake.in b/cmake/package.cmake.in
index f0b9fd0..aaec792 100644
--- a/cmake/package.cmake.in
+++ b/cmake/package.cmake.in
@@ -27,40 +27,23 @@ elseif (CPACK_GENERATOR MATCHES "DEB")
else ()
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}0")
endif ()
- set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}_${CPACK_PACKAGE_VERSION}-1_${CMAKE_SYSTEM_PROCESSOR}")
-
- execute_process (
- COMMAND dpkg --print-architecture
- RESULT_VARIABLE RV
- OUTPUT_VARIABLE CPACK_DEBIAN_PACKAGE_ARCHITECTURE
- )
- if (NOT RV EQUAL 0)
- set (CPACK_DEBIAN_PACKAGE_ARCHITECTURE i386)
- endif ()
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}_${CPACK_PACKAGE_VERSION}-1_${CPACK_PACKAGE_ARCHITECTURE}")
set (CPACK_DEBIAN_PACKAGE_DEPENDS)
- set (CPACK_DEBIAN_PACKAGE_SECTION "devel")
- set (CPACK_DEBIAN_PACKAGE_PRIORITY "optional")
- set (CPACK_DEBIAN_PACKAGE_HOMEPAGE "${CPACK_RPM_PACKAGE_URL}")
- set (CPACK_DEBIAN_PACKAGE_MAINTAINER "${CPACK_PACKAGE_VENDOR}")
+ set (CPACK_DEBIAN_PACKAGE_SECTION "devel")
+ set (CPACK_DEBIAN_PACKAGE_PRIORITY "optional")
+ set (CPACK_DEBIAN_PACKAGE_HOMEPAGE "${CPACK_RPM_PACKAGE_URL}")
+ set (CPACK_DEBIAN_PACKAGE_MAINTAINER "${CPACK_PACKAGE_VENDOR}")
+ set (CPACK_DEBIAN_PACKAGE_ARCHITECTURE "${CPACK_PACKAGE_ARCHITECTURE}")
# ------------------------------------------------------------------------------
# RPM package
elseif (CPACK_GENERATOR MATCHES "RPM")
- execute_process (
- COMMAND dpkg --print-architecture
- RESULT_VARIABLE RV
- OUTPUT_VARIABLE CPACK_RPM_PACKAGE_ARCHITECTURE
- )
- if (NOT RV EQUAL 0)
- set (CPACK_RPM_PACKAGE_ARCHITECTURE i386)
- endif ()
-
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}")
if (DEVEL)
set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-devel")
endif ()
- set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_VERSION}-1_${CMAKE_SYSTEM_PROCESSOR}")
+ set (CPACK_PACKAGE_FILE_NAME "${CPACK_PACKAGE_FILE_NAME}-${CPACK_PACKAGE_VERSION}-1.${CPACK_PACKAGE_ARCHITECTURE}")
endif ()
From cf40f73c4019a08de47da53f0c7f1d8ae0e9af32 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 20 Mar 2014 20:56:05 +0000
Subject: [PATCH 33/94] Set package architecture to i386 when compiling with
-m32.
---
CMakeLists.txt | 19 +++++++++++++++++++
1 file changed, 19 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 759fcb2..faefdd2 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -375,6 +375,25 @@ if (BUILD_PACKAGING)
endif ()
else ()
string (TOLOWER "${CMAKE_SYSTEM_NAME}" CPACK_SYSTEM_NAME)
+ if (CMAKE_CXX_FLAGS MATCHES "-m32")
+ set (CPACK_PACKAGE_ARCHITECTURE i386)
+ else ()
+ execute_process (
+ COMMAND dpkg --print-architecture
+ RESULT_VARIABLE RV
+ OUTPUT_VARIABLE CPACK_PACKAGE_ARCHITECTURE
+ )
+ if (RV EQUAL 0)
+ string (STRIP "${CPACK_PACKAGE_ARCHITECTURE}" CPACK_PACKAGE_ARCHITECTURE)
+ else ()
+ execute_process (COMMAND uname -m OUTPUT_VARIABLE CPACK_PACKAGE_ARCHITECTURE)
+ if (CPACK_PACKAGE_ARCHITECTURE MATCHES "x86_64")
+ set (CPACK_PACKAGE_ARCHITECTURE amd64)
+ else ()
+ set (CPACK_PACKAGE_ARCHITECTURE i386)
+ endif ()
+ endif ()
+ endif ()
endif ()
# source package settings
From bbe1895559c61ea72faeabf1f083e0cb16bc3a6b Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sat, 22 Mar 2014 01:00:11 +0000
Subject: [PATCH 34/94] Remove devel package content summary from README
---
README.txt | 2 --
1 file changed, 2 deletions(-)
diff --git a/README.txt b/README.txt
index b5ecbbb..958c87e 100644
--- a/README.txt
+++ b/README.txt
@@ -2,5 +2,3 @@ This package contains a library that implements commandline flags
processing. As such it's a replacement for getopt(). It has increased
flexibility, including built-in support for C++ types like string, and
the ability to define flags in the source file in which they're used.
-The devel package contains static and debug libraries and header files
-for developing applications that use the gflags package.
From 09f7800768f8cc02ecaff4fdb020c195ba4d363a Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 25 Mar 2014 15:29:56 +0000
Subject: [PATCH 35/94] Use GFLAGS_IS_A_DLL=1 in public headers if
BUILD_SHARED_LIBS is enabled (Fixes issue #77).
---
CMakeLists.txt | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 93d3a73..7ada98c 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -197,6 +197,15 @@ else ()
set (GFLAGS_ATTRIBUTE_UNUSED)
endif ()
+# whenever we build a shared library (DLL on Windows), configure the public
+# headers of the API for use of this library rather than the optionally
+# also build statically linked library; users can override GFLAGS_DLL_DECL
+if (BUILD_SHARED_LIBS)
+ set (GFLAGS_IS_A_DLL 1)
+else ()
+ set (GFLAGS_IS_A_DLL 0)
+endif ()
+
configure_headers (PUBLIC_HDRS ${PUBLIC_HDRS})
configure_sources (PRIVATE_HDRS ${PRIVATE_HDRS})
configure_sources (GFLAGS_SRCS ${GFLAGS_SRCS})
From 6040eac5b35763d94af5a0cf6aff75d84f0129b6 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 25 Mar 2014 15:29:56 +0000
Subject: [PATCH 36/94] Use GFLAGS_IS_A_DLL=1 in public headers if
BUILD_SHARED_LIBS is enabled (Fixes issue #77).
---
CMakeLists.txt | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 6ed3161..4702485 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -197,6 +197,15 @@ else ()
set (GFLAGS_ATTRIBUTE_UNUSED)
endif ()
+# whenever we build a shared library (DLL on Windows), configure the public
+# headers of the API for use of this library rather than the optionally
+# also build statically linked library; users can override GFLAGS_DLL_DECL
+if (BUILD_SHARED_LIBS)
+ set (GFLAGS_IS_A_DLL 1)
+else ()
+ set (GFLAGS_IS_A_DLL 0)
+endif ()
+
configure_headers (PUBLIC_HDRS ${PUBLIC_HDRS})
configure_sources (PRIVATE_HDRS ${PRIVATE_HDRS})
configure_sources (GFLAGS_SRCS ${GFLAGS_SRCS})
From 38213112a57f48e0d86206477313bf389e13d8fa Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Wed, 26 Mar 2014 19:37:01 +0000
Subject: [PATCH 37/94] Replace GFLAGS_NAMESPACE by @GFLAGS_NAMESPACE@ in
gflags_declare.h (Fixes issue #79).
---
src/gflags_declare.h.in | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/src/gflags_declare.h.in b/src/gflags_declare.h.in
index b0548fa..b9ab9c7 100644
--- a/src/gflags_declare.h.in
+++ b/src/gflags_declare.h.in
@@ -113,13 +113,13 @@ typedef std::string clstring;
DECLARE_VARIABLE(bool, B, name)
#define DECLARE_int32(name) \
- DECLARE_VARIABLE(GFLAGS_NAMESPACE::int32, I, name)
+ DECLARE_VARIABLE(::@GFLAGS_NAMESPACE@::int32, I, name)
#define DECLARE_int64(name) \
- DECLARE_VARIABLE(GFLAGS_NAMESPACE::int64, I64, name)
+ DECLARE_VARIABLE(::@GFLAGS_NAMESPACE@::int64, I64, name)
#define DECLARE_uint64(name) \
- DECLARE_VARIABLE(GFLAGS_NAMESPACE::uint64, U64, name)
+ DECLARE_VARIABLE(::@GFLAGS_NAMESPACE@::uint64, U64, name)
#define DECLARE_double(name) \
DECLARE_VARIABLE(double, D, name)
From aff8ef820a165d373ff47614304b337d2082f9dd Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 27 Mar 2014 01:09:20 +0000
Subject: [PATCH 38/94] Add GFLAGS_INCLUDE_DIR CMake variable (Fixes issue
#80).
Both GFLAGS_NAMESPACE and GFLAGS_INCLUDE_DIR can be used to customize the installation of the gflags library. One specifies the C++ namespace name of the gflags symbols, the other the include subdirectory path of the public header files. By default, both are set to "gflags", but other Google libraries still expect "google" as C++ namespace name, but not necessarily also include path.
---
CMakeLists.txt | 15 ++++++++++++---
cmake/utils.cmake | 12 ++++++------
2 files changed, 18 insertions(+), 9 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 4702485..8afdddf 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -24,7 +24,15 @@ version_numbers (
# ----------------------------------------------------------------------------
# options
-set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
+set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
+set (GFLAGS_INCLUDE_DIR "${PACKAGE_NAME}" CACHE STRING "Include subdirectory of gflags header files.")
+
+if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
+ message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
+endif ()
+if (GFLAGS_INCLUDE_DIR MATCHES "^\\.\\.[/\\]")
+ message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must not start with parent directory reference (../)")
+endif ()
option (BUILD_SHARED_LIBS "Request build of shared libraries." OFF)
option (BUILD_STATIC_LIBS "Request build of static libraries (default if BUILD_SHARED_LIBS is OFF)." OFF)
@@ -38,6 +46,7 @@ option (INSTALL_HEADERS "Request packaging of headers and other devel
mark_as_advanced (CLEAR CMAKE_INSTALL_PREFIX)
mark_as_advanced (CMAKE_CONFIGURATION_TYPES
GFLAGS_NAMESPACE
+ GFLAGS_INCLUDE_DIR
BUILD_STATIC_LIBS
BUILD_NC_TESTS
INSTALL_HEADERS)
@@ -212,7 +221,7 @@ configure_sources (GFLAGS_SRCS ${GFLAGS_SRCS})
include_directories ("${PROJECT_SOURCE_DIR}/src")
include_directories ("${PROJECT_BINARY_DIR}/include")
-include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}")
+include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}")
# ----------------------------------------------------------------------------
# output directories
@@ -282,7 +291,7 @@ configure_file (cmake/version.cmake.in "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-co
install (TARGETS ${TARGETS} DESTINATION ${LIBRARY_INSTALL_DIR} EXPORT gflags-lib)
if (INSTALL_HEADERS)
- install (FILES ${PUBLIC_HDRS} DESTINATION ${INCLUDE_INSTALL_DIR}/${GFLAGS_NAMESPACE})
+ install (FILES ${PUBLIC_HDRS} DESTINATION ${INCLUDE_INSTALL_DIR}/${GFLAGS_INCLUDE_DIR})
install (
FILES "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-install.cmake"
RENAME ${PACKAGE_NAME}-config.cmake
diff --git a/cmake/utils.cmake b/cmake/utils.cmake
index ead2638..97c9a66 100644
--- a/cmake/utils.cmake
+++ b/cmake/utils.cmake
@@ -47,11 +47,11 @@ function (configure_headers out)
set (tmp)
foreach (src IN LISTS ARGN)
if (EXISTS "${PROJECT_SOURCE_DIR}/src/${src}.in")
- configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}" @ONLY)
- list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" @ONLY)
+ list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
else ()
- configure_file ("${PROJECT_SOURCE_DIR}/src/${src}" "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}" COPYONLY)
- list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/${src}" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" COPYONLY)
+ list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
endif ()
endforeach ()
set (${out} "${tmp}" PARENT_SCOPE)
@@ -63,8 +63,8 @@ function (configure_sources out)
set (tmp)
foreach (src IN LISTS ARGN)
if (src MATCHES ".h$" AND EXISTS "${PROJECT_SOURCE_DIR}/src/${src}.in")
- configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}" @ONLY)
- list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" @ONLY)
+ list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
else ()
list (APPEND tmp "${PROJECT_SOURCE_DIR}/src/${src}")
endif ()
From 7c80cfd87c1eb195135c91f3493b35a53fb74c88 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sat, 22 Mar 2014 01:00:11 +0000
Subject: [PATCH 39/94] Remove devel package content summary from README
---
README.txt | 2 --
1 file changed, 2 deletions(-)
diff --git a/README.txt b/README.txt
index b5ecbbb..958c87e 100644
--- a/README.txt
+++ b/README.txt
@@ -2,5 +2,3 @@ This package contains a library that implements commandline flags
processing. As such it's a replacement for getopt(). It has increased
flexibility, including built-in support for C++ types like string, and
the ability to define flags in the source file in which they're used.
-The devel package contains static and debug libraries and header files
-for developing applications that use the gflags package.
From 38c4402f58ada036f4609ade095b9fb0ae3276e2 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 25 Mar 2014 15:29:56 +0000
Subject: [PATCH 40/94] Use GFLAGS_IS_A_DLL=1 in public headers if
BUILD_SHARED_LIBS is enabled (Fixes issue #77).
---
CMakeLists.txt | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 93d3a73..7ada98c 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -197,6 +197,15 @@ else ()
set (GFLAGS_ATTRIBUTE_UNUSED)
endif ()
+# whenever we build a shared library (DLL on Windows), configure the public
+# headers of the API for use of this library rather than the optionally
+# also build statically linked library; users can override GFLAGS_DLL_DECL
+if (BUILD_SHARED_LIBS)
+ set (GFLAGS_IS_A_DLL 1)
+else ()
+ set (GFLAGS_IS_A_DLL 0)
+endif ()
+
configure_headers (PUBLIC_HDRS ${PUBLIC_HDRS})
configure_sources (PRIVATE_HDRS ${PRIVATE_HDRS})
configure_sources (GFLAGS_SRCS ${GFLAGS_SRCS})
From 0c6e5fdb3f94da4e26ab5212a0e6b01739ecc999 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 27 Mar 2014 01:09:20 +0000
Subject: [PATCH 41/94] Add GFLAGS_INCLUDE_DIR CMake variable (Fixes issue
#80).
Both GFLAGS_NAMESPACE and GFLAGS_INCLUDE_DIR can be used to customize the installation of the gflags library. One specifies the C++ namespace name of the gflags symbols, the other the include subdirectory path of the public header files. By default, both are set to "gflags", but other Google libraries still expect "google" as C++ namespace name, but not necessarily also include path.
---
CMakeLists.txt | 15 ++++++++++++---
cmake/utils.cmake | 12 ++++++------
2 files changed, 18 insertions(+), 9 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 7ada98c..bb9f5e5 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -24,7 +24,15 @@ version_numbers (
# ----------------------------------------------------------------------------
# options
-set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
+set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
+set (GFLAGS_INCLUDE_DIR "${PACKAGE_NAME}" CACHE STRING "Include subdirectory of gflags header files.")
+
+if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
+ message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
+endif ()
+if (GFLAGS_INCLUDE_DIR MATCHES "^\\.\\.[/\\]")
+ message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must not start with parent directory reference (../)")
+endif ()
option (BUILD_SHARED_LIBS "Request build of shared libraries." OFF)
option (BUILD_STATIC_LIBS "Request build of static libraries (default if BUILD_SHARED_LIBS is OFF)." OFF)
@@ -38,6 +46,7 @@ option (INSTALL_HEADERS "Request packaging of headers and other devel
mark_as_advanced (CLEAR CMAKE_INSTALL_PREFIX)
mark_as_advanced (CMAKE_CONFIGURATION_TYPES
GFLAGS_NAMESPACE
+ GFLAGS_INCLUDE_DIR
BUILD_STATIC_LIBS
BUILD_NC_TESTS
INSTALL_HEADERS)
@@ -212,7 +221,7 @@ configure_sources (GFLAGS_SRCS ${GFLAGS_SRCS})
include_directories ("${PROJECT_SOURCE_DIR}/src")
include_directories ("${PROJECT_BINARY_DIR}/include")
-include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}")
+include_directories ("${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}")
# ----------------------------------------------------------------------------
# output directories
@@ -282,7 +291,7 @@ configure_file (cmake/version.cmake.in "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-co
install (TARGETS ${TARGETS} DESTINATION ${LIBRARY_INSTALL_DIR} EXPORT gflags-lib)
if (INSTALL_HEADERS)
- install (FILES ${PUBLIC_HDRS} DESTINATION ${INCLUDE_INSTALL_DIR}/${GFLAGS_NAMESPACE})
+ install (FILES ${PUBLIC_HDRS} DESTINATION ${INCLUDE_INSTALL_DIR}/${GFLAGS_INCLUDE_DIR})
install (
FILES "${PROJECT_BINARY_DIR}/${PACKAGE_NAME}-config-install.cmake"
RENAME ${PACKAGE_NAME}-config.cmake
diff --git a/cmake/utils.cmake b/cmake/utils.cmake
index ead2638..97c9a66 100644
--- a/cmake/utils.cmake
+++ b/cmake/utils.cmake
@@ -47,11 +47,11 @@ function (configure_headers out)
set (tmp)
foreach (src IN LISTS ARGN)
if (EXISTS "${PROJECT_SOURCE_DIR}/src/${src}.in")
- configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}" @ONLY)
- list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" @ONLY)
+ list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
else ()
- configure_file ("${PROJECT_SOURCE_DIR}/src/${src}" "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}" COPYONLY)
- list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/${src}" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" COPYONLY)
+ list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
endif ()
endforeach ()
set (${out} "${tmp}" PARENT_SCOPE)
@@ -63,8 +63,8 @@ function (configure_sources out)
set (tmp)
foreach (src IN LISTS ARGN)
if (src MATCHES ".h$" AND EXISTS "${PROJECT_SOURCE_DIR}/src/${src}.in")
- configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}" @ONLY)
- list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_NAMESPACE}/${src}")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" @ONLY)
+ list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
else ()
list (APPEND tmp "${PROJECT_SOURCE_DIR}/src/${src}")
endif ()
From 94c23575c7183b73912f4b60a66f49d3f3d59b70 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 27 Mar 2014 01:45:47 +0000
Subject: [PATCH 42/94] Update NEWS.
---
NEWS.txt | 17 +++++++++--------
1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/NEWS.txt b/NEWS.txt
index b9a68f3..ba8d91c 100644
--- a/NEWS.txt
+++ b/NEWS.txt
@@ -1,12 +1,15 @@
=== 20 March 2014 ===
-I've just released gflags 2.1.0.
+I've just released gflags 2.1.
The major changes are the use of CMake for the build configuration instead
-of the autotools and packaging support through CPack. This release compiles
-with all major compilers without warnings and passed the unit tests on
-Ubuntu 12.04, Windows 7 (Visual Studio 2008 and 2010, Cygwin, MinGW), and
-Mac OS X (Xcode 5.1).
+of the autotools and packaging support through CPack. The default namespace
+of all C++ symbols is now "gflags" instead of "google". This can be
+configured via the GFLAGS_NAMESPACE variable.
+
+This release compiles with all major compilers without warnings and passed
+the unit tests on Ubuntu 12.04, Windows 7 (Visual Studio 2008 and 2010,
+Cygwin, MinGW), and Mac OS X (Xcode 5.1).
The SVN repository on Google Code is now frozen and replaced by a Git
repository such that it can be used as Git submodule by projects. The main
@@ -21,9 +24,7 @@ For the further development, I am following the
with feature branch names prefixed by "feature/" and bugfix branch names
prefixed by "bugfix/", respectively.
-Binary and source distribution packages can be downloaded from
-[https://github.com/schuhschuh/gflags GitHub] as Google Code no longer
-permits the upload of such download packages.
+Binary and source [https://github.com/schuhschuh/gflags/releases packages] are available on GitHub.
=== 14 January 2013 ===
From dc8543a4738548dda6f210cca035693e19c7042d Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sun, 30 Mar 2014 15:16:00 +0100
Subject: [PATCH 43/94] Add test which uses gflags_declare.h.
Update issue 79
Added a test which uses gflags_declare.h as any other project would use it to avoid such avoidable build configuration mistakes.
---
test/CMakeLists.txt | 7 +++++++
test/gflags_declare_flags.cc | 9 +++++++++
test/gflags_declare_test.cc | 12 ++++++++++++
3 files changed, 28 insertions(+)
create mode 100644 test/gflags_declare_flags.cc
create mode 100644 test/gflags_declare_test.cc
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 49c97ea..ff07474 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -154,6 +154,13 @@ add_gflags_test(always_fail 1 "ERROR: failed validation of new value 'true' for
# debugger abort() intervention in case of Debug configuration.
#add_gflags_test(deadlock_if_cant_lock 0 "PASS" "" gflags_unittest --deadlock_if_cant_lock)
+# ----------------------------------------------------------------------------
+# use gflags_declare.h
+add_executable (gflags_declare_test gflags_declare_test.cc gflags_declare_flags.cc)
+
+add_test(NAME gflags_declare COMMAND gflags_declare_test --message "Hello gflags!")
+set_tests_properties(gflags_declare PROPERTIES PASS_REGULAR_EXPRESSION "Hello gflags!")
+
# ----------------------------------------------------------------------------
# (negative) compilation tests
if (BUILD_NC_TESTS)
diff --git a/test/gflags_declare_flags.cc b/test/gflags_declare_flags.cc
new file mode 100644
index 0000000..dc53de5
--- /dev/null
+++ b/test/gflags_declare_flags.cc
@@ -0,0 +1,9 @@
+#include
+#include
+
+DECLARE_string(message); // in gflags_delcare_test.cc
+
+void print_message()
+{
+ std::cout << FLAGS_message << std::endl;
+}
diff --git a/test/gflags_declare_test.cc b/test/gflags_declare_test.cc
new file mode 100644
index 0000000..707bcc0
--- /dev/null
+++ b/test/gflags_declare_test.cc
@@ -0,0 +1,12 @@
+#include
+
+DEFINE_string(message, "", "The message to print");
+void print_message(); // in gflags_declare_flags.cc
+
+int main(int argc, char **argv)
+{
+ gflags::SetUsageMessage("Test compilation and use of gflags_declare.h");
+ gflags::ParseCommandLineFlags(&argc, &argv, true);
+ print_message();
+ return 0;
+}
From eb5e1f7fe44992058db423594cba5c94da85462c Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sun, 30 Mar 2014 15:17:49 +0100
Subject: [PATCH 44/94] Bump version to 2.1.1.
---
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 8afdddf..b11c697 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -8,7 +8,7 @@ include (utils)
# ----------------------------------------------------------------------------
# package information
set (PACKAGE_NAME "gflags")
-set (PACKAGE_VERSION "2.1.0")
+set (PACKAGE_VERSION "2.1.1")
set (PACKAGE_STRING "${PACKAGE_NAME} ${PACKAGE_VERSION}")
set (PACKAGE_TARNAME "${PACKAGE_NAME}-${PACKAGE_VERSION}")
set (PACKAGE_BUGREPORT "https://code.google.com/p/gflags/issues/")
From 0890b699e97d7f8ffc898f3c5de6e2645be74e0c Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sun, 30 Mar 2014 15:18:26 +0100
Subject: [PATCH 45/94] Add NEWS of release version 2.1.1.
---
NEWS.txt | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/NEWS.txt b/NEWS.txt
index ba8d91c..7418607 100644
--- a/NEWS.txt
+++ b/NEWS.txt
@@ -1,3 +1,14 @@
+=== 30 March 2014 ===
+
+I've just released gflags 2.1.1.
+
+This release fixes a few bugs in the configuration of gflags_declare.h
+and adds a separate GFLAGS_INCLUDE_DIR CMake variable to the build configuration.
+Setting GFLAGS_NAMESPACE to "google" no longer changes also the include
+path of the public header files. This allows the use of the library with
+other Google projects such as glog which still use the deprecated "google"
+namespace for the gflags library, but include it as "gflags/gflags.h".
+
=== 20 March 2014 ===
I've just released gflags 2.1.
From ef5c5474b29318a418c1628038865ee252e98b0e Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sun, 30 Mar 2014 15:34:13 +0100
Subject: [PATCH 46/94] Set CPACK_PACKAGE_ARCHITECTURE to darwin on Mac OS.
---
CMakeLists.txt | 2 ++
1 file changed, 2 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index b11c697..17d38b4 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -392,6 +392,8 @@ if (BUILD_PACKAGING)
set (CPACK_SYSTEM_NAME "win32")
endif ()
set (CPACK_PACKAGE_ARCHITECTURE)
+ elseif (APPLE)
+ set (CPACK_PACKAGE_ARCHITECTURE darwin)
else ()
string (TOLOWER "${CMAKE_SYSTEM_NAME}" CPACK_SYSTEM_NAME)
if (CMAKE_CXX_FLAGS MATCHES "-m32")
From 40031034993c32ebfb4ef19730b58535ed76340b Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Sun, 30 Mar 2014 15:41:02 +0100
Subject: [PATCH 47/94] Add ChangeLog entries for release 2.1.1.
---
ChangeLog.txt | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/ChangeLog.txt b/ChangeLog.txt
index 9771549..e14d88e 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,3 +1,10 @@
+* Sun Mar 20 2014 - Andreas Schuh
+
+- gflags: version 2.1.1
+- Fixed issue 77: GFLAGS_IS_A_DLL expands to empty string in gflags_declare.h
+- Fixed issue 79: GFLAGS_NAMESPACE not expanded to actual namespace in gflags_declare.h
+- Fixed issue 80: Allow include path to differ from GFLAGS_NAMESPACE
+
* Thu Mar 20 2014 - Andreas Schuh
- gflags: version 2.1.0
From cac974eb07ba7528b01bb6db4836a18c2a88f247 Mon Sep 17 00:00:00 2001
From: shawke
Date: Mon, 7 Apr 2014 18:03:26 +0200
Subject: [PATCH 48/94] Fix compatibility with older versions of CMake
The "SONAME_FLAG" was introduced in CMake 2.8.9, while the current CMake scripts require 2.8.4 (first line of CMakeLists.txt). Increasing the required CMake version will block building in less recent OSes (e.g., for Ubuntu 12.04 LTS, the latest version from the official repositories is currently 2.8.7). The more compatible solution will be to use the old variable name, i.e. the one which was used before CMake was patched.
NB: this issue is triggered upon specifying -DBUILD_SHARED_LIBS=ON.
Related bug report: http://public.kitware.com/Bug/view.php?id=13884
Commit which implemented this new variable: http://cmake.org/gitweb?p=cmake.git;a=commitdiff;h=e1409ac5
---
cmake/CMakeCXXInformation.cmake | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/cmake/CMakeCXXInformation.cmake b/cmake/CMakeCXXInformation.cmake
index 4d0a14a..9ddae4a 100644
--- a/cmake/CMakeCXXInformation.cmake
+++ b/cmake/CMakeCXXInformation.cmake
@@ -256,7 +256,7 @@ include(CMakeCommonLanguageInclude)
# create a shared C++ library
if(NOT CMAKE_CXX_CREATE_SHARED_LIBRARY)
set(CMAKE_CXX_CREATE_SHARED_LIBRARY
- " -o ")
+ " -o ")
endif()
# create a c++ shared module copy the shared library rule by default
From 55490439d00273a7ae09e0d45095ef453a987fd7 Mon Sep 17 00:00:00 2001
From: John Khvatov
Date: Thu, 1 May 2014 00:57:04 +0400
Subject: [PATCH 49/94] cmake: append LIB_SUFFIX to LIBRARY_INSTALL_DIR
---
CMakeLists.txt | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 17d38b4..10c9cca 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -280,9 +280,9 @@ if (OS_WINDOWS)
set (CONFIG_INSTALL_DIR CMake)
else ()
set (RUNTIME_INSTALL_DIR bin)
- set (LIBRARY_INSTALL_DIR lib)
+ set (LIBRARY_INSTALL_DIR lib${LIB_SUFFIX})
set (INCLUDE_INSTALL_DIR include)
- set (CONFIG_INSTALL_DIR lib/cmake/${PACKAGE_NAME})
+ set (CONFIG_INSTALL_DIR lib${LIB_SUFFIX}/cmake/${PACKAGE_NAME})
endif ()
file (RELATIVE_PATH INSTALL_PREFIX_REL2CONFIG_DIR "${CMAKE_INSTALL_PREFIX}/${CONFIG_INSTALL_DIR}" "${CMAKE_INSTALL_PREFIX}")
From d9d06b99a4cbe03c6e40039b6d10c24686c82755 Mon Sep 17 00:00:00 2001
From: John Khvatov
Date: Thu, 1 May 2014 03:10:54 +0400
Subject: [PATCH 50/94] doc: rename namespace from google (deprecated) to
gflags (default)
---
doc/gflags.html | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/doc/gflags.html b/doc/gflags.html
index 1a887b4..3a66713 100644
--- a/doc/gflags.html
+++ b/doc/gflags.html
@@ -269,7 +269,7 @@ the getopt library, but has much less overhead to use. In fact, it's
just a single function call:
Usually, this code is at the beginning of main().
@@ -529,8 +529,8 @@ access parts of argv outside main, including the program
name (argv[0]).
For more information about these routines, and other useful helper
-methods such as google::SetUsageMessage() and
-google::SetVersionString, see gflags.h.
+methods such as gflags::SetUsageMessage() and
+gflags::SetVersionString, see gflags.h.
From e9144aa1597c63a73ab05ea980a349367501a3e6 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 1 May 2014 19:49:24 +0100
Subject: [PATCH 51/94] Make LIBRARY_INSTALL_DIR configurable by the user.
---
CMakeLists.txt | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 10c9cca..ee81c1b 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -280,9 +280,15 @@ if (OS_WINDOWS)
set (CONFIG_INSTALL_DIR CMake)
else ()
set (RUNTIME_INSTALL_DIR bin)
- set (LIBRARY_INSTALL_DIR lib${LIB_SUFFIX})
+ # The LIB_SUFFIX variable is used by the Fedora package maintainers.
+ # Also package maintainers of other distribution packages need to be able
+ # to specify the name of the library directory.
+ set (LIBRARY_INSTALL_DIR lib${LIB_SUFFIX}
+ CACHE STRING "Directory name for installed libraries, e.g., \"lib64\""
+ )
+ mark_as_advanced (LIBRARY_INSTALL_DIR)
set (INCLUDE_INSTALL_DIR include)
- set (CONFIG_INSTALL_DIR lib${LIB_SUFFIX}/cmake/${PACKAGE_NAME})
+ set (CONFIG_INSTALL_DIR ${LIBRARY_INSTALL_DIR}/cmake/${PACKAGE_NAME})
endif ()
file (RELATIVE_PATH INSTALL_PREFIX_REL2CONFIG_DIR "${CMAKE_INSTALL_PREFIX}/${CONFIG_INSTALL_DIR}" "${CMAKE_INSTALL_PREFIX}")
From 31f0e290d632d755034d6d2d2c29d3ec7be6b3f0 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 1 May 2014 19:58:25 +0100
Subject: [PATCH 52/94] Use LIB_INSTALL_DIR to initialize LIBRARY_INSTALL_DIR.
In particular the Fedora package maintainers pass LIB_INSTALL_DIR instead of LIBRARY_INSTALL_DIR.
---
CMakeLists.txt | 13 ++++++++-----
1 file changed, 8 insertions(+), 5 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index ee81c1b..a4d0f07 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -280,11 +280,14 @@ if (OS_WINDOWS)
set (CONFIG_INSTALL_DIR CMake)
else ()
set (RUNTIME_INSTALL_DIR bin)
- # The LIB_SUFFIX variable is used by the Fedora package maintainers.
- # Also package maintainers of other distribution packages need to be able
- # to specify the name of the library directory.
- set (LIBRARY_INSTALL_DIR lib${LIB_SUFFIX}
- CACHE STRING "Directory name for installed libraries, e.g., \"lib64\""
+ # The LIB_INSTALL_DIR and LIB_SUFFIX variables are used by the Fedora
+ # package maintainers. Also package maintainers of other distribution
+ # packages need to be able to specify the name of the library directory.
+ if (NOT LIB_INSTALL_DIR)
+ set (LIB_INSTALL_DIR "lib${LIB_SUFFIX}")
+ endif ()
+ set (LIBRARY_INSTALL_DIR "${LIB_INSTALL_DIR}"
+ CACHE PATH "Directory of installed libraries, e.g., \"lib64\""
)
mark_as_advanced (LIBRARY_INSTALL_DIR)
set (INCLUDE_INSTALL_DIR include)
From bf889786c2a3a2dab89610d0722634d2eedfc694 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 1 May 2014 20:16:16 +0100
Subject: [PATCH 53/94] Set VERSION property of library targets to
..
---
CMakeLists.txt | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index a4d0f07..7f65563 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -22,6 +22,8 @@ version_numbers (
PACKAGE_VERSION_PATCH
)
+set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}.${PACKAGE_VERSION_MINOR}")
+
# ----------------------------------------------------------------------------
# options
set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
@@ -257,6 +259,9 @@ foreach (TYPE IN ITEMS STATIC SHARED)
set_target_properties (
gflags${opts}-${type} PROPERTIES COMPILE_DEFINITIONS "${defines}"
OUTPUT_NAME "gflags${opts}"
+ # Set VERSION instead of SOVERSION such
+ # that it is also used on Windows
+ VERSION "${PACKAGE_SOVERSION}"
)
if (HAVE_SHLWAPI_H)
target_link_libraries (gflags${opts}-${type} shlwapi.lib)
From cd7aece14e2aac0669292c95ab42de6e267a5034 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Fri, 2 May 2014 11:12:05 +0100
Subject: [PATCH 54/94] Use major version number only as SOVERSION.
---
CMakeLists.txt | 9 ++++-----
1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 7f65563..ca2c1df 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -22,7 +22,7 @@ version_numbers (
PACKAGE_VERSION_PATCH
)
-set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}.${PACKAGE_VERSION_MINOR}")
+set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}")
# ----------------------------------------------------------------------------
# options
@@ -258,10 +258,9 @@ foreach (TYPE IN ITEMS STATIC SHARED)
endif ()
set_target_properties (
gflags${opts}-${type} PROPERTIES COMPILE_DEFINITIONS "${defines}"
- OUTPUT_NAME "gflags${opts}"
- # Set VERSION instead of SOVERSION such
- # that it is also used on Windows
- VERSION "${PACKAGE_SOVERSION}"
+ OUTPUT_NAME "gflags${opts}"
+ VERSION "${PACKAGE_VERSION}"
+ SOVERSION "${PACKAGE_SOVERSION}"
)
if (HAVE_SHLWAPI_H)
target_link_libraries (gflags${opts}-${type} shlwapi.lib)
From a93de007a65eea5f0eea1eb830788dbdb7c17112 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Fri, 2 May 2014 12:00:35 +0100
Subject: [PATCH 55/94] Define GFLAGS_NAMESPACE in public headers.
This avoids any mistakes where once @GFLAGS_NAMESPACE@ was used in public .h.in files, or the #define GFLAGS_NAMESPACE in internal source files.
---
src/config.h.in | 3 ---
src/gflags.h.in | 20 ++++++++++----------
src/gflags_declare.h.in | 15 ++++++++++-----
3 files changed, 20 insertions(+), 18 deletions(-)
diff --git a/src/config.h.in b/src/config.h.in
index c033dee..a8708da 100644
--- a/src/config.h.in
+++ b/src/config.h.in
@@ -70,9 +70,6 @@
// Define to the address where bug reports for this package should be sent.
#define PACKAGE_BUGREPORT @PACKAGE_BUGREPORT@
-// Namespace of gflags library symbols.
-#define GFLAGS_NAMESPACE @GFLAGS_NAMESPACE@
-
// ---------------------------------------------------------------------------
// Path separator
#ifndef PATH_SEPARATOR
diff --git a/src/gflags.h.in b/src/gflags.h.in
index 852de48..9ee7738 100644
--- a/src/gflags.h.in
+++ b/src/gflags.h.in
@@ -94,7 +94,7 @@
#endif
-namespace @GFLAGS_NAMESPACE@ {
+namespace GFLAGS_NAMESPACE {
// --------------------------------------------------------------------
@@ -136,7 +136,7 @@ extern GFLAGS_DLL_DECL bool RegisterFlagValidator(const std::string* flag, bool
// Convenience macro for the registration of a flag validator
#define DEFINE_validator(name, validator) \
static const bool name##_validator_registered = \
- @GFLAGS_NAMESPACE@::RegisterFlagValidator(&FLAGS_##name, validator)
+ GFLAGS_NAMESPACE::RegisterFlagValidator(&FLAGS_##name, validator)
// --------------------------------------------------------------------
@@ -442,7 +442,7 @@ class GFLAGS_DLL_DECL FlagRegisterer {
extern GFLAGS_DLL_DECL const char kStrippedFlagHelp[];
-} // namespace @GFLAGS_NAMESPACE@
+} // namespace GFLAGS_NAMESPACE
#ifndef SWIG // In swig, ignore the main flag declarations
@@ -450,7 +450,7 @@ extern GFLAGS_DLL_DECL const char kStrippedFlagHelp[];
#if defined(STRIP_FLAG_HELP) && STRIP_FLAG_HELP > 0
// Need this construct to avoid the 'defined but not used' warning.
#define MAYBE_STRIPPED_HELP(txt) \
- (false ? (txt) : @GFLAGS_NAMESPACE@::kStrippedFlagHelp)
+ (false ? (txt) : GFLAGS_NAMESPACE::kStrippedFlagHelp)
#else
#define MAYBE_STRIPPED_HELP(txt) txt
#endif
@@ -472,7 +472,7 @@ extern GFLAGS_DLL_DECL const char kStrippedFlagHelp[];
/* We always want to export defined variables, dll or no */ \
GFLAGS_DLL_DEFINE_FLAG type FLAGS_##name = FLAGS_nono##name; \
type FLAGS_no##name = FLAGS_nono##name; \
- static @GFLAGS_NAMESPACE@::FlagRegisterer o_##name( \
+ static GFLAGS_NAMESPACE::FlagRegisterer o_##name( \
#name, #type, MAYBE_STRIPPED_HELP(help), __FILE__, \
&FLAGS_##name, &FLAGS_no##name); \
} \
@@ -500,20 +500,20 @@ GFLAGS_DLL_DECL bool IsBoolFlag(bool from);
#define DEFINE_bool(name, val, txt) \
namespace fLB { \
typedef ::fLB::CompileAssert FLAG_##name##_value_is_not_a_bool[ \
- (sizeof(::fLB::IsBoolFlag(val)) != sizeof(double)) ? 1 : -1]; \
+ (sizeof(::fLB::IsBoolFlag(val)) != sizeof(double))? 1: -1]; \
} \
DEFINE_VARIABLE(bool, B, name, val, txt)
#define DEFINE_int32(name, val, txt) \
- DEFINE_VARIABLE(@GFLAGS_NAMESPACE@::int32, I, \
+ DEFINE_VARIABLE(GFLAGS_NAMESPACE::int32, I, \
name, val, txt)
#define DEFINE_int64(name, val, txt) \
- DEFINE_VARIABLE(@GFLAGS_NAMESPACE@::int64, I64, \
+ DEFINE_VARIABLE(GFLAGS_NAMESPACE::int64, I64, \
name, val, txt)
#define DEFINE_uint64(name,val, txt) \
- DEFINE_VARIABLE(@GFLAGS_NAMESPACE@::uint64, U64, \
+ DEFINE_VARIABLE(GFLAGS_NAMESPACE::uint64, U64, \
name, val, txt)
#define DEFINE_double(name, val, txt) \
@@ -554,7 +554,7 @@ inline clstring* dont_pass0toDEFINE_string(char *stringspot,
clstring* const FLAGS_no##name = ::fLS:: \
dont_pass0toDEFINE_string(s_##name[0].s, \
val); \
- static @GFLAGS_NAMESPACE@::FlagRegisterer o_##name( \
+ static GFLAGS_NAMESPACE::FlagRegisterer o_##name( \
#name, "string", MAYBE_STRIPPED_HELP(txt), __FILE__, \
s_##name[0].s, new (s_##name[1].s) clstring(*FLAGS_no##name)); \
extern GFLAGS_DLL_DEFINE_FLAG clstring& FLAGS_##name; \
diff --git a/src/gflags_declare.h.in b/src/gflags_declare.h.in
index b9ab9c7..279db24 100644
--- a/src/gflags_declare.h.in
+++ b/src/gflags_declare.h.in
@@ -37,6 +37,11 @@
#ifndef GFLAGS_DECLARE_H_
#define GFLAGS_DECLARE_H_
+
+// ---------------------------------------------------------------------------
+// Namespace of gflags library symbols.
+#define GFLAGS_NAMESPACE @GFLAGS_NAMESPACE@
+
// ---------------------------------------------------------------------------
// Windows DLL import/export.
@@ -69,7 +74,7 @@
# include // a third place for uint32_t or u_int32_t
#endif
-namespace @GFLAGS_NAMESPACE@ {
+namespace GFLAGS_NAMESPACE {
#if @GFLAGS_INTTYPES_FORMAT_C99@ // C99
typedef int32_t int32;
@@ -90,7 +95,7 @@ typedef unsigned __int64 uint64;
# error Do not know how to define a 32-bit integer quantity on your system
#endif
-} // namespace @GFLAGS_NAMESPACE@
+} // namespace GFLAGS_NAMESPACE
namespace fLS {
@@ -113,13 +118,13 @@ typedef std::string clstring;
DECLARE_VARIABLE(bool, B, name)
#define DECLARE_int32(name) \
- DECLARE_VARIABLE(::@GFLAGS_NAMESPACE@::int32, I, name)
+ DECLARE_VARIABLE(::GFLAGS_NAMESPACE::int32, I, name)
#define DECLARE_int64(name) \
- DECLARE_VARIABLE(::@GFLAGS_NAMESPACE@::int64, I64, name)
+ DECLARE_VARIABLE(::GFLAGS_NAMESPACE::int64, I64, name)
#define DECLARE_uint64(name) \
- DECLARE_VARIABLE(::@GFLAGS_NAMESPACE@::uint64, U64, name)
+ DECLARE_VARIABLE(::GFLAGS_NAMESPACE::uint64, U64, name)
#define DECLARE_double(name) \
DECLARE_VARIABLE(double, D, name)
From 659b440f9e403c9080eb304efc53b938c63cbe47 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Fri, 2 May 2014 14:56:58 +0100
Subject: [PATCH 56/94] Support alternative namespaces in GFLAGS_NAMESPACE
CMake variable.
The first element in the GFLAGS_NAMESPACE list is used as primary/default namespace. The symbols are then imported from this primary namespace into each of the other alternative namespaces with the using keyword. This is in particular used to maintain backwards compatibility with previous gflags library versions that used the "google" namespace instead of the new default "gflags" namespace.
---
CMakeLists.txt | 45 ++++++++++++++++----
cmake/utils.cmake | 4 +-
src/gflags.h.in | 4 ++
src/gflags_ns.h.in | 101 +++++++++++++++++++++++++++++++++++++++++++++
4 files changed, 144 insertions(+), 10 deletions(-)
create mode 100644 src/gflags_ns.h.in
diff --git a/CMakeLists.txt b/CMakeLists.txt
index ca2c1df..1e55bb0 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -26,15 +26,19 @@ set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}")
# ----------------------------------------------------------------------------
# options
-set (GFLAGS_NAMESPACE "${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier of gflags library.")
-set (GFLAGS_INCLUDE_DIR "${PACKAGE_NAME}" CACHE STRING "Include subdirectory of gflags header files.")
-
-if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
- message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
-endif ()
-if (GFLAGS_INCLUDE_DIR MATCHES "^\\.\\.[/\\]")
- message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must not start with parent directory reference (../)")
+set (GFLAGS_NAMESPACE "${PACKAGE_NAME};google" CACHE STRING "C++ namespace identifier(s) of gflags library.")
+set (GFLAGS_NAMESPACE_SECONDARY "${GFLAGS_NAMESPACE}")
+list (REMOVE_DUPLICATES GFLAGS_NAMESPACE_SECONDARY)
+if (NOT GFLAGS_NAMESPACE_SECONDARY)
+ message (FATAL_ERROR "GFLAGS_NAMESPACE must be set to one (or more) valid C++ namespace identifier(s separated by semicolon \";\").")
endif ()
+foreach (ns IN LISTS GFLAGS_NAMESPACE_SECONDARY)
+ if (NOT ns MATCHES "^[a-zA-Z][a-zA-Z0-9_]*$")
+ message (FATAL_ERROR "GFLAGS_NAMESPACE contains invalid namespace identifier: ${ns}")
+ endif ()
+endforeach ()
+list (GET GFLAGS_NAMESPACE_SECONDARY 0 GFLAGS_NAMESPACE)
+list (REMOVE_AT GFLAGS_NAMESPACE_SECONDARY 0)
option (BUILD_SHARED_LIBS "Request build of shared libraries." OFF)
option (BUILD_STATIC_LIBS "Request build of static libraries (default if BUILD_SHARED_LIBS is OFF)." OFF)
@@ -48,7 +52,6 @@ option (INSTALL_HEADERS "Request packaging of headers and other devel
mark_as_advanced (CLEAR CMAKE_INSTALL_PREFIX)
mark_as_advanced (CMAKE_CONFIGURATION_TYPES
GFLAGS_NAMESPACE
- GFLAGS_INCLUDE_DIR
BUILD_STATIC_LIBS
BUILD_NC_TESTS
INSTALL_HEADERS)
@@ -69,6 +72,17 @@ if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CXX_FLAGS)
set_property (CACHE CMAKE_BUILD_TYPE PROPERTY VALUE Release)
endif ()
+if (NOT GFLAGS_INCLUDE_DIR)
+ set (GFLAGS_INCLUDE_DIR "${GFLAGS_NAMESPACE}")
+else ()
+ if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
+ message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
+ endif ()
+ if (GFLAGS_INCLUDE_DIR MATCHES "^\\.\\.[/\\]")
+ message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must not start with parent directory reference (../)")
+ endif ()
+endif ()
+
# ----------------------------------------------------------------------------
# system checks
include (CheckTypeSize)
@@ -183,6 +197,19 @@ set (PUBLIC_HDRS
"gflags_completions.h"
)
+if (GFLAGS_NAMESPACE_SECONDARY)
+ set (INCLUDE_GFLAGS_NS_H "// Import gflags library symbols into alternative/deprecated namespace(s)")
+ foreach (ns IN LISTS GFLAGS_NAMESPACE_SECONDARY)
+ string (TOUPPER "${ns}" NS)
+ set (gflags_ns_h "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/gflags_${ns}.h")
+ configure_file ("${PROJECT_SOURCE_DIR}/src/gflags_ns.h.in" "${gflags_ns_h}" @ONLY)
+ list (APPEND PUBLIC_HDRS "${gflags_ns_h}")
+ set (INCLUDE_GFLAGS_NS_H "${INCLUDE_GFLAGS_NS_H}\n#include \"gflags_${ns}.h\"")
+ endforeach ()
+else ()
+ set (INCLUDE_GFLAGS_NS_H)
+endif ()
+
set (PRIVATE_HDRS
"config.h"
"util.h"
diff --git a/cmake/utils.cmake b/cmake/utils.cmake
index 97c9a66..9cef463 100644
--- a/cmake/utils.cmake
+++ b/cmake/utils.cmake
@@ -46,7 +46,9 @@ endfunction ()
function (configure_headers out)
set (tmp)
foreach (src IN LISTS ARGN)
- if (EXISTS "${PROJECT_SOURCE_DIR}/src/${src}.in")
+ if (IS_ABSOLUTE "${src}")
+ list (APPEND tmp "${src}")
+ elseif (EXISTS "${PROJECT_SOURCE_DIR}/src/${src}.in")
configure_file ("${PROJECT_SOURCE_DIR}/src/${src}.in" "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}" @ONLY)
list (APPEND tmp "${PROJECT_BINARY_DIR}/include/${GFLAGS_INCLUDE_DIR}/${src}")
else ()
diff --git a/src/gflags.h.in b/src/gflags.h.in
index 9ee7738..0324d39 100644
--- a/src/gflags.h.in
+++ b/src/gflags.h.in
@@ -565,4 +565,8 @@ inline clstring* dont_pass0toDEFINE_string(char *stringspot,
#endif // SWIG
+
+@INCLUDE_GFLAGS_NS_H@
+
+
#endif // GFLAGS_GFLAGS_H_
diff --git a/src/gflags_ns.h.in b/src/gflags_ns.h.in
new file mode 100644
index 0000000..1bb2038
--- /dev/null
+++ b/src/gflags_ns.h.in
@@ -0,0 +1,101 @@
+// Copyright (c) 2014, Andreas Schuh
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the names of its
+// contributors may be used to endorse or promote products derived from
+// this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+// -----------------------------------------------------------------------------
+// Imports the gflags library symbols into an alternative/deprecated namespace.
+
+#ifndef GFLAGS_GFLAGS_H_
+# error The internal header gflags_@ns@.h may only be included by gflags.h
+#endif
+
+#ifndef GFLAGS_@NS@_H_
+#define GFLAGS_@NS@_H_
+
+
+namespace @ns@ {
+
+
+using GFLAGS_NAMESPACE::int32;
+using GFLAGS_NAMESPACE::uint32;
+using GFLAGS_NAMESPACE::int64;
+using GFLAGS_NAMESPACE::uint64;
+
+using GFLAGS_NAMESPACE::RegisterFlagValidator;
+using GFLAGS_NAMESPACE::CommandLineFlagInfo;
+using GFLAGS_NAMESPACE::GetAllFlags;
+using GFLAGS_NAMESPACE::ShowUsageWithFlags;
+using GFLAGS_NAMESPACE::ShowUsageWithFlagsRestrict;
+using GFLAGS_NAMESPACE::DescribeOneFlag;
+using GFLAGS_NAMESPACE::SetArgv;
+using GFLAGS_NAMESPACE::GetArgvs;
+using GFLAGS_NAMESPACE::GetArgv;
+using GFLAGS_NAMESPACE::GetArgv0;
+using GFLAGS_NAMESPACE::GetArgvSum;
+using GFLAGS_NAMESPACE::ProgramInvocationName;
+using GFLAGS_NAMESPACE::ProgramInvocationShortName;
+using GFLAGS_NAMESPACE::ProgramUsage;
+using GFLAGS_NAMESPACE::VersionString;
+using GFLAGS_NAMESPACE::GetCommandLineOption;
+using GFLAGS_NAMESPACE::GetCommandLineFlagInfo;
+using GFLAGS_NAMESPACE::GetCommandLineFlagInfoOrDie;
+using GFLAGS_NAMESPACE::FlagSettingMode;
+using GFLAGS_NAMESPACE::SET_FLAGS_VALUE;
+using GFLAGS_NAMESPACE::SET_FLAG_IF_DEFAULT;
+using GFLAGS_NAMESPACE::SET_FLAGS_DEFAULT;
+using GFLAGS_NAMESPACE::SetCommandLineOption;
+using GFLAGS_NAMESPACE::SetCommandLineOptionWithMode;
+using GFLAGS_NAMESPACE::FlagSaver;
+using GFLAGS_NAMESPACE::CommandlineFlagsIntoString;
+using GFLAGS_NAMESPACE::ReadFlagsFromString;
+using GFLAGS_NAMESPACE::AppendFlagsIntoFile;
+using GFLAGS_NAMESPACE::ReadFromFlagsFile;
+using GFLAGS_NAMESPACE::BoolFromEnv;
+using GFLAGS_NAMESPACE::Int32FromEnv;
+using GFLAGS_NAMESPACE::Int64FromEnv;
+using GFLAGS_NAMESPACE::Uint64FromEnv;
+using GFLAGS_NAMESPACE::DoubleFromEnv;
+using GFLAGS_NAMESPACE::StringFromEnv;
+using GFLAGS_NAMESPACE::SetUsageMessage;
+using GFLAGS_NAMESPACE::SetVersionString;
+using GFLAGS_NAMESPACE::ParseCommandLineNonHelpFlags;
+using GFLAGS_NAMESPACE::HandleCommandLineHelpFlags;
+using GFLAGS_NAMESPACE::AllowCommandLineReparsing;
+using GFLAGS_NAMESPACE::ReparseCommandLineNonHelpFlags;
+using GFLAGS_NAMESPACE::ShutDownCommandLineFlags;
+using GFLAGS_NAMESPACE::FlagRegisterer;
+
+#ifndef SWIG
+using GFLAGS_NAMESPACE::ParseCommandLineFlags;
+#endif
+
+
+} // namespace @ns@
+
+
+#endif // GFLAGS_@NS@_H_
From 2b81a76bed7bba6c30cb8fc5a9507841bb047fcb Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 17 Jul 2014 02:14:41 +0100
Subject: [PATCH 57/94] fix: Include guard of alternative "gflags" namespace
header.
---
src/gflags_ns.h.in | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/src/gflags_ns.h.in b/src/gflags_ns.h.in
index 1bb2038..f692666 100644
--- a/src/gflags_ns.h.in
+++ b/src/gflags_ns.h.in
@@ -34,8 +34,8 @@
# error The internal header gflags_@ns@.h may only be included by gflags.h
#endif
-#ifndef GFLAGS_@NS@_H_
-#define GFLAGS_@NS@_H_
+#ifndef GFLAGS_NS_@NS@_H_
+#define GFLAGS_NS_@NS@_H_
namespace @ns@ {
@@ -98,4 +98,4 @@ using GFLAGS_NAMESPACE::ParseCommandLineFlags;
} // namespace @ns@
-#endif // GFLAGS_@NS@_H_
+#endif // GFLAGS_NS_@NS@_H_
From 76cbe0d003bb5d099683d4399e87b191795c4bcb Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 17 Jul 2014 02:45:50 +0100
Subject: [PATCH 58/94] Change default GFLAGS_NAMESPACE to "google;gflags" and
add GFLAGS_INCLUDE_DIR with default "gflags" to cache.
This ensures binary compatibility with previous 2.x release versions while allowing users to refer to the gflags library symbols using the preferred "gflags" namespace identifier.
---
CMakeLists.txt | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 1e55bb0..c63b2de 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -26,7 +26,7 @@ set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}")
# ----------------------------------------------------------------------------
# options
-set (GFLAGS_NAMESPACE "${PACKAGE_NAME};google" CACHE STRING "C++ namespace identifier(s) of gflags library.")
+set (GFLAGS_NAMESPACE "google;${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier(s) of gflags library.")
set (GFLAGS_NAMESPACE_SECONDARY "${GFLAGS_NAMESPACE}")
list (REMOVE_DUPLICATES GFLAGS_NAMESPACE_SECONDARY)
if (NOT GFLAGS_NAMESPACE_SECONDARY)
@@ -72,8 +72,9 @@ if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CXX_FLAGS)
set_property (CACHE CMAKE_BUILD_TYPE PROPERTY VALUE Release)
endif ()
+set (GFLAGS_INCLUDE_DIR "" CACHE STRING "Installation directory of header files relative to CMAKE_INSTALL_PREFIX.")
if (NOT GFLAGS_INCLUDE_DIR)
- set (GFLAGS_INCLUDE_DIR "${GFLAGS_NAMESPACE}")
+ set_property (CACHE GFLAGS_INCLUDE_DIR PROPERTY VALUE "${PACKAGE_NAME}")
else ()
if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
From 376ef823be65bc9902810370108bbac85f114304 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Thu, 17 Jul 2014 11:21:36 +0100
Subject: [PATCH 59/94] cmake: Do not cache GFLAGS_NAMESPACE and
GFLAGS_INCLUDE_DIR.
These CMake variables are now set to a default which both maintains binary backwards compatibility with previous versions of the library, but at the same time allows already the use of the new "gflags" namespace instead of "google". Users may still override the default using the -D option of cmake, for example, when they use the library directly as submodule in their own project and prefer a different namespace/installation directory.
---
CMakeLists.txt | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index c63b2de..9cd9025 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -26,7 +26,11 @@ set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}")
# ----------------------------------------------------------------------------
# options
-set (GFLAGS_NAMESPACE "google;${PACKAGE_NAME}" CACHE STRING "C++ namespace identifier(s) of gflags library.")
+if (NOT GFLAGS_NAMESPACE)
+ # maintain binary backwards compatibility with gflags library version <= 2.0,
+ # but at the same time enable the use of the preferred new "gflags" namespace
+ set (GFLAGS_NAMESPACE "google;${PACKAGE_NAME}")
+endif ()
set (GFLAGS_NAMESPACE_SECONDARY "${GFLAGS_NAMESPACE}")
list (REMOVE_DUPLICATES GFLAGS_NAMESPACE_SECONDARY)
if (NOT GFLAGS_NAMESPACE_SECONDARY)
@@ -51,7 +55,6 @@ option (INSTALL_HEADERS "Request packaging of headers and other devel
mark_as_advanced (CLEAR CMAKE_INSTALL_PREFIX)
mark_as_advanced (CMAKE_CONFIGURATION_TYPES
- GFLAGS_NAMESPACE
BUILD_STATIC_LIBS
BUILD_NC_TESTS
INSTALL_HEADERS)
@@ -72,9 +75,8 @@ if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CXX_FLAGS)
set_property (CACHE CMAKE_BUILD_TYPE PROPERTY VALUE Release)
endif ()
-set (GFLAGS_INCLUDE_DIR "" CACHE STRING "Installation directory of header files relative to CMAKE_INSTALL_PREFIX.")
if (NOT GFLAGS_INCLUDE_DIR)
- set_property (CACHE GFLAGS_INCLUDE_DIR PROPERTY VALUE "${PACKAGE_NAME}")
+ set (GFLAGS_INCLUDE_DIR "${PACKAGE_NAME}")
else ()
if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
From 2a40e1913740d348878b58de878e02002f448127 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 12:33:52 +0000
Subject: [PATCH 60/94] cmake: Add advanced cache entries for GFLAGS_NAMESPACE
and GFLAGS_INCLUDE_DIR
---
CMakeLists.txt | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 9cd9025..ca11b1d 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -29,7 +29,8 @@ set (PACKAGE_SOVERSION "${PACKAGE_VERSION_MAJOR}")
if (NOT GFLAGS_NAMESPACE)
# maintain binary backwards compatibility with gflags library version <= 2.0,
# but at the same time enable the use of the preferred new "gflags" namespace
- set (GFLAGS_NAMESPACE "google;${PACKAGE_NAME}")
+ set (GFLAGS_NAMESPACE "google;${PACKAGE_NAME}" CACHE STRING "Name(s) of library namespace (separate multiple options by semicolon)")
+ mark_as_advanced (GFLAGS_NAMESPACE)
endif ()
set (GFLAGS_NAMESPACE_SECONDARY "${GFLAGS_NAMESPACE}")
list (REMOVE_DUPLICATES GFLAGS_NAMESPACE_SECONDARY)
@@ -76,7 +77,8 @@ if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CXX_FLAGS)
endif ()
if (NOT GFLAGS_INCLUDE_DIR)
- set (GFLAGS_INCLUDE_DIR "${PACKAGE_NAME}")
+ set (GFLAGS_INCLUDE_DIR "${PACKAGE_NAME}" CACHE STRING "Name of include directory of installed header files")
+ mark_as_advanced (GFLAGS_INCLUDE_DIR)
else ()
if (IS_ABSOLUTE GFLAGS_INCLUDE_DIR)
message (FATAL_ERROR "GFLAGS_INCLUDE_DIR must be a path relative to CMAKE_INSTALL_PREFIX/include")
From eb89101a1a065c6829ca7bc27ee2cf26dd850fa4 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 12:34:22 +0000
Subject: [PATCH 61/94] doc: Replace README by previous NEWS in Markdown format
---
NEWS.txt => README.md | 118 ++++++++++++++++++++++++------------------
README.txt | 4 --
2 files changed, 67 insertions(+), 55 deletions(-)
rename NEWS.txt => README.md (76%)
delete mode 100644 README.txt
diff --git a/NEWS.txt b/README.md
similarity index 76%
rename from NEWS.txt
rename to README.md
index 7418607..1d6790d 100644
--- a/NEWS.txt
+++ b/README.md
@@ -1,22 +1,34 @@
-=== 30 March 2014 ===
+24 March 2015
+-------------
+
+Finalized move of gflags project from Google Code to GitHub.
+Email addresses of original issue reporters got lost in the process.
+Given the age of most issue reports, this should be neglibable.
+
+Please report any further issues using the GitHub issue tracker.
+
+
+30 March 2014
+-------------
I've just released gflags 2.1.1.
-This release fixes a few bugs in the configuration of gflags_declare.h
-and adds a separate GFLAGS_INCLUDE_DIR CMake variable to the build configuration.
-Setting GFLAGS_NAMESPACE to "google" no longer changes also the include
+This release fixes a few bugs in the configuration of gflags\_declare.h
+and adds a separate GFLAGS\_INCLUDE\_DIR CMake variable to the build configuration.
+Setting GFLAGS\_NAMESPACE to "google" no longer changes also the include
path of the public header files. This allows the use of the library with
other Google projects such as glog which still use the deprecated "google"
namespace for the gflags library, but include it as "gflags/gflags.h".
-=== 20 March 2014 ===
+20 March 2014
+-------------
I've just released gflags 2.1.
The major changes are the use of CMake for the build configuration instead
of the autotools and packaging support through CPack. The default namespace
of all C++ symbols is now "gflags" instead of "google". This can be
-configured via the GFLAGS_NAMESPACE variable.
+configured via the GFLAGS\_NAMESPACE variable.
This release compiles with all major compilers without warnings and passed
the unit tests on Ubuntu 12.04, Windows 7 (Visual Studio 2008 and 2010,
@@ -28,34 +40,36 @@ hosting of this project remains at Google Code. Thanks to the distributed
character of Git, I can push (and pull) changes from both GitHub and Google Code
in order to keep the two public repositories in sync.
When fixing an issue for a pull request through either of these hosting
-platforms, please reference the issue number as
-[https://code.google.com/p/support/wiki/IssueTracker#Integration_with_version_control described here].
+platforms, please reference the issue number as
+[described here](https://code.google.com/p/support/wiki/IssueTracker#Integration_with_version_control).
For the further development, I am following the
-[http://nvie.com/posts/a-successful-git-branching-model/ Git branching model]
+[Git branching model](http://nvie.com/posts/a-successful-git-branching-model/)
with feature branch names prefixed by "feature/" and bugfix branch names
prefixed by "bugfix/", respectively.
-Binary and source [https://github.com/schuhschuh/gflags/releases packages] are available on GitHub.
+Binary and source [packages](https://github.com/schuhschuh/gflags/releases) are available on GitHub.
-=== 14 January 2013 ===
+14 January 2013
+---------------
The migration of the build system to CMake is almost complete.
What remains to be done is rewriting the tests in Python such they can be
executed on non-Unix platforms and splitting them up into separate CTest tests.
Though merging these changes into the master branch yet remains to be done,
it is recommended to already start using the
-[https://github.com/schuhschuh/gflags/tree/cmake-migration cmake-migration] branch.
+[cmake-migration](https://github.com/schuhschuh/gflags/tree/cmake-migration) branch.
-=== 20 April 2013 ===
+20 April 2013
+-------------
More than a year has past since I (Andreas) took over the maintenance for
`gflags`. Only few minor changes have been made since then, much to my regret.
To get more involved and stimulate participation in the further
development of the library, I moved the project source code today to
-[https://github.com/schuhschuh/gflags GitHub].
-I believe that the strengths of [http://git-scm.com/ Git] will allow for better community collaboration
+[GitHub](https://github.com/schuhschuh/gflags).
+I believe that the strengths of [Git](http://git-scm.com/) will allow for better community collaboration
as well as ease the integration of changes made by others. I encourage everyone
who would like to contribute to send me pull requests.
Git's lightweight feature branches will also provide the right tool for more
@@ -74,13 +88,14 @@ Please continue to report any issues with gflags on Google Code. The GitHub proj
only be used to host the Git repository.
One major change of the project structure I have in mind for the next weeks
-is the migration from autotools to [http://www.cmake.org/ CMake].
+is the migration from autotools to [CMake](http://www.cmake.org/).
Check out the (unstable!)
-[https://github.com/schuhschuh/gflags/tree/cmake-migration cmake-migration]
+[cmake-migration](https://github.com/schuhschuh/gflags/tree/cmake-migration)
branch on GitHub for details.
-=== 25 January 2012 ===
+25 January 2012
+---------------
I've just released gflags 2.0.
@@ -91,8 +106,7 @@ around gflags and the ideas you have for the project going forward,
and look forward to having you on the team.
I bumped the major version number up to 2 to reflect the new community
-ownership of the project. All the
-[http://gflags.googlecode.com/svn/tags/gflags-2.0/ChangeLog changes]
+ownership of the project. All the [changes](ChangeLog.txt)
are related to the renaming. There are no functional changes from
gflags 1.7. In particular, I've kept the code in the namespace
`google`, though in a future version it should be renamed to `gflags`.
@@ -101,7 +115,8 @@ synonym of `/usr/local/include/gflags/`, though the former name has
been obsolete for some time now.
-=== 18 January 2011 ===
+18 January 2011
+---------------
The `google-gflags` Google Code page has been renamed to
`gflags`, in preparation for the project being renamed to
@@ -111,15 +126,16 @@ relinquishing ownership of the project; it will now be entirely
community run. The name change reflects that shift.
-=== 20 December 2011 ===
+20 December 2011
+----------------
I've just released gflags 1.7. This is a minor release; the major
change is that `CommandLineFlagInfo` now exports the address in memory
where the flag is located. There has also been a bugfix involving
-very long --help strings, and some other minor
-[http://code.google.com/p/google-gflags/source/browse/tags/gflags-1.7/ChangeLog changes].
+very long --help strings, and some other minor [changes](ChangeLog.txt).
-=== 29 July 2011 ===
+29 July 2011
+------------
I've just released gflags 1.6. The major new feature in this release
is support for setting version info, so that --version does something
@@ -138,11 +154,10 @@ frequent updates with better change descriptions. They will also
result in future `ChangeLog` entries being much more verbose (for better
or for worse).
-See the
-[http://code.google.com/p/google-gflags/source/browse/tags/gflags-1.6/ChangeLog ChangeLog]
-for a full list of changes for this release.
+See the [ChangeLog](ChangeLog.txt) for a full list of changes for this release.
-=== 24 January 2011 ===
+24 January 2011
+---------------
I've just released gflags 1.5. This release has only minor changes
from 1.4, including some slightly better reporting in --help, and
@@ -152,28 +167,30 @@ libraries under valgrind. The major change is to fix up the macros
If you have not had a problem with these macros, and don't need any of
the other changes described, there is no need to upgrade. See the
-[http://code.google.com/p/google-gflags/source/browse/tags/gflags-1.5/ChangeLog ChangeLog]
-for a full list of changes for this release.
+[ChangeLog](ChangeLog.txt) for a full list of changes for this release.
-=== 11 October 2010 ===
+11 October 2010
+---------------
I've just released gflags 1.4. This release has only minor changes
from 1.3, including some documentation tweaks and some work to make
the library smaller. If 1.3 is working well for you, there's no
particular reason to upgrade.
-=== 4 January 2010 ===
+4 January 2010
+--------------
I've just released gflags 1.3. gflags now compiles under MSVC, and
-all tests pass. I *really* never thought non-unix-y Windows folks
+all tests pass. I **really** never thought non-unix-y Windows folks
would want gflags, but at least some of them do.
The major news, though, is that I've separated out the python package
-into its own library, [http://code.google.com/p/python-gflags python-gflags].
+into its own library, [python-gflags](http://code.google.com/p/python-gflags).
If you're interested in the Python version of gflags, that's the place to
get it now.
-=== 10 September 2009 ==
+10 September 2009
+-----------------
I've just released gflags 1.2. The major change from gflags 1.1 is it
now compiles under MinGW (as well as cygwin), and all tests pass. I
@@ -184,14 +201,13 @@ wrong!
The other changes are minor, such as support for --htmlxml in the
python version of gflags.
-=== 15 April 2009 ===
+15 April 2009
+-------------
I've just released gflags 1.1. It has only minor changes fdrom gflags
-1.0 (see the
-[http://code.google.com/p/google-gflags/source/browse/tags/gflags-1.1/ChangeLog ChangeLog]
-for details). The major change is that I moved to a new
-system for creating .deb and .rpm files. This allows me to create
-x86_64 deb and rpm files.
+1.0 (see the [ChangeLog](ChangeLog.txt) for details).
+The major change is that I moved to a new system for creating .deb and .rpm files.
+This allows me to create x86\_64 deb and rpm files.
In the process of moving to this new system, I noticed an
inconsistency: the tar.gz and .rpm files created libraries named
@@ -199,7 +215,7 @@ libgflags.so, but the deb file created libgoogle-gflags.so. I have
fixed the deb file to create libraries like the others. I'm no expert
in debian packaging, but I believe this has caused the package name to
change as well. Please let me know (at
-[mailto:google-gflags@googlegroups.com
+[[mailto:google-gflags@googlegroups.com](mailto:google-gflags@googlegroups.com)
google-gflags@googlegroups.com]) if this causes problems for you --
especially if you know of a fix! I would be happy to change the deb
packages to add symlinks from the old library name to the new
@@ -210,20 +226,21 @@ If you've tried to install a .rpm or .deb and it doesn't work for you,
let me know. I'm excited to finally have 64-bit package files, but
there may still be some wrinkles in the new system to iron out.
-=== 1 October 2008 ===
+1 October 2008
+--------------
gflags 1.0rc2 was out for a few weeks without any issues, so gflags
1.0 is now released. This is much like gflags 0.9. The major change
is that the .h files have been moved from `/usr/include/google` to
`/usr/include/gflags`. While I have backwards-compatibility
forwarding headeds in place, please rewrite existing code to say
-{{{
+```
#include
-}}}
+```
instead of
-{{{
+```
#include
-}}}
+```
I've kept the default namespace to google. You can still change with
with the appropriate flag to the configure script (`./configure
@@ -233,8 +250,7 @@ non-backwards-compatible change, send mail to
`google-gflags@googlegroups.com`!
Version 1.0 also has some neat new features, like support for bash
-commandline-completion of help flags. See the
-[http://code.google.com/p/google-gflags/source/browse/tags/gflags-1.0rc2/ChangeLog
-ChangeLog] for more details.
+commandline-completion of help flags. See the [ChangeLog](ChangeLog.txt)
+for more details.
If I don't hear any bad news for a few weeks, I'll release 1.0-final.
diff --git a/README.txt b/README.txt
deleted file mode 100644
index 958c87e..0000000
--- a/README.txt
+++ /dev/null
@@ -1,4 +0,0 @@
-This package contains a library that implements commandline flags
-processing. As such it's a replacement for getopt(). It has increased
-flexibility, including built-in support for C++ types like string, and
-the ability to define flags in the source file in which they're used.
From 2614f123fd77603196ed4ac3ae6ff27be55c2f32 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 12:41:43 +0000
Subject: [PATCH 62/94] doc: Convert INSTALL instructions to Markdown
---
INSTALL.md | 54 +++++++++++++++++++++++++++++++++++++++++
INSTALL.txt | 70 -----------------------------------------------------
2 files changed, 54 insertions(+), 70 deletions(-)
create mode 100644 INSTALL.md
delete mode 100644 INSTALL.txt
diff --git a/INSTALL.md b/INSTALL.md
new file mode 100644
index 0000000..d054193
--- /dev/null
+++ b/INSTALL.md
@@ -0,0 +1,54 @@
+Installing a binary distribution package
+========================================
+
+No official binary distribution packages are provided by the gflags developers.
+There may, however, be binary packages available for your OS. Please consult
+also the package repositories of your Linux distribution.
+
+For example on Debian/Ubuntu Linux, gflags can be installed using the
+following command:
+
+ sudo apt-get install gflags
+
+
+Compiling the source code
+=========================
+
+The build system of gflags is since version 2.1 based on [CMake](http://cmake.org).
+The common steps to build, test, and install software are therefore:
+
+1. Extract source files.
+2. Create build directory and change to it.
+3. Run CMake to configure the build tree.
+4. Build the software using selected build tool.
+5. Test the built software.
+6. Install the built files.
+
+On Unix-like systems with GNU Make as build tool, these build steps can be
+summarized by the following sequence of commands executed in a shell,
+where ```$package``` and ```$version``` are shell variables which represent
+the name of this package and the obtained version of the software.
+
+ $ tar xzf gflags-$version-source.tar.gz
+ $ cd gflags-$version
+ $ mkdir build && cd build
+ $ ccmake ..
+
+ - Press 'c' to configure the build system and 'e' to ignore warnings.
+ - Set CMAKE_INSTALL_PREFIX and other CMake variables and options.
+ - Continue pressing 'c' until the option 'g' is available.
+ - Then press 'g' to generate the configuration files for GNU Make.
+
+ $ make
+ $ make test (optional)
+ $ make install (optional)
+
+In the following, only gflags-specific CMake settings available to
+configure the build and installation are documented.
+
+
+CMake Option | Description
+---------------------- | -------------------------------------------------------
+CMAKE_INSTALL_PREFIX | Installation directory, e.g., "/usr/local" on Unix and "C:\Program Files\gflags" on Windows.
+GFLAGS_NAMESPACE | Name of the C++ namespace to be used by the gflags library. Note that the public source header files are installed in a subdirectory named after this namespace. To maintain backwards compatibility with the Google Commandline Flags, set this variable to "google". The default is "gflags".
+GFLAGS_INCLUDE_DIR | Name of include subdirectory where headers are installed into.
diff --git a/INSTALL.txt b/INSTALL.txt
deleted file mode 100644
index a96a772..0000000
--- a/INSTALL.txt
+++ /dev/null
@@ -1,70 +0,0 @@
-
-INSTALLING A BINARY DISTRIBUTION PACKAGE
-========================================
-
-No official binary distribution packages are provided by the gflags developers.
-There may, however, be binary packages available for your OS at
-https://code.google.com/p/gflags/downloads/list. Please consult also the
-package repositories of your Linux distribution.
-
-For example on Debian/Ubuntu Linux, gflags can be installed using the
-following command:
-
-$ sudo apt-get install gflags
-
-
-
-BUILDING THE SOFTWARE FROM SOURCES
-==================================
-
-Build Steps
------------
-
-The build system of gflags is since version 2.1 based on CMake (cmake.org).
-The common steps to build, test, and install software based on CMake are:
-
-1. Extract source files.
-2. Create build directory and change to it.
-3. Run CMake to configure the build tree.
-4. Build the software using selected build tool.
-5. Test the built software.
-6. Install the built files.
-
-On Unix-like systems with GNU Make as build tool, these build steps can be
-summarized by the following sequence of commands executed in a shell,
-where $package and $version are shell variables which represent the name
-of this package and the obtained version of the software.
-
-$ tar xzf gflags-$version-source.tar.gz
-$ cd gflags-$version
-$ mkdir build && cd build
-$ ccmake ..
-
- - Press 'c' to configure the build system and 'e' to ignore warnings.
- - Set CMAKE_INSTALL_PREFIX and other CMake variables and options.
- - Continue pressing 'c' until the option 'g' is available.
- - Then press 'g' to generate the configuration files for GNU Make.
-
-$ make
-$ make test (optional)
-$ make install (optional)
-
-In the following, only gflags-specific CMake settings available to
-configure the build and installation are documented.
-
-
-CMake Options
--------------
-
-- CMAKE_INSTALL_PREFIX Installation directory, e.g., "/usr/local" on Unix
- and "C:\Program Files\gflags" on Windows.
-
-
-Advanced CMake Options
-----------------------
-
-- GFLAGS_NAMESPACE Name of the C++ namespace to be used by the gflags library.
- Note that the public source header files are installed in
- a subdirectory named after this namespace. To maintain
- backwards compatibility with the Google Commandline Flags,
- set this variable to "google". The default is "gflags".
From 3a49eafd20121a192f8240e100787527cddc3bad Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 12:51:30 +0000
Subject: [PATCH 63/94] add: Files from doc/ directory of master branch
---
designstyle.css | 115 ++++++++++
gflags.html | 558 ++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 673 insertions(+)
create mode 100644 designstyle.css
create mode 100644 gflags.html
diff --git a/designstyle.css b/designstyle.css
new file mode 100644
index 0000000..f5d1ec2
--- /dev/null
+++ b/designstyle.css
@@ -0,0 +1,115 @@
+body {
+ background-color: #ffffff;
+ color: black;
+ margin-right: 1in;
+ margin-left: 1in;
+}
+
+
+h1, h2, h3, h4, h5, h6 {
+ color: #3366ff;
+ font-family: sans-serif;
+}
+@media print {
+ /* Darker version for printing */
+ h1, h2, h3, h4, h5, h6 {
+ color: #000080;
+ font-family: helvetica, sans-serif;
+ }
+}
+
+h1 {
+ text-align: center;
+ font-size: 18pt;
+}
+h2 {
+ margin-left: -0.5in;
+}
+h3 {
+ margin-left: -0.25in;
+}
+h4 {
+ margin-left: -0.125in;
+}
+hr {
+ margin-left: -1in;
+}
+
+/* Definition lists: definition term bold */
+dt {
+ font-weight: bold;
+}
+
+address {
+ text-align: right;
+}
+/* Use the tag for bits of code and for variables and objects. */
+code,pre,samp,var {
+ color: #006000;
+}
+/* Use the tag for file and directory paths and names. */
+file {
+ color: #905050;
+ font-family: monospace;
+}
+/* Use the tag for stuff the user should type. */
+kbd {
+ color: #600000;
+}
+div.note p {
+ float: right;
+ width: 3in;
+ margin-right: 0%;
+ padding: 1px;
+ border: 2px solid #6060a0;
+ background-color: #fffff0;
+}
+
+UL.nobullets {
+ list-style-type: none;
+ list-style-image: none;
+ margin-left: -1em;
+}
+
+/*
+body:after {
+ content: "Google Confidential";
+}
+*/
+
+/* pretty printing styles. See prettify.js */
+.str { color: #080; }
+.kwd { color: #008; }
+.com { color: #800; }
+.typ { color: #606; }
+.lit { color: #066; }
+.pun { color: #660; }
+.pln { color: #000; }
+.tag { color: #008; }
+.atn { color: #606; }
+.atv { color: #080; }
+pre.prettyprint { padding: 2px; border: 1px solid #888; }
+
+.embsrc { background: #eee; }
+
+@media print {
+ .str { color: #060; }
+ .kwd { color: #006; font-weight: bold; }
+ .com { color: #600; font-style: italic; }
+ .typ { color: #404; font-weight: bold; }
+ .lit { color: #044; }
+ .pun { color: #440; }
+ .pln { color: #000; }
+ .tag { color: #006; font-weight: bold; }
+ .atn { color: #404; }
+ .atv { color: #060; }
+}
+
+/* Table Column Headers */
+.hdr {
+ color: #006;
+ font-weight: bold;
+ background-color: #dddddd; }
+.hdr2 {
+ color: #006;
+ background-color: #eeeeee; }
\ No newline at end of file
diff --git a/gflags.html b/gflags.html
new file mode 100644
index 0000000..3a66713
--- /dev/null
+++ b/gflags.html
@@ -0,0 +1,558 @@
+
+
+
+
+How To Use Gflags (formerly Google Commandline Flags)
+
+
+
+
+
+
+
+
+
How To Use gflags (formerly Google Commandline Flags)
Commandline flags are flags that users specify on the
+command line when they run an executable. In the command
+
+ fgrep -l -f /var/tmp/foo johannes brahms
+
+
-l and -f /var/tmp/foo are the two
+commandline flags. (johannes and brahms,
+which don't start with a dash, are commandline arguments.)
+
+
Typically, an application lists what flags the user is allowed to
+pass in, and what arguments they take -- in this example,
+-l takes no argument, and -f takes a
+string (in particular, a filename) as an argument. Users can use a
+library to help parse the commandline and store the flags in some data
+structure.
+
+
Gflags, the commandline flags library used within Google,
+differs from other libraries,
+such as getopt(), in that flag definitions can be
+scattered around the source code, and not just listed in one place
+such as main(). In practice, this means that a single
+source-code file will define and use flags that are meaningful to that
+file. Any application that links in that file will get the flags, and
+the gflags library will automatically handle that
+flag appropriately.
+
+
There's significant gain in flexibility, and ease of code reuse,
+due to this technique. However, there is a danger that two files will
+define the same flag, and then give an error when they're linked
+together.
+
+
The rest of this document describes how to use the commandlineflag
+library. It's a C++ library, so examples are in C++. However, there
+is a Python port with the same functionality, and this discussion
+translates directly to Python.
Using gflags within a project which uses CMake for its build system is easy. Therefore, simply add the following CMake code to your CMakeLists.txt file.
+
+
Defining a flag is easy: just use the appropriate macro for the
+type you want the flag to be, as defined at the bottom of
+gflags/gflags.h. Here's an example file,
+foo.cc:
+
+
+ #include <gflags/gflags.h>
+
+ DEFINE_bool(big_menu, true, "Include 'advanced' options in the menu listing");
+ DEFINE_string(languages, "english,french,german",
+ "comma-separated list of languages to offer in the 'lang' menu");
+
+
+
DEFINE_bool defines a boolean flag. Here are the
+types supported:
+
+
DEFINE_bool: boolean
+
DEFINE_int32: 32-bit integer
+
DEFINE_int64: 64-bit integer
+
DEFINE_uint64: unsigned 64-bit integer
+
DEFINE_double: double
+
DEFINE_string: C++ string
+
+
+
Note that there are no 'complex' types like lists: the "languages"
+flag in our example is a list of strings, but is defined of type
+"string", not "list_of_string" or similar. This is by design. We'd
+rather use only simple types for the flags, and allow for complex,
+arbitrary parsing routines to parse them, than to try to put the logic
+inside the flags library proper.
+
+
All DEFINE macros take the same three arguments: the name of the
+flag, its default value, and a 'help' string that describes its use.
+The 'help' string is displayed when the user runs the application with
+the --help flag.
+
+
You can define a flag in any source-code file in your executable.
+Only define a flag once! If you want to access a flag in more than
+one source file, DEFINE it in one file, and DECLARE it in the others. Even better, DEFINE it
+in foo.cc and DECLARE it in foo.h; then
+everyone who #includes foo.h can use the flag.
+
+
+Defining flags in libraries rather than in main() is powerful, but
+does have some costs. One is that a library might not have a good
+default value for its flags, for example if the flag holds a
+filename that might not exist in some environments. To mitigate such problems,
+you can use flag validators to ensure prompt
+notification (in the form of a crash) of an invalid flag value.
+
+
+
Note that while most functions in this library are defined in the
+google namespace, DEFINE_foo (and
+DECLARE_foo, below), should always
+be in the global namespace.
All defined flags are available to the program as just a normal
+variable, with the prefix FLAGS_ prepended. In the above
+example, the macros define two variables, FLAGS_big_menu
+(a bool), and FLAGS_languages (a C++ string).
+
+
You can read and write to the flag just like any other
+variable:
+
+ if (FLAGS_consider_made_up_languages)
+ FLAGS_languages += ",klingon"; // implied by --consider_made_up_languages
+ if (FLAGS_languages.find("finnish") != string::npos)
+ HandleFinnish();
+
+
+
You can also get and set flag values via special functions in
+gflags.h. That's a rarer use case, though.
Accessing a flag in the manner of the previous section only works
+if the flag was DEFINE-ed at the top of the file. If it
+wasn't, you'll get an 'unknown variable' error.
+
+
The DECLARE_type macro is available when you want to
+use a flag that's defined in another file. For instance, if I were
+writing bar.cc but wanted to access the big_menu, flag, I
+would put this near the top of bar.cc:
+
+ DECLARE_bool(big_menu);
+
+
+
This is functionally equivalent to saying extern
+FLAGS_big_menu.
+
+
Note that such an extern declaration introduces a dependency
+between your file and the file that defines the big_menu
+flag: foo.cc, in this case. Such implicit dependencies
+can be difficult to manage in large projects. For that reason we
+recommend the following guideline:
+
+
+If you DEFINE a flag in foo.cc, either don't DECLARE it
+at all, only DECLARE it in tightly related tests, or only DECLARE
+it in foo.h.
+
+
+
You should go the do-not-DECLARE route when the flag is only needed
+by foo.cc, and not in any other file. If you want to
+modify the value of the flag in the related test file to see if it is
+functioning as expected, DECLARE it in the foo_test.cc
+file.
+
+
If the flag does span multiple files, DECLARE it in the associated
+.h file, and make others #include that
+.h file if they want to access the flag. The
+#include will make explicit the dependency between the
+two files. This causes the flag to be a global variable.
After DEFINE-ing a flag, you may optionally register a validator
+function with the flag. If you do this, after the flag is parsed from
+the commandline, and whenever its value is changed via a call to
+SetCommandLineOption(), the validator function is called
+with the new value as an argument. The validator function should
+return 'true' if the flag value is valid, and false otherwise.
+If the function returns false for the new setting of the
+flag, the flag will retain its current value. If it returns false for the
+default value, ParseCommandLineFlags will die.
+
+
Here is an example use of this functionality:
+
+static bool ValidatePort(const char* flagname, int32 value) {
+ if (value > 0 && value < 32768) // value is ok
+ return true;
+ printf("Invalid value for --%s: %d\n", flagname, (int)value);
+ return false;
+}
+DEFINE_int32(port, 0, "What port to listen on");
+static const bool port_dummy = RegisterFlagValidator(&FLAGS_port, &ValidatePort);
+
+
+
By doing the registration at global initialization time (right
+after the DEFINE), we ensure that the registration happens before
+the commandline is parsed at the beginning of main().
+
+
RegisterFlagValidator() returns true if the
+registration is successful. It return false if the registration fails
+because a) the first argument does not refer to a commandline flag, or
+b) a different validator has already been registered for this flag.
The final piece is the one that tells the executable to process the
+commandline flags, and set the FLAGS_* variables to the
+appropriate, non-default value based on what is seen on the
+commandline. This is equivalent to the getopt() call in
+the getopt library, but has much less overhead to use. In fact, it's
+just a single function call:
Usually, this code is at the beginning of main().
+argc and argv are exactly as passed in to
+main(). This routine might modify them, which is why
+pointers to them are passed in.
+
+
The last argument is called "remove_flags". If true, then
+ParseCommandLineFlags removes the flags and their
+arguments from argv, and modifies argc
+appropriately. In this case, after the function call,
+argv will hold only commandline arguments, and not
+commandline flags.
+
+
If, on the other hand, remove_flags is false, then
+ParseCommandLineFlags will leave argc unchanged, but will
+rearrange the arguments in argv so that the flags are all at the
+beginning. For example, if the input is "/bin/foo" "arg1" "-q"
+"arg2" (which is legal but weird), the function will rearrange
+argv so it reads "/bin/foo", "-q", "arg1",
+"arg2". In this case, ParseCommandLineFlags
+returns the index into argv that holds the first commandline argument:
+that is, the index past the last flag. (In this example, it would
+return 2, since argv[2] points to arg1.)
The reason you make something a flag instead of a compile-time
+constant, is so users can specify a non-default value on the
+commandline. Here's how they might do it for an application that
+links in foo.cc:
This sets FLAGS_big_menu = false; and
+FLAGS_languages = "chinese,japanese,korean", when
+ParseCommandLineFlags is run.
+
+
Note the atypical syntax for setting a boolean flag to false:
+putting "no" in front of its name. There's a fair bit of flexibility
+to how flags may be specified. Here's an example of all the ways to
+specify the "languages" flag:
For boolean flags, the possibilities are slightly different:
+
+
app_containing_foo --big_menu
+
app_containing_foo --nobig_menu
+
app_containing_foo --big_menu=true
+
app_containing_foo --big_menu=false
+
+
(as well as the single-dash variant on all of these).
+
+
Despite this flexibility, we recommend using only a single form:
+--variable=value for non-boolean flags, and
+--variable/--novariable for boolean flags. This
+consistency will make your code more readable, and is also the format
+required for certain special-use cases like flagfiles.
+
+
It is a fatal error to specify a flag on the commandline that has
+not been DEFINED somewhere in the executable. If you need that
+functionality for some reason -- say you want to use the same set of
+flags for several executables, but not all of them DEFINE every flag
+in your list -- you can specify --undefok to suppress the error.
+
+
As in getopt(), -- by itself will terminate flags
+processing. So in foo -f1 1 -- -f2 2, f1 is
+considered a flag, but -f2 is not.
+
+
If a flag is specified more than once, only the last specification
+is used; the others are ignored.
+
+
Note that flags do not have single-letter synonyms, like they do in
+the getopt library, nor do we allow "combining" flags behind a
+single dash, as in ls -la.
Sometimes a flag is defined in a library, and you want to change
+its default value in one application but not others. It's simple to
+do this: just assign a new value to the flag in main(),
+before calling ParseCommandLineFlags():
+
+ DECLARE_bool(lib_verbose); // mylib has a lib_verbose flag, default is false
+ int main(int argc, char** argv) {
+ FLAGS_lib_verbose = true; // in my app, I want a verbose lib by default
+ ParseCommandLineFlags(...);
+ }
+
+
+
For this application, users can still set the flag value on the
+commandline, but if they do not, the flag's value will default to
+true.
There are a few flags defined by the commandlineflags module
+itself, and are available to all applications that use
+commandlineflags. These fall into
+three categories. First are the 'reporting' flags that, when found, cause
+the application to print some information about itself and exit.
+
+
+
--help
+
shows all flags from all files, sorted by file and then by name;
+ shows the flagname, its default value, and its help string
+
+
--helpfull
+
same as -help, but unambiguously asks for all flags
+ (in case -help changes in the future)
+
+
--helpshort
+
shows only flags for the file with the same name as the executable
+ (usually the one containing main())
+
+
--helpxml
+
like --help, but output is in xml for easier parsing
+
+
--helpon=FILE
+
shows only flags defined in FILE.*
+
+
--helpmatch=S
+
shows only flags defined in *S*.*
+
+
--helppackage
+
shows flags defined in files in same directory as main()
+
+
--version
+
prints version info for the executable
+
+
+
Second are the flags that affect how other flags are parsed.
+
+
+
--undefok=flagname,flagname,...
+
for those names listed as the argument to --undefok,
+ suppress the normal error-exit that occurs when
+ --name is seen on the commandline, but
+ name has not been DEFINED anywhere in the
+ application
+
+
+
Third are the 'recursive' flags, that cause other flag values to be
+set: --fromenv, --tryfromenv,
+--flagfile. These are described below in more
+detail.
+
+
--fromenv
+
+
--fromenv=foo,bar says to read the values for the
+foo and bar flags from the environment.
+In concert with this flag, you must actually set the values in the
+environment, via a line like one of the two below:
This is equivalent to specifying --foo=xxx,
+--bar=yyy on the commandline.
+
+
Note it is a fatal error to say --fromenv=foo if
+foo is not DEFINED somewhere in the application. (Though
+you can suppress this error via --undefok=foo, just like
+for any other flag.)
+
+
It is also a fatal error to say --fromenv=foo if
+FLAGS_foo is not actually defined in the environment.
+
+
--tryfromenv
+
+
--tryfromenv is exactly like --fromenv,
+except it is not a fatal error to say
+--tryfromenv=foo if FLAGS_foo is not
+actually defined in the environment. Instead, in such cases,
+FLAGS_foo just keeps its default value as specified in
+the application.
+
+
Note it is still an error to say --tryfromenv=foo if
+foo is not DEFINED somewhere in the application.
+
+
--flagfile
+
+
--flagfile=f tells the commandlineflags module to read
+the file f, and to run all the flag-assignments found in
+that file as if these flags had been specified on the commandline.
+
+
In its simplest form, f should just be a list of flag
+assignments, one per line. Unlike on the commandline, the equals sign
+separating a flagname from its argument is required for
+flagfiles. An example flagfile, /tmp/myflags:
+
+--nobig_menus
+--languages=english,french
+
+
+
With this flagfile, the following two lines are equivalent:
Note that many errors are silently suppressed in flagfiles. In
+particular, unrecognized flagnames are silently ignored, as are flags
+that are missing a required value (e.g., a flagfile that just says
+--languages).
+
+
The general format of a flagfile is a bit more complicated than the
+simple, common case above. It is: a sequence of filenames, one per
+line, followed by a sequence of flags, one per line, repeated as many
+times as desired. Filenames in a flagfile can use wildcards
+(* and ?), and the sequence of flags located
+after a sequence of filenames is processed only if the current
+executable's name matches one of the filenames. It is possible to
+start the flagfile with a sequence of flags instead of a sequence of
+filenames; if such a sequence of flags is present, these flags are
+applied to the current executable no matter what it is.
+
+
Lines that start with a # are ignored as comments.
+Leading whitespace is also ignored in flagfiles, as are blank
+lines.
+
+
It is possible for a flagfile to use the --flagfile
+flag to include another flagfile.
+
+
Flags are always processed in the expected order. That is,
+processing begins by examining the flags specified directly on the
+command line. If a flagfile is specified, its contents are processed,
+and then processing continues with remaining flags from the command
+line.
In addition to accessing FLAGS_foo directly, it is
+possible to access the flags programmatically, through an API. It is
+also possible to access information about a flag, such as its default
+value and help-string. A FlagSaver makes it easy to
+modify flags and then automatically undo the modifications later.
+Finally, there are somewhat unrelated, but useful, routines to easily
+access parts of argv outside main, including the program
+name (argv[0]).
+
+
For more information about these routines, and other useful helper
+methods such as gflags::SetUsageMessage() and
+gflags::SetVersionString, see gflags.h.
+ #define STRIP_FLAG_HELP 1 // this must go before the #include!
+ #include <gflags/gflags.h>
+
+
we will remove the help messages from the compiled source. This can
+reduce the size of the resulting binary somewhat, and may also be
+useful for security reasons.
Commandline flags are flags that users specify on the
-command line when they run an executable. In the command
-
- fgrep -l -f /var/tmp/foo johannes brahms
-
-
-l and -f /var/tmp/foo are the two
-commandline flags. (johannes and brahms,
-which don't start with a dash, are commandline arguments.)
-
-
Typically, an application lists what flags the user is allowed to
-pass in, and what arguments they take -- in this example,
--l takes no argument, and -f takes a
-string (in particular, a filename) as an argument. Users can use a
-library to help parse the commandline and store the flags in some data
-structure.
-
-
Gflags, the commandline flags library used within Google,
-differs from other libraries,
-such as getopt(), in that flag definitions can be
-scattered around the source code, and not just listed in one place
-such as main(). In practice, this means that a single
-source-code file will define and use flags that are meaningful to that
-file. Any application that links in that file will get the flags, and
-the gflags library will automatically handle that
-flag appropriately.
-
-
There's significant gain in flexibility, and ease of code reuse,
-due to this technique. However, there is a danger that two files will
-define the same flag, and then give an error when they're linked
-together.
-
-
The rest of this document describes how to use the commandlineflag
-library. It's a C++ library, so examples are in C++. However, there
-is a Python port with the same functionality, and this discussion
-translates directly to Python.
Using gflags within a project which uses CMake for its build system is easy. Therefore, simply add the following CMake code to your CMakeLists.txt file.
-
-
Defining a flag is easy: just use the appropriate macro for the
-type you want the flag to be, as defined at the bottom of
-gflags/gflags.h. Here's an example file,
-foo.cc:
-
-
- #include <gflags/gflags.h>
-
- DEFINE_bool(big_menu, true, "Include 'advanced' options in the menu listing");
- DEFINE_string(languages, "english,french,german",
- "comma-separated list of languages to offer in the 'lang' menu");
-
-
-
DEFINE_bool defines a boolean flag. Here are the
-types supported:
-
-
DEFINE_bool: boolean
-
DEFINE_int32: 32-bit integer
-
DEFINE_int64: 64-bit integer
-
DEFINE_uint64: unsigned 64-bit integer
-
DEFINE_double: double
-
DEFINE_string: C++ string
-
-
-
Note that there are no 'complex' types like lists: the "languages"
-flag in our example is a list of strings, but is defined of type
-"string", not "list_of_string" or similar. This is by design. We'd
-rather use only simple types for the flags, and allow for complex,
-arbitrary parsing routines to parse them, than to try to put the logic
-inside the flags library proper.
-
-
All DEFINE macros take the same three arguments: the name of the
-flag, its default value, and a 'help' string that describes its use.
-The 'help' string is displayed when the user runs the application with
-the --help flag.
-
-
You can define a flag in any source-code file in your executable.
-Only define a flag once! If you want to access a flag in more than
-one source file, DEFINE it in one file, and DECLARE it in the others. Even better, DEFINE it
-in foo.cc and DECLARE it in foo.h; then
-everyone who #includes foo.h can use the flag.
-
-
-Defining flags in libraries rather than in main() is powerful, but
-does have some costs. One is that a library might not have a good
-default value for its flags, for example if the flag holds a
-filename that might not exist in some environments. To mitigate such problems,
-you can use flag validators to ensure prompt
-notification (in the form of a crash) of an invalid flag value.
-
-
-
Note that while most functions in this library are defined in the
-google namespace, DEFINE_foo (and
-DECLARE_foo, below), should always
-be in the global namespace.
All defined flags are available to the program as just a normal
-variable, with the prefix FLAGS_ prepended. In the above
-example, the macros define two variables, FLAGS_big_menu
-(a bool), and FLAGS_languages (a C++ string).
-
-
You can read and write to the flag just like any other
-variable:
-
- if (FLAGS_consider_made_up_languages)
- FLAGS_languages += ",klingon"; // implied by --consider_made_up_languages
- if (FLAGS_languages.find("finnish") != string::npos)
- HandleFinnish();
-
-
-
You can also get and set flag values via special functions in
-gflags.h. That's a rarer use case, though.
Accessing a flag in the manner of the previous section only works
-if the flag was DEFINE-ed at the top of the file. If it
-wasn't, you'll get an 'unknown variable' error.
-
-
The DECLARE_type macro is available when you want to
-use a flag that's defined in another file. For instance, if I were
-writing bar.cc but wanted to access the big_menu, flag, I
-would put this near the top of bar.cc:
-
- DECLARE_bool(big_menu);
-
-
-
This is functionally equivalent to saying extern
-FLAGS_big_menu.
-
-
Note that such an extern declaration introduces a dependency
-between your file and the file that defines the big_menu
-flag: foo.cc, in this case. Such implicit dependencies
-can be difficult to manage in large projects. For that reason we
-recommend the following guideline:
-
-
-If you DEFINE a flag in foo.cc, either don't DECLARE it
-at all, only DECLARE it in tightly related tests, or only DECLARE
-it in foo.h.
-
-
-
You should go the do-not-DECLARE route when the flag is only needed
-by foo.cc, and not in any other file. If you want to
-modify the value of the flag in the related test file to see if it is
-functioning as expected, DECLARE it in the foo_test.cc
-file.
-
-
If the flag does span multiple files, DECLARE it in the associated
-.h file, and make others #include that
-.h file if they want to access the flag. The
-#include will make explicit the dependency between the
-two files. This causes the flag to be a global variable.
After DEFINE-ing a flag, you may optionally register a validator
-function with the flag. If you do this, after the flag is parsed from
-the commandline, and whenever its value is changed via a call to
-SetCommandLineOption(), the validator function is called
-with the new value as an argument. The validator function should
-return 'true' if the flag value is valid, and false otherwise.
-If the function returns false for the new setting of the
-flag, the flag will retain its current value. If it returns false for the
-default value, ParseCommandLineFlags will die.
-
-
Here is an example use of this functionality:
-
-static bool ValidatePort(const char* flagname, int32 value) {
- if (value > 0 && value < 32768) // value is ok
- return true;
- printf("Invalid value for --%s: %d\n", flagname, (int)value);
- return false;
-}
-DEFINE_int32(port, 0, "What port to listen on");
-static const bool port_dummy = RegisterFlagValidator(&FLAGS_port, &ValidatePort);
-
-
-
By doing the registration at global initialization time (right
-after the DEFINE), we ensure that the registration happens before
-the commandline is parsed at the beginning of main().
-
-
RegisterFlagValidator() returns true if the
-registration is successful. It return false if the registration fails
-because a) the first argument does not refer to a commandline flag, or
-b) a different validator has already been registered for this flag.
The final piece is the one that tells the executable to process the
-commandline flags, and set the FLAGS_* variables to the
-appropriate, non-default value based on what is seen on the
-commandline. This is equivalent to the getopt() call in
-the getopt library, but has much less overhead to use. In fact, it's
-just a single function call:
Usually, this code is at the beginning of main().
-argc and argv are exactly as passed in to
-main(). This routine might modify them, which is why
-pointers to them are passed in.
-
-
The last argument is called "remove_flags". If true, then
-ParseCommandLineFlags removes the flags and their
-arguments from argv, and modifies argc
-appropriately. In this case, after the function call,
-argv will hold only commandline arguments, and not
-commandline flags.
-
-
If, on the other hand, remove_flags is false, then
-ParseCommandLineFlags will leave argc unchanged, but will
-rearrange the arguments in argv so that the flags are all at the
-beginning. For example, if the input is "/bin/foo" "arg1" "-q"
-"arg2" (which is legal but weird), the function will rearrange
-argv so it reads "/bin/foo", "-q", "arg1",
-"arg2". In this case, ParseCommandLineFlags
-returns the index into argv that holds the first commandline argument:
-that is, the index past the last flag. (In this example, it would
-return 2, since argv[2] points to arg1.)
The reason you make something a flag instead of a compile-time
-constant, is so users can specify a non-default value on the
-commandline. Here's how they might do it for an application that
-links in foo.cc:
This sets FLAGS_big_menu = false; and
-FLAGS_languages = "chinese,japanese,korean", when
-ParseCommandLineFlags is run.
-
-
Note the atypical syntax for setting a boolean flag to false:
-putting "no" in front of its name. There's a fair bit of flexibility
-to how flags may be specified. Here's an example of all the ways to
-specify the "languages" flag:
For boolean flags, the possibilities are slightly different:
-
-
app_containing_foo --big_menu
-
app_containing_foo --nobig_menu
-
app_containing_foo --big_menu=true
-
app_containing_foo --big_menu=false
-
-
(as well as the single-dash variant on all of these).
-
-
Despite this flexibility, we recommend using only a single form:
---variable=value for non-boolean flags, and
---variable/--novariable for boolean flags. This
-consistency will make your code more readable, and is also the format
-required for certain special-use cases like flagfiles.
-
-
It is a fatal error to specify a flag on the commandline that has
-not been DEFINED somewhere in the executable. If you need that
-functionality for some reason -- say you want to use the same set of
-flags for several executables, but not all of them DEFINE every flag
-in your list -- you can specify --undefok to suppress the error.
-
-
As in getopt(), -- by itself will terminate flags
-processing. So in foo -f1 1 -- -f2 2, f1 is
-considered a flag, but -f2 is not.
-
-
If a flag is specified more than once, only the last specification
-is used; the others are ignored.
-
-
Note that flags do not have single-letter synonyms, like they do in
-the getopt library, nor do we allow "combining" flags behind a
-single dash, as in ls -la.
Sometimes a flag is defined in a library, and you want to change
-its default value in one application but not others. It's simple to
-do this: just assign a new value to the flag in main(),
-before calling ParseCommandLineFlags():
-
- DECLARE_bool(lib_verbose); // mylib has a lib_verbose flag, default is false
- int main(int argc, char** argv) {
- FLAGS_lib_verbose = true; // in my app, I want a verbose lib by default
- ParseCommandLineFlags(...);
- }
-
-
-
For this application, users can still set the flag value on the
-commandline, but if they do not, the flag's value will default to
-true.
There are a few flags defined by the commandlineflags module
-itself, and are available to all applications that use
-commandlineflags. These fall into
-three categories. First are the 'reporting' flags that, when found, cause
-the application to print some information about itself and exit.
-
-
-
--help
-
shows all flags from all files, sorted by file and then by name;
- shows the flagname, its default value, and its help string
-
-
--helpfull
-
same as -help, but unambiguously asks for all flags
- (in case -help changes in the future)
-
-
--helpshort
-
shows only flags for the file with the same name as the executable
- (usually the one containing main())
-
-
--helpxml
-
like --help, but output is in xml for easier parsing
-
-
--helpon=FILE
-
shows only flags defined in FILE.*
-
-
--helpmatch=S
-
shows only flags defined in *S*.*
-
-
--helppackage
-
shows flags defined in files in same directory as main()
-
-
--version
-
prints version info for the executable
-
-
-
Second are the flags that affect how other flags are parsed.
-
-
-
--undefok=flagname,flagname,...
-
for those names listed as the argument to --undefok,
- suppress the normal error-exit that occurs when
- --name is seen on the commandline, but
- name has not been DEFINED anywhere in the
- application
-
-
-
Third are the 'recursive' flags, that cause other flag values to be
-set: --fromenv, --tryfromenv,
---flagfile. These are described below in more
-detail.
-
-
--fromenv
-
-
--fromenv=foo,bar says to read the values for the
-foo and bar flags from the environment.
-In concert with this flag, you must actually set the values in the
-environment, via a line like one of the two below:
This is equivalent to specifying --foo=xxx,
---bar=yyy on the commandline.
-
-
Note it is a fatal error to say --fromenv=foo if
-foo is not DEFINED somewhere in the application. (Though
-you can suppress this error via --undefok=foo, just like
-for any other flag.)
-
-
It is also a fatal error to say --fromenv=foo if
-FLAGS_foo is not actually defined in the environment.
-
-
--tryfromenv
-
-
--tryfromenv is exactly like --fromenv,
-except it is not a fatal error to say
---tryfromenv=foo if FLAGS_foo is not
-actually defined in the environment. Instead, in such cases,
-FLAGS_foo just keeps its default value as specified in
-the application.
-
-
Note it is still an error to say --tryfromenv=foo if
-foo is not DEFINED somewhere in the application.
-
-
--flagfile
-
-
--flagfile=f tells the commandlineflags module to read
-the file f, and to run all the flag-assignments found in
-that file as if these flags had been specified on the commandline.
-
-
In its simplest form, f should just be a list of flag
-assignments, one per line. Unlike on the commandline, the equals sign
-separating a flagname from its argument is required for
-flagfiles. An example flagfile, /tmp/myflags:
-
---nobig_menus
---languages=english,french
-
-
-
With this flagfile, the following two lines are equivalent:
Note that many errors are silently suppressed in flagfiles. In
-particular, unrecognized flagnames are silently ignored, as are flags
-that are missing a required value (e.g., a flagfile that just says
---languages).
-
-
The general format of a flagfile is a bit more complicated than the
-simple, common case above. It is: a sequence of filenames, one per
-line, followed by a sequence of flags, one per line, repeated as many
-times as desired. Filenames in a flagfile can use wildcards
-(* and ?), and the sequence of flags located
-after a sequence of filenames is processed only if the current
-executable's name matches one of the filenames. It is possible to
-start the flagfile with a sequence of flags instead of a sequence of
-filenames; if such a sequence of flags is present, these flags are
-applied to the current executable no matter what it is.
-
-
Lines that start with a # are ignored as comments.
-Leading whitespace is also ignored in flagfiles, as are blank
-lines.
-
-
It is possible for a flagfile to use the --flagfile
-flag to include another flagfile.
-
-
Flags are always processed in the expected order. That is,
-processing begins by examining the flags specified directly on the
-command line. If a flagfile is specified, its contents are processed,
-and then processing continues with remaining flags from the command
-line.
In addition to accessing FLAGS_foo directly, it is
-possible to access the flags programmatically, through an API. It is
-also possible to access information about a flag, such as its default
-value and help-string. A FlagSaver makes it easy to
-modify flags and then automatically undo the modifications later.
-Finally, there are somewhat unrelated, but useful, routines to easily
-access parts of argv outside main, including the program
-name (argv[0]).
-
-
For more information about these routines, and other useful helper
-methods such as gflags::SetUsageMessage() and
-gflags::SetVersionString, see gflags.h.
- #define STRIP_FLAG_HELP 1 // this must go before the #include!
- #include <gflags/gflags.h>
-
-
we will remove the help messages from the compiled source. This can
-reduce the size of the resulting binary somewhat, and may also be
-useful for security reasons.
-
-
-
-
-Craig Silverstein, Andreas Schuh
-
-
-
-
-
From 0133710d47adf544ae0010ba3bef52002d255721 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 12:59:56 +0000
Subject: [PATCH 67/94] add: Common build directory names to ignore list
---
.gitignore | 3 +++
1 file changed, 3 insertions(+)
diff --git a/.gitignore b/.gitignore
index 39cb957..4281522 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,3 +1,6 @@
+/xcode/
+/build/
+/build-*/
.DS_Store
CMakeCache.txt
DartConfiguration.tcl
From 02e8c78f9dbe475cf8ff4bf476686f524d48845d Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 13:21:35 +0000
Subject: [PATCH 68/94] doc: Spelling correction
---
README.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/README.md b/README.md
index 1d6790d..dee5d87 100644
--- a/README.md
+++ b/README.md
@@ -3,7 +3,7 @@
Finalized move of gflags project from Google Code to GitHub.
Email addresses of original issue reporters got lost in the process.
-Given the age of most issue reports, this should be neglibable.
+Given the age of most issue reports, this should be negligable.
Please report any further issues using the GitHub issue tracker.
From 04c73f86c3abd4ef9ae89aa5924a5364e108906f Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 14:39:43 +0000
Subject: [PATCH 69/94] doc: Remove no longer needed include_directories
command from example
---
index.html | 2 --
1 file changed, 2 deletions(-)
diff --git a/index.html b/index.html
index 3a66713..8c42a9d 100644
--- a/index.html
+++ b/index.html
@@ -97,8 +97,6 @@ translates directly to Python.
Commandline flags are flags that users specify on the
-command line when they run an executable. In the command
-
- fgrep -l -f /var/tmp/foo johannes brahms
-
-
-l and -f /var/tmp/foo are the two
-commandline flags. (johannes and brahms,
-which don't start with a dash, are commandline arguments.)
-
-
Typically, an application lists what flags the user is allowed to
-pass in, and what arguments they take -- in this example,
--l takes no argument, and -f takes a
-string (in particular, a filename) as an argument. Users can use a
-library to help parse the commandline and store the flags in some data
-structure.
-
-
Gflags, the commandline flags library used within Google,
-differs from other libraries,
-such as getopt(), in that flag definitions can be
-scattered around the source code, and not just listed in one place
-such as main(). In practice, this means that a single
-source-code file will define and use flags that are meaningful to that
-file. Any application that links in that file will get the flags, and
-the gflags library will automatically handle that
-flag appropriately.
-
-
There's significant gain in flexibility, and ease of code reuse,
-due to this technique. However, there is a danger that two files will
-define the same flag, and then give an error when they're linked
-together.
-
-
The rest of this document describes how to use the commandlineflag
-library. It's a C++ library, so examples are in C++. However, there
-is a Python port with the same functionality, and this discussion
-translates directly to Python.
Using gflags within a project which uses CMake for its build system is easy. Therefore, simply add the following CMake code to your CMakeLists.txt file.
-
-
Defining a flag is easy: just use the appropriate macro for the
-type you want the flag to be, as defined at the bottom of
-gflags/gflags.h. Here's an example file,
-foo.cc:
-
-
- #include <gflags/gflags.h>
-
- DEFINE_bool(big_menu, true, "Include 'advanced' options in the menu listing");
- DEFINE_string(languages, "english,french,german",
- "comma-separated list of languages to offer in the 'lang' menu");
-
-
-
DEFINE_bool defines a boolean flag. Here are the
-types supported:
-
-
DEFINE_bool: boolean
-
DEFINE_int32: 32-bit integer
-
DEFINE_int64: 64-bit integer
-
DEFINE_uint64: unsigned 64-bit integer
-
DEFINE_double: double
-
DEFINE_string: C++ string
-
-
-
Note that there are no 'complex' types like lists: the "languages"
-flag in our example is a list of strings, but is defined of type
-"string", not "list_of_string" or similar. This is by design. We'd
-rather use only simple types for the flags, and allow for complex,
-arbitrary parsing routines to parse them, than to try to put the logic
-inside the flags library proper.
-
-
All DEFINE macros take the same three arguments: the name of the
-flag, its default value, and a 'help' string that describes its use.
-The 'help' string is displayed when the user runs the application with
-the --help flag.
-
-
You can define a flag in any source-code file in your executable.
-Only define a flag once! If you want to access a flag in more than
-one source file, DEFINE it in one file, and DECLARE it in the others. Even better, DEFINE it
-in foo.cc and DECLARE it in foo.h; then
-everyone who #includes foo.h can use the flag.
-
-
-Defining flags in libraries rather than in main() is powerful, but
-does have some costs. One is that a library might not have a good
-default value for its flags, for example if the flag holds a
-filename that might not exist in some environments. To mitigate such problems,
-you can use flag validators to ensure prompt
-notification (in the form of a crash) of an invalid flag value.
-
-
-
Note that while most functions in this library are defined in the
-google namespace, DEFINE_foo (and
-DECLARE_foo, below), should always
-be in the global namespace.
All defined flags are available to the program as just a normal
-variable, with the prefix FLAGS_ prepended. In the above
-example, the macros define two variables, FLAGS_big_menu
-(a bool), and FLAGS_languages (a C++ string).
-
-
You can read and write to the flag just like any other
-variable:
-
- if (FLAGS_consider_made_up_languages)
- FLAGS_languages += ",klingon"; // implied by --consider_made_up_languages
- if (FLAGS_languages.find("finnish") != string::npos)
- HandleFinnish();
-
-
-
You can also get and set flag values via special functions in
-gflags.h. That's a rarer use case, though.
Accessing a flag in the manner of the previous section only works
-if the flag was DEFINE-ed at the top of the file. If it
-wasn't, you'll get an 'unknown variable' error.
-
-
The DECLARE_type macro is available when you want to
-use a flag that's defined in another file. For instance, if I were
-writing bar.cc but wanted to access the big_menu, flag, I
-would put this near the top of bar.cc:
-
- DECLARE_bool(big_menu);
-
-
-
This is functionally equivalent to saying extern
-FLAGS_big_menu.
-
-
Note that such an extern declaration introduces a dependency
-between your file and the file that defines the big_menu
-flag: foo.cc, in this case. Such implicit dependencies
-can be difficult to manage in large projects. For that reason we
-recommend the following guideline:
-
-
-If you DEFINE a flag in foo.cc, either don't DECLARE it
-at all, only DECLARE it in tightly related tests, or only DECLARE
-it in foo.h.
-
-
-
You should go the do-not-DECLARE route when the flag is only needed
-by foo.cc, and not in any other file. If you want to
-modify the value of the flag in the related test file to see if it is
-functioning as expected, DECLARE it in the foo_test.cc
-file.
-
-
If the flag does span multiple files, DECLARE it in the associated
-.h file, and make others #include that
-.h file if they want to access the flag. The
-#include will make explicit the dependency between the
-two files. This causes the flag to be a global variable.
After DEFINE-ing a flag, you may optionally register a validator
-function with the flag. If you do this, after the flag is parsed from
-the commandline, and whenever its value is changed via a call to
-SetCommandLineOption(), the validator function is called
-with the new value as an argument. The validator function should
-return 'true' if the flag value is valid, and false otherwise.
-If the function returns false for the new setting of the
-flag, the flag will retain its current value. If it returns false for the
-default value, ParseCommandLineFlags will die.
-
-
Here is an example use of this functionality:
-
-static bool ValidatePort(const char* flagname, int32 value) {
- if (value > 0 && value < 32768) // value is ok
- return true;
- printf("Invalid value for --%s: %d\n", flagname, (int)value);
- return false;
-}
-DEFINE_int32(port, 0, "What port to listen on");
-static const bool port_dummy = RegisterFlagValidator(&FLAGS_port, &ValidatePort);
-
-
-
By doing the registration at global initialization time (right
-after the DEFINE), we ensure that the registration happens before
-the commandline is parsed at the beginning of main().
-
-
RegisterFlagValidator() returns true if the
-registration is successful. It return false if the registration fails
-because a) the first argument does not refer to a commandline flag, or
-b) a different validator has already been registered for this flag.
The final piece is the one that tells the executable to process the
-commandline flags, and set the FLAGS_* variables to the
-appropriate, non-default value based on what is seen on the
-commandline. This is equivalent to the getopt() call in
-the getopt library, but has much less overhead to use. In fact, it's
-just a single function call:
Usually, this code is at the beginning of main().
-argc and argv are exactly as passed in to
-main(). This routine might modify them, which is why
-pointers to them are passed in.
-
-
The last argument is called "remove_flags". If true, then
-ParseCommandLineFlags removes the flags and their
-arguments from argv, and modifies argc
-appropriately. In this case, after the function call,
-argv will hold only commandline arguments, and not
-commandline flags.
-
-
If, on the other hand, remove_flags is false, then
-ParseCommandLineFlags will leave argc unchanged, but will
-rearrange the arguments in argv so that the flags are all at the
-beginning. For example, if the input is "/bin/foo" "arg1" "-q"
-"arg2" (which is legal but weird), the function will rearrange
-argv so it reads "/bin/foo", "-q", "arg1",
-"arg2". In this case, ParseCommandLineFlags
-returns the index into argv that holds the first commandline argument:
-that is, the index past the last flag. (In this example, it would
-return 2, since argv[2] points to arg1.)
The reason you make something a flag instead of a compile-time
-constant, is so users can specify a non-default value on the
-commandline. Here's how they might do it for an application that
-links in foo.cc:
This sets FLAGS_big_menu = false; and
-FLAGS_languages = "chinese,japanese,korean", when
-ParseCommandLineFlags is run.
-
-
Note the atypical syntax for setting a boolean flag to false:
-putting "no" in front of its name. There's a fair bit of flexibility
-to how flags may be specified. Here's an example of all the ways to
-specify the "languages" flag:
For boolean flags, the possibilities are slightly different:
-
-
app_containing_foo --big_menu
-
app_containing_foo --nobig_menu
-
app_containing_foo --big_menu=true
-
app_containing_foo --big_menu=false
-
-
(as well as the single-dash variant on all of these).
-
-
Despite this flexibility, we recommend using only a single form:
---variable=value for non-boolean flags, and
---variable/--novariable for boolean flags. This
-consistency will make your code more readable, and is also the format
-required for certain special-use cases like flagfiles.
-
-
It is a fatal error to specify a flag on the commandline that has
-not been DEFINED somewhere in the executable. If you need that
-functionality for some reason -- say you want to use the same set of
-flags for several executables, but not all of them DEFINE every flag
-in your list -- you can specify --undefok to suppress the error.
-
-
As in getopt(), -- by itself will terminate flags
-processing. So in foo -f1 1 -- -f2 2, f1 is
-considered a flag, but -f2 is not.
-
-
If a flag is specified more than once, only the last specification
-is used; the others are ignored.
-
-
Note that flags do not have single-letter synonyms, like they do in
-the getopt library, nor do we allow "combining" flags behind a
-single dash, as in ls -la.
Sometimes a flag is defined in a library, and you want to change
-its default value in one application but not others. It's simple to
-do this: just assign a new value to the flag in main(),
-before calling ParseCommandLineFlags():
-
- DECLARE_bool(lib_verbose); // mylib has a lib_verbose flag, default is false
- int main(int argc, char** argv) {
- FLAGS_lib_verbose = true; // in my app, I want a verbose lib by default
- ParseCommandLineFlags(...);
- }
-
-
-
For this application, users can still set the flag value on the
-commandline, but if they do not, the flag's value will default to
-true.
There are a few flags defined by the commandlineflags module
-itself, and are available to all applications that use
-commandlineflags. These fall into
-three categories. First are the 'reporting' flags that, when found, cause
-the application to print some information about itself and exit.
-
-
-
--help
-
shows all flags from all files, sorted by file and then by name;
- shows the flagname, its default value, and its help string
-
-
--helpfull
-
same as -help, but unambiguously asks for all flags
- (in case -help changes in the future)
-
-
--helpshort
-
shows only flags for the file with the same name as the executable
- (usually the one containing main())
-
-
--helpxml
-
like --help, but output is in xml for easier parsing
-
-
--helpon=FILE
-
shows only flags defined in FILE.*
-
-
--helpmatch=S
-
shows only flags defined in *S*.*
-
-
--helppackage
-
shows flags defined in files in same directory as main()
-
-
--version
-
prints version info for the executable
-
-
-
Second are the flags that affect how other flags are parsed.
-
-
-
--undefok=flagname,flagname,...
-
for those names listed as the argument to --undefok,
- suppress the normal error-exit that occurs when
- --name is seen on the commandline, but
- name has not been DEFINED anywhere in the
- application
-
-
-
Third are the 'recursive' flags, that cause other flag values to be
-set: --fromenv, --tryfromenv,
---flagfile. These are described below in more
-detail.
-
-
--fromenv
-
-
--fromenv=foo,bar says to read the values for the
-foo and bar flags from the environment.
-In concert with this flag, you must actually set the values in the
-environment, via a line like one of the two below:
This is equivalent to specifying --foo=xxx,
---bar=yyy on the commandline.
-
-
Note it is a fatal error to say --fromenv=foo if
-foo is not DEFINED somewhere in the application. (Though
-you can suppress this error via --undefok=foo, just like
-for any other flag.)
-
-
It is also a fatal error to say --fromenv=foo if
-FLAGS_foo is not actually defined in the environment.
-
-
--tryfromenv
-
-
--tryfromenv is exactly like --fromenv,
-except it is not a fatal error to say
---tryfromenv=foo if FLAGS_foo is not
-actually defined in the environment. Instead, in such cases,
-FLAGS_foo just keeps its default value as specified in
-the application.
-
-
Note it is still an error to say --tryfromenv=foo if
-foo is not DEFINED somewhere in the application.
-
-
--flagfile
-
-
--flagfile=f tells the commandlineflags module to read
-the file f, and to run all the flag-assignments found in
-that file as if these flags had been specified on the commandline.
-
-
In its simplest form, f should just be a list of flag
-assignments, one per line. Unlike on the commandline, the equals sign
-separating a flagname from its argument is required for
-flagfiles. An example flagfile, /tmp/myflags:
-
---nobig_menus
---languages=english,french
-
-
-
With this flagfile, the following two lines are equivalent:
Note that many errors are silently suppressed in flagfiles. In
-particular, unrecognized flagnames are silently ignored, as are flags
-that are missing a required value (e.g., a flagfile that just says
---languages).
-
-
The general format of a flagfile is a bit more complicated than the
-simple, common case above. It is: a sequence of filenames, one per
-line, followed by a sequence of flags, one per line, repeated as many
-times as desired. Filenames in a flagfile can use wildcards
-(* and ?), and the sequence of flags located
-after a sequence of filenames is processed only if the current
-executable's name matches one of the filenames. It is possible to
-start the flagfile with a sequence of flags instead of a sequence of
-filenames; if such a sequence of flags is present, these flags are
-applied to the current executable no matter what it is.
-
-
Lines that start with a # are ignored as comments.
-Leading whitespace is also ignored in flagfiles, as are blank
-lines.
-
-
It is possible for a flagfile to use the --flagfile
-flag to include another flagfile.
-
-
Flags are always processed in the expected order. That is,
-processing begins by examining the flags specified directly on the
-command line. If a flagfile is specified, its contents are processed,
-and then processing continues with remaining flags from the command
-line.
In addition to accessing FLAGS_foo directly, it is
-possible to access the flags programmatically, through an API. It is
-also possible to access information about a flag, such as its default
-value and help-string. A FlagSaver makes it easy to
-modify flags and then automatically undo the modifications later.
-Finally, there are somewhat unrelated, but useful, routines to easily
-access parts of argv outside main, including the program
-name (argv[0]).
-
-
For more information about these routines, and other useful helper
-methods such as gflags::SetUsageMessage() and
-gflags::SetVersionString, see gflags.h.
- #define STRIP_FLAG_HELP 1 // this must go before the #include!
- #include <gflags/gflags.h>
-
-
we will remove the help messages from the compiled source. This can
-reduce the size of the resulting binary somewhat, and may also be
-useful for security reasons.
-
-
-
-
-Craig Silverstein, Andreas Schuh
-
-
-
-
-
From 13cf9e1b39b580cc6b886d1bf33bfbe87d25c3db Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 14:59:51 +0000
Subject: [PATCH 75/94] doc: Readding doc submodule
---
doc | 1 +
1 file changed, 1 insertion(+)
create mode 160000 doc
diff --git a/doc b/doc
new file mode 160000
index 0000000..957aa3a
--- /dev/null
+++ b/doc
@@ -0,0 +1 @@
+Subproject commit 957aa3aa622d48839c99a51eb8f8b1f55d16b06b
From 35fcdb3b2fd13da4178f793e61eaa461af7502fc Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 15:05:08 +0000
Subject: [PATCH 76/94] mod: Update gh-pages
---
doc | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/doc b/doc
index 957aa3a..3398e7b 160000
--- a/doc
+++ b/doc
@@ -1 +1 @@
-Subproject commit 957aa3aa622d48839c99a51eb8f8b1f55d16b06b
+Subproject commit 3398e7b0c920e84a137b1860f838b7d353d23e75
From 51f1db74312c4a9718dad77d2787d0ca22cce032 Mon Sep 17 00:00:00 2001
From: Andreas Schuh
Date: Tue, 24 Mar 2015 15:36:26 +0000
Subject: [PATCH 77/94] #101 Enable C language again as long as FindThreads
requires it
This avoids having patched CMake modules in the source tree of the gflags library. Usually a C compiler is installed along a C++ compiler (or it is used for C as well). The only slight downside is the extra configuration time needed by CMake to check the C compiler.
---
CMakeLists.txt | 10 +-
cmake/CMakeCXXInformation.cmake | 300 ------------------------------
cmake/CheckCXXLibraryExists.cmake | 80 --------
cmake/CheckForPthreads.cxx | 38 ----
cmake/CheckTypeSize.c.in | 37 ----
cmake/CheckTypeSize.cmake | 268 --------------------------
cmake/CheckTypeSizeMap.cmake.in | 1 -
cmake/FindThreadsCXX.cmake | 181 ------------------
8 files changed, 9 insertions(+), 906 deletions(-)
delete mode 100644 cmake/CMakeCXXInformation.cmake
delete mode 100644 cmake/CheckCXXLibraryExists.cmake
delete mode 100644 cmake/CheckForPthreads.cxx
delete mode 100644 cmake/CheckTypeSize.c.in
delete mode 100644 cmake/CheckTypeSize.cmake
delete mode 100644 cmake/CheckTypeSizeMap.cmake.in
delete mode 100644 cmake/FindThreadsCXX.cmake
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 1272770..275426d 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -18,6 +18,14 @@ set (PACKAGE_TARNAME "${PACKAGE_NAME}-${PACKAGE_VERSION}")
set (PACKAGE_BUGREPORT "https://github.com/schuhschuh/gflags/issues")
project (${PACKAGE_NAME} CXX)
+if (CMAKE_VERSION VERSION_LESS 100)
+ # C language still needed because the following required CMake modules
+ # (or their dependencies, respectively) are not correctly handling
+ # the case where only CXX is enabled.
+ # - CheckTypeSize.cmake (fixed in CMake 3.1, cf. http://www.cmake.org/Bug/view.php?id=14056)
+ # - FindThreads.cmake (--> CheckIncludeFiles.cmake <--)
+ enable_language (C)
+endif ()
version_numbers (
${PACKAGE_VERSION}
@@ -179,7 +187,7 @@ else ()
endif ()
set (CMAKE_THREAD_PREFER_PTHREAD TRUE)
-find_package (ThreadsCXX)
+find_package (Threads)
if (Threads_FOUND AND CMAKE_USE_PTHREADS_INIT)
set (HAVE_PTHREAD 1)
check_type_size (pthread_rwlock_t RWLOCK LANGUAGE CXX)
diff --git a/cmake/CMakeCXXInformation.cmake b/cmake/CMakeCXXInformation.cmake
deleted file mode 100644
index 9ddae4a..0000000
--- a/cmake/CMakeCXXInformation.cmake
+++ /dev/null
@@ -1,300 +0,0 @@
-# Copied from master branch of CMake (commit SHA 34a49dea) before release of
-# this newer version which seems to fix a bug of the one coming with CMake 2.8-12.
-
-#=============================================================================
-# Copyright 2004-2011 Kitware, Inc.
-#
-# Distributed under the OSI-approved BSD License (the "License");
-# see accompanying file Copyright.txt for details.
-#
-# This software is distributed WITHOUT ANY WARRANTY; without even the
-# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-# See the License for more information.
-#=============================================================================
-# (To distribute this file outside of CMake, substitute the full
-# License text for the above reference.)
-
-# This file sets the basic flags for the C++ language in CMake.
-# It also loads the available platform file for the system-compiler
-# if it exists.
-# It also loads a system - compiler - processor (or target hardware)
-# specific file, which is mainly useful for crosscompiling and embedded systems.
-
-# some compilers use different extensions (e.g. sdcc uses .rel)
-# so set the extension here first so it can be overridden by the compiler specific file
-if(UNIX)
- set(CMAKE_CXX_OUTPUT_EXTENSION .o)
-else()
- set(CMAKE_CXX_OUTPUT_EXTENSION .obj)
-endif()
-
-set(_INCLUDED_FILE 0)
-
-# Load compiler-specific information.
-if(CMAKE_CXX_COMPILER_ID)
- include(Compiler/${CMAKE_CXX_COMPILER_ID}-CXX OPTIONAL)
-endif()
-
-set(CMAKE_BASE_NAME)
-get_filename_component(CMAKE_BASE_NAME "${CMAKE_CXX_COMPILER}" NAME_WE)
-# since the gnu compiler has several names force g++
-if(CMAKE_COMPILER_IS_GNUCXX)
- set(CMAKE_BASE_NAME g++)
-endif()
-
-
-# load a hardware specific file, mostly useful for embedded compilers
-if(CMAKE_SYSTEM_PROCESSOR)
- if(CMAKE_CXX_COMPILER_ID)
- include(Platform/${CMAKE_SYSTEM_NAME}-${CMAKE_CXX_COMPILER_ID}-CXX-${CMAKE_SYSTEM_PROCESSOR} OPTIONAL RESULT_VARIABLE _INCLUDED_FILE)
- endif()
- if (NOT _INCLUDED_FILE)
- include(Platform/${CMAKE_SYSTEM_NAME}-${CMAKE_BASE_NAME}-${CMAKE_SYSTEM_PROCESSOR} OPTIONAL)
- endif ()
-endif()
-
-# load the system- and compiler specific files
-if(CMAKE_CXX_COMPILER_ID)
- include(Platform/${CMAKE_SYSTEM_NAME}-${CMAKE_CXX_COMPILER_ID}-CXX OPTIONAL RESULT_VARIABLE _INCLUDED_FILE)
-endif()
-if (NOT _INCLUDED_FILE)
- include(Platform/${CMAKE_SYSTEM_NAME}-${CMAKE_BASE_NAME} OPTIONAL
- RESULT_VARIABLE _INCLUDED_FILE)
-endif ()
-# We specify the compiler information in the system file for some
-# platforms, but this language may not have been enabled when the file
-# was first included. Include it again to get the language info.
-# Remove this when all compiler info is removed from system files.
-if (NOT _INCLUDED_FILE)
- include(Platform/${CMAKE_SYSTEM_NAME} OPTIONAL)
-endif ()
-
-if(CMAKE_CXX_SIZEOF_DATA_PTR)
- foreach(f ${CMAKE_CXX_ABI_FILES})
- include(${f})
- endforeach()
- unset(CMAKE_CXX_ABI_FILES)
-endif()
-
-# This should be included before the _INIT variables are
-# used to initialize the cache. Since the rule variables
-# have if blocks on them, users can still define them here.
-# But, it should still be after the platform file so changes can
-# be made to those values.
-
-if(CMAKE_USER_MAKE_RULES_OVERRIDE)
- # Save the full path of the file so try_compile can use it.
- include(${CMAKE_USER_MAKE_RULES_OVERRIDE} RESULT_VARIABLE _override)
- set(CMAKE_USER_MAKE_RULES_OVERRIDE "${_override}")
-endif()
-
-if(CMAKE_USER_MAKE_RULES_OVERRIDE_CXX)
- # Save the full path of the file so try_compile can use it.
- include(${CMAKE_USER_MAKE_RULES_OVERRIDE_CXX} RESULT_VARIABLE _override)
- set(CMAKE_USER_MAKE_RULES_OVERRIDE_CXX "${_override}")
-endif()
-
-
-# Create a set of shared library variable specific to C++
-# For 90% of the systems, these are the same flags as the C versions
-# so if these are not set just copy the flags from the c version
-if(NOT CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS)
- set(CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS ${CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS})
-endif()
-
-if(NOT CMAKE_CXX_COMPILE_OPTIONS_PIC)
- set(CMAKE_CXX_COMPILE_OPTIONS_PIC ${CMAKE_C_COMPILE_OPTIONS_PIC})
-endif()
-
-if(NOT CMAKE_CXX_COMPILE_OPTIONS_PIE)
- set(CMAKE_CXX_COMPILE_OPTIONS_PIE ${CMAKE_C_COMPILE_OPTIONS_PIE})
-endif()
-
-if(NOT CMAKE_CXX_COMPILE_OPTIONS_DLL)
- set(CMAKE_CXX_COMPILE_OPTIONS_DLL ${CMAKE_C_COMPILE_OPTIONS_DLL})
-endif()
-
-if(NOT CMAKE_SHARED_LIBRARY_CXX_FLAGS)
- set(CMAKE_SHARED_LIBRARY_CXX_FLAGS ${CMAKE_SHARED_LIBRARY_C_FLAGS})
-endif()
-
-if(NOT DEFINED CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS)
- set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS ${CMAKE_SHARED_LIBRARY_LINK_C_FLAGS})
-endif()
-
-if(NOT CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG)
- set(CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG ${CMAKE_SHARED_LIBRARY_RUNTIME_C_FLAG})
-endif()
-
-if(NOT CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG_SEP)
- set(CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG_SEP ${CMAKE_SHARED_LIBRARY_RUNTIME_C_FLAG_SEP})
-endif()
-
-if(NOT CMAKE_SHARED_LIBRARY_RPATH_LINK_CXX_FLAG)
- set(CMAKE_SHARED_LIBRARY_RPATH_LINK_CXX_FLAG ${CMAKE_SHARED_LIBRARY_RPATH_LINK_C_FLAG})
-endif()
-
-if(NOT DEFINED CMAKE_EXE_EXPORTS_CXX_FLAG)
- set(CMAKE_EXE_EXPORTS_CXX_FLAG ${CMAKE_EXE_EXPORTS_C_FLAG})
-endif()
-
-if(NOT DEFINED CMAKE_SHARED_LIBRARY_SONAME_CXX_FLAG)
- set(CMAKE_SHARED_LIBRARY_SONAME_CXX_FLAG ${CMAKE_SHARED_LIBRARY_SONAME_C_FLAG})
-endif()
-
-if(NOT CMAKE_EXECUTABLE_RUNTIME_CXX_FLAG)
- set(CMAKE_EXECUTABLE_RUNTIME_CXX_FLAG ${CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG})
-endif()
-
-if(NOT CMAKE_EXECUTABLE_RUNTIME_CXX_FLAG_SEP)
- set(CMAKE_EXECUTABLE_RUNTIME_CXX_FLAG_SEP ${CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG_SEP})
-endif()
-
-if(NOT CMAKE_EXECUTABLE_RPATH_LINK_CXX_FLAG)
- set(CMAKE_EXECUTABLE_RPATH_LINK_CXX_FLAG ${CMAKE_SHARED_LIBRARY_RPATH_LINK_CXX_FLAG})
-endif()
-
-if(NOT DEFINED CMAKE_SHARED_LIBRARY_LINK_CXX_WITH_RUNTIME_PATH)
- set(CMAKE_SHARED_LIBRARY_LINK_CXX_WITH_RUNTIME_PATH ${CMAKE_SHARED_LIBRARY_LINK_C_WITH_RUNTIME_PATH})
-endif()
-
-if(NOT CMAKE_INCLUDE_FLAG_CXX)
- set(CMAKE_INCLUDE_FLAG_CXX ${CMAKE_INCLUDE_FLAG_C})
-endif()
-
-if(NOT CMAKE_INCLUDE_FLAG_SEP_CXX)
- set(CMAKE_INCLUDE_FLAG_SEP_CXX ${CMAKE_INCLUDE_FLAG_SEP_C})
-endif()
-
-# for most systems a module is the same as a shared library
-# so unless the variable CMAKE_MODULE_EXISTS is set just
-# copy the values from the LIBRARY variables
-if(NOT CMAKE_MODULE_EXISTS)
- set(CMAKE_SHARED_MODULE_CXX_FLAGS ${CMAKE_SHARED_LIBRARY_CXX_FLAGS})
- set(CMAKE_SHARED_MODULE_CREATE_CXX_FLAGS ${CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS})
-endif()
-
-# repeat for modules
-if(NOT CMAKE_SHARED_MODULE_CREATE_CXX_FLAGS)
- set(CMAKE_SHARED_MODULE_CREATE_CXX_FLAGS ${CMAKE_SHARED_MODULE_CREATE_C_FLAGS})
-endif()
-
-if(NOT CMAKE_SHARED_MODULE_CXX_FLAGS)
- set(CMAKE_SHARED_MODULE_CXX_FLAGS ${CMAKE_SHARED_MODULE_C_FLAGS})
-endif()
-
-# Initialize CXX link type selection flags from C versions.
-foreach(type SHARED_LIBRARY SHARED_MODULE EXE)
- if(NOT CMAKE_${type}_LINK_STATIC_CXX_FLAGS)
- set(CMAKE_${type}_LINK_STATIC_CXX_FLAGS
- ${CMAKE_${type}_LINK_STATIC_C_FLAGS})
- endif()
- if(NOT CMAKE_${type}_LINK_DYNAMIC_CXX_FLAGS)
- set(CMAKE_${type}_LINK_DYNAMIC_CXX_FLAGS
- ${CMAKE_${type}_LINK_DYNAMIC_C_FLAGS})
- endif()
-endforeach()
-
-# add the flags to the cache based
-# on the initial values computed in the platform/*.cmake files
-# use _INIT variables so that this only happens the first time
-# and you can set these flags in the cmake cache
-set(CMAKE_CXX_FLAGS_INIT "$ENV{CXXFLAGS} ${CMAKE_CXX_FLAGS_INIT}")
-# avoid just having a space as the initial value for the cache
-if(CMAKE_CXX_FLAGS_INIT STREQUAL " ")
- set(CMAKE_CXX_FLAGS_INIT)
-endif()
-set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS_INIT}" CACHE STRING
- "Flags used by the compiler during all build types.")
-
-if(NOT CMAKE_NOT_USING_CONFIG_FLAGS)
- set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG_INIT}" CACHE STRING
- "Flags used by the compiler during debug builds.")
- set (CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL_INIT}" CACHE STRING
- "Flags used by the compiler during release builds for minimum size.")
- set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE_INIT}" CACHE STRING
- "Flags used by the compiler during release builds.")
- set (CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO_INIT}" CACHE STRING
- "Flags used by the compiler during release builds with debug info.")
-
-endif()
-
-if(CMAKE_CXX_STANDARD_LIBRARIES_INIT)
- set(CMAKE_CXX_STANDARD_LIBRARIES "${CMAKE_CXX_STANDARD_LIBRARIES_INIT}"
- CACHE STRING "Libraries linked by default with all C++ applications.")
- mark_as_advanced(CMAKE_CXX_STANDARD_LIBRARIES)
-endif()
-
-include(CMakeCommonLanguageInclude)
-
-# now define the following rules:
-# CMAKE_CXX_CREATE_SHARED_LIBRARY
-# CMAKE_CXX_CREATE_SHARED_MODULE
-# CMAKE_CXX_COMPILE_OBJECT
-# CMAKE_CXX_LINK_EXECUTABLE
-
-# variables supplied by the generator at use time
-#
-# the target without the suffix
-#
-#