157 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| # -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
 | |
| source "$(dirname "$0")/../lib/ulib/ulib" || exit 1
 | |
| urequire DEFAULTS
 | |
| 
 | |
| function display_help() {
 | |
|     uecho "$scriptname: Mettre à jour la documentation pour les outils de nutools
 | |
| 
 | |
| USAGE
 | |
|     $scriptname [options]
 | |
| 
 | |
| OPTIONS
 | |
|     -t, --tools
 | |
|         Ne générer la documentation que pour les outils
 | |
|     -l, --ulib
 | |
|         Ne générer la documentation que pour ulib
 | |
|     -s, --sync
 | |
|         Synchroniser avec nutools.html après la génération de la documentation
 | |
| Par défaut, la documentation est (re)générée pour les outils et pour ulib"
 | |
| }
 | |
| 
 | |
| function dump_content() {
 | |
|     local twpage="$1" content="$2"
 | |
|     if [ -f "$twpage" ]; then
 | |
|         awk '
 | |
| BEGIN { dump = 0 }
 | |
| !dump && ($0 == "" || $0 ~ /^[^#]/) { dump = 1 }
 | |
| dump { print }' <"$twpage" >"$content"
 | |
|     else
 | |
|         >"$content"
 | |
|     fi
 | |
| }
 | |
| 
 | |
| function write_twpage() {
 | |
|     local oldcontent="$1" title="$2" newcontent="$3" twpage="$4"
 | |
|     if testdiff "$oldcontent" "$newcontent"; then
 | |
|         local created="$(date +"%d/%m/%Y %H:%M")"
 | |
|         echo "# -*- coding: utf-8 mode: markdown -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
 | |
| ##@creator: $USER
 | |
| ##@created: $created
 | |
| ##@modifier: $USER
 | |
| ##@changecount: 1
 | |
| ##@tags:
 | |
| ##@title: $title" >"$twpage"
 | |
|         cat "$newcontent" >>"$twpage"
 | |
|     fi
 | |
| }
 | |
| 
 | |
| auto=1
 | |
| tools=
 | |
| ulib=
 | |
| sync=
 | |
| force=
 | |
| parse_opts "${PRETTYOPTS[@]}" \
 | |
|     --help '$exit_with display_help' \
 | |
|     -t,--tools '$auto=; tools=1' \
 | |
|     -l,--ulib '$auto=; ulib=1' \
 | |
|     -s,--sync '$auto=; sync=1' \
 | |
|     --force force=1 \
 | |
|     @ args -- "$@" && set -- "${args[@]}" || die "$args"
 | |
| 
 | |
| [ -n "$auto" ] && {
 | |
|     tools=1
 | |
|     ulib=1
 | |
|     sync=1
 | |
| }
 | |
| ac_set_tmpfile oldcontent
 | |
| ac_set_tmpfile newcontent
 | |
| cd "$scriptdir"
 | |
| 
 | |
| if [ -n "$tools" ]; then
 | |
|     if [ -n "$*" ]; then
 | |
|         cmds=("$@")
 | |
|     else
 | |
|         array_lsfiles cmds ..
 | |
|     fi
 | |
| 
 | |
|     for cmd in "${cmds[@]}"; do
 | |
|         cmdname="$(basename "$cmd")"
 | |
|         twpage="$cmdname.twp"
 | |
|         [ -x "$cmd" ] || continue
 | |
|         estep "$cmdname"
 | |
| 
 | |
|         dump_content "$twpage" "$oldcontent"
 | |
|         echo "
 | |
| {{{
 | |
| $("$cmd" --help)
 | |
| }}}" >"$newcontent"
 | |
| 
 | |
|         write_twpage "$oldcontent" "$cmdname" "$newcontent" "$twpage"
 | |
|     done
 | |
| fi
 | |
| 
 | |
| if [ -n "$ulib" ]; then
 | |
|     array_from_lines ulibnames "$(list_files ../lib/ulib)"
 | |
|     # faire l'entête
 | |
|     dump_content ulib.twp "$oldcontent"
 | |
|     echo "
 | |
| !Liste des librairies de ulib" >"$newcontent"
 | |
|     for ulibname in "${ulibnames[@]}"; do
 | |
|         echo "* [[ulib/$ulibname]]" >>"$newcontent"
 | |
|     done
 | |
|     write_twpage "$oldcontent" ulib "$newcontent" ulib.twp
 | |
|     # faire les pages
 | |
|     for ulibname in "${ulibnames[@]}"; do
 | |
|         ulib="../lib/ulib/$ulibname"
 | |
|         twpage="ulib_$ulibname.twp"
 | |
|         title="ulib/$ulibname"
 | |
|         dump_content "$twpage" "$oldcontent"
 | |
|         awkrun 'BEGIN {
 | |
|   in_func = 0
 | |
|   dump_doc = 0
 | |
|   dumped_doc = 0
 | |
|   print
 | |
| }
 | |
| !in_func && $0 ~ /^function / {
 | |
|   if (match($0, /function +([^ ]+)\(\)/, vs)) {
 | |
|     funcname = vs[1]
 | |
|     if (funcname !~ /^_/) {
 | |
|       in_func = 1
 | |
|       dump_doc = 1
 | |
|       dumped_doc = 0
 | |
|       print "!! {{{" funcname "}}}"
 | |
|       if ($0 ~ /}$/) {
 | |
|         in_func = 0
 | |
|         dump_doc = 0
 | |
|         dumped_doc = 0
 | |
|       }
 | |
|       next
 | |
|     }
 | |
|   }
 | |
| }
 | |
| in_func && dump_doc && $0 !~ /^ *#/ {
 | |
|   dump_doc = 0
 | |
| }
 | |
| in_func && dump_doc && $0 ~ /^ *#/ {
 | |
|   if (!dumped_doc) print "{{{"
 | |
|   gsub(/^ *#+ */, "")
 | |
|   print
 | |
|   dumped_doc = 1
 | |
| }
 | |
| in_func && $0 ~ /}$/ {
 | |
|   if (dumped_doc) print "}}}"
 | |
|   in_func = 0
 | |
|   dump_doc = 0
 | |
|   dumped_doc = 0
 | |
| }
 | |
| END { if (in_func) print "}}}" }
 | |
| ' <"$ulib" >"$newcontent"
 | |
|         write_twpage "$oldcontent" "$title" "$newcontent" "$twpage"
 | |
|     done
 | |
| fi
 | |
| 
 | |
| if [ -n "$sync" ]; then
 | |
|     ../twsync ${force:+--force}
 | |
| fi
 |