andrew-kane-gem-writer

everyinc/compound-engineering-plugin · updated Apr 8, 2026

$npx skills add https://github.com/everyinc/compound-engineering-plugin --skill andrew-kane-gem-writer
0 commentsdiscussion
summary

Write Ruby gems following Andrew Kane's battle-tested patterns from 100+ gems with 374M+ downloads (Searchkick, PgHero, Chartkick, Strong Migrations, Lockbox, Ahoy, Blazer, Groupdate, Neighbor, Blind Index).

skill.md

Andrew Kane Gem Writer

Write Ruby gems following Andrew Kane's battle-tested patterns from 100+ gems with 374M+ downloads (Searchkick, PgHero, Chartkick, Strong Migrations, Lockbox, Ahoy, Blazer, Groupdate, Neighbor, Blind Index).

Core Philosophy

Simplicity over cleverness. Zero or minimal dependencies. Explicit code over metaprogramming. Rails integration without Rails coupling. Every pattern serves production use cases.

Entry Point Structure

Every gem follows this exact pattern in lib/gemname.rb:

# 1. Dependencies (stdlib preferred)
require "forwardable"

# 2. Internal modules
require_relative "gemname/model"
require_relative "gemname/version"

# 3. Conditional Rails (CRITICAL - never require Rails directly)
require_relative "gemname/railtie" if defined?(Rails)

# 4. Module with config and errors
module GemName
  class Error < StandardError; end
  class InvalidConfigError < Error; end

  class << self
    attr_accessor :timeout, :logger
    attr_writer :client
  end

  self.timeout = 10  # Defaults set immediately
end

Class Macro DSL Pattern

The signature Kane pattern—single method call configures everything:

# Usage
class Product < ApplicationRecord
  searchkick word_start: [:name]
end

# Implementation
module GemName
  module Model
    def gemname(**options)
      unknown = options.keys - KNOWN_KEYWORDS
      raise ArgumentError, "unknown keywords: #{unknown.join(", ")}" if unknown.any?

      mod = Module.new
      mod.module_eval do
        define_method :some_method do
          # implementation
        end unless method_defined?(:some_method)
      end
      include mod

      class_eval do
        cattr_reader :gemname_options, instance_reader: false
        class_variable_set :@@gemname_options, options.dup
      end
    end
  end
end

Rails Integration

Always use ActiveSupport.on_load—never require Rails gems directly:

# WRONG
require "active_record"
ActiveRecord::Base.include(MyGem::Model)

# CORRECT
ActiveSupport.on_load(:active_record) do
  extend GemName::Model
end

# Use prepend for behavior modification
ActiveSupport.on_load(:active_record) do
  ActiveRecord::Migration.prepend(GemName::Migration)
end

Configuration Pattern

Use class << self with attr_accessor, not Configuration objects:

module GemName
  class << self
    attr_accessor :timeout, :logger
    attr_writer :master_key
  end

  def self.master_key
    @master_key ||= ENV["GEMNAME_MASTER_KEY"]
  end

  self.timeout = 10
  self.logger = nil
end

Error Handling

Simple hierarchy with informative messages:

module GemName
  class Error < StandardError; end
  class ConfigError < Error; end
  class ValidationError < Error; end
end

# Validate early with ArgumentError
def initialize(key:)
  raise ArgumentError, "Key must be 32 bytes" unless key&.bytesize == 32
end

Testing (Minitest Only)

# test/test_helper.rb
require "bundler/setup"
Bundler.require(:default)
require "minitest/autorun"
require "minitest/pride"

# test/model_test.rb
class ModelTest < Minitest::Test
  def test_basic_functionality
    assert_equal expected, actual
  end
end

Gemspec Pattern

Zero runtime dependencies when possible:

Gem::Specification.new do |spec|
  spec.name = "gemname"
  spec.version = GemName::VERSION
  spec.required_ruby_version = ">= 3.1"
  spec.files = Dir["*.{md,txt}", "{lib}/**/*"]
  spec.require_path = "lib"
  # NO add_dependency lines - dev deps go in Gemfile
end

Anti-Patterns to Avoid

  • method_missing (use define_method instead)
  • Configuration objects (use class accessors)
  • @@class_variables (use class << self)
  • Requiring Rails gems directly
  • Many runtime dependencies
  • Committing Gemfile.lock in gems
  • RSpec (use Minitest)
  • Heavy DSLs (prefer explicit Ruby)

Reference Files

For deeper patterns, see:

  • references/module-organization.md - Directory layouts, method decomposition
  • references/rails-integration.md - Railtie, Engine, on_load patterns
  • references/database-adapters.md - Multi-database support patterns
  • references/testing-patterns.md - Multi-version testing, CI setup
  • references/resources.md - Links to Kane's repos and articles

Discussion

Product Hunt–style comments (not star reviews)
  • No comments yet — start the thread.
general reviews

Ratings

4.847 reviews
  • Anika Abebe· Dec 24, 2024

    We added andrew-kane-gem-writer from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.

  • Pratham Ware· Dec 8, 2024

    Keeps context tight: andrew-kane-gem-writer is the kind of skill you can hand to a new teammate without a long onboarding doc.

  • Hiroshi Jackson· Dec 4, 2024

    andrew-kane-gem-writer has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • Sophia Martin· Dec 4, 2024

    Keeps context tight: andrew-kane-gem-writer is the kind of skill you can hand to a new teammate without a long onboarding doc.

  • Yash Thakker· Nov 27, 2024

    andrew-kane-gem-writer has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • William Brown· Nov 23, 2024

    Keeps context tight: andrew-kane-gem-writer is the kind of skill you can hand to a new teammate without a long onboarding doc.

  • Sophia Dixit· Nov 23, 2024

    andrew-kane-gem-writer has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • Isabella Johnson· Nov 15, 2024

    I recommend andrew-kane-gem-writer for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.

  • Mia Abebe· Nov 15, 2024

    andrew-kane-gem-writer reduced setup friction for our internal harness; good balance of opinion and flexibility.

  • Dhruvi Jain· Oct 18, 2024

    Solid pick for teams standardizing on skills: andrew-kane-gem-writer is focused, and the summary matches what you get after install.

showing 1-10 of 47

1 / 5