 090becd41e
			
		
	
	090becd41e
	
	
	
		
			
			Many bash functions are duplicated across scripts. This commit consolidates them on one file for more efficient managment. Some incidental updates were made: - set default start date in pickCompare to today-9 months instead of 2020-01-01. This reduces clutter when selecting authors and stale gerrits in output. - fix a routine used by normalize-includes Signed-off-by: Ron Stone <ronald.stone@windriver.com> Change-Id: Ifd64e38fbe4324c7d6b4eccb725ef3d8367f6578
		
			
				
	
	
		
			94 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| . $(pwd)/_utils.sh
 | |
| if [[ -z ${utils_loaded+x} ]]; then echo "Could not load utilities"; exit 1; fi
 | |
| 
 | |
| directive='pre-include::'
 | |
| d_begin=':start-after:'
 | |
| d_end=':end-before:'
 | |
| inc_base='doc/source'
 | |
| 
 | |
| 
 | |
| OIFS=$IFS; IFS=$'\n'
 | |
| parents=( $(grep -Rl '.. pre-include:: ' --exclude-dir=docs/build --include="*.r*st" --exclude-dir='.*' doc/*) )
 | |
| IFS=$OIFS
 | |
| 
 | |
| get_substr () {
 | |
| 
 | |
|   local _str=${1//\//\\/}
 | |
|   local _drop=$2
 | |
|   local _regex="$_drop\s+(.*)\s*$"
 | |
|   message "${_str} =~ $_regex"
 | |
| 
 | |
|   if [[ "${str}" =~ "$_regex" ]]
 | |
|   then
 | |
|      message "Found ${BASH_REMATCH[1]}"
 | |
|      echo "${BASH_REMATCH[1]}"
 | |
|   else
 | |
|      echo ""
 | |
|   fi
 | |
| }
 | |
| 
 | |
| get_inc_path () {
 | |
|   local _ppath=$1
 | |
|   local _inc=$2
 | |
| 
 | |
|   if [[ ${_inc::1} == "/" ]]; then
 | |
|     echo "$inc_base$_inc"
 | |
|   else
 | |
|     echo "$(dirname $_ppath)/$_inc"
 | |
|   fi
 | |
| }
 | |
| 
 | |
| get_include_content () {
 | |
|   local _inc_file=$1
 | |
|   local _inc_start=$2
 | |
|   local _inc_end=$3
 | |
|   local _content
 | |
| 
 | |
|   check_file_deps $_inc_file
 | |
| 
 | |
|   if [[ $_inc_start != "" ]] && [[ $_inc_end != "" ]]; then
 | |
|     _content=$(awk "/.. $_inc_start/{flag=1; next} /.. $_inc_end/{flag=0} flag" "$_inc_file" | sed -r "s/^\s*\.\. $_inc_end\s*$//g")
 | |
|     # _content=$(sed -n '/\.\. $_inc_start/,/\.\. $_inc_end/{p;/\.\. $_inc_end/q}' $_inc_file)
 | |
|   elif [[ $_inc_start == "" ]] && [[ $_inc_end == "" ]]; then
 | |
|     _content=$(<$_inc_file)
 | |
|   else
 | |
|     error "Something went horribly wrong"
 | |
|   fi
 | |
|   echo "$_content"
 | |
| }
 | |
| 
 | |
| ## Run
 | |
| 
 | |
| for _f in "${parents[@]}"; do
 | |
|   readarray -t _content < "$_f"
 | |
|   for i in "${!_content[@]}"; do
 | |
|     if [[ ${_content[i]} =~ $directive ]]; then
 | |
|       _inc_file=$(trimspaces $(echo ${_content[i]} | sed -r 's|\s*\.\. pre-include::\s+||g'))
 | |
|       message "found ${_content[i]}: $_l\nExtracted $_inc_file"
 | |
|       if [[ ${_content[i+1]} =~ $d_begin ]]; then
 | |
|         _inc_start=$(trimspaces $(echo ${_content[i+1]} | sed -r 's|\s*:start-after:\s+||g'))
 | |
|         _inc_end=$(trimspaces $(echo ${_content[i+2]} | sed -r 's|\s*:end-before:\s+||g'))
 | |
| 
 | |
|         if [[ $_inc_end == "" ]]
 | |
|         then
 | |
|           error "start/end paramter mismatch in\n$_f\n Quiting"
 | |
|           exit 1
 | |
|         fi
 | |
| 
 | |
|         message "Extracted $_inc_start"
 | |
|         message "Extracted $_inc_end"
 | |
|         _content[i+1]=""
 | |
|         _content[i+2]=""
 | |
|       fi
 | |
|       _inc_file=$(get_inc_path "$_f" "$_inc_file")
 | |
|       _includestring=$(get_include_content $_inc_file $_inc_start $_inc_end)
 | |
|       _content[i]="$_includestring"
 | |
|     fi
 | |
|     # ((_line=$_line+1))
 | |
|   done
 | |
|   for line in "${_content[@]}"; do out="$out\n$line"; done
 | |
|   echo -e "${out//\\n/$'\n'}" > $_f
 | |
| done
 |