Заметки об опыте перехода с Axapta 3.0 на AX 2009
Типы X++ date/utcDateTime НЕ преобразуются автоматически в System.DateTime в .NET CIL
Теги ax2012, cil, datetime, utcdatetime
Замечательная статья MSDN How to: Marshal Between X++ and CLR Primitive Types [AX 2012] утверждает следующее:
Среди поддерживаемых значится преобразование date ↔ System.DateTime; на самом деле, в интерпретаторе X++, по крайней мере, в AX 2012 R2 и выше замечательно преобразуются и значения типов utcDateTime ↔ System.DateTime! Но рассмотрим такой пример кода:Всё хорошо, пока дело не доходит до выполнения в CIL - а тут нас поджидает System.NotSupportedException с сообщением вида
либо
если rvalue - типа utcDateTime. В чем же дело? А в том, что магия неявного преобразования типов работает только в интерпретаторе байт-кода X++, а в CIL все происходит иначе, поэтому если есть хотя бы нановероятность того, что подобный ваш код будет выполняться в CIL, всегда выполняйте явное преобразование типов вида:
Цитата:
In Microsoft Dynamics AX, the X++ language does implicit conversion or marshaling between several X++ primitive types and their counterpart types managed by the common language runtime (CLR). This means that the X++ assignment operator, the single equal sign (=), can be used between certain pairings of an X++ type with a .NET Framework CLR type.
X++:
System.Web.HttpCookie cookie = new System.Web.HttpCookie('test'); date dateVar = today() + 1; cookie.set_Expires(dateVar);
Цитата:
DateTimeConverter cannot convert from Microsoft.Dynamics.Ax.Xpp.AxShared.Date
Цитата:
DateTimeConverter cannot convert from Microsoft.Dynamics.Ax.Xpp.AxShared.utcdatetime
X++:
cookie.set_Expires(CLRInterop::getObjectForAnyType(dateVar));
Всего комментариев 3
Комментарии
-
Как раз в указанной статье есть Note: There is no implicit marshaling between the X++ utcdatetime and .NET Framework System.DateTime type. For more information about how to convert between utcdatetime and System.DateTime, see How to: Convert Between utcdatetime and System.DateTime.
А уже по ссылке упомянуты два специальных метода в Global
И что самое интересное - похоже, что в каком-то из последних билдов R2 приведение типов пофиксили, и сейчас с этим нет проблем, по крайней мере, в билде 6.2.1000.9323.X++:Global::utcDateTime2SystemDateTime Global::CLRSystemDateTime2UtcDateTime
Запись от b_nosoff размещена 19.01.2015 в 12:52
Обновил(-а) b_nosoff 19.01.2015 в 13:23 -
Спасибо, я тоже читал примечание и ссылки на методы Global, но тут речь не об этом. В статье MSDN говорится, что есть автоматическое преобразование для типа date, но нет автоматического преобразования для utcDateTime. По факту же получается немного иначе: есть автоматическое преобразование и для date, и для utcDateTime (как минимум в R2) - но только при работе в интерпретаторе байт-кода X++, а при работе в CIL нет автоматического преобразования ни для date, ни для utcDateTime.
Запись от gl00mie размещена 19.01.2015 в 13:28 -
Запись от b_nosoff размещена 19.01.2015 в 14:26