본문 바로가기

iOS/iOS (응용)

[iOS] SwiftPM - SwiftPackage

1️⃣ Swift Package & Swift Package Manager


🤔 Swift Package란?

코드 모듈을 재사용 가능하고 쉽게 배포할 수 있도록 만든 구조화된 패키지입니다.

패키지를 사용하면 코드의 재사용성을 높이고, 의존성을 쉽게 관리하며, 프로젝트의 유지 보수를 용이하게 할 수 있습니다.

패키지는 Swift 소스파일과 Package.swift라는 매니페스트파일로 구성됩니다.

Package.swift는 PackageDescription 모듈을 사용하여 패키지 이름과 내용을 정의합니다.

패키지는 하나 이상의 Target이 존재하고, 각각의 Target은 Product를 지정하고 하나 이상의 의존성을 선언할 수 있습니다.

 

🤔 Swift Package Manager(SwiftPM)란?

Swift Package Manager는 Swift 코드의 "패키지" 배포 및 사용을 관리하는 도구입니다. 이 도구는 Swift 빌드 시스템과 통합되어 의존성을 다운로드, 컴파일, 링크하여 타겟 제품에 자동으로 통합하는 과정을 자동화합니다.

SwiftPM은 패키지 생성 및 관리, 버전 관리, 의존성 관리, 빌드 및 테스트 등을 쉽게 수행할 수 있도록 도와주는 Apple에서 공식적으로 지원하는 도구입니다.

SwiftPM은 2016년 공개되었습니다. 이전에는 코코아팟이나 카르타고와 같은 third-party도구를 이용했습니다.

기존에는 터미널에서 Package를 생성하였지만 2019년부터 Xcode에서 지원을 시작했습니다.

SwiftPM은 Swift 3.0 이상, Xcode 11 이상부터 포함되어 있습니다.

 

🔗 Swift Package Community 이 링크에서 다양한 용도의 패키지를 추천받을 수 있습니다.

🔗 Swift Package Index에서 원하는 패키지를 검색할 수 있습니다.

 

Swift Package 만들기


Swift 패키지를 만드는 것은 개인적인 용도로, 회사 내에서 개인적으로 사용하기 위해 코드를 모듈화하거나 나머지 Swift 커뮤니티가 사용할 수 있도록 오픈 소스 패키지를 릴리스하는 좋은 방법입니다.

 

추가 링크

 

 

 

  1. Swift 설치
# 명령어를 실행하여 설치여부를 확인합니다.
$ swift --version

 

 

2. SwiftPM을 사용하여 새로운 프로젝트를 생성

# 새로운 프로젝트 생성 
$ swift package init --name <프로젝트명> --type <타입명>
  • <프로젝트명>: 생성할 패키지의 이름을 입력합니다.
  • <타입명>: 패키지의 타입을 지정합니다.
    • library 또는 executable 중 하나를 선택할 수 있습니다. library는 다른 Swift코드로 가져올 수 있는 모듈이 포함되어 있고, executable은 운영체제에서 실행할 수 있는 프로그램입니다.

3. Sources/<프로젝트명>/<프로젝트명>.swift 초기소스파일에서 코드를 작성합니다.

 

4. Sources/<프로젝트명>Tests/<프로젝트명>Tests.swift 파일에서 테스트코드를 작성합니다.

 

5. 테스트 실행

# 명령어를 실행하여 테스트를 실행합니다.
$ swift test

 

6. Swift Pacakge Index에 추가

 

몇가지 요구사항을 충족하면 SPI에 추가할 수 있습니다.

  • 패키지 저장소는 모두 공개적으로 접근가능해야 합니다.
  • 패키지는 루트 폴더에 유효한 Package.swift 파일을 포함해야 합니다.
  • 패키지는 Swift 5.0 이상으로 작성되어야 합니다.
  • 패키지에는 버전 태그가 지정된 릴리스가 하나 이상 있어야 합니다.
  • 최신 Swift 툴체인을 사용하여 swift package dump-package을 실행할 때 패키지는 모두 유효한 JSON을 출력해야 합니다.
  • 패키지 URL에는 프로토콜(일반적으로 https )과 .git 확장자가 포함되어야 합니다.
  • 패키지는 모두 오류 없이 컴파일되어야 합니다.
  • 모든 패키지 내용물은 🔗 code of conduct을 준수해야 합니다.

요구사항을 충족하고 🔗 PackageList로 이동하여 Add Package 클릭

 

 

Swift Package 구조


 

.
├── Package.swift
├── Sources
│   └── MyLibrary
│       └── MyLibrary.swift
└── Tests
    └── MyLibraryTests
        └── MyLibraryTests.swift

Package.swift은 Swift의 매니페스트 파일입니다. 프로젝트의 메타데이터와 종속성을 보관하는 곳입니다.

Sources/MyLibrary/MyLibrary.swift은 라이브러리 초기 소스 파일이며 라이브러리 코드를 작성할 곳입니다. Test/MyLibraryTests/MyLibraryTests.swift은 라이브러리에 대한 테스트를 작성할 수 있는 곳입니다.

 

🔗 참고링크


 

Swift Package Manager 적용기 - tech.kakao.com

안녕하세요! 카페앱개발파트에서 iOS 개발을 하고 있는 셀린(Celine.jin)...

tech.kakao.com