Gentoo Archives: gentoo-commits

From: Brian Evans <grknight@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-db/myodbc/, dev-db/myodbc/files/
Date: Wed, 28 Feb 2018 23:12:58
Message-Id: 1519859563.fb94ebc448db596b58715e5b081e30a73dceec3d.grknight@gentoo
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"