Class: Fastlane::Actions::XcodeSelectAction

Inherits:
Fastlane::Action show all
Defined in:
lib/fastlane/actions/xcode_select.rb

Overview

See: developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/xcode-select.1.html

DESCRIPTION

xcode-select controls the location of the developer directory used by xcrun(1), xcodebuild(1), cc(1),
and other Xcode and BSD development tools. This also controls the locations that are searched for  by
man(1) for developer tool manpages.

DEVELOPER_DIR

Overrides the active developer directory. When DEVELOPER_DIR  is  set,  its  value  will  be  used
instead of the system-wide active developer directory.

Note that for historical reason, the developer directory is considered to be the Developer content
directory inside the Xcode application (for  example  /Applications/Xcode.app/Contents/Developer).
You  can  set  the  environment variable to either the actual Developer contents directory, or the
Xcode application directory -- the xcode-select provided  shims  will  automatically  convert  the
environment variable into the full Developer content path.

Class Method Summary collapse

Methods inherited from Fastlane::Action

action_name, authors, available_options, details, output, sh, step_text

Class Method Details

.authorObject



39
40
41
# File 'lib/fastlane/actions/xcode_select.rb', line 39

def self.author
  "dtrenz"
end

.descriptionObject



35
36
37
# File 'lib/fastlane/actions/xcode_select.rb', line 35

def self.description
  "Change the xcode-path to use. Useful for beta versions of Xcode"
end

.is_supported?(platform) ⇒ Boolean

Returns:

  • (Boolean)


43
44
45
# File 'lib/fastlane/actions/xcode_select.rb', line 43

def self.is_supported?(platform)
  [:ios, :mac].include?platform
end

.run(params) ⇒ Object



21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/fastlane/actions/xcode_select.rb', line 21

def self.run(params)
  xcode_path = (params.first rescue nil)

  # Verify that a param was passed in
  raise "Path to Xcode application required (e.x. \"/Applications/Xcode.app\")".red unless xcode_path.to_s.length > 0

  # Verify that a path to a directory was passed in
  raise "Path '#{xcode_path}' doesn't exist".red unless Dir.exists?(xcode_path)

  Helper.log.info "Setting Xcode version to #{xcode_path} for all build steps"

  ENV["DEVELOPER_DIR"] = xcode_path + "/Contents/Developer"
end