Форум программистов, компьютерный форум CyberForum.ru

Магия при компиляции больших проектов - C++

Восстановить пароль Регистрация
 
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
08.03.2014, 22:41     Магия при компиляции больших проектов #1
Приветствую товарищи.
Пишу(сал) большой проект разбитый на несколько библиотек, консолей, windows приложений и т.к. И недавно с ним стала происходить какая-то магия. Всё началось с того, что нужно было добавить функцию GetText в Core-библиотеку и началась полная белеберда.
Появилось сообщения об ошибке, компилятор не может найти тип std::wostringstream. Хотя в ниже стоящей функции - всё нормально [как раз оттуда была скопирована проверка].
Листинг взят с одного фала.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
        std::string GetText(int length) {
            __int8* binaryData = new __int8[length + 1];
            DWORD cbRead;
            if (!ReadFile(this->PipeServer(), binaryData, length, &cbRead, NULL)){
                std::wostringstream ost; //Здесь ошибка C2079
                ost << GetLastError();
                EventLogManager::ErrorMessage(L"Произошла ошибка при получении сообщения\n" + ost.str());
                throw std::exception();
            }
            binaryData[length] = '\0';
            std::string resultString(binaryData);
            delete [] binaryData;
            return resultString;
        }
        template<class TypeDataQuery>
        TypeDataQuery GetData(){
            const size_t sizeData = sizeof(TypeDataQuery);
            __int8 binaryData[sizeData];
            DWORD cbRead;
            if (!ReadFile(this->PipeServer(), binaryData, sizeData, &cbRead, NULL)){
                std::wostringstream ost; //А здесь ошибки нет
                ost << GetLastError();
                EventLogManager::ErrorMessage(L"Произошла ошибка при получении сообщения\n" + ost.str());
                throw std::exception();
            }
            return *((TypeDataQuery*) &binaryData);
        }
Если закомментировать строки
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
std::string GetText(int length) {
            __int8* binaryData = new __int8[length + 1];
            DWORD cbRead;
            if (!ReadFile(this->PipeServer(), binaryData, length, &cbRead, NULL)){
//              std::wostringstream ost; //Здесь ошибка C2079
//              ost << GetLastError();
//              EventLogManager::ErrorMessage(L"Произошла ошибка при получении сообщения\n" + ost.str());
//              throw std::exception();
            }
            binaryData[length] = '\0';
            std::string resultString(binaryData);
            delete [] binaryData;
            return resultString;
        }
Код скомпилируется, но после запуска выдается следующая ошибка.
A copy of communicationbase.h was not fond in "d:\programs C++\MyProgpam\Core\communicationbase.h", but the current source code is different from the version built into "d:\programs C++\MyProgpam\Core\communicationbase.h".

В общем, я измучился понимая причину всего этого. Есть хоть у кого-то идеи как всё это исправить?
Компилятор Visual Studio 2013 Professional Update 1
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Worf
42 / 42 / 6
Регистрация: 06.02.2014
Сообщений: 227
08.03.2014, 22:55     Магия при компиляции больших проектов #2
Возможно, он ссылается на какую-то функицию или что-то подобное, что вы из библиотеки не стянули
Хотя, вам же в ошибке ответ Google переводчик:
"Копия communicationbase.h не любил в "D: \ программы C + + \ MyProgpam \ Ядро \ communicationbase.h", но в настоящее время исходный код отличается от версии, встроенного в "D: \ программы C + + \ MyProgpam \ Ядро \ communicationbase . ч "

Добавлено через 4 минуты
А более понятно "копирование из communicationbase.h не поддерживается, но код отличается от того, что был в communicationbase.h"
Как я понимаю, на что-то он, всё такие, пытается сослаться или вызвать
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
08.03.2014, 22:55  [ТС]     Магия при компиляции больших проектов #3
Цитата Сообщение от Worf Посмотреть сообщение
Возможно, он ссылается на какую-то функицию или что-то подобное, что вы из библиотеки не стянули
Библиотеки все мною писаны, как собственно и файл communicationbase.h.
А, если Вы имели ввиду std::wostringstream, то я не понимаю, почему на 10 строчек ниже он прекрасно отрабатывает.
Worf
42 / 42 / 6
Регистрация: 06.02.2014
Сообщений: 227
08.03.2014, 22:58     Магия при компиляции больших проектов #4
А если попробовать в режиме ручного прогона программы посмотреть, на какой именно строке начинаются проблемы?
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
08.03.2014, 23:05  [ТС]     Магия при компиляции больших проектов #5
Первую проблему решил.
Просто добавив подключение библиотеки.
#include <sstream>
По ходу где-то в при компилировании функций GetData они поключалась. Хотя я пока не понял где.
Но вторая проблема с "неверной библиотекой осталась.
Worf
42 / 42 / 6
Регистрация: 06.02.2014
Сообщений: 227
08.03.2014, 23:07     Магия при компиляции больших проектов #6
А на какой строке вылазит ошибка?
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
08.03.2014, 23:10  [ТС]     Магия при компиляции больших проектов #7
Цитата Сообщение от Worf Посмотреть сообщение
А если попробовать в режиме ручного прогона программы посмотреть, на какой именно строке начинаются проблемы?
Не всё так гладко в Датском королевстве. Если не ставить брекпоинт в функции "GetText", то окошко с надписью:
A copy of communicationbase.h was not fond in "d:\programs C++\MyProgpam\Core\communicationbase.h", but the current source code is different from the version built into "d:\programs C++\MyProgpam\Core\communicationbase.h.
Не выскакивает. А вот если поставить, то оно появляется сразу после запуска.
Библиотеки все статичные, то искать проблему динамике, особого смысла нет [как мне кажется]. Что-то надо где-то настроить в проекте.
Вот только где?
Worf
42 / 42 / 6
Регистрация: 06.02.2014
Сообщений: 227
08.03.2014, 23:14     Магия при компиляции больших проектов #8
У меня такое ощущение, что вы не подключили какие-то ещё библиотеки
DrOffset
6461 / 3835 / 886
Регистрация: 30.01.2014
Сообщений: 6,630
08.03.2014, 23:14     Магия при компиляции больших проектов #9
Russian_Dragon, возможно изменился заголовочный файл, который включается во многие модули, но перекомпилированы были не все такие модули. В таком случае нужно пересобрать все модули с изменениями, чтобы избежать нарушения ODR.
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
08.03.2014, 23:22  [ТС]     Магия при компиляции больших проектов #10
Цитата Сообщение от DrOffset Посмотреть сообщение
Russian_Dragon, возможно изменился заголовочный файл, который включается во многие модули, но перекомпилированы были не все такие модули. В таком случае нужно пересобрать все модули с изменениями, чтобы избежать нарушения ODR.
Так в Configuration Manager [ответственный за компиляцию] проставил везде галочки, что бы компилировалось всё. В настройках солюшена проставил зависимости проектов [причем это было сделано сразу и уже не раз перепроверено]. Отдельно пересобрал Core-библиотеку - толку ноль.
DrOffset
6461 / 3835 / 886
Регистрация: 30.01.2014
Сообщений: 6,630
08.03.2014, 23:23     Магия при компиляции больших проектов #11
Russian_Dragon, пересобери все. полностью. с зачисткой. потом отпишись о результатах.
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
08.03.2014, 23:32  [ТС]     Магия при компиляции больших проектов #12
На самом деле недели три назад я нашел какое-то кривое решение. Которое было примерно таким:
1) я правлю код в приложении который использует библиотеку [убрав любую строчку]
2) компилю
3) возвращаю код на место
4) запускаю
Вроде как-то так. Но мало того, что я сейчас не помню как я это тогда делал, так еще мне кривизна решения убивает, т.к. нужно было делать каждый раз когда я вношу изменения в Core-библиотеку.

Добавлено через 4 минуты
Цитата Сообщение от DrOffset Посмотреть сообщение
Russian_Dragon, пересобери все. полностью. с зачисткой. потом отпишись о результатах.
Полная очистка солюшена и его пересборка помогла на этот раз. Но если исправить строчку в коде - ошибка возвращается.
DrOffset
6461 / 3835 / 886
Регистрация: 30.01.2014
Сообщений: 6,630
08.03.2014, 23:47     Магия при компиляции больших проектов #13
Russian_Dragon, Надо избегать сильных связей. И если библиотека используется много где, то общие, разделяемые части нужно делать как можно реже изменяемыми. Иначе только полная пересборка. С нарушением ODR всегда так.
Russian_Dragon
 Аватар для Russian_Dragon
10 / 11 / 0
Регистрация: 18.02.2012
Сообщений: 140
09.03.2014, 00:21  [ТС]     Магия при компиляции больших проектов #14
Цитата Сообщение от DrOffset Посмотреть сообщение
Russian_Dragon, Надо избегать сильных связей. И если библиотека используется много где, то общие, разделяемые части нужно делать как можно реже изменяемыми. Иначе только полная пересборка. С нарушением ODR всегда так.
Как-то плохо. В C# всё лучше с этим вопросом. Но спасибо.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.03.2014, 01:19     Магия при компиляции больших проектов
Еще ссылки по теме:

Отладка больших проектов. Какие приемы использовать C++
C++ Массивы, магия
C++ Магия OpenMP

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
DrOffset
6461 / 3835 / 886
Регистрация: 30.01.2014
Сообщений: 6,630
09.03.2014, 01:19     Магия при компиляции больших проектов #15
Russian_Dragon, C# сильно моложе. А С++ тащит за собой наследие С. Освежи в памяти что такое компиляция в С++ и С, какие этапы сборки программы, и поймешь причину этого (в любом случае это должен знать всякий С++ программист).
Yandex
Объявления
09.03.2014, 01:19     Магия при компиляции больших проектов
Ответ Создать тему
Опции темы

Текущее время: 17:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru