When there was no parallelism (no top-level -j arg and a pre-1.7
sphinx-build), the argument passed would be empty ("") instead of just
being missing, which would (understandably) badly confuse sphinx-build.
Fix this by removing the quotes.
Reported-by: Rafael J. Wysocki <rafael@kernel.org>
Fixes: 51e46c7a40 ("docs, parallelism: Rearrange how jobserver reservations are made")
Cc: stable@vger.kernel.org  # v5.5 only
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Jonathan Corbet <corbet@lwn.net>
		
	
			
		
			
				
	
	
		
			34 lines
		
	
	
		
			876 B
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			34 lines
		
	
	
		
			876 B
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/bin/sh
 | |
| # SPDX-License-Identifier: GPL-2.0+
 | |
| #
 | |
| # Figure out if we should follow a specific parallelism from the make
 | |
| # environment (as exported by scripts/jobserver-exec), or fall back to
 | |
| # the "auto" parallelism when "-jN" is not specified at the top-level
 | |
| # "make" invocation.
 | |
| 
 | |
| sphinx="$1"
 | |
| shift || true
 | |
| 
 | |
| parallel="$PARALLELISM"
 | |
| if [ -z "$parallel" ] ; then
 | |
| 	# If no parallelism is specified at the top-level make, then
 | |
| 	# fall back to the expected "-jauto" mode that the "htmldocs"
 | |
| 	# target has had.
 | |
| 	auto=$(perl -e 'open IN,"'"$sphinx"' --version 2>&1 |";
 | |
| 			while (<IN>) {
 | |
| 				if (m/([\d\.]+)/) {
 | |
| 					print "auto" if ($1 >= "1.7")
 | |
| 				}
 | |
| 			}
 | |
| 			close IN')
 | |
| 	if [ -n "$auto" ] ; then
 | |
| 		parallel="$auto"
 | |
| 	fi
 | |
| fi
 | |
| # Only if some parallelism has been determined do we add the -jN option.
 | |
| if [ -n "$parallel" ] ; then
 | |
| 	parallel="-j$parallel"
 | |
| fi
 | |
| 
 | |
| exec "$sphinx" $parallel "$@"
 |