Browse Source

add debian package information and initscripts

Andrew Karpow 10 năm trước cách đây
mục cha
commit
338b27676c
3 tập tin đã thay đổi với 132 bổ sung18 xóa
  1. 27 18
      CMakeLists.txt
  2. 6 0
      contrib/default.debian
  3. 99 0
      contrib/init.debian

+ 27 - 18
CMakeLists.txt

@@ -2,29 +2,38 @@ cmake_minimum_required(VERSION 2.6)
 
 project (ympd)
 
-SET(CPACK_PACKAGE_DESCRIPTION_SUMMARY "MPD web client based on Websockets and
+set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "MPD web client based on Websockets and
 Bootstrap")
-SET(CPACK_PACKAGE_VENDOR "Andrew Karpow <andy@ndyk.de>")
-SET(CPACK_PACKAGE_VERSION_MAJOR "0")
-SET(CPACK_PACKAGE_VERSION_MINOR "1")
-SET(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${PROJECT_SOURCE_DIR}/cmake/")
-
-FIND_PACKAGE(LibWebSockets REQUIRED)
-FIND_PACKAGE(LibMPDClient REQUIRED)
-INCLUDE(CheckCSourceCompiles)
-INCLUDE(CPack)
-
-SET(SOURCES
+set(CPACK_PACKAGE_VENDOR "Andrew Karpow <andy@ndyk.de>")
+SET(CPACK_DEBIAN_PACKAGE_MAINTAINER "andy@ndyk.de")
+set(CPACK_PACKAGE_VERSION_MAJOR "0")
+set(CPACK_PACKAGE_VERSION_MINOR "1")
+set(CPACK_PACKAGE_VERSION_PATCH "")
+set(CPACK_BINARY_DEB "ON")
+set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${PROJECT_SOURCE_DIR}/cmake/")
+
+find_package(LibWebSockets REQUIRED)
+find_package(LibMPDClient REQUIRED)
+include(CheckCSourceCompiles)
+include(CPack)
+
+SET(CMAKE_C_FLAGS_DEBRELEASE "-O2 -DNDEBUG -pipe")
+
+set(SOURCES
     src/ympd.c
     src/http_server.c
     src/mpd_client.c
     )
 
-ADD_EXECUTABLE(ympd ${SOURCES})
-ADD_DEFINITIONS(-DDATADIR="${CMAKE_INSTALL_PREFIX}/share/${PROJECT_NAME}")
-
-TARGET_LINK_LIBRARIES(ympd ${LIBMPDCLIENT_LIBRARY} ${LIBWEBSOCKETS_LIBRARIES})
+add_executable(ympd ${SOURCES})
+add_definitions(-DDATADIR="${CMAKE_INSTALL_PREFIX}/share/${PROJECT_NAME}")
 
-INSTALL(TARGETS ympd DESTINATION bin)
-INSTALL(DIRECTORY htdocs DESTINATION share/${PROJECT_NAME})
+target_link_libraries(ympd ${LIBMPDCLIENT_LIBRARY} ${LIBWEBSOCKETS_LIBRARIES})
 
+install(TARGETS ympd DESTINATION bin)
+install(DIRECTORY htdocs DESTINATION share/${PROJECT_NAME})
+install(FILES contrib/init.debian DESTINATION /etc/init.d
+    PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE
+    WORLD_READ WORLD_EXECUTE CONFIGURATIONS debrelease RENAME ${PROJECT_NAME})
+install(FILES contrib/default.debian DESTINATION /etc/default/${PROJECT_NAME}
+    CONFIGURATIONS debrelease RENAME ${PROJECT_NAME})

+ 6 - 0
contrib/default.debian

@@ -0,0 +1,6 @@
+# Set this to the user and group the ympd should get after socket opening.
+YMPD_USER=ympd
+YMPD_GROUP=ympd
+
+# See ympd --help for more options
+DAEMON_OPT="--uid $YMPD_USER --gid $YMPD_GROUP"

+ 99 - 0
contrib/init.debian

@@ -0,0 +1,99 @@
+#/bin/sh
+### BEGIN INIT INFO
+# Provides:          ympd
+# Required-Start:    $local_fs $mpd
+# Required-Stop:     $local_fs $mpd
+# Default-Start:     2 3 4 5
+# Default-Stop:      0 1 6
+# Short-Description: Daemonized version of ympd.
+# Description:       Enable service provided by ympd.
+### END INIT INFO
+#Author: Andrew Karpow <andy@ndyk.de>
+
+PATH=/sbin:/usr/sbin:/bin:/usr/bin
+DESC="ympd Daemon"
+NAME=ympd
+DAEMON=/usr/bin/$NAME
+PIDFILE=/var/run/$NAME.pid
+SCRIPTNAME=/etcinit.d/$NAME
+LOG_OUT=/var/log/$NAME.out
+LOG_ERR=/var/log/$NAME.err
+YMPD_USER=ympd
+YMPD_GROUP=ympd
+DAEMON_OPT="--uid $YMPD_USER --gid $YMPD_GROUP"
+
+# Exit if the package is not installed
+[ -x "$DAEMON" ] || exit 0
+
+# Read configuration variable file if it is present
+[ -r /etc/default/$NAME ] && . /etc/default/$NAME
+
+# Load the VERBOSE setting and other rcS variables
+[ -f /etc/default/rcS ] && . /etc/default/rcS
+
+do_start()
+{
+    start-stop-daemon --start --background --quiet --pidfile $PIDFILE --make-pidfile \
+        --exec $DAEMON --test > /dev/null || return 1
+    start-stop-daemon --start --background --quiet --pidfile $PIDFILE --make-pidfile \
+        --exec $DAEMON --stdout $LOG_OUT --stderr $LOG_ERR -- $DAEMON_OPT || return 2
+}
+
+do_stop()
+{
+    start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
+    RETVAL="$?"
+    
+    [ "$RETVAL" = 2 ] && return 2
+    rm -f $PIDFILE
+    return "$RETVAL"
+}
+
+case "$1" in
+  start)
+    [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
+    do_start
+    case "$?" in
+        0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
+        2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
+    esac
+    ;;
+  stop)
+    [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
+    do_stop
+    case "$?" in
+        0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
+        2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
+    esac
+    ;;
+  status)
+    status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
+    ;;
+  restart|force-reload)
+    #
+    # If the "reload" option is implemented then remove the
+    # 'force-reload' alias
+    #
+    log_daemon_msg "Restarting $DESC" "$NAME"
+    do_stop
+    case "$?" in
+      0|1)
+        do_start
+        case "$?" in
+            0) log_end_msg 0 ;;
+            1) log_end_msg 1 ;; # Old process is still running
+            *) log_end_msg 1 ;; # Failed to start
+        esac
+        ;;
+      *)
+        # Failed to stop
+        log_end_msg 1
+        ;;
+    esac
+    ;;
+  *)
+    echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2
+    exit 3
+    ;;
+esac
+