reorganize directories
[awesomized/libmemcached] / docs / CMakeLists.txt
index 31f30ca07cf4128f854da95294e6d35b80a4aff1..07709dd07b69a117bf0ccf234af0f747bbe437b2 100644 (file)
@@ -1,20 +1,20 @@
 find_package(Sphinx)
 
-if(SPHINX_EXECUTABLE)
+if(NOT SPHINX_EXECUTABLE)
 
-    if(NOT DEFINED SPHINX_THEME)
-        set(SPHINX_THEME sphinx_rtd_theme)
-        set(SPHINX_THEME_OPTIONS "'collapse_navigation':False, 'navigation_depth':2, 'titles_only':False, 'includehidden':False")
-    endif()
+    message(WARNING "The sphinx-build command is required to build manpages.")
 
-    if(NOT DEFINED SPHINX_THEME_DIR)
-        set(SPHINX_THEME_DIR)
-    endif()
+else()
 
     if(NOT DEFINED SPHINX_OPTIONS)
         set(SPHINX_OPTIONS)
     endif()
 
+    if(NOT DEFINED SPHINX_THEME)
+        set(SPHINX_THEME sphinx_rtd_theme)
+        set(SPHINX_THEME_OPTIONS "'collapse_navigation':False, 'navigation_depth':2, 'titles_only':False, 'includehidden':False")
+    endif()
+
     set(SPHINX_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/source")
 
     # configured documentation tools and intermediate build results
@@ -34,26 +34,50 @@ if(SPHINX_EXECUTABLE)
             "${SPHINX_BUILD_DIR}/conf.py"
             @ONLY)
 
-    add_custom_target("docs"
+    add_custom_target(html
             ${SPHINX_EXECUTABLE}
-            -q -a -b html
+            -q -b html
             -c "${SPHINX_BUILD_DIR}"
             -d "${SPHINX_CACHE_DIR}"
             ${SPHINX_OPTIONS}
             "${SPHINX_SOURCE_DIR}"
             "${SPHINX_HTML_DIR}"
             BYPRODUCTS ${SPHINX_HTML_DIR}
-            COMMENT "Build HTML documentation with Sphinx")
-    #list(APPEND ADDITIONAL_CLEAN_FILES ${SPHINX_CACHE_DIR} ${SPHINX_HTML_DIR})
-    add_custom_target(man
+            )
+    add_custom_target(man ALL
             ${SPHINX_EXECUTABLE}
-            -q -a -b man
+            -q -b man
             -c "${SPHINX_BUILD_DIR}"
             -d "${SPHINX_CACHE_DIR}"
             ${SPHINX_OPTIONS}
             "${SPHINX_SOURCE_DIR}"
             "${SPHINX_MAN_DIR}"
             BYPRODUCTS ${SPHINX_MAN_DIR}
-            COMMENT "Build manpage documentation with Sphinx")
-    #list(APPEND ADDITIONAL_CLEAN_FILES ${SPHINX_CACHE_DIR} ${SPHINX_MAN_DIR})
+            )
+
+    set(MAN_EXT "")
+    if(GZIP_MAN)
+        find_program(PIGZ pigz)
+        if(PIGZ)
+            set(GZIP ${PIGZ})
+        else()
+            find_package(UnixCommands)
+        endif()
+        if(GZIP)
+            set(MAN_EXT ".gz")
+            add_custom_target(man_gz ALL
+                    ${GZIP} -rkf ${SPHINX_MAN_DIR}
+                    DEPENDS man
+                    )
+        endif()
+    endif()
+
+    install(DIRECTORY ${SPHINX_MAN_DIR}/
+            DESTINATION ${CMAKE_INSTALL_MANDIR}/man1
+            FILES_MATCHING PATTERN *.1${MAN_EXT}
+            )
+    install(DIRECTORY ${SPHINX_MAN_DIR}/
+            DESTINATION ${CMAKE_INSTALL_MANDIR}/man3
+            FILES_MATCHING PATTERN *.3${MAN_EXT}
+            )
 endif()