• Chris Bracken's avatar
    Build Flutter app as a framework on iOS (#8971) · 0ee3f57a
    Chris Bracken authored
    **THIS IS A BREAKING CHANGE.** See below for migration steps for
    existing projects.
    
    Previously, Flutter app code was built as a raw dylib on iOS.  Dynamic
    libraries outside of a framework bundle are not supported on iOS, except
    for the system Swift libraries provided by Xcode.
    
    See:
    https://developer.apple.com/library/content/technotes/tn2435/_index.html#//apple_ref/doc/uid/DTS40017543-CH1-TROUBLESHOOTING_BUNDLE_ERRORS-EMBEDDED__DYLIB_FILES
    
    * Migrates Xcode build from app.dylib to App.framework
    * Migrates flutter create template
    * Migrates example projects
    
    Migration steps for existing projects
    =====================================
    
    The following steps should be taken from the root of your Flutter
    project:
    
    1. Edit `ios/.gitignore`: add `/Flutter/App.framework` on a new line.
    2. In the Xcode project navigator, remove `app.dylib` from the Flutter
       folder. Delete this file from the `ios/Flutter` directory in your project.
    3. Run a build to generate `ios/Flutter/App.framework`. From the command
       line, run `flutter build ios`. If you have not configured app signing
       in Xcode, an alternative method is to open the simulator, then run
       `flutter run -d iP`.
    4. In the Xcode project navigator, select the `Runner` project. In the
       project settings that are displayed in the main view, ensure that the
       `Runner` target is selected. You can verify this by exposing the
       sidebar using the [| ] icon in the upper-left corner of the main
       view.
    5. Select the *General* tab in the project settings. Under the
       *Embedded Binaries* section, click '+' to add `App.framework`. In the
       sheet that drops down, click the *Add Other...* button. Navigate to
       the `ios/Flutter` directory and select `App.framework`. Click *Open*.
       In the sheet that drops down, select *Create folder references*, then
       click *Finish*.
    6. In the project settings, verify that `App.framework` has been added to the
       *Embedded Binaries* and *Linked Frameworks and Libraries* lists.
    7. In the Xcode project navigator, drag `App.framework` under the
       Flutter folder.
    8. In the Xcode project navigator, select `Flutter` then from the
       *File* menu, select *Add Files to "Runner"...*. Navigate to the
       `ios/Flutter` directory, select `AppFrameworkInfo.plist` and click
       the *Add* button.
    9. From the command line, in your project directory, run
       `flutter build clean`, then `flutter run`.
    
    At this point your project should be fully migrated.
    0ee3f57a
Name
Last commit
Last update
..
analyze.dart Loading commit data...
analyze_base.dart Loading commit data...
analyze_continuously.dart Loading commit data...
analyze_once.dart Loading commit data...
build.dart Loading commit data...
build_aot.dart Loading commit data...
build_apk.dart Loading commit data...
build_flx.dart Loading commit data...
build_ios.dart Loading commit data...
channel.dart Loading commit data...
config.dart Loading commit data...
create.dart Loading commit data...
daemon.dart Loading commit data...
devices.dart Loading commit data...
doctor.dart Loading commit data...
drive.dart Loading commit data...
format.dart Loading commit data...
fuchsia_reload.dart Loading commit data...
install.dart Loading commit data...
logs.dart Loading commit data...
packages.dart Loading commit data...
precache.dart Loading commit data...
run.dart Loading commit data...
screenshot.dart Loading commit data...
stop.dart Loading commit data...
test.dart Loading commit data...
trace.dart Loading commit data...
update_packages.dart Loading commit data...
upgrade.dart Loading commit data...