한국어
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 89014
119 Qt로 데이터를 직렬화(serialization)하는 방법 makersweb 2020.08.04 2435
118 최초의 Qt 6.0 스냅샷 제공 (First Qt 6.0 Snapshot Available) j2doll 2020.06.21 834
117 Qt MQTT 에 대해서 file makersweb 2020.06.02 1262
116 Embedded Linux 에서 Qt 및 Graphics Stack file 운영자 2020.05.27 894
115 ShaderEffect QML Type을 이용한 버튼 클릭 효과 file makersweb 2020.05.22 1347
114 Qt기반의 서버와 클라이언트간 SOAP(Simple Object Access Protocol) file makersweb 2020.05.11 1222
113 재진입(Reentrancy) 및 스레드 안전성(Thread-Safety) makersweb 2020.04.19 1532
112 Qt 5.15 및 Qt 6의 출시 일정 makersweb 2020.04.09 1159
111 콘솔에서 사용자 입력받기 file makersweb 2020.03.22 52224
110 컨테이너 클래스 - QVector makersweb 2020.03.17 3179
109 Qt로 작성된 안드로이드 APP에 Splash Screen을 추가 file makersweb 2020.03.10 1118
108 QLabel의 텍스트 색과 배경색을 변경 makersweb 2020.02.25 7305
107 라즈베리파이4에 대한 Qt 5.14.1 크로스컴파일 [1] file makersweb 2020.02.12 4750
106 QOpenGLWidget 을 투명하게 적용 file makersweb 2020.02.05 1389
105 2020년에 변경되는 Qt 오퍼 (Qt offering changes 2020) [2] j2doll 2020.01.31 942
104 Qt로 XML 파싱 : Qt 6에서 업데이트된 (Parsing XML with Qt: Updates for Qt 6) [1] j2doll 2020.01.16 1203
103 Qt 멀티 스레드 프로그래밍 시 유의해야 할 몇 가지 makersweb 2020.01.13 5350
102 ApplicationWindow 와 메뉴바(MenuBar)구성 file makersweb 2020.01.04 1776
101 QThread 소개 및 예제 makersweb 2019.12.25 20627
» Qt의 오픈소스 라이센스 소개 file makersweb 2019.12.15 13360