mirror of
				https://review.coreboot.org/flashrom.git
				synced 2025-10-20 17:20:53 +02:00 
			
		
		
		
	 8b074c8b7c
			
		
	
	8b074c8b7c
	
	
	
		
			
			As of version 3.x, `sphinx-build` outputs man pages to "8" directory
instead of "man8" expected by Makefile and doc/meson.build. See:
    https://github.com/sphinx-doc/sphinx/issues/7996
    https://github.com/sphinx-doc/sphinx/issues/9217
Current solution is to rename "8" to "man8" after documentation build.
That enables successful build and installation, as well as dependency
tracking at build-system level, but not on `sphinx-build` own level
upon which `meson` build blindly relies.
Change-Id: I9cd280551a1ba4d17edb2e857d56f80431b61e1b
Signed-off-by: Anton Samsonov <devel@zxlab.ru>
Reviewed-on: https://review.coreboot.org/c/flashrom/+/77778
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Anastasia Klimchuk <aklm@chromium.org>
Reviewed-by: Peter Marheine <pmarheine@chromium.org>
		
	
		
			
				
	
	
		
			30 lines
		
	
	
		
			937 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			937 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| OUTPUT_HOME="$1"
 | |
| MAN_OUTPUTS="$2"
 | |
| SPHINXBUILD="$3"
 | |
| shift 3
 | |
| 
 | |
| "${SPHINXBUILD}" "$@" || exit $?
 | |
| 
 | |
| SPHINXBUILD_MAJOR="$("${SPHINXBUILD}" --version | cut -d' ' -f2 | cut -d'.' -f1)"
 | |
| if [ "${SPHINXBUILD_MAJOR}" -ge 4 ]; then
 | |
| 	exit 0
 | |
| fi
 | |
| 
 | |
| # sphinx-build 3.x outputs man pages to "8" directory instead of expected "man8".
 | |
| # The following block checks for "man8" (and other output paths in ${MAN_OUTPUTS})
 | |
| # and, if that is missing, but "8" dir exists instead, it renames "8" to "man8"
 | |
| # and creates a symlink named "8" that points to "man8", so that anyone is happy
 | |
| # during the rest of current build and subsequent builds as well.
 | |
| 
 | |
| for MAN_OUTPUT in ${MAN_OUTPUTS}; do
 | |
| 	PATH_TARGET="${OUTPUT_HOME}/${MAN_OUTPUT}"
 | |
| 	PATH_ACTUAL="${OUTPUT_HOME}/${MAN_OUTPUT#man}"
 | |
| 	if [ -d "${PATH_ACTUAL}" -a ! -L "${PATH_ACTUAL}" ]; then
 | |
| 		rm -rf "${PATH_TARGET}"
 | |
| 		mv "${PATH_ACTUAL}" "${PATH_TARGET}"
 | |
| 		ln -s "${MAN_OUTPUT}" "${PATH_ACTUAL}"
 | |
| 	fi
 | |
| done
 |