데브기어 컴포넌트 컨버터

 

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

 

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

  • 컴포넌트 컨버터(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 18075
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 16405
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 19030
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 24656
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 26013
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 21391
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 41976
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 177274
214 [10.4 시드니][업데이트 2] TNUMBERBOX – 새로운 VCL 컨트롤 관리자 2021.03.08 552
213 이 달의 기술자료 - 2015년 12월 file 험프리 2015.11.27 551
212 이 달의 기술자료 - 2015년 10월 file 험프리 2015.09.25 551
211 이 달의 기술자료 - 2019년 01월 험프리 2018.12.28 548
210 이 달의 기술자료 - 2017년 06월 file 험프리 2017.05.30 548
209 [발표자료] VCL 애플리케이션 확장하기 with RAD 서버 관리자 2017.03.16 545
208 RAD스튜디오 로드맵 - 2019년 8월 관리자 2019.08.13 545
207 BDE/파라독스를 인터베이스(INTERBASE)로 마이그레이션 하기 관리자 2021.05.31 544
206 [오픈소스] 델파이 코드 커버리지 소개 file 험프리 2019.12.05 542
205 이 달의 기술자료 - 2018년 02월 file 험프리 2018.01.25 542
204 RAD스튜디오 2020 로드맵 – 자세한 내용을 확인해보세요! (PM들의 코멘터리) 관리자 2020.11.19 541
203 [사물인터넷 동영상] 위험 지역 경보 시스템 관리자 2015.07.28 541
202 이 달의 기술자료 - 2017년 11월 file 험프리 2017.10.30 541
201 생산성을 끌어올려줄 겟잇(GetIt)의 최신 컴포넌트들 관리자 2021.01.18 540
200 이 달의 기술자료 - 2019년 02월 file 험프리 2019.01.25 539
» 데브기어 컴포넌트 컨버터 소개(마이그레이션 자동화 도구) 험프리 2020.01.29 538
198 [앵콜세미나] 사물인터넷 실제 구현하기, DeepDive!: 비콘, 스마트조명, 블루투스 체중계 관리자 2015.08.19 536
197 이 달의 기술자료 - 2017년 08월 험프리 2017.07.28 534
196 API로 머신 러닝과 컴퓨터 비전 활용하기 관리자 2021.05.04 533
195 이 달의 기술자료 - 2018년 08월 file 험프리 2018.07.31 533