한국어
Qt
 

Qt의 라이센스는 프로젝트 상황에 맞도록 크게 두가지 선택지를 제공한다. 각각의 특징들과 오픈소스 라이센스 Qt를 사용할 때 생기는 몇가지 오해를 소개한다.

 
첫번째로 커머셜(commercial) 라이센스는 Qt 소스코드의 사용, 개발에 조건 없이 사용할 수 있으며 외부에 공개하고 싶지 않은 프로젝트, 독점적인 소프트웨어를 개발 할 수 있다. 커머셜 라이센스를 구매하기전 프로젝트에서 필요로 하는 모듈 또는 솔루션을 사용할 수 있는지와 프로젝트 규모에 따라 달라지는 부분도 고려해야 할 것이다.
 
다른 하나는 GNU LGPL (LGPL) 버전 3에 따라 라이센스가 부여 된 오픈소스 라이센스이다. LGPL은 GPL 라이센스의 강력한 카피레프트 조건을 다소 완화한 라이센스로 이 라이센스의 약관을 준수 할 수 있는 소프트웨어를 개발 할 수 있다. 다만 오픈소스 라이센스 Qt의 경우 GNU LGPL v3에서는 일부 모듈을 사용할 수 없고 GNU 일반 공개 라이선스(GPL)에 따라 사용할 수 있다. Qt 5.14 기준으로 다음과 같은 툴, 모듈, 에드온들은 GPLv3라이센스로 제공된다.
 
• Qt Charts
• Qt CoAP
• Qt Data Visualization
• Qt Device Utilities
• Qt KNX
• Qt Lottie Animation
• Qt MQTT
• Qt Network Authentication
• Qt Quick WebGL
• Qt Virtual Keyboard
• Qt Wayland Compositor
• Qt Application Manager 
• Qt PDF
• Qt Creator 
• Qt for WebAssembly
 
Qt 6 기준 상용 라이센스 또는 GPL v3에 따라 사용 가능한 애드온 
 

GNU.png

 

몇 가지 오해
 

오픈소스 라이센스 Qt를 사용하면 내가 개발한 소스코드를 공개해야한다?

위에 언급한 몇가지 GPL라이센스 도메인을 제외하고 LGPL라이센스 라이브러리를 응용프로그램에서 동적(dynamic) 또는 정적(static)으로 링크 시켜 사용하는 경우, 응용프로그램의 소스코드 공개 의무는 발생하지 않는다. (정적 링크에서는 응용프로그램의 오브젝트 코드를 사용자에게 제공의무가 발생한다.) 다만 어떤 링크방법이든 Qt 소스코드를 수정하면 수정한 Qt소스코드는 공개해야하고 Qt 소스코드와 응용프로그램 소스코드를 결합하여 컴파일하는 경우도 전체 소스코들 공개의무가 발생한다.

 

오픈소스 라이센스 Qt를 사용하면 상업용 프로그램을 개발할 수 없다?

GPL이든 LGPL라이센스든 상업적으로 이용할 수 있다. 그러나 GPL라이센스 오픈소스를 사용하면 무조건 소스코드 공개해야 하는 것과 까다로운 의무가 따르므로 상업용 소프트웨어 개발에서는 꺼리기 마련이다.

 
 
다음은 해외 커뮤니티 사이트에서 Qt와 LGPL 라이센스에 대해서 비교적 잘 이해하고 있는 사람의 글을 일부 가져온 것이다.

 

라이선스 비용을 지불하지 않고 상용 비공개 소스 제품에서 Qt를 사용하고 싶다면 LGPL 버전을 사용하면 쉽게 할 수 있습니다.

  1. 상용 버전을 구입하지 마십시오.
  2. Qt 라이브러리의 소스 코드를 변경하지 마십시오. 그대로 사용하십시오.
  3. 링크 지침과 함께 정적으로 또는 동적으로 링크된 오브젝트 파일에 대한 액세스를 제공할 수 있어야합니다. 정적 링크와 동적 링크는 LGPL에서 중요하지 않습니다. LGPL은 사용자가 직접 오픈 소스 라이브러리 소스 코드에 대한 액세스 권한과 수정하고 이를 비공개 소스 오브젝트 파일에 링크하여 바이너리를 생성 할 수 있어야합니다.

상용 코드를 commercial.o로 컴파일 한 다음 LGPL 코드를 lgpl.o로 컴파일하여 단일 바이너리로 링크합니다.

ld -o binary  lgpl.o commercial.o -lc

소프트웨어를 제공 할 때 바이너리(오브젝트파일)를 함께 보내고, 링크 지침과 함께 commercial.o 및 LGPL 라이센스 소스 코드에 대한 액세스를 제공합니다. 사용자는 이제 Qt의 LGPL 버전을 조작하고 lgpl.o로 컴파일하고 소스 코드에 액세스하지 않고도 commercial.o에 링크 할 수 있습니다. (참고 : 물론 LGPL에서 Qt를 수정할 수도 있습니다. 하지만 포크를 직접 유지 관리해야하며 일반적으로 그렇게하고 싶지 않을 것입니다.)

 
참조 사이트 : 

https://news.ycombinator.com/item?id=23321448

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 86136
119 Q_D매크로와 d-pointer file makersweb 2019.05.07 761
118 Qt기반의 오픈소스 프로젝트들 makersweb 2019.05.15 5454
117 QtSerialPort를 사용한 시리얼(Serial)통신 [3] makersweb 2019.05.21 11957
116 QML에서 멀티 스레드(multithreading) 프로그래밍 file makersweb 2019.05.25 2673
115 QtCreator Design으로 GUI만들기 (QML로 만드는 Hello World -2) [1] file makersweb 2019.05.26 14961
114 QtInstallerFramework로 온라인 설치프로그램(Online Installer)만드는 방법 [4] file makersweb 2019.05.28 6272
113 QML 강좌 - 동적 Listing (ListView) file makersweb 2019.06.01 10118
112 Qt Quick Controls 2사용 및 스타일 설정 file makersweb 2019.06.07 6278
111 Qt Creator에서 임베디드 장치로 deploy설정(Custom Process Step) file makersweb 2019.06.15 2205
110 QML, 이미지, 폰트등을 바이너리 리소스로 만들기 makersweb 2019.06.24 3525
109 Qt기반의 오픈소스 프로젝트들 - 2 운영자 2019.07.21 4017
108 [Qt] Google Play의 향후 요구 사항을 준수하는 방법 [2] j2doll 2019.07.29 977
107 [Qt News] Qt6 Git 개발 초기 단계 시작하기 j2doll 2019.08.02 2337
106 [Qt News] Qt 6 기술 비전 (Technical vision for Qt 6) [2] j2doll 2019.08.08 2121
105 열거형(enum)을 QML에서 사용하는 방법과 문자열(QString)로 얻기 makersweb 2019.08.20 3897
104 [Qt News] Qt for Python을 위한 기술 비전 j2doll 2019.08.20 1626
103 MCU용 Qt에 대해서 makersweb 2019.08.22 1921
102 QSocketNotifier로 파일 디스크립터의 활동감지 makersweb 2019.08.28 1735
101 C++로 구현된 모델을 QML의 ListView에서 참조 file makersweb 2019.09.07 4935
100 컨테이너에 적재된 객체를 편리하게 삭제하기 makersweb 2019.09.18 1670