xcodebuild
커맨드라인 도구(Command Line Tool)의 docbuild
명령어로 .doccarchive
파일 추출 및 정적 웹 호스팅을 위한 형태로 변형하는 과정.
docc-plugin
의 경우 빌드 대상(build destination)이 macOS 으로 고정되어 있고 다른 대상으로 변경할 수 없습니다.
빌드 대상을 변경하고자 하는 경우 xcodebuild
커맨드라인 도구(Command Line Tool)의 docbuild
명령어를 사용해야합니다.
이 문서에서 xcodebuild
커맨드라인 도구를 사용해서 빌드 대상을 iOS 로 변경하여 DocC 프레임워크 기반 개발문서를 아카이브하고 더 나아가 정적 웹호스팅을 위한 형태로 변형하는 과정을 다뤄보겠습니다.
xcodebuild docbuild -scheme BoxOffice \
-derivedDataPath /tmp/docbuild \
-destination 'generic/platform=iOS'
docbuild
는 문서 아카이브 (.doccarchive
) 파일을 생성하는 명령어1 입니다. docbuild
의 옵션은 다음과 같습니다.
옵션 | 설명 | 예시 코드 |
---|---|---|
-scheme {스킴이름} |
문서 빌드를 하고자하는 스킴 | -scheme MyPackage |
-derivedDataPath {아카이브저장위치} |
저장 위치. 필수는 아니지만 이 옵션을 포함하면 .doccarchive 번들을 찾을 때 용이. |
-derivedDataPath /tmp/docbuild |
-destination {플랫폼} |
빌드 destination | -destination 'generic/platform=iOS' |
Tip
-destination
옵션 설정 시generic/platform=iOS
에서generic
을 제외시키면 모든 iOS 시뮬레이터로 빌드하기 때문에 긴 빌드 시간이 > 소요되었습니다. 따라서 특정 시뮬레이터들을 돌려야 하는 경우가 아니면generic
을 포함시키는 것이 좋습니다.
$(xcrun --find docc) process-archive \
transform-for-static-hosting /tmp/docbuild/Build/Products/Debug-iphoneos/{타겟이름}.doccarchive \
--hosting-base-path {레포지토리_이름} \
--output-path {저장위치}
xcrun --find docc
는 docc
도구를 실행시키는 명령어 입니다. process-archive
는 아카이브를 처리하는 docc
명령어 입니다.
옵션 | 설명 | 예시코드 |
---|---|---|
transform-for-static-hosting 2 |
호스팅 형태로 바꿀 .doccarchive 파일 위치 |
transform-for-static-hosting /tmp/docbuild/Build/Products/Debug-iphoneos/BoxOffice.doccarchive |
--hosting-base-path {호스팅경로} |
호스팅할 주소의 base 경로 값. 깃헙페이지의 경우 레포지토리 이름. | --hosting-base-path my-repository-name |
`--output-path {결과물저장위치} | 결과물 저장 위치. (/docs 로 하는 것을 권장) |
--output-path ./docs |
/docs
경로에 웹 호스팅이 가능한 파일들이 위치한 것을 알 수 있습니다. 과정2.1 과 과정2.2 의 명령어들을 .sh
스크립트 파일로 저장해두면 GitHub Actions 로 배포3할 때 용이합니다.
xcodebuild
커맨드라인 도구에도 docc 에 대한 명령어들이 있어 문서를 빌드하고, 아카이브 파일을 정적 웹호스팅을 위한 형태로 변형할 수 있습니다.
docc-plugin
에서는 macOS로 고정되어 있는 빌드 대상을 변경할 수 없는 반면 xcodebuild
는 빌드 대상을 바꿀 수 있기 때문에 macOS 가 아닌 다른 플랫폼(예: iOS)만 지원하는 스위프트 패키지의 경우 xcodebuild
커맨드라인 도구를 사용하여 문서를 빌드할 수 있습니다.
1: https://developer.apple.com/documentation/xcode/distributing-documentation-to-external-developers, Apple, Inc.
2: https://apple.github.io/swift-docc-plugin/documentation/swiftdoccplugin, Apple, Inc.