 e07f8a6be2
			
		
	
	e07f8a6be2
	
	
	
		
			
			Allow passing tox context via env var and content meta. This makes certian contitional build steps easier for users to maintain. Change-Id: I578ac6e7ed758cee04f7e2985a14065ffc99177d Signed-off-by: Ron Stone <ronald.stone@windriver.com>
		
			
				
	
	
		
			205 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			205 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| 
 | |
| declare RED='\033[0;31m'
 | |
| declare OG="\033[93m"
 | |
| declare GR='\033[0;32m'
 | |
| declare NC='\033[0m'
 | |
| 
 | |
| # Output functions. Colorize various types of messages. 
 | |
| message () { echo -e "$@" 1>&2; }
 | |
| confirmation () { message $GR$@$NC; }
 | |
| warn () { message $OG$@$NC; }
 | |
| error () { message $RED$0:$?: $@$NC; exit 1; }
 | |
| 
 | |
| declare meta_ver=":MM(.)mm:"
 | |
| 
 | |
| # Check for and exit if file dependancies are not met. Takes a list of full or
 | |
| # relative paths.
 | |
| check_file_deps () {
 | |
|   for filereq in $@
 | |
|   do
 | |
|     if [ ! -f "${filereq}" ] && [ ! -L "${filereq}" ]; then error "${filereq}  not found. Quiting."; exit 1; fi
 | |
|   done
 | |
|   return 0
 | |
| }
 | |
| 
 | |
| # Check for and exit if command dependancies are not met. Takes a list of 
 | |
| # executables.
 | |
| check_util_deps () {
 | |
|   for dep in $@
 | |
|   do
 | |
|     if ! hash $dep 2>/dev/null; then
 | |
|       error >&2 "... $dep dependency not met. Please install."
 | |
|       exit 1
 | |
|     fi
 | |
|   done
 | |
| }
 | |
| 
 | |
| # Creates an rST  title over/underscore string of the same length
 | |
| # as the argument. Section strings are not supported. Returned output
 | |
| # is a sequence of equal signs (=).
 | |
| make_strike () {
 | |
|   local _title="$1"
 | |
|   local _strike
 | |
|   _strike=$(for ((i=1; i<=${#_title}; i++)); do
 | |
|     printf '=%.0s' "$i"
 | |
|   done)
 | |
|   echo $_strike
 | |
| }
 | |
| 
 | |
| # Trim leading and trailing whitespaces from string.
 | |
| trimspaces () {
 | |
|   local _s=$1
 | |
| 
 | |
|   _s="${_s#"${_s%%[![:space:]]*}"}"
 | |
|   _s="${_s#"${_s%%[![:space:]]*}"}"
 | |
| 
 | |
|   echo $_s
 | |
| }
 | |
| 
 | |
| # Sets a global hash of acronyms and definitions from rst :abbr: defs. Also
 | |
| # sets an array of hash keys to facilitate sorting.
 | |
| #
 | |
| # Takes path to the file to parse. Optional "1" flag as second option 
 | |
| # suppresses plural forms such as "PVCs". 
 | |
| get_abbrs () {
 | |
| 
 | |
|   local ABBREVS
 | |
|   declare -a -g acro_keys
 | |
|   declare -A -g acro_keyvals
 | |
|   local regex=":abbr:\`([A-Za-z]+)\s+\((.*)\)\`"
 | |
| 
 | |
|   [[ ! -z ${1+x} ]] && [[ -e $1 ]] && ABBREVS="$1" \
 | |
|      || error "Can't find abbrevs file $1"
 | |
| 
 | |
|   [[ ! -z $2{+x} ]] && [[ ${2} == "1" ]] \
 | |
|      && local strip_plurals=$2
 | |
| 
 | |
|   while IFS= read -r line
 | |
|   do
 | |
|     if [[ $line =~ $regex ]]; then 
 | |
|   
 | |
|       if [[ ${strip_plurals} -eq 1 ]] && [[ ${BASH_REMATCH[1]:0-1} == "s" ]]; then
 | |
|         message " Skipping pluralization \"${BASH_REMATCH[1]}\""
 | |
|         continue
 | |
|       fi
 | |
|       acro_keys+=("${BASH_REMATCH[1]}")
 | |
|       acro_keyvals["${BASH_REMATCH[1]}"]="${BASH_REMATCH[2]}"
 | |
|     fi
 | |
|   done < "$ABBREVS" || error "Cannot read $ABBREVS"
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| # Report duplicate :abbr: anchor strings. (Duplicate placeholders cause 
 | |
| # Sphinx warnings.)
 | |
| #
 | |
| # Takes an array of anchor strings. Echos duplicates and returns a duplicate
 | |
| # count
 | |
| check_abbr_dups () {
 | |
| 
 | |
|    local -a _anchors=("$@")
 | |
|    declare -a dups; declare -i _dup_count=0
 | |
|    IFS=$'\n'; dups=($(sort -f <<<"${_anchors[*]}")); unset IFS
 | |
|    
 | |
|    message "... Checking for duplicate anchor strings"
 | |
|    
 | |
|    for ((i=0; i < ${#dups[@]}; i++)); do
 | |
|      if [[ ${dups[$i]} == ${dups[$i-1]} ]]; then 
 | |
|        warn " Duplicate anchor string \"${dups[$i]}\" found"
 | |
|        ((_dup_count=$_dup_count+1))
 | |
|      fi
 | |
|    done
 | |
| 
 | |
|    echo $_dup_count
 | |
| 
 | |
| }
 | |
| 
 | |
| # Return this product version
 | |
| #
 | |
| # Finds and echos out this-ver value from _this.txt
 | |
| # Calling context is responsible for parsing major and
 | |
| # minor numbers into vars (g_YY and g_MM by convention)
 | |
| get_this_version() {
 | |
| 
 | |
|   local this_file="_this.txt"
 | |
|     local ver_file=$(find doc* -name $this_file)
 | |
|     [[ ! -f ${ver_file} ]] && \
 | |
|        error "$this_file not found. Quiting."
 | |
| 
 | |
|   local _ver
 | |
|   local regex_ver="\.\.\s+\|this-ver\|\s+replace::\s+([0-9]{2}\.[0-9]{2})\s*"
 | |
| 
 | |
|   local _this=$(grep this-ver $ver_file)
 | |
|   
 | |
|   if [[ "${_this}" =~ $regex_ver ]]
 | |
|   then
 | |
|      _ver="${BASH_REMATCH[1]}"
 | |
|   else
 | |
|      error "Can't find local product version"
 | |
|   fi
 | |
|   echo $_ver
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| # List hash of separator characters used in ":MM<char>mm:" style 
 | |
| # placeholders
 | |
| #
 | |
| # Takes path to the file to scan.
 | |
| # Sets global hash 'spacers'. Note that BRE special characters will be escaped.
 | |
| 
 | |
| get_version_spacers() {
 | |
| 
 | |
|    local _sep
 | |
|    check_file_deps $1 && \
 | |
|      local _f=$1
 | |
| 
 | |
|    spacers=()
 | |
|    while read l; do
 | |
|       _sep=''
 | |
|       if [[ $l =~ ${meta_ver} ]]; then
 | |
|         [[ ${BASH_REMATCH[1]} == [\$\*\.\\\[\]] ]] && \
 | |
|            _sep="\\${BASH_REMATCH[1]}" || \
 | |
|            _sep="${BASH_REMATCH[1]}"
 | |
|         spacers["${_sep}"]=0
 | |
|       fi
 | |
|    done < $_f
 | |
| 
 | |
| }
 | |
| 
 | |
| # Replace ":MM<char>mm:" placeholders in a target file.
 | |
| #
 | |
| # Takes path to file to manipulate and overwrites on disk
 | |
| # Returns 0 on success
 | |
| # Note: global hash 'spacers' must be set; see get_version_spacers
 | |
| 
 | |
| replace_version_placeholders() {
 | |
| 
 | |
|    check_file_deps $1 && \
 | |
|      local _f=$1
 | |
|      local _rs
 | |
| 
 | |
|    for sp in "${!spacers[@]}"; do
 | |
|      [[ $sp == '^' ]] && _rs="" || _rs=$sp
 | |
|      sed -i "s/:MM${sp}mm:/${g_YY}$_rs${g_MM}/g" $_f
 | |
|    done
 | |
| 
 | |
|    return 0
 | |
| 
 | |
| }
 | |
| 
 | |
| # Return the name of the current default branch
 | |
| get_this_branch() {
 | |
| 
 | |
|   local _regex_br="defaultbranch=(.*)\s*$"
 | |
|   local _config="$PWD/.gitreview"
 | |
| 
 | |
|   if [[ $(cat $_config) =~ $_regex_br ]]; then
 | |
|      echo "${BASH_REMATCH[1]}"
 | |
|   else
 | |
|      error "$PWD is not a branch"
 | |
|   fi
 | |
| }
 | |
| 
 | |
| declare utils_loaded=1
 |