Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
C
cocoapods
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
gengmeiios
cocoapods
Commits
ec3d6542
Commit
ec3d6542
authored
Nov 05, 2011
by
Eloy Duran
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'dependency-targets'. Closes #11.
parents
99417d11
340bdb1e
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
24 changed files
with
367 additions
and
421 deletions
+367
-421
Podfile
examples/MacRubySample/Podfile
+8
-0
project.pbxproj
examples/SSCatalog/SSCatalog.xcodeproj/project.pbxproj
+1
-1
bridge_support_generator.rb
lib/cocoapods/bridge_support_generator.rb
+2
-4
installer.rb
lib/cocoapods/installer.rb
+138
-40
podfile.rb
lib/cocoapods/podfile.rb
+63
-5
resolver.rb
lib/cocoapods/resolver.rb
+5
-5
specification.rb
lib/cocoapods/specification.rb
+5
-4
config.rb
lib/cocoapods/xcode/config.rb
+2
-2
copy_resources_script.rb
lib/cocoapods/xcode/copy_resources_script.rb
+15
-3
project.rb
lib/cocoapods/xcode/project.rb
+0
-0
integration_spec.rb
spec/integration_spec.rb
+76
-26
bridge_support_generator_spec.rb
spec/unit/bridge_support_generator_spec.rb
+2
-2
installer_spec.rb
spec/unit/installer_spec.rb
+5
-70
podfile_spec.rb
spec/unit/podfile_spec.rb
+41
-0
config_spec.rb
spec/unit/xcode/config_spec.rb
+1
-1
project_spec.rb
spec/unit/xcode/project_spec.rb
+0
-0
Pods-Prefix.pch
xcode-project-templates/cocoa-static-library/Pods-Prefix.pch
+0
-7
Pods.xcconfig
xcode-project-templates/cocoa-static-library/Pods.xcconfig
+0
-1
project.pbxproj
...lates/cocoa-static-library/Pods.xcodeproj/project.pbxproj
+0
-104
PodsResources.sh
...e-project-templates/cocoa-static-library/PodsResources.sh
+0
-8
Pods-Prefix.pch
...ject-templates/cocoa-touch-static-library/Pods-Prefix.pch
+0
-7
Pods.xcconfig
...roject-templates/cocoa-touch-static-library/Pods.xcconfig
+0
-1
project.pbxproj
...cocoa-touch-static-library/Pods.xcodeproj/project.pbxproj
+3
-122
PodsResources.sh
...ect-templates/cocoa-touch-static-library/PodsResources.sh
+0
-8
No files found.
examples/MacRubySample/Podfile
View file @
ec3d6542
...
@@ -4,3 +4,11 @@ generate_bridge_support!
...
@@ -4,3 +4,11 @@ generate_bridge_support!
dependency
'ASIHTTPRequest'
dependency
'ASIHTTPRequest'
dependency
'SBJson'
dependency
'SBJson'
target
:debug
do
dependency
'CocoaLumberjack'
end
target
:test
,
:exclusive
=>
true
do
dependency
'Kiwi'
end
examples/SSCatalog/SSCatalog.xcodeproj/project.pbxproj
View file @
ec3d6542
...
@@ -330,7 +330,7 @@
...
@@ -330,7 +330,7 @@
);
);
runOnlyForDeploymentPostprocessing
=
0
;
runOnlyForDeploymentPostprocessing
=
0
;
shellPath
=
/bin/sh
;
shellPath
=
/bin/sh
;
shellScript
=
"${SRCROOT}/Pods/Pods
R
esources.sh"
;
shellScript
=
"${SRCROOT}/Pods/Pods
-r
esources.sh"
;
showEnvVarsInLog
=
0
;
showEnvVarsInLog
=
0
;
};
};
/* End PBXShellScriptBuildPhase section */
/* End PBXShellScriptBuildPhase section */
...
...
lib/cocoapods/bridge_support_generator.rb
View file @
ec3d6542
...
@@ -15,11 +15,9 @@ module Pod
...
@@ -15,11 +15,9 @@ module Pod
@headers
.
map
{
|
header
|
"-I '
#{
header
.
dirname
}
'"
}.
uniq
@headers
.
map
{
|
header
|
"-I '
#{
header
.
dirname
}
'"
}.
uniq
end
end
def
create_in
(
root
)
def
save_as
(
pathname
)
puts
"==> Generating BridgeSupport metadata file"
unless
config
.
silent?
puts
"==> Generating BridgeSupport metadata file"
unless
config
.
silent?
file
=
root
+
"Pods.bridgesupport"
gen_bridge_metadata
%{-c "#{search_paths.join(' ')}" -o '#{pathname}' '#{headers.join("' '")}'}
gen_bridge_metadata
%{-c "#{search_paths.join(' ')}" -o '#{file}' '#{headers.join("' '")}'}
file
end
end
end
end
end
end
lib/cocoapods/installer.rb
View file @
ec3d6542
module
Pod
module
Pod
class
Installer
class
Installer
include
Config
::
Mixin
module
Shared
def
initialize
(
specification
)
@specification
=
specification
end
def
dependent_specification_sets
def
dependent_specification_sets
@dependent_specification_sets
||=
Resolver
.
new
(
@specification
).
resolve
@dependent_specification_sets
||=
Resolver
.
new
(
@podfile
,
@definition
?
@definition
.
dependencies
:
nil
).
resolve
end
end
def
build_specification_sets
def
build_specification_sets
...
@@ -17,6 +12,17 @@ module Pod
...
@@ -17,6 +12,17 @@ module Pod
def
build_specifications
def
build_specifications
build_specification_sets
.
map
(
&
:specification
)
build_specification_sets
.
map
(
&
:specification
)
end
end
end
class
Target
include
Config
::
Mixin
include
Shared
attr_reader
:target
def
initialize
(
podfile
,
xcodeproj
,
definition
)
@podfile
,
@xcodeproj
,
@definition
=
podfile
,
xcodeproj
,
definition
end
def
xcconfig
def
xcconfig
@xcconfig
||=
Xcode
::
Config
.
new
({
@xcconfig
||=
Xcode
::
Config
.
new
({
...
@@ -29,75 +35,167 @@ module Pod
...
@@ -29,75 +35,167 @@ module Pod
})
})
end
end
def
templat
e
def
xcconfig_filenam
e
@template
||=
ProjectTemplate
.
new
(
@specification
.
platform
)
"
#{
@definition
.
lib_name
}
.xcconfig"
end
end
def
xcodeproj
def
copy_resources_script
@xcodeproj
||=
Xcode
::
Project
.
new
(
template
.
xcodeproj_path
)
@copy_resources_script
||=
Xcode
::
CopyResourcesScript
.
new
(
build_specifications
.
map
do
|
spec
|
spec
.
expanded_resources
end
.
flatten
)
end
def
copy_resources_filename
"
#{
@definition
.
lib_name
}
-resources.sh"
end
def
bridge_support_generator
BridgeSupportGenerator
.
new
(
build_specifications
.
map
do
|
spec
|
spec
.
header_files
.
map
do
|
header
|
config
.
project_pods_root
+
header
end
end
.
flatten
)
end
def
bridge_support_filename
"
#{
@definition
.
lib_name
}
.bridgesupport"
end
# TODO move out
def
save_prefix_header_as
(
pathname
)
pathname
.
open
(
'w'
)
do
|
header
|
header
.
puts
"#ifdef __OBJC__"
header
.
puts
"#import
#{
@podfile
.
platform
==
:ios
?
'<UIKit/UIKit.h>'
:
'<Cocoa/Cocoa.h>'
}
"
header
.
puts
"#endif"
end
end
def
prefix_header_filename
"
#{
@definition
.
lib_name
}
-prefix.pch"
end
end
# TODO move xcconfig related code into the xcconfig method, like copy_resources_script and generate_bridge_support.
# TODO move xcconfig related code into the xcconfig method, like copy_resources_script and generate_bridge_support.
def
generate_project
def
install!
puts
"==> Generating Xcode project and xcconfig"
unless
config
.
silent?
# First add the target to the project
@target
=
@xcodeproj
.
targets
.
new_static_library
(
@definition
.
lib_name
)
user_header_search_paths
=
[]
user_header_search_paths
=
[]
build_specifications
.
each
do
|
spec
|
build_specifications
.
each
do
|
spec
|
xcconfig
.
merge!
(
spec
.
xcconfig
)
xcconfig
.
merge!
(
spec
.
xcconfig
)
group
=
xcodeproj
.
add_pod_group
(
spec
.
name
)
# Only add implementation files to the compile phase
# Only add implementation files to the compile phase
spec
.
implementation_files
.
each
do
|
file
|
spec
.
implementation_files
.
each
do
|
file
|
group
.
add_source_file
(
file
,
nil
,
spec
.
compiler_flags
)
@target
.
add_source_file
(
file
,
nil
,
spec
.
compiler_flags
)
end
end
# Add header files to a `copy header build phase` for each destination
# Add header files to a `copy header build phase` for each destination
# directory in the pod's header directory.
# directory in the pod's header directory.
spec
.
copy_header_mappings
.
each
do
|
header_dir
,
files
|
spec
.
copy_header_mappings
.
each
do
|
header_dir
,
files
|
copy_phase
=
xcodeproj
.
add_copy_header_build_phase
(
spec
.
name
,
header_dir
)
copy_phase
=
@target
.
copy_files_build_phases
.
new_pod_dir
(
spec
.
name
,
header_dir
)
files
.
each
do
|
file
|
files
.
each
do
|
file
|
group
.
add_source_file
(
file
,
copy_phase
)
@target
.
add_source_file
(
file
,
copy_phase
)
end
end
end
end
# Collect all header search paths
# Collect all header search paths
user_header_search_paths
.
concat
(
spec
.
user_header_search_paths
)
user_header_search_paths
.
concat
(
spec
.
user_header_search_paths
)
end
end
xcconfig
.
merge!
(
'USER_HEADER_SEARCH_PATHS'
=>
user_header_search_paths
.
sort
.
uniq
.
join
(
" "
))
xcconfig
.
merge!
(
'USER_HEADER_SEARCH_PATHS'
=>
user_header_search_paths
.
sort
.
uniq
.
join
(
" "
))
# Add all the target related support files to the group, even the copy
# resources script although the project doesn't actually use them.
support_files_group
=
@xcodeproj
.
groups
.
find
do
|
group
|
group
.
name
==
"Targets Support Files"
end
.
groups
.
new
(
"name"
=>
@definition
.
lib_name
)
support_files_group
.
files
.
new
(
'path'
=>
copy_resources_filename
)
prefix_file
=
support_files_group
.
files
.
new
(
'path'
=>
prefix_header_filename
)
xcconfig_file
=
support_files_group
.
files
.
new
(
"path"
=>
xcconfig_filename
)
# Assign the xcconfig as the base config of each config.
@target
.
buildConfigurations
.
each
do
|
config
|
config
.
baseConfiguration
=
xcconfig_file
config
.
buildSettings
[
'GCC_PREFIX_HEADER'
]
=
prefix_header_filename
end
end
end
def
copy_resources_script
def
create_files_in
(
root
)
@copy_resources_script
||=
Xcode
::
CopyResourcesScript
.
new
(
build_specifications
.
map
{
|
spec
|
spec
.
expanded_resources
}.
flatten
)
xcconfig
.
save_as
(
root
+
xcconfig_filename
)
if
@podfile
.
generate_bridge_support?
bridge_support_generator
.
save_as
(
root
+
bridge_support_filename
)
copy_resources_script
.
resources
<<
bridge_support_filename
end
save_prefix_header_as
(
root
+
prefix_header_filename
)
copy_resources_script
.
save_as
(
root
+
copy_resources_filename
)
end
end
end
def
bridge_support_generator
include
Config
::
Mixin
BridgeSupportGenerator
.
new
(
build_specifications
.
map
do
|
spec
|
include
Shared
spec
.
header_files
.
map
do
|
header
|
config
.
project_pods_root
+
header
def
initialize
(
podfile
)
@podfile
=
podfile
end
def
template
@template
||=
ProjectTemplate
.
new
(
@podfile
.
platform
)
end
def
xcodeproj
unless
@xcodeproj
@xcodeproj
=
Xcode
::
Project
.
new
(
template
.
xcodeproj_path
)
# First we need to resolve dependencies across *all* targets, so that the
# same correct versions of pods are being used for all targets. This
# happens when we call `build_specifications'.
build_specifications
.
each
do
|
spec
|
# Add all source files to the project grouped by pod
group
=
xcodeproj
.
add_pod_group
(
spec
.
name
)
spec
.
expanded_source_files
.
each
do
|
path
|
group
.
children
.
new
(
'path'
=>
path
.
to_s
)
end
end
# Add a group to hold all the target support files
xcodeproj
.
main_group
.
groups
.
new
(
'name'
=>
'Targets Support Files'
)
end
@xcodeproj
end
def
targets
@targets
||=
@podfile
.
targets
.
values
.
map
do
|
target_definition
|
Target
.
new
(
@podfile
,
xcodeproj
,
target_definition
)
end
end
end
.
flatten
)
end
end
def
install!
def
install!
puts
"Installing dependencies of:
#{
@
specification
.
defined_in_file
}
"
unless
config
.
silent?
puts
"Installing dependencies of:
#{
@
podfile
.
defined_in_file
}
"
unless
config
.
silent?
build_specifications
.
each
(
&
:install!
)
build_specifications
.
each
(
&
:install!
)
generate_project
root
=
config
.
project_pods_root
root
=
config
.
project_pods_root
puts
" * Copying contents of template directory `
#{
template
.
path
}
' to `
#{
root
}
'"
if
config
.
verbose?
puts
" * Copying contents of template directory `
#{
template
.
path
}
' to `
#{
root
}
'"
if
config
.
verbose?
template
.
copy_to
(
root
)
template
.
copy_to
(
root
)
puts
"==> Generating Xcode project and xcconfig"
unless
config
.
silent?
targets
.
each
do
|
target
|
target
.
install!
target
.
create_files_in
(
root
)
end
pbxproj
=
File
.
join
(
root
,
'Pods.xcodeproj'
)
pbxproj
=
File
.
join
(
root
,
'Pods.xcodeproj'
)
puts
" * Writing Xcode project file to `
#{
pbxproj
}
'"
if
config
.
verbose?
puts
" * Writing Xcode project file to `
#{
pbxproj
}
'"
if
config
.
verbose?
xcodeproj
.
save_as
(
pbxproj
)
xcodeproj
.
save_as
(
pbxproj
)
xcconfig
.
create_in
(
root
)
if
@specification
.
generate_bridge_support?
path
=
bridge_support_generator
.
create_in
(
root
)
copy_resources_script
.
resources
<<
path
.
relative_path_from
(
config
.
project_pods_root
)
end
copy_resources_script
.
create_in
(
root
)
build_specifications
.
each
(
&
:post_install
)
# Post install hooks run last!
targets
.
each
do
|
target
|
target
.
build_specifications
.
each
{
|
spec
|
spec
.
post_install
(
target
)
}
end
end
end
# For now this assumes just one pods target, i.e. only libPods.a.
# Not sure yet if we should try to be smart with apps that have multiple
# targets and try to map pod targets to those app targets.
#
# Possible options are:
# 1. Only cater to the most simple setup
# 2. Try to automagically figure it out by name. For example, a pod target
# called `:some_target' could map to an app target called `SomeTarget'.
# (A variation would be to not even camelize the target name, but simply
# let the user specify it with the proper case.)
# 3. Let the user specify the app target name as an extra argument, but this
# seems to be a less good version of the variation on #2.
def
configure_project
(
projpath
)
def
configure_project
(
projpath
)
root
=
File
.
dirname
(
projpath
)
root
=
File
.
dirname
(
projpath
)
xcworkspace
=
File
.
join
(
root
,
File
.
basename
(
projpath
,
'.xcodeproj'
)
+
'.xcworkspace'
)
xcworkspace
=
File
.
join
(
root
,
File
.
basename
(
projpath
,
'.xcodeproj'
)
+
'.xcworkspace'
)
...
@@ -118,8 +216,8 @@ module Pod
...
@@ -118,8 +216,8 @@ module Pod
'lastKnownFileType'
=>
'text.xcconfig'
'lastKnownFileType'
=>
'text.xcconfig'
})
})
app_project
.
targets
.
each
do
|
target
|
app_project
.
targets
.
each
do
|
target
|
target
.
buildConfiguration
List
.
buildConfiguration
s
.
each
do
|
config
|
target
.
buildConfigurations
.
each
do
|
config
|
config
.
baseConfiguration
Reference
=
configfile
config
.
baseConfiguration
=
configfile
end
end
end
end
app_project
.
main_group
<<
configfile
app_project
.
main_group
<<
configfile
...
@@ -131,7 +229,7 @@ module Pod
...
@@ -131,7 +229,7 @@ module Pod
'sourceTree'
=>
'BUILT_PRODUCTS_DIR'
'sourceTree'
=>
'BUILT_PRODUCTS_DIR'
})
})
app_project
.
objects
.
select_by_class
(
Xcode
::
Project
::
PBXFrameworksBuildPhase
).
each
do
|
build_phase
|
app_project
.
objects
.
select_by_class
(
Xcode
::
Project
::
PBXFrameworksBuildPhase
).
each
do
|
build_phase
|
build_phase
.
files
<<
libfile
.
build
_file
build_phase
.
files
<<
libfile
.
build
Files
.
new
end
end
app_project
.
main_group
<<
libfile
app_project
.
main_group
<<
libfile
...
@@ -143,7 +241,7 @@ module Pod
...
@@ -143,7 +241,7 @@ module Pod
'outputPaths'
=>
[],
'outputPaths'
=>
[],
'runOnlyForDeploymentPostprocessing'
=>
'0'
,
'runOnlyForDeploymentPostprocessing'
=>
'0'
,
'shellPath'
=>
'/bin/sh'
,
'shellPath'
=>
'/bin/sh'
,
'shellScript'
=>
"${SRCROOT}/Pods/Pods
R
esources.sh
\n
"
'shellScript'
=>
"${SRCROOT}/Pods/Pods
-r
esources.sh
\n
"
})
})
app_project
.
targets
.
each
{
|
target
|
target
.
buildPhases
<<
copy_resources
}
app_project
.
targets
.
each
{
|
target
|
target
.
buildPhases
<<
copy_resources
}
...
...
lib/cocoapods/podfile.rb
View file @
ec3d6542
module
Pod
module
Pod
class
Podfile
class
Podfile
class
Target
attr_reader
:name
,
:parent
,
:target_dependencies
def
initialize
(
name
,
parent
=
nil
)
@name
,
@parent
,
@target_dependencies
=
name
,
parent
,
[]
end
def
lib_name
name
==
:default
?
"Pods"
:
"Pods-
#{
name
}
"
end
# Returns *all* dependencies of this target, not only the target specific
# ones in `target_dependencies`.
def
dependencies
@target_dependencies
+
(
@parent
?
@parent
.
dependencies
:
[])
end
end
def
self
.
from_file
(
path
)
def
self
.
from_file
(
path
)
podfile
=
Podfile
.
new
do
podfile
=
Podfile
.
new
do
eval
(
path
.
read
,
nil
,
path
.
to_s
)
eval
(
path
.
read
,
nil
,
path
.
to_s
)
...
@@ -9,8 +27,10 @@ module Pod
...
@@ -9,8 +27,10 @@ module Pod
podfile
podfile
end
end
include
Config
::
Mixin
def
initialize
(
&
block
)
def
initialize
(
&
block
)
@
dependencies
=
[]
@
targets
=
{
:default
=>
(
@target
=
Target
.
new
(
:default
))
}
instance_eval
(
&
block
)
instance_eval
(
&
block
)
end
end
...
@@ -58,10 +78,12 @@ module Pod
...
@@ -58,10 +78,12 @@ module Pod
# * http://semver.org
# * http://semver.org
# * http://docs.rubygems.org/read/chapter/7
# * http://docs.rubygems.org/read/chapter/7
def
dependency
(
name
,
*
version_requirements
)
def
dependency
(
name
,
*
version_requirements
)
@dependencies
<<
Dependency
.
new
(
name
,
*
version_requirements
)
@
target
.
target_
dependencies
<<
Dependency
.
new
(
name
,
*
version_requirements
)
end
end
attr_reader
:dependencies
def
dependencies
@targets
.
values
.
map
(
&
:target_dependencies
).
flatten
end
# Specifies that a BridgeSupport metadata should be generated from the
# Specifies that a BridgeSupport metadata should be generated from the
# headers of all installed Pods.
# headers of all installed Pods.
...
@@ -72,6 +94,42 @@ module Pod
...
@@ -72,6 +94,42 @@ module Pod
@generate_bridge_support
=
true
@generate_bridge_support
=
true
end
end
attr_reader
:targets
# Defines a new static library target and scopes dependencies defined from
# the given block. The target will by default include the dependencies
# defined outside of the block, unless the `:exclusive => true` option is
# given.
#
# Consider the following Podfile:
#
# dependency 'ASIHTTPRequest'
#
# target :debug do
# dependency 'SSZipArchive'
# end
#
# target :test, :exclusive => true do
# dependency 'JSONKit'
# end
#
# This Podfile defines three targets. The first one is the `:default` target,
# which produces the `libPods.a` file. The second and third are the `:debug`
# and `:test` ones, which produce the `libPods-debug.a` and `libPods-test.a`
# files.
#
# The `:default` target has only one dependency (ASIHTTPRequest), whereas the
# `:debug` target has two (ASIHTTPRequest, SSZipArchive). The `:test` target,
# however, is an exclusive target which means it will only have one
# dependency (JSONKit).
def
target
(
name
,
options
=
{})
parent
=
@target
@targets
[
name
]
=
@target
=
Target
.
new
(
name
,
options
[
:exclusive
]
?
nil
:
parent
)
yield
ensure
@target
=
parent
end
# This is to be compatible with a Specification for use in the Installer and
# This is to be compatible with a Specification for use in the Installer and
# Resolver.
# Resolver.
...
@@ -86,13 +144,13 @@ module Pod
...
@@ -86,13 +144,13 @@ module Pod
end
end
def
dependency_by_name
(
name
)
def
dependency_by_name
(
name
)
@
dependencies
.
find
{
|
d
|
d
.
name
==
name
}
dependencies
.
find
{
|
d
|
d
.
name
==
name
}
end
end
def
validate!
def
validate!
lines
=
[]
lines
=
[]
lines
<<
"* the `platform` attribute should be either `:osx` or `:ios`"
unless
[
:osx
,
:ios
].
include?
(
@platform
)
lines
<<
"* the `platform` attribute should be either `:osx` or `:ios`"
unless
[
:osx
,
:ios
].
include?
(
@platform
)
lines
<<
"* no dependencies were specified, which is, well, kinda pointless"
if
@
dependencies
.
empty?
lines
<<
"* no dependencies were specified, which is, well, kinda pointless"
if
dependencies
.
empty?
raise
(
Informative
,
([
"The Podfile at `
#{
@defined_in_file
}
' is invalid:"
]
+
lines
).
join
(
"
\n
"
))
unless
lines
.
empty?
raise
(
Informative
,
([
"The Podfile at `
#{
@defined_in_file
}
' is invalid:"
]
+
lines
).
join
(
"
\n
"
))
unless
lines
.
empty?
end
end
end
end
...
...
lib/cocoapods/resolver.rb
View file @
ec3d6542
module
Pod
module
Pod
class
Resolver
class
Resolver
def
initialize
(
specification
)
def
initialize
(
specification
,
dependencies
=
nil
)
@specification
=
specification
@specification
,
@dependencies
=
specification
,
dependencies
||
specification
.
dependencies
end
end
def
resolve
def
resolve
@sets
=
[]
@sets
=
[]
find_dependency_sets
(
@specification
)
find_dependency_sets
(
@specification
,
@dependencies
)
@sets
@sets
end
end
def
find_dependency_sets
(
specification
)
def
find_dependency_sets
(
specification
,
dependencies
=
nil
)
specification
.
dependencies
.
each
do
|
dependency
|
(
dependencies
||
specification
.
dependencies
)
.
each
do
|
dependency
|
set
=
find_dependency_set
(
dependency
)
set
=
find_dependency_set
(
dependency
)
set
.
required_by
(
specification
)
set
.
required_by
(
specification
)
unless
@sets
.
include?
(
set
)
unless
@sets
.
include?
(
set
)
...
...
lib/cocoapods/specification.rb
View file @
ec3d6542
...
@@ -325,17 +325,18 @@ module Pod
...
@@ -325,17 +325,18 @@ module Pod
# This is a convenience method which gets called after all pods have been
# This is a convenience method which gets called after all pods have been
# downloaded, installed, and the Xcode project and related files have been
# downloaded, installed, and the Xcode project and related files have been
# generated. Override this to, for instance, add to the prefix header:
# generated. (It receives the Pod::Installer::Target instance for the current
# target.) Override this to, for instance, add to the prefix header:
#
#
# Pod::Spec.new do |s|
# Pod::Spec.new do |s|
# def s.post_install
# def s.post_install
(target)
# prefix_header = config.project_pods_root +
'Pods-Prefix.pch'
# prefix_header = config.project_pods_root +
target.prefix_header_filename
# prefix_header.open('a') do |file|
# prefix_header.open('a') do |file|
# file.puts(%{#ifdef __OBJC__\n#import "SSToolkitDefines.h"\n#endif})
# file.puts(%{#ifdef __OBJC__\n#import "SSToolkitDefines.h"\n#endif})
# end
# end
# end
# end
# end
# end
def
post_install
def
post_install
(
target
)
end
end
end
end
...
...
lib/cocoapods/xcode/config.rb
View file @
ec3d6542
...
@@ -25,8 +25,8 @@ module Pod
...
@@ -25,8 +25,8 @@ module Pod
@attributes
.
map
{
|
key
,
value
|
"
#{
key
}
=
#{
value
}
"
}.
join
(
"
\n
"
)
@attributes
.
map
{
|
key
,
value
|
"
#{
key
}
=
#{
value
}
"
}.
join
(
"
\n
"
)
end
end
def
create_in
(
pods_root
)
def
save_as
(
pathname
)
(
pods_root
+
'Pods.xcconfig'
)
.
open
(
'w'
)
{
|
file
|
file
<<
to_s
}
pathname
.
open
(
'w'
)
{
|
file
|
file
<<
to_s
}
end
end
end
end
end
end
...
...
lib/cocoapods/xcode/copy_resources_script.rb
View file @
ec3d6542
module
Pod
module
Pod
module
Xcode
module
Xcode
class
CopyResourcesScript
class
CopyResourcesScript
CONTENT
=
<<
EOS
#!/bin/sh
install_resource()
{
echo "cp -R ${SRCROOT}/Pods/$1 ${CONFIGURATION_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
cp -R ${SRCROOT}/Pods/$1 ${CONFIGURATION_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}
}
EOS
attr_reader
:resources
attr_reader
:resources
# A list of files relative to the project pods root.
# A list of files relative to the project pods root.
...
@@ -8,13 +18,15 @@ module Pod
...
@@ -8,13 +18,15 @@ module Pod
@resources
=
resources
@resources
=
resources
end
end
def
create_in
(
root
)
def
save_as
(
pathname
)
return
if
@resources
.
empty?
pathname
.
open
(
'w'
)
do
|
script
|
(
root
+
'PodsResources.sh'
).
open
(
'a'
)
do
|
script
|
script
.
puts
CONTENT
@resources
.
each
do
|
resource
|
@resources
.
each
do
|
resource
|
script
.
puts
"install_resource '
#{
resource
}
'"
script
.
puts
"install_resource '
#{
resource
}
'"
end
end
end
end
# TODO use File api
system
(
"chmod +x '
#{
pathname
}
'"
)
end
end
end
end
end
end
...
...
lib/cocoapods/xcode/project.rb
View file @
ec3d6542
This diff is collapsed.
Click to expand it.
spec/integration_spec.rb
View file @
ec3d6542
...
@@ -38,8 +38,6 @@ else
...
@@ -38,8 +38,6 @@ else
config
.
silent
=
true
config
.
silent
=
true
config
.
repos_dir
=
fixture
(
'spec-repos'
)
config
.
repos_dir
=
fixture
(
'spec-repos'
)
config
.
project_pods_root
=
temporary_directory
+
'Pods'
config
.
project_pods_root
=
temporary_directory
+
'Pods'
def
config
.
ios?
;
true
;
end
def
config
.
osx?
;
false
;
end
FileUtils
.
cp_r
(
fixture
(
'integration/.'
),
config
.
project_pods_root
)
FileUtils
.
cp_r
(
fixture
(
'integration/.'
),
config
.
project_pods_root
)
end
end
...
@@ -51,6 +49,9 @@ else
...
@@ -51,6 +49,9 @@ else
# TODO add a simple source file which uses the compiled lib to check that it really really works
# TODO add a simple source file which uses the compiled lib to check that it really really works
it
"should activate required pods and create a working static library xcode project"
do
it
"should activate required pods and create a working static library xcode project"
do
spec
=
Pod
::
Podfile
.
new
do
spec
=
Pod
::
Podfile
.
new
do
# first ensure that the correct info is available to the specs when they load
config
.
rootspec
=
self
self
.
platform
platform
self
.
platform
platform
dependency
'ASIWebPageRequest'
,
'>= 1.8.1'
dependency
'ASIWebPageRequest'
,
'>= 1.8.1'
dependency
'JSONKit'
,
'>= 1.0'
dependency
'JSONKit'
,
'>= 1.0'
...
@@ -61,26 +62,29 @@ else
...
@@ -61,26 +62,29 @@ else
installer
.
install!
installer
.
install!
root
=
config
.
project_pods_root
root
=
config
.
project_pods_root
(
root
+
'Reachability.podspec'
).
should
.
exist
(
root
+
'Reachability.podspec'
).
should
.
exist
if
platform
==
:ios
(
root
+
'ASIHTTPRequest.podspec'
).
should
.
exist
(
root
+
'ASIHTTPRequest.podspec'
).
should
.
exist
(
root
+
'ASIWebPageRequest.podspec'
).
should
.
exist
(
root
+
'ASIWebPageRequest.podspec'
).
should
.
exist
(
root
+
'JSONKit.podspec'
).
should
.
exist
(
root
+
'JSONKit.podspec'
).
should
.
exist
(
root
+
'SSZipArchive.podspec'
).
should
.
exist
(
root
+
'SSZipArchive.podspec'
).
should
.
exist
(
root
+
'Pods.xcconfig'
).
read
.
should
==
installer
.
xcconfig
.
to_s
(
root
+
'Pods.xcconfig'
).
read
.
should
==
installer
.
targets
.
first
.
xcconfig
.
to_s
project_file
=
(
root
+
'Pods.xcodeproj/project.pbxproj'
).
to_s
project_file
=
(
root
+
'Pods.xcodeproj/project.pbxproj'
).
to_s
NSDictionary
.
dictionaryWithContentsOfFile
(
project_file
).
should
==
installer
.
xcodeproj
.
to_hash
NSDictionary
.
dictionaryWithContentsOfFile
(
project_file
).
should
==
installer
.
xcodeproj
.
to_hash
#
puts "\n[!] Compiling static library..."
puts
"
\n
[!] Compiling static library..."
#
Dir.chdir(config.project_pods_root) do
Dir
.
chdir
(
config
.
project_pods_root
)
do
#
system("xcodebuild > /dev/null 2>&1").should == true
system
(
"xcodebuild > /dev/null 2>&1"
).
should
==
true
#system("xcodebuild").should == true
#system("xcodebuild").should == true
#
end
end
end
end
it
"does not activate pods that are only part of other pods"
do
it
"does not activate pods that are only part of other pods"
do
spec
=
Pod
::
Podfile
.
new
do
spec
=
Pod
::
Podfile
.
new
do
# first ensure that the correct info is available to the specs when they load
config
.
rootspec
=
self
self
.
platform
platform
self
.
platform
platform
dependency
'Reachability'
dependency
'Reachability'
end
end
...
@@ -94,16 +98,18 @@ else
...
@@ -94,16 +98,18 @@ else
it
"adds resources to the xcode copy script"
do
it
"adds resources to the xcode copy script"
do
spec
=
Pod
::
Podfile
.
new
do
spec
=
Pod
::
Podfile
.
new
do
# first ensure that the correct info is available to the specs when they load
config
.
rootspec
=
self
self
.
platform
platform
self
.
platform
platform
dependency
'SSZipArchive'
dependency
'SSZipArchive'
end
end
installer
=
SpecHelper
::
Installer
.
new
(
spec
)
installer
=
SpecHelper
::
Installer
.
new
(
spec
)
dependency_spec
=
installer
.
build_specifications
.
first
installer
.
targets
.
first
.
build_specifications
.
first
.
resources
=
'LICEN*'
,
'Readme.*'
dependency_spec
.
resources
=
'LICEN*'
,
'Readme.*'
installer
.
install!
installer
.
install!
contents
=
(
config
.
project_pods_root
+
'Pods
R
esources.sh'
).
read
contents
=
(
config
.
project_pods_root
+
'Pods
-r
esources.sh'
).
read
contents
.
should
.
include
"install_resource 'SSZipArchive/LICENSE'
\n
"
\
contents
.
should
.
include
"install_resource 'SSZipArchive/LICENSE'
\n
"
\
"install_resource 'SSZipArchive/Readme.markdown'"
"install_resource 'SSZipArchive/Readme.markdown'"
end
end
...
@@ -111,6 +117,9 @@ else
...
@@ -111,6 +117,9 @@ else
# TODO we need to do more cleaning and/or add a --prune task
# TODO we need to do more cleaning and/or add a --prune task
it
"overwrites an existing project.pbxproj file"
do
it
"overwrites an existing project.pbxproj file"
do
spec
=
Pod
::
Podfile
.
new
do
spec
=
Pod
::
Podfile
.
new
do
# first ensure that the correct info is available to the specs when they load
config
.
rootspec
=
self
self
.
platform
platform
self
.
platform
platform
dependency
'JSONKit'
dependency
'JSONKit'
end
end
...
@@ -120,18 +129,60 @@ else
...
@@ -120,18 +129,60 @@ else
Pod
::
Source
.
reset!
Pod
::
Source
.
reset!
Pod
::
Spec
::
Set
.
reset!
Pod
::
Spec
::
Set
.
reset!
spec
=
Pod
::
Podfile
.
new
do
spec
=
Pod
::
Podfile
.
new
do
# first ensure that the correct info is available to the specs when they load
config
.
rootspec
=
self
self
.
platform
platform
self
.
platform
platform
dependency
'SSZipArchive'
dependency
'SSZipArchive'
end
end
installer
=
SpecHelper
::
Installer
.
new
(
spec
)
installer
=
SpecHelper
::
Installer
.
new
(
spec
)
installer
.
install!
installer
.
install!
installer
=
Pod
::
Installer
.
new
(
spec
)
installer
.
generate_project
project
=
Pod
::
Xcode
::
Project
.
new
(
config
.
project_pods_root
+
'Pods.xcodeproj'
)
project
=
Pod
::
Xcode
::
Project
.
new
(
config
.
project_pods_root
+
'Pods.xcodeproj'
)
project
.
source_files
.
should
==
installer
.
xcodeproj
.
source_files
project
.
source_files
.
should
==
installer
.
xcodeproj
.
source_files
end
end
it
"creates a project with multiple targets"
do
Pod
::
Source
.
reset!
Pod
::
Spec
::
Set
.
reset!
podfile
=
Pod
::
Podfile
.
new
do
# first ensure that the correct info is available to the specs when they load
config
.
rootspec
=
self
self
.
platform
platform
target
(
:debug
)
{
dependency
'SSZipArchive'
}
target
(
:test
,
:exclusive
=>
true
)
{
dependency
'JSONKit'
}
dependency
'ASIHTTPRequest'
end
installer
=
Pod
::
Installer
.
new
(
podfile
)
installer
.
install!
#project = Pod::Xcode::Project.new(config.project_pods_root + 'Pods.xcodeproj')
#p project
#project.targets.each do |target|
#target.source_build_phases.
#end
root
=
config
.
project_pods_root
(
root
+
'Pods.xcconfig'
).
should
.
exist
(
root
+
'Pods-debug.xcconfig'
).
should
.
exist
(
root
+
'Pods-test.xcconfig'
).
should
.
exist
(
root
+
'Pods-resources.sh'
).
should
.
exist
(
root
+
'Pods-debug-resources.sh'
).
should
.
exist
(
root
+
'Pods-test-resources.sh'
).
should
.
exist
Dir
.
chdir
(
config
.
project_pods_root
)
do
puts
"
\n
[!] Compiling static library `Pods'..."
#system("xcodebuild -target Pods").should == true
system
(
"xcodebuild -target Pods > /dev/null 2>&1"
).
should
==
true
puts
"
\n
[!] Compiling static library `Pods-debug'..."
system
(
"xcodebuild -target Pods-debug > /dev/null 2>&1"
).
should
==
true
puts
"
\n
[!] Compiling static library `Pods-test'..."
system
(
"xcodebuild -target Pods-test > /dev/null 2>&1"
).
should
==
true
end
end
it
"sets up an existing project with pods"
do
it
"sets up an existing project with pods"
do
basename
=
platform
==
:ios
?
'iPhone'
:
'Mac'
basename
=
platform
==
:ios
?
'iPhone'
:
'Mac'
projpath
=
temporary_directory
+
'ASIHTTPRequest.xcodeproj'
projpath
=
temporary_directory
+
'ASIHTTPRequest.xcodeproj'
...
@@ -143,27 +194,26 @@ else
...
@@ -143,27 +194,26 @@ else
installer
=
SpecHelper
::
Installer
.
new
(
spec
)
installer
=
SpecHelper
::
Installer
.
new
(
spec
)
installer
.
install!
installer
.
install!
installer
.
configure_project
(
projpath
)
installer
.
configure_project
(
projpath
)
xcworkspace
=
temporary_directory
+
'ASIHTTPRequest.xcworkspace'
xcworkspace
=
temporary_directory
+
'ASIHTTPRequest.xcworkspace'
workspace
=
Pod
::
Xcode
::
Workspace
.
new_from_xcworkspace
(
xcworkspace
)
workspace
=
Pod
::
Xcode
::
Workspace
.
new_from_xcworkspace
(
xcworkspace
)
workspace
.
projpaths
.
sort
.
should
==
[
'ASIHTTPRequest.xcodeproj'
,
'Pods/Pods.xcodeproj'
]
workspace
.
projpaths
.
sort
.
should
==
[
'ASIHTTPRequest.xcodeproj'
,
'Pods/Pods.xcodeproj'
]
project
=
Pod
::
Xcode
::
Project
.
new
(
projpath
)
project
=
Pod
::
Xcode
::
Project
.
new
(
projpath
)
config
=
project
.
files
.
find
{
|
f
|
f
.
path
=~
/Pods.xcconfig$/
}
libPods
=
project
.
files
.
find
{
|
f
|
f
.
name
==
'libPods.a'
}
config
.
should
.
not
.
equal
nil
copy_resources
=
project
.
objects
.
select_by_class
(
Pod
::
Xcode
::
Project
::
PBXShellScriptBuildPhase
).
find
do
|
ss
|
ss
.
shellScript
[
'PodsResources.sh'
]
end
copy_resources
.
should
.
not
.
equal
nil
project
.
targets
.
each
do
|
target
|
project
.
targets
.
each
do
|
target
|
bases
=
target
.
buildConfigurationList
.
buildConfigurations
.
map
(
&
:baseConfigurationReference
)
target
.
buildConfigurations
.
each
do
|
config
|
bases
.
uniq
[
0
].
uuid
.
should
==
config
.
uuid
config
.
baseConfiguration
.
path
.
should
==
'Pods/Pods.xcconfig'
target
.
buildPhases
.
map
(
&
:uuid
).
should
.
include
copy_resources
.
uuid
end
end
lib
=
project
.
files
.
find
{
|
f
|
f
.
path
=~
/libPods.a$/
}
lib
.
should
.
not
.
equal
nil
phase
=
target
.
frameworks_build_phases
.
first
project
.
objects
.
select_by_class
(
Pod
::
Xcode
::
Project
::
PBXFrameworksBuildPhase
).
each
do
|
build_phase
|
phase
.
files
.
map
{
|
buildFile
|
buildFile
.
file
}.
should
.
include
libPods
build_phase
.
files
.
map
(
&
:uuid
).
should
.
include
lib
.
build_file
.
uuid
# should be the last phase
target
.
buildPhases
.
last
.
shellScript
.
should
==
"${SRCROOT}/Pods/Pods-resources.sh
\n
"
end
end
end
end
end
end
end
end
end
end
spec/unit/bridge_support_generator_spec.rb
View file @
ec3d6542
...
@@ -7,8 +7,8 @@ describe "Pod::BridgeSupportGenerator" do
...
@@ -7,8 +7,8 @@ describe "Pod::BridgeSupportGenerator" do
def
generator
.
gen_bridge_metadata
(
command
)
def
generator
.
gen_bridge_metadata
(
command
)
@command
=
command
@command
=
command
end
end
generator
.
create_in
(
Pathname
.
new
(
"/path/to/Pods
"
))
generator
.
save_as
(
Pathname
.
new
(
"/path/to/Pods.bridgesupport
"
))
generator
.
instance_variable_get
(
:@command
).
should
==
generator
.
instance_variable_get
(
:@command
).
should
==
%{-c "-I '/some/dir' -I '/some/other/dir'" -o '/path/to/Pods
/Pods
.bridgesupport' '#{headers.join("' '")}'}
%{-c "-I '/some/dir' -I '/some/other/dir'" -o '/path/to/Pods.bridgesupport' '#{headers.join("' '")}'}
end
end
end
end
spec/unit/installer_spec.rb
View file @
ec3d6542
...
@@ -3,7 +3,7 @@ require File.expand_path('../../spec_helper', __FILE__)
...
@@ -3,7 +3,7 @@ require File.expand_path('../../spec_helper', __FILE__)
describe
"Pod::Installer"
do
describe
"Pod::Installer"
do
describe
", by default,"
do
describe
", by default,"
do
before
do
before
do
@xcconfig
=
Pod
::
Installer
.
new
(
Pod
::
Spec
.
new
)
.
xcconfig
.
to_hash
@xcconfig
=
Pod
::
Installer
.
new
(
Pod
::
Podfile
.
new
{
platform
:ios
}).
targets
.
first
.
xcconfig
.
to_hash
end
end
it
"sets the header search paths where installed Pod headers can be found"
do
it
"sets the header search paths where installed Pod headers can be found"
do
...
@@ -33,9 +33,9 @@ describe "Pod::Installer" do
...
@@ -33,9 +33,9 @@ describe "Pod::Installer" do
end
end
it
"generates a BridgeSupport metadata file from all the pod headers"
do
it
"generates a BridgeSupport metadata file from all the pod headers"
do
spec
=
Pod
::
Spec
.
new
do
|
s
|
spec
=
Pod
::
Podfile
.
new
do
s
.
platform
=
:osx
platform
:osx
s
.
dependency
'ASIHTTPRequest'
dependency
'ASIHTTPRequest'
end
end
expected
=
[]
expected
=
[]
installer
=
Pod
::
Installer
.
new
(
spec
)
installer
=
Pod
::
Installer
.
new
(
spec
)
...
@@ -44,71 +44,6 @@ describe "Pod::Installer" do
...
@@ -44,71 +44,6 @@ describe "Pod::Installer" do
expected
<<
config
.
project_pods_root
+
header
expected
<<
config
.
project_pods_root
+
header
end
end
end
end
installer
.
bridge_support_generator
.
headers
.
should
==
expected
installer
.
targets
.
first
.
bridge_support_generator
.
headers
.
should
==
expected
end
it
"adds all source files that should be included in the library to the xcode project"
do
[
[
'ASIHTTPRequest'
,
[
'Classes'
],
{
'ASIHTTPRequest'
=>
"Classes/*.{h,m}"
,
'Reachability'
=>
"External/Reachability/*.{h,m}"
},
{
"USER_HEADER_SEARCH_PATHS"
=>
'"$(BUILT_PRODUCTS_DIR)/Pods" '
\
'"$(BUILT_PRODUCTS_DIR)/Pods/ASIHTTPRequest" '
\
'"$(BUILT_PRODUCTS_DIR)/Pods/Reachability"'
,
"ALWAYS_SEARCH_USER_PATHS"
=>
"YES"
,
"OTHER_LDFLAGS"
=>
"-ObjC -all_load "
\
"-framework SystemConfiguration -framework MobileCoreServices "
\
"-framework CFNetwork -lz.1"
}
],
[
'Reachability'
,
[
"External/Reachability/*.h"
,
"External/Reachability/*.m"
],
{
'Reachability'
=>
"External/Reachability/*.{h,m}"
,
},
{
"USER_HEADER_SEARCH_PATHS"
=>
'"$(BUILT_PRODUCTS_DIR)/Pods" '
\
'"$(BUILT_PRODUCTS_DIR)/Pods/Reachability"'
,
"ALWAYS_SEARCH_USER_PATHS"
=>
"YES"
,
"OTHER_LDFLAGS"
=>
"-ObjC -all_load"
}
],
[
'ASIWebPageRequest'
,
[
'**/ASIWebPageRequest.*'
],
{
'ASIHTTPRequest'
=>
"Classes/*.{h,m}"
,
'ASIWebPageRequest'
=>
"Classes/ASIWebPageRequest/*.{h,m}"
,
'Reachability'
=>
"External/Reachability/*.{h,m}"
},
{
"USER_HEADER_SEARCH_PATHS"
=>
'"$(BUILT_PRODUCTS_DIR)/Pods" '
\
'"$(BUILT_PRODUCTS_DIR)/Pods/ASIHTTPRequest" '
\
'"$(BUILT_PRODUCTS_DIR)/Pods/Reachability"'
,
"ALWAYS_SEARCH_USER_PATHS"
=>
"YES"
,
"HEADER_SEARCH_PATHS"
=>
"$(SDKROOT)/usr/include/libxml2"
,
"OTHER_LDFLAGS"
=>
"-ObjC -all_load "
\
"-lxml2.2.7.3 -framework SystemConfiguration "
\
"-framework MobileCoreServices -framework CFNetwork -lz.1"
}
],
].
each
do
|
name
,
patterns
,
expected_patterns
,
xcconfig
|
Pod
::
Source
.
reset!
Pod
::
Spec
::
Set
.
reset!
installer
=
Pod
::
Installer
.
new
(
Pod
::
Spec
.
new
do
|
s
|
s
.
platform
=
:ios
s
.
dependency
(
name
)
s
.
source_files
=
*
patterns
end
)
installer
.
generate_project
expected_patterns
.
each
do
|
name
,
pattern
|
pattern
=
config
.
project_pods_root
+
'ASIHTTPRequest'
+
pattern
expected
=
pattern
.
glob
.
map
do
|
file
|
file
.
relative_path_from
(
config
.
project_pods_root
)
end
installer
.
xcodeproj
.
source_files
[
name
].
size
.
should
==
expected
.
size
installer
.
xcodeproj
.
source_files
[
name
].
sort
.
should
==
expected
.
sort
end
installer
.
xcconfig
.
to_hash
.
should
==
xcconfig
end
end
end
end
end
spec/unit/podfile_spec.rb
View file @
ec3d6542
...
@@ -23,6 +23,47 @@ describe "Pod::Podfile" do
...
@@ -23,6 +23,47 @@ describe "Pod::Podfile" do
podfile
.
generate_bridge_support?
.
should
==
true
podfile
.
generate_bridge_support?
.
should
==
true
end
end
describe
"concerning targets (dependency groups)"
do
before
do
@podfile
=
Pod
::
Podfile
.
new
do
target
:debug
do
dependency
'SSZipArchive'
end
target
:test
,
:exclusive
=>
true
do
dependency
'JSONKit'
end
dependency
'ASIHTTPRequest'
end
end
it
"returns all dependencies of all targets combined, which is used during resolving to enusre compatible dependencies"
do
@podfile
.
dependencies
.
map
(
&
:name
).
sort
.
should
==
%w{ ASIHTTPRequest JSONKit SSZipArchive }
end
it
"adds dependencies outside of any explicit target block to the default target"
do
target
=
@podfile
.
targets
[
:default
]
target
.
lib_name
.
should
==
'Pods'
target
.
dependencies
.
should
==
[
Pod
::
Dependency
.
new
(
'ASIHTTPRequest'
)]
end
it
"adds dependencies of the outer target to non-exclusive targets"
do
target
=
@podfile
.
targets
[
:debug
]
target
.
lib_name
.
should
==
'Pods-debug'
target
.
dependencies
.
sort_by
(
&
:name
).
should
==
[
Pod
::
Dependency
.
new
(
'ASIHTTPRequest'
),
Pod
::
Dependency
.
new
(
'SSZipArchive'
)
]
end
it
"does not add dependencies of the outer target to exclusive targets"
do
target
=
@podfile
.
targets
[
:test
]
target
.
lib_name
.
should
==
'Pods-test'
target
.
dependencies
.
should
==
[
Pod
::
Dependency
.
new
(
'JSONKit'
)]
end
end
describe
"concerning validations"
do
describe
"concerning validations"
do
it
"raises if no platform is specified"
do
it
"raises if no platform is specified"
do
exception
=
lambda
{
exception
=
lambda
{
...
...
spec/unit/xcode/config_spec.rb
View file @
ec3d6542
...
@@ -25,7 +25,7 @@ describe "Pod::Xcode::Config" do
...
@@ -25,7 +25,7 @@ describe "Pod::Xcode::Config" do
it
"creates the config file"
do
it
"creates the config file"
do
@config
.
merge!
(
'HEADER_SEARCH_PATHS'
=>
'/some/path'
)
@config
.
merge!
(
'HEADER_SEARCH_PATHS'
=>
'/some/path'
)
@config
.
merge!
(
'OTHER_LD_FLAGS'
=>
'-l xml2.2.7.3'
)
@config
.
merge!
(
'OTHER_LD_FLAGS'
=>
'-l xml2.2.7.3'
)
@config
.
create_in
(
temporary_directory
)
@config
.
save_as
(
temporary_directory
+
'Pods.xcconfig'
)
(
temporary_directory
+
'Pods.xcconfig'
).
read
.
split
(
"
\n
"
).
sort
.
should
==
[
(
temporary_directory
+
'Pods.xcconfig'
).
read
.
split
(
"
\n
"
).
sort
.
should
==
[
"OTHER_LD_FLAGS = -framework Foundation -l xml2.2.7.3"
,
"OTHER_LD_FLAGS = -framework Foundation -l xml2.2.7.3"
,
"HEADER_SEARCH_PATHS = /some/path"
"HEADER_SEARCH_PATHS = /some/path"
...
...
spec/unit/xcode/project_spec.rb
View file @
ec3d6542
This diff is collapsed.
Click to expand it.
xcode-project-templates/cocoa-static-library/Pods-Prefix.pch
deleted
100644 → 0
View file @
99417d11
//
// Prefix header for all source files of the 'Pods' target in the 'Pods' project
//
#ifdef __OBJC__
#import <Cocoa/Cocoa.h>
#endif
xcode-project-templates/cocoa-static-library/Pods.xcconfig
deleted
100644 → 0
View file @
99417d11
xcode-project-templates/cocoa-static-library/Pods.xcodeproj/project.pbxproj
View file @
ec3d6542
...
@@ -6,33 +6,14 @@
...
@@ -6,33 +6,14 @@
objectVersion
=
46
;
objectVersion
=
46
;
objects
=
{
objects
=
{
/* Begin PBXBuildFile section */
518ACD3F1446050200F6BE80
/* Cocoa.framework in Frameworks */
=
{
isa
=
PBXBuildFile
;
fileRef
=
518ACD3E1446050200F6BE80
/* Cocoa.framework */
;
};
/* End PBXBuildFile section */
/* Begin PBXFileReference section */
/* Begin PBXFileReference section */
518ACD3B1446050200F6BE80
/* libPods.a */
=
{
isa
=
PBXFileReference
;
explicitFileType
=
archive.ar
;
includeInIndex
=
0
;
path
=
libPods.a
;
sourceTree
=
BUILT_PRODUCTS_DIR
;
};
518ACD3E1446050200F6BE80
/* Cocoa.framework */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
wrapper.framework
;
name
=
Cocoa.framework
;
path
=
System/Library/Frameworks/Cocoa.framework
;
sourceTree
=
SDKROOT
;
};
518ACD3E1446050200F6BE80
/* Cocoa.framework */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
wrapper.framework
;
name
=
Cocoa.framework
;
path
=
System/Library/Frameworks/Cocoa.framework
;
sourceTree
=
SDKROOT
;
};
518ACD461446050200F6BE80
/* Pods-Prefix.pch */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
sourcecode.c.h
;
path
=
"Pods-Prefix.pch"
;
sourceTree
=
"<group>"
;
};
518ACD53144605B400F6BE80
/* Pods.xcconfig */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
text.xcconfig
;
path
=
Pods.xcconfig
;
sourceTree
=
"<group>"
;
};
/* End PBXFileReference section */
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
518ACD381446050200F6BE80
/* Frameworks */
=
{
isa
=
PBXFrameworksBuildPhase
;
buildActionMask
=
2147483647
;
files
=
(
518ACD3F1446050200F6BE80
/* Cocoa.framework in Frameworks */
,
);
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
/* Begin PBXGroup section */
518ACD301446050100F6BE80
=
{
518ACD301446050100F6BE80
=
{
isa
=
PBXGroup
;
isa
=
PBXGroup
;
children
=
(
children
=
(
518ACD53144605B400F6BE80
/* Pods.xcconfig */
,
518ACD5B1446449B00F6BE80
/* Pods */
,
518ACD5B1446449B00F6BE80
/* Pods */
,
518ACD3D1446050200F6BE80
/* Frameworks */
,
518ACD3D1446050200F6BE80
/* Frameworks */
,
518ACD3C1446050200F6BE80
/* Products */
,
518ACD3C1446050200F6BE80
/* Products */
,
...
@@ -42,7 +23,6 @@
...
@@ -42,7 +23,6 @@
518ACD3C1446050200F6BE80
/* Products */
=
{
518ACD3C1446050200F6BE80
/* Products */
=
{
isa
=
PBXGroup
;
isa
=
PBXGroup
;
children
=
(
children
=
(
518ACD3B1446050200F6BE80
/* libPods.a */
,
);
);
name
=
Products
;
name
=
Products
;
sourceTree
=
"<group>"
;
sourceTree
=
"<group>"
;
...
@@ -55,55 +35,15 @@
...
@@ -55,55 +35,15 @@
name
=
Frameworks
;
name
=
Frameworks
;
sourceTree
=
"<group>"
;
sourceTree
=
"<group>"
;
};
};
518ACD451446050200F6BE80
/* Supporting Files */
=
{
isa
=
PBXGroup
;
children
=
(
518ACD461446050200F6BE80
/* Pods-Prefix.pch */
,
);
name
=
"Supporting Files"
;
path
=
Pods
;
sourceTree
=
"<group>"
;
};
518ACD5B1446449B00F6BE80
/* Pods */
=
{
518ACD5B1446449B00F6BE80
/* Pods */
=
{
isa
=
PBXGroup
;
isa
=
PBXGroup
;
children
=
(
children
=
(
518ACD451446050200F6BE80
/* Supporting Files */
,
);
);
name
=
Pods
;
name
=
Pods
;
sourceTree
=
"<group>"
;
sourceTree
=
"<group>"
;
};
};
/* End PBXGroup section */
/* End PBXGroup section */
/* Begin PBXHeadersBuildPhase section */
518ACD391446050200F6BE80
/* Headers */
=
{
isa
=
PBXHeadersBuildPhase
;
buildActionMask
=
2147483647
;
files
=
(
);
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXHeadersBuildPhase section */
/* Begin PBXNativeTarget section */
518ACD3A1446050200F6BE80
/* Pods */
=
{
isa
=
PBXNativeTarget
;
buildConfigurationList
=
518ACD4C1446050200F6BE80
/* Build configuration list for PBXNativeTarget "Pods" */
;
buildPhases
=
(
518ACD371446050200F6BE80
/* Sources */
,
518ACD381446050200F6BE80
/* Frameworks */
,
518ACD391446050200F6BE80
/* Headers */
,
);
buildRules
=
(
);
dependencies
=
(
);
name
=
Pods
;
productName
=
Pods
;
productReference
=
518ACD3B1446050200F6BE80
/* libPods.a */
;
productType
=
"com.apple.product-type.library.static"
;
};
/* End PBXNativeTarget section */
/* Begin PBXProject section */
/* Begin PBXProject section */
518ACD321446050100F6BE80
/* Project object */
=
{
518ACD321446050100F6BE80
/* Project object */
=
{
isa
=
PBXProject
;
isa
=
PBXProject
;
...
@@ -122,21 +62,10 @@
...
@@ -122,21 +62,10 @@
projectDirPath
=
""
;
projectDirPath
=
""
;
projectRoot
=
""
;
projectRoot
=
""
;
targets
=
(
targets
=
(
518ACD3A1446050200F6BE80
/* Pods */
,
);
);
};
};
/* End PBXProject section */
/* End PBXProject section */
/* Begin PBXSourcesBuildPhase section */
518ACD371446050200F6BE80
/* Sources */
=
{
isa
=
PBXSourcesBuildPhase
;
buildActionMask
=
2147483647
;
files
=
(
);
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXSourcesBuildPhase section */
/* Begin XCBuildConfiguration section */
/* Begin XCBuildConfiguration section */
518ACD4A1446050200F6BE80
/* Debug */
=
{
518ACD4A1446050200F6BE80
/* Debug */
=
{
isa
=
XCBuildConfiguration
;
isa
=
XCBuildConfiguration
;
...
@@ -185,30 +114,6 @@
...
@@ -185,30 +114,6 @@
};
};
name
=
Release
;
name
=
Release
;
};
};
518ACD4D1446050200F6BE80
/* Debug */
=
{
isa
=
XCBuildConfiguration
;
baseConfigurationReference
=
518ACD53144605B400F6BE80
/* Pods.xcconfig */
;
buildSettings
=
{
GCC_PRECOMPILE_PREFIX_HEADER
=
YES
;
GCC_PREFIX_HEADER
=
"Pods-Prefix.pch"
;
OTHER_LDFLAGS
=
(
);
PRODUCT_NAME
=
"$(TARGET_NAME)"
;
};
name
=
Debug
;
};
518ACD4E1446050200F6BE80
/* Release */
=
{
isa
=
XCBuildConfiguration
;
baseConfigurationReference
=
518ACD53144605B400F6BE80
/* Pods.xcconfig */
;
buildSettings
=
{
GCC_PRECOMPILE_PREFIX_HEADER
=
YES
;
GCC_PREFIX_HEADER
=
"Pods-Prefix.pch"
;
OTHER_LDFLAGS
=
(
);
PRODUCT_NAME
=
"$(TARGET_NAME)"
;
};
name
=
Release
;
};
/* End XCBuildConfiguration section */
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
/* Begin XCConfigurationList section */
...
@@ -221,15 +126,6 @@
...
@@ -221,15 +126,6 @@
defaultConfigurationIsVisible
=
0
;
defaultConfigurationIsVisible
=
0
;
defaultConfigurationName
=
Release
;
defaultConfigurationName
=
Release
;
};
};
518ACD4C1446050200F6BE80
/* Build configuration list for PBXNativeTarget "Pods" */
=
{
isa
=
XCConfigurationList
;
buildConfigurations
=
(
518ACD4D1446050200F6BE80
/* Debug */
,
518ACD4E1446050200F6BE80
/* Release */
,
);
defaultConfigurationIsVisible
=
0
;
defaultConfigurationName
=
Release
;
};
/* End XCConfigurationList section */
/* End XCConfigurationList section */
};
};
rootObject
=
518ACD321446050100F6BE80
/* Project object */
;
rootObject
=
518ACD321446050100F6BE80
/* Project object */
;
...
...
xcode-project-templates/cocoa-static-library/PodsResources.sh
deleted
100755 → 0
View file @
99417d11
#!/bin/sh
install_resource
()
{
echo
"cp -R
${
SRCROOT
}
/Pods/
$1
${
CONFIGURATION_BUILD_DIR
}
/
${
UNLOCALIZED_RESOURCES_FOLDER_PATH
}
"
cp
-R
${
SRCROOT
}
/Pods/
$1
${
CONFIGURATION_BUILD_DIR
}
/
${
UNLOCALIZED_RESOURCES_FOLDER_PATH
}
}
xcode-project-templates/cocoa-touch-static-library/Pods-Prefix.pch
deleted
100644 → 0
View file @
99417d11
//
// Prefix header for all source files of the 'Pods' target in the 'Pods' project
//
#ifdef __OBJC__
#import <UIKit/UIKit.h>
#endif
xcode-project-templates/cocoa-touch-static-library/Pods.xcconfig
deleted
100644 → 0
View file @
99417d11
xcode-project-templates/cocoa-touch-static-library/Pods.xcodeproj/project.pbxproj
View file @
ec3d6542
...
@@ -6,46 +6,14 @@
...
@@ -6,46 +6,14 @@
objectVersion
=
46
;
objectVersion
=
46
;
objects
=
{
objects
=
{
/* Begin PBXBuildFile section */
515B0FB9141D52E0001DC3E6
/* Foundation.framework in Frameworks */
=
{
isa
=
PBXBuildFile
;
fileRef
=
515B0FB8141D52E0001DC3E6
/* Foundation.framework */
;
};
/* End PBXBuildFile section */
/* Begin PBXCopyFilesBuildPhase section */
82A8B61C142F7EC7006897C9
/* Copy Public Headers */
=
{
isa
=
PBXCopyFilesBuildPhase
;
buildActionMask
=
2147483647
;
dstPath
=
"$(PUBLIC_HEADERS_FOLDER_PATH)"
;
dstSubfolderSpec
=
16
;
files
=
(
);
name
=
"Copy Public Headers"
;
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXCopyFilesBuildPhase section */
/* Begin PBXFileReference section */
/* Begin PBXFileReference section */
515160D0141EC5D100EBB823
/* Pods.xcconfig */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
text.xcconfig
;
path
=
Pods.xcconfig
;
sourceTree
=
"<group>"
;
};
515B0FB5141D52E0001DC3E6
/* libPods.a */
=
{
isa
=
PBXFileReference
;
explicitFileType
=
archive.ar
;
includeInIndex
=
0
;
path
=
libPods.a
;
sourceTree
=
BUILT_PRODUCTS_DIR
;
};
515B0FB8141D52E0001DC3E6
/* Foundation.framework */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
wrapper.framework
;
name
=
Foundation.framework
;
path
=
System/Library/Frameworks/Foundation.framework
;
sourceTree
=
SDKROOT
;
};
515B0FB8141D52E0001DC3E6
/* Foundation.framework */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
wrapper.framework
;
name
=
Foundation.framework
;
path
=
System/Library/Frameworks/Foundation.framework
;
sourceTree
=
SDKROOT
;
};
515B0FBC141D52E0001DC3E6
/* Pods-Prefix.pch */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
sourcecode.c.h
;
path
=
"Pods-Prefix.pch"
;
sourceTree
=
SOURCE_ROOT
;
};
/* End PBXFileReference section */
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
515B0FB2141D52E0001DC3E6
/* Frameworks */
=
{
isa
=
PBXFrameworksBuildPhase
;
buildActionMask
=
2147483647
;
files
=
(
515B0FB9141D52E0001DC3E6
/* Foundation.framework in Frameworks */
,
);
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
/* Begin PBXGroup section */
515B0FAA141D52E0001DC3E6
=
{
515B0FAA141D52E0001DC3E6
=
{
isa
=
PBXGroup
;
isa
=
PBXGroup
;
children
=
(
children
=
(
515160D0141EC5D100EBB823
/* Pods.xcconfig */
,
515B0FC9141D5FBE001DC3E6
/* Pods */
,
515B0FC9141D5FBE001DC3E6
/* Pods */
,
515B0FB7141D52E0001DC3E6
/* Frameworks */
,
515B0FB7141D52E0001DC3E6
/* Frameworks */
,
515B0FB6141D52E0001DC3E6
/* Products */
,
515B0FB6141D52E0001DC3E6
/* Products */
,
...
@@ -55,7 +23,6 @@
...
@@ -55,7 +23,6 @@
515B0FB6141D52E0001DC3E6
/* Products */
=
{
515B0FB6141D52E0001DC3E6
/* Products */
=
{
isa
=
PBXGroup
;
isa
=
PBXGroup
;
children
=
(
children
=
(
515B0FB5141D52E0001DC3E6
/* libPods.a */
,
);
);
name
=
Products
;
name
=
Products
;
sourceTree
=
"<group>"
;
sourceTree
=
"<group>"
;
...
@@ -68,59 +35,21 @@
...
@@ -68,59 +35,21 @@
name
=
Frameworks
;
name
=
Frameworks
;
sourceTree
=
"<group>"
;
sourceTree
=
"<group>"
;
};
};
515B0FBB141D52E0001DC3E6
/* Supporting Files */
=
{
isa
=
PBXGroup
;
children
=
(
515B0FBC141D52E0001DC3E6
/* Pods-Prefix.pch */
,
);
name
=
"Supporting Files"
;
path
=
Pods
;
sourceTree
=
"<group>"
;
};
515B0FC9141D5FBE001DC3E6
/* Pods */
=
{
515B0FC9141D5FBE001DC3E6
/* Pods */
=
{
isa
=
PBXGroup
;
isa
=
PBXGroup
;
children
=
(
children
=
(
515B0FBB141D52E0001DC3E6
/* Supporting Files */
,
);
);
name
=
Pods
;
name
=
Pods
;
sourceTree
=
"<group>"
;
sourceTree
=
"<group>"
;
};
};
/* End PBXGroup section */
/* End PBXGroup section */
/* Begin PBXHeadersBuildPhase section */
515B0FB3141D52E0001DC3E6
/* Headers */
=
{
isa
=
PBXHeadersBuildPhase
;
buildActionMask
=
2147483647
;
files
=
(
);
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXHeadersBuildPhase section */
/* Begin PBXNativeTarget section */
515B0FB4141D52E0001DC3E6
/* Pods */
=
{
isa
=
PBXNativeTarget
;
buildConfigurationList
=
515B0FC2141D52E0001DC3E6
/* Build configuration list for PBXNativeTarget "Pods" */
;
buildPhases
=
(
515B0FB1141D52E0001DC3E6
/* Sources */
,
515B0FB2141D52E0001DC3E6
/* Frameworks */
,
515B0FB3141D52E0001DC3E6
/* Headers */
,
82A8B61C142F7EC7006897C9
/* Copy Public Headers */
,
);
buildRules
=
(
);
dependencies
=
(
);
name
=
Pods
;
productName
=
Pods
;
productReference
=
515B0FB5141D52E0001DC3E6
/* libPods.a */
;
productType
=
"com.apple.product-type.library.static"
;
};
/* End PBXNativeTarget section */
/* Begin PBXProject section */
/* Begin PBXProject section */
515B0FAC141D52E0001DC3E6
/* Project object */
=
{
515B0FAC141D52E0001DC3E6
/* Project object */
=
{
isa
=
PBXProject
;
isa
=
PBXProject
;
attributes
=
{
LastUpgradeCheck
=
0420
;
};
buildConfigurationList
=
515B0FAF141D52E0001DC3E6
/* Build configuration list for PBXProject "Pods" */
;
buildConfigurationList
=
515B0FAF141D52E0001DC3E6
/* Build configuration list for PBXProject "Pods" */
;
compatibilityVersion
=
"Xcode 3.2"
;
compatibilityVersion
=
"Xcode 3.2"
;
developmentRegion
=
English
;
developmentRegion
=
English
;
...
@@ -133,21 +62,10 @@
...
@@ -133,21 +62,10 @@
projectDirPath
=
""
;
projectDirPath
=
""
;
projectRoot
=
""
;
projectRoot
=
""
;
targets
=
(
targets
=
(
515B0FB4141D52E0001DC3E6
/* Pods */
,
);
);
};
};
/* End PBXProject section */
/* End PBXProject section */
/* Begin PBXSourcesBuildPhase section */
515B0FB1141D52E0001DC3E6
/* Sources */
=
{
isa
=
PBXSourcesBuildPhase
;
buildActionMask
=
2147483647
;
files
=
(
);
runOnlyForDeploymentPostprocessing
=
0
;
};
/* End PBXSourcesBuildPhase section */
/* Begin XCBuildConfiguration section */
/* Begin XCBuildConfiguration section */
515B0FC0141D52E0001DC3E6
/* Debug */
=
{
515B0FC0141D52E0001DC3E6
/* Debug */
=
{
isa
=
XCBuildConfiguration
;
isa
=
XCBuildConfiguration
;
...
@@ -193,34 +111,6 @@
...
@@ -193,34 +111,6 @@
};
};
name
=
Release
;
name
=
Release
;
};
};
515B0FC3141D52E0001DC3E6
/* Debug */
=
{
isa
=
XCBuildConfiguration
;
baseConfigurationReference
=
515160D0141EC5D100EBB823
/* Pods.xcconfig */
;
buildSettings
=
{
DSTROOT
=
/tmp/Pods.dst
;
GCC_PRECOMPILE_PREFIX_HEADER
=
YES
;
GCC_PREFIX_HEADER
=
"Pods-Prefix.pch"
;
GCC_VERSION
=
com.apple.compilers.llvm.clang.1_0
;
OTHER_LDFLAGS
=
"-ObjC"
;
PRODUCT_NAME
=
"$(TARGET_NAME)"
;
SKIP_INSTALL
=
YES
;
};
name
=
Debug
;
};
515B0FC4141D52E0001DC3E6
/* Release */
=
{
isa
=
XCBuildConfiguration
;
baseConfigurationReference
=
515160D0141EC5D100EBB823
/* Pods.xcconfig */
;
buildSettings
=
{
DSTROOT
=
/tmp/Pods.dst
;
GCC_PRECOMPILE_PREFIX_HEADER
=
YES
;
GCC_PREFIX_HEADER
=
"Pods-Prefix.pch"
;
GCC_VERSION
=
com.apple.compilers.llvm.clang.1_0
;
OTHER_LDFLAGS
=
"-ObjC"
;
PRODUCT_NAME
=
"$(TARGET_NAME)"
;
SKIP_INSTALL
=
YES
;
};
name
=
Release
;
};
/* End XCBuildConfiguration section */
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
/* Begin XCConfigurationList section */
...
@@ -233,15 +123,6 @@
...
@@ -233,15 +123,6 @@
defaultConfigurationIsVisible
=
0
;
defaultConfigurationIsVisible
=
0
;
defaultConfigurationName
=
Release
;
defaultConfigurationName
=
Release
;
};
};
515B0FC2141D52E0001DC3E6
/* Build configuration list for PBXNativeTarget "Pods" */
=
{
isa
=
XCConfigurationList
;
buildConfigurations
=
(
515B0FC3141D52E0001DC3E6
/* Debug */
,
515B0FC4141D52E0001DC3E6
/* Release */
,
);
defaultConfigurationIsVisible
=
0
;
defaultConfigurationName
=
Release
;
};
/* End XCConfigurationList section */
/* End XCConfigurationList section */
};
};
rootObject
=
515B0FAC141D52E0001DC3E6
/* Project object */
;
rootObject
=
515B0FAC141D52E0001DC3E6
/* Project object */
;
...
...
xcode-project-templates/cocoa-touch-static-library/PodsResources.sh
deleted
100755 → 0
View file @
99417d11
#!/bin/sh
install_resource
()
{
echo
"cp -R
${
SRCROOT
}
/Pods/
$1
${
CONFIGURATION_BUILD_DIR
}
/
${
UNLOCALIZED_RESOURCES_FOLDER_PATH
}
"
cp
-R
${
SRCROOT
}
/Pods/
$1
${
CONFIGURATION_BUILD_DIR
}
/
${
UNLOCALIZED_RESOURCES_FOLDER_PATH
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment