Исправление ошибок в отладчике

Область действия диспетчера наблюдения

В окне 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 даже после аварийного останова в режиме прерывания. Теперь вместо поиска в длинном перечне из стека обратного отслеживания достаточно лишь ввести искомую переменную.