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.
442 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 442 attribute :product_install_path, String |
#product_reference ⇒ PBXFileReference
Returns the reference to the product file.
433 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 433 has_one :product_reference, PBXFileReference |
#product_type ⇒ String
Returns the build product type identifier.
429 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 429 attribute :product_type, String |
Instance Method Details
#add_file_references(file_references, compiler_flags = {}) ⇒ Array<PBXBuildFile>
Adds source files to the target.
510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 510 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.
542 543 544 545 546 547 548 549 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 542 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.
451 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 451 has_many :build_phases, AbstractBuildPhase |
#build_rules ⇒ PBXBuildRule
Returns the build rules of this target.
425 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 425 has_many :build_rules, PBXBuildRule |
#extension_target_type? ⇒ Boolean
Returns Whether the target is an extension.
477 478 479 480 481 482 483 484 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 477 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.
577 578 579 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 577 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.
557 558 559 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 557 def headers_build_phase find_or_create_build_phase_by_class(PBXHeadersBuildPhase) end |
#launchable_target_type? ⇒ Boolean
Returns Whether the target is launchable.
488 489 490 491 492 493 494 495 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 488 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.
438 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 438 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.
587 588 589 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 587 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.
621 622 623 624 625 626 627 628 629 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 621 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.
567 568 569 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 567 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.
460 461 462 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 460 def symbol_type Constants::PRODUCT_TYPE_UTI.key(product_type) end |
#test_target_type? ⇒ Boolean
Returns Whether the target is a test target.
466 467 468 469 470 471 472 473 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 466 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
639 640 641 642 643 644 645 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 639 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
631 632 633 634 635 636 637 |
# File 'lib/xcodeproj/project/object/native_target.rb', line 631 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 |