-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Dart GSoC 2023 Project Ideas
A list of Google Summer of Code project ideas for Dart.
For GSoC related discussions please use the dart-gsoc group.
Potential mentors
- Jonas Jensen (jonasfj)
[email protected]
- Daco Harkes (dcharkes)
[email protected]
- Sigurd Meldgaard (sigurdm)
[email protected]
- Liam Appelbe (liamappelbe)
[email protected]
TODO: Finish this page.
- Possible Mentor(s): [email protected]
- Difficulty: Hard
- Project size: / Large (350 hours)
- Skills: Dart, Go
Description: Package FFIgen makes interop with C and Objective-C seamless, and the (experimental) package JNIgen does the same for Java and Kotlin. However, what about Go?
In this project we would parse Go files and generate C wrappers and Dart bindings to those C wrappers so that developers can easily interop with Go from Dart.
- Design a way to interop with Go. We can explore cgo, is this at the right abstraction level for interop? Or would we want a more high level interaction? For example, since Go is garbage collected, can we have handles to Go data structures from Dart that prevent them from being Garbage collected?
- Design an approach to get the right information from a Go API. This will likely involve a Go parser and static analysis tool. That data structure then needs to be made accessible in Dart (either serialization such as in JNIgen or with direct FFI as in FFIgen).
- Generate the code that does 1 and 2.
- Profit!
(Alternatively, we could also do this project for another language. IDL, C++, Rust, …)
Good Sample Project: (1) Build a small sample project where you interop with a Go library. (2) Build a prototype for generating the bindings for that library, and (3) use a Go parser to generate those bindings.
- Possible Mentor(s): [email protected]
- Difficulty: Hard
- Project size: Large (350 hours)
- Skills: Dart, static analysis
Description: When writing Dart code it is useful to write
documentation comments,
such comments will be included in automatically generated documentation created by dartdoc
.
Documentation comments for dartdoc
are written in markdown, which allows authors to
embed code samples.
This project aims to create tools for testing code samples embedded in documentation comments.
This will likely involve:
- Using
package:analyzer
to extract documentation comments. - Using
package:markdown
to extract code samples. - Testing these code samples by:
- Running
dart analyze
on the code sample, - Passing the code sample through
dart format
, and/or, - Running the code sample in an isolate and compare stdout to comments from the sample.
- Running
For this project, we'll finish the dartdoc_test
package, such that it can be used by
package authors who wish to test code samples in their documentation comments.
As part of this project, we'll likely have to define conventions for what is expected of a code sample in documentation comments:
- What libraries (if any) are implicitly imported?
- Can you make code samples that are excluded from testing?
- Can comments inside the code sample be used to indicate expected output in stdout?
- How should code be written?
- Do all code samples need a
main
function? - Do we wrap top-level code in an implicit
main
to keep it simple? - Do we run the top-level function if it has a name other than
main
?
- Do all code samples need a
- Do we allow dead-code in samples (without an
// ignore: unreachable
comment)? - What lints do we apply to sample code (same as the top-level project).
Some of these questions might be debated in the project proposal. A project proposal should also discuss how package authors would run the code sample tests. Finally, a project proposal is encouraged to outline implementation stages, including strech goals.
Good Sample Project: Build a function that given some Dart code as a string will run analysis on the Dart code and count static errors (feel free to extend with lints, etc).
- Possible Mentor(s): TODO
- Difficulty: Hard / Easy
- Project size: Medium (175 hours) / Large (350 hours)
- Skills: Dart, TODO
Description: TODO
Good Sample Project: TODO
Important
The wiki has moved to https://github.com/dart-lang/sdk/tree/main/docs; please don't edit the pages here.