Gentoo Archives: gentoo-commits

From: Brian Evans <grknight@××××××××.com>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] proj/mysql-extras:master commit in: /
Date: Tue, 29 Jul 2014 18:41:30
Message-Id: 1406659256.9490a24afb658277ba94d95d49f3f1d16723e1e0.grknight.pub@gentoo
1 commit: 9490a24afb658277ba94d95d49f3f1d16723e1e0
2 Author: Brian Evans <grknight <AT> gentoo <DOT> org>
3 AuthorDate: Tue Jul 29 18:40:18 2014 +0000
4 Commit: Brian Evans <grknight <AT> tuffmail <DOT> com>
5 CommitDate: Tue Jul 29 18:40:56 2014 +0000
6 URL: http://git.overlays.gentoo.org/gitweb/?p=proj/mysql-extras.git;a=commit;h=9490a24a
7
8 Respin ELIB patch for percona 5.6.19
9
10 ---
11 00000_index.txt | 8 +-
12 20006_all_cmake_elib-percona-5.6.19.patch | 206 ++++++++++++++++++++++++++++++
13 2 files changed, 213 insertions(+), 1 deletion(-)
14
15 diff --git a/00000_index.txt b/00000_index.txt
16 index ac7bcb0..e9fb4a5 100644
17 --- a/00000_index.txt
18 +++ b/00000_index.txt
19 @@ -1619,7 +1619,13 @@
20 @@ Also install static libs by ENABLE_STATIC_LIBS
21
22 @patch 20006_all_cmake_elib-percona-5.6.16.patch
23 -@ver 5.06.16.00 to 5.06.99.99
24 +@ver 5.06.16.00 to 5.06.18.99
25 +@pn percona-server
26 +@@ Add ELIBPATH to split client and embedded libs
27 +@@ Also install static libs by ENABLE_STATIC_LIBS
28 +
29 +@patch 20006_all_cmake_elib-percona-5.6.19.patch
30 +@ver 5.06.19.00 to 5.06.99.99
31 @pn percona-server
32 @@ Add ELIBPATH to split client and embedded libs
33 @@ Also install static libs by ENABLE_STATIC_LIBS
34
35 diff --git a/20006_all_cmake_elib-percona-5.6.19.patch b/20006_all_cmake_elib-percona-5.6.19.patch
36 new file mode 100644
37 index 0000000..65c348b
38 --- /dev/null
39 +++ b/20006_all_cmake_elib-percona-5.6.19.patch
40 @@ -0,0 +1,206 @@
41 +diff -ur mysql-old/cmake/install_layout.cmake mysql/cmake/install_layout.cmake
42 +--- mysql-old/cmake/install_layout.cmake 2014-01-20 00:14:06.581799638 -0100
43 ++++ mysql/cmake/install_layout.cmake 2014-01-20 00:15:27.647802721 -0100
44 +@@ -43,7 +43,8 @@
45 + # - INSTALL_SBINDIR (directory with mysqld)
46 + # - INSTALL_SCRIPTDIR (several scripts, rarely used)
47 + #
48 +-# - INSTALL_LIBDIR (directory with client end embedded libraries)
49 ++# - INSTALL_LIBDIR (directory with client libraries)
50 ++# - INSTALL_ELIBDIR (directory with embedded libraries)
51 + # - INSTALL_PLUGINDIR (directory for plugins)
52 + #
53 + # - INSTALL_INCLUDEDIR (directory for MySQL headers)
54 +@@ -117,6 +118,7 @@
55 + SET(INSTALL_SCRIPTDIR_STANDALONE "scripts")
56 + #
57 + SET(INSTALL_LIBDIR_STANDALONE "lib")
58 ++SET(INSTALL_ELIBDIR_STANDALONE "lib")
59 + SET(INSTALL_PLUGINDIR_STANDALONE "lib/mysql/plugin")
60 + #
61 + SET(INSTALL_INCLUDEDIR_STANDALONE "include")
62 +@@ -148,9 +150,11 @@
63 + #
64 + IF(CMAKE_SYSTEM_PROCESSOR MATCHES "x86_64")
65 + SET(INSTALL_LIBDIR_RPM "lib64")
66 ++ SET(INSTALL_ELIBDIR_RPM "lib64")
67 + SET(INSTALL_PLUGINDIR_RPM "lib64/mysql/plugin")
68 + ELSE()
69 + SET(INSTALL_LIBDIR_RPM "lib")
70 ++ SET(INSTALL_ELIBDIR_RPM "lib")
71 + SET(INSTALL_PLUGINDIR_RPM "lib/mysql/plugin")
72 + ENDIF()
73 + #
74 +@@ -178,6 +182,7 @@
75 + SET(INSTALL_SCRIPTDIR_DEB "scripts")
76 + #
77 + SET(INSTALL_LIBDIR_DEB "lib")
78 ++SET(INSTALL_ELIBDIR_DEB "lib")
79 + SET(INSTALL_PLUGINDIR_DEB "lib/mysql/plugin")
80 + #
81 + SET(INSTALL_INCLUDEDIR_DEB "include")
82 +@@ -204,6 +209,7 @@
83 + SET(INSTALL_SCRIPTDIR_SVR4 "scripts")
84 + #
85 + SET(INSTALL_LIBDIR_SVR4 "lib")
86 ++SET(INSTALL_ELIBDIR_SVR4 "lib")
87 + SET(INSTALL_PLUGINDIR_SVR4 "lib/plugin")
88 + #
89 + SET(INSTALL_INCLUDEDIR_SVR4 "include")
90 +@@ -234,7 +240,7 @@
91 + # Set INSTALL_FOODIR variables for chosen layout (for example, INSTALL_BINDIR
92 + # will be defined as ${INSTALL_BINDIR_STANDALONE} by default if STANDALONE
93 + # layout is chosen)
94 +-FOREACH(var BIN SBIN LIB MYSQLSHARE SHARE PLUGIN INCLUDE SCRIPT DOC MAN
95 ++FOREACH(var BIN SBIN LIB ELIB MYSQLSHARE SHARE PLUGIN INCLUDE SCRIPT DOC MAN
96 + INFO MYSQLTEST SQLBENCH DOCREADME SUPPORTFILES MYSQLDATA PLUGINTEST)
97 + SET(INSTALL_${var}DIR ${INSTALL_${var}DIR_${INSTALL_LAYOUT}}
98 + CACHE STRING "${var} installation directory" ${FORCE})
99 +diff -ur mysql-old/cmake/libutils.cmake mysql/cmake/libutils.cmake
100 +--- mysql-old/cmake/libutils.cmake 2014-01-20 00:14:06.581799638 -0100
101 ++++ mysql/cmake/libutils.cmake 2014-01-20 00:15:27.647802721 -0100
102 +@@ -40,6 +40,8 @@
103 + # - MERGE_LIBRARIES(target [STATIC|SHARED|MODULE] [linklib1 .... linklibN]
104 + # [EXPORTS exported_func1 .... exported_func_N]
105 + # [OUTPUT_NAME output_name]
106 ++# [OUTPUT_DIR output_dir]
107 ++
108 + # This macro merges several static libraries into a single one or creates a shared
109 + # library from several convenience libraries
110 +
111 +@@ -214,7 +216,7 @@
112 + #)
113 + MACRO(MERGE_LIBRARIES)
114 + MYSQL_PARSE_ARGUMENTS(ARG
115 +- "EXPORTS;OUTPUT_NAME;COMPONENT"
116 ++ "EXPORTS;OUTPUT_NAME;COMPONENT;OUTPUT_DIR"
117 + "STATIC;SHARED;MODULE;NOINSTALL"
118 + ${ARGN}
119 + )
120 +@@ -265,7 +267,11 @@
121 + IF(ARG_COMPONENT)
122 + SET(COMP COMPONENT ${ARG_COMPONENT})
123 + ENDIF()
124 +- MYSQL_INSTALL_TARGETS(${TARGET} DESTINATION "${INSTALL_LIBDIR}" ${COMP})
125 ++ IF(ARG_OUTPUT_DIR)
126 ++ MYSQL_INSTALL_TARGETS(${TARGET} DESTINATION "${ARG_OUTPUT_DIR}" ${COMP})
127 ++ ELSE()
128 ++ MYSQL_INSTALL_TARGETS(${TARGET} DESTINATION "${INSTALL_LIBDIR}" ${COMP})
129 ++ ENDIF()
130 + ENDIF()
131 + SET_TARGET_PROPERTIES(${TARGET} PROPERTIES LINK_INTERFACE_LIBRARIES "")
132 +
133 +diff -ur mysql-old/libmysql/CMakeLists.txt mysql/libmysql/CMakeLists.txt
134 +--- mysql-old/libmysql/CMakeLists.txt 2014-01-20 00:14:06.580799638 -0100
135 ++++ mysql/libmysql/CMakeLists.txt 2014-01-20 00:15:27.647802721 -0100
136 +@@ -179,8 +179,13 @@
137 + LIST(APPEND LIBS auth_win_client)
138 + ENDIF()
139 +
140 ++SET(INSTALL_STATIC_LIBS "")
141 ++IF(NOT ENABLE_STATIC_LIBS)
142 ++ SET(INSTALL_STATIC_LIBS "NOINSTALL")
143 ++ENDIF()
144 ++
145 + # Merge several convenience libraries into one big perconaserverclient
146 +-MERGE_LIBRARIES(perconaserverclient STATIC ${LIBS} COMPONENT Development)
147 ++MERGE_LIBRARIES(perconaserverclient STATIC ${LIBS} COMPONENT Development OUTPUT_DIR ${INSTALL_LIBDIR} ${INSTALL_STATIC_LIBS})
148 +
149 + # Visual Studio users need debug static library for debug projects
150 + INSTALL_DEBUG_SYMBOLS(clientlib)
151 +@@ -210,9 +215,11 @@
152 + ENDIF()
153 +
154 + IF(UNIX)
155 + GET_TARGET_NAME(perconaserverclient lib_name)
156 +- INSTALL_SYMLINK(perconaserverclient
157 +- ${lib_name} ${CMAKE_STATIC_LIBRARY_PREFIX}perconaserverclient_r.a
158 +- ${INSTALL_LIBDIR} Development)
159 ++ IF(ENABLE_STATIC_LIBS)
160 ++ INSTALL_SYMLINK(perconaserverclient
161 ++ ${lib_name} ${CMAKE_STATIC_LIBRARY_PREFIX}perconaserverclient_r.a
162 ++ ${INSTALL_LIBDIR} Development)
163 ++ ENDIF()
164 + ENDIF()
165 +
166 + IF(NOT DISABLE_SHARED)
167 +diff -ur mysql-old/libmysqld/CMakeLists.txt mysql/libmysqld/CMakeLists.txt
168 +--- mysql-old/libmysqld/CMakeLists.txt 2014-01-20 00:14:06.453799634 -0100
169 ++++ mysql/libmysqld/CMakeLists.txt 2014-01-20 00:25:46.375826250 -0100
170 +@@ -126,8 +126,13 @@
171 + ENDIF()
172 + ENDFOREACH()
173 +
174 ++SET(INSTALL_STATIC_LIBS "")
175 ++IF(NOT ENABLE_STATIC_LIBS)
176 ++ SET(INSTALL_STATIC_LIBS "NOINSTALL")
177 ++ENDIF()
178 ++
179 + MERGE_LIBRARIES(mysqlserver STATIC ${EMBEDDED_LIBS}
180 +- OUTPUT_NAME ${MYSQLSERVER_OUTPUT_NAME} COMPONENT Embedded)
181 ++ OUTPUT_NAME ${MYSQLSERVER_OUTPUT_NAME} COMPONENT Embedded OUTPUT_DIR ${INSTALL_ELIBDIR} ${INSTALL_STATIC_LIBS})
182 +
183 + # Visual Studio users need debug static library
184 + IF(MSVC)
185 +@@ -135,12 +135,14 @@
186 + ENDIF()
187 +
188 + IF(UNIX)
189 +- INSTALL_DEBUG_TARGET(mysqlserver DESTINATION ${INSTALL_LIBDIR} RENAME
190 ++ INSTALL_DEBUG_TARGET(mysqlserver DESTINATION ${INSTALL_ELIBDIR} RENAME
191 + ${CMAKE_STATIC_LIBRARY_PREFIX}mysqld-debug)
192 + ENDIF()
193 +
194 + IF(NOT DISABLE_SHARED)
195 +- MERGE_LIBRARIES(libmysqld SHARED mysqlserver EXPORTS ${CLIENT_API_FUNCTIONS})
196 ++ MERGE_LIBRARIES(libmysqld SHARED mysqlserver EXPORTS ${CLIENT_API_FUNCTIONS}
197 ++ COMPONENT Embedded OUTPUT_DIR ${INSTALL_ELIBDIR})
198 ++
199 + IF(UNIX)
200 + # Name the shared library, handle versioning (provides same api as client library
201 + # hence the same version)
202 +--- mysql-old/libservices/CMakeLists.txt 2014-02-06 14:35:25.162325748 -0500
203 ++++ mysql/libservices/CMakeLists.txt 2014-02-06 14:36:20.051137978 -0500
204 +@@ -26,4 +26,6 @@
205 + my_thread_scheduler_service.c)
206 +
207 + ADD_LIBRARY(mysqlservices ${MYSQLSERVICES_SOURCES})
208 +-INSTALL(TARGETS mysqlservices DESTINATION ${INSTALL_LIBDIR} COMPONENT Development)
209 ++IF(ENABLE_STATIC_LIBS)
210 ++ INSTALL(TARGETS mysqlservices DESTINATION ${INSTALL_LIBDIR} COMPONENT Development)
211 ++ENDIF()
212 +
213 +diff -aurN mysql.old/scripts/CMakeLists.txt mysql/scripts/CMakeLists.txt
214 +--- mysql.old/scripts/CMakeLists.txt 2014-03-25 09:10:46.000000000 -0400
215 ++++ mysql/scripts/CMakeLists.txt 2014-04-25 23:19:05.544375123 -0400
216 +@@ -192,6 +192,7 @@
217 + SET(scriptdir ${prefix}/${INSTALL_BINDIR})
218 + SET(libexecdir ${prefix}/${INSTALL_SBINDIR})
219 + SET(pkgdatadir ${prefix}/${INSTALL_MYSQLSHAREDIR})
220 ++SET(elibdir ${prefix}/${INSTALL_ELIBDIR})
221 + IF(INSTALL_LAYOUT MATCHES "STANDALONE")
222 + SET(localstatedir ${prefix}/data)
223 + ELSE()
224 +diff -aurN mysql.old/scripts/mysql_config.sh mysql/scripts/mysql_config.sh
225 +--- mysql.old/scripts/mysql_config.sh 2014-03-25 09:10:46.000000000 -0400
226 ++++ mysql/scripts/mysql_config.sh 2014-04-25 23:21:36.030085686 -0400
227 +@@ -91,6 +91,10 @@
228 + plugindir_rel=`echo $plugindir | sed -e "s;^$basedir/;;"`
229 + fix_path plugindir $plugindir_rel lib/mysql/plugin lib/plugin
230 +
231 ++elibdir='@elibdir@'
232 ++elibdir_rel=`echo $elibdir | sed -e "s;^$basedir/;;"`
233 ++fix_path elibdir $elibdir_rel lib64/mysql lib64 lib/mysql lib
234 ++
235 + pkgincludedir='@pkgincludedir@'
236 + if [ -f "$basedir/include/mysql/mysql.h" ]; then
237 + pkgincludedir="$basedir/include/mysql"
238 +@@ -113,7 +117,7 @@
239 + libs=" $ldflags -L$pkglibdir @RPATH_OPTION@ -lperconaserverclient @ZLIB_DEPS@ @NON_THREADED_LIBS@"
240 + libs="$libs @openssl_libs@ @STATIC_NSS_FLAGS@ "
241 + libs_r=" $ldflags -L$pkglibdir @RPATH_OPTION@ -lperconaserverclient_r @ZLIB_DEPS@ @CLIENT_LIBS@ @openssl_libs@ "
242 +-embedded_libs=" $ldflags -L$pkglibdir @RPATH_OPTION@ -lmysqld @LIBDL@ @ZLIB_DEPS@ @LIBS@ @WRAPLIBS@ @openssl_libs@ "
243 ++embedded_libs=" $ldflags -L$elibdir @RPATH_OPTION@ -lmysqld @LIBDL@ @ZLIB_DEPS@ @LIBS@ @WRAPLIBS@ @openssl_libs@ "
244 + embedded_libs="$embedded_libs @QUOTED_CMAKE_CXX_LINK_FLAGS@"
245 +
246 + cflags="-I$pkgincludedir @CFLAGS@ " #note: end space!