File: FindSphinx.cmake

package info (click to toggle)
cvc5 1.3.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 87,260 kB
  • sloc: cpp: 383,850; java: 12,207; python: 12,090; sh: 5,679; ansic: 4,729; lisp: 763; perl: 208; makefile: 38
file content (102 lines) | stat: -rw-r--r-- 3,162 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
###############################################################################
# Top contributors (to current version):
#   Daniel Larraz
#
# This file is part of the cvc5 project.
#
# Copyright (c) 2009-2025 by the authors listed in the file AUTHORS
# in the top-level source directory and their institutional affiliations.
# All rights reserved.  See the file COPYING in the top-level source
# directory for licensing information.
# #############################################################################
#
# Find Sphinx
# Sphinx_FOUND - system has the sphinx-build executable
# Sphinx_EXECUTABLE - path to the sphinx-build executable
# Sphinx_VERSION - Sphinx version
##

include(python-scripts-paths)
# Defines the Python_SCRIPTS_Paths variable with
# a list of Python "Scripts" directories
collect_python_scripts_paths()

if (Sphinx_FIND_REQUIRED)
  set(Sphinx_FIND_MODE FATAL_ERROR)
else()
  set(Sphinx_FIND_MODE STATUS)
endif()

macro(get_sphinx_version)
  find_program(Sphinx_EXECUTABLE sphinx-build ${Python_SCRIPTS_Paths})
  if(Sphinx_EXECUTABLE)
    execute_process(
      COMMAND "${Sphinx_EXECUTABLE}" --version
      RESULT_VARIABLE Sphinx_VERSION_CHECK_RESULT
      OUTPUT_VARIABLE Sphinx_VERSION
      ERROR_QUIET
    )
  else()
    set(Sphinx_VERSION_CHECK_RESULT 127) # Not-found exit code
  endif()
endmacro()

set(INSTALL_SPHINX FALSE)

get_sphinx_version()

if (Sphinx_VERSION_CHECK_RESULT EQUAL 0)
  set(Sphinx_FOUND TRUE)
  message(STATUS "Found Sphinx version: ${Sphinx_VERSION}")
  if (DEFINED Sphinx_FIND_VERSION)
    if (Sphinx_FIND_VERSION_EXACT)
      if (NOT (Sphinx_VERSION VERSION_EQUAL ${Sphinx_FIND_VERSION}))
        set(INSTALL_SPHINX TRUE)
        set(INSTALL_SPHINX_OPTION "==${Sphinx_FIND_VERSION}")
        set(INSTALL_SPHINX_MESSAGE "==${Sphinx_FIND_VERSION}")
      endif()
    else()
      if (Sphinx_VERSION VERSION_LESS ${Sphinx_FIND_VERSION})
        set(INSTALL_SPHINX TRUE)
        set(INSTALL_SPHINX_OPTION ";-U")
        set(INSTALL_SPHINX_MESSAGE ">=${Sphinx_FIND_VERSION}")
      endif()
    endif()
    if (INSTALL_SPHINX AND NOT ENABLE_AUTO_DOWNLOAD)
      set(INSTALL_SPHINX FALSE)
      message(${Sphinx_FIND_MODE}
        "Sphinx version${INSTALL_SPHINX_MESSAGE} is required, "
        "but found version ${Sphinx_VERSION}.\n"
        "Use --auto-download to let us install it for you."
      )
    endif()
  endif()
else()
  set(Sphinx_FOUND FALSE)
  if (NOT ENABLE_AUTO_DOWNLOAD)
    message(${Sphinx_FIND_MODE}
      "Could NOT find sphinx-build executable. "
      "Use --auto-download to let us install it for you.")
  else()
    set(INSTALL_SPHINX TRUE)
    set(INSTALL_SPHINX_OPTION ";-U")
    set(INSTALL_SPHINX_MESSAGE "")
  endif()
endif()

if(INSTALL_SPHINX)
  message(STATUS "Installing sphinx${INSTALL_SPHINX_MESSAGE}")
  execute_process(
    COMMAND
    ${Python_EXECUTABLE} -m pip install sphinx${INSTALL_SPHINX_OPTION}
    RESULT_VARIABLE SPHINX_INSTALL_CMD_EXIT_CODE
  )
  if(SPHINX_INSTALL_CMD_EXIT_CODE)
    message(${Sphinx_FIND_MODE}
      "Could NOT install sphinx${INSTALL_SPHINX_MESSAGE}"
    )
  else()
    set(Sphinx_FOUND TRUE)
    get_sphinx_version()
  endif()
endif()