데브기어 컴포넌트 컨버터 소개(오픈소스)

2020. 1. 22. 17:06

데브기어 컴포넌트 컨버터



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


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

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

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

엡바카데로는 reFind라는 정규표현식 치환 도구를 통해 마이그레이션 자동화 작업을 지원합니다.
reFind는 정규표현식을 이용해 소스파일에서 컴포넌트 종류와 속성등을 전환하는 작업을 할 수 있습니다.
하지만, reFind는 컴포넌트와 속성 등을 일대일로 치환하기 때문에 하나의 컴포넌트를 여러개의 컴포넌트로 나누거나, 속성, 이벤트 등을 추가하는 작업에 제약이 있습니다.

데브기어 컴포넌트 컨버터는 컴포넌트 코드를 분석해 컴포넌트 정보를 취득 후, 그 정보로 새로운 컴포넌트로 조합하는 방식으로 구현되었습니다.
이 방식을 이용해 하나의 컴포넌트를 여러개의 컴포넌트로 나누거나, 여러개의 컴포넌트 정보로 하나의 컴포넌트로 합치는 등의 작업이 가능합니다.

컴포넌트 정보를 분석하거나 조합하는 과정은 컨버터 클래스에 구현합니다.
이 컨버터 클래스는 컴포넌트 별로 작성해야 하며, 본인의 코딩 스타일에 따라 다르게 구현해야 합니다.
데브기어 컴포넌트 컨버터는 오픈소스로 제공하며, 소스코드를 다운로드 받아 본인의 소스코드에 맞게 직접 제작하는 과정이 필요합니다.

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

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

위 기능들을 이용해 대규모의 컴포넌트와 컴포넌트를 사용하는 소스코드를 일괄 변경할 수 있습니다.

제작 계기

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


엠바카데로에서는 이미 reFind라는 마이그레이션 도구를 제공합니다. reFind로 컴포넌트 또는 속성을 변경할 수 있습니다. 하지만 reFind는 일대일로 컴포넌트와 속성을 변경합니다.

리얼그리드를 퀀텀그리드로 변경하기 위해서는 하나의 리얼그리드 컴포넌트를 여러개의 퀀텀그리드 컴포넌트로 나눠야하고, 두 컴포넌트의 속성이 상이해 재구성해야 했습니다. 또한 이벤트 핸들러의 구조도 상이해 이벤트 핸들러 구조를 변경해 다시 연결해야 합니다. 이와 같이 컴포넌트와 구조가 변경되면 소스코드도 대폭 변경되어야 합니다.

만약, 컴포넌트를 사용한 코드가 몇군데라면 한명이 수작업으로 변경하는 것이 좋습니다.
하지만 사용하는 코드가 수십~수백개라면 여려명이 오랜시간 변경작업을 진행해야 할 것입니다. 이 경우 시간도 오래걸리고, 각자의 개발 스타일에 따라 다르게 구현하게 되면 향후 유지보수도 어려울 수 있습니다.

위 작업을 자동화 하면, 시간과 인력이 절약되고 동일한 방향으로 변경되어 유지보수에도 유리합니다. 또한 재작업에 대한 부담도 줄게됩니다.

사용방법

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


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

다음 링크를 통해 데브기어 컴포넌트 컨버터의 구조와 구현방법을 설명합니다.

  • 데브기어 컴포넌트 컨버터 구조와 원리 - 준비 중
  • 데브기어 컴포넌트 컨버터 사용 샘플 - 준비 중

사용하며 필요한 기능이나 궁금한 내용은 의견 부탁드립니다.


험프리 험프리.김현수 마이그레이션