MFC
2006.05.19 17:32

노트패드를 이용한 덤프

조회 수 35312 댓글 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
번호 분류 제목 날짜 조회 수 추천 수
16 MFC MFC app 디버깅 출력을 위한 콘솔 생성하기 2009.09.01 44510 0
15 MFC 커맨드 창 속성 제어 2009.09.01 39625 0
14 MFC 도스 커맨드 실행하기 1 2009.09.01 50916 0
13 MFC Cstring methods 2009.04.21 56798 0
12 MFC 비트맵 비교 2009.03.23 42525 0
11 MFC 현재디렉토리의 파일리스트들을 알아오는 클래스 CFindFile 2008.05.07 64699 0
10 MFC 현재 실행된 어플리케이션의 디렉토리 적용하기 2008.05.07 42362 0
9 MFC 리사이징 다이얼로그(Resizing dialog) 2008.03.24 48701 0
8 MFC 시스템 출력 리디렉션 - 도스 커맨드 결과 받아오기 file 2007.08.14 54971 0
» MFC 노트패드를 이용한 덤프 file 2006.05.19 35312 0
6 MFC 시작프로그램 레지스트리에 등록/해제 함수 2006.04.14 47727 0
5 MFC [C] Unicode 사용에 대하여 2006.04.14 48979 0
4 MFC API를 이용하는 유니코드와 ANSI 문자열간의 변환 방법 2006.04.14 65167 0
3 MFC CString을 유니코드로 변환 WCHAR에 저장하는 방법 1 2006.04.14 58762 0
2 MFC 다이얼로그 기반 APP에서 Edit에 엔터키 먹게 하기 2006.04.14 49506 0
목록
Board Pagination ‹ Prev 1 2 3 Next ›
/ 3

나눔글꼴 설치 안내


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

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

설치 취소

Designed by sketchbooks.co.kr / sketchbook5 board skin

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5