Class: Pod::Command::Framework
- Inherits:
-
Pod::Command
- Object
- Pod::Command
- Pod::Command::Framework
- Includes:
- Config::Mixin
- Defined in:
- lib/cocoapods-framework/command/framework.rb
Overview
Create a PR to add your plugin to CocoaPods/cocoapods.org in the ‘plugins.json` file, once your plugin is released.
This is an example of a cocoapods plugin adding a top-level subcommand to the ‘pod’ command.
You can also create subcommands of existing or new commands. Say you wanted to add a subcommand to ‘list` to show newly deprecated pods, (e.g. `pod list deprecated`), there are a few things that would need to change.
-
move this file to ‘lib/pod/command/list/deprecated.rb` and update the class to exist in the the Pod::Command::List namespace
-
change this class to extend from ‘List` instead of `Command`. This tells the plugin system that it is a subcommand of `list`.
-
edit ‘lib/cocoapods_plugins.rb` to require this file
Class Method Summary collapse
Instance Method Summary collapse
-
#initialize(argv) ⇒ Framework
constructor
A new instance of Framework.
- #run ⇒ Object
- #validate! ⇒ Object
Constructor Details
#initialize(argv) ⇒ Framework
Returns a new instance of Framework.
38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/cocoapods-framework/command/framework.rb', line 38 def initialize(argv) @name = argv.shift_argument @source = argv.shift_argument @spec_sources = argv.option('spec-sources', 'https://github.com/CocoaPods/Specs.git').split(',') subspecs = argv.option('subspecs') @subspecs = subspecs.split(',') unless subspecs.nil? @configuration = argv.option('configuration', 'Release') @use_modular_headers = argv.option('use-modular-headers', true) @force = argv.flag?('force', true) super end |
Class Method Details
.options ⇒ Object
28 29 30 31 32 33 34 35 36 |
# File 'lib/cocoapods-framework/command/framework.rb', line 28 def self. [ ['--no-force', 'Overwrite existing files.'], ['--configuration', 'Build the specified configuration (e.g. Debug). Defaults to Release'], ['--spec-sources=private,https://github.com/CocoaPods/Specs.git', 'The sources to pull dependent pods from (defaults to https://github.com/CocoaPods/Specs.git)'], ['--subspecs', 'Only include the given subspecs'], ['--use-modular-headers', 'pakcage uses modular headers during packaging'] ].concat super end |
Instance Method Details
#run ⇒ Object
55 56 57 58 |
# File 'lib/cocoapods-framework/command/framework.rb', line 55 def run frameworker = Frameworker.new(@name, @source, @spec_sources, @subspecs, @configuration, @force, @use_modular_headers) frameworker.run end |
#validate! ⇒ Object
50 51 52 53 |
# File 'lib/cocoapods-framework/command/framework.rb', line 50 def validate! super help! 'A Pod name is required.' unless @name end |