1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263
|
# -*- shell-script -*-
# list.sh - Some listing commands
#
# Copyright (C) 2002, 2003, 2004, 2005, 2006, 2008, 2009 Rocky Bernstein
# rocky@gnu.org
#
# bashdb is free software; you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free
# Software Foundation; either version 2, or (at your option) any later
# version.
#
# bashdb is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# for more details.
#
# You should have received a copy of the GNU General Public License along
# with bashdb; see the file COPYING. If not, write to the Free Software
# Foundation, 59 Temple Place, Suite 330, Boston, MA 02111 USA.
_Dbg_help_add list \
'list [START|.|FN] [COUNT] -- List lines of a script.
START is the starting line or dot (.) for current line. Subsequent
list commands continue from the last line listed. If a function name
is given list the text of the function.
If COUNT is omitted, use the setting LISTSIZE. Use "set listsize" to
change this setting.'
# l [start|.] [cnt] List cnt lines from line start.
# l sub List source code fn
_Dbg_do_list() {
typeset first_arg
if (( $# > 0 )) ; then
first_arg="$1"
shift
else
first_arg='.'
fi
if [[ $first_arg == '.' ]] ; then
_Dbg_list "$_Dbg_frame_last_filename" $*
return $?
fi
typeset filename
typeset -i line_number
typeset full_filename
_Dbg_linespec_setup "$first_arg"
if [[ -n $full_filename ]] ; then
(( $line_number == 0 )) && line_number=1
_Dbg_check_line $line_number "$full_filename"
(( $? == 0 )) && \
_Dbg_list "$full_filename" "$line_number" $*
return $?
else
_Dbg_file_not_read_in "$filename"
return 1
fi
}
# /search/
_Dbg_do_search_back() {
typeset delim_search_pat=$1
if [[ -z "$1" ]] ; then
_Dbg_msg "Need a search pattern"
return 1
fi
shift
case "$delim_search_pat" in
[?] )
;;
[?]* )
typeset -a word
word=($(_Dbg_split '?' $delim_search_pat))
_Dbg_last_search_pat=${word[0]}
;;
# Error
* )
_Dbg_last_search_pat=$delim_search_pat
esac
typeset -i i
typeset -i max_line=$(_Dbg_get_assoc_scalar_entry "_Dbg_maxline_" $_cur_filevar)
for (( i=_Dbg_listline-1; i > 0 ; i-- )) ; do
typeset source_line
_Dbg_get_source_line $i
eval "$_seteglob"
if [[ $source_line == *$_Dbg_last_search_pat* ]] ; then
eval "$_resteglob"
_Dbg_do_list $i 1
_Dbg_listline=$i
return 0
fi
eval "$_resteglob"
done
_Dbg_msg "search pattern: $_Dbg_last_search_pat not found."
return 1
}
_Dbg_help_add '/' \
'/search/ -- Search forward and list line of a script.'
# /search/
_Dbg_do_search() {
typeset delim_search_pat=${1}
if [[ -z "$1" ]] ; then
_Dbg_msg "Need a search pattern"
return 1
fi
shift
typeset search_pat
case "$delim_search_pat" in
/ )
;;
/* )
typeset -a word
word=($(_Dbg_split '/' $delim_search_pat))
_Dbg_last_search_pat=${word[0]}
;;
* )
_Dbg_last_search_pat=$delim_search_pat
esac
typeset -i i
typeset -i max_line=`_Dbg_get_assoc_scalar_entry "_Dbg_maxline_" $_cur_filevar`
for (( i=_Dbg_listline+1; i < max_line ; i++ )) ; do
typeset source_line
_Dbg_get_source_line $i
eval "$_seteglob"
if [[ $source_line == *$_Dbg_last_search_pat* ]] ; then
eval "$_resteglob"
_Dbg_do_list $i 1
_Dbg_listline=$i
return 0
fi
eval "$_resteglob"
done
_Dbg_msg "search pattern: $_Dbg_last_search_pat not found."
return 1
}
# S [[!]pat] List Subroutine names [not] matching a pattern
# Pass along whether or not to print "system" functions?
_Dbg_do_list_functions() {
typeset pat=$1
typeset -a fns_a
fns_a=(`_Dbg_get_functions 0 "$pat"`)
typeset -i i
for (( i=0; i < ${#fns_a[@]}; i++ )) ; do
_Dbg_msg ${fns_a[$i]}
done
}
# V [![pat]] List variables and values for whose variables names which
# match pat $1. If ! is used, list variables that *don't* match.
# If pat ($1) is omitted, use * (everything) for the pattern.
_Dbg_do_list_variables() {
local _Dbg_old_glob="$GLOBIGNORE"
GLOBIGNORE="*"
local _Dbg_match="$1"
_Dbg_match_inverted=no
case ${_Dbg_match} in
\!*)
_Dbg_match_inverted=yes
_Dbg_match=${_Dbg_match#\!}
;;
"")
_Dbg_match='*'
;;
esac
local _Dbg_list=`declare -p`
local _Dbg_old_ifs=${IFS}
IFS="
"
local _Dbg_temp=${_Dbg_list}
_Dbg_list=""
local -i i=0
local -a _Dbg_list
# GLOBIGNORE protects us against using the result of
# a glob expansion, but it doesn't protect us from
# actually performing it, and this can bring bash down
# with a huge _Dbg_source_ variable being globbed.
# So here we disable globbing momentarily
set -o noglob
for _Dbg_item in ${_Dbg_temp}; do
_Dbg_list[${i}]="${_Dbg_item}"
i=${i}+1
done
set +o noglob
IFS=${_Dbg_old_ifs}
local _Dbg_item=""
local _Dbg_skip=0
local _Dbg_show_cmd=""
_Dbg_show_cmd=`echo -e "case \\${_Dbg_item} in \n${_Dbg_match})\n echo yes;;\n*)\necho no;; esac"`
for (( i=0; (( i < ${#_Dbg_list[@]} )) ; i++ )) ; do
_Dbg_item=${_Dbg_list[$i]}
case ${_Dbg_item} in
*\ \(\)\ )
_Dbg_skip=1
;;
\})
_Dbg_skip=0
continue
esac
if [[ _Dbg_skip -eq 1 ]]; then
continue
fi
# Ignore all _Dbg_ variables here because the following
# substitutions takes a long while when it encounters
# a big _Dbg_source_
case ${_Dbg_item} in
_Dbg_*) # Hide/ignore debugger variables.
continue;
;;
esac
_Dbg_item=${_Dbg_item/=/==/}
_Dbg_item=${_Dbg_item%%=[^=]*}
case ${_Dbg_item} in
_=);;
*=)
_Dbg_item=${_Dbg_item%=}
local _Dbg_show=`eval $_Dbg_show_cmd`
if [[ "$_Dbg_show" != "$_Dbg_match_inverted" ]]; then
if [[ -n ${_Dbg_item} ]]; then
local _Dbg_var=`declare -p ${_Dbg_item} 2>/dev/null`
if [[ -n "$_Dbg_var" ]]; then
# Uncomment the following 3 lines to use literal
# linefeeds
# _Dbg_var=${_Dbg_var//\\\\n/\\n}
# _Dbg_var=${_Dbg_var//
#/\n}
# Comment the following 3 lines to use literal linefeeds
_Dbg_var=${_Dbg_var//\\\\n/\\\\\\n}
_Dbg_var=${_Dbg_var//
/\\n}
_Dbg_var=${_Dbg_var#* * }
_Dbg_msg ${_Dbg_var}
fi
fi
fi
;;
*)
;;
esac
done
GLOBIGNORE=$_Dbg_old_glob
}
_Dbg_alias_add l list
|