Исправление ошибок в отладчике
Область действия диспетчера наблюдения
В окне Watch Manager может выводиться содержимое только тех переменных, которые оказываются действительными в области действия той части сценария, на которой было остановлено его выполнение. Рассмотрим для примера следующий сценарий:
function foo x =
(
y = x * x
)
function start = (
y = foo 5)
r = start()
break()
Если попытаться запросить значение переменной y в точке прерывания, в окне Watch Manager появится следующее сообщение о необъявленной переменной: "** Undeclared variable: y.". Дело в том, что обе переменные y оказались вне области действия данного блока кода.
Для запроса значения любой из переменных y придется видоизменить сценарий следующим образом:
function foo x =
(
y = X * X
break()
y
)
function start = (
y = foo 5
break()
Y
)
r = start()
break()
Приложение
Оператор break возвращает значение ОК. Следовательно, для возврата правильного значения нужно явно указать переменную y в конце каждой функции. В противном случае функция возвратит неверное значение.
Итак, вы научились останавливать выполнение сценариев вручную, используя метод break. Кроме того, вы научились запрашивать значения переменных с помощью того же метода break вместо методов print и format. А теперь покажем, как в отладчике MAXScript Debugger исправляются настоящие ошибки типа "Unknownproperty: <insert property name here>" (Неизвестное свойство: <укажите здесь имя свойства>). Такая ошибка знакома всякому опытному создателю сценариев. Она обычно приводит к вопросу "Чье неизвестное свойство?".
Для перехвата подобных ошибок откройте сначала отладчик, а затем диалоговое окно Debugger Parameters и установите флажки Break On Error (Прервать при ошибке) и Break On Exception (Прервать при исключительной ситуации). Далее откройте новое окно редактора MAXScript Editor, введите и вычислите следующий фрагмент кода:
function bazz a b = a.x * b
bazz undefined 5
При выполнении этого фрагмента кода в окне вывода из отладчика появляется
следующаяошибка:
#
-- Unknown property: "x" in undefined
** thread data: threadID:3156
** ------------------------------------------------------
** [stack level: 0]
** In bazz()
-- Parameters:
-- a: undefined
-- b: 5
-- Locals:
-- a: undefined
-- b: 5
-- Externals:
-- owner: undefined
** ------------------------------------------------------
** [stack level: 1]
** called from top-level
Примечание. Вывод результатов обратного отслеживания по стеку в приемнике команд также усовершенствован. Теперь он частично отражает информацию, появляющуюся в окне вывода из отладчика. (Напомним, что вывод результатов обратного отслеживания по стеку в приемнике команд недоступен в режиме прерывания сценария.)
Приложение
В данном случае о самой ошибке сообщается во второй строке, а затем в окне вывода из отладчика появляется содержимое стека обратного отслеживания. Анализируя содержимое этого окна, можно прийти к выводу, что параметр a не определен. Аналогичную информацию о переменных можно было бы с тем же успехом вывести в окне Watch Manager. Преимущество вывода из отладчика над выводом результатов обратного отслеживания по стеку в приемнике команд состоит в том, что значения переменных могут быть введены в окне Watch Manager даже после аварийного останова в режиме прерывания. Теперь вместо поиска в длинном перечне из стека обратного отслеживания достаточно лишь ввести искомую переменную.