QT_ADD_OPENAPI_CLIENT
제공된 OpenAPI 사양을 사용하여 HTTP 클라이언트를 생성합니다.
이 명령은 Qt6 패키지의 OpenApiTools 구성 요소에 정의되어 있습니다. 패키지를 로드합니다:
find_package(Qt6 REQUIRED COMPONENTS OpenApiTools)
이 명령은 Qt 6.11에 도입되었습니다.
참고: 이 명령은 기술 프리뷰 버전이며 향후 릴리스에서 변경될 수 있습니다.
개요
qt_add_openapi_client(<target> SPEC_FILE <file> [OUTPUT_DIRECTORY <dir>] [ADDITIONAL_PROPERTIES property1=value1 property2=value2 ...] [GENERATE_OPTIONS generate_option1 generate_option2 ...] [JAVA_OPTIONS jvm_option1 jvm_option2 ...] [GENERATE_DOCUMENTATION] [DOCUMENTATION_OUTPUT_DIRECTORY <dir>] [OUTPUT_PUBLIC_HEADERS_DIR <dir>] [OUTPUT_PRIVATE_HEADERS_DIR <dir>] )
버전 없는 명령을 사용할 수 없는 경우 qt6_add_openapi_client() 을 대신 사용합니다. 이 명령과 동일한 인수 집합을 지원합니다.
설명
qt_add_openapi_client 함수는 제공된 사양 파일에 대한 Qt OpenAPI 생성기를 호출합니다. 결과적으로 이 명령은 소스 파일의 범위를 생성하고 대상 소스 목록에 추가합니다. 타깃이 존재하지 않으면 오류 메시지와 함께 생성이 중지됩니다. 대상을 생성하려면 qt_add_library 또는 qt_add_executable 함수를 호출할 수 있습니다.
참고: 현재 client 코드 생성만 지원됩니다.
인수
SPEC_FILE코드 생성에 필수인 OpenAPI 사양 파일을 지정합니다. 파일의 확장자는*.yaml여야 합니다.OUTPUT_DIRECTORY생성된 코드의 출력 디렉터리를 지정합니다. 지정하지 않으면CMAKE_CURRENT_BINARY_DIR가 사용됩니다.ADDITIONAL_PROPERTIES생성 명령에 대한 추가 구성 속성을 지정합니다. 이 속성은 유효성 검사 없이 OpenAPI 생성기에 있는 그대로 전달됩니다.GENERATE_OPTIONS생성 명령에 전달되는 추가 옵션을 지정합니다.GENERATE_OPTIONS을 통해 전달된-i및--input-spec인수는 무시됩니다. OpenAPI 사양 파일은SPEC_FILE인수를 사용하여 독점적으로 설정됩니다.GENERATE_OPTIONS을 통해 전달된-o및--output인수는 무시됩니다. 출력 디렉토리는OUTPUT_DIRECTORY인수를 사용하여 독점적으로 설정됩니다.JAVA_OPTIONSOpenAPI 생성기를 호출할 때 JVM에 전달되는 추가 옵션을 지정합니다. 이를 사용하여 JVM 동작을 구성합니다. 옵션은 유효성 검사 없이 그대로 전달됩니다.GENERATE_DOCUMENTATION생성된 클래스에 대한doxygen문서 생성을 활성화합니다.DOCUMENTATION_OUTPUT_DIRECTORYdoxygen문서를 저장할 디렉터리를 지정합니다. 이 옵션은GENERATE_DOCUMENTATION와 함께만 사용할 수 있습니다.OUTPUT_PUBLIC_HEADERS_DIR생성된 공개 헤더 목록을 저장할 디렉터리를 지정하며, 그렇지 않으면OUTPUT_DIRECTORY에서 헤더를 찾을 수 있습니다.OUTPUT_PRIVATE_HEADERS_DIR는 생성된 비공개 헤더 목록을 저장할 디렉터리를 지정하며, 그렇지 않으면OUTPUT_DIRECTORY에서 헤더를 찾을 수 있습니다.
생성 동작 사용자 지정
GENERATE_OPTIONS 및 ADDITIONAL_PROPERTIES 인수를 사용하면 업스트림 OpenAPI 생성기와 Qt 생성기 플러그인의 동작을 모두 사용자 정의할 수 있습니다.
아래 예제는 프로젝트에서 두 인수를 함께 사용하는 방법을 보여줍니다:
qt6_add_openapi_client(ClientExample
SPEC_FILE
${CMAKE_CURRENT_SOURCE_DIR}/example.yaml
ADDITIONAL_PROPERTIES
cppNamespace=ExampleNamespace
modelNamePrefix=Example
GENERATE_OPTIONS
--skip-overwrite
--api-name-suffix MyApiSuffix
)생성기 인수의 동작과 지원되는 값은 설치된 OpenAPI 생성기 버전에 따라 다르며 버전 간에 변경될 수 있습니다.
두 가지 방법으로 추가 구성 속성을 제공할 수 있습니다:
ADDITIONAL_PROPERTIES인수를 사용합니다.GENERATE_OPTIONS인수에-p또는--additional-properties전달.
두 가지를 동시에 사용하면 예기치 않은 결과가 발생할 수 있습니다. 한 가지 방법을 선택하는 것이 좋습니다.
참고: 일부 추가 속성에는 재정의할 수 없는 고정 값이 있습니다. 이러한 값을 재정의하려고 하면 해당 값이 무시됩니다. 예를 들어 packageName 추가 속성은 함수의 <target> 매개변수에 해당하며 수정할 수 없습니다.
JVM 동작 사용자 지정하기
다음 예는 JAVA_OPTIONS 을 사용하여 대용량 사양 파일에 대한 YAML 파서 제한을 늘리고 로그 출력을 경고로만 줄이는 방법을 보여줍니다:
qt6_add_openapi_client(ClientExample
SPEC_FILE
${CMAKE_CURRENT_SOURCE_DIR}/example.yaml
JAVA_OPTIONS
-DmaxYamlCodePoints=99999999
-Dlog.level=warn
)© 2026 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.