Class: Pod::Command

Inherits:
CLAide::Command
  • Object
show all
Includes:
Options, Pod::Config::Mixin
Defined in:
lib/cocoapods/command.rb,
lib/cocoapods/command/env.rb,
lib/cocoapods/command/ipc.rb,
lib/cocoapods/command/lib.rb,
lib/cocoapods/command/list.rb,
lib/cocoapods/command/init.rb,
lib/cocoapods/command/spec.rb,
lib/cocoapods/command/repo.rb,
lib/cocoapods/command/setup.rb,
lib/cocoapods/command/cache.rb,
lib/cocoapods/command/update.rb,
lib/cocoapods/command/install.rb,
lib/cocoapods/command/ipc/repl.rb,
lib/cocoapods/command/ipc/spec.rb,
lib/cocoapods/command/ipc/list.rb,
lib/cocoapods/command/repo/add.rb,
lib/cocoapods/command/outdated.rb,
lib/cocoapods/command/spec/cat.rb,
lib/cocoapods/command/lib/lint.rb,
lib/cocoapods/command/spec/lint.rb,
lib/cocoapods/command/repo/lint.rb,
lib/cocoapods/command/repo/list.rb,
lib/cocoapods/command/spec/edit.rb,
lib/cocoapods/command/repo/push.rb,
lib/cocoapods/command/cache/list.rb,
lib/cocoapods/command/spec/which.rb,
lib/cocoapods/command/lib/create.rb,
lib/cocoapods/command/repo/update.rb,
lib/cocoapods/command/repo/remove.rb,
lib/cocoapods/command/ipc/podfile.rb,
lib/cocoapods/command/cache/clean.rb,
lib/cocoapods/command/spec/create.rb,
lib/cocoapods/command/options/repo_update.rb,
lib/cocoapods/command/ipc/update_search_index.rb,
lib/cocoapods/command/options/project_directory.rb

Direct Known Subclasses

Cache, Env, IPC, Init, Install, Lib, List, Outdated, Repo, Setup, Spec, Update

Defined Under Namespace

Modules: Options Classes: Cache, Env, IPC, Init, Install, Lib, List, Outdated, Repo, Setup, Spec, Update

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Pod::Config::Mixin

#config

Constructor Details

#initialize(argv) ⇒ Command

TODO:

If a command is run inside another one some settings which where true might return false.

TODO:

We should probably not even load colored unless needed.

TODO:

Move silent flag to CLAide.

Note:

It is important that the commands don't override the default settings if their flag is missing (i.e. their value is nil)

Returns a new instance of Command



82
83
84
85
86
87
88
89
# File 'lib/cocoapods/command.rb', line 82

def initialize(argv)
  super
  config.silent = argv.flag?('silent', config.silent)
  config.verbose = self.verbose? unless verbose.nil?
  unless self.ansi_output?
    String.send(:define_method, :colorize) { |string, _| string }
  end
end

Class Method Details

.optionsObject



40
41
42
43
44
# File 'lib/cocoapods/command.rb', line 40

def self.options
  [
    ['--silent', 'Show nothing'],
  ].concat(super)
end

.report_error(exception) ⇒ Object



55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# File 'lib/cocoapods/command.rb', line 55

def self.report_error(exception)
  case exception
  when Interrupt
    puts '[!] Cancelled'.red
    Config.instance.verbose? ? raise : exit(1)
  when SystemExit
    raise
  else
    if ENV['COCOA_PODS_ENV'] != 'development'
      puts UI::ErrorReport.report(exception)
      exit 1
    else
      raise exception
    end
  end
end

.run(argv) ⇒ Object



46
47
48
49
50
51
52
53
# File 'lib/cocoapods/command.rb', line 46

def self.run(argv)
  help! 'You cannot run CocoaPods as root.' if Process.uid == 0
  verify_xcode_license_approved!

  super(argv)
ensure
  UI.print_warnings
end

.verify_xcode_license_approved!Object (private)



139
140
141
142
143
144
145
# File 'lib/cocoapods/command.rb', line 139

def self.verify_xcode_license_approved!
  if `/usr/bin/xcrun clang 2>&1` =~ /license/ && !$?.success?
    raise Informative, 'You have not agreed to the Xcode license, which ' \
      'you must do to use CocoaPods. Agree to the license by running: ' \
      '`xcodebuild -license`.'
  end
end

Instance Method Details

#ensure_master_spec_repo_exists!void

This method returns an undefined value.

Ensure that the master spec repo exists



95
96
97
98
99
# File 'lib/cocoapods/command.rb', line 95

def ensure_master_spec_repo_exists!
  unless config.sources_manager.master_repo_functional?
    Setup.new(CLAide::ARGV.new([])).run
  end
end

#installer_for_configInstaller (private)

Returns a new Installer parametrized from the Pod::Config.

Returns:



111
112
113
# File 'lib/cocoapods/command.rb', line 111

def installer_for_config
  Installer.new(config.sandbox, config.podfile, config.lockfile)
end

#verify_lockfile_exists!void (private)

This method returns an undefined value.

Checks that the lockfile exists.

Raises:

  • If the lockfile does not exists.



133
134
135
136
137
# File 'lib/cocoapods/command.rb', line 133

def verify_lockfile_exists!
  unless config.lockfile
    raise Informative, "No `Podfile.lock' found in the project directory, run `pod install'."
  end
end

#verify_podfile_exists!void (private)

This method returns an undefined value.

Checks that the podfile exists.

Raises:

  • If the podfile does not exists.



121
122
123
124
125
# File 'lib/cocoapods/command.rb', line 121

def verify_podfile_exists!
  unless config.podfile
    raise Informative, "No `Podfile' found in the project directory."
  end
end