AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 22.03.2006, 13:22   #1  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
Объект, как параметр COM-метода
Добрый день, гуру.

Возможно ли возвращать объект, как параметр метода, через COM-коннектор?

Есть идея написать небольшую утилиту; причем логику хочется реализовать на X++, а интерфейс на С#. При таком подходе я не привязываюсь к структуре таблиц, которая может измениться при переходе на новую версию. Кроме того, в будущем я легко смогу сделать интерфейсную часть на web (например, Perl).

При проектировании этой утилиты возникла потребность в классе X++, который хранил бы коллекцию записей и реализовывал бы пару методов: int getRecordCount(), MyObject getMyObjectByNum(int _num). Соответсвенно возникает вопрос - смогу ли я дернуть второй метод (getMyObjectByNum через COM), получить на клиенте (С#) объект MyObject (по сути его реализация на X++) и поработать с его методами из С#-программы?

Заранее спасибо.
Старый 22.03.2006, 14:19   #2  
Jabberwocky is offline
Jabberwocky
Microsoft Dynamics
Аватар для Jabberwocky
Сотрудники Microsoft Dynamics
 
274 / 307 (11) ++++++
Регистрация: 02.09.2005
Адрес: Москва
Вот что об этом сказано в Писании:

The IAxaptaObject interface derives from IDispatch, and provides methods for calling methods of Microsoft Axapta objects.

The IAxaptaObject interface is a dual interface, and objects can be created using IAxapta::CreateObject or IAxapta::CreateObjectEx only.

И здесь же пример использования из приложения на VB:
Код:
Dim Axapta As Object
Dim MyObject As Object
Set Axapta = CreateObject("AxaptaCOMConnector.Axapta")

Axapta.Logon
‘ create an Axapta object
Set MyObject = Axapta.CreateObject("MyClass", "new parameter1", 2)
‘ we can now call methods of "MyObject" using its "Call" method
MyObject.Call "MyMethod", "parameter1", 2
Старый 22.03.2006, 14:26   #3  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
Спасибо.

Интересует возможность примерно следующего:

MyObject.Call "MyMethod", "parameter1", MyObject

То есть, маршалинг объектов между аксаптой и X++. Причем как X++ объектов, так и системных.
Старый 22.03.2006, 15:04   #4  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
не получится. с колбеками в аксапте туго
Старый 22.03.2006, 15:30   #5  
Jabberwocky is offline
Jabberwocky
Microsoft Dynamics
Аватар для Jabberwocky
Сотрудники Microsoft Dynamics
 
274 / 307 (11) ++++++
Регистрация: 02.09.2005
Адрес: Москва
Цитата:
Сообщение от belugin
не получится. с колбеками в аксапте туго
Не понял, а какое отношение маршалинг объектов имеет к понятию call-back?

Что касается передачи ссылки на объект X++ в модуль на C#, допустим, технически это возможно, но дальше-то что? Для модуля C# ссылка на объект X++ это ссылка на некую структуру в памяти, о которой C# не имеет ни малейшего представления и уж точно не сможет выполнить метод класса X++ самостоятельно. Выполнение метода класса X++ возможно только через Axapta COM Connector. Не совсем понятна постановка задачи...
Старый 22.03.2006, 15:47   #6  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
Цитата:
Для модуля C# ссылка на объект X++ это ссылка на некую структуру в памяти,
О, вот мы и подошли к сути дела.

Цитата:
о которой C# не имеет ни малейшего представления и уж точно не сможет выполнить метод класса X++ самостоятельно.
А вот в этом как раз мой вопрос. Сможет или не сможет. Если бы я писал COM объект на C++ я бы сделал MIDL файл и зарегистрировал мой MyObject в реестре как COM - объект.
Соответсвенно программа на C# зная идентификатор COM-объекта, смогла бы получить COM-интерфейс, который реализуется моим COM-объектом. Аксапта же не регистрирует в системе свои объекты, как COM-объекты.

Хотя я наверное COM совсем забыл
Старый 22.03.2006, 16:32   #7  
Jabberwocky is offline
Jabberwocky
Microsoft Dynamics
Аватар для Jabberwocky
Сотрудники Microsoft Dynamics
 
274 / 307 (11) ++++++
Регистрация: 02.09.2005
Адрес: Москва
Вот именно, объекты Аксапты не зарегистрированы в операционной системе как самостоятельные сущности. Они существуют только внутри Аксапты и могут вызываться только самой Аксаптой, т.к. скомпилированы не в универсальный managed code в терминах платформы .NET, а в некий псевдо- байт-код, выполнение которого возможно только ядром Аксапты.
Старый 22.03.2006, 16:43   #8  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
Цитата:
Вот именно, объекты Аксапты не зарегистрированы в операционной системе как самостоятельные сущности. Они существуют только внутри Аксапты и могут вызываться только самой Аксаптой
Угу. Спасибо за подтверждение.

Цитата:
т.к. скомпилированы не в универсальный managed code в терминах платформы .NET
В общем то, для COM и не требуется компиляция в managed code. Достаточно компиляции в исполнимый машинный код. Другое дело, что здесь мы и этого не наблюдаем. И похоже, что Com Connector не предоставляет такой возможности.
Старый 22.03.2006, 17:06   #9  
EVGL is offline
EVGL
Banned
Соотечественники
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
4,445 / 3001 (0) ++++++++++
Регистрация: 09.07.2002
Адрес: Parndorf, AT
А я бы решил эту задачу так: класс Аксапта getMyObjectByNum() возвращал бы строку - элемент XML, который разбирается Вашим внешним COM-компонентом. В этом случае вы не так зависите от структуры таблицы, можете добавлять и удалять поля из элемента.
За это сообщение автора поблагодарили: Андре (4).
Старый 22.03.2006, 17:12   #10  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
EVGL, спасибо.

В данной ситуации очень удачный вариант. Хотя я теряю возможность вызывать методы объекта (те самые callback вызовы, про которые писал belugin), я хотя бы могу получить набор сложно-структурированной информации.

Еще раз спасибо. Жаль только что сам до этого не дошел - похоже год работы консультантом дает о себе знать
Старый 22.03.2006, 18:21   #11  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
еще можно вести некий список созданных в C# объектов (можно использовать, например Scripting.Dictionary), который передавать в аксапту например, через Running Objects Table или сделать его Singleton'ом, запоминать там в SysGlobalCache

Перед тем как передавать объект в аксапту, запихивать в список на стороне C# после чего извлекать из списка на стороне Axapta и передавать в качестве параметра методу.

то есть будет что-то типа
Код:
Dim Axapta As Object
Dim MyObject As Object
Set Axapta = CreateObject("AxaptaCOMConnector.Axapta")
Dim myRegistry as new Registry

Axapta.Logon
‘ create an Axapta object

Dim secondObject as New MyClass
Dim index as Int
index=myRegistry.register(secondObject)

Dim secondObjectWrapper as Object
' вызвать статический метод для получения обертки объекта аксапты передав ему index в реестре объектов
secondObjectWrapper = Axapta.CallStaticMethon "Regiserty", index
‘ Передать обертку внктрь аксапты
MyObject.Call "MyMethod", "parameter1", secondObjectWrapper
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Ошибка при вызове COM-метода koraman DAX: Программирование 8 23.10.2014 09:57
танцы с бубном - COM Объект не имеет метода 'worksheets' Artem Mikhailov DAX: Программирование 4 05.02.2007 14:25
Как удалить COM объект? jon DAX: Программирование 8 11.09.2006 16:11
FormActiveXControl Объект не имеет метода Application() chi DAX: Программирование 10 22.12.2005 16:05
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 01:27.