Coder Social home page Coder Social logo

Добавить директиву компиляции для защиты от бесконечной рекурсии about onescript HOT 12 OPEN

tormozit avatar tormozit commented on September 28, 2024
Добавить директиву компиляции для защиты от бесконечной рекурсии

from onescript.

Comments (12)

nixel2007 avatar nixel2007 commented on September 28, 2024 1

Максимальную глубину стека можно ограничить средствами встроенного языка, добавив в функцию параметр-счётчик.

from onescript.

EvilBeaver avatar EvilBeaver commented on September 28, 2024

Не очень понял, как именно должна выглядеть такая директива компиляции и как она будет определять, что рекурсия - бесконечная?

from onescript.

tormozit avatar tormozit commented on September 28, 2024

Я не прошу определять что рекурсия бесконечная, на стороне движка. Я прошу добавить любое средство которое поможет программисту это выявлять. В платформе 1С в серверном интерпретаторе реализован выброс исключения при превышении пороговой (ненастраиваемой) глубины стека с выводом фрагмента стека, по которому легко выявить цикл стека.
Хотелось бы тут аналогичное удобство. Но важный момент - у меня был тяжелый (без возможности отладки) случай медленной рекурсии. Поэтому до 1000 глубина стека врядли бы дошла за разумное время. Поэтому мне нужно ручное управление порогом.

from onescript.

nixel2007 avatar nixel2007 commented on September 28, 2024

Так и в оскрипте реализован выброс исключения при превышении стека, разве нет? Не понимаю, причём тут сравнение с платформой, если твоя проблема в том, что у тебя была медленная функция, которая не дошла до пределов стека.

Ты просто просишь добавить возможность управления допустимой глубиной стека, без привязки к материнской платформе.

from onescript.

EvilBeaver avatar EvilBeaver commented on September 28, 2024

Поэтому до 1000 глубина стека врядли бы дошла за разумное время. Поэтому мне нужно ручное управление порогом.

т.е. ты хочешь что-то типа

&КонтрольРекурсии(4)
Процедура Рекурсивная()
    Рекурсивная();
КонецПроцедуры

и чтобы на 4 вызове она выдала некое исключение?

from onescript.

tormozit avatar tormozit commented on September 28, 2024

чтобы на 4 вызове она выдала некое исключение?

Да. Только я не знаю какие методы образуют цикл вызовов. Поэтому директива компиляции нужна для модуля, а не метода.

from onescript.

tormozit avatar tormozit commented on September 28, 2024

Пример исключения в платформе 1С

Переполнение стека встроенного языка на сервере
по причине:

Справочник.ОбработчикиОбъектов.Форма.ФормаСписка.Форма : 13 : СлужебныйМодуль.ФормаСпискаПриСозданииНаСервере(ЭтотОбъект, Отказ, СтандартнаяОбработка);
ОбщийМодуль.СлужебныйМодуль.Модуль : 2606 : ПодключаемыеКоманды.ПриСозданииНаСервере(Форма);
ОбщийМодуль.ПодключаемыеКоманды.Модуль : 88 : КэшФормы = ПодключаемыеКомандыПовтИсп.КэшФормы(ИмяФормы, ИсточникиЧерезЗапятую, ЭтоФормаОбъекта);
ОбщийМодуль.ПодключаемыеКомандыПовтИсп.Модуль : 12 : Возврат Новый ФиксированнаяСтруктура(ПодключаемыеКоманды.КэшФормы(ИмяФормы, ИсточникиЧерезЗапятую, ЭтоФормаОбъекта));
...
ОбщийМодуль.ОбщегоНазначения.Модуль : 3830 : Возврат Справочники.ИдентификаторыОбъектовМетаданных.ИдентификаторОбъектаМетаданных(
Справочник.ИдентификаторыОбъектовМетаданных.МодульМенеджера : 644 : Идентификаторы = ИдентификаторыОбъектовМетаданных(Массив, ВызыватьИсключение, Истина);
Справочник.ИдентификаторыОбъектовМетаданных.МодульМенеджера : 659 : ИдентификаторыПоПолнымИменам = КэшИдентификаторов().ИдентификаторыПоПолнымИменам;
Справочник.ИдентификаторыОбъектовМетаданных.МодульМенеджера : 0
по причине:
Переполнение стека встроенного языка на сервере

from onescript.

nixel2007 avatar nixel2007 commented on September 28, 2024

@EvilBeaver предлагаешь использовать декоратор?)

from onescript.

EvilBeaver avatar EvilBeaver commented on September 28, 2024

@EvilBeaver предлагаешь использовать декоратор?)

Нет, не предлагаю. Не уверен что он поможет. У тебя же цепочка рекурсии необязательно А->А, может быть А->Б->В->А

from onescript.

nixel2007 avatar nixel2007 commented on September 28, 2024

Сяетчиу на уровне класса ничего не мешает сделать же

from onescript.

EvilBeaver avatar EvilBeaver commented on September 28, 2024

Сяетчиу на уровне класса ничего не мешает сделать же

на уровне класса Коллстек?

from onescript.

nixel2007 avatar nixel2007 commented on September 28, 2024

Нет, прям на уровне декоратора. В нем можно добавить поле и добавить перехватчик на вызываемый метод, который будет счётчик инкрементировать, проверять на переполнение и кидать исключение.

from onescript.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.