I'm following an internet tutorial on Firebase and as part of it, I had to do some work on the command line. I'm pretty comfortable with the command line, but I'm unfamiliar with Cocoapods. I ran pod repo update
but after doing so I realized I ran it on my entire Documents folder of my Mac instead of the folder that contained my project. I took over 20 mins to execute and it printed out literally thousands of things when it finally completed, some of which included "create" and "deleted". I was kind of concerned- would run this command have modified anything in my Documents besides the Firebase project? And what does pod repo update
even do for that matter?
As per the documentation pod repo update updates the spec repos located at ~/.cocoapods/repos
in your home folder.
Updates the local clone of the spec-repo NAME. If NAME is omitted this will update all spec-repos in ~/.cocoapods/repos.
The repo
is basically a list of all pods and versions available. I have just encountered an error in our CI builds because the repo did not include a spec for a library I have just added. By running pod repo update
it now knows of this newer version and can continue to install it.
So to answer your question.. Running pod repo update
in your documents folder will not do anything in that folder. It will update its pod spec references in your ~/.cocoapods/repos
folder only.
~/.cocoapods/repos
folder. So when you install it it will get the current list of pods/libraries available. a few months down the line and say Swift updates to a new version, then you want the updated pod that supports that swift version. but your local cocoapods does not know about this updated version. so you run pod repo update and cocoapods updates its list of libraries available –
Blastema The main Specs repo is nothing but a list of ALL PodSpecs. A PodSpec is:
A specification describes a version of Pod library. It includes details about where the source should be fetched from [which tag or commit or branch], what files to use, the build settings to apply, and other general metadata such as its name, version, and description.
Each version of the PodSpec is under a tag directory. The repo doesn't contain the pod itself. The repo contains the PodSpec. The PodSpec gives the location of the repo and a bunch of other meta data⚡︎
spec.source = { :git => 'https://github.com/tonymillion/Reachability.git', :tag => 'v3.1.0' }
When you do pod repo update
, you're pulling the latest PodSpecs (not the actual pod) from https://github.com/CocoaPods/Specs. If you want to only update an individual pod source, then just do pod repo update [NAME]
Cocoapods/Specs master repo:
The list of some Alamofire PodSpecs
A single PodSpec 4.7.3:
⚡︎: PodSpec: A specification describes a version of Pod library. It includes details about where the source should be fetched from, what files to use, the build settings to apply, and other general metadata such as its name, version, and description.
Your actual project pulls in the code through either pod update
or pod install
then the physical files get downloaded to your mac and copied for your project.
Often you'd get this error:
None of your spec sources contain a spec satisfying the dependencies:
AlamoFire (= 11.0.3), AlamoFire (= 11.0.3)
.You have either: * out-of-date source repos which you can update with
pod repo update
or withpod install --repo-update
. * mistyped the name or version. * not added the source repo that hosts the Podspec to your Podfile.
Spec sources is what's important. It just means you haven't pulled in the specs.
You can easily see spec sources you have by doing pod repo
. Mine is:
cocoapods
- Type: git (remotes/origin/master)
- URL: https://github.com/CocoaPods/Specs.git
- Path: /Users/mfaani/.cocoapods/repos/cocoapods
private_pods
- Type: git (master)
- URL: [email protected]:xyz/private_Cocoapods.git
- Path: /Users/mfaani/.cocoapods/repos/private_cocoapods
trunk
- Type: CDN
- URL: https://cdn.cocoapods.org/
- Path: /Users/mfaani/.cocoapods/repos/trunk
© 2022 - 2024 — McMap. All rights reserved.