[содержание] [назад] [пред] [вверх] [след] [вперед]
в этой главе обсуждается, как запустить ddd и как выйти из него. в
двух словах:
обычно вы можете запустить ddd, вызвав программу
ddd .
вы также можете запустить ddd с различными аргументами и ключами,
чтобы с самого начала конкретнее определить среду отладки.
чаще всего ddd запускают с одним аргументом, указывающим исполняемую
программу:
ddd программа
если вы используете в качестве подчиненного отладчика gdb, dbx,
ladebug или xdb, вы также можете указать при запуске исполняемую
программу и файл с дампом памяти:
ddd программа дамп
если вы собираетесь отлаживать работающий процесс, вы можете вместо
этого задать в качестве второго аргумента id этого процесса, например,
ddd программа 1234
присоединит ddd к процессу 1234 (если нет файла с именем
`1234'; ddd сначала ищет файл с дампом памяти).
вы можете управлять и другими аспектами ddd, вызывая его с
определенными ключами. чтобы получить список ключей ddd,
вызовите его как
ddd --help
наиболее важны ключи для указания подчиненного отладчика (см. раздел 2.1.1 выбор подчиненного отладчика), но вы можете также настроить при запуске
несколько аспектов ddd (см. раздел 2.1.2 ключи ddd).
кроме того, ddd понимает обычные ключи x, такие как -display
или -geometry . см. раздел 2.1.3 ключи x windows, для получения подробностей.
все аргументы и ключи, не распознанные ddd, передаются подчиненному
отладчику; раздел 2.1.4 ключи подчиненного отладчика. чтобы передать
подчиненному отладчику ключ, который конфликтует с ключом x или
перечисленным здесь ключом ddd, используйте ключ --debugger
(см. раздел 2.1.2 ключи ddd).
чаще всего требуются ключи для выбора конкретного подчиненного
отладчика.
обычно выбор подчиненного отладчика определяется тем, какую программу
нужно анализировать:
-
если для программы требуется конкретный интерпретатор, такой как java,
python или perl, то вам нужно использовать jdb, pydb или отладчик
perl.
используйте
ddd --jdb программа
ddd --pydb программа
ddd --perl программа
для запуска ddd с jdb, pydb или perl в качестве подчиненного
отладчика.
-
если программа является исполняемым двоичным файлом, вам нужен gdb,
dbx, ladebug или xdb. вообще, из этих отладчиков наибольшую
функциональность предоставляет gdb.
используйте
ddd --gdb программа
ddd --dbx программа
ddd --ladebug программа
ddd --xdb программа
для запуска ddd с gdb, dbx, ladebug или xdb в качестве
подчиненного отладчика.
если вы вызываете ddd без этих ключей, но указываете анализируемую
программу, то ddd выберет подчиненный отладчик автоматически:
-
если программа -- это программа на языке python или perl, или
java-класс, ddd вызовет соответствующий отладчик.
-
если программа -- это исполняемый двоичный файл, ddd вызовет
отладчик, применяемый по умолчанию для двоичных программ (обычно это
gdb).
см. раздел 2.5 настройка диалога с подчиненным отладчиком, для получения подробностей об
определении подчиненного отладчика.
вы можете детальнее управлять запуском ddd, используя перечисленные
ниже ключи. все ключи можно сокращать, если это не приводит к
неоднозначности; вместо двойного дефиса -- можно использовать
одинарный - . практически каждый ключ контролирует особый
ресурс или класс ресурсов ddd (см. раздел 3.6 настройка ddd).
--attach-windows
-
присоединить окно исходного текста и окно данных к консоли отладчика,
тогда у ddd будет одно большое окно. эта установка принимается по
умолчанию.
указание этого ключа эквивалентно установке класса ресурсов ddd
`separate' в значение `off'. см. раздел 3.6.4.2 размещение окон, для
дополнительной информации.
--attach-source-window
-
присоединить к консоли отладчика только окно исходного текста.
указание этого ключа эквивалентно установке ресурса ddd
`separatesourcewindow' в значение `off'. см. раздел 3.6.4.2 размещение окон, для
дополнительной информации.
--attach-data-window
-
присоединить к консоли отладчика только окно данных.
указание этого ключа эквивалентно установке ресурса ddd
`separatedatawindow' в значение `off'. см. раздел 3.6.4.2 размещение окон, для дополнительной информации.
--automatic-debugger
-
автоматически определить подчиненный отладчик по заданным аргументам.
указание этого ключа эквивалентно установке ресурса ddd
`autodebugger' в значение `on'. см. раздел 2.5 настройка диалога с подчиненным отладчиком.
--button-tips
-
включить всплывающие подсказки для кнопок.
указание этого ключа эквивалентно установке ресурса ddd
`buttontips' в значение `on'. см. раздел 3.6.2 настройка справки ddd, для
получения подробностей.
--configuration
-
напечатать на стандартный вывод конфигурационные установки ddd и
выйти.
указание этого ключа эквивалентно установке ресурса ddd
`showconfiguration' в значение `on'. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--check-configuration
-
проверить рабочую среду ddd (в частности, конфигурацию x), сообщить о
возможных причинах неисправностей и выйти.
указание этого ключа эквивалентно установке ресурса ddd
`checkconfiguration' в значение `on'. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--data-window
-
открыть при запуске окно данных.
указание этого ключа эквивалентно установке ресурса ddd
`opendatawindow' в значение `on'. см. раздел 3.6.4.4 переключение окон,
для получения подробностей.
--dbx
-
запустить в качестве подчиненного отладчика dbx.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `dbx'. см. раздел 2.5 настройка диалога с подчиненным отладчиком.
--debugger имя
-
вызвать подчиненный отладчик с указанным именем. это полезно,
если у вас есть несколько версий отладчика, или если подчиненный
отладчик нельзя вызвать по его обычному имени (например,
gdb ,
dbx , xdb , jdb , pydb или
perl ).
этот ключ также можно использовать для передачи подчиненному отладчику
ключей, которые иначе конфликтовали бы с ключами ddd. к примеру,
чтобы передать xdb ключ -d каталог , напишите так:
ddd --debugger "xdb -d каталог"
если вы применяете ключ --debugger , убедитесь, что указан также
и тип подчиненного отладчика. то есть используйте один из ключей
--gdb , --dbx , --xdb , --jdb ,
--pydb или --perl (если только принимаемые по
умолчанию установки не срабатывают).
указание этого ключа эквивалентно установке ресурса ddd
`debuggercommand' в значение имя. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для дополнительной информации.
--debugger-console
-
открыть при запуске консоль отладчика.
указание этого ключа эквивалентно установке ресурса ddd
`opendebuggerconsole' в значение `on'. см. раздел 3.6.4.4 переключение окон,
для получения подробностей.
--disassemble
-
дизассемблировать исходный код. смотрите также ключ
--no-disassemble ниже.
указание этого ключа эквивалентно установке ресурса ddd
`disassemble' в значение `on'. см. раздел 4.4 настройка окна исходного кода,
для получения подробностей.
--exec-window
-
запускать отлаживаемую программу в специально созданном окне выполнения.
это бывает нужно для программ, предъявляющих какие-то особые требования
к терминалу, которым не удовлетворяет окно отладчика, например, они
хотят непосредственно обрабатывать ввод с клавиатуры или использовать
управляющие последовательности терминала. см. раздел 6.2 использование окна выполнения, для получения подробностей.
указание этого ключа эквивалентно установке ресурса ddd
`separateexecwindow' в значение `on'. см. раздел 6.2.1 настройка окна выполнения, для дополнительной информации.
--font имя-шрифта
-
-fn имя-шрифта
-
использовать по умолчанию шрифт с указанными именем.
указание этого ключа эквивалентно установке ресурса ddd
`defaultfont' в значение `имя-шрифта'. см. раздел 3.6.4.3 настройка шрифтов, для дополнительной информации.
--fonts
-
напечатать на стандартный вывод используемые ddd определения шрифтов.
указание этого ключа эквивалентно установке ресурса ddd
`showfonts' в значение `on'. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--fontsize размер
-
установить размер шрифта по умолчанию (в десятых пункта). чтобы
ddd использовал 12-пунктовые шрифты, напишите
--fontsize
120 .
указание этого ключа эквивалентно установке класса ресурсов ddd
`fontsize' в значение `размер'. см. раздел 3.6.4.3 настройка шрифтов, для
дополнительной информации.
--fullname
-
-f
-
включить tty-интерфейс: принимать дополнительные команды отладчика со
стандартного ввода и перенаправлять вывод отладчика на стандартный
вывод. текущая позиция печатается в формате gdb
-fullname ,
который подходит для программ-интерфейсов отладчика. по умолчанию
выключаются консоль отладчика и окно исходного кода. см. раздел 10.2 ввод команд с терминала,
обсуждение tty-интерфейса.
указание этого ключа эквивалентно установке класса ресурсов ddd
`ttymode' в значение `on'. см. раздел 10.2 ввод команд с терминала, для
дополнительной информации.
--gdb
-
запустить в качестве подчиненного отладчика gdb.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `gdb'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для получения подробностей.
--glyphs
-
показывать выполняемое в текущий момент место и точки останова
значками. смотрите также ключ
--no-glyphs ниже.
указание этого ключа эквивалентно установке ресурса ddd
`displayglyphs' в значение `on'. см. раздел 4.4 настройка окна исходного кода,
для получения подробностей.
--help
-
-h
-
-?
-
выдать список часто используемых ключей. показать также ключи
подчиненного отладчика.
указание этого ключа эквивалентно установке ресурса ddd
`showinvocation' в значение `on'. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--host имя-машины
-
--host имя-пользователя@имя-машины
-
запустить подчиненный отладчик непосредственно на удаленной машине
имя-машины. если задано имя-пользователя, и не не задан
ключ
--login , использовать имя-пользователя как имя
удаленного пользователя. см. раздел 2.4.2 использование ddd с удаленным подчиненным отладчиком, для получения
подробностей.
указание этого ключа эквивалентно установке ресурса ddd
`debuggerhost' в значение имя-машины. см. раздел 2.4.2 использование ddd с удаленным подчиненным отладчиком, для получения подробностей.
--jdb
-
запустить в качестве подчиненного отладчика jdb.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `jdb'.
см. раздел 2.5 настройка диалога с подчиненным отладчиком, для получения подробностей.
--ladebug
-
запустить в качестве подчиненного отладчика ladebug.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `ladebug'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для дополнительной информации.
--lesstif-hacks
-
эквивалентно
--lesstif-version 999 . использовать не
рекомендуется.
указание этого ключа эквивалентно установке ресурса ddd
`lesstifversion' в значение 999 . см. раздел 10.19 использование ddd с lesstif, для
получения подробностей.
--lesstif-version версия
-
задействовать некоторые хитрости, чтобы ddd правильно работал с
lesstif. см. раздел 10.19 использование ddd с lesstif, обсуждение этой темы.
указание этого ключа эквивалентно установке ресурса ddd
`lesstifversion' в значение версия. см. раздел 10.19 использование ddd с lesstif, для
подробностей.
--license
-
напечатать на стандартный вывод лицензию ddd и выйти.
указание этого ключа эквивалентно установке ресурса ddd
`showlicense' в значение on. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--login имя-пользователя
-
-l имя-пользователя
-
использовать имя-пользователя как имя удаленного пользователя.
см. раздел 2.4.2 использование ddd с удаленным подчиненным отладчиком, для получения подробностей.
указание этого ключа эквивалентно установке ресурса ddd
`debuggerhostlogin' в значение имя-пользователя.
см. раздел 2.4.2 использование ddd с удаленным подчиненным отладчиком, для получения подробностей.
--maintenance
-
включить меню верхнего уровня `maintenance', включающее средства
для отладки ddd. см. раздел 3.1.9 меню menu, для получения
подробностей.
указание этого ключа эквивалентно установке ресурса ddd
`maintenance' в значение on. см. раздел 3.1.9 меню menu, для
получения дополнительной информации.
--manual
-
напечатать на стандартный вывод руководство по ddd и выйти.
указание этого ключа эквивалентно установке ресурса ddd
`showmanual' в значение on. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--news
-
напечатать на стандартный вывод новости о ddd и выйти.
указание этого ключа эквивалентно установке ресурса ddd
`shownews' в значение on. см. раздел 10.12 получение диагностики, для получения
подробностей.
--no-button-tips
-
выключить всплывающие подсказки для кнопок.
указание этого ключа эквивалентно установке ресурса ddd
`buttontips' в значение `off'. см. раздел 3.6.2 настройка справки ddd, для
получения подробностей.
--no-data-window
-
не открывать окно данных при запуске.
указание этого ключа эквивалентно установке ресурса ddd
`opendatawindow' в значение `off'. см. раздел 3.6.4.4 переключение окон,
для получения подробностей.
--no-debugger-console
-
не открывать при запуске консоль отладчика.
указание этого ключа эквивалентно установке ресурса ddd
`opendebuggerconsole' в значение `off'. см. раздел 3.6.4.4 переключение окон, для получения подробностей.
--no-disassemble
-
не дизассемблировать исходный код.
указание этого ключа эквивалентно установке ресурса ddd
`disassemble' в значение `on'. см. раздел 4.4 настройка окна исходного кода,
для получения подробностей.
--no-exec-window
-
запускать отлаживаемую программу не в специально созданном окне
выполнения, а использовать для этого консоль отладчика. это полезно для
программ, которые мало общаются с терминалом, или для удаленной отладки.
см. раздел 6.2 использование окна выполнения, для получения дополнительной
информации.
указание этого ключа эквивалентно установке ресурса ddd
`separateexecwindow' в значение `off'. см. раздел 6.2.1 настройка окна выполнения, для дополнительной информации.
--no-glyphs
-
не использовать графические значки; показывать выполняемую в текущий
момент позицию и точки останова с помощью текстовых знаков.
указание этого ключа эквивалентно установке ресурса ddd
`displayglyphs' в значение `off'. см. раздел 4.4 настройка окна исходного кода,
для получения подробностей.
--no-lesstif-hacks
-
эквивалентно
--lesstif-version 1000 . использовать не
рекомендуется.
указание этого ключа эквивалентно установке ресурса ddd
`lesstifversion' в значение 1000 . см. раздел 10.19 использование ddd с lesstif, для
подробностей.
--no-maintenance
-
не включать меню верхнего уровня `maintenance' для отладки ddd.
принимается по умолчанию. см. раздел 3.1.9 меню menu, для
получения дополнительной информации.
указание этого ключа эквивалентно установке ресурса ddd
`maintenance' в значение off. см. раздел 3.1.9 меню menu, для
получения дополнительной информации.
--no-source-window
-
не открывать при запуске окно исходного кода.
указание этого ключа эквивалентно установке ресурса ddd
`opensourcewindow' в значение `off'. см. раздел 3.6.4.4 переключение окон, для получения подробностей.
--no-value-tips
-
выключить всплывающие подсказки для значений.
указание этого ключа эквивалентно установке ресурса ddd
`valuetips' в значение `off'. см. раздел 7.1 просмотр простых значений с помощью подсказок,
для дополнительной информации.
--nw
-
не использовать интерфейс x windows. запустить подчиненный отладчик на
локальной машине.
--perl
-
запустить perl в качестве подчиненного отладчика.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `perl'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для получения подробностей.
--pydb
-
запустить pydb в качестве подчиненного отладчика.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `pydb'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для дополнительной информации.
--panned-graph-editor
-
использовать для прокрутки окна данных панель прокрутки athena.
большинство пользователей предпочитают ее полоскам прокрутки, поскольку
она позволяют делать двумерную прокрутку. однако, по умолчанию панель
прокрутки выключена, потому что некоторые реализации motif плохо
работают с виджетами athena. см. раздел 7.3.1.12 настройка отображений, для деталей;
смотрите также ключ
--scrolled-graph-editor ниже.
указание этого ключа эквивалентно установке ресурса ddd
`pannedgrapheditor' в значение `on'. см. раздел 7.3.1.12 настройка отображений, для получения подробностей.
--play-log файл-протокола
-
повторить предыдущий сеанс ddd.
ddd --play-log файл-протокола
вызывает ddd как подчиненный отладчик, имитируя подчиненный отладчик,
указанный в файле-протокола (смотрите ниже). это полезно для
отладки ddd.
указание этого ключа эквивалентно установке ресурса ddd
`playlog' в значение `on'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для дополнительной информации.
--play файл-протокола
-
имитировать подчиненный отладчик. файл-протокола -- это файл
`$home/.ddd/log', созданный одним из предыдущих сеансов
ddd (см. раздел 10.12.1 запись протокола). при вводе команды искать ее в
файле-протокола и повторить записанный ответ; если команда не
найдена, не делать ничего. это используется ключом
--play .
--rhost имя-машины
-
--rhost имя-пользователя@имя-машины
-
запустить подчиненный отладчик в интерактивном режиме на удаленной
машине имя-машины. если задано имя-пользователя, и не задан
ключ
--login , использовать его в качестве имени удаленного
пользователя. см. раздел 2.4.2 использование ddd с удаленным подчиненным отладчиком, для получения подробностей.
указание этого ключа эквивалентно установке ресурса ddd
`debuggerrhost' в значение имя-машины. см. раздел 2.4.2 использование ddd с удаленным подчиненным отладчиком, для получения подробностей.
--scrolled-graph-editor
-
использовать в окне данных полоски прокрутки motif. это принимается по
умолчанию в большинстве конфигураций ddd. см. раздел 7.3.1.12 настройка отображений, для получения подробностей; смотрите также
--panned-graph-editor ниже.
указание этого ключа эквивалентно установке ресурса ddd
`pannedgrapheditor' в значение `off'. см. раздел 7.3.1.12 настройка отображений, для получения подробностей.
--separate-windows
-
--separate
-
разделить консоль и окна исходного кода и данных. смотрите также ключи
--attach выше.
указание этого ключа эквивалентно установке класса ресурсов ddd
`separate' в значение `off'. см. раздел 3.6.4.2 размещение окон, для
дополнительной информации.
--session сеанс
-
загрузить при запуске указанный сеанс. см. раздел 2.3.2 продолжение сеансов, для получения подробностей.
указание этого ключа эквивалентно установке ресурса ddd
`session' в значение сеанс. см. раздел 2.3.2 продолжение сеансов, для
получения подробностей.
--source-window
-
открыть при запуске окно с исходным текстом.
указание этого ключа эквивалентно установке ресурса ddd
`opensourcewindow' в значение `on'. см. раздел 3.6.4.4 переключение окон,
для получения подробностей.
--status-at-bottom
-
поместить строку состояния внизу окна исходного текста.
указание этого ключа эквивалентно установке ресурса ddd
`statusatbottom' в значение `on'. см. раздел 3.6.4.2 размещение окон, для
дополнительной информации.
--status-at-top
-
поместить строку состояния вверху окна исходного текста.
указание этого ключа эквивалентно установке ресурса ddd
`statusatbottom' в значение `off'. см. раздел 3.6.4.2 размещение окон,
для дополнительной информации.
--sync-debugger
-
не обрабатывать события x windows, когда отладчик занят. это может
слегка повысить производительность на однопроцессорных системах.
указание этого ключа эквивалентно установке ресурса ddd
`synchronousdebugger' в значение `on'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для получения подробностей.
--toolbars-at-bottom
-
помещать панели инструментов внизу соответствующего окна.
указание этого ключа эквивалентно установке ресурса ddd
`toolbarsatbottom' в значение `on'. см. раздел 3.6.4.2 размещение окон,
для дополнительной информации.
--toolbars-at-top
-
помещать панели инструментов вверху соответствующего окна.
указание этого ключа эквивалентно установке ресурса ddd
`toolbarsatbottom' в значение `off'. см. раздел 3.6.4.2 размещение окон,
для дополнительной информации.
--trace
-
напечатать диалог между ddd и подчиненным отладчиком на стандартный
поток ошибок. это полезно для отладки ddd. если ключ
--trace не задан, эта информация записывается в файл
`~/.ddd/log' (`~' обозначает ваш начальный каталог),
чтобы вы могли проводить также и "посмертную" отладку.
см. раздел 10.12.1 запись протокола, подробности о записи протокола.
указание этого ключа эквивалентно установке ресурса ddd `trace'
в значение on. см. раздел 10.12 получение диагностики, для получения подробностей.
--tty
-
-t
-
включить tty-интерфейс, принимая дополнительные команды отладчика со
стандартного ввода и перенаправляя вывод отладчика на стандартный вывод.
текущая позиция печатается в формате, понятном человеку. по умолчанию
консоль отладчика выключается.
указание этого ключа эквивалентно установке ресурса ddd
`ttymode' в значение `on'. см. раздел 10.2 ввод команд с терминала, для
дополнительной информации.
--value-tips
-
включить всплывающие подсказки для значений.
указание этого ключа эквивалентно установке ресурса ddd
`valuetips' в значение `on'. см. раздел 7.1 просмотр простых значений с помощью подсказок,
для дополнительной информации.
--version
-
-v
-
напечатать на стандартный вывод версию ddd и выйти.
указание этого ключа эквивалентно установке ресурса ddd
`showversion' в значение `on'. см. раздел 10.12 получение диагностики, для
дополнительной информации.
--vsl-library библиотека
-
загрузить vsl-библиотеку библиотека, а не использовать
встроенную в ddd. это полезно для настройки геометрии и шрифтов в
изображениях данных.
указание этого ключа эквивалентно установке ресурса ddd
`vsllibrary' в значение библиотека. см. раздел 7.3.7.3 настройка внешнего вида отображений, для дополнительной информации.
--vsl-path путь
-
искать vsl-библиотеки по указанному пути (это разделенный
двоеточиями список каталогов).
указание этого ключа эквивалентно установке ресурса ddd
`vslpath' в значение путь. см. раздел 7.3.7.3 настройка внешнего вида отображений, для дополнительной информации.
--vsl-help
-
показать список остальных ключей, управляющих интерпретатором vsl.
эти ключи предназначены для отладки и могут меняться без предупреждений.
--xdb
-
запустить xdb в качестве подчиненного отладчика.
указание этого ключа эквивалентно установке ресурса ddd
`debugger' в значение `xdb'. см. раздел 2.5 настройка диалога с подчиненным отладчиком, для получения подробностей.
ddd также понимает перечисленные ниже ключи x windows. обратите
внимание, у этих ключей только один дефис - .
-display дисплей
-
использовать x-сервер дисплей. по умолчанию дисплей берется
из переменной среды
display .
-geometry геометрия
-
задает начальный размер и позицию консоли отладчика.
-iconic
-
запустить ddd в свернутом виде.
-name имя
-
дать ddd указанное имя.
-selectiontimeout время
-
задает промежуток времени (в миллисекундах), в течение которого два
общающихся приложения должны ответить друг другу на запрос о выделении.
-title имя
-
дать окну ddd заголовок имя.
-xrm строка-ресурса
-
задает имя ресурса и его значение, перекрывающее установку по умолчанию.
все ключи, которые ddd не распознает, передаются подчиненному
отладчику. этот раздел перечисляет наиболее полезные ключи разных
подчиненных отладчиков, поддерживаемых ddd.
эти ключи gdb полезны при использовании ddd с gdb в качестве
подчиненного отладчика. всесто двойных дефисов -- можно также
использовать одинарные - .
-b скорость
-
устанавливает скорость порта в бодах, для удаленной отладки.
--cd каталог
-
сменить текущий каталог на указанный.
--command файл
-
выполнить команды gdb из указанного файла.
--core файл-дампа
-
анализировать указанный файл-дампа.
--directory каталог
-
-d каталог
-
добавить каталог к пути поиска исходных файлов.
--exec выполняемый-файл
-
использовать указанный файл в качестве выполняемого.
--mapped
-
использовать отображаемые в память файлы символов, если они
поддерживаются системой.
--nx
-
-n
-
не считывать файл `.gdbinit'.
--readnow
-
полностью считать файлы символов при первом обращении.
--se файл
-
использовать файл как файл символов и выполняемый файл.
--symbols файл-символов
-
считать символы из указанного файла.
см. раздел `вызов gdb' в отладка с gdb,
другие ключи, которые можно использовать с gdb.
варианты dbx сильно различаются по ключам, поэтому мы не можем
привести здесь список. смотрите man-страницы dbx(1) и
ladebug(1).
данные ключи xdb полезны при использовании его в качестве
подчиненного отладчика для ddd.
-d каталог
-
задает каталог как дополнительный каталог для поиска исходных
файлов.
-p id-процесса
-
задает id существующего процесса, который пользователь собирается
отлаживать.
-l библиотека
-
предварительно загрузить информацию о разделяемой библиотеке.
-l all велит делать это всегда.
-s число
-
установить размер кеша строк равным числу байт (по умолчанию это
1024, минимальное значение).
-s
-
включить отладку разделяемых библиотек.
другие ключи можно найти с man-странице xdb(1).
следующие ключи jdb полезны при использовании его в качестве
подчиненного отладчика для ddd.
-host имя-машины
-
машина интерпретатора, к которой следует подключиться.
-password пароль
-
пароль интерпретатора (из
-debug ).
следующие ключи jdb передаются отлаживаемому процессу:
-verbose
-
-v
-
включить режим подробной диагностики.
-debug
-
включить удаленную отладку java.
-noasyncgc
-
запретить асинхронную сборку мусора.
-verbosegc
-
печатать сообщение, когда происходит сборка мусора.
-noclassgc
-
выключить сборку мусора для классов.
-checksource
-
-cs
-
проверять при загрузке классов, не обновился ли исходный файл.
-ss число
-
устанавливает максимальный размер реального стека для любой нити.
-oss число
-
устанавливает максимальный размер стека java для любой нити.
-ms число
-
устанавливает начальный размер кучи java.
-mx число
-
устанавливает максимальный размер кучи java.
-dимя=значение
-
устанавливает системное свойство имя в указанное значение.
-classpath путь
-
список каталогов, в которых следует искать классы. путь -- это
разделенный двоеточиями список каталогов.
-prof
-
-prof:файл
-
выводить профилировочные данные в файл `./java.prof'. если указан
файл, выводить эти данные в `./файл'.
-verify
-
проверять все классы перед чтением.
-verifyremote
-
проверять классы, считываемые из сети (по умолчанию).
-noverify
-
не проверять классы.
-dbgtrace
-
печатать информацию для отладки jdb.
другие ключи можно найти в документации на jdb.
для получения списка полезных ключей pydb смотрите его документацию.
самый важный ключ perl для использования с ddd -- это -w ;
он включает печать нескольких важных предупреждений. остальные ключи
смотрите в man-странице perlrun(1).
если у вас запущено несколько экземпляров ddd, они разделяют общие
настройки и файлы истории. это означает, что примененные к одному
экземпляру изменения могут быть потеряны, когда их перезапишет другой
экземпляр. ddd может защитить вас от нежелательных потерь двумя
способами. первый -- это автоматическая перезагрузка измененных
параметров, управляемая следующим ресурсом (см. раздел 3.6 настройка ddd):
- ресурс: checkoptions (класс checkoptions)
-
каждые n секунд, где n -- это значение данного ресурса,
ddd проверяет, не изменился ли файл параметров. по умолчанию это
30 . установка этого ресурса в значение 0 выключает
проверку файла параметров.
обычно автоматической перезагрузки параметров бывает достаточно. если
вам нужна более сильная защита, ddd также может выдавать
предупреждение о запуске нескольких экземпляров. по умолчанию это
предупреждение не выводится. если вы хотите получать его, включите
`edit => preferences => warn if multiple ddd
instances are running'.
эта установка привязана к такому ресурсу (см. раздел 3.6 настройка ddd):
- ресурс: warniflocked (класс warniflocked)
-
нужно ли предупреждать, если запущено несколько экземпляров ddd
(`on'), или не нужно (`off', по умолчанию).
если вас раздражают предупреждения x windows, вы можете подавить их,
установив `edit => preferences => general =>
suppress x warnings'.
данная установка привязана к следующему ресурсу (см. раздел 3.6 настройка ddd):
- ресурс: suppresswarnings (класс suppresswarnings)
-
если это `on', предупреждения x не выводятся. это бывает иногда
полезно для выполняемых файлов, собранных на машине с другой
конфигурацией x windows или motif. по умолчанию `off'.
чтобы покинуть ddd, выберите `file => exit'. вы также
можете набрать команду quit в подсказке отладчика или нажать
ctrl+q. gdb и xdb также поддерживают команду q
или знак конца файла (обычно ctrl+d). при закрытии последнего
окна ddd также завершится.
прерывание (esc или `interrupt') не закрывает ddd, а
завершает действие любой работающей в данный момент команды отладчика и
возвращает на командный уровень. можно всегда безопасно ввести знак
прерывания, потому что отладчик не позволяет ему подействовать до тех
пор, пока это не будет безопасно.
если обычное прерывание не срабатывает, вы можете использовать аварийный
останов (ctrl+\ или `abort'), что посылает подчиненному
отладчику сигнал sigabrt . используйте это только в чрезвычайных
ситуациях; после этого сигнала подчиненный отладчик может оказаться в
несогласованном состоянии или даже завершиться.
в крайнем случае (например, если ddd зависает), вы можете также
прервать сам ddd, используя сигнал прерывания sigint ). это
можно сделать, набрав знак прерывания (обычно это ctrl+c) в
оболочке, откуда был запущен ddd, или с помощью команды unix
kill . этот сигнал прерывает любое действие ddd;
подчиненный отладчик также прерывается. поскольку прерывание может
привести к внутренней несогласованности, прибегайте к нему только в
исключительных ситуациях; как можно быстрее сохраните свою работу и
перезапустите ddd.
если вы хотите прервать текущий сеанс ddd, вы можете сохранить все
состояние отладчика как сеанс на диске и продолжить работу
позднее.
чтобы сохранить сеанс, выберите `file => save session as'.
у вас спросят символьное имя для этого сеанса.
если ваша программа запущена (см. раздел 6. запуск программы), или если вы открыли файл
с дампом (см. раздел 4.2.2 открывание дампов памяти), ddd также может включить
в сеанс дамп памяти, с тем чтобы данные отлаживаемой программы
восстанавливались после повторного открытия сеанса. чтобы получить дамп
памяти, ddd как правило должен уничтожить отлаживаемую
программу. это означает, что вы не сможете продолжить выполнение
программы после сохранения сеанса. в зависимости от архитектуры могут
быть доступны и другие пути получения дампа памяти.
включение дампа необходимо для восстановления содержимого памяти и
исполняемой в текущий момент позиции. чтобы включить в сеанс дамп
памяти, задействуйте `include core dump'.
после щелчка на `save' сеанс сохраняется в
`~/.ddd/sessions/сеанс'.
вот список вещей, состояние которых записывается в сеансе:
после сохранения текущего состояния сеанса он становится активным.
это означает, что состояние ddd будет сохраняться как сеанс по
умолчанию:
-
пользовательские параметры будут сохраняться в
`~/.ddd/sessions/сеанс/init', а не в
`~/.ddd/init'. см. раздел 3.6.1.3 сохранение параметров, для получения
подробностей.
-
история команд ddd будет сохраняться в
`~/.ddd/sessions/сеанс/history', а не в
`~/.ddd/history'. см. раздел 10.1.2 история команд, для
дополнительной информации.
чтобы сделать текущий сеанс неактивным, откройте сеанс по
умолчанию с именем `[none]'. см. раздел 2.3.2 продолжение сеансов,
подробности об открывании сеансов.
чтобы продолжить сохраненный ранее сеанс, нажмите `file =>
open session' и выберите из списка имя нужного сеанса. после щелчка на
`open' будет восстановлено полное состояние ddd для указанного
сеанса.
сеанс с именем `[none]' -- это сеанс по умолчанию, который
активен при запуске ddd. чтобы сохранить параметры для сеанса по
умолчанию, откройте его и запишите параметры. см. раздел 3.6.1.3 сохранение параметров, для получения подробностей.
если восстановленный сеанс включает дамп памяти, то отлаживаемая
программа будет в том же состоянии, в каком она была во время сохранения
сеанса; в частности, вы сможете исследовать данные программы. однако, у
вас не будет возможности продолжить выполнение программы, поскольку ее
процесс и среда (открытые файлы, ресурсы, etc.) больше не существуют.
тем не менее, вы сможете перезапустить программу, снова используя
восстановленные точки останова и отображения данных.
открытие сеансов также восстанавливает определения команд, кнопок,
операции быстрого создания отображений и размер табуляции в исходнике.
таким образом вы можете держать различные наборы определений для каждого
сеанса.
вы также можете указать, какой сеанс следует открыть, при запуске
ddd. чтобы вызвать ddd с сеансом сеанс, используйте
ddd --session сеанс
есть также краткая форма записи, которая открывает сеанс и
вызывает подчиненный отладчик для исполняемого файла с именем
сеанс (в случае, если сеанс невозможно открыть):
ddd =сеанс
при перезапуске сеанса нет нужды давать другие ключи командной строки,
поскольку они будут перекрыты ключами, сохраненными в сеансе.
для записи и восстановления сеансов ddd вы также можете использовать
менеджер сеансов для x windows, такой как xsm .(7) когда ddd
завершается менеджером сеансов, он сохраняет свое состояние под именем,
которое ему сообщает менеджер сеансов; восстановление x-сеанса
заставляет ddd перезагрузить сохраненное состояние.
чтобы удалить сеансы, которые вам больше не нужны, выберите `file
=> open session' или `file => save session'.
выделите ненужные сеансы и щелкните на `delete'.
сеанс по умолчанию `[none]' нельзя удалить.
вы можете изменить место, где ddd записывает сеансы, устанавливая
переменную среды ddd_sessions равной имени каталога. по умолчанию
принимается `~/.ddd/sessions/'.
когда это применимо, ddd поддерживает команду gcore , которая
служит для получения файла с дампом памяти работающей программы. вы
можете ввести путь этой команды через `edit => preferences
=> helpers => get core file'. оставьте значение пустым,
если у вас нет gcore или подобной программы.
данная установка привязана к следующему ресурсу (см. раздел 3.6 настройка ddd):
- ресурс: getcorecommand (класс getcorecommand)
-
команда для получения дампа памяти работающего процесса (обычно это
gcore ) `@file@' заменяется на базовое имя создаваемого
файла; `@pid@' заменяется на id процесса. вывод должен быть
записан в `@file@.@pid@'.
оставьте значение пустым, если у вас нет gcore или подобной
программы.
вы можете запустить ddd, подчиненный отладчик и отлаживаемую
программу на разных машинах.
вы можете запустить ddd на удаленной машине, используя текущую машину
в качестве x-дисплея. для вызова ddd на удаленной машине наберите
ddd -display дисплей
где дисплей -- это имя x-сервера, к которому следует
подсоединиться (например, `имя-машины:0.0', где
имя-машины -- это имя вашей машины).
вместо указания ключа -display дисплей вы также можете
установить переменную среды display равной дисплею.
чтобы запустить подчиненный отладчик на удаленной машине, вам требуется
доступ к этой машине по `remsh' (в системах bsd это называется
`rsh').
для запуска отладчика на удаленной машине имя-машины, вызовите
ddd как
ddd --host имя-машины удаленная-программа
если удаленное имя пользователя отличается от локального, используйте
ddd --host имя-машины --login имя-пользователя
удаленная-программа
или
ddd --host имя-пользователя@имя-машины удаленная-программа
в удаленном режиме отладки есть несколько трудных мест:
-
удаленный отладчик запускается в вашем начальном каталоге на удаленной
машине. следовательно, вы должны указывать абсолютный путь к
удаленной-программе (или путь относительно вашего начального
каталога на удаленной машине). то же относится к удаленным файлам с
дампами. кроме того, убедитесь, что при отладке работающей программы вы
указываете id удаленного процесса.
-
удаленный отладчик запускается в неинтерактивном режиме. некоторые
версии dbx плохо с этим справляются. если вы не получили подсказку
от удаленного отладчика, используйте ключ
--rhost вместо
--host . тогда удаленный отладчик будет запущен через
интерактивную оболочку на удаленной машине, что может улучшить ситуацию.
замечание: при использовании --rhost , ddd вызывает
подчиненный отладчик, как только появляется подсказка оболочки. первый
кусок вывода на удаленной машине, завершающийся пробелом или знаком
`>', и после которого не следует перевод строки, считается
подсказкой оболочки. если необходимо, настройте подсказку оболочки на
удаленной машине.
-
для запуска удаленной программы ddd вызывает на удаленной машине
эмулятор терминала
xterm , передавая в качестве адреса текущее
значение переменной среды display . если удаленная машина не может
запустить xterm или не имеет доступа к вашему x-дисплею,
запустите ddd с ключом --no-exec-window . тогда ввод/вывод
программы будет идти через консоль отладчика ddd.
-
в удаленном режиме все исходники загружаются с удаленной машины; диалоги
для выбора файлов сканируют удаленные каталоги. это может привести к
несколько более медленной работе, чем обычно.
-
чтобы обнаружить проблемы, возникшие при удаленной отладке, запустите
ddd с ключом
--trace . тогда отдаваемые ddd команды
оболочки печатаются на стандартный поток ошибок.
см. раздел 2.4.2.1 настройка удаленной отладки, о настройке удаленного режима.
когда вы запускаете подчиненный отладчик на удаленной машине
(см. раздел 2.4 удаленная отладка), все команды для обращения к подчиненному
отладчику и его файлам должны запускаться удаленно. этим управляют
следующие ресурсы (см. раздел 3.6 настройка ddd):
- ресурс: rshcommand (класс rshcommand)
-
команда удаленной оболочки для запуска терминальных команд на удаленной
машине. обычно это
remsh , rsh , ssh или
on .
- ресурс: listcorecommand (класс listcorecommand)
-
команда для перечисления всех файлов с дампами на удаленной машине.
строка `@mask@' заменяется на фильтр файлов. по умолчанию
принимается такая установка:
ddd*listcorecommand: \
file @mask@ | grep '.*:.*core.*' | cut -d: -f1
- ресурс: listdircommand (класс listdircommand)
-
команда для перечисления всех каталогов на удаленной машине. строка
`@mask@' заменяется на фильтр файлов. по умолчанию принимается
такая установка:
ddd*listdircommand: \
file @mask@ | grep '.*:.*directory.*' | cut -d: -f1
- ресурс: listexeccommand (класс listexeccommand)
-
команда для перечисления всех исполняемых файлов на удаленной машине.
строка `@mask@' заменяется на фильтр файлов. по умолчанию
действует такая установка:
ddd*listexeccommand: \
file @mask@ | grep '.*:.*exec.*' \
| grep -v '.*:.*script.*' \
| cut -d: -f1 | grep -v '.*\.o$'
- ресурс: listsourcecommand (класс listsourcecommand)
-
команда для перечисления всех исходных файлов на удаленной машине.
строка `@mask@' заменяется на фильтр файлов. по умолчанию
действует такая установка:
ddd*listsourcecommand: \
file @mask@ | grep '.*:.*text.*' | cut -d: -f1
отладчик gdb позволяет вам запускать отлаживаемую программу на
удаленной машине (называемой удаленной целью), тогда как gdb
работает на локальной машине.
см. раздел `remote debugging' в debugging with gdb, для получения подробностей. в двух словах,
требуются следующие шаги:
-
переслать исполняемый файл на удаленную цель.
-
запустить на удаленной цели
gdbserver .
-
запустить ddd, используя gdb на локальной машине, и загрузить тот
же исполняемый файл с помощью команды gdb
file .
-
соединиться с удаленным сервером `gdbserver', применив команду
gdb
target remote .
локальный файл `.gdbinit' полезен для подготовки путей поиска, etc.
разумеется, вы можете также комбинировать удаленные режимы ddd и
gdb, запуская ddd, gdb и отлаживаемую программу на разных
машинах.
перечисленные ниже установки управляют диалогом ddd с его подчиненным
отладчиком.
чтобы выбрать используемый по умолчанию отладчик, выберите `edit
=> preferences => startup => debugger type'. вы
можете сделать так, чтобы
-
ddd определял подходящий подчиненный отладчик автоматически по
аргументам командной строки. это включается установкой `determine
automatically from arguments'.
-
ddd запускал выбранный вами отладчик, как указано в `debugger
type'.
следующие ресурсы ddd управляют вызовом подчиненного отладчика
(см. раздел 3.6 настройка ddd).
- ресурс: autodebugger (класс autodebugger)
-
если `on' (по умолчанию), ddd будет пытаться определить тип
отладчика по аргументам, возможно, перекрывая ресурс `debugger'
(смотрите ниже). если `off', ddd будет вызывать отладчик,
указанный ресурсом `debugger', независимо от аргументов.
- ресурс: debugger (класс debugger)
-
тип подчиненного отладчика (`gdb', `dbx', `ladebug',
`xdb', `jdb', `pydb' или `perl').
данный ресурс обычно устанавливается через ключи --gdb ,
--dbx , --ladebug , --xdb , --jdb ,
--pydb и --perl ; см. раздел 2.1.2 ключи ddd, для получения подробной
информации.
- ресурс: debuggercommand (класс debuggercommand)
-
имя, по которому следует вызывать подчиненный отладчик. если эта строка
пуста (по умолчанию), используется тип отладчика (ресурс
`debugger').
данный ресурс обычно устанавливается через ключ --debugger ;
см. раздел 2.1.2 ключи ddd, для получения подробной информации.
ddd использует несколько ресурсов для инициализации подчиненного
отладчика (см. раздел 3.6 настройка ddd).
- ресурс: gdbinitcommands (класс initcommands)
-
данная строка содержит список разделенных переводами строки команд,
которые первым делом посылаются gdb. есть побочный эффект: все
указанные в этом ресурсе установки считаются фиксированными и не могут
быть изменены через панель установок gdb, если только перед ними не
стоит пробел. по умолчанию ресурс `gdbinitcommands' содержит
несколько абсолютно необходимых для ddd установок:
ddd*gdbinitcommands: \
set height 0\n\
set width 0\n\
set verbose off\n\
set prompt (gdb) \n
тогда как установки `set height', `set width' и `set
prompt' фиксированы, установку `set verbose' можно изменить из
панели настройки gdb (хотя это сбрасываться при каждом запуске
ddd).
не используйте этот ресурс для настройки gdb; вместо этого, напишите
персональный файл `~/.gdbinit'. подробности смотрите в
документации по gdb.
- ресурс: gdbsettings (класс settings)
-
эта строка содержит список разделенных переводами строки команд, которые
также посылаются gdb. по умолчанию ее значение равно
ddd*gdbsettings: \
set print asm-demangle on\n
этот ресурс используется для записи и восстановления установок
отладчика.
- ресурс: sourceinitcommands (класс sourceinitcommands)
-
если `on' (по умолчанию), ddd записывает все команды
инициализации gdb во временный файл и велит gdb считать его, а не
посылает команды по одной. это приводит к более быстрому запуску
(особенно если вы определяете много пользовательских команд). если
`off', ddd посылает gdb команды по отдельности.
- ресурс: dbxinitcommands (класс initcommands)
-
эта строка содержит список разделенных переводами строки команд, которые
изначально посылаются dbx. по умолчанию она пуста.
не используйте этот ресурс для настройки dbx; вместо этого, напишите
персональный файл `~/.dbxinit' или `~/.dbxrc'. подробности
смотрите в документации по dbx.
- ресурс: dbxsettings (класс settings)
-
данная строка содержит список разделенных переводами строки команд,
которые также изначально посылаются dbx. по умолчанию она пуста.
- ресурс: xdbinitcommands (класс initcommands)
-
данная строка содержит список разделенных переводами строки команд,
которые изначально посылаются xdb. по умолчанию она пуста.
не используйте этот ресурс для настройки xdb; вместо этого, напишите
персональный файл `~/.xdbrc'. подробности смотрите в документации
по xdb.
- ресурс: xdbsettings (класс settings)
-
эта строка содержит список разделенных переводами строки команд, которые
также посылаются xdb. по умолчанию она пуста.
- ресурс: jdbinitcommands (класс initcommands)
-
эта строка содержит список разделенных переводами строки команд, которые
изначально посылаются jdb. этот ресурс можно использовать для
настройки jdb. по умолчанию он пуст.
- ресурс: jdbsettings (класс settings)
-
эта строка содержит список разделенных переводами строки команд, которые
также изначально посылаются jdb. по умолчанию она пуста.
ddd использует этот ресурс для записи и восстановления установок
jdb.
- ресурс: pydbinitcommands (класс initcommands)
-
данная строка содержит список разделенных переводами строки команд,
которые изначально посылаются pydb. по умолчанию она пуста.
этот ресурс можно использовать для настройки pydb.
- ресурс: pydbsettings (класс settings)
-
эта строка содержит список разделенных переводами строки команд, которые
также изначально посылаются pydb. по умолчанию она пуста.
ddd использует этот ресурс для записи и восстановления установок
pydb.
- ресурс: perlinitcommands (класс initcommands)
-
эта строка содержит список разделенных переводами строки команд, которые
изначально посылаются отладчику perl. по умолчанию она пуста.
этот ресурс можно использовать для настройки отладчика perl.
- ресурс: perlsettings (класс settings)
-
данная строка содержит список разделенных переводами строки команд,
которые также изначально посылаются отладчику perl. по умолчанию она
пуста.
ddd использует этот ресурс для записи и восстановления установок
отладчика perl.
- ресурс: initsymbols (класс initsymbols)
-
при загрузке исполняемого файла, ddd запрашивает у подчиненного
отладчика начальную позицию в исходном тексте -- обычно это функция
main . если такая позиция не найдена, ddd пробует другие
символы из этого разделенного переводами строки списка. значение,
которое принимается по умолчанию, велит ddd искать различные варианты
главной функции (в особенности главные функции фортрана):
main\n\
main\n\
main_\n\
main_\n\
main__\n\
main__\n\
_main\n\
_main\n\
__main\n\
__main
- ресурс: openselection (класс openselection)
-
если это `on', вызванный без аргументов ddd проверяет, не
содержит ли текущее выделение или буфер обмена имя файла или url
выполняемой программы. если это так, ddd автоматически откроет эту
программу для отладки. если данный ресурс равен `off' (по
умолчанию), вызванный без аргументов ddd всегда будет запускаться без
отлаживаемой программы.
следующие ресурсы управляют общением с подчиненным отладчиком.
- ресурс: blockttyinput (класс blockttyinput)
-
должен ли ddd блокироваться при чтении данных от подчиненного
отладчика через псевдотерминальный интерфейс. большинство систем
unix, кроме gnu/linux требуют этого; установите его в
`on'. на gnu/linux, устанавливайте его равным `off'.
значение `auto' (по умолчанию) всегда делает "лучший" выбор (то
есть лучший выбор из известных разработчикам ddd).
- ресурс: displaytimeout (класс displaytimeout)
-
время ожидания (в миллисекундах) пока подчиненный отладчик закончит
вывод информации отображения. по умолчанию
2000 .
- ресурс: positiontimeout (класс positiontimeout)
-
время ожидания (в миллисекундах) пока подчиненный отладчик закончит
вывод информации о позиции. по умолчанию
500 .
- ресурс: questiontimeout (класс questiontimeout)
-
время (в секундах) ожидания ответа от подчиненного отладчика. по
умолчанию
10 .
- ресурс: synchronousdebugger (класс synchronousdebugger)
-
если `on', события x не обрабатываются, пока отладчик занят. это
может слегка улучшить производительность на однопроцессорных системах.
см. раздел 2.1.2 ключи ddd, о ключе
--sync-debugger .
- ресурс: terminateoneof (класс terminateoneof)
-
если `on', ddd завершает подчиненный отладчик, когда ddd
обнаруживает конец файла (то есть, когда подчиненный отладчик закрывает
канал вывода). так ddd действовал по умолчанию в версии 2.x и более
ранних. если это `off' (по умолчанию), ddd не делает ничего
особенного.
- ресурс: usettycommand (класс usettycommand)
-
если `on', использовать команду gdb
tty для
перенаправления ввода/вывода в отдельное окно выполнения. если
`off', использовать явное перенаправление посредством операторов
перенаправления оболочки `<' и `>'. по умолчанию `off'
(явное перенаправление), так как на некоторых системах и в некоторых
версиях gdb команда tty работает неправильно.
[содержание] [назад] [пред] [вверх] [след] [вперед]
|