1 |
commit: fb94ebc448db596b58715e5b081e30a73dceec3d |
2 |
Author: Brian Evans <grknight <AT> gentoo <DOT> org> |
3 |
AuthorDate: Wed Feb 28 23:12:43 2018 +0000 |
4 |
Commit: Brian Evans <grknight <AT> gentoo <DOT> org> |
5 |
CommitDate: Wed Feb 28 23:12:43 2018 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fb94ebc4 |
7 |
|
8 |
dev-db/myodbc: Version bump for 5.3.10; fix building 5.2.7-r3 |
9 |
|
10 |
Package-Manager: Portage-2.3.24, Repoman-2.3.6 |
11 |
|
12 |
dev-db/myodbc/Manifest | 1 + |
13 |
dev-db/myodbc/files/5.3.10-cxxlinkage.patch | 29 ++++++++++ |
14 |
dev-db/myodbc/myodbc-5.2.7-r3.ebuild | 1 + |
15 |
...myodbc-5.2.7-r3.ebuild => myodbc-5.3.10.ebuild} | 62 +++++++++++++--------- |
16 |
4 files changed, 68 insertions(+), 25 deletions(-) |
17 |
|
18 |
diff --git a/dev-db/myodbc/Manifest b/dev-db/myodbc/Manifest |
19 |
index ffc0ab6232d..c15882461b4 100644 |
20 |
--- a/dev-db/myodbc/Manifest |
21 |
+++ b/dev-db/myodbc/Manifest |
22 |
@@ -1,3 +1,4 @@ |
23 |
DIST mysql-connector-odbc-5.2.7-src.tar.gz 606472 BLAKE2B 297f1ae57802f682616283bae9c3ff7ef88f8f016274884794f6b476bf9b92bc1da8af9cb89f41fa2a74238f91fbc39b9427529b806ac4ffb52aecd895cd8cd8 SHA512 f54ac8a23ade71da85e1335e95eccdccfd68a8687d17a584ced103812bdc5aee8014769a84eaa22724bb2cb23d34c7188c964d3283723defeaef5157a4b3c60f |
24 |
+DIST mysql-connector-odbc-5.3.10-src.tar.gz 2646571 BLAKE2B e85e179ee8a54c8c98dd254e949c08227adc72141d52bc15935eafd60edaf95f47c12ca51fa9472ae29c761d5de2149277c58e6d3f02a566668be17f595ca7ba SHA512 ebe56b95a1690332959a7a37e8ed381b46730fb9f6fbd6522ddc1a6961e4c8cdac59681a957b33abeb6cae12f210278e4063daa59ce952d92acf427bc188e22b |
25 |
DIST mysql-connector-odbc-5.3.9-linux-debian9-x86-32bit.tar.gz 11501665 BLAKE2B e41dd65d940c0c91c67e6ec4c46ea2c3327e96d372c493635d05833862f2aa73919410a9e9a9c090a6fa65fd29e022a9b088c07a5e11089aee04b3b86005ad1e SHA512 02fcf6ac88f6052206aa55b6fc2b37f499da26e596e8e64b1c20e87dc4a24f745416da56c6e1268feff60321f54cb45864b8d34e055ea2f99da37b6efeedc844 |
26 |
DIST mysql-connector-odbc-5.3.9-linux-debian9-x86-64bit.tar.gz 12013057 BLAKE2B e372cfb6ca49f9f01e9e60d7cd497fc009ec38dee76ca2cfb74cc95213b84ef1eebca85e1400f19c9715c0f9b2ef40fc212196e14189f5506be8d0e887507ce4 SHA512 b54ca167f762b4d8b988b4a91f14dc6a4bf49f55bc639ce8eecc9eba6c11400bd3494d74ef77ebe3348bdefd8fb5b8c1b62b3a6beebb926a1899da17ea4a1b44 |
27 |
|
28 |
diff --git a/dev-db/myodbc/files/5.3.10-cxxlinkage.patch b/dev-db/myodbc/files/5.3.10-cxxlinkage.patch |
29 |
new file mode 100644 |
30 |
index 00000000000..796a13754f8 |
31 |
--- /dev/null |
32 |
+++ b/dev-db/myodbc/files/5.3.10-cxxlinkage.patch |
33 |
@@ -0,0 +1,29 @@ |
34 |
+diff -aurN a/cmake/FindMySQL.cmake b/cmake/FindMySQL.cmake |
35 |
+--- a/cmake/FindMySQL.cmake 2016-11-29 07:40:13.000000000 -0500 |
36 |
++++ b/cmake/FindMySQL.cmake 2017-02-17 13:59:18.115389096 -0500 |
37 |
+@@ -747,7 +747,7 @@ |
38 |
+ endif() |
39 |
+ |
40 |
+ if(NOT MYSQL_CXXFLAGS) |
41 |
+- if(MYSQL_CXX_LINKAGE OR MYSQL_VERSION_ID GREATER 50603) |
42 |
++ if(MYSQL_CXX_LINKAGE) |
43 |
+ _mysql_conf(MYSQL_CXXFLAGS "--cxxflags") |
44 |
+ set(MYSQL_CXX_LINKAGE 1) |
45 |
+ else() |
46 |
+diff -aurN a/CMakeLists.txt b/CMakeLists.txt |
47 |
+--- a/CMakeLists.txt 2018-02-10 21:41:13.161553751 -0500 |
48 |
++++ b/CMakeLists.txt 2018-02-10 21:45:20.038398824 -0500 |
49 |
+@@ -379,10 +379,9 @@ |
50 |
+ SET(EXECUTABLE_OUTPUT_PATH "${CMAKE_BINARY_DIR}/bin") |
51 |
+ SET(LIBRARY_OUTPUT_PATH "${CMAKE_BINARY_DIR}/lib") |
52 |
+ |
53 |
+-SET(LIB_SUBDIR "lib") |
54 |
+-IF(RPM_BUILD AND CMAKE_SYSTEM_PROCESSOR MATCHES "(x86_64|ppc64|ppc64p7|s390x|sparc64)") |
55 |
+- SET(LIB_SUBDIR "lib64") |
56 |
+-ENDIF() |
57 |
++IF(NOT LIB_SUBDIR) |
58 |
++ MESSAGE(ERROR "LIB_SUBDIR is not set") |
59 |
++ENDIF(NOT LIB_SUBDIR) |
60 |
+ |
61 |
+ MESSAGE(STATUS "Installation library subdir: ${LIB_SUBDIR}") |
62 |
+ |
63 |
|
64 |
diff --git a/dev-db/myodbc/myodbc-5.2.7-r3.ebuild b/dev-db/myodbc/myodbc-5.2.7-r3.ebuild |
65 |
index 2aa325486f3..5f7d1930d02 100644 |
66 |
--- a/dev-db/myodbc/myodbc-5.2.7-r3.ebuild |
67 |
+++ b/dev-db/myodbc/myodbc-5.2.7-r3.ebuild |
68 |
@@ -69,6 +69,7 @@ multilib_src_configure() { |
69 |
-DWITH_DOCUMENTATION_INSTALL_PATH=/usr/share/doc/${PF} |
70 |
-DMYSQL_LIB_DIR="${ROOT}/usr/$(get_libdir)" |
71 |
-DLIB_SUBDIR="$(get_libdir)" |
72 |
+ -DNO_THREADS=ON |
73 |
) |
74 |
cmake-utils_src_configure |
75 |
} |
76 |
|
77 |
diff --git a/dev-db/myodbc/myodbc-5.2.7-r3.ebuild b/dev-db/myodbc/myodbc-5.3.10.ebuild |
78 |
similarity index 68% |
79 |
copy from dev-db/myodbc/myodbc-5.2.7-r3.ebuild |
80 |
copy to dev-db/myodbc/myodbc-5.3.10.ebuild |
81 |
index 2aa325486f3..9fd6b225fc6 100644 |
82 |
--- a/dev-db/myodbc/myodbc-5.2.7-r3.ebuild |
83 |
+++ b/dev-db/myodbc/myodbc-5.3.10.ebuild |
84 |
@@ -2,6 +2,10 @@ |
85 |
# Distributed under the terms of the GNU General Public License v2 |
86 |
|
87 |
EAPI=6 |
88 |
+ |
89 |
+# Build is broken with ninja |
90 |
+CMAKE_MAKEFILE_GENERATOR=emake |
91 |
+ |
92 |
inherit cmake-multilib flag-o-matic versionator |
93 |
|
94 |
MAJOR="$(get_version_component_range 1-2 $PV)" |
95 |
@@ -10,12 +14,11 @@ MY_P="${MY_PN}-${PV/_p/r}-src" |
96 |
|
97 |
DESCRIPTION="ODBC driver for MySQL" |
98 |
HOMEPAGE="http://www.mysql.com/products/myodbc/" |
99 |
-SRC_URI="mirror://mysql/Downloads/Connector-ODBC/${MAJOR}/${MY_P}.tar.gz" |
100 |
-RESTRICT="primaryuri" |
101 |
+SRC_URI="https://dev.mysql.com/get/Downloads/Connector-ODBC/${MAJOR}/${MY_P}.tar.gz" |
102 |
|
103 |
LICENSE="GPL-2" |
104 |
SLOT="${MAJOR}" |
105 |
-KEYWORDS="amd64 ~ppc ~x86" |
106 |
+KEYWORDS="~amd64 ~ppc ~x86" |
107 |
IUSE="" |
108 |
|
109 |
# Does not build with mysql-connector-c |
110 |
@@ -25,8 +28,6 @@ RDEPEND=" |
111 |
abi_x86_32? ( |
112 |
!app-emulation/emul-linux-x86-db[-abi_x86_32(-)] |
113 |
) |
114 |
- !dev-db/mysql-connector-c |
115 |
- !>=dev-db/mariadb-10.2.0 |
116 |
" |
117 |
DEPEND="${RDEPEND}" |
118 |
S=${WORKDIR}/${MY_P} |
119 |
@@ -34,7 +35,19 @@ S=${WORKDIR}/${MY_P} |
120 |
# Careful! |
121 |
DRIVER_NAME="${PN}-${SLOT}" |
122 |
|
123 |
+# Patch document path so it doesn't install files to /usr |
124 |
+PATCHES=( |
125 |
+ "${FILESDIR}/${MAJOR}-cmake-doc-path.patch" |
126 |
+ "${FILESDIR}/5.3.10-cxxlinkage.patch" |
127 |
+# "${FILESDIR}/${MAJOR}-mariadb-dynamic-array.patch" |
128 |
+ "${FILESDIR}/5.2.7-my_malloc.patch" |
129 |
+# "${FILESDIR}/${MAJOR}-mariadb-buffer_length.patch" |
130 |
+) |
131 |
+ |
132 |
src_prepare() { |
133 |
+ # Fix undefined references due to standards change |
134 |
+# append-cflags -std=gnu89 |
135 |
+ |
136 |
# Remove Tests |
137 |
sed -i -e "s/ADD_SUBDIRECTORY(test)//" \ |
138 |
"${S}/CMakeLists.txt" |
139 |
@@ -42,33 +55,33 @@ src_prepare() { |
140 |
# Fix as-needed on the installer binary |
141 |
echo "TARGET_LINK_LIBRARIES(myodbc-installer odbc)" >> "${S}/installer/CMakeLists.txt" |
142 |
|
143 |
- # Patch document path so it doesn't install files to /usr |
144 |
- local FILES=( "${FILESDIR}/cmake-doc-path.patch" |
145 |
- "${FILESDIR}/${PV}-r1-cxxlinkage.patch" |
146 |
- "${FILESDIR}/${PV}-mariadb-dynamic-array.patch" |
147 |
- "${FILESDIR}/${PV}-my_malloc.patch" ) |
148 |
- |
149 |
- # Fix undefined references due to standards change |
150 |
- append-cflags -std=gnu89 |
151 |
- |
152 |
- MYSQL_SERVER_INCLUDE=$(mysql_config --include | cut -d ' ' -f 1) |
153 |
- append-cflags "${MYSQL_SERVER_INCLUDE}/server" |
154 |
- |
155 |
- append-cppflags -DSTACK_DIRECTION=1 |
156 |
- |
157 |
cmake-utils_src_prepare |
158 |
} |
159 |
|
160 |
multilib_src_configure() { |
161 |
- # The RPM_BUILD flag does nothing except install to /usr/lib64 when "x86_64" |
162 |
+# local clientlib |
163 |
+# for clientlib in "mariadb" "perconaclient" "mysqlclient" "notfound" ; do |
164 |
+# [[ -x "${EPREFIX}/usr/$(get_libdir)/lib${clientlib}.so" ]] && break |
165 |
+# done |
166 |
+# [[ "${clientlib}x" == "notfoundx" ]] && \ |
167 |
+# die "Installed client library name could not be determined" |
168 |
+ |
169 |
# MYSQL_CXX_LINKAGE expects "mysql_config --cxxflags" which doesn't exist on MariaDB |
170 |
mycmakeargs+=( |
171 |
-DMYSQL_CXX_LINKAGE=0 |
172 |
-DWITH_UNIXODBC=1 |
173 |
- -DMYSQLCLIENT_LIB_NAME="libmysqlclient.so" |
174 |
+# -DMYSQLCLIENT_LIB_NAME="${clientlib}" |
175 |
+# -DMYSQLCLIENT_LIB_NAME="mysqlclient" |
176 |
-DWITH_DOCUMENTATION_INSTALL_PATH=/usr/share/doc/${PF} |
177 |
- -DMYSQL_LIB_DIR="${ROOT}/usr/$(get_libdir)" |
178 |
- -DLIB_SUBDIR="$(get_libdir)" |
179 |
+ -DMYSQL_LIB_DIR="${EPREFIX}/usr/$(get_libdir)" |
180 |
+ -DLIB_SUBDIR="$(get_libdir)/${PN}-${MAJOR}" |
181 |
+ -DMYSQL_INCLUDE_DIR="$(mysql_config --variable=pkgincludedir)" |
182 |
+ -DMYSQLCLIENT_NO_THREADS=ON |
183 |
+ -DDISABLE_GUI=ON |
184 |
+ # The NUMA and LIBWRAP options are not really used. |
185 |
+ # They are just copied from the server code |
186 |
+ -DWITH_NUMA=OFF |
187 |
+ -DWITH_LIBWRAP=OFF |
188 |
) |
189 |
cmake-utils_src_configure |
190 |
} |
191 |
@@ -82,8 +95,7 @@ multilib_src_install_all() { |
192 |
sed \ |
193 |
-e "s,__PN__,${DRIVER_NAME},g" \ |
194 |
-e "s,__PF__,${MAJOR},g" \ |
195 |
- -e "s,libmyodbc3.so,libmyodbc${SLOT:0:1}a.so,g" \ |
196 |
- -e "s,lib/libmyodbc,$(get_libdir)/${DRIVER_NAME}/libmyodbc,g" \ |
197 |
+ -e "s,lib/libmyodbc3.so,$(get_libdir)/${PN}-${MAJOR}/libmyodbc${SLOT:0:1}a.so,g" \ |
198 |
>"${D}"/usr/share/${PN}-${SLOT}/${i} \ |
199 |
<"${FILESDIR}"/${i}.m4 \ |
200 |
|| die "Failed to build $i" |