]> git.pld-linux.org Git - packages/gpsd.git/commitdiff
- updated to 3.1, uses scons now auto/th/gpsd-3_1-1
authorJakub Bogusz <qboosh@pld-linux.org>
Tue, 27 Sep 2011 19:11:59 +0000 (19:11 +0000)
committercvs2git <feedback@pld-linux.org>
Sun, 24 Jun 2012 12:13:13 +0000 (12:13 +0000)
- most of build/install rewritten (we all know scons is great...)
- link patch replaced by new one, added qt patch
- static libs are gone

Changed files:
    gpsd-link.patch -> 1.5
    gpsd-qt.patch -> 1.1
    gpsd.spec -> 1.34

gpsd-link.patch
gpsd-qt.patch [new file with mode: 0644]
gpsd.spec

index c81a4aec0e4dd58c291ef65f5b30d961521d59db..1fc091602ca982289dbc496562915c44d5a582ec 100644 (file)
@@ -1,39 +1,47 @@
---- gpsd-2.96/configure.ac.orig        2011-03-22 00:20:02.000000000 +0100
-+++ gpsd-2.96/configure.ac     2011-03-24 21:03:08.032911291 +0100
-@@ -151,13 +151,13 @@
- AC_HEADER_TIME
- AC_STRUCT_TIMEZONE
--AC_CHECK_LIB(nsl, gethostbyname, LIBNSL="-lnsl")
-+AC_CHECK_FUNC([gethostbyname], , [AC_CHECK_LIB(nsl, gethostbyname, LIBNSL="-lnsl")])
- AC_SUBST(LIBNSL)
--AC_CHECK_LIB(socket, socket, LIBSOCKET="-lsocket")
-+AC_CHECK_FUNC([socket], , [AC_CHECK_LIB(socket, socket, LIBSOCKET="-lsocket")])
- AC_SUBST(LIBSOCKET)
- AC_CHECK_LIB(m, rint, LIBM="-lm")
- AC_SUBST(LIBM)
--AC_CHECK_LIB(c, open, LIBC="-lc")
-+AC_CHECK_FUNC([open], , [AC_CHECK_LIB(c, open, LIBC="-lc")])
- AC_SUBST(LIBC)
- AC_CHECK_LIB(pthread, pthread_setcancelstate,
-       [LIBPTHREAD="-lpthread"
-@@ -198,7 +198,7 @@
- dnl Check for curses headers and libraries.  The presence of the
- dnl library is used to decide whether or not to build some programs.
--AC_CHECK_LIB(ncurses, initscr, NCURSES_LIBS="-lncurses")
-+AC_CHECK_LIB(ncurses, initscr, NCURSES_LIBS="-lncurses -ltinfo")
- AC_SUBST(NCURSES_LIBS)
- if test x"$NCURSES_LIBS" = x"" ; then
-   AC_MSG_WARN([Not including curses support])
---- gpsd-2.96/Makefile.am.orig 2011-03-15 04:34:31.000000000 +0100
-+++ gpsd-2.96/Makefile.am      2011-03-24 21:02:52.688910453 +0100
-@@ -272,7 +272,7 @@
- nodist_libgpsd_la_SOURCES = packet_names.h ais_json.i
- libgps_la_LIBADD = $(LIBM) $(LIBC) $(LIBNSL) $(LIBSOCKET) $(LIBPTHREAD)
--libgpsd_la_LIBADD = $(LIBM) $(LIBC) $(LIBNSL) $(LIBSOCKET) $(LIBPTHREAD) $(BLUEZ_LIBS) $(LIBRT) libgps.la
-+libgpsd_la_LIBADD = $(LIBM) $(LIBC) $(LIBNSL) $(LIBSOCKET) $(LIBPTHREAD) $(BLUEZ_LIBS) $(LIBUSB_LIBS) $(LIBRT) libgps.la
- noinst_SCRIPTS =
+--- gpsd-3.1/SConstruct.orig   2011-08-28 13:14:24.000000000 +0200
++++ gpsd-3.1/SConstruct        2011-09-26 18:53:55.711394116 +0200
+@@ -686,7 +686,7 @@
+ compiled_gpsdlib = Library(env=env,
+                            target="gpsd",
+                            sources=libgpsd_sources,
+-                           version=libversion, parse_flags=usblibs + rtlibs + bluezlibs)
++                           version=libversion, parse_flags=usblibs + rtlibs + bluezlibs + ["-L.", "-lgps", "-lm"])
  
+ libraries = [compiled_gpslib, compiled_gpsdlib]
+@@ -709,7 +709,7 @@
+             compile_flags = qt_env['CFLAGS']
+         qtobjects.append(qt_env.SharedObject(src.split(".")[0] + '-qt', src,
+                                        CC=compile_with, CFLAGS=compile_flags))
+-    compiled_qgpsmmlib = Library(qt_env, "Qgpsmm", qtobjects, libversion)
++    compiled_qgpsmmlib = Library(qt_env, "Qgpsmm", qtobjects, libversion, parse_flags=["-L.", "-lgps"])
+     libraries.append(compiled_qgpsmmlib)
+ # The libraries have dependencies on system libraries
+@@ -751,7 +751,7 @@
+ gpsd_env.MergeFlags("-pthread")
+ gpsd = gpsd_env.Program('gpsd', gpsd_sources,
+-                        parse_flags = gpsdlibs + dbus_xmit_libs)
++                        parse_flags = gpsdlibs + dbus_xmit_libs + ["-lm"])
+ env.Depends(gpsd, [compiled_gpsdlib, compiled_gpslib])
+ gpsdecode = env.Program('gpsdecode', ['gpsdecode.c'], parse_flags=gpsdlibs)
+@@ -764,7 +764,7 @@
+ env.Depends(gpsdctl, compiled_gpslib)
+ gpsmon = env.Program('gpsmon', gpsmon_sources,
+-                     parse_flags=gpsdlibs + ncurseslibs)
++                     parse_flags=gpsdlibs + ncurseslibs + ["-lm"])
+ env.Depends(gpsmon, [compiled_gpsdlib, compiled_gpslib])
+ gpspipe = env.Program('gpspipe', ['gpspipe.c'], parse_flags=gpslibs)
+@@ -776,7 +776,7 @@
+ lcdgps = env.Program('lcdgps', ['lcdgps.c'], parse_flags=gpslibs)
+ env.Depends(lcdgps, compiled_gpslib)
+-cgps = env.Program('cgps', ['cgps.c'], parse_flags=gpslibs + ncurseslibs)
++cgps = env.Program('cgps', ['cgps.c'], parse_flags=gpslibs + ncurseslibs + ["-lm"])
+ env.Depends(cgps, compiled_gpslib)
+ binaries = [gpsd, gpsdecode, gpsctl, gpsdctl, gpspipe, gpxlogger, lcdgps]
diff --git a/gpsd-qt.patch b/gpsd-qt.patch
new file mode 100644 (file)
index 0000000..8cfb002
--- /dev/null
@@ -0,0 +1,16 @@
+--- gpsd-3.1/gpsd.h-tail.orig  2011-08-26 13:56:08.000000000 +0200
++++ gpsd-3.1/gpsd.h-tail       2011-09-27 20:47:19.111181574 +0200
+@@ -758,7 +758,12 @@
+ #define DEBUG_JSON    5       /* minimum level for verbose JSON debugging */
+ # define libgps_debug_trace(args) (void) libgps_trace args
+ extern int libgps_debuglevel;
+-extern void libgps_dump_state(struct gps_data_t *);
++#ifdef __cplusplus
++extern "C"
++#else
++extern
++#endif
++void libgps_dump_state(struct gps_data_t *);
+ #else
+ # define libgps_debug_trace(args) /*@i1@*/do { } while (0)
+ #endif /* LIBGPS_DEBUG */
index e481b27745a299e927910ce396433facc0312535..1b183fadd76d900f161b152b42db410409877855 100644 (file)
--- a/gpsd.spec
+++ b/gpsd.spec
@@ -2,22 +2,20 @@
 # Conditional build:
 %bcond_without dbus    # build without dbus support
 %bcond_without bluez   # build without Bluetooth support
-%bcond_without x       # build without X Window System support
 #
 Summary:       Service daemon for mediating access to a GPS
 Summary(pl.UTF-8):     Oprogramowanie komunikujące się z GPS-em
 Name:          gpsd
-Version:       2.96
-Release:       3
+Version:       3.1
+Release:       1
 License:       BSD
 Group:         Daemons
 Source0:       http://download.berlios.de/gpsd/%{name}-%{version}.tar.gz
-# Source0-md5: 26a7a04d4298bc3a3a5d89fef4582b64
+# Source0-md5: f280b914c19da3a91aa5e67d83d35033
 Patch0:                %{name}-link.patch
+Patch1:                %{name}-qt.patch
 URL:           http://gpsd.berlios.de/
 BuildRequires: QtNetwork-devel >= 4.4
-BuildRequires: autoconf >= 2.50
-BuildRequires: automake
 %if %{with dbus}
 BuildRequires: dbus-devel
 BuildRequires: dbus-glib-devel
@@ -26,19 +24,22 @@ BuildRequires:      dbus-glib-devel
 BuildRequires: docbook-dtd412-xml
 BuildRequires: docbook-style-xsl
 BuildRequires: libstdc++-devel
-BuildRequires: libtool >= 2:1.5
 BuildRequires: libusb-devel >= 1.0.0
 BuildRequires: libxslt-progs
 BuildRequires: ncurses-devel
 BuildRequires: pkgconfig
 BuildRequires: python-devel >= 1:2.4
+BuildRequires: scons >= 1.2.1
+BuildRequires: sed >= 4.0
 BuildRequires: qt4-qmake >= 4.4
 BuildRequires: rpm-pythonprov
 BuildRequires: xmlto
 Requires:      %{name}-libs = %{version}-%{release}
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
-%define                udevdir         /lib/udev
+# libgpsd expects gpsd_report() defined by user
+# libQgpsmm expects libgps_dump_state(gps_data_t*) 
+%define                skip_post_check_so      libgpsd\.so.* libQgpsmm\.so.*
 
 %description
 gpsd is a service daemon that mediates access to a GPS sensor
@@ -105,6 +106,7 @@ Summary(pl.UTF-8):  Biblioteki klienckie dla C i Pythona do komunikacji z gpsd lu
 Group:         Development/Libraries
 Requires:      %{name}-libs = %{version}-%{release}
 Requires:      libstdc++-devel
+Obsoletes:     gpsd-static
 
 %description devel
 This package provides C header files for the gpsd shared libraries
@@ -116,18 +118,6 @@ Ten pakiet zawiera pliki nagłówkowe C dla bibliotek współdzielonych
 gpsd zarządzających dostępem do GPS-a dla aplikacji, a także moduły
 Pythona. Do działania bibliotek potrzebny jest gpsd.
 
-%package static
-Summary:       Static GPS client library
-Summary(pl.UTF-8):     Statyczna biblioteka kliencka GPS
-Group:         Development/Libraries
-Requires:      %{name}-devel = %{version}-%{release}
-
-%description static
-Static GPS client library.
-
-%description static -l pl.UTF-8
-Statyczna biblioteka kliencka GPS.
-
 %package qt-libs
 Summary:       GPS Qt4 integration library
 Summary(pl.UTF-8):     Biblioteka integrująca GPS z Qt4
@@ -213,37 +203,53 @@ xgpsspeed to prędkościomierz używający informacji o położeniu z GPS-a.
 %prep
 %setup -q
 %patch0 -p1
+%patch1 -p1
+
+# make .egg-info in builddir
+%{__sed} -i -e 's/^\(build = .*\)\])$/\1, python_egg_info])/' SConstruct
 
 %build
-%{__libtoolize}
-%{__aclocal}
-%{__autoconf}
-%{__autoheader}
-%{__automake}
-%configure \
-       CPPFLAGS="-I/usr/include/ncurses" \
-       %{?with_bluez:--enable-bluetooth} \
-       %{?with_dbus:--enable-dbus} \
-       %{!?with_x:--without-x}
-
-%{__make} -j1
+export CC="%{__cc}"
+export CXX="%{__cxx}"
+export CFLAGS="%{rpmcflags}"
+export CXXFLAGS="%{rpmcxxflags}"
+export CPPFLAGS="%{rpmcppflags} -I/usr/include/ncurses $(pkg-config --cflags dbus-1)"
+export LDFLAGS="%{rpmldflags}"
+%scons \
+       %{!?with_bluez:bluez=False} \
+       %{?with_dbus:dbus_export=True}
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{%{py_sitedir},%{_datadir}/%{name}}
-install -d $RPM_BUILD_ROOT{%{udevdir},/etc/{udev/rules.d,sysconfig}}
-
-%{__make} -j1 install \
-       DESTDIR=$RPM_BUILD_ROOT
-
-install gpsd.hotplug gpsd.hotplug.wrapper $RPM_BUILD_ROOT%{udevdir}
-#install       gpsd.udev $RPM_BUILD_ROOT/etc/udev/rules.d/25-gpsd.rules
-#install       gpsd.sysconfig $RPM_BUILD_ROOT/etc/sysconfig/gpsd
+install -d $RPM_BUILD_ROOT{%{_datadir}/%{name},/lib/udev/rules.d,/etc/sysconfig}
+
+# must install manually
+# or great scons would recompile everything
+install -d $RPM_BUILD_ROOT{%{_bindir},%{_sbindir},%{_includedir},%{_libdir},%{_pkgconfigdir},%{_mandir}/man{1,3,5,8},%{py_sitedir}/gps}
+install cgps gegps gpscat gpsctl gpsdecode gpsfake gpsmon gpspipe gpsprof gpxlogger lcdgps xgps xgpsspeed $RPM_BUILD_ROOT%{_bindir}
+install gpsd gpsdctl $RPM_BUILD_ROOT%{_sbindir}
+cp -p cgps.1 gegps.1 gps.1 gpscat.1 gpsctl.1 gpsdecode.1 gpsfake.1 gpsmon.1 gpspipe.1 gpsprof.1 lcdgps.1 xgps.1 xgpsspeed.1 $RPM_BUILD_ROOT%{_mandir}/man1
+cp -p gpsd_json.5 srec.5 $RPM_BUILD_ROOT%{_mandir}/man5
+cp -p gpsd.8 gpsdctl.8 $RPM_BUILD_ROOT%{_mandir}/man8
+cp -p gps.h gpsd.h libgpsmm.h $RPM_BUILD_ROOT%{_includedir}
+cp -dp lib{Qgpsmm,gps,gpsd}.so{,.??,.*.*.*} $RPM_BUILD_ROOT%{_libdir}
+for f in libgps.pc libgpsd.pc ; do
+       %{__sed} -e 's,@VERSION@,%{version},;s,@prefix@,%{_prefix},;s,@libdir@,/%{_lib},' ${f}.in >$RPM_BUILD_ROOT%{_pkgconfigdir}/${f}
+done
+cp -p libQgpsmm.3 libgps.3 libgpsd.3 libgpsmm.3 $RPM_BUILD_ROOT%{_mandir}/man3
+cp -p gps-%{version}.egg-info $RPM_BUILD_ROOT%{py_sitedir}
+install gps/*.so $RPM_BUILD_ROOT%{py_sitedir}/gps
+cp -p gps/*.py $RPM_BUILD_ROOT%{py_sitedir}/gps
+
+install gpsd.hotplug $RPM_BUILD_ROOT/lib/udev
+install gpsd.rules $RPM_BUILD_ROOT/lib/udev/rules.d/25-gpsd.rules
+#install packaging/rpm/gpsd.init $RPM_BUILD_ROOT/etc/rc.d/init.d/gpsd
+#install packaging/rpm/gpsd.sysconfig $RPM_BUILD_ROOT/etc/sysconfig/gpsd
 install dgpsip-servers $RPM_BUILD_ROOT%{_datadir}/gpsd/dgpsip-servers
 
 # check if missing header installation is up to date
 [ ! -f $RPM_BUILD_ROOT%{_includedir}/libQgpsmm_global.h ] || exit 1
-install libQgpsmm/libQgpsmm_global.h $RPM_BUILD_ROOT%{_includedir}
+install libQgpsmm_global.h $RPM_BUILD_ROOT%{_includedir}
 
 [ ! -d $RPM_BUILD_ROOT%{_desktopdir} ] || exit 1
 install -d $RPM_BUILD_ROOT{%{_desktopdir},%{_pixmapsdir}}
@@ -266,24 +272,26 @@ rm -rf $RPM_BUILD_ROOT
 %files
 %defattr(644,root,root,755)
 %doc README INSTALL COPYING TODO AUTHORS
-%attr(755,root,root) %{_sbindir}/gpsd
 %attr(755,root,root) %{_bindir}/gpsmon
-%{_mandir}/man8/gpsd.8*
+%attr(755,root,root) %{_sbindir}/gpsd
+%attr(755,root,root) %{_sbindir}/gpsdctl
 %{_mandir}/man1/gpsmon.1*
+%{_mandir}/man8/gpsd.8*
+%{_mandir}/man8/gpsdctl.8*
 %dir %{_datadir}/gpsd
 %{_datadir}/gpsd/dgpsip-servers
 
 %files -n udev-gpsd
 %defattr(644,root,root,755)
-%attr(755,root,root) %{udevdir}/gpsd.hotplug
-%attr(755,root,root) %{udevdir}/gpsd.hotplug.wrapper
-#/etc/udev/rules.d/25-gpsd.rules
+%attr(755,root,root) /lib/udev/gpsd.hotplug
+#/lib/udev/rules.d/25-gpsd.rules
+#%attr(754,root,root) /etc/rc.d/init.d/gpsd
 #%config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/gpsd
 
 %files libs
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_libdir}/libgpsd.so.*.*.*
-%attr(755,root,root) %ghost %{_libdir}/libgpsd.so.0
+%attr(755,root,root) %ghost %{_libdir}/libgpsd.so.20
 %attr(755,root,root) %{_libdir}/libgps.so.*.*.*
 %attr(755,root,root) %ghost %{_libdir}/libgps.so.20
 
@@ -292,8 +300,6 @@ rm -rf $RPM_BUILD_ROOT
 %attr(755,root,root) %{_bindir}/gpsdecode
 %attr(755,root,root) %{_libdir}/libgps.so
 %attr(755,root,root) %{_libdir}/libgpsd.so
-%{_libdir}/libgps.la
-%{_libdir}/libgpsd.la
 %{_includedir}/gps.h
 %{_includedir}/gpsd.h
 %{_includedir}/libgpsmm.h
@@ -303,13 +309,9 @@ rm -rf $RPM_BUILD_ROOT
 %{_mandir}/man3/libgps.3*
 %{_mandir}/man3/libgpsd.3*
 %{_mandir}/man3/libgpsmm.3*
+%{_mandir}/man5/gpsd_json.5*
 %{_mandir}/man5/srec.5*
 
-%files static
-%defattr(644,root,root,755)
-%{_libdir}/libgps.a
-%{_libdir}/libgpsd.a
-
 %files qt-libs
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_libdir}/libQgpsmm.so.*.*.*
@@ -318,20 +320,23 @@ rm -rf $RPM_BUILD_ROOT
 %files qt-devel
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_libdir}/libQgpsmm.so
-%{_libdir}/libQgpsmm.prl
 %{_includedir}/libQgpsmm_global.h
-%{_pkgconfigdir}/Qgpsmm.pc
+%{_mandir}/man3/libQgpsmm.3*
+# missing in scons build
+#%{_libdir}/libQgpsmm.prl
+#%{_pkgconfigdir}/Qgpsmm.pc
 
 %files -n python-gps
 %defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/gegps
 %attr(755,root,root) %{_bindir}/gpscat
 %attr(755,root,root) %{_bindir}/gpsfake
 %attr(755,root,root) %{_bindir}/gpsprof
 %dir %{py_sitedir}/gps
 %attr(755,root,root) %{py_sitedir}/gps/*.so
 %{py_sitedir}/gps/*.py[co]
-%{py_sitedir}/gps-%{version}-py*.egg-info
-%{py_sitedir}/gpscap.py[co]
+%{py_sitedir}/gps-%{version}.egg-info
+%{_mandir}/man1/gegps.1*
 %{_mandir}/man1/gpscat.1*
 %{_mandir}/man1/gpsfake.1*
 %{_mandir}/man1/gpsprof.1*
@@ -347,7 +352,6 @@ rm -rf $RPM_BUILD_ROOT
 %{_mandir}/man1/gps.1*
 %{_mandir}/man1/gpspipe.1*
 
-%if %{with x}
 %files clients-gui
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_bindir}/lcdgps
@@ -359,4 +363,3 @@ rm -rf $RPM_BUILD_ROOT
 %{_desktopdir}/xgps.desktop
 %{_desktopdir}/xgpsspeed.desktop
 %{_pixmapsdir}/gpsd-logo.png
-%endif
This page took 0.088519 seconds and 4 git commands to generate.