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

Adding dart build #51165

Open
laoshaw opened this issue Jan 30, 2023 · 12 comments
Open

Adding dart build #51165

laoshaw opened this issue Jan 30, 2023 · 12 comments
Assignees
Labels
area-dart-cli Use area-dart-cli for issues related to the 'dart' command like tool. dart-cli-compile Issues related to the 'dart compile' tool

Comments

@laoshaw
Copy link

laoshaw commented Jan 30, 2023

dart run will automatically do pub-get and compile and run, which is nice and similar to cargo-run or go-run.

dart compile exe -- needs to specify entry point and needs a separate pub-get step, tedious, but fine.

since dart-run respects pubspec.yaml and does what it needs to do, can we add dart build that also respects pubspec.yaml and auto builds some default output, e.g. exe, or multiple output, e.g. exe and aot, whatever is the most popular ones as the defaults?

this way the dart toolchain is also very consistent with others, e.g. rust and golang as mentioned above.

Thanks.

@vsmenon vsmenon added the area-dart-cli Use area-dart-cli for issues related to the 'dart' command like tool. label Jan 30, 2023
@bkonyi bkonyi added the dart-cli-compile Issues related to the 'dart compile' tool label Jan 30, 2023
@bkonyi bkonyi self-assigned this Jan 30, 2023
@dcharkes
Copy link
Contributor

dcharkes commented Mar 2, 2023

In the context of

I've prototyped some dart build functionality recently which outputs a folder, including possible dylibs from native packages: https://dart-review.googlesource.com/c/sdk/+/267340.

It would be worth considering other things than just native assets for a dart build.

@mit-mit
Copy link
Member

mit-mit commented Mar 20, 2023

dart compile exe -- needs to specify entry point and needs a separate pub-get step, tedious, but fine.

The "needs a separate pub-get step"-part is tracked here: #50422

@jakemac53
Copy link
Contributor

Imo it would be better to not introduce another top level command which has a lot of overlap with an existing command. Can this be an option to compile like --bundle or something?

@mit-mit
Copy link
Member

mit-mit commented Mar 22, 2023

compile usually uses subcommand, so I'd think it should be dart compile bundle. wdyt Daco?

@jakemac53
Copy link
Contributor

could bundle apply to both AOT and Kernel compilation? If so it should possibly be a flag for the subcommands?

@bkonyi
Copy link
Contributor

bkonyi commented Mar 22, 2023

I don't know how I feel about bundle covering all the build functionality since we're not necessarily creating a bundle of artifacts. We could just be compiling a library for use with FFI when we're running from source AFAIK. Maybe we could have dart compile bundle for preparing Dart applications to be shipped and dart compile native-libraries to just perform build steps needed for FFI artifacts?

@laoshaw
Copy link
Author

laoshaw commented Mar 22, 2023

build is consistent with other modern tools,e.g cargo,golang,please keep it

@dcharkes
Copy link
Contributor

could bundle apply to both AOT and Kernel compilation?

Possibly, we would have a kernel file with dylibs next to it, and the kernel file containing the (relative) paths of the dylibs.
However, what would the use be? You can't really use that bundle without the dart SDK, and if you have a Dart SDK, why not run from source? So yes we could, but what is the product benefit?

If so it should possibly be a flag for the subcommands?

The commands currently take an optional output filename as parameter. That doesn't work with bundles, that parameter would need to be a directory. Adding a flag leading to a file/directory differents in output parameter and actual output might be surprising.

Maybe we could have dart compile bundle for preparing Dart applications to be shipped and dart compile native-libraries to just perform build steps needed for FFI artifacts?

How we build artifacts entirely depends on how we run. Dart doesn't have cross compilation (currently), so that's not on the table yet. But dart run and dart test will require all their native libraries to be dynamic libraries. While dart compile bundle (assuming AOT) can support both static and dynamic libraries. When we support static libraries, we can even do dart compile exe which would then build only static libaries and still output a single executable.

Therefore one would need to specify what to build when doing dart compile native-assets. For example dart compile native-assets -Dtarget=linux_x64 -Dpackaging=dynamic. (Side note, we've been using "native assets" as naming for the feature for a while. Not everything might be a "library".)

@dcharkes
Copy link
Contributor

dart compile bundle

@mit-mit should that then be exe always? (and never aotsnapshot or kernel).

Otherwise it's going to be dart compile bundle exe.

@dcharkes
Copy link
Contributor

dcharkes commented Mar 23, 2023

Should we deprecate dart compile instead? Flutter is also flutter build? cc @mkustermann

(FWIW: flutter assemble is also a public command, though not used by users. If we care about consistency with Flutter.)

@dcharkes dcharkes self-assigned this Mar 23, 2023
@laoshaw
Copy link
Author

laoshaw commented Mar 23, 2023

deprecate compile is a good idea,no others use this keyword to build

@dcharkes
Copy link
Contributor

dcharkes commented May 31, 2023

In e1ae1b4, we have landed support for this in Dart behind an experimental flag. On the main branch (and dev releases) this feature is available via --enable-experiment=native-assets.

If you're not using the native assets feature (#50565), the only difference between dart compile and dart build should currently be that build output things in a folder (so that we can bundle dynamic libraries).

Please note that we will probably do breaking changes to how this feature works before we go to non-experimental.

@bkonyi bkonyi removed their assignment Feb 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area-dart-cli Use area-dart-cli for issues related to the 'dart' command like tool. dart-cli-compile Issues related to the 'dart compile' tool
Projects
None yet
Development

No branches or pull requests

6 participants