Actions
Трассировка обхода сценарного КА¶
Что есть на данный момент (конец июня 2010)¶
- Реализована трассировка для старых UTT.
- Состояния, начало и конец переходов, запуск и завершение сценариев трассирует обходчик.
- Значения итерационных переменных трассируются сгенерированным кодом по мере их вычисления. При этом в трассе возможны незавершённые переходы, у которых оттрассированы не все описанные в коде сценарного метода итерационные переменные (вообще говоря, они не являются переходами).
- Ранее вызовы дуг всегда выполняли next + call; затем для нужд проекта спрямителя были реализованы вызовы call, а для нужд проекта netfsm - вызовы next. Старые обходчики (dfsm, ndfsm) используют только вызовы старого образца.
- stable переменные хранятся в одной структуре с итерационными, то есть, вообще говоря, привязаны не к состоянию, а, например, к сохранённой в обходчике дуге.
Что нужно¶
- Реализовать трассировку обхода сценарного КА средствами Aspectrace (в аспекте "fsm") совместно с или вместо старой трассировки.
- Реализовать библиотечный метод, получающий указатели на
ScenarioFunctionDesc
и структуру данных, содержащую значения итерационных переменных, и осуществляющий трассировку (UTT & Aspectrace) всех значений итерационных переменных. При этом в структуреScenarioFunctionDesc
должно добавиться поле, содержащее ссылку на соответствующийStructTypeDesc
. - Вся трассировка должна выполняться кодом обходчика. Для устранения из трасс незавершённых переходов следует отказаться в обходчике от вызовов старого образца, а делать всегда отдельно next и отдельно call. При вызове next обычная трассировка не производится (но может производиться какая-то другая). При вызове call трассируется сообщение
transition_start
, затем трассируются значения итерационных переменных, затем выполняется собственно вызов, затем трассируется сообщениеtransition_end
. - Пересмотреть концепцию и реализацию
stable
переменных. - Возможно также, понадобятся некоторые языковые механизмы, аналогичные call-блоку, позволяющие выделять код, не являющийся выражениеем iterate, который также должен выполняться только при вызове next.
Updated by Sergey Groshev over 14 years ago · 5 revisions