Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как отловить qDebug??? 
:(
    Опции темы
Racot
Дата 27.2.2012, 21:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 63
Регистрация: 11.10.2011

Репутация: нет
Всего: нет



При работе в QtCreator в "вывод приложения" выводится разная отладочная инфа (я так полагаю с помощью qDebug) типа:

QIODevice::read: Called with maxSize < 0
или
libpng warning: Interlace handling should be turned on when using png_read_image
(последнее я так и не понял)

на работу приложения никак не влияет.....но уже напрягает когда выводится десятками.
Можно ли их как-нибудь отловить при выводе?....точку останова поставить или ещё как?
PM MAIL   Вверх
_GRIN_
Дата 28.2.2012, 11:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


одинокий падаван
**


Профиль
Группа: Участник
Сообщений: 272
Регистрация: 18.11.2007
Где: Калуга

Репутация: 6
Всего: 7



Racot, делаешь свою функцию вывода для qDebug(), qWarning() ... и регистрируешь её.
http://developer.qt.nokia.com/doc/qt-4.8/q...stallMsgHandler

В ней ставишь брэкпоинты и ловишь.
Цитата(Racot @  27.2.2012,  19:27 Найти цитируемый пост)
QIODevice::read: Called with maxSize < 0
или
libpng warning: Interlace handling should be turned on when using png_read_image
(последнее я так и не понял)

Ну QIODevice::read тебя может в исходники qt и выведет, а вот libpng - это уж друга либа об ошибках сигнализирует. Ты лучше в сообщения вчитайся, которые в лог выводятся =)


--------------------
Дорогу осилит идущий
PM MAIL Skype   Вверх
math64
Дата 28.2.2012, 14:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 23
Всего: 72



Вот так, например, можно перенаправить вывод сообщений в файл:
Код

oldHandler = qInstallMsgHandler(msgHandler);

void msgHandler(QtMsgType msg, const char *buf)
{
    if (!logFile.isOpen())
        logFile.open(QFile::Append);
    logFile.write(buf);
    logFile.write("\n");
    logFile.close();
    if (oldHandler)
        oldHandler(msg, buf); // Вызов обработчика по умолчанию (Windows)
    else { // Печать в stderr (Linux)
        fprintf(stderr, "%s\n", buf);
        fflush(stderr);
    }
}

PM   Вверх
borisbn
Дата 28.2.2012, 14:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 4875
Регистрация: 6.2.2010
Где: Ростов-на-Дону

Репутация: 48
Всего: 135



вау. хорошая функция. а то, что 
Цитата(_GRIN_ @  28.2.2012,  11:38 Найти цитируемый пост)
Ну QIODevice::read тебя может в исходники qt и выведет, а вот libpng - это уж друга либа об ошибках сигнализирует

дык по стеку можно вернуться и внимательно проанализировать, что ты там подаёшь в стандартные ф-ции


--------------------
Женщины отличаются от программистов тем, что у них чары состоят из стрингов
PM MAIL Jabber   Вверх
math64
Дата 28.2.2012, 15:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 23
Всего: 72



Цитата(borisbn @  28.2.2012,  14:32 Найти цитируемый пост)
вау. хорошая функция

вот ещё одна:
Код

QDebug qDebugTime()
{
    QByteArray ba = QTime::currentTime().toString("hh:mm:ss.zzz").toLocal8Bit();
    return qDebug() << ba.data();
}


PM   Вверх
Racot
Дата 28.2.2012, 18:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 63
Регистрация: 11.10.2011

Репутация: нет
Всего: нет



Спасибо!!!всё доходчиво объяснили)))) smile 
PM MAIL   Вверх
borisbn
Дата 28.2.2012, 22:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 4875
Регистрация: 6.2.2010
Где: Ростов-на-Дону

Репутация: 48
Всего: 135



Цитата(math64 @  28.2.2012,  15:04 Найти цитируемый пост)
вот ещё одна:

ну... такого добра у меня у самого много)) я про qInstallMsgHandler говорил. просто не знал про неё


--------------------
Женщины отличаются от программистов тем, что у них чары состоят из стрингов
PM MAIL Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С/С++: Кроссплатформенное программирование, QT/Gtk+/wxWidgets"
JackYF
Любитель
  • В заголовке темы в квадратных скобках обозначьте используемую вами библиотеку, например: [QT],[GTK],[wx].
  • Если вопрос актуален только для некоторой версии библиотеки, либо, если вы пользуетесь не самой последней версией, укажите это. Например: [QT4], [GTK2].
  • Все начинающие изучать Qt - не забудьте зайти сюда.
  • Проставьте несколько ключевых слов темы, чтобы её можно было легче найти.
  • В вопросе укажите полную версию версию библиотеки, а также все дополнительные используемые программные пакеты.
  • Не забывайте пользоваться кнопкой "Код".
  • Телепатов на форуме нет! Задавайте чёткий, конкретный и полный вопрос. Указывайте полностью ошибки компилятора и компоновщика.
  • Новое сообщение должно иметь прямое отношение к тематике этого раздела. Флуд, флейм, оффтопик запрещены.
  • Категорически запрещается обсуждение вареза, "кряков", взлома программ и т.д.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, Любитель.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | С/С++: Кроссплатформенное программирование, Qt/Gtk+/wxWidgets | Следующая тема »


 




[ Время генерации скрипта: 0.1157 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.