Agent Instructions — avrebarra.github.io
Agent Instructions — avrebarra.github.io
Personal blog and website built with Jekyll, hosted on GitHub Pages.
Key Commands
| Purpose | Command |
|---|---|
| Local dev server | make watch |
| Create new post stub | make new_post |
| Serve workspace assets | make serve-workspace (port 7173) |
Ruby/Jekyll env managed via rbenv. See README.md for initial setup.
Project Layout
_posts/<category>/YYYY-MM-DD-slug.md # published posts
_drafts/YYYY-MM-DD-slug.md # unpublished drafts
_layouts/ # page/post HTML templates
_includes/ # reusable HTML partials
_sass/ # SCSS partials
pages/ # standalone pages (about, index, etc.)
workspace/ # static workspace assets
openspec/ # API spec files
Post categories (subdirectories under _posts/):
journals/— personal journal entrieslearning-notes/— technical learning notestechnicals-go/— Go-specific technical poststhoughts/— opinion pieces and essays
Post Frontmatter
Every post requires this frontmatter:
---
layout: post
title: Post Title Here
date: YYYY-MM-DD HH:MM:SS +0000
highlighted: false # true = featured on index
categories:
tags: []
series: Series Name # groups related posts; leave blank if standalone
---
seriesis used to group related posts — keep it consistent across related entries.- Drafts in
_drafts/use the same frontmatter format. - Prefer
make new_postto scaffold the stub rather than creating files manually.
Site Config
_config.yml — site name, URL, footer links, Giscus comments config.
Comments are powered by Giscus (GitHub Discussions).
Rich Block Architecture
- Rich post blocks are authored directly in post Markdown using inline HTML contracts (for example
data-rich-block="quote",data-rich-block="download",data-rich-block="headline-image", anddata-rich-block="inline-gallery"). - Visual contracts and spacing for these blocks live in
style.scss. - Runtime enhancement for interactive/structured blocks is mounted via Preact from
assets/js/runtime.jsand component modules inassets/js/components/. - When adding a new rich block, add its island module in
assets/js/components/and register itsrun...Enhancementscall inassets/js/runtime.js. inline-gallerykeeps grid rendering for small sets and upgrades to a horizontal multi-visible strip when 3 or more images are present (or whendata-layout="carousel"is set). Left/right controls appear only when items overflow the available width.headline-imageandinline-gallerysupport click-to-open full-size images in a new browser tab via the shared runtime utility inassets/js/components/rich-image-preview.js.- Treat rich blocks as static-first, JS-optional components. Do not assume they are Jekyll include partials unless explicitly introduced as such.
Design Governance
DESIGN.md is the canonical design authority for this repository.
Rules for System Design Changes
- Always adhere to DESIGN.md — Agent instructions and design-affecting decisions must align with DESIGN.md as the binding contract.
- Require explicit chat confirmation before updates — Any change affecting system design documentation (DESIGN.md only) must first be confirmed explicitly by the user in chat before proceeding.
- System design scope is DESIGN.md only — For this governance policy, “system design” refers exclusively to DESIGN.md. Other documentation may be updated without triggering these governance rules.
- Mandatory blocking lint validation — Every DESIGN.md edit must pass the validation command
npx @google/design.md lint DESIGN.mdbefore the change is considered complete. Lint failures block further changes until resolved.
AGENTS.md Attachment
AGENTS.md must be available as context on every AI agent invocation so agents understand repository structure, key commands, project layout, and governance rules when exploring, brainstorming, creating specs, or implementing tasks.