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

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

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


« : 28-01-2004 23:35 » 

При создании MFC Extension DLL (не Regular) даже если выставить везде в опциях проекта Use MFC as Static Library - MFC все равно компилиться динамически. Можете проверить (у меня даже пустой (созданный мастером и выставленной опцией) проект такой dll компилит их динамически).
 В принципе для подобных dll везде написано, что ее клиент обязан быть приложением MFC. Я так понимаю что эта фраза и означает вышесформулированную траблу.

 Вопрос: прав ли я?
 И если не прав - то как обойти проблему и закинуть MFC статически в длл эту.
Записан

Сила ночи, сила дня - одинакого фигня....
Джон
просто
Администратор

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

« Ответ #1 : 29-01-2004 08:26 » 

Хм... а как ты определяешь зависимость от MFC?
На 7.1 (.NET 2003) это работает. Regular DLL with MFC statically linked даёт ДЛЛ которая не зависит от MFC.
Записан

Я вам что? Дурак? По выходным и праздникам на работе работать. По выходным и праздникам я работаю дома.
"Just because the language allows you to do something does not mean that it’s the correct thing to do." Trey Nash
"Physics is like sex: sure, it may give some practical results, but that's not why we do it." Richard P. Feynman
"All science is either physics or stamp collecting." Ernest Rutherford
"Wer will, findet Wege, wer nicht will, findet Gründe."
ChaoticCube
ChaoticCube
Помогающий

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


« Ответ #2 : 29-01-2004 11:00 » 

Определяю depends.exe - вижу их просто.

 Потом - я не про Regular DLL, я про MFC Extension DLL.

 В Regular - действительно все хорошо.
Записан

Сила ночи, сила дня - одинакого фигня....
Джон
просто
Администратор

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

« Ответ #3 : 29-01-2004 13:08 » 

Аaaa... нет не получится на то оно и расширение, вот что MSDN говорит:

MFC extension DLL
Select this option if you want your program to make calls to the MFC library at run time, and if you want to share MFC objects between your DLL and the calling application. This option reduces the disk and memory requirements of your program, if it is composed of multiple executable files that all use the MFC library. Only MFC programs can call functions in your DLL. You must redistribute the MFC DLL with this type of project.

так что ...  она по определению динамическая

А в чём проблема то? Почему Regular не подходит? Это ведь как раз то что ты хочешь, насколько я понял. Те DLL c MFC классами и ничего в придачу.
Записан

Я вам что? Дурак? По выходным и праздникам на работе работать. По выходным и праздникам я работаю дома.
"Just because the language allows you to do something does not mean that it’s the correct thing to do." Trey Nash
"Physics is like sex: sure, it may give some practical results, but that's not why we do it." Richard P. Feynman
"All science is either physics or stamp collecting." Ernest Rutherford
"Wer will, findet Wege, wer nicht will, findet Gründe."
ChaoticCube
ChaoticCube
Помогающий

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


« Ответ #4 : 29-01-2004 20:39 » 

Я хочу класс перегруженный от MFC экспортить.

типа class SListCtrl: CListCtrl

И по необходимости у юзера support делать. Это возможно хоть как-то?
Записан

Сила ночи, сила дня - одинакого фигня....
Джон
просто
Администратор

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

« Ответ #5 : 30-01-2004 10:48 » 

Конечно возможно, библиотеки расширения MFC для этого и предназначены. Простейший пример тому сама MFC.  Ага

Я кажется понял, в чём твоя проблема. Ты думал, наверное, что только MFC extension DLL является MFC библиотекой? По идее они все такие. Разница в след.

Одна (Regular statically linked) использует MFC статически, и поэтому не требует её после компиляции и может быть использована как с MFC так и SDK ЕХЕшниками.

Две другие требуют наличия MFC на целевом компе, но одна (Regular shared MFC ) использует её только для себя, поэтоому тоже может быть использована как с MFC так и SDK ЕХЕшниками , а другая (extension) использует её совместно с ЕХЕ и может быть использована ТОЛЬКО с MFC ЕХЕшниками.

"ЕХЕшники" не совсем корректно, тк это могут быть и другие ДЛЛ, но для упрощения я думаю понятно.

А экспортировать MFC классы из ДЛЛ можно, точно так же как и простые классы:

Например для твоего примера:

   #ifdef _MYMFCCLASSDLL_
      #define MYMFCCLASSDLLEXPORT  _declspec(dllexport)
   #else
      #define MYMFCCLASSDLLEXPORT  _declspec(dllimport)
   #endif

class MYMFCCLASSDLLEXPORT CMyListCltrl : public CListCtrl
{
...
}
Записан

Я вам что? Дурак? По выходным и праздникам на работе работать. По выходным и праздникам я работаю дома.
"Just because the language allows you to do something does not mean that it’s the correct thing to do." Trey Nash
"Physics is like sex: sure, it may give some practical results, but that's not why we do it." Richard P. Feynman
"All science is either physics or stamp collecting." Ernest Rutherford
"Wer will, findet Wege, wer nicht will, findet Gründe."
ChaoticCube
ChaoticCube
Помогающий

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


« Ответ #6 : 31-01-2004 00:12 » 

Как экспортить классы мне понятно.

Тока в случае с Regular библиотеками и перегрузкой классов от CObject и ниже по иерархии MFC - выдает варнинг, что типа библиотека для этого не предназначена.

В случае с Ext, динамическая загрузка все равно есть. Вопрос - если у мя все dll MFC загружены в Exe статически, либа Ext, что не будет требовать длл MFC на диске?

Скажи какой проект мне делать, как я понял Ext(или ошибаюсь)?
Если делаю Ext и в Exe компилю статически длл MFC на винте у конечного юзверя нужны будут или нет?
Записан

Сила ночи, сила дня - одинакого фигня....
Джон
просто
Администратор

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

« Ответ #7 : 01-02-2004 12:28 » 

ChaoticCube,  Что ты хочешь в конечном итоге получить?

ЕХЕ + ДЛЛ без MFC на целевом компе (ессно, что она тебе нужна в процессе сборки). Подгружается-ли она динамически?
только ЕХЕ (с или без MFC), но в процессе сборки тебе нужна ДЛЛ с MFC классами
и тд Потому, что от этого зависит, что и как тебе надо выбрать.

Собственно все варианты уже перебраны в описании типов ДЛЛ.

На твой последний вопрос ответ - да, нужна MFC. И Regular shared и ЕХТ требуют MFC.

Может тебе LIB нужен для сборки?
Записан

Я вам что? Дурак? По выходным и праздникам на работе работать. По выходным и праздникам я работаю дома.
"Just because the language allows you to do something does not mean that it’s the correct thing to do." Trey Nash
"Physics is like sex: sure, it may give some practical results, but that's not why we do it." Richard P. Feynman
"All science is either physics or stamp collecting." Ernest Rutherford
"Wer will, findet Wege, wer nicht will, findet Gründe."
ChaoticCube
ChaoticCube
Помогающий

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


« Ответ #8 : 01-02-2004 18:43 » 

На компе юзверя мне не нужны MFC ДЛЛ. Понятно что во время сборки они мне нужны.

Пусть мой класс перегруженной кнопки к примеру находиться в 1.dll (MFC Ext With Static MFC)

1.exe - файл с прогой (Static MFC) Собираю через 1.lib файл.

На компе конечного юзверя я хочу что б было файло: 1.exe и 1.dll (для облегчения support).

Так вот 1.dll в любом случае грузит MFC динамически (проверено depends.exe)
Если я загружу в exe весь MFC статически при подобной сборке на целевом компе я добьюсь желаимого или нет, вот в чем вопрос.
Записан

Сила ночи, сила дня - одинакого фигня....
Джон
просто
Администратор

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

« Ответ #9 : 03-02-2004 15:13 » 

Сорри за задержку.

Хм... не думаю чтобы это прокатило. Ведь если ты ехпортируешь классы, то при любом изменении ДЛЛ тебе надо будет перекомпилировать и ЕХЕ тоже. Те тебе придётся полный комплект поставлять, а не просто одну ДЛЛ. Жаль

Это "вечная" проблемма ДЛЛ. Это кстати и привело к созданию СОМ объектов (ActiveX, ATL). Те экспортируются тн "интерфейсные" - нейтральные классы. Хотя я уехал от темы.

В общем я думаю что ты не сможешь так сделать, как задумал (если я тебя правильно понял):

Даже не знаю, что посоветовать... Если с ходу, то:

1. Ты можешь для облегчения сборки создать статическая библиотеку (LIB) c поддержкой MFC, тогда ЕХЕ можно сделать MFC независимым

2. Использовать "интерфейсный" класс, который в свою очередь мспользует MFC объекты.

А какя вообще задача? в смысле - зачем надо динамически MFC классы подгружать?
Записан

Я вам что? Дурак? По выходным и праздникам на работе работать. По выходным и праздникам я работаю дома.
"Just because the language allows you to do something does not mean that it’s the correct thing to do." Trey Nash
"Physics is like sex: sure, it may give some practical results, but that's not why we do it." Richard P. Feynman
"All science is either physics or stamp collecting." Ernest Rutherford
"Wer will, findet Wege, wer nicht will, findet Gründe."
ChaoticCube
ChaoticCube
Помогающий

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


« Ответ #10 : 03-02-2004 16:19 » new

Понял. Спасибо.

Задача - просто хочется весь GUI интерфейс раскидать по dll. Зачем - понятно.

Так вот - пусть сущ. 10 диалогов каждый в своей длл. В 1-ом, 2 и 3 - используются элементы пускай перегруженной кнопки к примеру. Хотелось сделать так что б кнопка лежала отдельно и эти диалоги ее загружали бы.

Другими словами что б в код 1-ой, 2-ой и 3-ей длл не входила кнопка эта, а лежала бы отдельно.

Понял - нельзя. Буду включать статически.

Еще раз спасибо.
Записан

Сила ночи, сила дня - одинакого фигня....
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines