From 1636c34f83bf7903fd0e4971281b5cd75fd5a3b1 Mon Sep 17 00:00:00 2001
From: Přemysl Janouch 
Date: Sun, 19 May 2013 07:49:47 +0200
Subject: Add a manpage
---
 CMakeLists.txt   | 38 ++++++++++++++++++++++++++++++---
 docs/sdtui.1.xml | 64 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 99 insertions(+), 3 deletions(-)
 create mode 100644 docs/sdtui.1.xml
diff --git a/CMakeLists.txt b/CMakeLists.txt
index e83ddc1..eb40db7 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -1,5 +1,5 @@
 project (sdtui C)
-cmake_minimum_required (VERSION 2.8.0)
+cmake_minimum_required (VERSION 2.8.4)
 
 # Moar warnings
 if ("${CMAKE_C_COMPILER_ID}" MATCHES "GNU" OR CMAKE_COMPILER_IS_GNUC)
@@ -30,6 +30,31 @@ GETTEXT_CREATE_TRANSLATIONS (
 	${CMAKE_CURRENT_SOURCE_DIR}/po/${CMAKE_PROJECT_NAME}.pot
 	ALL ${project_PO_FILES})
 
+# Documentation
+find_program (XSLTPROC_EXECUTABLE xsltproc)
+if (NOT XSLTPROC_EXECUTABLE)
+	message (FATAL_ERROR "xsltproc not found")
+endif (NOT XSLTPROC_EXECUTABLE)
+
+set (project_MAN_PAGES "${CMAKE_PROJECT_NAME}.1")
+foreach (page ${project_MAN_PAGES})
+	set (page_output "${CMAKE_CURRENT_BINARY_DIR}/${page}")
+	list (APPEND project_MAN_PAGES_OUTPUT "${page_output}")
+	add_custom_command (OUTPUT ${page_output}
+		COMMAND ${XSLTPROC_EXECUTABLE}
+			--nonet
+			--param make.year.ranges 1
+			--param make.single.year.ranges 1
+			--param man.charmap.use.subset 0
+			--param man.authors.section.enabled 0
+			http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl
+			"${CMAKE_CURRENT_SOURCE_DIR}/docs/${page}.xml"
+		DEPENDS "docs/${page}.xml"
+		COMMENT "Generating man page for ${page}" VERBATIM)
+endforeach (page)
+
+add_custom_target (docs ALL DEPENDS ${project_MAN_PAGES_OUTPUT})
+
 # Project source files
 set (project_common_sources
 	src/generator.c
@@ -80,8 +105,15 @@ add_executable (add-pronunciation
 target_link_libraries (add-pronunciation ${project_common_libraries})
 
 # The files to be installed
-install (TARGETS ${CMAKE_PROJECT_NAME} DESTINATION bin)
-install (FILES LICENSE DESTINATION share/doc/${CMAKE_PROJECT_NAME})
+include (GNUInstallDirs)
+install (TARGETS ${CMAKE_PROJECT_NAME} DESTINATION ${CMAKE_INSTALL_BINDIR})
+install (FILES LICENSE DESTINATION ${CMAKE_INSTALL_DOCDIR})
+
+foreach (page ${project_MAN_PAGES_OUTPUT})
+	string (REGEX MATCH "\\.([0-9])" manpage_suffix "${page}")
+	install (FILES "${page}"
+		DESTINATION "${CMAKE_INSTALL_MANDIR}/man${CMAKE_MATCH_1}")
+endforeach (page)
 
 # Do some unit tests
 option (BUILD_TESTING "Build tests" OFF)
diff --git a/docs/sdtui.1.xml b/docs/sdtui.1.xml
new file mode 100644
index 0000000..c0ed3ec
--- /dev/null
+++ b/docs/sdtui.1.xml
@@ -0,0 +1,64 @@
+
+
+
+	sdtui
+	sdtui
+	
+		Přemysl
+		Janouch
+	
+
+
+
+	sdtui
+	1
+	User Commands
+
+
+
+	sdtui
+	StarDict terminal UI
+
+
+
+	
+		sdtui
+		
+			
+		
+		
+			dictionary.ifo
+		
+	
+
+
+Description
+sdtui is a StarDict dictionary viewer custom tailored
+for viewing translation dictionaries, using a simple curses-based terminal UI.
+
+The program expects to find on its command line the path to a dictionary's
+.ifo file, which contains further information required for loading the
+dictionary.
+Future versions may additionally show a list of dictionaries available in
+preset search paths on startup.
+
+
+Options
+
+	
+		, 
+		
+		show help options
+		
+	
+
+	
+		, 
+		
+		output version information and exit
+		
+	
+
+
+
+
-- 
cgit v1.2.3-70-g09d2