Skip to content

Commit d9431f1

Browse files
authored
Merge pull request #3 from TheAlphamerc/master
Merge master to develop
2 parents 2e7f462 + f011ea3 commit d9431f1

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

59 files changed

+4865
-1567
lines changed

.gitignore

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,7 @@
3737
**/android/gradlew.bat
3838
**/android/local.properties
3939
**/android/**/GeneratedPluginRegistrant.java
40+
**/android/app/google-services.json
4041

4142
# iOS/XCode related
4243
**/ios/**/*.mode1v3
@@ -64,6 +65,9 @@
6465
**/ios/Flutter/flutter_export_environment.sh
6566
**/ios/ServiceDefinitions.json
6667
**/ios/Runner/GeneratedPluginRegistrant.*
68+
**/ios/Runner/GoogleService-Info.plist
69+
/Users/ashwindas/Desktop/Workspace/Git Projects/flutter_twitter_clone/ios/Runner/GoogleService-Info.plist
70+
GoogleService-Info.plist
6771

6872
# Exceptions to above rules.
6973
!**/ios/**/default.mode1v3
@@ -73,3 +77,5 @@
7377
!/packages/flutter_tools/test/data/dart_dependencies_test/**/.packages
7478
.flutter-plugins-dependencies
7579
android/app/google-services.json
80+
google-services.json
81+

assets/images/bulb.png

5.2 KB
Loading

assets/images/qr.png

9.19 KB
Loading

ios/Flutter/Flutter.podspec

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
#
2+
# NOTE: This podspec is NOT to be published. It is only used as a local source!
3+
#
4+
5+
Pod::Spec.new do |s|
6+
s.name = 'Flutter'
7+
s.version = '1.0.0'
8+
s.summary = 'High-performance, high-fidelity mobile apps.'
9+
s.description = <<-DESC
10+
Flutter provides an easy and productive way to build and deploy high-performance mobile apps for Android and iOS.
11+
DESC
12+
s.homepage = 'https://flutter.io'
13+
s.license = { :type => 'MIT' }
14+
s.author = { 'Flutter Dev Team' => '[email protected]' }
15+
s.source = { :git => 'https://github.com/flutter/engine', :tag => s.version.to_s }
16+
s.ios.deployment_target = '8.0'
17+
s.vendored_frameworks = 'Flutter.framework'
18+
end

ios/Podfile

Lines changed: 50 additions & 34 deletions
Original file line numberDiff line numberDiff line change
@@ -15,51 +15,67 @@ def parse_KV_file(file, separator='=')
1515
if !File.exists? file_abs_path
1616
return [];
1717
end
18-
pods_ary = []
18+
generated_key_values = {}
1919
skip_line_start_symbols = ["#", "/"]
20-
File.foreach(file_abs_path) { |line|
21-
next if skip_line_start_symbols.any? { |symbol| line =~ /^\s*#{symbol}/ }
22-
plugin = line.split(pattern=separator)
23-
if plugin.length == 2
24-
podname = plugin[0].strip()
25-
path = plugin[1].strip()
26-
podpath = File.expand_path("#{path}", file_abs_path)
27-
pods_ary.push({:name => podname, :path => podpath});
28-
else
29-
puts "Invalid plugin specification: #{line}"
30-
end
31-
}
32-
return pods_ary
20+
File.foreach(file_abs_path) do |line|
21+
next if skip_line_start_symbols.any? { |symbol| line =~ /^\s*#{symbol}/ }
22+
plugin = line.split(pattern=separator)
23+
if plugin.length == 2
24+
podname = plugin[0].strip()
25+
path = plugin[1].strip()
26+
podpath = File.expand_path("#{path}", file_abs_path)
27+
generated_key_values[podname] = podpath
28+
else
29+
puts "Invalid plugin specification: #{line}"
30+
end
31+
end
32+
generated_key_values
3333
end
3434

3535
target 'Runner' do
3636
use_frameworks!
37+
use_modular_headers!
38+
39+
# Flutter Pod
3740

38-
# Prepare symlinks folder. We use symlinks to avoid having Podfile.lock
39-
# referring to absolute paths on developers' machines.
40-
system('rm -rf .symlinks')
41-
system('mkdir -p .symlinks/plugins')
41+
copied_flutter_dir = File.join(__dir__, 'Flutter')
42+
copied_framework_path = File.join(copied_flutter_dir, 'Flutter.framework')
43+
copied_podspec_path = File.join(copied_flutter_dir, 'Flutter.podspec')
44+
unless File.exist?(copied_framework_path) && File.exist?(copied_podspec_path)
45+
# Copy Flutter.framework and Flutter.podspec to Flutter/ to have something to link against if the xcode backend script has not run yet.
46+
# That script will copy the correct debug/profile/release version of the framework based on the currently selected Xcode configuration.
47+
# CocoaPods will not embed the framework on pod install (before any build phases can generate) if the dylib does not exist.
4248

43-
# Flutter Pods
44-
generated_xcode_build_settings = parse_KV_file('./Flutter/Generated.xcconfig')
45-
if generated_xcode_build_settings.empty?
46-
puts "Generated.xcconfig must exist. If you're running pod install manually, make sure flutter pub get is executed first."
47-
end
48-
generated_xcode_build_settings.map { |p|
49-
if p[:name] == 'FLUTTER_FRAMEWORK_DIR'
50-
symlink = File.join('.symlinks', 'flutter')
51-
File.symlink(File.dirname(p[:path]), symlink)
52-
pod 'Flutter', :path => File.join(symlink, File.basename(p[:path]))
49+
generated_xcode_build_settings_path = File.join(copied_flutter_dir, 'Generated.xcconfig')
50+
unless File.exist?(generated_xcode_build_settings_path)
51+
raise "Generated.xcconfig must exist. If you're running pod install manually, make sure flutter pub get is executed first"
52+
end
53+
generated_xcode_build_settings = parse_KV_file(generated_xcode_build_settings_path)
54+
cached_framework_dir = generated_xcode_build_settings['FLUTTER_FRAMEWORK_DIR'];
55+
56+
unless File.exist?(copied_framework_path)
57+
FileUtils.cp_r(File.join(cached_framework_dir, 'Flutter.framework'), copied_flutter_dir)
5358
end
54-
}
59+
unless File.exist?(copied_podspec_path)
60+
FileUtils.cp(File.join(cached_framework_dir, 'Flutter.podspec'), copied_flutter_dir)
61+
end
62+
end
63+
64+
# Keep pod path relative so it can be checked into Podfile.lock.
65+
pod 'Flutter', :path => 'Flutter'
5566

5667
# Plugin Pods
68+
69+
# Prepare symlinks folder. We use symlinks to avoid having Podfile.lock
70+
# referring to absolute paths on developers' machines.
71+
system('rm -rf .symlinks')
72+
system('mkdir -p .symlinks/plugins')
5773
plugin_pods = parse_KV_file('../.flutter-plugins')
58-
plugin_pods.map { |p|
59-
symlink = File.join('.symlinks', 'plugins', p[:name])
60-
File.symlink(p[:path], symlink)
61-
pod p[:name], :path => File.join(symlink, 'ios')
62-
}
74+
plugin_pods.each do |name, path|
75+
symlink = File.join('.symlinks', 'plugins', name)
76+
File.symlink(path, symlink)
77+
pod name, :path => File.join(symlink, 'ios')
78+
end
6379
end
6480

6581
# Prevent Cocoapods from embedding a second Flutter framework and causing an error with the new Xcode build system.

0 commit comments

Comments
 (0)