데브기어 컴포넌트 컨버터

 

데브기어 컴포넌트 컨버터는 델파이 소스파일을 분석해 컴포넌트와 소스코드를 변경해주는 오픈소스 기반 마이그레이션 자동화 도구입니다.

 

데브기어 컴포넌트 컨버터는 컴포넌트 컨버터와 소스코드 컨버터 두개의 애플리케이션으로 구성됩니다.

  • 컴포넌트 컨버터(CompMigrationTool) - 델파이 폼파일(*.dfm)과 소스파일(*.pas)에서 컴포넌트 정보를 변경합니다.
  • 소스코드 컴버터(SrcMigrationTool) - 델파이 소스파일(*.pas)에서 컴포넌트를 사용한 코드를 찾아 변환합니다.
 

데브기어 컴포넌트 컨버터의 특징

엡바카데로는 reFind라는 정규표현식 치환 도구를 통해 마이그레이션 자동화 작업을 지원합니다.
reFind는 정규표현식을 이용해 소스파일에서 컴포넌트 종류와 속성등을 전환하는 작업을 할 수 있습니다.
하지만, reFind는 컴포넌트와 속성 등을 일대일로 치환하기 때문에 하나의 컴포넌트를 여러개의 컴포넌트로 나누거나, 속성, 이벤트 등을 추가하는 작업에 제약이 있습니다.
 
데브기어 컴포넌트 컨버터는 컴포넌트를 사용하는 코드를 분석해 컴포넌트 정보 취득 후, 그 정보로 새로운 컴포넌트용 코드를 생성해 치환합니다. 이 방식으로 하나의 컴포넌트를 여러개의 컴포넌트로 나누거나, 여러개의 컴포넌트 정보로 하나의 컴포넌트로 합치는 등의 작업이 가능합니다.
 
컴포넌트 사용 및 소스코드 작성 패턴은 사용자에 따라 다르기 때문에, 
컴포넌트 정보를 분석하거나 조합하는 과정은 커스터 마이징 가능한 컨버터 클래스를 (상속후)직접 작성해야 합니다.
이 프로젝트에 포함된 기존 컨버터를 참조해 작성할 수 있습니다.
  • RealGrid를 퀀텀그리드(cxGrid)로 변환하는 컨버터
  • ODAC을 FireDAC으로 변환하는 컨버터 등

 

데브기어 컴포넌트 컨버터의 기능

데브기어 컴포넌트 컨버터의 주요 기능은 다음과 같습니다.
  • 소스파일과 폼파일에서 컴포넌트 정보를 변경합니다.
  • 소스파일에서 컴포넌트 사용 코드를 변경합니다.
  • 지정한 디렉토리 하위 파일을 선택해 일괄 변환 가능합니다.
  • 변환작업은 컨버터에 구현되며, 직접 컨버터를 구현해 변환 작업을 추가할 수 있습니다.
 
세부적인 특징은 다음과 같습니다.
  • 하나의 컴포넌트를 여러개의 컴포넌트로 나누어 변경할 수 있습니다.(예> TRealGrid -> TcxGrid, TcxLevel, TcxTableView)
  • 하나의 속성을 여러개의 속성으로 나누어 변경할 수 있습니다.
  • 이벤트 핸들러와 매개변수를 변경할 수 있습니다.
  • uses 절의 유닛을 추가, 제거할 수 있습니다.
  • 컴포넌트를 제거할 수 있습니다.
  • 컴포넌트 속성을 추가할 수 있습니다.
 
위 기능들을 이용해 대규모의 컴포넌트와 컴포넌트를 사용하는 소스코드를 일괄 변경할 수 있습니다.
 

 

제작 계기

이 도구를 제작한 계기는 리얼그리드(TRealGrid)를 퀀텀그리도(TcxGrid)로 전환하는 작업을 진행하기 위해서입니다.

 
엠바카데로에서는 이미 reFind라는 마이그레이션 도구를 제공합니다. reFind로 컴포넌트 또는 속성을 변경할 수 있습니다. 하지만 reFind는 일대일로 컴포넌트와 속성을 변경합니다.
 
리얼그리드를 퀀텀그리드로 변경하기 위해서는 하나의 리얼그리드 컴포넌트를 여러개의 퀀텀그리드 컴포넌트로 나눠야하고,
두 컴포넌트의 속성 및 이벤트(및 파라미터)가 상이해 하나의 속성을 여러개로 변경하도록 재구성하거나, 이벤트 핸들러 구조를 변경해 다시 연결하고 이벤트 핸들러의 소스코드등을 변경해야 합니다.
 
만약, 리얼그리드 사용량이 작다면 시간이 걸리더라도 수작어으로 진행하는 것이 좋지만, 사용량이 많다면(제가 진행한 프로젝트는 약 천여개의 그리드 사용) 자동화하는 것이 좋습니다.
자동화시 작업시간을 줄여주는 것은 물론이고, 일관된 방식으로 코드를 변경할 수 있어 향후 유지보수에 유리합니다.(또한 재작업에 대한 부담도 줄여줍니다.)
 
모든 작업을 자동화 하는 것은 효율적이지 않습니다. 되도록 반복되는 작업을 이 툴로 자동화하고, 최종적으로 검토 및 마무리는 수작업으로 진행하는 것이 좋습니다.

 

사용방법

데브기어 컴포넌트 컨버터는 오픈소스로 제공됩니다.

 

이 도구는 완성된 패키지형 프로그램이 아닙니다. 변환작업을 수행할 컨버터를 직접 구현해야합니다.

다음 글을 통해 데브기어 컴포넌트 컨버터 원리와 구조를 설명합니다.

 

사용하며 필요한 기능이나 궁금한 내용은 의견 부탁드립니다.
번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 15417
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13960
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16496
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22048
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23267
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18921
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39245
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174696
554 [발표자료] 20200130 실제 사례로 살펴보는 소프트웨어 현대화 방안 file 관리자 2020.01.31 228
553 [코드레이지2019] VCL 현대화: WinAPI, COM & Shell 인터페이스, WinRT 통합하기 김원경 2020.01.30 187
552 TJumpList 컴포넌트 사용하기 file 김원경 2020.01.30 248
» 데브기어 컴포넌트 컨버터 소개(마이그레이션 자동화 도구) 험프리 2020.01.29 513
550 [코드레이지2019] 파이어몽키에서 사용자 정의 Message Box 디자인하기 김원경 2020.01.23 269
549 [업데이트][패치][10.3.3] RAD 스튜디오 10.3.3 아이폰 XS와 XR 디버깅 패치 험프리 2020.01.23 237
548 프로젝트 경험을 통해 터득한 효과적인 마이그레이션 프로세스 file 험프리 2020.01.22 563
547 [고객사례-유틸리티, C++빌더] Reg Organizer - 시스템 레지스트리 구성&최적화 유틸리티 관리자 2020.01.20 345
546 윈도우 10 룩앤필을 바로 적용할 수 있는 윈도우 10 VCL 컨트롤 소개 file 험프리 2020.01.15 327
545 [업데이트][패치][10.3.3] RAD 스튜디오 10.3.3 Indy 서버 SSL 인증서 패치 험프리 2020.01.14 541
544 [고객사례-게임, 델파이] Tears of Ra 관리자 2020.01.10 436
543 윈도우용 네이티브 앱 개발: 왜 중요할까요? 관리자 2020.01.07 374
542 High-DPI를 적용한 윈도우 10으로 빠르게 마이그레이션 하기 관리자 2020.01.07 350
541 MS와 엠바카데로 기술팀이 생각하는 윈도우 애플리케이션의 방향 관리자 2020.01.07 376
540 마이크로소프트 스토어(Microsoft Store)에 앱 등록하기 - APPX 활용 관리자 2020.01.07 616
539 [오픈소스] TGPuttyLib 소개 - PuTTY 기반 SFTP 클라이언트 험프리 2020.01.03 888
538 이 달의 기술자료 - 2020년 01월 험프리 2019.12.26 395
537 코드레이지 2019 재생목록 file 험프리 2019.12.26 255
536 [10.3.3][업데이트][핫픽스] RAD 스튜디오, 델파이, C++빌더 10.3.3 패치 목록 [1] 험프리 2019.12.26 892
535 VCL의 역할과 방향 - 마르코 칸투의 VCL 이야기! 관리자 2019.12.17 593