워프비전

워프비전 (http://www.warpvision.co.kr)은 2002년에 설립된 광학검사장비 전문기업입니다.

수원 영통구에 위치하였으며 워프비전은 반도체 및 디스플레이 필름등의 검사 장비를 스템코, 스테코, LG이노텍 등에 제공하고 있습니다.

 

델파이는 워프비전에서 설비를 제어하고 관리하는 소프트웨어 개발에 사용되었습니다. 

프로젝트 진행 (업그레이드 마이그레이션)

개요

- 카메라의 발전에 따른 이미지 해상도가 증가와, 윈도우 10 등 최신 운영체제 사용 증가를 수용하기 위한 업그레이드

 

당면과제

- 고해상도 이미지 처리 시 메모리 부족 문제 해소 (32-bit 운영체제 설계상, 메모리를 최대 4GB 까지로 사용이 제한됨) 

- 윈도우10 64-bit 운영체제 사용자 증가에 대응

- 중국, 일본 등 해외 고객사를 위한 현지 언어 지원

 

해결책

- 윈도우10 64-bit 전용 애플리케이션 구축 (32-bit 용 애플리케이션 병행 지원)

- 멀티-바이트 문자열 지원 등 애플리케이션 국제화

워프비전 - 마이그레이션 컨설팅

  • 프로젝트 기간 : 2019년 4월(1개월)
  • 지원 방법 : 마이그레이션 컨설팅
  • 델파이 버전 : 델파이 2007 32-bit > 델파이 XE7 32/64-bit
  • 업무 범위
    • 메인 프로그램 : 2개 프로젝트(약 100여개 소스코드)
    • 컴포넌트 : 자체제작 2개, 오픈소스 2개

 

마이그레이션 컨설팅

설비 소프트웨어 프로젝트의 경우 실질적인 소스코드의 양이 많지 않아 자체적으로 진행이 가능할 것으로 생각되지만,  마이그레이션은 생소한 작업이며, 기존 업무와 병행하며 진행하는 것은 현실적으로는 기간과 비용 측면에서 득보다 실이 많습니다.

또한 프로젝트 하나에서 델파이 버전 업그레이드와 64-bit 지원이라는 2가지 목적을 모두 달성해야 하므로 외부 전문가의 지원이 도움이 된다고  판단하여 데브기어의 마이그레이션 컨설팅 프로젝트를 선택해 주셨습니다.

 

참고로, 저는 데브기어를 통해 3가지 방식으로 마이그레이션 작업을 지원합니다. 하단의 참고 항목을 확인해주세요.

 

핵심 작업

  • 델파이 버전 업그레이드
  • 64-bit 지원 (32-bit와 병행 지원)
  • 자체 제작 컴포넌트 마이그레이션
  • 데이터 엑세스 컴포넌트 변경(FIBPlust > FireDAC)

 

작업절차

64-bit 지원이 실질적인 핵심과제입니다. 하지만, 64-bit를 지원하는 델파이 버전으로 업그레이드가 선행되어야 하므로 2단계로 나누어 순서대로 진행됩니다.

 

1 단계: 32-bit 애플리케이션 개발 환경 업그레이드 (델파이 2007 --> 델파이 XE7)

2단계: 델파이 XE7에서 64-bit 애플리케이션으로 확장 (32-bit 와 64-bit 모두 빌드 및 실행)

1단계에서 마이그레이션 작업을 대부분 처리하게 됩니다. 컴포넌트 전환 및 데이터 엑세스 컴포넌트 변경도 1차에서 완료됩니다.

2단계에서 XE7 32-bit로 1차 완성된 결과물로 64-bit도 병행 지원하도록 작업합니다.

 

컴포넌트 전환

이 프로젝트의 특이점은 대부분의 UI 컨트롤들을 자체제작해 사용했다는 것입니다. 하지만 대부분 기본 컨트롤을 기반으로 기능을 확장한 방식이었습니다. 따라서, 32-bit를 유지한 상태에서 델파이 2007에서 델파이 XE7로 마이그레이션 하는 과정에서 큰 이슈는 없었습니다.

 

그외 써드파티 컴포넌트들은 XE7을 지원하는 것들은 업그레이드 했고, 이벤트의 파라메터 데이터 타입이 변경되는 등의 작업정도로 진행했습니다.

그중 이슈는 오픈소스인 Toolbar2000의 경우 XE7을 지원하지 않았지만, 소스코드를 보유하고 있었기 때문에 소스코드를 컴파일 하며 문제가되는 부분을 직접 수정했습니다.(이후 64-bit 지원하도록 수정해 64-bit에서도 사용했습니다.)

 

데이터 엑세스 컴포넌트 변경

고객사는 Firebird를 DBMS로 사용했고, 데이터 엑세스 컴포넌트로 FIBPlus를 사용했지만, 델파이XE7에 내장된 효율적인 데이터 엑세스 컴포넌트인 FireDAC 사용을 원했습니다.

 

reFind(마이그레이션 자동화 도구)를 이용해 컴포넌트 및 속성, 메소드등을 자동전환 하는 패턴을 직접 만들어 일괄 변경했습니다.

 

이미지 라이브러리 교체

해당 프로젝트에서는 JPEG 라이브러리로 인텔사의 IJL을 사용했습니다.

하지만 IJL은 64-bit를 지원하지 않아 다른 JPEG 라이브러리가 필요했습니다.

델파이 내장 JPEG 라이브러리인 TJPEGImage를 시도해 봤지만, 저장 시 성능이 좋지 않아 JPEG 라이브러리 검토 후 libJPEG-Turbo로 교체했습니다.

 

64-bit 지원

대부분의 코드들은 64-bit에서도 정상 동작합니다.

하지만, 일부 데이터 타입의 경우 32-bit와 64-bit의 크기가 달라 문제가 생길 수 있습니다.

이번 프로젝트의 대표적인 문제는 다음과 같습니다.

  • 포인터로 사용하는 변수가 Integer(또는 LongInt)로 선언된 경우
  • 포인터로 사용하는 변수를 Integer(또는 LongInt)로 형변환 하는 경우
  • 윈도우(또는 소켓) 핸들을 Integer 또는 LongInt로 사용하는 경우

대응방법은

  • 포인터의 경우 데이터 타입을 Pointer 또는 NativeInt로 지정
    (NativeInt의 경우 32bit에서 4Byte, 64bit에서 8Byte로 사용 됨)
  • 윈도우의 핸들의 경우 THandle로 명시적으로 데이터 타입 지정
  • 소켓 핸들의 경우 TSocket으로 명시적으로 데이터 타입 지정

참고자료

 

기타 기능 추가

VCL 스타일 적용 : http://tech.devgear.co.kr/delphi_news/414834

다국어 지원 : http://tech.devgear.co.kr/delphi_news/408214

 

마지막으로, 

최근 사용자들은 윈도우10 등의 64-bit 운영체제를 많이 사용합니다.

32-bit 애플리케이션도 64-bit 운영체제에서 윈도우즈 호환성 모드를 통해 잘 작동합니다. 

하지만, 4GB 이상의 메모리를 사용해야 하거나 기타 메모리 이슈가 있다면, 64-bit 애플리케이션 개발을 검토하시기 바랍니다.

 

참고

데브기어의 마이그레이션 지원 서비스는 다음과 같이 3가지 플랜이 있습니다.

마이그레이션 무상 컨설팅

마이그레이션 체크리스트와 가이드 문서를 제공합니다. 작성 후 메일을 보내주시면 이메일과 방문을 통해 컨설팅을 지원합니다.

 

마이그레이션 워크샵(4일)

마이그레이션을 좀 더 효과적으로 직접 진행하고 싶다면, 워크샵 과정에 참석하세요. 마이그레이션 자동화 방안, 가이드 문서 작성 등을 배우고, 혼자 해결하기 어려운 부분을 멘토링을 통해 해결해 더 쉽고, 빠르게 마이그레이션 할 수 있습니다.

마이그레이션 컨설팅(유상)

마이그레이션 시의 위험요소 파악, 전환체계(자동화 방안, 마이그레이션 가이드 작성 등) 구축 등을 경험많은 마이그레이션 전문가를 통해 진행할 수 있습니다.

  • 별도로 요청해 주세요.. : ask@embarcadero.kr

 

번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 14387
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13023
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 15532
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 21064
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 22297
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 17933
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 38228
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 173741
170 [추가된 문법] DLL 정적 호출 시 지연 호출(Delayed)-델파이 2010 추가 김원경 2016.12.27 1090
169 부동소수점 숫자(실수)에 대한 참고 글 [1] 험프리 2016.12.14 1126
168 퀵레포트(Quick Report)에 사진 출력하기 험프리 2016.08.01 1849
167 BLOB 컬럼에 (이미지 등의)데이터 읽고 쓰기 험프리 2016.08.01 6073
166 1차 공개 중고생 강의용 앱 소스 및 메뉴얼입니다. file 쭈니아빠 2016.07.16 759
165 [추가된 문법 정리] - 배열 상수 초기화:델파이 XE7 추가 관리자 2016.06.03 3294
164 [추가된 문법 정리] - 클래스 필드(Class Field):델파이 2007 추가 관리자 2016.06.03 824
163 브레이크 포인트를 설정해도 디버깅이 안되는 경우 살펴볼 항목 file 험프리 2016.05.13 2789
162 OutputDebugString 함수로 디버그로그를 출력할 수 있습니다. file 험프리 2016.02.16 4221
161 [안드로이드] 배포파일, 아이콘, 스플래쉬 등이 잘 배포되었는지 확인하기 file 험프리 2015.11.11 1520
160 [다시보기] RAD Studio 10 시애틀 딥다이브 세션 다시보기(영문) Humphery 2015.10.02 549
159 [마이그레이션] 함수(또는 변수)에 빨간밑줄이 가고 컴파일 시 Undeclared Identifier 오류 시 조치방법 file 험프리 2015.09.30 2353
158 델파이 문서화 도구 참고링크 Humphery 2015.09.11 1149
157 [하이브리드 앱 개발] 웹페이지에서 델파이 함수 호출하기 Humphery 2015.06.26 4049
156 안드로이드 웹브라우저에서 "tel:, sms:" 링크가 동작하지 않는 이슈 해결하기 Humphery 2015.06.26 4805
155 [윈도우10] 델파이로 윈도우10 알림 표시하기(WinRT API 이용) Humphery 2015.06.24 2304
154 파이어닥(FireDAC)으로 IBLite 연결 시 "unavaliable database." 오류 발생에 대한 대응 file Humphery 2015.05.15 765
153 델파이에서 MSOffice 엑셀과 워드 연동 참고자료. [1] Humphery 2015.04.27 3748
152 [델파이7 이후 새로운 기능][XE2~] 프로젝트 매니저에서 타겟플랫폼을 64-bit Windows로 선택 해 64비트 애플리케이션을 개발할 수 있습니다. file Humphery 2015.04.23 4719
151 [델파이7 이후 새로운 기능] 추가되고 개선된 VCL 컴포넌트 Humphery 2015.04.22 3560