2010년 10월 22일 금요일

CString으로 문자열 리소스를 사용하자

문자열을 스트링 테이블에 담아놓고 사용하는게 좋다고들 말하지만 쓰기가 귀찮아서 그냥 소스에 적는 경우가 많습니다.

하지만 CString에서는 스트링 테이블 사용을 쉽게 하기 위한 좋은 방법을 많이 제공합니다. 적극 활용하시기 바랍니다.

혹시 압니까? 프로그램이 평가가 좋아서 수출하게 됐는데 CPP코드 죄다 뒤져가면서 "아, 여기도 문자열이 있다" "아, 100개쯤 더 있는데 어디지..." 라고 하면서 밤을 세게 될지.

미리 스트링 테이블에 넣어뒀다면. "아저씨, 이거 일본어로 번역해주세요." 라고 하면서 번역 잘하는 사람에게 넘기면 끝이란 것이죠. 음하하!

1. 초기화

CString strError((LPCSTR)IDS_ERROR_FAILED);

strError += "너 바보?";

WriteLog(strError);

이런 식으로 생성자에서 문자열 리소스의 아이디를 줄 수 있습니다.

문자열 리소스의 아이디는 반드시 (LPCSTR)로 캐스팅해야 합니다.

(동작이 궁금하신 분은 MFC의 CString소스를 보세요. 재밌습니다. 결국 API에서 MAKEINTRESOURCE라는 걸 사용하는 것도 비슷하게 동작할까 생각되네요.)



조금 응용하자면...

WriteLog(CString((LPCSTR)IDS_ERROR_AGAIN));

이런식으로 사용할 수도 있겠죠.



2. 변경

아무때라도

strError.LoadString(IDS_ERROR_OMG);

이런 식으로 해서 새로운 문자열을 로드할 수 있습니다.



3. format

strError.Format(IDS_ERROR_FORMAT, nErrorCode, strID);

이렇게 Format문에 바로 사용하는 것도 가능합니다.

위의 예에 어울리는 IDS_ERROR_FORMAT는

"에러코드 : %d, 문제를 일으킨 사람 : %sn"

정도겠죠?



4. 주의

이건 MSDN에도 안나오는 겁니다. 예전에 제가 이것 때문에 죽을 뻔 한적이 있어서... -_-;

CString에 1024자 이상의 한글이 마구 섞인 문자열 리소스를 로드하면 윈95에서 시스템이 다운될 수 있습니다. (또 95만 죽습니다. 98, NT는 아무문제 없습니다.)

API LoadString이 일본어나 한국어 문자열 리소스를 로드할 때 리턴값을 잘못 계산하는 버그가 있는데 MFC의 LoadString에서 필요한 버퍼의 크기를 계산하는 부분과 절묘하게 맞물려서 시스템이 죽을 수 있습니다. 좀 아쉬운 부분이네요.

아마 왠만하면 1024자 이상이 필요한 일은 없을겁니다. ^^;

이 때는 차라리 크기를 지정해서 API LoadString을 사용하거나 afxpriv.h에 선언된 AfxLoadString을 사용하세요.

댓글 없음:

댓글 쓰기