Skip to content

Latest commit

 

History

History
67 lines (44 loc) · 4.68 KB

using_xcodebuild.md

File metadata and controls

67 lines (44 loc) · 4.68 KB

xcodebuild docbuild 명령어로 문서 빌드 배포하기

xcodebuild 커맨드라인 도구(Command Line Tool)의 docbuild 명령어로 .doccarchive 파일 추출 및 정적 웹 호스팅을 위한 형태로 변형하는 과정.

1. 배경 및 목적

docc-plugin 의 경우 빌드 대상(build destination)이 macOS 으로 고정되어 있고 다른 대상으로 변경할 수 없습니다. 빌드 대상을 변경하고자 하는 경우 xcodebuild 커맨드라인 도구(Command Line Tool)의 docbuild 명령어를 사용해야합니다.

이 문서에서 xcodebuild 커맨드라인 도구를 사용해서 빌드 대상을 iOS 로 변경하여 DocC 프레임워크 기반 개발문서를 아카이브하고 더 나아가 정적 웹호스팅을 위한 형태로 변형하는 과정을 다뤄보겠습니다.

2. 진행 방법과 결과 데이터

2.1. 문서 아카이브 파일 생성 (.doccarchive)

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 을 포함시키는 것이 좋습니다.

2.2. 정적 호스팅을 위한 형태로 변형 (/docs)

$(xcrun --find docc) process-archive \
  transform-for-static-hosting /tmp/docbuild/Build/Products/Debug-iphoneos/{타겟이름}.doccarchive \
  --hosting-base-path {레포지토리_이름} \
  --output-path {저장위치}

xcrun --find doccdocc 도구를 실행시키는 명령어 입니다. process-archive 는 아카이브를 처리하는 docc 명령어 입니다.

옵션 설명 예시코드
transform-for-static-hosting2 호스팅 형태로 바꿀 .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

2.3. 빌드 결과물 처리

/docs 경로에 웹 호스팅이 가능한 파일들이 위치한 것을 알 수 있습니다. 과정2.1과정2.2 의 명령어들을 .sh 스크립트 파일로 저장해두면 GitHub Actions 로 배포3할 때 용이합니다.

3. 결론

xcodebuild 커맨드라인 도구에도 docc 에 대한 명령어들이 있어 문서를 빌드하고, 아카이브 파일을 정적 웹호스팅을 위한 형태로 변형할 수 있습니다.

docc-plugin 에서는 macOS로 고정되어 있는 빌드 대상을 변경할 수 없는 반면 xcodebuild 는 빌드 대상을 바꿀 수 있기 때문에 macOS 가 아닌 다른 플랫폼(예: iOS)만 지원하는 스위프트 패키지의 경우 xcodebuild 커맨드라인 도구를 사용하여 문서를 빌드할 수 있습니다.

4. 참고문헌

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.

3: https://github.com/jaesung-0o0/package-docc-example