flutter/packages/flutter_tools/templates/package_ffi
Daco Harkes cec2400658
[native_assets] Stop running link hooks in JIT mode (#151534)
Stop running link hooks in debug mode.

Rationale: link hooks only get access to tree-shaking info in release builds, so they can't do anything meaningful in debug builds. Debug builds should be fast as development cycle, so running less is better.

More details:

* https://github.com/dart-lang/native/issues/1252

Also: rolls packages to latest versions.

## Implementation details

The decision whether linking is enabled is made as follows:

* For normal builds `build_info.dart::BuildMode` is used to determine whether Dart is compiled in JIT or AOT mode.
* Testers always run in JIT, so no linking.
* Native asset dry runs only run for JIT builds (e.g only when hot reload and hot restart are enabled).

## Testing

The integration test is updated to output an asset for linking if `BuildConfig.linkingEnabled` is true, and to output an asset for bundling directly if linking is not enabled.
2024-07-12 06:44:23 +00:00
..
hook [deps] Roll dart-lang/native packages (#151403) 2024-07-09 07:41:35 +00:00
lib Fixed a lot of typos (#141431) 2024-01-12 22:10:25 +00:00
src.tmpl Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
test Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
.gitignore.tmpl Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
.metadata.tmpl Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
analysis_options.yaml.tmpl Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
CHANGELOG.md.tmpl Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
ffigen.yaml.tmpl Modify plugin_ffi and package_ffi template (#143376) 2024-02-15 10:37:30 +00:00
LICENSE.tmpl Native assets support for MacOS and iOS (#130494) 2023-09-10 08:07:13 +00:00
pubspec.yaml.tmpl [native_assets] Stop running link hooks in JIT mode (#151534) 2024-07-12 06:44:23 +00:00
README.md.tmpl Switch to more reliable flutter.dev link destinations in the tool (#150587) 2024-06-26 23:30:39 +00:00

# {{projectName}}

{{description}}

## Getting Started

This project is a starting point for a Flutter
[FFI package](https://flutter.dev/to/ffi-package),
a specialized package that includes native code directly invoked with Dart FFI.

## Project structure

This template uses the following structure:

* `src`: Contains the native source code, and a CmakeFile.txt file for building
  that source code into a dynamic library.

* `lib`: Contains the Dart code that defines the API of the plugin, and which
  calls into the native code using `dart:ffi`.

* `bin`: Contains the `build.dart` that performs the external native builds.

## Building and bundling native code

`build.dart` does the building of native components.

Bundling is done by Flutter based on the output from `build.dart`.

## Binding to native code

To use the native code, bindings in Dart are needed.
To avoid writing these by hand, they are generated from the header file
(`src/{{projectName}}.h`) by `package:ffigen`.
Regenerate the bindings by running `dart run ffigen --config ffigen.yaml`.

## Invoking native code

Very short-running native functions can be directly invoked from any isolate.
For example, see `sum` in `lib/{{projectName}}.dart`.

Longer-running functions should be invoked on a helper isolate to avoid
dropping frames in Flutter applications.
For example, see `sumAsync` in `lib/{{projectName}}.dart`.

## Flutter help

For help getting started with Flutter, view our
[online documentation](https://docs.flutter.dev), which offers tutorials,
samples, guidance on mobile development, and a full API reference.