데브기어 컴포넌트 컨버터

 

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

 

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

  • 컴포넌트 컨버터(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 15442
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13962
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16499
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22055
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23268
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18923
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39257
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174713
214 [FMX] 폼의 높이를 애니메이션으로 변경하기, 툴바를 끌어 폼 이동하기 험프리 2017.09.12 530
213 [10.4 시드니][업데이트 2] TNUMBERBOX – 새로운 VCL 컨트롤 관리자 2021.03.08 529
212 이 달의 기술자료 - 2017년 03월 file 험프리 2017.02.24 529
211 이 달의 기술자료 - 2015년 10월 file 험프리 2015.09.25 529
210 API로 머신 러닝과 컴퓨터 비전 활용하기 관리자 2021.05.04 526
209 이 달의 기술자료 - 2017년 11월 file 험프리 2017.10.30 525
208 이 달의 기술자료 - 2017년 06월 file 험프리 2017.05.30 525
207 [앵콜세미나] 사물인터넷 실제 구현하기, DeepDive!: 비콘, 스마트조명, 블루투스 체중계 관리자 2015.08.19 525
206 이 달의 기술자료 - 2019년 02월 file 험프리 2019.01.25 524
205 이 달의 기술자료 - 2018년 08월 file 험프리 2018.07.31 524
204 RAD스튜디오 2020 로드맵 – 자세한 내용을 확인해보세요! (PM들의 코멘터리) 관리자 2020.11.19 523
203 이 달의 기술자료 - 2019년 01월 험프리 2018.12.28 522
202 RAD스튜디오 로드맵 - 2019년 8월 관리자 2019.08.13 522
» 데브기어 컴포넌트 컨버터 소개(마이그레이션 자동화 도구) 험프리 2020.01.29 519
200 이 달의 기술자료 - 2017년 08월 험프리 2017.07.28 518
199 [10.3 리오][업데이트 2] IDE 향상된 기능들 [4] 관리자 2019.08.12 517
198 이 달의 기술자료 - 2019년 03월 file 험프리 2019.02.27 517
197 이 달의 기술자료 - 2016년 01월 file 험프리 2015.12.28 515
196 이 달의 기술자료 - 2018년 04월 file 험프리 2018.03.30 515
195 10.1 베를린 부터는 리본 컨트롤을 겟잇 패키지 매니저에서 설치할 수 있습니다. 험프리 2016.05.27 514