Показать сообщение отдельно
Старый 07.05.2021, 09:05   #7  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
Цитата:
Сообщение от fed Посмотреть сообщение
А то я вот совсем не понимаю, ЗАЧЕМ было делать такую мелкогранулированную систему, а потом ее же наглухо закрывать от расширений...
Понятно зачем закрывают для расширений - чтобы не поддерживать точки расширения которые могут быть никому не нужны. Если все-таки нужны, есть возможность сделать extensibility request.

Вот, например, сделали вы метод

X++:
public void test(str _arg)
И хочется добавить параметр:
  • добавить обязательный параметр - breaking change (может быть вызов из расширения)
  • добавить необязательный параметр - breaking change (может быть обернут расширением)
  • добавить новый метод с дополнительным параметром можно, но прекратить вызывать старый метод - breaking change (на вызов может быть подписано расширение, котрое перестанет работать)
  • можно использовать disposable context, это приемлемо, но ломает рекурсию.

Решения:
  • Hookable(false) - если надо чтобы можно было подписаться на метод, то сделать отдельное событие (это не блокирует создание нового метода, вызывающеего то же событие)
  • Передавать аргументы при помощи класса (как в дотнете события сделаны XXXEventArgs) - добавление свойства в класс это не breaking change
  • Продумывать для каких сценариев нужны расширения, а для каких нет

Последний раз редактировалось belugin; 07.05.2021 в 09:15.