Skip to content

Commit dacff62

Browse files
committed
🔥 Remove redundant code from linking, and unlinking scripts.
1 parent 1e00576 commit dacff62

File tree

2 files changed

+15
-26
lines changed

2 files changed

+15
-26
lines changed

link.rb

Lines changed: 11 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -24,21 +24,17 @@
2424
# Get useful variables
2525
project = Xcodeproj::Project.open(project_location)
2626
frameworks_group = project.groups.find { |group| group.display_name == 'Frameworks' }
27-
frameworks_group = project.new_group('Frameworks') if frameworks_group == nil
27+
frameworks_group ||= project.new_group('Frameworks')
2828
target = project.targets.find { |target| target.to_s == target_name }
2929
frameworks_build_phase = target.build_phases.find { |build_phase| build_phase.to_s == 'FrameworksBuildPhase' }
3030

3131
# Add new "Embed Frameworks" build phase to target
3232
embed_frameworks_build_phase = target.build_phases.find { |build_phase| build_phase.to_s == 'Embed Frameworks'}
3333
Kernel.exit(0) if embed_frameworks_build_phase
34-
35-
if embed_frameworks_build_phase == nil
36-
is_linked = false
37-
embed_frameworks_build_phase = project.new(Xcodeproj::Project::Object::PBXCopyFilesBuildPhase)
38-
embed_frameworks_build_phase.name = 'Embed Frameworks'
39-
embed_frameworks_build_phase.symbol_dst_subfolder_spec = :frameworks
40-
target.build_phases << embed_frameworks_build_phase
41-
end
34+
embed_frameworks_build_phase = project.new(Xcodeproj::Project::Object::PBXCopyFilesBuildPhase)
35+
embed_frameworks_build_phase.name = 'Embed Instabug Framework'
36+
embed_frameworks_build_phase.symbol_dst_subfolder_spec = :frameworks
37+
target.build_phases << embed_frameworks_build_phase
4238

4339
# Add framework search path to target
4440
['Debug', 'Release'].each do |config|
@@ -52,21 +48,15 @@
5248
end
5349

5450
# Add framework to target as "Embedded Frameworks"
55-
framework_ref = frameworks_group.files.find { |file_reference| file_reference.path == "#{framework_root}/#{framework_name}"}
51+
framework_ref = frameworks_group.new_file("#{framework_root}/#{framework_name}")
52+
build_file = embed_frameworks_build_phase.add_file_reference(framework_ref)
53+
frameworks_build_phase.add_file_reference(framework_ref)
54+
build_file.settings = { 'ATTRIBUTES' => ['CodeSignOnCopy', 'RemoveHeadersOnCopy'] }
5655

57-
if framework_ref == nil
58-
framework_ref = frameworks_group.new_file("#{framework_root}/#{framework_name}")
59-
build_file = embed_frameworks_build_phase.add_file_reference(framework_ref)
60-
frameworks_build_phase.add_file_reference(framework_ref)
61-
build_file.settings = { 'ATTRIBUTES' => ['CodeSignOnCopy', 'RemoveHeadersOnCopy'] }
62-
end
6356

6457
#Add New Run Script Phase to Build Phases
65-
shell_script_build_phase = target.shell_script_build_phases.find { |build_phase| build_phase.to_s == INSTABUG_PHASE_NAME }
66-
if shell_script_build_phase == nil
67-
phase = target.new_shell_script_build_phase(INSTABUG_PHASE_NAME)
68-
phase.shell_script = INSTABUG_PHASE_SCRIPT
69-
end
58+
phase = target.new_shell_script_build_phase(INSTABUG_PHASE_NAME)
59+
phase.shell_script = INSTABUG_PHASE_SCRIPT
7060

7161
# Save Xcode project
7262
project.save

unlink.rb

Lines changed: 4 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -26,22 +26,21 @@
2626
# Remove "Embed Frameworks" build phase to target
2727
embed_frameworks_build_phase = target.build_phases.find { |build_phase| build_phase.to_s == 'Embed Frameworks'}
2828
Kernel.exit(0) unless embed_frameworks_build_phase
29-
target.build_phases.delete(embed_frameworks_build_phase) if embed_frameworks_build_phase
29+
target.build_phases.delete(embed_frameworks_build_phase)
3030

3131
# Remove framework search path from target
3232
['Debug', 'Release'].each do |config|
33-
# is_string ||= target.build_settings(config)['FRAMEWORK_SEARCH_PATHS'].is_a? String
34-
target.build_settings(config)['FRAMEWORK_SEARCH_PATHS'].delete(framework_root) if target.build_settings(config)['FRAMEWORK_SEARCH_PATHS'].is_a? Array
33+
target.build_settings(config)['FRAMEWORK_SEARCH_PATHS'].delete(framework_root)
3534
end
3635

3736
# Remove framework from target from "Embedded Frameworks"
3837
framework_ref = frameworks_group.files.find { |file_reference| file_reference.path == "#{framework_root}/#{framework_name}"}
3938
frameworks_build_phase.remove_file_reference(framework_ref)
40-
framework_ref.remove_from_project if framework_ref
39+
framework_ref.remove_from_project
4140

4241
#Delete New Run Script Phase from Build Phases
4342
shell_script_build_phase = target.shell_script_build_phases.find { |build_phase| build_phase.to_s == INSTABUG_PHASE_NAME }
44-
target.build_phases.delete(shell_script_build_phase) if shell_script_build_phase
43+
target.build_phases.delete(shell_script_build_phase)
4544

4645
# Save Xcode project
4746
project.save

0 commit comments

Comments
 (0)