To install or update CocoaPods see this guide.
To install release candidates run [sudo] gem install cocoapods --pre
-
Give a meaningful message for the case where there is no available stable version for a pod, and user do not explicitly specify the required version. Muhammed Yavuz Nuzumlalı #4197
-
Use watchsimulator when validating pods with the watchOS platform. Thomas Kollbach #4130
-
C or C++ preprocessor output files with
.i
extension now have their compiler flags set correctly.
Andrea Aresu -
Remove SDKROOT relative search path as it isn't needed anymore since XCTest.
Boris Bügling #4219 -
Podfile generated by
pod init
now specifies iOS 8.0 as the default platform and includesuse_frameworks!
for Swift projects. Jamie Evans
-
Using vendored frameworks without a
Headers
directory will no longer cause a crash.
Samuel Giddins #3967 -
Computing the set of transitive dependencies for a pod target, even if the target is scoped, will no longer smash the stack.
Samuel Giddins #4092 -
Take into account a specification's
exclude_files
when constructing resource bundles.
Samuel Giddins #4065 -
Fix resolving to platform-compatible versions of transitive dependencies.
Samuel Giddins #4084
- This release fixes a file permissions error when using the RubyGem.
Samuel Giddins
- Ensure all gem files are readable.
Samuel Giddins #4085
- The
HEADER_SEARCH_PATHS
will no longer be constructed recursively.
Samuel Giddins twoboxen #1437 #3760
-
Collapse the namespaced public and private pod xcconfig into one single xcconfig file.
Marius Rackwitz #3916 -
Add
--sources
option topush
command.
Dimitris Koutsogiorgas #3912 -
Implicitly unlock all local dependencies when installing.
Samuel Giddins #3764 -
The resolver error message when a conflict occurred due to platform deployment target mismatches will now explain that.
Samuel Giddins #3926 -
Add
:source_provider
hook to allow plugins to provide sources.
Eric Amorde #3190 #3792 -
Remove embed frameworks build phase from target types, where it is not required.
Marius Rackwitz #3905 #4028 -
Add a
--private
option topod spec lint
,pod lib lint
, andpod repo push
that will ignore warnings that only apply to public specifications and sources.
Samuel Giddins Core#190 #2682 -
Add support for dynamic
vendored_frameworks
andvendored_libraries
.
Samuel Giddins #1993
-
Build settings specified in
pod_target_xcconfig
of a spec are also for library targets only applied to the pod target.
Marius Rackwitz #3906 -
Use APPLICATION_EXTENSION_API_ONLY for watchOS 2 extensions.
Boris Bügling #3920 -
Prevent copying resources to installation directory when
SKIP_INSTALL
is enabled.
Dominique d'Argent #3971 -
Embed frameworks into app and watch extensions.
Boris Bügling #4004 -
Fix missing
$(inherited)
for generated xcconfigLIBRARY_SEARCH_PATHS
andHEADER_SEARCH_PATHS
build settings.
Tyler Fox #3908 -
Fix source locking/unlocking.
Samuel Giddins #4059 -
Include the
-ObjC
linker flag when staticvendored_frameworks
are present.
Samuel Giddins #3870 #3992
-
Fix generation of xcconfig files that specify both
-iquote
and-isystem
headers.
Russ Bishop #3893 -
Pods integrated as static libraries can no longer be imported as modules, as that change had unexpected side-effects.
Boris Bügling #3898 #3879 #3888 #3886 #3889 #3884 -
Source file locking now happens after plugin and podfile post-install hooks have run.
Samuel Giddins #3529 -
Only set project, dylib, and compatibility versions to valid, three integer values.
Samuel Giddins #3887
-
Set project, dylib, and compatibility versions when building pods as frameworks.
Marius Rackwitz -
Pods integrated as static libraries can now be imported as modules.
Tomas Linhart #3874
-
Ensure the aggregate
.xcconfig
file only has the settings for the appropriate build configuration.
Samuel Giddins #3842 -
Show the correct error when
pod spec lint
finds multiple podspecs, and at least one of them fails linting.
Samuel Giddins #3869 -
Set header search paths properly on the user target when
vendored_libraries
Pods are used while integrating Pods as frameworks.
Jonathan MacMillan #3857 -
Only link public headers in the sandbox for Pods that are not being built into dynamic frameworks, when integrating Pods as frameworks.
Jonathan MacMillan #3867 -
Don't lock resource files, only source files.
Mason Glidden #3557 -
Fix copying frameworks when integrating with today extensions.
Samuel Giddins #3819
- Improve the message shown when trying to use Swift Pods without frameworks.
Now it includes the offending Pods so that the user can take action to remove
the Pods, if they don’t want to move to frameworks yet.
Eloy Durán #3830
- Properly merge the
user_target_xcconfig
s of multiple subspecs.
Samuel Giddins #3813
-
The resolver will now take supported platform deployment targets into account when resolving dependencies.
Samuel Giddins #2443 -
Pods.xcodeproj
will now be written with deterministic UUIDs, vastly reducing project churn and merge conflicts. This behavior can be disabled via the newCOCOAPODS_DISABLE_DETERMINISTIC_UUIDS
environment variable.
Samuel Giddins -
cocoapods-stats
is now a default plugin.
Samuel Giddins
-
Ensure that the
prepare_command
is run even when skipping the download cache.
Samuel Giddins #3674 -
Public headers inside a directory named
framework
should be linked in the sandbox.
Vincent Isambart #3751 -
Properly support targets with spaces in their name in the embed frameworks script.
Samuel Giddins #3754 -
Don't add the
-ObjC
linker flag if it's unnecessary.
Samuel Giddins #3537 -
Ensure that no duplicate framework or target dependencies are created.
Samuel Giddins #3763
-
De-duplicate Pod Targets: CocoaPods now recognizes when a dependency is used multiple times across different user targets, but needs to be built only once. The targets in
Pods.xcodeproj
need to be duplicated when one of the following applies:- They are used on different platforms.
- They are used with differents sets of subspecs.
- They have any dependency which needs to be duplicated.
You can opt-out of this behavior installation-wise, by setting the following option in your ``~/.cocoapods/config.yaml`:
deduplicate_targets: false
-
The CocoaPods environment header has been removed.
Samuel Giddins #2390 -
The
Installer
is passed directly to thepre_install
andpost_install
hooks defined in the Podfile, instead of the previously usedHooks::InstallerRepresentation
.
Marius Rackwitz #3648 -
Deprecate the
xcconfig
attribute in the Podspec DSL, which is replaced by the new attributespod_target_xcconfig
anduser_target_xcconfig
.
Marius Rackwitz CocoaPods#3465
-
The notice about a new version being available will now include our recommendation of using the latest stable version.
Hugo Tunius #3667 -
New commands
pod cache list
andpod cache clean
allows you to see the contents of the cache and clean it.
Olivier Halligon #3508 -
The download cache will automatically be reset when changing CocoaPods versions.
Samuel Giddins #3542 -
Supports running pre-install hooks in plugins. This happens before the resolver does its work, and offers easy access to the sandbox, podfile and lockfile via a
PreInstallHooksContext
object. This also renames the post-install hooks fromHooksContext
toPostInstallHooksContext
.
Orta Therox #3540 -
Allow passing additional arguments to
pod lib create
, which then get passed as-is to theconfigure
scripts.
Samuel Giddins #2160 -
Use
-analyzer-disable-all-checks
to disable static analyzer for pods withinhibit_warnings
enabled (requires Xcode >= 6.1).
Dieter Komendera #2402 -
Cache globbing in
PathList
to speed uppod install
.
Vincent Isambart #3699 -
CocoaPods will validate your podfile and try to identify problems and conflicts in how you've specified the dependencies.
Hugo Tunius #995 -
pod update
will now accept root pod names, even when only subspecs are installed.
Samuel Giddins #3689 -
Support for the new
watchos
platform.
Boris Bügling #3681
-
Added recursive support to the public headers of vendored frameworks that are automatically linked in the sandbox. This fixes and issue for framework header directories that contain sub-directories.
Todd Casey #3161 -
Public headers of vendored frameworks are now automatically linked in the sandbox. That allows transitive inclusion of headers from other pods.
Vincent Isambart #3161 -
Fixes an issue that prevented static libraries from building.
OTHER_LIBTOOLFLAGS
is no longer set to the value ofOTHER_LDFLAGS
. If you want to create a static library that includes all dependencies for (internal/external) distribution then you should use a tool likecocoapods-packager
.
Michael Moscardini #2747 #2704 -
The embed frameworks script will now properly filter out symlinks to the directories that are filtered, which fixes an issue when submitting to the Mac App Store.
Samuel Giddins -
The error report template is now more robust against missing executables.
Samuel Giddins #3719 -
Attempting to specify a
git
source where a Podspec for the requested pod is not found will have a more helpful error message.
Samuel Giddins -
pod outdated
will now accept the--no-repo-update
and--no-integrate
options.
Samuel Giddins -
Fixes an issue which prevented using a custom
CONFIGURATION_BUILD_DIR
when integrating CocoaPods via dynamic frameworks.
Tim Rosenblatt #3675 -
Pods frameworks in codesigned Mac apps are now signed.
Nikolaj Schumacher #3646
-
Schemes of development pods will now be shared.
Boris Bügling #3600 -
Recognizes incomplete cache when the original download of a pod was interrupted.
Marius Rackwitz #3561 -
Allow opting out of pod source locking, meaning
pod try
yields editable projects.
Samuel Giddins cocoapods-try#31
-
pod repo push
will now find and push JSON podspecs.
#3494 Kyle Fuller -
Flush stdin/stderr and wait a bit in
executable
.
Boris Bügling #3500
-
[Cache] Fixes a bug that caused that a pod, which was cached once is not updated correctly when needed e.g. for
pod spec lint
.
Marius Rackwitz #3498 -
Only add the "Embed Pods Frameworks" script for application and unit test targets.
Marius Rackwitz #3440 -
C++ source files with
.cc
,.cxx
and.c++
extensions now have their compiler flags set correctly.
Chongyu Zhu Kyle Fuller -
Handle broken symlinks when installing a Pod.
Daniel Barden #3515 -
Just remove write permissions from files, so executables are unaffected.
Mason Glidden #3501 -
Always copy the generated
Podfile.lock
toPods/Manifest.lock
so they are guaranteed to match, character-by-character, after installation.
Samuel Giddins #3502 -
Don't generate an umbrella header when a custom module map is specified. This avoids an incomplete module map warning.
Samuel Giddins -
Actually allow skipping the download cache by downloading directly to the download target when requested.
Samuel Giddins
For more details, see 📝 CocoaPods 0.37 on our blog.
- Print the UTF-8 warning to STDERR.
Matt Holgate
-
Handle caching specs that have subspecs with higher minimum deployment targets without deleting needed source files.
Samuel Giddins #3471 -
Automatically detect JSON podspecs in
pod lib lint
.
Samuel Giddins #3477
-
Add environment variable
COCOAPODS_SKIP_UPDATE_MESSAGE
to disable new version message.
Andrea Mazzini #3364 -
Use user project's object version for pods project.
Boris Bügling #253
-
Adding
$(inherited)
toFRAMEWORK_SEARCH_PATHS
build setting in xcconfig for aggregate.
Tomohiro Kumagai #3429 -
Don't crash when the downloader can't find an appropriate podspec in a
git
pod.
Samuel Giddins #3433 -
Automatically lock Pod source files after installing.
Mason Glidden #1154 -
Handle subprocesses leaking STDOUT/STDERR pipes by more strictly managing process lifetime and not allowing I/O to block completion of the task.
Samuel Giddins #3101 -
Do not create pod target if
source_files
only contains headers.
Boris Bügling #3106 -
Run a pod's
prepare_command
(if it has one) before it is cleaned in the download cache.
Marius Rackwitz Samuel Giddins #3436 -
Don't set the
-fno-objc-arc
compiler flags for files for which the flag makes no sense.
Samuel Giddins #2559 -
Also apply a pod's configuration to any resource targets defined by the pod.
Tom Adriaenssen #3463
-
Allow the specification of custom module map files.
Samuel Giddins Marius Rackwitz #3145 -
Show the source URI for local Pod specification repositories in
pod repo list
.
Kyle Fuller -
Only show a warning when there is a minimum deployment target mismatch between target and spec, instead of throwing a hard error.
Samuel Giddins #1241 -
Add download caching for pods, which speeds up
pod install
and linting, potentially by several orders of magnitude.
Samuel Giddins #2863 #3172 -
Add a
--fail-fast
option to bothpod spec lint
andpod lib lint
that causes the linter to exit as soon as a single subspec or platform fails linting.
Marius Rackwitz -
Naïvely prevent base xcconfig warnings for targets that have custom config files set.
Chris Brauchli #2633 -
Ensure private headers are declared as such in a framework's generated module map.
Samuel Giddins #2974
-
Do not pass code-sign arguments to xcodebuild when linting OS X targets.
Boris Bügling #3310 -
Fixes an issue showing the URL to remote resources in
pod repo list
.
Kyle Fuller -
Fixes a problem with code signing when integrating CocoaPods into a Today Widget extension.
Christian Sampaio #3390
- Fixes various problems with Pods that use xcasset bundles. Pods that
use xcassets can now be used with the
pod :path
option.
Kyle Fuller #1549 #3384 #3358
- Fix using the downloader.
Samuel Giddins #3344 #3345
-
Unique resources passed to the script generator.
Diego Torres #3315 #3327 -
Update the
Manifest.lock
when migrating local podspecs to JSON. This fixes runningpod install
after upgrading to0.36
.
Samuel Giddins #3292 #3299
-
Workarounds(✻) for the resource script's handling of
.xcasset
files.
sodas Tony Li Chongyu Zhu #3247 #3303 -
Fix the sanitization of configuration names in the generated target environment header.
Samuel Giddins #3301
(✻) Note: these fixes are only temporary to avoid overriding the user project's
xcassets
. We are aware that these workarounds are "too greedy" and thus user projects having differentxcassets
for different targets will still have issues; we (@AliSoftware) are working on a deeper fix (#3263) for the next release.
For more details, see 📝 CocoaPods 0.36 on our blog.
- Allows Swift pods to have a deployment target under iOS 8.0 if they use
XCTest.
Samuel Giddins #3225
-
Include Swift-specific build settings on target creation, i.e. disable optimizations for debug configuration. Marius Rackwitz #3238
-
Only copy explicitly specified xcasset files into the bundle of the integrated target.
Marius Rackwitz #3219 -
Correctly filter Xcode warnings about the use of dynamic frameworks.
Boris Bügling -
Fixes warnings, when the aggregate target doesn't contain any pod target, which is build, because
PODS_FRAMEWORK_BUILD_PATH
was added toFRAMEWORK_SEARCH_PATHS
, but never created.
Marius Rackwitz #3217 -
Allows the usage of
:head
dependencies even when the most recent published version was a pre-release.
Samuel Giddins #3212 -
Limit the check for transitive static binaries to those which are directly linked to the user target.
Boris Bügling #3194 -
Lint to prevent dynamic libraries and frameworks from passing with iOS 7.
Boris Bügling #3193 -
Shows an informative error message when there is no base specification found for a
:head
dependency.
Samuel Giddins #3230 -
Fix the
OTHER_SWIFT_FLAGS
generated, so it inherits previous definitions.
Daniel Thorpe #2983
-
Set the
APPLICATION_EXTENSION_API_ONLY
build setting if integrating with a watch extension target.
Boris Bügling #3153 -
Build for iOS simulator only during validation. This allows validation without having provisioning profiles set up.
Boris Bügling #3083 Swift#13 -
Explicitly inform the user to close existing project when switching to a workspace for the first time.
Kyle Fuller #2996 -
Automatically detect conflicts between framework names.
Samuel Giddins #2943 -
Use the proper
TMPDIR
for the CocoaPods process, instead of blindly using/tmp
.
Samuel Giddins -
Let lint fail for Swift pods supporting deployment targets below iOS 8.0.
Boris Bügling #2963 -
Reject installation if a static library is used as a transitive dependency while integrating Pods as frameworks.
Samuel Giddins #2926 -
Do not copy Swift standard libraries multiple times.
Boris Bügling #3131 -
Check for Xcode License Agreement before running commands.
Xavi Matos #3002 -
pod update PODNAME
will update pods in a case-insensitive manner.
Samuel Giddins #2992 -
Allow specifying repo names to
pod {spec,lib} lint --sources
.
Samuel Giddins #2685 -
Require explicit use of
use_frameworks!
for Pods written in Swift.
Boris Bügling #3029 -
Lint as framework automatically. If needed,
--use-libraries
option allows linting as a static library.
Boris Bügling #2912 -
Adding Xcode Legacy build location support for default Pods.xcodeproj. It defaults to
${SRCROOT}/../build
but can be changed in apost_install
hook by using theProject#symroot=
writer.
Sam Marshall
-
Set
SKIP_INSTALL=YES
for all generated targets to avoid producing Generic Xcode Archives on Archive.
Marius Rackwitz #3188 -
Added support for .tpp C++ header files in specs (previously were getting filtered out and symlinks wouldn't get created in the Pods/Headers folder.)
Honza Dvorsky #3129 -
Fixed installation for app-extension targets which had no dependencies configured in the Podfile.
Boris Bügling #3102 -
Correct escaping of resource bundles in 'Copy Pods Resources' script.
Seán Labastille #3082 -
Correctly update sources when calling
pod outdated
, and also respect the--[no-]repo-update
flag.
Samuel Giddins #3137 -
Fix the
OTHER_SWIFT_FLAGS
generated, so#if COCOAPODS
works in Swift.
Samuel Giddins #2983 -
Output a properly-formed
Podfile
when runningpod init
with a target that contains a'
in its name.
Samuel Giddins #3136 -
Remove the stored lockfile checkout source when switching to a development pod.
Samuel Giddins #3141 -
Migrate local Ruby podspecs to JSON, allowing updating those pods to work.
Samuel Giddins #3038 -
Removing grep color markup in the embed frameworks script.
Adriano Bonat #3117 -
Fixes an issue where
pod ipc list
andpod ipc podfile
was returning an error.
Kyle Fuller #3134 -
Fixes an issue with spaces in the path to the user's developer tools.
Boris Bügling #3181
- Changes the default spec repositories used from all configured spec
repositories, to the master spec repository when no spec repositories
are explicitly configured in a Podfile.
Kyle Fuller #2946
-
Set the APPLICATION_EXTENSION_API_ONLY build setting if integrating with an app extension target.
Boris Bügling #2980 -
Xcodebuild warnings will now be reported as
warning
during linting instead ofnote
.
Hugo Tunius -
Copy only the resources required for the current build configuration.
Samuel Giddins #2391
-
Ensure that linting fails if xcodebuild doesn't successfully build your Pod.
Kyle Fuller #2981 cocoapods-trunk#33 -
Clone the master spec repository when no spec repositories are explicitly defined in the Podfile. This fixes problems using CocoaPods for the first time without any explicit spec repositories.
Kyle Fuller #2946 -
Xcodebuild warnings with the string
error
in them will no longer be linted as errors if they are in fact warnings.
Hugo Tunius #2579 -
Any errors which occur during fetching of external podspecs over HTTP will now be gracefully handled.
Hugo Tunius #2823 -
When updating spec repositories only update the git sourced repos.
Dustin Clark #2558 -
Pods referenced via the
:podspec
option will have their podspecs properly parsed in the local directory if the path points to a local file.
Samuel Giddins -
Fix an issue where using Swift frameworks in an Objective-C host application causes an error because the Swift frameworks we're not code signed.
Joseph Ross #3008
CocoaPods • CocoaPods-Core • Xcodeproj • CLAide • Molinillo • cocoapods-downloader • cocoapods-try • cocoapods-trunk • cocoapods-plugins
-
Support Frameworks & Swift: CocoaPods now recognizes Swift source files and builds dynamic frameworks when necessary. A project can explicitly opt-in via
use_frameworks!
in the Podfile, or if any dependency contains Swift code, all pods for that target will be integrated as frameworks.As a pod author, you can change the module name of the built framework by specifying a
module_name
in the podspec. The built frameworks are embedded into the host application with a new shell script build phase in the user's project allowing configuration-dependent pods.
-
Bundle Resources into Frameworks: Previously all resources were compiled and copied into the
mainBundle
. Now Pods have to use[NSBundle bundleForClass:<#Class from Pod#>]
to access provided resources relative to the bundle. -
Only the hooks specified by usage of the
plugin
directive of thePodfile
will be run. Additionally, plugins that depend on hooks will have to update to specify their 'plugin name' when registering the hooks in order to make it possible for those hooks to be run.
Samuel Giddins #2640
-
Do not generate targets for Pods without sources.
Boris Bügling #2918 -
Show the name of the source for each hook that is run in verbose mode.
Samuel Giddins #2639 -
Move pods' private headers to
Headers/Private
fromHeaders/Build
. Since some SCM ignore templates includebuild
by default, this makes it easier to check in thePods/
directory.
Samuel Giddins #2623 -
Validate that a specification's
public_header_files
andprivate_header_files
file patterns only match header files. Also, validate that all file patterns, if given, match at least one file.
Samuel Giddins #2914 -
Installer changed to organize a development pod's source and resource files into subgroups reflecting their organization in the filesystem.
Imre mihaly
-
Fix updating a pod that has subspec dependencies.
Samuel Giddins #2879 -
Restore the
#define
s in the environment header when the--no-integrate
installation option is used.
Samuel Giddins #2876 -
Fix issues when trying to discover the xcodeproj automatically but the current path contains special characters (
[
,]
,{
,}
,*
,?
).
Olivier Halligon #2852 -
Fix linting subspecs that have a higher deployment target than the root spec.
Samuel Giddins #1919 -
Fix the reading of podspecs that come from the
:git
,:svn
,:http
, or:hg
options in yourPodfile
that used context-dependent ruby code, such as reading a file to determine the specification version.
Samuel Giddins #2875 -
Fix the updating of
:git
,:svn
, and:hg
dependencies when updating all pods.
Samuel Giddins #2859 -
Fix an issue when a user doesn't yet have any spec repositories configured.
Boris Bügling -
Fix an issue updating repositories when another spec repository doesn't have a remote.
Kyle Fuller #2965
CocoaPods • CocoaPods-Core • Xcodeproj • cocoapods-downloader
For more details, see 📝 CocoaPods 0.35 on our blog.
-
Allow the specification of file patterns for the Podspec's
requires_arc
attribute.
Kyle Fuller Samuel Giddins #532 -
From now on, pods installed directly from their repositories will be recorded in the
Podfile.lock
file and will be guaranteed to be checked-out using the same revision on subsequent installations. Examples of this are when using the:git
,:svn
, or:hg
options in yourPodfile
.
Samuel Giddins #1058
-
Fix an output formatting issue with various commands like
pod search
andpod trunk
. Olivier Halligon #2603 -
Show a helpful error message if the old resolver incorrectly activated a pre-release version that now leads to a version conflict.
Samuel Giddins -
Provides a user friendly message when using
pod spec create
with a repository that doesn't yet have any commits.
Kyle Fuller #2803 -
Fixes an issue with integrating into projects where there is a slash in the build configuration name.
Kyle Fuller #2767 -
Pods will use
CLANG_ENABLE_OBJC_ARC = 'YES'
instead ofCLANG_ENABLE_OBJC_ARC = 'NO'
. For pods withrequires_arc = false
the-fno-objc-arc
flag will be specified for the all source files.
Hugo Tunius #2262 -
Fixed an issue that Core Data mapping models where not compiled when copying resources to main application bundle.
Yan Rabovik -
Fix uninitialized constant Class::YAML crash in some cases. Tim Shadel
-
pod search
,pod spec which
,pod spec cat
andpod spec edit
now use plain text search by default instead of a regex. Especiallypod search UIView+UI
now searches for pods containing exactlyUIView+UI
in their name, not trying to interpret the+
as a regular expression. Note: You can still use a regular expression with the new--regex
flag that has been added to these commands, e.g.pod search --regex "(NS|UI)Color"
. Olivier Halligon Core#188 -
Use
--allow-warnings
rather than--error-only
for pod spec validation Daniel Tomlinson #2820
- Allow the resolver to fail faster when there are unresolvable conflicts
involving the Lockfile.
Samuel Giddins
-
Allows pre-release spec versions when a requirement has an external source specified.
Samuel Giddins #2768 -
We no longer require git version 1.7.5 or greater.
Kyle Fuller -
Fix the usage of
:head
pods.
Samuel Giddins #2789 -
Show a more informative message when attempting to lint a spec whose source could not be downloaded.
Samuel Giddins #2667 #2759
-
The
Resolver
has been completely rewritten to use Molinillo, an iterative dependency resolution algorithm that automatically resolves version conflicts. The order in which dependencies are declared in thePodfile
no longer has any effect on the resolution process.You should ensure that
pod install
,pod update
andpod update [NAME]
work as expected and install the correct versions of your pods during this RC1 release. Samuel Giddins #978 #2002
-
Support for older versions of Ruby has been dropped and CocoaPods now depends on Ruby 2.0.0 or greater. This is due to the release of Xcode 6.0 which has dropped support for OS X 10.8, which results in the minimum version of Ruby pre-installed on OS X now being 2.0.0.
If you are using a custom installation of Ruby older than 2.0.0, you will need to update. Or even better, migrate to system Ruby.
Kyle Fuller -
Attempts to resolve circular dependencies will now raise an exception.
Samuel Giddins Molinillo#6
-
The use of implicit sources has been un-deprecated. By default, all available spec-repos will be used. There should only be a need to specify explicit sources if you want to specifically exclude certain spec-repos, such as the
master
spec-repo, if you want to declare the order of spec look-up precedence, or if you want other users of a Podfile to automatically have a spec-repo cloned onpod install
.
Eloy Durán -
The
pod push
command has been removed as it has been deprecated in favour ofpod repo push
in CocoaPods 0.33.
Fabio Pelosin -
Refactorings in preparation to framework support, which could break usage of the Hooks API.
Marius Rackwitz #2461 -
Implicit dependencies are now locked, so simply running
pod install
will not cause them to be updated when they shouldn't be.
Samuel Giddins #2318 #2506 -
Pre-release versions are only considered in the resolution process when there are dependencies that explicitly reference pre-release requirements.
Samuel Giddins #1489 -
Only setup the master specs repo if required.
Daniel Tomlinson #2562 -
Sandbox::FileAccessor
now optionally includes expanded paths of headers of vendored frameworks inpublic_headers
.
Eloy Durán #2722 -
Analysis is now halted and the user informed when there are multiple different external sources for dependencies with the same root name. The user is also now warned when there are duplicate dependencies in the Podfile.
Samuel Giddins #2738 -
Multiple subspecs that point to the same external dependency will now only cause that external source to be fetched once.
Samuel Giddins #2743
-
Fixes an issue in the
XCConfigIntegrator
where not all targets that need integration were being integrated, but were getting incorrect warnings about the user having specified a custom base configuration.
Eloy Durán 2752 -
Do not try to clone spec-repos in
/
.
Eloy Durán #2723 -
Improved sanitizing of configuration names which have a numeric prefix.
Steffen Matthischke #2700 -
Fixes an issues where headers from a podspec with one platform are exposed to targets with a different platform. The headers are now only exposed to the targets with the same platform.
Michael Melanson Kyle Fuller #1249
-
Fixes a crash when running
pod outdated
.
Samuel Giddins #2624 -
Ensure that external sources (as specified in the
Podfile
) are downloaded when their source is missing, even if their specification is present.
Samuel Giddins #2494 -
Fixes an issue where running
pod install/update
while the Xcode project is open can cause the open project to have build failures until Xcode is restarted.
Kyle Fuller #2627 #2665 -
Fixes a crash when using file URLs as a source.
Kurry Tran #2683 -
Fixes an issue when using pods in static library targets and building with Xcode 6 which requires
OTHER_LIBTOOLFLAGS
instead ofOTHER_LDFLAGS
, thus basically reverting to the previous Xcode behaviour, for now at least.
Kyle Fuller Eloy Durán #2666 -
Fixes an issue running the resources script when Xcode is installed to a directory with a space when compiling xcassets.
Kyle Fuller #2684 -
Fixes an issue when installing Pods with resources to a target which doesn't have any resources.
Kyle Fuller #2083 -
Ensure that git 1.7.5 or newer is installed when running pod.
Kyle Fuller #2651
-
Make the output of
pod outdated
show what runningpod update
will do. Takes into account the sources specified in thePodfile
.
Samuel Giddins #2470 -
Allows the use of the
GCC_PREPROCESSOR_DEFINITION
flag${inherited}
without emitting a warning.
Samuel Giddins #2577 -
Integration with user project will no longer replace an existing base build configuration.
Robert Jones #1736
-
Improved sanitizing of configuration names to avoid generating invalid preprocessor definitions.
Boris Bügling #2542 -
More robust generation of source names from URLs.
Samuel Giddins #2534 -
Allow the
Validator
to only use specific sources. Allows customizable source forpod spec lint
andpod lib lint
, with both defaulting tomaster
. Samuel Giddins #2543 cocoapods-trunk#28 -
Takes into account the sources specified in
Podfile
runningpod outdated
.
Samuel Giddins #2553 -
Ensures that the master repo is shallow cloned when added via a Podfile
source
directive.
Samuel Giddins #3586 -
Ensures that the user project is not saved when there are no user targets integrated.
Samuel Giddins #2561 #2593 -
Fix a crash when running
pod install
with an empty target that inherits a pod from a parent target.
Kyle Fuller #2591 -
Take into account versions of a Pod from all specified sources when resolving dependencies.
Thomas Visser #2556 -
Sanitize build configuration names in target environment header macros.
Kra Larivain #2532
- Doesn't take into account the trailing
.git
in repository URLs when trying to find a matching specs repo.
Samuel Giddins #2526
For more details, see 📝 CocoaPods 0.34 on our blog.
-
Add support for loading podspecs from only specific spec-repos via
sources
. By default, when there are no sources specified in a Podfile all source repos will be used. This has always been the case. However, this implicit use of sources is now deprecated. Once you specify specific sources, no repos will be included by default. For example:source 'https://github.com/artsy/Specs.git' source 'https://github.com/CocoaPods/Specs.git'
Any source URLs specified that have not yet been added will be cloned before resolution begins.
François Benaiteau Fabio Pelosin Samuel Giddins #1143 Core#19 Core#170 #2515
- Added the
pod repo list
command which lists all the repositories.
Luis Ascorbe #1455
-
Works around an Xcode issue where linting would fail even though
xcodebuild
actually succeeds. Xcode.app also doesn't fail when this issue occurs, so it's safe for us to do the same.
Kra Larivain Boris Bügling Eloy Durán Samuel E. Giddins #2394 #2395 -
Fixes the detection of JSON podspecs included via
:path
.
laiso #2489 -
Fixes an issue where
pod install
would crash during Plist building if any pod has invalid UTF-8 characters in their title or description.
Ladislav Martincik #2482 -
Fix crash when the URL of a private GitHub repo is passed to
pod spec create
as an argument.
Fabio Pelosin #1543
-
Fixes an issue where
pod lib lint
would crash if a podspec couldn't be loaded.
Kyle Fuller #2147 -
Fixes an issue where
pod init
would not addsource 'master'
to newly created Podfiles.
Ash Furrow #2473
-
The use of the
$PODS_ROOT
environment variable has been deprecated and should not be used. It will be removed in future versions of CocoaPods.
#2449 -
Add support for loading podspecs from specific spec-repos only, a.k.a. ‘sources’. By default, when not specifying any specific sources in your Podfile, the ‘master’ spec-repo will be used, as was always the case. However, once you specify specific sources the ‘master’ spec-repo will not be included by default. For example:
source 'private-spec-repo' source 'master'
-
The
Pods
directory has been reorganized. This might require manual intervention in projects where files generated by CocoaPods have manually been imported into the user's project (common with the acknowledgements files).
#1055 Fabio Pelosin Michele Titolo -
Plugins are now expected to include the
cocoapods-plugin.rb
file in./lib
.
Fabio Pelosin CLAide#28 -
The specification
requires_arc
attribute now defaults to true.
Fabio Pelosin CocoaPods#267
-
Add support to specify dependencies per build configuration:
pod 'Lookback', :configurations => ['Debug']
Currently configurations can only be specified per single Pod.
Joachim Bengtsson Eloy Durán Fabio Pelosin #1791 #1668 #731 -
Improved performance of git downloads using shallow clone.
Marin Usalj Fabio Pelosin cocoapods-downloader#29 -
Simplify installation: CocoaPods no longer requires the compilation of the troublesome native extensions.
Fabio Pelosin Xcodeproj#168 Xcodeproj#167 -
Add hooks for plugins. Currently only the installer hook is supported. A plugin can register itself to be activated after the installation with the following syntax:
Pod::HooksManager.register(:post_install) do |installer_context| # implementation end
The
installer_context
is an instance of thePod::Installer:HooksContext
class which provides the information about the installation.
Fabio Pelosin Core#132 -
Add a support for migrating the sandbox to new versions of CocoaPods.
Fabio Pelosin -
Display an indication for deprecated Pods in the command line search.
Hugo Tunius #2180 -
Use the CLIntegracon gem for the integration tests.
Marius Rackwitz #2371 -
Include configurations that a user explicitly specifies, in their Podfile, when the
--no-integrate
option is specified.
Eloy Durán -
Properly quote the
-isystem
values in the xcconfig files.
Eloy Durán -
Remove the installation post install message which presents the CHANGELOG.
Fabio Pelosin Eloy Durán -
Add support for user-specified project directories with the
--project-directory
option.
Samuel E. Giddins #2183 -
Now the
plutil
tool is used when available to produce output consistent with Xcode.
Fabio Pelosin -
Indicate the name of the pod whose requirements cannot be satisfied.
Seivan Heidari Fabio Pelosin #1938 -
Add support for JSON specs to external sources (
:path
,:git
, etc) options.
Kyle Fuller #2320 -
Generate the workspaces using the same output of Xcode.
Fabio Pelosin
-
Fix
pod repo push
to first check if a Specs directory exists and if so push there.
Edward Valentini #2060 -
Fix
pod outdated
to not include subspecs.
Ash Furrow #2136 -
Always evaluate podspecs from the original podspec directory. This fixes an issue when depending on a pod via
:path
and that pod's podspec uses relative paths.
Kyle Fuller pod-template#50 -
Fix spec linting to not warn for missing license file in subspecs.
Fabio Pelosin Core#132 -
Fix
pod init
so that it doesn't recurse when checking for Podfiles.
Paddy O'Brien #2181 -
Fix missing XCTest framework in Xcode 6.
Paul Williamson #2296 -
Support multiple values in
ARCHS
.
Robert Zuber #1904 -
Fix static analysis in Xcode 6.
Samuel E. Giddins #2402 -
Fix an issue where a version of a spec will not be locked when using multiple subspecs of a podspec.
Kyle Fuller Fabio Pelosin #2135 -
Fix an issue using JSON podspecs installed directly from a lib's repository.
Kyle Fuller #2320 -
Support and use quotes in the
OTHER_LDFLAGS
of xcconfigs to avoid issues with targets containing a space character in their name.
Fabio Pelosin
-
Fix
pod spec lint
forjson
podspecs.
Fabio Pelosin #2157 -
Fixed downloader issues related to
json
podspecs.
Fabio Pelosin #2158 -
Fixed
--no-ansi
flag in help banners.
Fabio Pelosin #34
For more details, see 📝 CocoaPods 0.33 on our blog.
- The deprecated
pre_install
and thepod_install
hooks of the specification class have been removed.
Fabio Pelosin #2151 #2153
-
Added the
cocoapods-trunk
plugin which introduces thetrunk
subcommand.
Fabio Pelosin #2151 #2153 -
The
pod push
sub-command has been moved to thepod repo push
sub-command. Moreover pushing to the master repo from it has been disabled.
Fabio Pelosin #2151 #2153 -
Overhauled command line interface. Add support for auto-completion script (d). If auto-completion is enabled for your shell you can configure it for CocoaPods with the following command:
rm -f /usr/local/share/zsh/site-functions/_pod dpod --completion-script > /usr/local/share/zsh/site-functions/_pod exec zsh
Currently only the Z shell is supported.
Fabio Pelosin CLAide#25 CLAide#20 CLAide#19 CLAide#17 CLAide#12 -
The
--version
flag is now only supported for the rootpod
command. If used in conjunction with the--verbose
flag the version of the detected plugins will be printed as well.
Fabio Pelosin CLAide#13 CLAide#14 -
The extremely meta
cocoaPods-plugins
is now installed by default providing information about the available and the installed plug-ins.
David Grandinetti Olivier Halligon Fabio Pelosin #2092 -
Validate the reachability of
social_media_url
,documentation_url
anddocset_url
in podspecs we while linting a specification.
Kyle Fuller #2025 -
Print the current version when the repo/lockfile requires a higher version.
Samuel E. Giddins #2049 -
Show
help
when running thepod
command instead of defaulting topod install
.
Kyle Fuller #1771
-
Show the actual executable when external commands fail.
Boris Bügling #2102 -
Fixed support for file references in the workspace generated by CocoaPods.
Kyle Fuller Fabio Pelosin Xcodeproj#105 -
Show a helpful error message when reading version information with merge conflict.
Samuel E. Giddins #1853 -
Show deprecated specs when invoking
pod outdated
.
Samuel E. Giddins #2003 -
Fixes an issue where
pod repo update
may start an un-committed merge.
Kyle Fuller #2024
- Fixed the Podfile
default_subspec
attribute in nested subspecs.
Fabio Pelosin #2050
For more details, see 📝 CocoaPods 0.32 on our blog.
-
Allow to update only a list of given pods with
pod update [POD_NAMES...]
.
Marius Rackwitz CocoaPods#760 -
pod update
prints the previous version of the updated pods.
Andrea Mazzini #2008 -
pod update
falls back topod install
if no Lockfile is present.
Marius Rackwitz -
File references in the Pods project for development Pods now are absolute if the dependency is specified with an absolute paths.
Samuel Ford #1042 -
Added
deprecated
anddeprecated_in_favor_of
attributes to Specification DSL.
Paul Young Core#87 -
Numerous improvements to the validator and to the linter.
- Validate the reachability of screenshot URLs in podspecs while linting a
specification.
Kyle Fuller #2010 - Support HTTP redirects when linting homepage and screenshots.
Boris Bügling #2027 - The linter now checks
framework
andlibrary
attributes for invalid strings.
Paul Williamson Fabio Pelosin Core#66 Core#96 Core#105 - The Linter will not check for comments anymore.
Fabio Pelosin Core#108 - Removed legacy checks from the linter.
Fabio Pelosin Core#108 - Added logic to handle subspecs and platform scopes to linter check of
the
requries_arc
attribute.
Fabio Pelosin CocoaPods#2005 - The linter no longer considers empty a Specification if it only specifies the
resource_bundle
attribute.
Joshua Kalpin #63 #95
- Validate the reachability of screenshot URLs in podspecs while linting a
specification.
-
pod lib create
is now using theconfigure
file instead of the_CONFIGURE.rb
file.
Piet Brauer Orta Therox -
pod lib create
now disallows any pod name that begins with a.
Dustin Clark #2026 Core#97 Core#98 -
Prevent the user from using
pod
commands as root.
Kyle Fuller #1815 -
Dependencies declared with external sources now support HTTP downloads and have improved support for all the options supported by the downloader.
Fabio Pelosin -
An informative error message is presented when merge conflict is detected in a YAML file.
Luis de la Rosa #69 #100
-
Fixed the Podfile
default_subspec
attribute in nested subspecs.
Fabio Pelosin #1021 -
Warn when including deprecated pods Samuel E. Giddins #2003
- The specification now strips the indentation of the
prefix_header
andprepare_command
to aide their declaration as a here document (similarly to what it already does with the description).
Fabio Pelosin Core#51
- Fix linting for Pods which declare a private repo as the source.
Boris Bügling Core#82
For more details, see 📝 CocoaPods 0.31 on our blog.
-
Warnings are not promoted to errors anymore to maximise compatibility with existing libraries.
Fabio Pelosin #1629 -
Include the versions of the Pods to the output of
pod list
.
Stefan Damm Robert Zuber #1617 -
Generated prefix header file will now have unique prefix_header_contents for Pods with subspecs.
Luis de la Rosa #1449 -
The linter will now check the reachability of the homepage of Podspecs during a full lint.
Richard Lee Fabio Pelosin #1704 Core#70 -
Improved detection of the last version of a specification in
pod spec
subcommands.
Laurent Sansonetti #1953 -
Display advised settings for Travis CI in the warning related presented when the terminal encoding is not set to UTF-8.
Richard Lee #1933 #1941 -
Unset the
CDPATH
env variable before shelling-out toprepare_command
.
Marc Boquet #1943
-
Resolve crash related to the I18n deprecation warning.
Eloy Durán #1950 -
Fix compilation issues related to the native Extension of Xcodeproj.
Eloy Durán -
Robustness against user Git configuration and against merge commits in
pod repo
subcommands.
Boris Bügling #1949 #1978 -
Gracefully inform the user if the
:head
option is not supported for a given download strategy.
Boris Bügling #1947 #1958 -
Cleanup a pod directory if error occurs while downloading.
Alex Rothenberg #1842 #1960 -
No longer warn for Github repositories with OAuth authentication.
Boris Bügling #1928 Core#77 -
Fix for when using
s.version
as the:tag
for a git repository in a Podspec.
Joel Parsons #1721 Core#72 -
Improved escaping of paths in Git downloader.
Vladimir Burdukov cocoapods-downloader#14 -
Podspec without explicitly set
requires_arc
attribute no longer passes the lint.
Richard Lee #1840 Core#71 -
Properly quote headers in the
-isystem
compiler flag of the aggregate targets.
Eloy Durán #1862 #1894
For more details, see 📝 CocoaPods 0.30 on our blog.
-
Radically reduce first run pod setup bandwidth by creating a shallow clone of the ‘master’ repo by default. Use the
--no-shallow
option to perform a full clone instead.
Jeff Verkoeyen #1803 -
Improves the error message when searching with an invalid regular expression.
Kyle Fuller -
Improves
pod init
to save Xcode project file in Podfile when one was supplied.
Kyle Fuller -
Adds functionality to specify a template URL for the
pod lib create
command.
Piet Brauer
-
Fixes a bug with
pod repo remove
silently handling permission errors.
Kyle Fuller #1778 -
pod push
now properly checks that the repo has changed before attempting to commit. This only affected pods with special characters (such as+
) in their names.
Gordon Fontenot #1739
CocoaPods • CocoaPods-core • cocoapods-downloader
For more details, see 📝 CocoaPods 0.29 on our blog.
-
The command
podfile_info
is now a plugin offered by CocoaPods. As a result, the command has been removed from CocoaPods.
Joshua Kalpin #1589 -
JSON has been adopted as the format to store specifications. As a result the
pod ipc spec
command returns a JSON representation and the YAML specifications are not supported anymore. JSON specifications adopt the.podspec.json
extension. Fabio Pelosin #1568
-
Introduced
pod try
the easiest way to test the example project of a pod.
Fabio Pelosin #1568 -
Pod headers are now provided to the user target as a system header. This means that any warnings in a Pod's code will show under its target in Xcode's build navigator, and never under the user target.
Swizzlr #1596 -
Support LZMA2 compressed tarballs in the downloader.
Kyle Fuller cocoapods-downloader#5 -
Add Bazaar support for installing directly from a repo.
Fred McCann #1632 -
The
pod search <query>
command now supports regular expressions for the query parameter when searching using the option--full
.
Florian Hanke #1643 -
Pod lib lint now accepts multiple podspecs in the same folder.
kra Larivain/OpenTable #1635 -
The
pod push
command will now silently test the upcoming CocoaPods trunk service. The service is only tested when pushing to the master repo and the test doesn't affect the normal workflow.
Fabio Pelosin -
The
pod search <query>
command now supports searching on cocoapods.org when searching using the option--web
. Options--ios
and--osx
are fully supported. Florian Hanke #1643 -
The
pod search <query>
command now supports multiword queries when using the--web
option. Florian Hanke #1643
-
Fixed a bug which resulted in
pod lib lint
not being able to find the headers.
Fabio Pelosin #1566 -
Fixed the developer frameworks search paths so that
$(SDKROOT)/Developer/Library/Frameworks
is used for iOS and$(DEVELOPER_LIBRARY_DIR)/Frameworks
is used for OS X.
Kevin Wales #1562 -
When updating the pod repos, repositories with unreachable remotes are now ignored. This fixes an issue with certain private repositories.
Joshua Kalpin #1595 #1571 -
The linter will now display an error if a Pod's name contains whitespace.
Joshua Kalpin Core#39 #1610 -
Having the silent flag enabled in the config will no longer cause issues with
pod search
. In addition, the flag--silent
is no longer supported for the command.
Joshua Kalpin #1627 -
The linter will now display an error if a framework ends with
.framework
(i.e.QuartzCore.framework
).
Joshua Kalpin #1331 Core#45 -
The linter will now display an error if a library ends with
.a
or.dylib
(i.e.z.dylib
). It will also display an error if it begins withlib
(i.e.libxml
).
Joshua Kalpin Core#44 -
The ARCHS build setting can come back as an array when more than one architecture is specified.
Carson McDonald #1628 -
Fixed all issues caused by
/tmp
being a symlink to/private/tmp
. This affected mostlypod lib lint
, causing it to fail when the Pod usedprefix_header_*
or when the pod headers imported headers using the namespaced syntax (e.g.#import <MyPod/Header.h>
).
kra Larivain/OpenTable #1514 -
Fixed an incorrect path being used in the example app Podfile generated by
pod lib create
. Eloy Durán cocoapods-try#5
CocoaPods • CocoaPods-core • CLAide
For more details, see 📝 CocoaPods 0.28 on our blog.
-
CLAide now supports gem plugins. An example CocoaPods plugin can be found at open_pod_bay.
As of yet there are no promises made yet on the APIs, so try to fail as gracefully as possible in case a CocoaPods update breaks your usage. In these cases, also please let us know what you would need, so we can take this into account when we do finalize APIs.
-
Compiling
xcassets
withactool
now usesUNLOCALIZED_RESOURCES_FOLDER_PATH
instead ofPRODUCT_NAME.WRAPPER_EXTENSION
as output directory as it is more accurate and allows the project to overwriteWRAPPER_NAME
.
Marc Knaup #1556 -
Added a condition to avoid compiling xcassets when
WRAPPER_EXTENSION
is undefined, as it would be in the case of static libraries. This prevents trying to copy the compiled files to a directory that does not exist.
Noah McCann #1521 -
Added additional condition to check if
actool
is available when compilingxcassets
. This prevents build failures of Xcode 5 projects on Travis CI (or lower Xcode versions).
Michal Konturek #1511 -
Added a condition to properly handle universal or mac apps when compiling xcassets. This prevents build errors in the xcassets compilation stage particularly when using xctool to build.
Ryan Marsh #1594 -
Vendored Libraries now correctly affect whether a podspec is considered empty.
Joshua Kalpin Core#38 -
Vendored Libraries and Vendored Frameworks now have their paths validated correctly.
Joshua Kalpin #1567 -
Gists are now correctly accepted with https.
Joshua Kalpin Core#38 -
The
pod push
command is now more specific about the branch it pushes to.
orta #1561 -
Dtrace files are now properly left unflagged when installing, regardless of configuration.
Swizzlr #1560 -
Users are now warned if their terminal encoding is not UTF-8. This fixes an issue with a small percentage of pod names that are incompatible with ASCII.
Joshua Kalpin #1570
CocoaPods • cocoapods-core • Xcodeproj
For more details, see 📝 CocoaPods 0.27 and improved installation UX on our blog.
-
The xcodeproj gem now comes bundled with prebuilt binaries for the Ruby versions that come with OS X 10.8 and 10.9. Users now no longer need to install the Xcode Command Line Tools or deal with the Ruby C header location.
Eloy Durán Xcodeproj#88 -
Targets passed to the
link_with
method of the Podfile DSL no longer need to be explicitly passed as an array.link_with ['target1', 'target2']
can now be written aslink_with 'target1', 'target2'
.
Adam Sharp Core#30 -
The copy resources script now compiles xcassets resources.
Ulrik Damm #1427 -
pod repo
now support aremove ['repo_name']
command.
Joshua Kalpin #1493 #1484
-
The architecture is now set in the build settings of the user build configurations.
Fabio Pelosin #1450 #1462 -
Fixed a crash related to CocoaPods being unable to resolve an unique build setting of an user target with custom build configurations.
Fabio Pelosin #1462 #1463 #1457 -
Fixed a defect which prevented subspecs from being dependant on a pod with a name closely matching the name of one of the subspec's parents.
Noah McCann #29 -
The developer dir relative to the SDK is not added anymore if testing frameworks are detected in OS X targets, as it doesn't exists, avoiding the presentation of the relative warning in Xcode.
Fabio Pelosin
CocoaPods • cocoapods-core • Xcodeproj
-
Fixed a crash which was causing a failure in
pod lib create
if the name of the Pod included spaces. As spaces are not supported now this is gracefully handled with an informative message.
Kyle Fuller #1456 -
If an user target doesn't specify an architecture the value specified for the project is used in CocoaPods targets.
Fabio Pelosin #1450 -
The Pods project now properly configures ARC on all build configurations.
Fabio Pelosin #1454
CocoaPods • cocoapods-core • Xcodeproj
For more details, see 📝 CocoaPods 0.26 on our blog.
-
CocoaPods now creates and hides the schemes of its targets after every installation. The schemes are not shared because the flag which keeps track whether they should be visible is a user only flag. The schemes are still present and to debug a single Pod it is possible to make its scheme visible in the Schemes manager of Xcode. This is rarely needed though because the user targets trigger the compilation of the Pod targets.
Fabio Pelosin #1185 -
Installations which don't integrate a user target (lint subcommands and
--no-integrate
option) now set the architecture of OS X Pod targets to$(ARCHS_STANDARD_64_BIT)
(Xcode 4 default value for new targets). This fixes lint issues with Xcode 4.
Fabio Pelosin #1185 -
Further improvements to the organization of the Pods project
- The project is now is sorted by name with groups at the bottom.
- Source files are now stored in the root group of the spec, subspecs are not
stored in a
Subspec
group anymore and the products of the Pods all are stored in the products group of the project. - The frameworks are referenced relative to the Developer directory and namespaced per platform.
-
Added the
documentation_url
DSL attribute to the specifications.
Fabio Pelosin #1273
-
The search paths of vendored frameworks and libraries now are always specified relatively.
Fabio Pelosin #1405 -
Fix an issue where CocoaPods would fail to work when used with an older version of the Active Support gem. This fix raises the dependency version to the earliest compatible version of Active Support.
Kyle Fuller #1407 -
CocoaPods will not attempt to load anymore all the version of a specification preventing crashes if those are incompatible.
Fabio Pelosin #1272
CocoaPods • cocoapods-core • Xcodeproj
-
Added support for Xcode 5.
The generated Pods Xcode project is now compatible with
arm64
projects and is updated to use Xcode 5’s default settings removing all warnings.NOTE to users migrating projects from Xcode 4, or are still using Xcode 4:
- The Pods Xcode project now sets the
ONLY_ACTIVE_ARCH
build setting toYES
in theDebug
configuration. You will have to set the same on your project/target, otherwise the build will fail. - Ensure your project/target has an
ARCHS
value set, otherwise the build will fail. - When building a iOS project from the command-line, with the
xcodebuild
tool that comes with Xcode 4, you’ll need to completely disable this setting by appending to your build command:ONLY_ACTIVE_ARCH=NO
.
- The Pods Xcode project now sets the
-
Speed up project generation in
pod install
andpod update
. -
The pre and post install hooks that have been deprecated now include the name and version of the spec that’s using them.
-
Only create a single resource bundle for all targets. Prior to this change a resource bundle included into multiple targets within the project would create duplicately named targets in the Pods Xcode project, causing duplicately named Schemes to be created on each invocation of
pod install
. All targets that reference a given resource bundle now have dependencies on a single common target. -
Solved outstanding issues with CocoaPods resource bundles and Archive builds:
- The rsync task copies symlinks into the App Bundle, producing an invalid
app. This change add
--copy-links
to the rsync invocation to ensure the target files are copied rather than the symlink. - The Copy Resources script uses
TARGET_BUILD_DIR
which points to the App Archiving folder during an Archive action. Switching toBUILT_PRODUCTS_DIR
instead ensures that the path is correct for all actions and configurations.
- The rsync task copies symlinks into the App Bundle, producing an invalid
app. This change add
-
Ensure resource bundles are copied to installation location on install actions Chris Gummer #1364
-
Various bugfixes in Xcodeproj, refer to its CHANGELOG for details.
CocoaPods • cocoapods-core • Xcodeproj • cocoapods-downloader
-
Added
pod init
command which generates a Podfile according to the targets of the project stored in the working directory and to the templates stored in the~/.cocoapods/templates
folder. Two templates are supported:- the
Podfile.default
template for regular targets. - and the
Podfile.test
template for test targets. Ian Ynda-Hummel #1106 #1045
- the
-
CocoaPods will now leverage the xcproj command line tool if available in the path of the user to touch saved projects. This will result in projects being serialized in the exact format used by Xcode eliminating merge conflicts and other related issues. To learn more about how to install xcproj see its readme. Cédric Luthi #1275
-
Rationalized and cleaned up Pods project group structure and path specification.
-
Create all necessary build configurations for Pods.xcodeproj at the project level. If the user’s project has more than just Debug and Release build configurations, they may be explicitly specified in the Podfile:
xcodeproj 'MyApp', 'App Store' => :release, 'Debug' => :debug, 'Release' => :release
If build configurations aren’t specified in the Podfile then they will be automatically picked from the user’s project in Release mode.
These changes will ensure that thelibPods.a
static library is not stripped for all configurations, as explained in #1217.
Cédric Luthi
#1294 -
Added basic support for Bazaar repositories.
Fred McCann
cocoapods-downloader#4
-
Fixed crash in
pod spec cat
. -
Use the
TARGET_BUILD_DIR
environment variable for installing resource bundles.
Cédric Luthi
#1268 -
CoreData versioned models are now properly handled respecting the contents of the
.xccurrentversion
file.
Ashton-W
#1288, Xcodeproj#83 -
OS X frameworks are now copied to the Resources folder using rsync to properly overwrite existing files.
Nikolaj Schumacher
#1063 -
User defined build configurations are now added to the resource bundle targets.
#1309
CocoaPods • cocoapods-core • Xcodeproj • cocoapods-downloader
-
Added
prepare_command
attribute to Specification DSL. The prepare command will replace thepre_install
hook. Thepost_install
hook has also been deprecated. #1247The reason we provided Ruby hooks at first, was because we wanted to offer the option to make any required configuration possible. By now, however, we have a pretty good idea of the use-cases and are therefore locking down the freedom that was once available. In turn, we’re adding attributes that can replace the most common use-cases. (See the enhancements directly following this entry for more info).
The second reason we need to lock this down is because this is the last remaining obstacle to fully serialize specifications, which we need in order to move to a ‘spec push’ web-service in the future.
-
Added
resource_bundles
attribute to the Specification DSL.
#743 #1186 -
Added
vendored_frameworks
attribute to the Specification DSL.
#809 #1075 -
Added
vendored_libraries
attribute to the Specification DSL.
#809 #1075 -
Restructured
.cocoapods
folder to contain repos in a subdirectory.
Ian Ynda-Hummel #1150 -
Improved
pod spec create
template.
#1223 -
Added copy&paste-friendly dependency to
pod search
.
#1073 -
Improved performance of the installation of Pods with git sources which specify a tag.
#1077 -
Core Data
xcdatamodeld
files are now properly referenced from the Pods project.
#1155 -
Removed punctuation check from the specification validations.
#1242 -
Deprecated the
documentation
attribute of the Specification DSL.
Core#20
- Fix copy resource script issue related to filenames with spaces.
Denis Hennessy #1231
- Add support for .xcdatamodel resource files (in addition to .xcdatamodeld). #1201
-
Always exlude
USE_HEADERMAP
from the user’s project. #1216 -
Use correct template repo when using the
pod lib create
command. #1214 -
Fixed issue with
pod push
failing when the podspec is unchanged. It will now report[No change] ExamplePod (0.1.0)
and continue to push other podspecs if they exist. #1199 -
Set STRIP_INSTALLED_PRODUCT = NO in the generated Pods project. This allows Xcode to include symbols from CocoaPods in dSYMs during Archive builds. #1217
-
Ensure the resource script doesn’t fail due to the resources list file not existing when trying to delete it. #1198
-
Fix handling of spaces in paths when compiling xcdatamodel(d) files. #1201
CocoaPods • cocoapods-core • Xcodeproj
- The build settings of the Pods project and of its target have been updated to be in line with the new defaults of the future versions of Xcode.
-
Specifications defining build setting with the
[*]
syntax are now properly handled. #1171 -
The name of the files references are now properly set fixing a minor regression introduced by CocoaPods 0.22.1 and matching more closely Xcode behaviour.
-
The validator now builds the Pods target instead of the first target actually performing the validation.
-
Build settings defined through the
xcconfig
attribute of apodspec
are now stripped of duplicate values when merged in an aggregate target. #1189
- Fixed a crash related to target dependencies and subspecs. #1168
CocoaPods • cocoapods-core • Xcodeproj
-
Added the
pod lib create
subcommand which allows to create a new Pod adhering to the best practices. The template is still a bit primitive and we encourage users to provide feedback by submitting patches and issues to https://github.com/CocoaPods/CocoaPods. #850 -
Added the
pod lib lint
subcommand which allows to lint the Pod stored in the working directory (a pod spec in the root is needed). This subcommand is equivalent to the deprecatedpod spec lint --local
. #850 -
The dependencies of the targets of the Pods project are now made explicit. #1165
-
The size of the cache used for the git repos is now configurable. For more details see https://github.com/CocoaPods/CocoaPods/blob/master/lib/cocoapods/config.rb#L7-L25 #1159
-
The copy resources shell script now aborts if any error occurs. #1098
-
The output of shell script build phases no longer includes environment variables to reduce noise. #1122
-
CocoaPods no longer sets the deprecated
ALWAYS_SEARCH_USER_PATHS
build setting.
-
Pods whose head state changes now are correctly detected and reinstalled. #1160
-
Fixed the library reppresentation of the hooks which caused issues with the
#copy_resources_script_path
method. #1157 -
Frameworks symlinks are not properly preserved by the copy resources script. Thanks to Thomas Dohmke (ashtom) for the fix. #1063
CocoaPods • cocoapods-core • Xcodeproj
-
Fixed a linter issue related to the dedicated targets change. #1130
-
Fixed xcconfig issues related to Pods including a dot in the name. #1152
CocoaPods • cocoapods-core • Xcodeproj
-
Pods are now built in dedicated targets. This enhancement isolates the build environment of each Pod from other ones eliminating pollution issues. It also introduces an important architectural improvement which lays the foundation for the upcoming CocoaPods features. Stay tuned! This feature has been implemented by Jeremy Slater. #1011 #983 #841
-
Reduced external dependencies and deprecation of Rake::FileList. #1080
-
Fixed crash due to Podfile.lock containing multiple version requirements for a Pod. #1076
-
Fixed a build error due to the copy resources script using the same temporary file for multiple targets. #1099
- Ensure that, in a sandbox-pod env, RubyGems loads the CocoaPods gem on system Ruby (1.8.7). #939
- Allow sandbox-pod to execute any tool inside the Xcode.app bundle.
- Allow sandbox-pod to execute any tool inside a rbenv prefix.
- Made sandbox-pod executable visible as it wasn't correctly configured in the gemspec.
- Made sandbox-pod executable actually work when installed as a gem. (In which case every executable is wrapped in a wrapper bin script and the DATA constant can no longer be used.)
- Required CLAide 0.3.2 as 0.3.0 didn't include all the files in the gemspec and 0.3.1 was not correctly processed by RubyGems.
CocoaPods • cocoapods-core • cocoapods-downloader • Xcodeproj • CLAide
-
Introduces an experimental sandbox feature. #939
Let’s face it, even though we have a great community that spends an amazing amount of time on curating the specifications, the internet can be a hostile place and the community is growing too large to take a naive approach any longer.
As such, we have started leveraging OS X’s sandbox facilities to disallow unsanctioned operations. This is still very experimental and therefore has to be used explicitely, for now, but that does not mean we don’t want you to start using it and report issues.
To use the sandbox, simply use the
sandbox-pod
command instead. E.g.:$ sandbox-pod install
In case of issues, be sure to check
/var/log/system.log
for ‘deny’ messages. For instance, here’s an example where the sandbox denies read access to/
:May 16 00:23:35 Khaos kernel[0]: Sandbox: ruby(98430) deny file-read-data /
NOTE: The above example is actually one that we know of. We’re not sure yet which process causes this, but there shouldn’t be a need for any process to read data from the root path anyways.
NOTE 2: At the moment the sandbox is not compatible with the
:path
option when referencing Pods that are not stored within the directory of the Podfile. -
The naked
pod
command now defaults topod install
. #958 -
CocoaPods will look for the Podfile in the ancestors paths if one is not available in the working directory. #940
-
Documentation generation has been removed from CocoaPods as it graduated to CocoaDocs. This decision was taken because CocoaDocs is a much better solution which doesn't clutter Xcode's docsets while still allowing access to the docsets with Xcode and with Dash. Removing this feature keeps the installer leaner and easier to develop and paves the way for the upcoming sandbox. Private pods can use pre install hook to generate the documentation. If there will be enough demand this feature might be reintegrated as plugin (see #1037).
-
Improved performance of the copy resources script and thus build time of the integrated targets. Contribution by @onato #1050.
-
The changelog for the current version is printed after CocoaPods is installed/updated. #853.
- Inheriting
inhibit_warnings
per pod is now working #1032 - Fix copy resources script for iOS < 6 and OS X < 10.8 by removing the
--reference-external-strings-file
flag. #1030 - Fixed issues with the
:head
option of the Podfile. #1046 #1039
- Project-level preprocessor macros are not overwritten anymore. #903
- A Unique hash instances for the build settings of the Pods target is now created resolving interferences in the hooks. #1014
- Compile time introspection. Macro definitions which allow to inspect the installed Pods and their version have been introduced in the build environment of the Pod libraries (example).
- CocoaPods now defines the
COCOAPODS=1
macro in the Pod and the Client targets. This is useful for libraries which conditionally expose interfaces. #903 - Added support for the
private_header_files
attribute of the Specification DSL. #998 - CocoaPods now defines the deployment target of the Pods project computed as the minimum deployment target of the Pods libraries. #556
- Added
pod podfile-info
command. Shows list of used Pods and their info in a project or supplied Podfile. Options:--all
- with dependencies.--md
- in Markdown. #855 - Added
pod help
command. You can still use the old format with --help flag. #957 - Restored support for Podfiles named
CocoaPods.podfile
. Moreover, the experimental YAML format of the Podfile now is associated with files namedCocoaPods.podfile.yaml
. #1004
- The
:local
flag in Podfile has been renamed to:path
and the old syntax has been deprecated. #971
- Fixed issue related to
pod outdated
and external sources. #954 - Fixed issue with .svn folders in copy resources script. #972
- Fixed a bug introduced in 0.18 which cause compilation issue due to the quoting of the inherited value in the xcconfigs. #956
- Robustness against user targets including build files with missing file references. #938
- Partially fixed slow performance from the command line #919
CocoaPods • cocoapods-core • Xcodeproj
- Added the ability to inhibit warnings per pod.
Just pass
:inhibit_warnings => true
inline. This feature has been implemented by Marin Usalj (@mneorr). #10 #934 - Inhibiting warnings will also suppress the warnings of the static analyzer.
- A new build phase has been added to check that your
installation is in sync with the
Podfile.lock
and fail the build otherwise. The new build phase will not be added automatically to targets already integrated with CocoaPods, for integrating targets manually see this comment. This feature has been implemented by Ullrich Schäfer (@stigi). #946 - The
pod search
commands now accepts the--ios
and the--osx
arguments to filter the results by platform. #625 - The developer frameworks are automatically added if
SenTestingKit
is detected. There is no need to specify them in specifications anymore. #771 - The
--no-update
argument of theinstall
,update
,outdated
subcommands has been renamed to--no-repo-update
. #913
- Improved handling for Xcode projects containing non ASCII characters. Special thanks to Cédric Luthi (@0xced), Vincent Isambart (@vincentisambart), and Manfred Stienstra (@Manfred) for helping to develop the workaround. #926
- Corrected improper configuration of the PODS_ROOT xcconfig variable in non-integrating installations. #918
- Improved support for pre-release versions using dashes. #935
- Documentation sets are now namespaced by pod solving improper attribution. #659
- Fix crash related to the specification of the workspace as a relative path. #920
- Fix an issue related to the
podspec
dsl directive of the Podfile for specifications with internal dependencies. #928 - Fix crash related to search from the command line. #929
- Enabled the FileList deprecation warning in the Linter.
- CocoaPods will raise if versions requirements are specified for dependencies with external sources.
- The exclude patterns now handle folders automatically.
- Always create the CACHE_ROOT directory when performing a search. #917
- Don’t break when specifying doc options, but not appledoc ones. #906
- Sort resolved specifications. #907
- Subspecs do not need to include HEAD information. #905
- Allow the analyzer to do its work without updating sources. motion-cocoapods#50
- Fixed an issue which lead to the missing declaration of the plural directives of the Specification DSL. #816
- The resolver now respects the order of specification of the target definitions.
- Restore usage of cache file to store a cache for expensive stats.
- Moved declaration of
Pod::FileList
to CocoaPods-core.
- Fine tuned the Specification linter and the health reporter of repositories.
- Search results are sorted.
- CocoaPods updates the repositories by default. #872
- Fixed a crash which was present when the Podfile specifies a workspace. #871
- Fix for a bug which lead to a broken installation in paths containing brackets and other glob metacharacters. #862
- Fix for a bug related to the case of the paths which lead to clean all files in the directories of the Pods.
- CocoaPods now maintains a search index which is updated incrementally instead
of analyzing all the specs every time. The search index can be updated
manually with the
pod ipc update-search-index
command. - Enhancements to the
pod repo lint
command. - CocoaPods will not create anymore the pre commit hook in the master repo
during setup. If already created it is possible remove it deleting the
~/.cocoapods/master/.git/hooks/pre-commit
path. - Improved support for linting and validating specs repo.
- The
--no-clean
argument is not ignored anymore by the installer. - Proper handling of file patterns ending with a slash.
- More user errors are raised as an informative.
- Restored compatibility with
Podfile::TargetDefinition#copy_resources_script_name
in the Podfile hooks. - Updated copy resources script so that it will use base internationalization #846
- Robustness against an empty configuration file.
- Fixed a crash with
pod push
#848 - Fixed an issue which lead to the creation of a Pods project which would crash Xcode. #854
- Fixed a crash related to a
PBXVariantGroup
present in the frameworks build phase of client targets. #859
- The
podspec
option of thepod
directive of the Podfile DSL now accepts folders.
[CocoaPods](https://github.com/CocoaPods/CocoaPods/compare/0.17.0.rc2...0.17.0.rc3 • Xcodeproj)
- CocoaPods will not crash anymore if the license file indicated on the spec doesn't exits.
- Pre install hooks are called before the Pods are cleaned.
- Fixed and issue which prevent the inclusion of OTHER_CFLAGS and OTHER_CPLUSPLUSFLAGS in the release builds of the Pods project.
- Fixed
pod lint --local
- Fixed the
--allow-warnings
ofpod push
#835 - Added
copy_resources_script_name
to the library representation used in the hooks. #837
- General improvements to
pod ipc
. - Added
pod ipc repl
subcommand.
- Restored output coloring.
- Fixed a crash related to subspecs #819
- Git repos were not cached for dependencies with external sources. #820
- Restored support for directories for the preserve_patterns specification attribute. #823
CocoaPods • Xcodeproj • cocoapods-core • cocoapods-downloader
At some point in future the master repo will be switched to the YAML format of specifications. This means that specifications with hooks (or any other kind of dynamic logic) will not be accepted. Please let us know if there is need for other DSL attributes or any other kind of support.
Currently the following specifications fail to load as they depended on the CocoaPods internals and need to be updated:
- LibComponentLogging-pods/0.0.1/LibComponentLogging-pods.podspec
- RestKit/0.9.3/RestKit.podspec
- Three20/1.0.11/Three20.podspec
- ARAnalytics/1.1/ARAnalytics.podspec
Other specifications, might present compatibility issues for the reasons presented below.
- Subspecs do not inherit the files patterns from the parent spec anymore. This feature made the implementation more complicated and was not easy to explain to podspecs maintainers. Compatibility can be easily fixed by adding a 'Core' subspec.
- Support for inline podspecs has been removed.
- The support for Rake::FileList is being deprecated, in favor of a more consistent DSL. Rake::FileList also presented issues because it would access the file system as soon as it was converted to an array.
- The hooks architecture has been re-factored and might present incompatibilities (please open an issue if appropriate).
- The
requires_arc
attribute default value is transitioning fromfalse
totrue
. In the meanwhile a value is needed to pass the lint. - Deprecated
copy_header_mapping
hook. - Deprecated
exclude_header_search_paths
attribute. - External sources are not supported in the dependencies of specifications anymore. Actually they never have been supported, they just happened to work.
- Podfile:
- It is not needed to specify the platform anymore (unless not integrating) as CocoaPods now can infer the platform from the integrated targets.
- Specification:
preferred_dependency
has been renamed todefault_subspec
.- Added
exclude_files
attribute. - Added
screenshots
attribute. - Added default values for attributes like
source_files
.
- Released preview documentation.
- CocoaPods now has support for working in teams and not committing the Pods folder, as it will keep track of the status of the Pods folder. #552
- Simplified installation: no specific version of ruby gems is required anymore.
- The workspace is written only if needed greatly reducing the occasions in which Xcode asks to revert.
- The Lockfile is sorted reducing the SCM noise. #591
- Added Podfile, Frameworks, and Resources to the Pods project. #647 #588
- Adds new subcommand
pod spec cat NAME
to print a spec file to standard output. - Specification hooks are only called when the specification is installed.
- The
--no-clean
option of thepod spec lint
command now displays the Pods project for inspection. - It is now possible to specify default values for the configuration in
~/.cocoapods/config.yaml
(default values). - CocoaPods now checks the checksums of the installed specifications and reinstalls them if needed.
- Support for YAML formats of the Podfile and the Specification.
- Added new command
pod ipc
to provide support for inter process communication through YAML formats. - CocoaPods now detects if the folder of a Pod is empty and reinstalls it. #534
- Install hooks and the
prefix_header_contents
attribute are supported in subspecs. #617 - Dashes are now supported in the versions of the Pods. #293
- CocoaPods is not confused anymore by target definitions with different activated subspec. #535
- CocoaPods is not confused anymore by to dependencies from external sources. #548
- The git cache will always update against the remote if a tag is requested, resolving issues where library maintainers where updating the tag after a lint and would be confused by CocoaPods using the cached commit for the tag. #407 #596
- Major clean up and refactor of the whole code base.
- Extracted the core classes into cocoapods-core gem.
- Extracted downloader into cocoapods-downloader.
- Extracted command-line command & option handling into CLAide.
- Explicitely require
date
in the gemspec for Ruby 2.0.0. 34da3f7
- Only flatten tarballs, not zipballs, from HTTP sources. A zipball can contain single directories in the root that should be preserved, for instance a framework bundle. This reverts part of the change in 0.16.1. NOTE This will break some podspecs that were changed after 0.16.1. #783 #727
- Never consider aggregate targets in the user’s project for integration. #729 #784
- Support comments on all build phases, groups and targets in Xcode projects. #51
- Ensure default Xcode project values are copied before being used. b43087c
- Block assertions in Release builds. #53 #803 #802
- Compile Core Data model files. #795
- Add
Xcodeproj::Differ
, which shows differences between Xcode projects. 308941e
- Quote storyboard and xib paths in ‘copy resource’ script. #740
- Fix use of
podspec
directive in Podfile with no options specified. #768 - Generate Mac OS X Pods target with the specified deployment target. #757
- Disable libSystem objects for ARC libs that target older platforms. This applies when the deployment target is set to < iOS 6.0 or OS X 10.8, or not specified at all. #352 #1161
- Mark header source files as ‘Project’ not ‘Public’. #747
- Add
PBXGroup
as acceptablePBXFileReference
value. #49 - Make
xcodeproj show
without further arguments actually work. #45
- Added support for pre-download over Mercurial. #750
- After unpacking source from a HTTP location, move the source into the parent dir if the archive contained only one child. This is done to make it consistent with how source from other types of locations are described in a podspec. NOTE This might break some podspecs that assumed the incorrect layout. #727 #728
- Remove duplicate option in
pod update
command. #725 - Memory fixes in Xcodeproj. #43
- Sort contents of xcconfig files by setting name. #591
- Add helpers to get platform name, deployment target, and frameworks build phases
- Take SDKROOT into account when adding frameworks.
- Use Rake 0.9.4 #657
- The usage of specifications defined in a Podfile is deprecated. Use the
:podspec
option with a file path instead. Complete removal will most probably happen in 0.17.0. #549 #616 #525
- Always consider inline podspecs as needing installation.
- Fix detection when the lib has already been integrated with the user’s target. #643 #614 #613
- Fix for Rake 0.9.3 #657
- Added support for copying frameworks to the app bundle. #597
- Ignore PBXReferenceProxy while integrating into user project. #626
- Added support for PBXAggregateTarget and PBXLegacyTarget. #615
- Added support for PBXReferenceProxy. #612
- Fix for uninitialized constant Xcodeproj::Constants error.
- Xcodeproj partial rewrite.
#565
#561
- Performance improvements in the
Generating support files
phase. - Better support for editing existing projects and sorting groups.
- Performance improvements in the
- Added support for
.hh
headers. #576
- Restored support for running CocoaPods without a terminal. #575 #577
- The git cache now always uses a barebones repo preventing a number of related issues. #581 #569
- Improved fix for the issue that lead to empty directories for Pods. #572 #602
- Xcodeproj robustness against invalid values, such as malformed UTF8. #592
- Show error if syntax error in Podfile or Podfile.lock.
- Fixed an issue that lead to empty directories for Pods. #519 #568
- Fixed a crash related to the RubyGems version informative. #570
- Fixed a crash for
pod outdated
. #567 - Fixed an issue that lead to excessively slow sets computation.
- Pod
install
will update the specs repo only if needed. #533 - CocoaPods now searches for the highest version of a Pod on all the repos. #85
- Added a pre install hook to the Podfile and to root specifications. #486
- Support for
header_mappings_dir
attribute in subspecs. - Added support for linting a Podspec using the files from its folder
pod spec lint --local
- Refactored UI.
- Added support for Podfiles named
CocoaPods.podfile
which allows to associate an editor application in Mac OS X. #528 - Added config option to disable the new version available message. #448
- Added support for extracting
.tar.bz2
files #522 - Improved feedback for errors of repo subcommands. #505
- Subspecs namespacing has been restored. #541
- Improvements to the git cache that should be more robust.
#517
- In certain conditions pod setup would execute twice.
- The git cache now is updated if a branch is not found #514
- Forcing UTF-8 encoding on licenses generation in Ruby 1.9. #530
- Added support for
.hpp
headers. #244
- In certain conditions the spec of an external would have been overridden by the spec in the root of a Pod. #489
- CocoaPods now uses a recent version of Octokit. #490
- Fixed a bug that caused Pods with preferred dependencies to be always installed. Specs#464
- Fixed Xcode 4.4+ artwork warning. Specs#508
- Fix incorrect name for Pods from external sources with preferred subspecs. #485
- Prevent duplication of Pod with a local source and mutliple activated specs. #485
- Fixed the
uninitialized constant Pod::Lockfile::Digest
error. #484
- Improve installation process by preserving the installed versions of Pods
across installations and machines. A Pod is reinstalled if:
- the version required in the Podfile changes and becomes incompatible with the installed one. #191
- the external source changes.
- the head status changes (from disabled to enabled or vice-versa).
- Introduce
pod update
command that installs the dependencies of the Podfile ignoring the lockfilePodfile.lock
. #131 - Introduce
pod outdated
command that shows the pods with known updates. - Add
:local
option for dependencies which will use the source files directly from a local directory. This is usually used for libraries that are being developed in parallel to the end product (application/library). #458, #415, #156. - Folders of Pods which are no longer required are removed during installation. #298
- Add meaningful error messages
- The subversion downloader now does an export instead of a checkout, which makes it play nicer with SCMs that store metadata in each directory. #245
- Now the Podfile is added to the Pods project for convenient editing.
- The git cache now fetches the tags from the remote if it can’t find the reference.
- Xcodeproj now builds on 10.6.8 and Travis CI without symlinking headers.
- Only try to install, add source files to the project, and clean a Pod once. #376
- External Pods might be reinstalled due to the migration to the new
Podfile.lock
. - The SCM reference of head Pods is not preserved across machines.
- Pods whose inline specification changed are not detected as modified. As a
workaround, remove their folder stored in
Pods
. - Pods whose specification changed are not detected as modified. As a
workaround, remove their folder stored in
Pods
.
- Add Podfile
podspec
which allows to use the dependencies of a podspec file. #162 - Check if any of the build settings defined in the xcconfig files is overridden. #92
- The Linter now checks that there are no compiler flags that disable warnings.
- The final project isn’t affected anymore by the
inhibit_all_warnings!
option. - Support for redirects while using podspec from an url. #462
- The documentation is generated using the public headers if they are specified.
- In case of a download failure the installation is aborted and the error message is shown.
- Git submodules are initialized only if requested.
- Don’t impose a certain structure of the user’s project by raising if no ‘Frameworks’ group exists. #431
- Support for GitHub Gists in the linter.
- Allow specifying ARC settings in subspecs.
- Add Podfile
inhibit_all_warnings!
which will inhibit all warnings from the Pods library. #209 - Make the Pods Xcode project prettier by namespacing subspecs in nested groups. #466
- Fixed a crash related to subspecs without header files. [#449]
- Git submodules are loaded after the appropriate referenced is checked out and will be not loaded anymore in the cache. [#451]
- Fixed SVN support for the head version. [#432]
- Added support for public headers. [#440]
- Added
pod repo lint
. [#423] - Improved support for
:head
option and SVN repositories. - When integrating Pods with a project without "Frameworks" group in root of the project, raise an informative message. #431
- Dropped support for legacy
config.ios?
andconfig.osx?
- Version message now correctly terminates with a 0 exit status.
- Resolved an issue that lead to git error messages in the error report.
- Added a
--local-only
option topod push
so that developers can push locally and test before pushing to a remote. #405 - Added line number information for errors generated in the Podfile. #408
- Pods stored in git repositories now initialize submodules. #406
- Removed note about the post install hook form the linter.
- Improved xcodebuild error detection in the linter.
- Ensure the git cache exists, before updating it, when trying to install the ‘bleeding edge’ of a pod. #426
- Clean downloaded external pods after resolving and activating (sub)specs. #414
- Support
tar.gz
as filename in a HTTP source. #428
- When generating the PodsDummy class, make that class unique to each target. #402
- Raise an informative error message when the platform in the
Podfile
is omitted or incorrect. #403
- CocoaPods 0.9.x needs Xcodeproj 0.3.0.
- Force downloading the ‘bleeding edge’ version of a pod with the
:head
flag. #392 - Support for weak frameworks. #263
- Use double quotes when shelling out. This makes a url like
$HOME/local/lib
work. #396
- Relaxed linter to accepts pod that only specify paths to preserve (like TuneupJS).
- Gender neutralization of podfile documentation. #384
- Exit early when using an old RubyGems version (< 1.4.0). These versions contain subtle bugs related to prerelease version comparisons. Unfortunately, OS X >= 10.7 ships with 1.3.6. #398
Syntax change in Podfile: dependency
has been replaced by pod
.
ruby platform :ios pod 'JSONKit', '~> 1.4' pod 'Reachability', '~> 2.0.4'
- Properly quote all paths given to Git.
- Added support for branches in git repos.
- Added support for linting remote files, i.e.
pod spec lint http://raw/file.podspec
. - Improved
Spec create template
. - The indentation is automatically stripped for podspecs strings.
- The default warnings of Xcode are not overriden anymore.
- Improvements to the detection of the license files.
- Improvements to
pod spec lint
. - CocoaPods is now case insensitive.
- Switched to master branch for specs repo.
- Fixed a crash with
pod spec lint
related topreserve_paths
. - Fixed a bug that caused subspecs to not inherit the compiler flags of the top level specification.
- Fixed a bug that caused duplication of system framworks.
A full list of all the changes since 0.5.1 can be found here.
CocoaPods can now integrate all the targets specified in your Podfile
.
To specify which target, in your Xcode project, a Pods target should be linked
with, use the link_with
method like so:
``ruby platform :ios
workspace 'MyWorkspace'
link_with ['MyAppTarget', 'MyOtherAppTarget'] dependency 'JSONKit'
target :test, :exclusive => true do xcodeproj 'TestProject', 'Test' => :debug link_with 'TestRunnerTarget' dependency 'Kiwi' end ``
NOTE: As you can see it can take either one target name, or an array of names.
-
If no explicit Xcode workspace is specified and only one project exists in the same directory as the Podfile, then the name of that project is used as the workspace’s name.
-
If no explicit Xcode project is specified for a target, it will use the Xcode project of the parent target. If no target specifies an expicit Xcode project and there is only one project in the same directory as the Podfile then that project will be used.
-
If no explicit target is specified, then the Pods target will be linked with the first target in your project. So if you only have one target you do not need to specify the target to link with.
See #76 for more info.
Finally, CocoaPods will add build configurations to the Pods project for all
configurations in the other projects in the workspace. By default the
configurations are based on the Release
configuration, to base them on the
Debug
configuration you will have to explicitely specify them as can be seen
above in the following line:
xcodeproj 'TestProject', 'Test' => :debug
CocoaPods will now generate documentation for every library with the
appledoc
tool and install it into Xcode’s documentation viewer.
You can customize the settings used like so:
s.documentation = { :appledoc => ['--product-name', 'My awesome project!'] }
Alternatively, you can specify a URL where an HTML version of the documentation can be found:
s.documentation = { :html => 'http://example.com/docs/index.html' }
See #149 and #151 for more info.
CocoaPods will now generate two 'Acknowledgements' files for each target specified in your Podfile which contain the License details for each Pod used in that target (assuming details have been specified in the Pod spec).
There is a markdown file, for general consumption, as well as a property list file that can be added to a settings bundle for an iOS application.
You don't need to do anything for this to happen, it should just work.
If you're not happy with the default boilerplate text generated for the title, header
and footnotes in the files, it's possible to customise these by overriding the methods
that generate the text in your Podfile
like this:
class ::Pod::Generator::Acknowledgements
def header_text
"My custom header text"
end
end
You can even go one step further and customise the text on a per target basis by checking against the target name, like this:
class ::Pod::Generator::Acknowledgements
def header_text
if @target_definition.label.end_with?("MyTargetName")
"Custom header text for MyTargetName"
else
"Custom header text for other targets"
end
end
end
Finally, here's a list of the methods that are available to override:
header_title
header_text
footnote_title
footnote_text
The Sandbox represents the entire contents of the POD_ROOT
(normally
SOURCE_ROOT/Pods
). A LocalPod represents a pod that has been installed within
the Sandbox.
These two classes can be used as better homes for various pieces of logic currently spread throughout the installation process and provide a better API for working with the contents of this directory.
All Xcodeproj APIs are now in snake_case
, instead of camelCase
. If you are
manipulating the project from your Podfile's post_install
hook, or from a
podspec, then update these method calls.
-
#188:
list
command now displays the specifications introduced in the master repo if it is given as an option the number of days to take into account. -
#188: Transferred search layout improvements and options to
list
command. -
#166: Added printing of homepage and source to search results.
-
#177: Added
--stat
option to display watchers and forks for pods hosted on GitHub. -
#177: Introduced colors and tuned layout of search.
-
#112: Introduced
--push
option to$ pod setup
. It configures the master spec repository to use the private push URL. The change is preserved in future calls to$ pod setup
. -
#153: It is no longer required to call
$ pod setup
. -
#163: Print a template for a new ticket when an error occurs.
-
Added a new Github-specific downloader that can download repositories as a gzipped tarball.
-
No more global state is kept during resolving of dependencies.
-
Updated Xcodeproj to have a friendlier API.
-
#142: Xcode 4.3.2 no longer supports passing the -fobj-arc flag to the linker and will fail to build. The addition of this flag was a workaround for a compiler bug in previous versions. This flag is no longer included by default - to keep using this flag, you need to add
set_arc_compatibility_flag!
to your Podfile. -
#183: Fix for
.DS_Store
file in~/.cocoapods
prevents$ pod install
from running. -
#134: Match
IPHONEOS_DEPLOYMENT_TARGET
build setting withdeployment_target
option in generated Pods project file. -
#142: Add
-fobjc-arc
toOTHER_LDFLAGS
if any pods require ARC. -
#148: External encoding set to UTF-8 on Ruby 1.9 to fix crash caused by non-ascii characters in pod description.
-
Ensure all header search paths are quoted in the xcconfig file.
-
Added weak quoting to
ibtool
input paths.
No longer requires MacRuby. Runs on MRI 1.8.7 (OS X system version) and 1.9.3.
A full list of all the changes since 0.3.0 can be found here.
Oops, accidentally skipped this version.
Add support for multiple static library targets in the Pods Xcode project with different sets of depedencies. This means that you can create a separate library which contains all dependencies, including extra ones that you only use in, for instance, a debug or test build. [docs]
# This Podfile will build three static libraries:
# * libPods.a
# * libPods-debug.a
# * libPods-test.a
# This dependency is included in the `default` target, which generates the
# `libPods.a` library, and all non-exclusive targets.
dependency 'SSCatalog'
target :debug do
# This dependency is only included in the `debug` target, which generates
# the `libPods-debug.a` library.
dependency 'CocoaLumberjack'
end
target :test, :exclusive => true do
# This dependency is *only* included in the `test` target, which generates
# the `libPods-test.a` library.
dependency 'Kiwi'
end
A dependency can take a git url if the repo contains a podspec file in its root, or a podspec can be loaded from a file or HTTP location. If no podspec is available, a specification can be defined inline in the Podfile. [docs]
# From a spec repo.
dependency 'SSToolkit'
# Directly from the Pod’s repo (if it contains a podspec).
dependency 'SSToolkit', :git => 'https://github.com/samsoffes/sstoolkit.git'
# Directly from the Pod’s repo (if it contains a podspec) with a specific commit (or tag).
dependency 'SSToolkit', :git => 'https://github.com/samsoffes/sstoolkit.git',
:commit => '2adcd0f81740d6b0cd4589af98790eee3bd1ae7b'
# From a podspec that's outside a spec repo _and_ the library’s repo. This can be a file or http url.
dependency 'SSToolkit', :podspec => 'https://raw.github.com/gist/1353347/ef1800da9c5f5d267a642b8d3950b41174f2a6d7/SSToolkit-0.1.1.podspec'
# If no podspec is available anywhere, you can define one right in your Podfile.
dependency do |s|
s.name = 'SSToolkit'
s.version = '0.1.3'
s.platform = :ios
s.source = { :git => 'https://github.com/samsoffes/sstoolkit.git', :commit => '2adcd0f81740d6b0cd4589af98790eee3bd1ae7b' }
s.resources = 'Resources'
s.source_files = 'SSToolkit/**/*.{h,m}'
s.frameworks = 'QuartzCore', 'CoreGraphics'
def s.post_install(target)
prefix_header = config.project_pods_root + target.prefix_header_filename
prefix_header.open('a') do |file|
file.puts(%{#ifdef __OBJC__\n#import "SSToolkitDefines.h"\n#endif})
end
end
end
This allows the user to customize, for instance, the generated Xcode project before it’s written to disk. [docs]
# Enable garbage collection support for MacRuby applications.
post_install do |installer|
installer.project.targets.each do |target|
target.build_configurations.each do |config|
config.build_settings['GCC_ENABLE_OBJC_GC'] = 'supported'
end
end
end
Generate a Podfile.lock file next to the Podfile, which contains a manifest of your application’s dependencies and their dependencies.
PODS:
- JSONKit (1.4)
- LibComponentLogging-Core (1.1.4)
- LibComponentLogging-NSLog (1.0.2):
- LibComponentLogging-Core (>= 1.1.4)
- RestKit-JSON-JSONKit (0.9.3):
- JSONKit
- RestKit (= 0.9.3)
- RestKit-Network (0.9.3):
- LibComponentLogging-NSLog
- RestKit (= 0.9.3)
- RestKit-ObjectMapping (0.9.3):
- RestKit (= 0.9.3)
- RestKit-Network (= 0.9.3)
DOWNLOAD_ONLY:
- RestKit (0.9.3)
DEPENDENCIES:
- RestKit-JSON-JSONKit
- RestKit-ObjectMapping
We no longer ship template projects with the gem, but instead generate them programmatically. This code has moved out into its own Xcodeproj gem, allowing you to automate Xcode related tasks.