공통 데브기어 컴포넌트 컨버터 소개(마이그레이션 자동화 도구)
2020.01.29 15:31
데브기어 컴포넌트 컨버터
데브기어 컴포넌트 컨버터는 델파이 소스파일을 분석해 컴포넌트와 소스코드를 변경해주는 오픈소스 기반 마이그레이션 자동화 도구입니다.
데브기어 컴포넌트 컨버터는 컴포넌트 컨버터와 소스코드 컨버터 두개의 애플리케이션으로 구성됩니다.
- 컴포넌트 컨버터(CompMigrationTool) - 델파이 폼파일(*.dfm)과 소스파일(*.pas)에서 컴포넌트 정보를 변경합니다.
- 소스코드 컴버터(SrcMigrationTool) - 델파이 소스파일(*.pas)에서 컴포넌트를 사용한 코드를 찾아 변환합니다.
데브기어 컴포넌트 컨버터의 특징
엡바카데로는 reFind라는 정규표현식 치환 도구를 통해 마이그레이션 자동화 작업을 지원합니다.
reFind는 정규표현식을 이용해 소스파일에서 컴포넌트 종류와 속성등을 전환하는 작업을 할 수 있습니다.
하지만, reFind는 컴포넌트와 속성 등을 일대일로 치환하기 때문에 하나의 컴포넌트를 여러개의 컴포넌트로 나누거나, 속성, 이벤트 등을 추가하는 작업에 제약이 있습니다.
데브기어 컴포넌트 컨버터는 컴포넌트를 사용하는 코드를 분석해 컴포넌트 정보 취득 후, 그 정보로 새로운 컴포넌트용 코드를 생성해 치환합니다. 이 방식으로 하나의 컴포넌트를 여러개의 컴포넌트로 나누거나, 여러개의 컴포넌트 정보로 하나의 컴포넌트로 합치는 등의 작업이 가능합니다.
컴포넌트 사용 및 소스코드 작성 패턴은 사용자에 따라 다르기 때문에,
컴포넌트 정보를 분석하거나 조합하는 과정은 커스터 마이징 가능한 컨버터 클래스를 (상속후)직접 작성해야 합니다.
이 프로젝트에 포함된 기존 컨버터를 참조해 작성할 수 있습니다.
- RealGrid를 퀀텀그리드(cxGrid)로 변환하는 컨버터
- ODAC을 FireDAC으로 변환하는 컨버터 등
데브기어 컴포넌트 컨버터의 기능
데브기어 컴포넌트 컨버터의 주요 기능은 다음과 같습니다.
- 소스파일과 폼파일에서 컴포넌트 정보를 변경합니다.
- 소스파일에서 컴포넌트 사용 코드를 변경합니다.
- 지정한 디렉토리 하위 파일을 선택해 일괄 변환 가능합니다.
- 변환작업은 컨버터에 구현되며, 직접 컨버터를 구현해 변환 작업을 추가할 수 있습니다.
세부적인 특징은 다음과 같습니다.
- 하나의 컴포넌트를 여러개의 컴포넌트로 나누어 변경할 수 있습니다.(예> TRealGrid -> TcxGrid, TcxLevel, TcxTableView)
- 하나의 속성을 여러개의 속성으로 나누어 변경할 수 있습니다.
- 이벤트 핸들러와 매개변수를 변경할 수 있습니다.
- uses 절의 유닛을 추가, 제거할 수 있습니다.
- 컴포넌트를 제거할 수 있습니다.
- 컴포넌트 속성을 추가할 수 있습니다.
위 기능들을 이용해 대규모의 컴포넌트와 컴포넌트를 사용하는 소스코드를 일괄 변경할 수 있습니다.
제작 계기
이 도구를 제작한 계기는 리얼그리드(TRealGrid)를 퀀텀그리도(TcxGrid)로 전환하는 작업을 진행하기 위해서입니다.
엠바카데로에서는 이미 reFind라는 마이그레이션 도구를 제공합니다. reFind로 컴포넌트 또는 속성을 변경할 수 있습니다. 하지만 reFind는 일대일로 컴포넌트와 속성을 변경합니다.
리얼그리드를 퀀텀그리드로 변경하기 위해서는 하나의 리얼그리드 컴포넌트를 여러개의 퀀텀그리드 컴포넌트로 나눠야하고,
두 컴포넌트의 속성 및 이벤트(및 파라미터)가 상이해 하나의 속성을 여러개로 변경하도록 재구성하거나, 이벤트 핸들러 구조를 변경해 다시 연결하고 이벤트 핸들러의 소스코드등을 변경해야 합니다.
만약, 리얼그리드 사용량이 작다면 시간이 걸리더라도 수작어으로 진행하는 것이 좋지만, 사용량이 많다면(제가 진행한 프로젝트는 약 천여개의 그리드 사용) 자동화하는 것이 좋습니다.
자동화시 작업시간을 줄여주는 것은 물론이고, 일관된 방식으로 코드를 변경할 수 있어 향후 유지보수에 유리합니다.(또한 재작업에 대한 부담도 줄여줍니다.)
모든 작업을 자동화 하는 것은 효율적이지 않습니다. 되도록 반복되는 작업을 이 툴로 자동화하고, 최종적으로 검토 및 마무리는 수작업으로 진행하는 것이 좋습니다.
사용방법
데브기어 컴포넌트 컨버터는 오픈소스로 제공됩니다.
이 도구는 완성된 패키지형 프로그램이 아닙니다. 변환작업을 수행할 컨버터를 직접 구현해야합니다.
다음 글을 통해 데브기어 컴포넌트 컨버터 원리와 구조를 설명합니다.
사용하며 필요한 기능이나 궁금한 내용은 의견 부탁드립니다.