Claude-skill-registry dgroomes-project-conventions
Conventions and style guidelines for dgroomes' personal projects. Use when upgrading, maintaining, or creating projects in dgroomes' repositories. Covers README style, Gradle configuration, version catalogs, commit messages, and general code conventions.
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/dgroomes-project-conventions" ~/.claude/skills/majiayu000-claude-skill-registry-dgroomes-project-conventions && rm -rf "$T"
skills/data/dgroomes-project-conventions/SKILL.mddgroomes Project Conventions
Overview
This skill captures the conventions and patterns used across dgroomes' personal "playground" repositories. Apply these conventions when upgrading dependencies, restructuring projects, or creating new content.
README Conventions
Structure and Formatting
- Single-line description immediately after the
# heading - Use 📚 emoji prefix for playground/learning repos (e.g., "📚 Learning and exploring JUnit.")
- Two newlines before each markdown section (not one)
- Use
for list items, not-*
Required Sections
- Title -
# project-name - One-line description - With 📚 emoji for playground repos
- Quote block (optional) - Official tagline from the technology's website
- Overview - Expanded description of the project
- Subproject listings (if applicable) - Each with
subproject/`` heading### \ - Instructions - Numbered steps with code blocks
- Wish List - TODOs and future work
- Reference - Links (singular "Reference", not "References")
Quote Block Style
> The programmer-friendly testing framework for Java and the JVM > > -- <cite>https://junit.org/</cite>
Overview Section
- Comes after the one-line description and optional quote block
- Provides expanded context, motivation, or explanation
- Can include multiple paragraphs
- No "Follow these instructions" here - that goes in Instructions section
Instructions Section
- Start with intro line: "Follow these instructions to..." or "Follow the below instructions to..."
- Numbered list (1, 2, 3...)
- Sub-bullets use
with 3-space indent for commands and explanations* - STRONG GUIDELINE: Never go more than one indentation level - no nested sub-sub-bullets
- Use fenced code blocks with
languageshell - Code fences are indented to align with the bullet text (3 spaces +
+ fence)* - Include timing information when demonstrating performance ("The command took X seconds for me")
Example structure:
## Instructions Follow these instructions to build and run the project. 1. Pre-requisite: Java 25 2. Build the program * ```shell ./gradlew build ``` * The command took 2.3 seconds for me 3. Run the tests * ```shell ./gradlew test ```
Note the indentation pattern:
- Number at column 0
at column 3 (3 spaces)*- Code fence at column 5 (aligned with text after
)* - Code content at column 5 (same as fence)
Wish List Conventions
- Use
for open items- [ ] - Use
for completed items (keep these, don't delete!)- [x] DONE - Use
for skipped items (unchecked, not- [ ] SKIP
)[x] - Format:
- [x] DONE Description of what was done
Gradle Conventions
Version Catalog (libs.versions.toml)
- Place in
gradle/libs.versions.toml - For composite builds (includeBuild), each needs its own
gradle/libs.versions.toml - Alphabetical ordering in both
and[versions]
sections[libraries] - Include release notes URL as comment
[versions] junit = "6.0.1" # JUnit releases: https://junit.org/junit5/docs/current/release-notes/index.html slf4j = "2.0.17" # SLF4J releases: http://www.slf4j.org/news.html [libraries] junit-bom = { module = "org.junit:junit-bom", version.ref = "junit" } junit-jupiter = { module = "org.junit.jupiter:junit-jupiter" } slf4j-api = { module = "org.slf4j:slf4j-api", version.ref = "slf4j" }
Build File Style
- Use
instead of string interpolation likelayout.buildDirectory.dir("path")"${layout.buildDirectory.asFile.get()}/path" - Use Java toolchain for version specification:
java { toolchain { languageVersion.set(JavaLanguageVersion.of(25)) } }
JUnit BOM Usage
- Use the JUnit BOM for dependency management
- BOM manages versions for jupiter, platform, vintage
- Exception:
needs explicit version (it's an uber-jar not managed by BOM)junit-platform-console-standalone
dependencies { implementation(platform(libs.junit.bom)) testImplementation(platform(libs.junit.bom)) testImplementation(libs.junit.jupiter) testRuntimeOnly(libs.junit.platform.launcher) // Needs explicit version - not managed by BOM junitLauncher(libs.junit.platform.console.standalone) }
JUnit 6 Specifics
Unified Versioning
JUnit 6 uses unified versioning - Platform, Jupiter, and Vintage all share the same version number. The old JUnit 5 pattern of "replace leading 5 with 1 for Platform" is obsolete.
CLI Changes
JUnit 6 Console Launcher uses subcommands. Add
execute before options:
# JUnit 5 style (old) java -jar junit-platform-console-standalone.jar --scan-classpath # JUnit 6 style (new) java -jar junit-platform-console-standalone.jar execute --scan-classpath
General Code Conventions
Comments
- Never delete existing comments - preserve them when rewriting code
- Never add comments unless explaining cryptic or unusual code
- No docstrings, type annotations, or comments on code you didn't change
File Operations
- Never delete files yourself - ask the user to do it
- Prefer editing existing files over creating new ones
Preserving Content
- Don't delete timing information in READMEs (it's narrative content)
- Don't delete DONE wish list items (they document project history)
- Don't delete existing emoji usage
Commit Message Style
Short and descriptive. Patterns:
Upgrades: JUnit 6, Java 25, Gradle version catalog[subproject] Description of changeUpdate lib versions; readme style- Single word for simple changes:
,UpgradesCleanup
Project Structure Patterns
Standalone Subprojects
- Each subproject is completely independent
- Root
usessettings.gradle.kts
for composite buildsincludeBuild() - Each subproject has its own README, build files, and potentially gradle wrapper
Utility Projects
- Helper projects (like
) useutil/
notinclude()includeBuild() - These share the root project's version catalog