[PATCH] mysql subpkg

Rex Dieter rdieter at fedoraproject.org
Mon Jun 25 19:57:30 UTC 2012


---
 akonadi.spec          |   83 ++++++++++++++++++++++++++++++-------------------
 akonadiserverrc.mysql |    2 ++
 2 files changed, 53 insertions(+), 32 deletions(-)
 create mode 100644 akonadiserverrc.mysql

diff --git a/akonadi.spec b/akonadi.spec
index 7c988d4..5678214 100644
--- a/akonadi.spec
+++ b/akonadi.spec
@@ -1,17 +1,12 @@
 
-## Can be either MYSQL(uptsream default), SQLITE, or POSTGRES(untested)
-%ifarch %{arm}
+# base pkg default to SQLITE now, install -mysql if you want that instead
 %global database_backend SQLITE
-%else
-%global database_backend MYSQL
-%endif
 
 Summary: PIM Storage Service
 Name:    akonadi
 Version: 1.7.90
-Release: 1%{?dist}
+Release: 2%{?dist}
 
-Group:   System Environment/Libraries
 License: LGPLv2+
 URL:     http://community.kde.org/KDE_PIM/Akonadi 
 %if 0%{?snap}
@@ -22,7 +17,9 @@ Source0: akonadi-%{version}-%{snap}.tar.bz2
 # Official release
 Source0: http://download.kde.org/stable/akonadi/src/akonadi-%{version}.tar.bz2
 %endif
-BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
+
+## mysql config
+Source10: akonadiserverrc.mysql
 
 ## upstream patches
 
@@ -46,29 +43,35 @@ BuildRequires: postgresql-server
 
 %{?_qt4_version:Requires: qt4%{?_isa} >= %{_qt4_version}}
 
-%if "%{?database_backend}" == "MYSQL"
-Requires: qt4-mysql%{?_isa}
-# not *strictly* required, but we need a functional default configuration
-Requires: mysql-server
-%endif
 Requires(postun): /sbin/ldconfig
 
 %description
 %{summary}.
-%if "%{?database_backend}" == "MYSQL"
-Requires an available instance of mysql server at runtime.  
-Akonadi can spawn a per-user one automatically if the mysql-server 
-package is installed on the machine.
-See also: %{_sysconfdir}/akonadi/mysql-global.conf
-%endif
 
 %package devel
 Summary: Developer files for %{name}
-Group:   Development/Libraries
 Requires: %{name}%{?_isa} = %{version}-%{release}
 %description devel
 %{summary}.
 
+%package mysql
+Summary: Akonadi MySQL backend support
+# upgrade path
+Obsoletes: akonadi < 1.7.90-2
+Requires: %{name}%{?_isa} = %{version}-%{release}
+Requires: mysql-server
+Requires: qt4-mysql%{?_isa}
+Requires(post): %{_sbindir}/update-alternatives
+Requires(postun): %{_sbindir}/update-alternatives
+%description mysql
+Configures akonadi to use mysql backend by default.
+
+Requires an available instance of mysql server at runtime.
+Akonadi can spawn a per-user one automatically if the mysql-server
+package is installed on the machine.
+See also: %{_sysconfdir}/akonadi/mysql-global.conf
+
+
 
 %prep
 %setup -q -n akonadi-%{version}
@@ -90,6 +93,8 @@ make %{?_smp_mflags} -C %{_target_platform}
 rm -rf %{buildroot} 
 make install/fast DESTDIR=$RPM_BUILD_ROOT -C %{_target_platform}
 
+install -p -m644 -D %{SOURCE10} %{buildroot}%{_sysconfdir}/xdg/akonadi/akonadiserverrc.mysql
+
 mkdir -p %{buildroot}%{_datadir}/akonadi/agents
 
 # create "big" config (analog to -mobile.conf)
@@ -117,11 +122,7 @@ install -p -m644 -D akonadiserverrc %{buildroot}%{_sysconfdir}/xdg/akonadi/akona
 %check
 export PKG_CONFIG_PATH=%{buildroot}%{_datadir}/pkgconfig:%{buildroot}%{_libdir}/pkgconfig
 test "$(pkg-config --modversion akonadi)" = "%{version}"
-## in mock,
-#The following tests FAILED:
-#	 14 - akonadi-dbconfigtest (Failed)
-# tests succeed locally (?) -- rex
-xvfb-run -a dbus-launch --exit-with-session make test -C %{_target_platform} ||:
+xvfb-run -a dbus-launch --exit-with-session make test -C %{_target_platform} 
 
 
 %clean
@@ -140,16 +141,10 @@ if [ $1 -eq 0 ] ; then
 fi
 
 %files
-%defattr(-,root,root,-)
 %doc AUTHORS lgpl-license
 %dir %{_sysconfdir}/xdg/akonadi/
 %ghost %config(missingok,noreplace) %{_sysconfdir}/xdg/akonadi/akonadiserverrc
 %dir %{_sysconfdir}/akonadi/
-# example conf's
-%{_sysconfdir}/akonadi/mysql-global-big.conf
-%{_sysconfdir}/akonadi/mysql-global-mobile.conf
-%config(noreplace) %{_sysconfdir}/akonadi/mysql-global.conf
-%config(noreplace) %{_sysconfdir}/akonadi/mysql-local.conf
 %{_bindir}/akonadi_agent_launcher
 %{_bindir}/akonadi_agent_server
 %{_bindir}/akonadi_control
@@ -165,14 +160,38 @@ fi
 %{_qt4_plugindir}/sqldrivers/libqsqlite3.so
 
 %files devel
-%defattr(-,root,root,-)
 %{_includedir}/akonadi/
 %{_libdir}/pkgconfig/akonadi.pc
 %{_libdir}/libakonadiprotocolinternals.so
 %{_libdir}/cmake/Akonadi/
 
+%post mysql
+%{_sbindir}/update-alternatives \
+  --install %{_sysconfdir}/xdg/akonadi/akonadiserverrc \
+  akonadiserverrc \
+  %{_sysconfdir}/xdg/akonadi/akonadiserverrc.mysql \
+  10
+
+%postun mysql
+if [ $1 -eq 0 ]; then
+%{_sbindir}/update-alternatives \
+  --remove akonadiserverrc \
+  %{_sysconfdir}/xdg/akonadi/akonadiserverrc.mysql 
+fi
+
+%files mysql
+%config(noreplace) %{_sysconfdir}/xdg/akonadi/akonadiserverrc.mysql
+%config(noreplace) %{_sysconfdir}/akonadi/mysql-global.conf
+%config(noreplace) %{_sysconfdir}/akonadi/mysql-local.conf
+# example conf's
+%{_sysconfdir}/akonadi/mysql-global-big.conf
+%{_sysconfdir}/akonadi/mysql-global-mobile.conf
+
 
 %changelog
+* Mon Jun 25 2012 Rex Dieter <rdieter at fedoraproject.org> 1.7.90-2
+- -mysql subpkg
+
 * Mon Jun 25 2012 Rex Dieter <rdieter at fedoraproject.org> 1.7.90-1
 - 1.7.90
 
diff --git a/akonadiserverrc.mysql b/akonadiserverrc.mysql
new file mode 100644
index 0000000..f72ecdb
--- /dev/null
+++ b/akonadiserverrc.mysql
@@ -0,0 +1,2 @@
+[%General]
+Driver=QMYSQL
-- 
1.7.10.4


--------------030704030407050406050303--


More information about the kde mailing list