Claude Code Plugins

Community-maintained marketplace

Feedback

Auto-generates professional README.md files for Arduino/ESP32/RP2040 projects following open-source best practices. Use when user wants to document their project for GitHub, needs help writing a README, or says "make my project shareable". Follows awesome-readme standards with sections for Overview, Hardware, Software, Setup, Usage, Troubleshooting, and Contributing.

Install Skill

1Download skill
2Enable skills in Claude

Open claude.ai/settings/capabilities and find the "Skills" section

3Upload to Claude

Click "Upload skill" and select the downloaded ZIP file

Note: Please verify skill by going through its instructions before using it.

SKILL.md

name readme-generator
description Auto-generates professional README.md files for Arduino/ESP32/RP2040 projects following open-source best practices. Use when user wants to document their project for GitHub, needs help writing a README, or says "make my project shareable". Follows awesome-readme standards with sections for Overview, Hardware, Software, Setup, Usage, Troubleshooting, and Contributing.

README Generator

Creates professional, beginner-friendly README files for maker projects.

Resources

This skill includes bundled tools:

  • scripts/generate_readme.py - Full README generator with wiring diagrams and templates

Quick Start

Interactive mode:

uv run scripts/generate_readme.py --interactive

Quick generation:

uv run scripts/generate_readme.py --project "Weather Station" --board "ESP32" --output README.md

Scan existing project:

uv run scripts/generate_readme.py --scan /path/to/arduino/project --output README.md

When to Use

  • "Help me document this project"
  • "I want to share this on GitHub"
  • "Write a README for my project"
  • User has working project, needs documentation
  • Before publishing to GitHub/Instructables

Information Gathering

Ask User For:

1. Project name and one-line description
2. What problem does it solve / why did you build it?
3. Main features (3-5 bullet points)
4. Hardware components used
5. Software libraries required
6. Any photos/videos/GIFs available?
7. License preference (MIT recommended for open source)
8. Target audience (beginners/intermediate/advanced)

Auto-Extract From Code:

  • Pin assignments from config.h
  • Library includes
  • WiFi/Bluetooth features
  • Sensor types

README Template

Generate using this structure (based on awesome-readme best practices):

# ๐ŸŽฏ [Project Name]

![Project Status](https://img.shields.io/badge/status-active-brightgreen)
![Platform](https://img.shields.io/badge/platform-ESP32-blue)
![License](https://img.shields.io/badge/license-MIT-green)

> One-line description of what this project does and why it's useful.

![Project Photo/GIF](images/project-demo.gif)

## ๐Ÿ“‹ Table of Contents

- [Overview](#overview)
- [Features](#features)
- [Hardware Components](#hardware-components)
- [Wiring Diagram](#wiring-diagram)
- [Software Dependencies](#software-dependencies)
- [Installation](#installation)
- [Configuration](#configuration)
- [Usage](#usage)
- [Troubleshooting](#troubleshooting)
- [Contributing](#contributing)
- [License](#license)
- [Acknowledgments](#acknowledgments)

## ๐Ÿ” Overview

[2-3 paragraphs explaining:]
- What the project does
- Why you built it / what problem it solves
- Who it's for (target audience)

### Demo

[Embed video or GIF showing project in action]

## โœจ Features

- โœ… Feature 1 - brief description
- โœ… Feature 2 - brief description
- โœ… Feature 3 - brief description
- ๐Ÿšง Planned: Feature 4 (coming soon)

## ๐Ÿ”ง Hardware Components

| Component | Quantity | Purpose | Notes |
|-----------|----------|---------|-------|
| [MCU Board] | 1 | Main controller | [version/variant] |
| [Sensor 1] | 1 | [function] | [I2C address, etc.] |
| [Display] | 1 | User interface | [resolution] |
| ... | ... | ... | ... |

**Estimated Cost:** $XX-XX

### Where to Buy

- [Component 1](link) - Amazon/AliExpress
- [Component 2](link) - Adafruit/SparkFun

## ๐Ÿ“ Wiring Diagram

![Wiring Diagram](images/wiring-diagram.png)

### Pin Connections

| MCU Pin | Component | Pin | Function |
|---------|-----------|-----|----------|
| GPIO21 | BME280 | SDA | I2C Data |
| GPIO22 | BME280 | SCL | I2C Clock |
| GPIO4 | LED | Anode | Status indicator |
| ... | ... | ... | ... |

## ๐Ÿ’ป Software Dependencies

### Required Software

- [Arduino IDE](https://www.arduino.cc/en/software) (v2.0+) or [PlatformIO](https://platformio.org/)
- [Board package] - [installation link]

### Required Libraries

| Library | Version | Purpose | Install via |
|---------|---------|---------|-------------|
| [Library1] | >=1.0.0 | [function] | Library Manager |
| [Library2] | >=2.3.0 | [function] | Library Manager |
| ... | ... | ... | ... |

## ๐Ÿ“ฆ Installation

### Option 1: Arduino IDE

1. **Install Arduino IDE**
   - Download from [arduino.cc](https://www.arduino.cc/en/software)
   
2. **Add Board Support** (if using ESP32/RP2040)

File โ†’ Preferences โ†’ Additional Board Manager URLs: https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_index.json

Then: Tools โ†’ Board โ†’ Boards Manager โ†’ Search "[board]" โ†’ Install

3. **Install Required Libraries**
- Sketch โ†’ Include Library โ†’ Manage Libraries
- Search and install each library from the table above

4. **Clone or Download This Repository**
```bash
git clone https://github.com/[username]/[repo-name].git

Or download ZIP and extract

  1. Open the Project
    • Open [project-name].ino in Arduino IDE

Option 2: PlatformIO (Recommended for Advanced Users)

  1. Install VS Code + PlatformIO extension

  2. Clone and open:

    git clone https://github.com/[username]/[repo-name].git
    cd [repo-name]
    code .
    
  3. PlatformIO will automatically install dependencies from platformio.ini

โš™๏ธ Configuration

Before uploading, customize config.h:

// === NETWORK SETTINGS ===
#define WIFI_SSID     "your-wifi-name"
#define WIFI_PASSWORD "your-wifi-password"

// === HARDWARE PINS ===
#define LED_PIN       4
#define SENSOR_SDA    21
#define SENSOR_SCL    22

// === FEATURE FLAGS ===
#define ENABLE_OLED   true
#define ENABLE_WIFI   true
#define DEBUG_MODE    true

Environment-Specific Settings

Setting Development Production
DEBUG_MODE true false
SERIAL_BAUD 115200 9600
SLEEP_INTERVAL 10s 300s

๐Ÿš€ Usage

Basic Operation

  1. Power On - Connect USB or battery
  2. Wait for Boot - Status LED blinks during initialization
  3. [Normal Operation] - Description of what happens

LED Status Indicators

LED State Meaning
Solid Green Normal operation
Blinking Blue WiFi connecting
Red Flash Error (check serial)

Serial Monitor

Open Serial Monitor at 115200 baud to see:

[BOOT] Project Name v1.0.0
[INFO] Initializing sensors...
[OK] BME280 found at 0x76
[INFO] Connecting to WiFi...
[OK] Connected: 192.168.1.100
[DATA] Temp: 23.5ยฐC, Humidity: 45%

Web Interface (if applicable)

Navigate to http://[device-ip] to access:

  • Real-time sensor readings
  • Configuration panel
  • Data export

โ“ Troubleshooting

Common Issues

Upload fails: "Failed to connect"

ESP32: Hold BOOT button while clicking Upload, release when "Connecting..." appears.

Arduino: Check correct COM port selected in Tools โ†’ Port.

Sensor not detected
  1. Check wiring (SDA/SCL not swapped?)
  2. Run I2C scanner sketch to verify address
  3. Add pull-up resistors (4.7kฮฉ) if not on module
  4. Check voltage compatibility (3.3V vs 5V)
WiFi won't connect
  1. Verify SSID/password in config.h (case-sensitive!)
  2. 2.4GHz only (ESP32 doesn't support 5GHz)
  3. Check router isn't blocking new devices
  4. Try moving closer to router
Random resets
  1. Power supply too weak - use 500mA+ source
  2. Add 100ยตF capacitor near MCU
  3. Check for short circuits
  4. Disable brownout detector (ESP32)

Still Stuck?

  1. Check Issues for similar problems
  2. Open a new issue with:
    • Hardware setup (board, sensors)
    • Error messages (full serial output)
    • Steps to reproduce

๐Ÿค Contributing

Contributions are welcome! Here's how:

Reporting Bugs

  1. Check existing issues first
  2. Use the bug report template
  3. Include serial output and hardware details

Suggesting Features

  1. Open an issue with [Feature Request] prefix
  2. Describe use case and expected behavior

Pull Requests

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make your changes
  4. Test thoroughly
  5. Commit: git commit -m 'Add amazing feature'
  6. Push: git push origin feature/amazing-feature
  7. Open a Pull Request

Code Style

  • Use meaningful variable names
  • Comment complex logic
  • Follow existing formatting
  • Test on actual hardware before PR

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

MIT License

Copyright (c) [year] [author]

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

๐Ÿ™ Acknowledgments

  • [Library/Project] - for [what it provides]
  • [Person/Tutorial] - inspiration/guidance
  • [Community] - testing and feedback

๐Ÿ“ฌ Contact

[Your Name] - @twitter_handle - email@example.com

Project Link: https://github.com/[username]/[repo-name]


โญ If this project helped you, please give it a star!


---

## Section Guidelines

### Good vs Bad Examples

**Project Description:**

โŒ Bad: "An Arduino project with sensors" โœ… Good: "Battery-powered environmental monitor that tracks temperature, humidity, and air quality, sending alerts when thresholds are exceeded"


**Features:**

โŒ Bad: "Has WiFi" โœ… Good: "๐Ÿ“ถ WiFi connectivity with automatic reconnection and OTA updates"


**Installation Steps:**

โŒ Bad: "Install the libraries and upload" โœ… Good: Step-by-step with screenshots, version numbers, exact menu paths


### Visual Assets

**Recommended:**
- Project photo (hero image)
- Wiring diagram (Fritzing or hand-drawn)
- Demo GIF (< 5MB, 10-15 seconds)
- Schematic (KiCad export)

**Creating GIFs:**
- Use ScreenToGif (Windows) or Peek (Linux)
- Optimize with ezgif.com
- Keep under 5MB for GitHub

### Badges

```markdown
<!-- Status badges -->
![Build Status](https://img.shields.io/badge/build-passing-brightgreen)
![Version](https://img.shields.io/badge/version-1.0.0-blue)
![License](https://img.shields.io/badge/license-MIT-green)

<!-- Platform badges -->
![Arduino](https://img.shields.io/badge/platform-Arduino-00979D?logo=arduino)
![ESP32](https://img.shields.io/badge/platform-ESP32-blue)
![Raspberry Pi](https://img.shields.io/badge/platform-RPi_Pico-C51A4A)

<!-- Social badges -->
![GitHub stars](https://img.shields.io/github/stars/user/repo)
![GitHub forks](https://img.shields.io/github/forks/user/repo)

File Structure Recommendation

project-name/
โ”œโ”€โ”€ README.md              # Main documentation
โ”œโ”€โ”€ LICENSE                # MIT license file
โ”œโ”€โ”€ .gitignore            # Ignore build files
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ main.ino          # Main sketch
โ”‚   โ””โ”€โ”€ config.h          # User configuration
โ”œโ”€โ”€ lib/                  # Local libraries (optional)
โ”œโ”€โ”€ docs/
โ”‚   โ”œโ”€โ”€ WIRING.md         # Detailed wiring guide
โ”‚   โ”œโ”€โ”€ API.md            # API documentation (if applicable)
โ”‚   โ””โ”€โ”€ CHANGELOG.md      # Version history
โ”œโ”€โ”€ images/
โ”‚   โ”œโ”€โ”€ project-photo.jpg
โ”‚   โ”œโ”€โ”€ wiring-diagram.png
โ”‚   โ””โ”€โ”€ demo.gif
โ”œโ”€โ”€ hardware/             # PCB/enclosure files (optional)
โ”‚   โ”œโ”€โ”€ schematic.pdf
โ”‚   โ””โ”€โ”€ enclosure.stl
โ””โ”€โ”€ examples/             # Additional example sketches
    โ””โ”€โ”€ basic/

Quick README Checklist

Before publishing, verify:

โ–ก Project name is clear and memorable
โ–ก One-line description explains the "what" and "why"
โ–ก Hero image/GIF shows project in action
โ–ก All hardware components listed with links
โ–ก Wiring diagram included
โ–ก All libraries listed with versions
โ–ก Step-by-step installation instructions
โ–ก Configuration section explains all settings
โ–ก Usage section shows expected output
โ–ก Troubleshooting covers common issues
โ–ก License file present
โ–ก Contact information included
โ–ก No broken links
โ–ก Spelling/grammar checked