/* CommandPrmpt_One.cpp */

#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>
#include <locale.h>
#include <string.h>
#include <windows.h>

#define STR_LEN 256
#define CMD_TOKEN_NUM 10

TCHAR ERROR_CMD[] = _T("'%s'은(는) 실행할 수 있는 프로그램이 아닙니다. \n");

int CmdProcessing();
TCHAR * StrLower(TCHAR *);
int _tmain(int agrc, TCHAR * argv[])
{
// 한글 입력 가능하게끔
_tsetlocale(LC_ALL, _T("Korean"));

DWORD isExit;
while(1)
{
isExit = CmdProcessing();
if(isExit == TRUE)
{
_fputts(_T("명령어 처리를 종료합니다. \n"), stdout);
break;
}
}
return 0;
}

TCHAR cmdString[STR_LEN];
TCHAR cmdTokenList[CMD_TOKEN_NUM][STR_LEN];
TCHAR seps[] = _T(" , \t \n ");

int CmdProcessing(void) // 명령어를 입력받아 해당 명령어에 지정되어 있는 기능을 수행함.
{ // exit가 입력되면 TRUE를 반환하고 이는 프로그램의 종료로 이어진다.
_fputts(_T("Best command prompt>> "), stdout);
_getts(cmdString);
TCHAR * token = _tcstok(cmdString, seps);
int tokenNum = 0;
while(token != NULL)
{
_tcscpy(cmdTokenList[tokenNum++], StrLower(token));
token = _tcstok(NULL, seps);
}

if(!_tcscmp(cmdTokenList[0], _T("exit")))
{
return TRUE;
}
else if(!_tcscmp(cmdTokenList[0], _T("추가 되는 명령어 1")))
{
}
else if(!_tcscmp(cmdTokenList[0], _T("추가 되는 명령어 2")))
{
}
else
{
_tprintf(ERROR_CMD, cmdTokenList[0]);
}
return 0;
}

TCHAR * StrLower(TCHAR *pStr) // 문자열 내의 존재하는 모든 대문자를 소문자로 변경
{ // 변경된 문자열의 포인터를 반환한다.
TCHAR *ret = pStr;
while(*pStr)
{
if(_istupper(*pStr))
*pStr = _totlower(*pStr);
pStr++;
}
return ret;
}

위 코드는 프로젝트를 쉽게 이해하기 위해 간결하게 제시된 코드이다.
주목해서 봐야할 사항
- 명령어를 추가할 때 변경되는 부분
- 명령어의 대,소문자를 구분하지 않기 위해서 고려된 부분
- 명령어 EXIT가 입력되었을 때 프로그램 종료방식
 
출처. 윈도우즈 프로그래밍 | 윤성우 저  | 한빛미디어 
신고
  1. 김멋져 2012.03.26 05:30 신고

    매우 많은 도움되었습니다. 감사합니다.

  2. 김민식 2016.11.20 18:41 신고

    인풋을 받고, 다음 명령을 실행하니 버퍼가 입력되 있어서, 자동으로 명령어를 계속 실행합니다. T.T
    cmdString이 원래 코드에서 자동으로 비워지나요?

+ Recent posts

티스토리 툴바