Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: 1 [2]  Все   Вниз
  Печать  
Автор Тема: интеграция с 1С (создание COM компонента)  (Прочитано 47681 раз)
0 Пользователей и 7 Гостей смотрят эту тему.
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #30 : 02-08-2011 18:09 » new

Леш, речь по прежнему о DLL, реализующей COM-интерфейс?
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #31 : 02-08-2011 18:17 » 

да
Записан

RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #32 : 02-08-2011 18:53 » 

Чтобы не путаться я процитирую все свою мысленную цепочку.

При регистрации происходит запуск DLL и вызов некой функции в ней (см. MSDN). Соотв., срабатывают зависимости и прочее.

Я в курсе - вызывается DllRegisterServer

Интересно, возможно ли как-то узнать, как "запустили приложение" - штатно, или только для регистрации DLL ?

Вызов DllRegisterServer разве не информативно?

не понимаю вопроса

Леш, речь по прежнему о DLL, реализующей COM-интерфейс?

да

Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #33 : 02-08-2011 19:01 » 

так
Записан

Kivals
Команда клуба

ca
Offline Offline
Пол: Мужской

WWW
« Ответ #34 : 02-08-2011 19:17 » 

Если я правильно понимаю - у тебя есть 2 точки входа: main() (или как там она для WinAPI?) и DllRegisterServer(). Соответственно в какую функцию попал - так и запустили приложение. Рома пишет, что из названия функции DllRegisterServer понятно, что она вызывается, когда запустили для регистрации (по логике из других мест эта функция вызываться не должна)
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #35 : 02-08-2011 20:14 » 

Kivals, WinMain . Но она в каркасе, я этот код не создаю и вообще не трогаю. Я имею право редактировать только код проекта

DllRegisterServer - да, доступна. Но что всё это даёт в данной ситауции ?

Поставил в этой функции мессадж бокс - затыкание происходит до входа в неё. Объект то глобальный (тот, что произведён от CWinApp). Нужно как-то до вызова InitInstance взвести какой-нибудь флажок внутри глобальной переменной. Откуда это можно сделать - не могу придумать...

Добавлено через 5 минут и 38 секунд:
как вариант -  сравнить путь к модулю с путём к DLL , но это не сработает для случая, когда вызывающий модуль будет лежать в одной папке с DLL
« Последнее редактирование: 02-08-2011 20:20 от Алексей1153 » Записан

Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #36 : 02-08-2011 20:35 » 

стек вызовов до нужного места огорчает Жаль

(click to show)

Добавлено через 11 минут и 7 секунд:
кстати, забыл уточнить, что затык происходит не только при регистрации, но и в момент создания объекта в экселе

* stk.PNG (21.43 Кб - загружено 1522 раз.)
« Последнее редактирование: 02-08-2011 21:21 от Алексей1153++ » Записан

RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #37 : 02-08-2011 20:55 » 

Леш, вот такая мысль возникла: а если сделать двухуровневую библиотеку? Первый уровень - COM без MFC с реализацией обертки всего интерфейса и управляющих функций, а саму реализацию с MFC вынести во вторую библиотеку и вызывать из первой вторую?
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #38 : 02-08-2011 21:21 » 

Ром, это ж переделывать много, а потом отлаживать. И неправильно всё это в корне, ведь хочется добиться идеала: есть проект на MFC , лёгким движением молнии визарда+немного кода = превращаем его в COM

Тут вот внезапно конкретный виновник торжества выявился. В theApp (глобальной переменной) , в InitInstance создаётся диалог, далее его мемберы, среди которых ОПЯТЬ ЭТОТ  CWinThread , а поток я создаю CREATE_SUSPENDED. Прослеживаем по стеку вызовов (а сам объект COM только что создался в экселе )

(click to show)

и во всём виноват (непонятно , каким образом!!! ) ждущий WaitForSingleObject . Вопрос: почему , если это просто EXE , то данный момент не приводит к замиранию всей программы, а в случае с объектом COM - затыкается ?

То ли я устал на сегодня... Пока не могу сообразить )))

* stk2.PNG (31.69 Кб - загружено 1289 раз.)
« Последнее редактирование: 02-08-2011 21:23 от Алексей1153++ » Записан

Вад
Модератор

ru
Offline Offline
Пол: Мужской

« Ответ #39 : 02-08-2011 21:52 » 

Алексей1153++, а что за startup.hEvent, которого ждёшь? Дело ведь, значит, не в Wait-е, а в Event-е, который не зажигается.
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #40 : 03-08-2011 03:38 » 

Вад, файл, где этот код находится, это не мой файл, он из состава MFC
Записан

Страниц: 1 [2]  Все   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines