Class: Xcodeproj::Project::Object::PBXNativeTarget
- Inherits:
-
AbstractTarget
- Object
- AbstractObject
- AbstractTarget
- Xcodeproj::Project::Object::PBXNativeTarget
- Defined in:
- lib/xcodeproj/project/object/native_target.rb
Overview
Represents a target handled by Xcode.
Attributes collapse
-
#product_install_path ⇒ String
The install path of the product.
-
#product_reference ⇒ PBXFileReference
The reference to the product file.
-
#product_type ⇒ String
The build product type identifier.
Attributes inherited from AbstractTarget
#build_configuration_list, #comments, #name, #product_name
Attributes inherited from AbstractObject
Attributes collapse
-
#build_phases ⇒ ObjectList<AbstractBuildPhase>
The build phases of the target.
-
#build_rules ⇒ PBXBuildRule
The build rules of this target.
-
#package_product_dependencies ⇒ ObjectList<XCSwiftPackageProductDependency>
The Swift package products necessary to build this target.
Helpers collapse
-
#add_file_references(file_references, compiler_flags = {}) ⇒ Array<PBXBuildFile>
Adds source files to the target.
-
#add_resources(resource_file_references) ⇒ void
Adds resource files to the resources build phase of the target.
-
#extension_target_type? ⇒ Boolean
Whether the target is an extension.
-
#frameworks_build_phase ⇒ PBXFrameworksBuildPhase
Finds or creates the frameworks build phase of the target.
-
#headers_build_phase ⇒ PBXHeadersBuildPhase
Finds or creates the headers build phase of the target.
-
#launchable_target_type? ⇒ Boolean
Whether the target is launchable.
-
#resources_build_phase ⇒ PBXResourcesBuildPhase
Finds or creates the resources build phase of the target.
-
#source_build_phase ⇒ PBXSourcesBuildPhase
Finds or creates the source build phase of the target.
-
#symbol_type ⇒ Symbol
The type of the target expressed as a symbol.
-
#test_target_type? ⇒ Boolean
Whether the target is a test target.
AbstractObject Hooks collapse
-
#sort(_options = nil) ⇒ Object
Sorts the to many attributes of the object according to the display name.
- #to_ascii_plist ⇒ Object
- #to_hash_as(method = :to_hash) ⇒ Object
Methods inherited from AbstractTarget
#add_build_configuration, #add_dependency, #add_system_framework, #add_system_library, #add_system_library_tbd, #build_configurations, #build_settings, #common_resolved_build_setting, #copy_files_build_phases, #dependencies, #dependency_for_target, #deployment_target, #deployment_target=, #frameworks_build_phases, #new_copy_files_build_phase, #new_shell_script_build_phase, #platform_name, #pretty_print, #resolved_build_setting, #sdk, #sdk_version, #shell_script_build_phases
Methods inherited from AbstractObject
#<=>, #==, #ascii_plist_annotation, #display_name, #inspect, isa, #nested_object_for_hash, #pretty_print, #remove_from_project, #sort_recursively, #to_hash
Instance Attribute Details
#product_install_path ⇒ String
Returns the install path of the product.
446 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 446 attribute :product_install_path, String |
#product_reference ⇒ PBXFileReference
Returns the reference to the product file.
437 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 437 has_one :product_reference, PBXFileReference |
#product_type ⇒ String
Returns the build product type identifier.
433 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 433 attribute :product_type, String |
Instance Method Details
#add_file_references(file_references, compiler_flags = {}) ⇒ Array<PBXBuildFile>
Adds source files to the target.
514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 514 def add_file_references(file_references, compiler_flags = {}) file_references.map do |file| extension = File.extname(file.path).downcase header_extensions = Constants::HEADER_FILES_EXTENSIONS is_header_phase = header_extensions.include?(extension) phase = is_header_phase ? headers_build_phase : source_build_phase unless build_file = phase.build_file(file) build_file = project.new(PBXBuildFile) build_file.file_ref = file phase.files << build_file end if compiler_flags && !compiler_flags.empty? && !is_header_phase (build_file.settings ||= {}).merge!('COMPILER_FLAGS' => compiler_flags) do |_, old, new| [old, new].compact.join(' ') end end yield build_file if block_given? build_file end end |
#add_resources(resource_file_references) ⇒ void
This method returns an undefined value.
Adds resource files to the resources build phase of the target.
546 547 548 549 550 551 552 553 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 546 def add_resources(resource_file_references) resource_file_references.each do |file| next if resources_build_phase.include?(file) build_file = project.new(PBXBuildFile) build_file.file_ref = file resources_build_phase.files << build_file end end |
#build_phases ⇒ ObjectList<AbstractBuildPhase>
Apparently only PBXCopyFilesBuildPhase and PBXShellScriptBuildPhase can appear multiple times in a target.
Returns the build phases of the target.
455 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 455 has_many :build_phases, AbstractBuildPhase |
#build_rules ⇒ PBXBuildRule
Returns the build rules of this target.
429 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 429 has_many :build_rules, PBXBuildRule |
#extension_target_type? ⇒ Boolean
Returns Whether the target is an extension.
481 482 483 484 485 486 487 488 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 481 def extension_target_type? case symbol_type when :app_extension, :watch_extension, :watch2_extension, :tv_extension, :messages_extension true else false end end |
#frameworks_build_phase ⇒ PBXFrameworksBuildPhase
A target should have only one frameworks build phase.
Finds or creates the frameworks build phase of the target.
581 582 583 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 581 def frameworks_build_phase find_or_create_build_phase_by_class(PBXFrameworksBuildPhase) end |
#headers_build_phase ⇒ PBXHeadersBuildPhase
A target should have only one headers build phase.
Finds or creates the headers build phase of the target.
561 562 563 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 561 def headers_build_phase find_or_create_build_phase_by_class(PBXHeadersBuildPhase) end |
#launchable_target_type? ⇒ Boolean
Returns Whether the target is launchable.
492 493 494 495 496 497 498 499 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 492 def launchable_target_type? case symbol_type when :application, :command_line_tool true else false end end |
#package_product_dependencies ⇒ ObjectList<XCSwiftPackageProductDependency>
Returns the Swift package products necessary to build this target.
442 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 442 has_many :package_product_dependencies, XCSwiftPackageProductDependency |
#resources_build_phase ⇒ PBXResourcesBuildPhase
A target should have only one resources build phase.
Finds or creates the resources build phase of the target.
591 592 593 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 591 def resources_build_phase find_or_create_build_phase_by_class(PBXResourcesBuildPhase) end |
#sort(_options = nil) ⇒ Object
Sorts the to many attributes of the object according to the display name.
Build phases are not sorted as they order is relevant.
625 626 627 628 629 630 631 632 633 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 625 def sort( = nil) attributes_to_sort = to_many_attributes.reject { |attr| attr.name == :build_phases } attributes_to_sort.each do |attrb| list = attrb.get_value(self) list.sort! do |x, y| x.display_name <=> y.display_name end end end |
#source_build_phase ⇒ PBXSourcesBuildPhase
A target should have only one source build phase.
Finds or creates the source build phase of the target.
571 572 573 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 571 def source_build_phase find_or_create_build_phase_by_class(PBXSourcesBuildPhase) end |
#symbol_type ⇒ Symbol
Returns The type of the target expressed as a symbol.
464 465 466 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 464 def symbol_type Constants::PRODUCT_TYPE_UTI.key(product_type) end |
#test_target_type? ⇒ Boolean
Returns Whether the target is a test target.
470 471 472 473 474 475 476 477 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 470 def test_target_type? case symbol_type when :octest_bundle, :unit_test_bundle, :ui_test_bundle true else false end end |
#to_ascii_plist ⇒ Object
643 644 645 646 647 648 649 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 643 def to_ascii_plist plist = super if !plist.value['packageProductDependencies'].nil? && plist.value['packageProductDependencies'].empty? plist.value.delete('packageProductDependencies') end plist end |
#to_hash_as(method = :to_hash) ⇒ Object
635 636 637 638 639 640 641 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 635 def to_hash_as(method = :to_hash) hash_as = super if !hash_as['packageProductDependencies'].nil? && hash_as['packageProductDependencies'].empty? hash_as.delete('packageProductDependencies') end hash_as end |