Модераторы: feodorv, GremlinProg, xvr, Fixin
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> DbgPrint и va_start не могу адаптировать 
V
    Опции темы
12usver12
Дата 27.6.2010, 23:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



собсно есть такой код, вроде делал все как написано для этих макросов...
в итоге так и не получилось адаптировать
Код


// прототип из хидера oscalls.h    int DbgPrint(__in_z __format_string char *_Format, ...);

FARPROC adrDbgPrint = 0;
int DbgPrint_(char *_Format, ...)
{
    if (!adrDbgPrint) adrDbgPrint = GetProcAddress(GetModuleHandleW(L"ntdll.dll"),"DbgPrint");
    va_list args;
    va_start(args, _Format);
    int res = ((int (__stdcall*)(char*, ...)) adrDbgPrint)(_Format, args);
    /*
    __asm
    {
        push args
        push _Format
        call adrDbgPrint
    }
    */
    va_end(args);
    return res;
}


выводит в консоль неправильное значение , где же косяк ? 

Это сообщение отредактировал(а) 12usver12 - 27.6.2010, 23:50
PM MAIL   Вверх
586
Дата 28.6.2010, 00:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Судя по прототипу, DbgPrint требует передачи самих параметров, а не указателя va_list. А количество параметров не известно, и поэтому их не передать (либо вычислить количество параметров, пропарсив строку форматирования).
Если нужно замаскировать вызов GetProcAddress, то можно так написать:
Код
ULONG (__cdecl *DbgPrint_)(LPCSTR, ...) = (ULONG (__cdecl*)(LPCSTR, ...))
    GetProcAddress(GetModuleHandleW(L"ntdll.dll"),"DbgPrint");

int main()
{
    DbgPrint_("%u\n", 5555);
}


Это сообщение отредактировал(а) 586 - 28.6.2010, 00:51
PM   Вверх
12usver12
Дата 28.6.2010, 09:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



работает, получается каждый раз при вызове этой функи выполняется GetProcAddress(GetModuleHandleW(L"ntdll.dll"),"DbgPrint")  или оно только раз при инициализации выполняется ?
PM MAIL   Вверх
586
Дата 28.6.2010, 10:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Цитата(12usver12 @  28.6.2010,  10:05 Найти цитируемый пост)
работает, получается каждый раз при вызове этой функи выполняется GetProcAddress(GetModuleHandleW(L"ntdll.dll"),"DbgPrint")  или оно только раз при инициализации выполняется ? 

Один раз выполнится при инициализации. Только в конструкторах классов надо использовать этот указатель с осторожностью - указатель DbgPrint_ может быть ещё не инициализирован.

Кстати! Есть же ещё функция OutputDebugString:
Код
#include <windows.h>
#include <tchar.h>

#ifndef _ARRAYSIZE
# define _ARRAYSIZE(x) (sizeof(x)/sizeof(x[0]))
#endif

void vDebugPrintf(LPCTSTR lpFmt, va_list v)
{
    TCHAR buf[2048];
    _vsntprintf(buf, _ARRAYSIZE(buf), lpFmt, v);
    buf[_ARRAYSIZE(buf)-1] = _T('\0');
    OutputDebugString(buf);
}

void DebugPrintf(LPCTSTR lpFmt, ...)
{
    va_list v;
    va_start(v, lpFmt);
    vDebugPrintf(lpFmt, v);
    va_end(v);
}

int main()
{
    DebugPrintf(_T("%u\n"), 5555);
}

PM   Вверх
12usver12
Дата 28.6.2010, 11:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



ну да я тоже использовал подобную конструкцию, но проблема в том что нужно было выделять фиксированный буфер TCHAR buf[2048] , иногда это мешало, так как данные иногда были больше размера буфера, впринципе можно было динамически стек выделять, но не хотелось лепить велики, так как есть уже DbgPrint  
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Системное программирование и WinAPI"
Fixin
GremlinProg
xvr
feodorv
  • Большое количество информации и примеров с использованием функций WinAPI можно найти в MSDN
  • Описание сообщений, уведомлений и примеров с использованием компонент WinAPI (BUTTON, EDIT, STATIC, и т.п.), можно найти в MSDN Control Library
  • Непосредственно, перед созданием новой темы, проверьте заголовок и удостоверьтесь, что он отражает суть обсуждения.
  • После заполнения поля "Название темы", обратите внимание на наличие и содержание панели "А здесь смотрели?", возможно Ваш вопрос уже был решен.
  • Приводите часть кода, в которой предположительно находится проблема или ошибка.
  • Если указываете код, пользуйтесь тегами [code][/code], или их кнопочными аналогами.
  • Если вопрос решен, воспользуйтесь соответствующей ссылкой, расположенной напротив названия темы.
  • Один топик - один вопрос!
  • Перед тем как создать тему - прочтите это .

На данный раздел распространяются Правила форума и Правила раздела С++:Общие вопросы .


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Chipset, Step, Fixin, GremlinProg, xvr. feodorv.

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


 




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


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

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