삽질하는플머

KOL-CE 2.80.3 릴리즈.

Lazarus/KOL-CE
간만에 소스포지에 가 봤더니 KOL-CE 2.80.3 버전이 나왔다. 2009년 1월 23일이면 연휴 바로 직전이군..
http://sourceforge.net/projects/kol-ce/

수정된 사항을 간단히 짚어보면,

* Enabled TTrayIcon for wince.
* Fixed compilation with FPC 2.2.3 and FPC 2.3.1. Patch by Carolos Foscolos.
* MCK: Fixed updating of source code in trunk version of Lazarus.
* MCK: Fixed code generation for new KOL application template, when form's unit name is renamed.
* MCK: Add InitCommonControls() call to fix themed control drawing if only standard controls are used.
* MCK: Fixed error "Restoring toolbar buttons bitmap from then previous version of the KOL&MCK format."  version of the KOL&MCK format."

이라는군. 아무튼 기쁜 소식이다~~!!!

이전 2.80.2 버전을 설치했던 경로는 /lazarus/userlib/kol-ce-2.80.2. 새 버전은 /lazarus/userlib/kol-ce-2.80.3 에 설치. (이거 누가 그랬을까~~ 누가 그랬을까!! 아마추어 같이~~ ㅠㅠ) 따라서 이전에 작업했던 프로젝트 파일 (*.lpi) 내의 경로들을 모두 수정 해 주어야 한다. 귀찮네... 다음번에 라자루스를 설치할 때는 그냥 lazarus/userlib/kol-ce 를 사용해야 겠다.

참고로 이 버전의 KOL-CE의 SIP메뉴 관련 수정 위치는 KOL.pas 의 33,847 라인이다.
매번 귀찮으니... 짧은 영어로라도 패치를 만들어 보내야 할 듯... ㅠㅠ;;

프로젝트의 버전 번호를 100 이상으로

Lazarus
언제부터인지 버전정보에 0.... 을 적는 것 보다 날짜를 적는 것에 익숙해져 버렸다. 
게임개발을 오래 하다보니 네버엔딩 스토리에 익숙해 져 그런건지... 

아무튼, 라자루스에서 이렇게 버전정보 앞부분에 연도값을 적으려고 시도 해 보니




황당하게도 다시 100으로 바뀌어 버린다.

 

LCL의 TSpinEdit 에서 MaxValue의 디폴트값이 100이고 이게 수정되지 않고 쓰인 듯 하다. 
/lazarus/ide/projectopts.pp 파일을 찾아 버전에 관계된 SpinEdit 컨트롤의 MaxValue를 적당히
수정 해 주고 라자루스를 다시 빌드하면 이 문제를 해결할 수 있다. 

2008년 11월 17일에 해당 버그를 라자루스 버그 트래커에 등록 했고, 2009년 1월 19일에 
0.9.27 리비전 18342에 적용되었다고 한다. 두 달이나 걸리는군... 

아무튼 새 버전이 기다려진다. ^^;;



Pocket PC 2003 에뮬레이터 띄우기

Lazarus/Mobile

Embedded VC 4.0 을 받고 서팩4, 윈도 CE 5.0 및 PocketPC 2003 SDK를 설치하게 되면 시스템에 버추얼머신 우쩌구 하는 경고가 뜨면서 충돌예상 시스템이라 설치할 수 없다는 에러가 난다. 그 후 윈도 CE 5.0 에뮬은 잘 동작하지만 PPC2003 은 아래와 같은 경고가 발생하며 동작하지 않게 된다.




잘은 모르겠지만, 라자루스 위키에서 WM 5.0용 에뮬레이터를 깔 때 Virtual PC 2007을 설치하라고 말하는 것으로 보아... 무언가 예전과는 많이 바뀐 듯...

아무튼 이 에뮬레이터를 구동하는 단축키는 "C:\Program Files\Windows CE Tools\wce420\POCKET PC 2003\Emulation\emul.cmd" 를 실행시키게 되어있고 이 emul.cmd 의 내용은 다음과 같다.

start "" "C:\Program Files\Common Files\Microsoft Shared\Windows CE Tools\Platman\bin\PBEmulator.exe" /MemorySize 64 /Fastbackground /Skin "C:\Program Files\Windows CE Tools\wce420\POCKET PC 2003\Emulation\pocket_pc_emulator_skin.xml" /CEImage "C:\Program Files\Windows CE Tools\wce420\POCKET PC 2003\Emulation\PPC_2003_WWE.bin" /VMName "POCKET PC 2003 - POCKET PC 2003 Emulator" /HostKey 165


저 중간에 PBEmulator.exe 는 윈도 CE 3.0 에 대한 에뮬레이터였을 것이고... 그렇다면 이걸 지금 잘 동작하는 Emulator_500.exe로 바꿔보면 어떨까??

start "" "C:\Program Files\Common Files\Microsoft Shared\Windows CE Tools\Platman\bin\Emulator_500.exe" /MemorySize 64 /Fastbackground /Skin "C:\Program Files\Windows CE Tools\wce420\POCKET PC 2003\Emulation\pocket_pc_emulator_skin.xml" /CEImage "C:\Program Files\Windows CE Tools\wce420\POCKET PC 2003\Emulation\PPC_2003_WWE.bin" /VMName "POCKET PC 2003 - POCKET PC 2003 Emulator" /HostKey 165


결과는 대 성공!!! 잘 구동된다!!! 반갑다 Pocket PC 2003!!




뭐 당연한 이야기겠지만, CPU는 암 에뮬레이션이 아니라 인텔이다. 따라서 i386-wince 용으로 컴파일 한 프로그램만 구동될 것이다.




당분간 POZ 충전할 일은 없겠다. 캬캬캬~~~

MS에서 제공하는 해법도 있지만, 보안에 관계된 문제가 생길 수 있고 악성 코드에 감염될 수 있다는 경고가 붙어있다. 꼭 필요할 때만 수행하라고 하는데... 하지 않는 편이 좋을 듯...

KOL.PAS의 SHCreateMenuBar 호출부 수정

Lazarus/KOL-CE

윈도 CE는 종류도 참 많다. 델마당에 올렸던 글에 신성기님이 달아두신 답변을 옮겨본다.

신성기 (barmi)
Windows Mobile(WM)에 비해 Windows CE (WinCE)는 포괄적인 개념입니다. WM5는 WinCE5.0기반으로 구동되는 서브셋입니다. 즉, WinCE는 MS Platform builder로 만들어지는 Embedded OS의 총칭이고, Wimdows Mobile은 이전의 Palm sized PC -> Pocket PC의 차세대 명칭으로 WinCE 기반으로 쉘,기능의 guide line을 만들어 둔 것입니다.
WinCE와 WM의 버전을 비교해 보면 다음과 같습니다.
WinCE 2.1 - Palm Sized PC (Hand Held PC)
WinCE 3.0 - PocketPC 2000/2002/2003/2003SE
WinCE 4.2
WinCE 5.0 - Windows Mobile 5
WinCE 5.2 - Windows Mobile 6
WinCE 6.0 - Windows Mobile 7
실제 Pocket PC는 모두 WinCE 3.0기반으로 만들어 진 것이라, OS의 기본 성능은 동일하고 포함되는 shell이나 dll에 따라 버전이 구분됩니다.
참고하세요.


문제는, KOL로 빌드한 실행파일의 경우 친구놈의 아이나비 플러스에서 에러가 나는 현상이 발생한다는 것. KOL은 폼을 생성하면서 SIP부분을 구현하기 위해 SHCreateMenuBar 를 호출하는데, 아이나비 플러스의 aygshell.dll 에는 이 함수가 없기 때문이다. 또 다른 글에 휘오른님이 달아두신 댓글에서 보이듯 동일한 현상이 포켓피시 2003에서도 발생한다고 하는데,

휘오른 (leekg999)
저번에 라자루스로 wince용으로 만든 다음, 파일크기를 보니 기본이 1M 더군요. 그러려니 하고, 좀 지난 pda(h4150,ppc2003)에 올려서 실행했더니,겨우겨우 로딩한뒤에, 다운먹더군요.KOL-CE 는  실행순간 넉다운..;; 제가 라자루스를 컴퓨터 3대에 깔아서 해봤는데, 윈도우 환경을 너무 타는 것 같습니다. 어떤때는 컴파일 되고, 어떤때는 IDE에서 오류나고,크로스 컴파일을 지원한다는게 매력적인 환경이지만, 초보에겐 삽질이 힘들더라구요 ㅠ_ㅠ
(혹시 WM5 이상 기종에서 성능은 어느정도 나오는지 아시는 분 계시나요?)  


포켓PC 2003에 SIP 영역이 없다는 것을 고려하면 같은 이유라고 짐작된다. (시간 날 때, 책상위에서 잠자고 있는 poz에 밥을 먹인 뒤 테스트 해 봐야 겠다.)

아무튼 이 문제를 해결하려면 KOL.PAS의 TControl.CreateWindow 함수를 손 봐 주어야 한다. 버전 2.80.1 에서는 33,837 번 라인, 버전 2.80.2 에서는 33,845 번 라인을 아래와 같이 수정하자.

2009.1.28 추가.
2009년 1월 23일에 릴리즈 된 2.80.3 버전에서는 33,847 에 해당 코드가 있다. 이거 매번 귀찮으니... 패치를 만들어 보내야 할 듯...


 // if CePlatform <> cpSmartphone then begin
 // -->> 위 코드를 다음과 같이 수정한다. 
 if CePlatform = cpPocketPC then begin


CePlatform 이 단순히 cpPocketPC인 것으로 봐서... 아무래도 2003에서는 또 다른 삽질이 필요할 듯...
이 문서는 삽질이 끝난 뒤 다시 업데이트 하도록 하자.


-->> PocketPC 2003 에뮬레이터에서 굴려본 결과는, 위의 경우와 관계없이 제대로 동작한다. 
CePlatform 값 자체도 cpPocketPC로 인식되므로 사실 저 코드와 별 차이가 없어보인다...

쩝... 결국 POZ를 충전해야 한다는 건가...


델마당의 휘오른님의 댓글에 의하면, 저 코드를 적용했을 때 h4150, PPC2003 에서 정상동작 한다고 한다. 따라서 POZ 밥먹이기는 귀차니즘에 의해 잠정중단~~ ^^;

KOL-CE 사용하기

Lazarus/KOL-CE
z라자루스를 깔고 초기 상태 그대로 예제를 만들어 빌드하면... 실행파일의 용량은 약 11메가. 말 그대로 덜덜덜...
윈도 CE용 개발도구로 라자루스를 선택한 사람들에게 그 크기는 재앙에 가깝다.
디버깅의 라인정보 빼고 스마트링크를 켜 주면 1메가로 줄어들지만... 그래도 무겁기는 매 한가지.

그러다 만난 KOL-CE는 말 그대로 복음과도 같은 존재. 윈도용 실행파일은 41kb에서 시작한다. 오오~~!!!
http://wiki.freepascal.org/KOL-CE

델파이에서 KOL-CE를 쓰면 무려 11kb 로 줄어든다는데... 후덜덜덜...

아무튼 이 멋진 도우미의 사용법에 대해 간단히 알아보자.

설치하기.

1. 다운로드 받아서 압축을 푼다. (C:\lazarus\userlib\kol-ce-2.80.2 에 풀었음)
2. Components -> Open package file (.lpk) 메뉴를 선택하고, MCK 폴더를 찾아가 "MirrorKOLPackage.lpk" 를 열어준다.



3. 패키지 윈도가 표시되면 Install 버튼을 눌러준다.
4. MCK와 IDE가 다시 컴파일되고 나서 라자루스가 재시작 될 것이다.

인생 최대의 삽질의 추억!!

몇 개의 컴포넌트가 보이지 않는 현상이 생기길래 라자루스 IDE 재빌드부터 생각나는 일은 모두 시도 해 봄.
심지어는 컴포넌트 팔래트까지 종류별로 바꿔보았다.

MIRROR.pas 의 RegisterComponents는 RegisterComponents( 'KOL Mirror', [...
mckCtrls.pas 에는 RegisterComponents( 'KOL Ctrls', [ ...
mckObjs.pas 에는 RegisterComponents( 'KOL Objs', [ ... 와 같이 변경.

저렇게 했는데도 안보이길래... 우연히 화면을 늘려봤더니 얌전히 숨어있는 것이 아닌가..
라자루스는 화면의 가로폭이 작으면 컴포넌트들을 2열로 배열하는 걸 몰랐었다.



도대체 이 문제 때문에 라자루스를 몇 번이나 재설치 했었는지... 쩝쩝...





사용하기.
새 버전의 KOL에서는 예전처럼 폼을 저장하고 다시 불러오는 닭짓이 필요 없다. 라자루스의 File -> New 메뉴에서 "KOL Application" 을 골라주면 그걸로 끝!!






프로젝트와 폼에 적당한 이름을 지어주고 저장하자.

저장부터 해야 한다!! KOL 프로젝트는 저장될 때 프레임워크의 코다가 추가되는 방식이니 저장하지 않고 빌드하면서 안된다고 삽질하지 말 것!!!

또한 이 때 경로명에 한글이 들어가 있다면 KOL이 인식하지 못하니 유의할 것!!

빌드 해 보면 41kb 짜리 실행파일을 얻을 수 있다.




윈 CE 빌드.
Project -> Compiler options 메뉴를 선택한 뒤, Code 페이지의 설정을 다음과 같이 바꿔준다.
KOL은 LCL을 사용하지 않기 때문에 LCL Widget type 은 그대로 두어도 된다.



빌드 해 보면 53kb 짜리 실행파일이 생긴다. 윈 CE 에뮬레이터로 옮기고 돌려보면 잘 동작하는 것을 확인할 수 있다.