This repository is private.
All pages are served over SSL and all pushing and pulling is done over SSH.
No one may fork, clone, or view it unless they are added as a member.
Every repository with this icon (
) is private.
Every repository with this icon (
This repository is public.
Anyone may fork, clone, or view it.
Every repository with this icon (
) is public.
Every repository with this icon (
commit 52a294db87d3df36cc0adaf48f5dcb88e511de08
tree 0d7e4a59f0d6fe4c05861281d3efbc41fe2cfeb7
parent 1cdcf1faad508f07716edb271985ec2c35b64af2
tree 0d7e4a59f0d6fe4c05861281d3efbc41fe2cfeb7
parent 1cdcf1faad508f07716edb271985ec2c35b64af2
kshdb /
| name | age | message | |
|---|---|---|---|
| |
.gitignore | Wed Jun 10 12:03:53 -0700 2009 | |
| |
AUTHORS | Mon Sep 29 20:14:33 -0700 2008 | |
| |
COPYING | Thu Aug 21 10:50:54 -0700 2008 | |
| |
INSTALL | Thu Aug 21 10:50:54 -0700 2008 | |
| |
Makefile.am | ||
| |
NEWS | ||
| |
README | Fri Jun 19 06:21:43 -0700 2009 | |
| |
THANKS | Mon Sep 29 20:14:33 -0700 2008 | |
| |
acinclude.m4 | Thu Aug 14 08:28:25 -0700 2008 | |
| |
autogen.sh | Sat Aug 16 09:53:42 -0700 2008 | |
| |
command/ | ||
| |
configure.ac | ||
| |
dbg-io.sh | ||
| |
dbg-main.sh | ||
| |
dbg-opts.sh | ||
| |
dbg-pre.sh | ||
| |
dbg-trace.sh.in | Wed Jun 10 12:03:53 -0700 2009 | |
| |
doc/ | ||
| |
emacs/ | Sun Nov 02 07:21:10 -0800 2008 | |
| |
getopt-test.sh | Sat Aug 16 09:53:42 -0700 2008 | |
| |
getopts_long.sh | Mon Sep 29 20:14:33 -0700 2008 | |
| |
kshdb.in | Fri Jun 12 19:15:55 -0700 2009 | |
| |
lib/ | ||
| |
test/ | ||
| |
testing.sh | Sun Aug 10 07:19:32 -0700 2008 |
README
0. INTRODUCTION This is a port and cleanup of my bash debugger bashdb (http://bashdb.sf.net). The command syntax generally follows that of the GNU debugger gdb. However this debugger depends on a number bug fixes and of debugging support features that are neither part of the POSIX 1003.1 standard and only in ksh93t+ releases. In particular, there are fixes to a number of the .sh variables like .sh.level and .sh.file. 1. SETUP To get the code, install git and run in a ksh shell: git-clone git://github.com/rocky/kshdb.git cd kshdb ./autogen.sh # Add configure options. See ./configure --help If you've got a suitable ksh93t installed, then make && make test To try on a real program such as perhaps /etc/profile: ./kshdb /etc/profile # substitute /etc/profile with your favorite ksh script If you are happy and "make test" above worked, install via: sudo make install and uninstall with sudo make uninstall # ;-) See INSTALL for generic configure installation instructions. 2. WHAT'S HERE, WHAT'S NOT and WHY NOT What's missing falls into a two categories: * Stuff that can be ported in a straightforward way from bashdb * Stuff that needs additional ksh support Of the things which can be ported in a straight-forward way, however some of them I want to revise and simplify. In some cases, the fact that ksh has associative arrays simplifies code. On other cases, the code I wrote needs refactoring and better modularization. Writing documentation is important, but an extensive guide will have to wait. For now one can consult the reference guide that comes with bashdb: http://bashdb.sf.net/bashdb.html There is some minimal help to get a list of commands and some help for each. 3. WHAT'S NOT HERE YET IN DETAIL 3.a) Showing frame arguments This can done with or without support from ksh, albeit faster with help from ksh. 3.b) Setting $0 3.c) lots of other stuff including... display expressions, signal handling, debugger commands: debug condition file handle history pwd signal tty watch None of this is rocket science. Should be pretty straight-forward to add. 4. WHAT MAY NEED MORE WORK AND SUPPORT FROM KSH 4.a) stopping points that can be used for breakpoint








