Skillshub dart-language
Dart 3.x language feature standards: null safety, records, sealed classes, switch pattern matching, extensions, and async/await. ALWAYS consult 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/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/HoangNguyen0403/agent-skills-standard/dart-language" ~/.claude/skills/comeonoliver-skillshub-dart-language && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/dart-language/SKILL.mdsource content
Dart Language Patterns
Priority: P0 (CRITICAL)
Modern Dart standards for safety, performance, and readability.
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: Do not use the bang operator
unless you can prove the value is non-null via!
orif
.assert - No var for members: Do not use
for class members; usevar
or explicit types.final - No logic in constructors: Do 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", };
Related Topics
feature-based-clean-architecture | tooling