MFC
2006.05.19 17:32

노트패드를 이용한 덤프

조회 수 34104 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print Files
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print Files
어딘가에서 노트패드를 이용한 덤프 방법이 있길래 살펴보았다가 하나 만들어 두는것도 괜찮다 싶어서 만들어 보았습니다.


기능
1. 노트패드가 실행되지 않았을 경우 노트패드를 실행시킨다.
2. 노트패드가 특정 파일을 열어놓은 상태에서도 출력이 원활하게 이루어지도록 한다.
3. 출력은 항상 제일 하단에 위치하도록 한다.


사용 방법
#include "http://pds5.devpia.com/vc_lec/8000/7241/DumpToNotePAD.h"


DumpToNotePAD("노트패드로 내용 출력중..");
DumpToNotePAD("[%s] %d, %.10lf, %s", sVal1, nVal, fVal, sVal2);
DumpToNotePAD("샘플 : %s", sVal);


되도록 MFC 클래스는 배제한 상태로 짰습니다. CPP의 내용은 다음과 같습니다.


#include "Tlhelp32.h"


static HWND hWndNotePad=NULL;


BOOL CALLBACK EnumWndProcForNotePAD(HWND hwnd, LPARAM lParam)
{
    DWORD processID;
    ::GetWindowThreadProcessId(hwnd, &processID);
    if (processID == (DWORD)lParam)
    {
        //동일한 프로세스 핸들.
        //프로세스 핸들이 일정한 상태에서 최상위 부모윈도우를 찾는다.
        HWND hParent = hwnd;
        do
        {
            hwnd = hParent;
            hParent = ::GetWindow(hParent, GW_OWNER);
            ::GetWindowThreadProcessId(hParent, &processID);
        } while (hParent && processID == (DWORD)lParam);
        if (::IsWindowVisible(hwnd))
        {
            //해당 윈도우가 사용가능한 윈도우인지 검사한다.
            hWndNotePad = hwnd;
            return FALSE; //작업을 종료한다.
        }
    }
    return TRUE;
}


void DumpToNotePAD(char *fmt, ...)
{
    char buffer[4096]={0};
    va_list argptr;
    va_start(argptr, fmt);
    vsprintf(buffer, fmt, argptr);
    va_end(argptr);
    strcat(buffer, "\r\n");


    //-------------------------------------------------------------------
    //NotePAD를 찾는다.
    for (int T=0; T<2; T++)
    {
        if (hWndNotePad == NULL || !IsWindow(hWndNotePad))
        {
            HANDLE hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPALL, 0);
            if (hSnapshot != (HANDLE)(-1))
            {
                //설정된 프로세스명을 가진 모든 프로세스ID를 획득한다.
                PROCESSENTRY32 Process;
                Process.dwSize = sizeof(PROCESSENTRY32);
                if (Process32First(hSnapshot, &Process))
                {
                    do
                    {
                        char handleName[512]={0};
                        strcpy(handleName, Process.szExeFile);
                        int len = strlen(handleName);
                        if (len > 1 && handleName[1] == ':') //전체 경로 포함
                        {
                            char drive[_MAX_DRIVE]={0};
                            char dir[_MAX_DIR]={0};
                            char fname[_MAX_FNAME]={0};
                            char ext[_MAX_EXT]={0};


                            _splitpath(handleName, drive, dir, fname, ext);
                            sprintf(handleName, "%s%s", fname, ext);
                        }
                        len = strlen(handleName);
                        //대문자로 변경
                        for (int i=0; i<len; i++)
                            *(handleName + i) = toupper(*(handleName+i));
                        //실행 프로세스 이미지명은 너무 길면 확장자 영역이 잘린다.
                        //따라서 첫부분이 일치하면 해당 프로세스를 찾은것으로 한다.
                        if (strstr(handleName, "NOTEPAD"))
                            ::EnumWindows(EnumWndProcForNotePAD, (LPARAM)Process.th32ProcessID);
                    } while (Process32Next(hSnapshot, &Process));
                }
                CloseHandle(hSnapshot);
            }
        }


        //NotePAD를 찾지 못한 경우 NotePAD를 실행시킨다.
        if (hWndNotePad == NULL || !IsWindow(hWndNotePad))
        {
            ::ShellExecute(NULL, NULL, "NotePAD.exe", NULL, NULL, SW_SHOWNORMAL);
            Sleep(100); //NotePAD가 실행될 수 있는 시간을 준다.
        }
        else
            break;
    }
    if (hWndNotePad == NULL || !IsWindow(hWndNotePad)) return; //예외 처리
    //----------------------------------------------------------------------------


    //NotePAD의 에디터 창을 찾는다.
    //NotePAD는 구성상 첫번째 자식이 에디터 창이다.(SPY++로 확인 가능)
    HWND hWnd = ::GetWindow(hWndNotePad, GW_CHILD);


    //NotePAD의 하단으로 커서 위치 이동
    ::SendMessage(hWnd, EM_SETSEL,(DWORD)0,(DWORD)-1);
    ::SendMessage(hWnd, EM_SETSEL,(DWORD)-1,(DWORD)0);
    //내용 출력
    ::SendMessage(hWnd, EM_REPLACESEL, 0, (LPARAM)buffer);
}


Dreamy의 코드 스크랩

내가 모으고 내가 보는

List of Articles
번호 분류 제목 날짜 조회 수 추천 수
416 일반 마크다운 markdown (.md) 파일이란 2017.07.12 12927 0
415 Pi 아두이노 (Arduino)로 서보모터 (SG90) 제어 2017.07.11 11611 0
414 일반 배치파일(bat)에서 명령 실행결과를 변수에 저장하는 방법 2017.07.05 19660 0
413 LINUX 프로세스를 이름으로 단번에 종료하기 2017.06.07 9403 0
412 C++ istringstream 을 이용한 string type 변환 & 토크나이징 2017.06.07 9300 0
411 LINUX bluetooth on Ubuntu 2017.05.25 14119 0
410 Pi Raspberry pi 에 Bluetooth사용을 위한 bluez설치 및 실행 2017.05.24 10385 0
409 LINUX 블루투스 사용하기 hci tool 2017.05.24 12539 0
408 일반 BT와 BLE 2017.05.16 7309 0
407 LINUX [Shell Script] Bash 파일 유무 체크하는 방법과 파일 존재 검사 옵션 2017.05.16 22028 0
406 LINUX [Shell Script] Bash 실행결과를 변수에 담기 2017.05.16 14009 0
405 Pi SSD1306 OLED Displays with Raspberry Pi 2017.05.10 7343 0
404 Pi SPI란? (Serial Peripheral Interface) 2017.04.20 16158 0
403 Pi LCD interface 종류 및 Driver IC 2017.04.17 6960 0
402 Pi 아두이노의 인터럽트 (interrupt) 사용 2017.04.13 15034 0
목록
Board Pagination ‹ Prev 1 2 3 4 5 6 7 8 9 10 11 ... 34 Next ›
/ 34

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소

Designed by sketchbooks.co.kr / sketchbook5 board skin

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5