class Pod::Command::Lib::Dylint
Public Class Methods
new(argv)
click to toggle source
Calls superclass method
# File lib/pod/command/lib/dylint.rb, line 50 def initialize(argv) @quick = argv.flag?('quick') @allow_warnings = argv.flag?('allow-warnings') @clean = argv.flag?('clean', true) @fail_fast = argv.flag?('fail-fast', false) @subspecs = argv.flag?('subspecs', true) @only_subspec = argv.option('subspec') @use_frameworks = !argv.flag?('use-libraries') @source_urls = argv.option('sources', 'https://github.com/CocoaPods/Specs.git').split(',') @private = argv.flag?('private', false) @swift_version = argv.option('swift-version', nil) @skip_import_validation = argv.flag?('skip-import-validation', false) @skip_tests = argv.flag?('skip-tests', false) @podspecs_paths = argv.arguments! super end
options()
click to toggle source
Calls superclass method
# File lib/pod/command/lib/dylint.rb, line 30 def self.options [ ['--quick', 'Lint skips checks that would require to download and build the spec'], ['--allow-warnings', 'Lint validates even if warnings are present'], ['--subspec=NAME', 'Lint validates only the given subspec'], ['--no-subspecs', 'Lint skips validation of subspecs'], ['--no-clean', 'Lint leaves the build directory intact for inspection'], ['--fail-fast', 'Lint stops on the first failing platform or subspec'], ['--use-libraries', 'Lint uses static libraries to install the spec'], ['--sources=https://github.com/artsy/Specs,master', 'The sources from which to pull dependent pods ' \ '(defaults to https://github.com/CocoaPods/Specs.git). ' \ 'Multiple sources must be comma-delimited.'], ['--private', 'Lint skips checks that apply only to public specs'], ['--swift-version=VERSION', 'The SWIFT_VERSION that should be used to lint the spec. ' \ 'This takes precedence over a .swift-version file.'], ['--skip-import-validation', 'Lint skips validating that the pod can be imported'], ['--skip-tests', 'Lint skips building and running tests during validation'], ].concat(super) end
Public Instance Methods
run()
click to toggle source
# File lib/pod/command/lib/dylint.rb, line 71 def run UI.puts File.expand_path('installer/analyzer') UI.puts podspecs_to_lint.each do |podspec| validator = Pod::DyValidator.new(podspec, @source_urls) validator.local = true validator.quick = @quick validator.no_clean = !@clean validator.fail_fast = @fail_fast validator.allow_warnings = @allow_warnings validator.no_subspecs = !@subspecs || @only_subspec validator.only_subspec = @only_subspec validator.use_frameworks = @use_frameworks validator.ignore_public_only_results = @private validator.swift_version = @swift_version validator.skip_import_validation = @skip_import_validation validator.skip_tests = @skip_tests validator.validate unless @clean UI.puts "Pods workspace available at `#{validator.validation_dir}/App.xcworkspace` for inspection." UI.puts end if validator.validated? UI.puts "#{validator.spec.name} passed validation.".green else spec_name = podspec spec_name = validator.spec.name if validator.spec message = "#{spec_name} did not pass validation, due to #{validator.failure_reason}." if @clean message << "\nYou can use the `--no-clean` option to inspect " \ 'any issue.' end raise Informative, message end end end
validate!()
click to toggle source
Calls superclass method
# File lib/pod/command/lib/dylint.rb, line 67 def validate! super end
Private Instance Methods
podspecs_to_lint()
click to toggle source
@return [Pathname] The path of the podspec found in the current
working directory.
@raise If no podspec is found. @raise If multiple podspecs are found.
# File lib/pod/command/lib/dylint.rb, line 122 def podspecs_to_lint if !@podspecs_paths.empty? Array(@podspecs_paths) else podspecs = Pathname.glob(Pathname.pwd + '*.podspec{.json,}') if podspecs.count.zero? raise Informative, 'Unable to find a podspec in the working ' \ 'directory' end podspecs end end