Agent-skills-standard dart-language
Dart 3.x language feature standards: null safety, records, sealed classes, switch pattern matching, extensions, and async/await. Use when using !, ?., ??, late, sealed classes, record types, switch expressions, or async patterns — and before introducing any new Dart 3.x construct to confirm the modern idiomatic approach. (triggers: **/*.dart, sealed, record, switch, pattern, !, late, async, extension)
install
source · Clone the upstream repo
git clone https://github.com/HoangNguyen0403/agent-skills-standard
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/HoangNguyen0403/agent-skills-standard "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/dart/dart-language" ~/.claude/skills/hoangnguyen0403-agent-skills-standard-dart-language && rm -rf "$T"
manifest:
skills/dart/dart-language/SKILL.mdsource content
Dart Language Patterns
Priority: P0 (CRITICAL)
Implementation Guidelines
- Null Safety: Avoid
. Use!
,?.
, or short-circuiting. Use??
only if necessary.late - Immutability: Use
for all variables. Usefinal
for data classes.@freezed - Pattern Matching (3.x): Use
with patterns and destructuring.switch (value) - Records: Use Records (e.g.,
) for returning multiple values.(String, int) - Sealed Classes: Use
for exhaustive state handling in domain logic.sealed class - Extensions: Use
to add utility methods to third-party types.extension - Wildcards (3.7+): Use
for unused variables in declarations and patterns._ - Tear-offs: Prefer using tear-offs (e.g.,
) over anonymous lambdas (e.g.,list.forEach(print)
).list.forEach((e) => print(e)) - Asynchrony: Prefer
over rawasync/await
. UseFuture.then
for fire-and-forget logic if necessary.unawaited - Encapsulation: Use
prefix for library-private members. Prefer_
properties.final - Collections: Use
,collection-if
, and spread operatorscollection-for
.... - Safe List Access: Prefer
,.firstOrNull
, or.lastOrNull
..elementAtOrNull(i) - No dynamic: Use
or generics instead ofObject
.dynamic - Type Aliases: Use
for complex IDs or callbacks.typedef
Anti-Patterns
- No ! Operator: not use bang operator
unless you can prove value non-null via!
orif
.assert - No var for members: not use
for class members; usevar
or explicit types.final - No logic in constructors: not perform complex calculations or async work inside constructors.
Code
// Sealed class and Switch expression sealed class Result {} class Success extends Result { final String data; Success(this.data); } class Failure extends Result {} String message(Result r) => switch (r) { Success(data: var d) => "Got $d", Failure() => "Error", };
References
- feature-based-clean-architecture | tooling