AXForum  
Zurück   AXForum > Microsoft Dynamics AX > DAX Blogs
All
Kennwort vergessen?
Registrieren Forum Rules Hilfe Benutzerliste Heutige Beiträge Suchen

 
 
Themen-Optionen Thema durchsuchen Ansicht
Alt 10.10.2017, 23:11   #1  
Blog bot ist offline
Blog bot
Участник
 
25.646 / 848 (80) +++++++
Registriert seit: 28.10.2006
mfp: Replaceable methods
Источник: https://blogs.msdn.microsoft.com/mfp...eable-methods/
==============
Chain of command enables wrapping of methods – but you must call next. This ensure the "chain" is not broken, and everyone wrapping the method will indeed be called. However, sometimes it makes sense to break the chain. Here are some examples where this could be useful: In lookup methods. The base implementation will open...

==============
Источник: https://blogs.msdn.microsoft.com/mfp...eable-methods/
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Alt 11.10.2017, 01:07   #2  
ax_mct ist offline
ax_mct
Banned
 
2.548 / 1091 (0) ++++++++
Registriert seit: 10.10.2005
Ort: Westlands
Эх Ваня, Ваня...


Zitat:
Chain of command enables wrapping of methods – but you must call next. This ensure the "chain" is not broken, and everyone wrapping the method will indeed be called.

However, sometimes it makes sense to break the chain. Here are some examples where this could be useful:

In lookup methods. The base implementation will open a lookup dialog, anyone wrapping will (likely) also open a dialog. Yet the user only expects one lookup.

In methods with complex SQL operations. As of now; there are select statements (including delete_from, update_recordset, insert_recordset) we cannot make extensible. One way to work around the limitation is to move the statement to a dedicated method, and make the method replaceable.

In conversion methods. Here you can conditionally call next, to skip the base conversion, if your logic can handle the conversion.

In Platform Update 11 – we can now decorate methods with the [Replaceable] attribute. This will relax the compiler, so it doesn't look for the next keyword. Logically, this means that when wrapping a Replaceable method, there is no guarantee that your logic will fire. Someone else might be replacing the method, and breaking the chain.

The author of the code is still in control of which methods are replaceable.

My dear "partner in crime" Vanya Kashperuk has written a great post about the new capability here: http://kashperuk.blogspot.dk/2017/10...ibility_7.html
Обратите внимание на рассматриваемые примеры. Как далек он (изобретатель то есть) от клиента.

Сижу я значит на клиенте пол-года-год и все это время лукапы отгружаю. Паллетами.
Alt 11.10.2017, 04:38   #3  
trud ist offline
trud
Участник
Лучший по профессии 2017
 
1.039 / 1635 (57) ++++++++
Registriert seit: 07.06.2003
Blog-Einträge: 1
ну т.е. по сути они изобрели заново слои. со всеми теми же проблемами, но без вообще хоть какого-то тулинга разрешения конфликтов и сравнения, без поддержки существования нескольких версий(в CoC методы вызываются рандомно, т.е. если вы один и тот же метод замените в USR и ISV никто не гарантирует что вызовется USR).
главное конечно чтоб не получилось как с windows phone
Zitat:
«Мы очень старались стимулировать разработчиков. Платили деньги… писали для них приложения…
Alt 11.10.2017, 08:58   #4  
belugin ist offline
belugin
Участник
Benutzerbild von belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4.622 / 2925 (107) +++++++++
Registriert seit: 16.01.2004
Blog-Einträge: 5
Zitat:
Zitat von trud Beitrag anzeigen
ну т.е. по сути они изобрели заново слои.
В слоях мы можем омерлеерить любой метод, а здесь - только такой как позволено.

По идее к этому должно прилагаться описание (например в XML документации), на что надеется вызывающий код (то есть контракт, который должны соблюдать расширения) и способ разрешения конфликтов между расширениями (вот
это нетривиально. Например не вызывать super можно только если есть уверенность что исходные данные сгенерированы расширением и больше никем).

Будут ли так делать или просто проставят атрибут в методах по требованию - посмотрим.
Alt 11.10.2017, 09:58   #5  
trud ist offline
trud
Участник
Лучший по профессии 2017
 
1.039 / 1635 (57) ++++++++
Registriert seit: 07.06.2003
Blog-Einträge: 1
Zitat:
Zitat von belugin Beitrag anzeigen
В слоях мы можем омерлеерить любой метод, а здесь - только такой как позволено.

По идее к этому должно прилагаться описание (например в XML документации), на что надеется вызывающий код
Не понял идею с документацией. ну т.е. если смотреть его примеры - типичная задача - добавить в insert_recordset доп. поле.
Alt 11.10.2017, 10:03   #6  
belugin ist offline
belugin
Участник
Benutzerbild von belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4.622 / 2925 (107) +++++++++
Registriert seit: 16.01.2004
Blog-Einträge: 5
Zitat:
Zitat von trud Beitrag anzeigen
Не понял идею с документацией. ну т.е. если смотреть его примеры - типичная задача - добавить в insert_recordset доп. поле.
Например в документации написать какой-нибудь признак, по которым разводить экстеншены с этими дополнительными полями (например генерация проводок для какого-то нового своего модуля). Либо в документации разрешить перекрывать только клиентам (которым не надо ни с кем сливаться).
Alt 11.10.2017, 10:05   #7  
kashperuk ist offline
kashperuk
Участник
Benutzerbild von kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4.361 / 2084 (78) +++++++++
Registriert seit: 30.05.2004
Ort: Atlanta, GA, USA
Zitat:
Zitat von belugin Beitrag anzeigen
В слоях мы можем омерлеерить любой метод, а здесь - только такой как позволено.

По идее к этому должно прилагаться описание (например в XML документации), на что надеется вызывающий код (то есть контракт, который должны соблюдать расширения) и способ разрешения конфликтов между расширениями (вот
это нетривиально. Например не вызывать super можно только если есть уверенность что исходные данные сгенерированы расширением и больше никем).

Будут ли так делать или просто проставят атрибут в методах по требованию - посмотрим.
Можешь привести пример, как ты видишь текст такой вот секции?
Отличался ли бы этот текст от метода к методу?
Alt 11.10.2017, 10:24   #8  
belugin ist offline
belugin
Участник
Benutzerbild von belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4.622 / 2925 (107) +++++++++
Registriert seit: 16.01.2004
Blog-Einträge: 5
Zitat:
Zitat von kashperuk Beitrag anzeigen
Можешь привести пример, как ты видишь текст такой вот секции?
Дупустим, у нас есть корреспонденция проводок реализованная на таких методах а не событиях.

"Расширение должно вызывать метод, кроме того, случая, когда в параметрах ГК установлено значения признака SummarizationAlgorithm равного значению, которое добавлено компанией-автором расширения.

В этом случае, автор расширения должен суммировать проводки и запихать их во времменные таблицы такието"

Но на самом деле более очевидным было бы ввдедения интерфейса SummarizationAlgorithm и вызов его методов.

Zitat:
Отличался ли бы этот текст от метода к методу?
Да, потому, что нельзя придумать такой универсальный признак, по которому перекрывающие расширения гарантированно не пересекались.
Stichworte
chain of command

 

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Kashperuk Ivan: Development tutorial: Extensibility: Replaceable in Chain of Command methods Blog bot DAX Blogs 13 09.10.2017 14:45
mfp: What is new in X++ in AX7? Blog bot DAX Blogs 2 10.02.2016 00:29
mfp: X++ in AX7: Extension methods Blog bot DAX Blogs 10 17.12.2015 18:22
Kashperuk Ivan: Tutorial: Caching display methods Blog bot DAX Blogs 3 29.09.2015 22:07
axaptapedia: Table Methods Generator Blog bot DAX Blogs 0 13.02.2009 02:05

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Gehe zu

Рейтинг@Mail.ru
Alle Zeitangaben in WEZ +3. Es ist jetzt 04:10 Uhr.
Powered by vBulletin® Version 3.8.5 (Deutsch)
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.