Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[native_assets_cli] Add config.code.flutter.cApi #1836

Open
dcharkes opened this issue Dec 19, 2024 · 4 comments
Open

[native_assets_cli] Add config.code.flutter.cApi #1836

dcharkes opened this issue Dec 19, 2024 · 4 comments

Comments

@dcharkes
Copy link
Collaborator

Developers might want to build native code against flutter.h.

To prevent version skew between the package and the Flutter SDK, from-source build should use flutter.h from Flutter itself.
We should provide a path to it in the build config. Something along the lines of

config
  .code
    .flutter
      .cApi
        .headerPath
        .version

(Should flutter-specific code-specific config live under config.flutter.code or config.code.flutter?)

This is analogous to:

To support prebuilt binaries, the version should be taken into account.

Note that this doesn't solve version skew between generated dart:ffi bindings with FFIgen on a flutter.h and then flutter.h getting a breaking change. This could theoretically be solved by providing access to version in Dart (for example via passing in version as a define in a C lib and compiling it in and accessing it via an FFI call, or by writing the version to a data asset and accessing it at runtime), and then branching between two sets of generated bindings. (This is a similar issue to #1589.)

@mkustermann
Copy link
Member

Developers might want to build native code against flutter.h.

I don't think we'd want anything in dart-lang/native for that, as that is flutter specific.

So it would be a flutter-specific extension to the protocol. Because of that it would probably live in flutter/flutter. In fact it would probably be a package that flutter ships as part of Flutter SDK (i.e. a pined package:flutter_hooks Flutter SDK package, just like package:flutter).

Regarding stability of flutter.h. This is no different from stability of dart_api_dl.h, I assume it's kept very stable. Packages making use of it could use flutter sdk constraints to narrow that (e.g. newly introduced API functions in flutter version X would cause the package to use minimum flutter sdk version, ...).

(Should flutter-specific code-specific config live under config.flutter.code or config.code.flutter?)

The config.code.* namespace is managed by e.g. package:code and is intended to be used independent of flutter. It can decide to add more things to it's namespace, so I'd say that flutter specifics shouldn't be in there.

=> I'd tend to say flutter specifics can be in config.flutter* and flutter can manage that namespace.

@dcharkes
Copy link
Collaborator Author

dcharkes commented Dec 19, 2024

Developers might want to build native code against flutter.h.

I don't think we'd want anything in dart-lang/native for that, as that is flutter specific.

So it would be a flutter-specific extension to the protocol. Because of that it would probably live in flutter/flutter. In fact it would probably be a package that flutter ships as part of Flutter SDK (i.e. a pined package:flutter_hooks Flutter SDK package, just like package:flutter).

Agreed. (Seems like I violated my own rule and filed the issue in the wrong repo!)

(Should flutter-specific code-specific config live under config.flutter.code or config.code.flutter?)

The config.code.* namespace is managed by e.g. package:code and is intended to be used independent of flutter. It can decide to add more things to it's namespace, so I'd say that flutter specifics shouldn't be in there.

=> I'd tend to say flutter specifics can be in config.flutter* and flutter can manage that namespace.

So you're kind of saying that extensibility should only be at the root of the config.json, not in nested maps? (I just filed #1837.)

@dcharkes
Copy link
Collaborator Author

Is the flutter.h not also an flutter embedder API (used for other C++ apps that want to embed flutter) rather than an API for plugins to talk to? Or is it both?

Originally posted by @mkustermann in #1837 (comment)

@stuartmorgan Could you elaborate on the need for having flutter.h available for your exploration of writing plugins with FFIgen/JNIgen? Was it for getting access to textures, or something else?

@stuartmorgan
Copy link

Is the flutter.h not also an flutter embedder API (used for other C++ apps that want to embed flutter) rather than an API for plugins to talk to? Or is it both?

Flutter.h (from Flutter.framework) is both for iOS apps that want to embedded Flutter views (including the default flutter create-created app), and for plugins.

@stuartmorgan Could you elaborate on the need for having flutter.h available for your exploration of writing plugins with FFIgen/JNIgen? Was it for getting access to textures, or something else?

The specific plugin API I was trying to get access to was the texture registry. Longer term we could provide a Dart-based way of doing that specific thing, but there are a variety of plugin APIs that a plugin that is introducing FFI might want access to in order to move logic to Dart.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: No status
Development

No branches or pull requests

3 participants