惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

L
LangChain Blog
Martin Fowler
Martin Fowler
P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
A
About on SuperTechFans
Google DeepMind News
Google DeepMind News
博客园_首页
量子位
小众软件
小众软件
F
Full Disclosure
Vercel News
Vercel News
爱范儿
爱范儿
Engineering at Meta
Engineering at Meta
F
Fortinet All Blogs
博客园 - 聂微东
V
V2EX
Blog — PlanetScale
Blog — PlanetScale
罗磊的独立博客
WordPress大学
WordPress大学
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
T
Tor Project blog
Google DeepMind News
Google DeepMind News
M
MIT News - Artificial intelligence
L
Lohrmann on Cybersecurity
H
Hacker News: Front Page
Spread Privacy
Spread Privacy
AI
AI
C
Cyber Attacks, Cyber Crime and Cyber Security
C
CERT Recently Published Vulnerability Notes
D
Docker
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Recorded Future
Recorded Future
L
LINUX DO - 热门话题
Microsoft Azure Blog
Microsoft Azure Blog
Recent Commits to openclaw:main
Recent Commits to openclaw:main
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Latest news
Latest news
W
WeLiveSecurity
Application and Cybersecurity Blog
Application and Cybersecurity Blog
博客园 - 司徒正美
博客园 - 叶小钗
T
Threat Research - Cisco Blogs
P
Privacy International News Feed
O
OpenAI News
Help Net Security
Help Net Security
aimingoo的专栏
aimingoo的专栏
宝玉的分享
宝玉的分享
博客园 - Franky

Hacker News: Show HN

PurrrrrFocus: Pomodoro Timer App - App Store Workflow Engine — Multi-Step Orchestration for Bun RapidPhoto: Pro Photo Editor App - App Store GitHub - DheerG/swarms: Achieve extraordinary results with claude code across a variety of tasks SPICE simulation → oscilloscope → verification with Claude Code — Lucas Gerads Show HN: VCoding – A 5 MB native Windows IDE with no dynamic dependencies Show HN: LLMs don't hallucinate because they're bad at math, it's the format GitHub - Agent-FM/agentfm-core: AgentFM is a peer-to-peer network that turns everyday computers into a decentralized AI supercomputer. AgentFM lets you run massive AI workloads directly across a global mesh of idle CPUs and GPUs. Show HN: Tracking Top US Science Olympiad Alumni over Last 25 Years GitHub - Potarix/agent-hub: One place to talk to all your agents Show HN: Runtime security for AI agents(injection,tool abuse, data exfiltration) GitHub - dubeyKartikay/lazyspotify: Terminal Spotify client for macOS and Linux GitHub - the-banana-tool/king-louie: Easy to use GUI Personal AI Assistant. Win/Linux/Mac. Show HN I made my vacation rental bookable by AI agents–no Airbnb, 0% commission GitHub - basteez/jsf-autoreload: maven plugin to enable hot reload on jsf projects uvm32/hosts/host-gdbstub at main · ringtailsoftware/uvm32 GitHub - labsai/EDDI: Config-driven engine that turns JSON into production-grade AI agents. Multi-agent orchestration, 12+ LLM providers, MCP/A2A protocols, RAG, persistent memory, and enterprise compliance (EU AI Act, GDPR, HIPAA). Built on Quarkus. GitHub - glitchnsec/fortyone-oss: AI Executive Assistant Platform Quickstart | Alien GitHub - muxshed/shed: One stream in, or many. Every destination, simultaneously. No cloud middleman, no per-channel fees, no limits. GitHub - ocrbase-hq/ocrbase: 📄 PDF/IMG ->.MD/JSON Document OCR API for PaddleOCR and GLMOCR. Self-hostable. GitHub - impactjo/home-memory: MCP server that lets your AI assistant remember everything about your home. GitHub - Sets88/dbcls: DbCls is a powerful terminal database client that supports various databases GitHub - neptun2000/heor-agent-mcp GitHub - SeanFDZ/macmind: Single-layer transformer in HyperTalk for the classic Macintosh RollQuation: Math Puzzles - Apps on Google Play GitHub - dropbox/witchcraft Show HN: Agent-cache – Multi-tier LLM/tool/session caching for Valkey and Redis GitHub - opentalon/opentalon: OpenTalon is an open-source platform built from the ground up in Go as a robust alternative to OpenClaw LinkedIn™ 职位抓取工具 - Chrome 应用商店 GitHub - EdoardoBambini/Agent-Armor-Iaga: AI agents are getting tool access — shell, file system, databases, APIs, secrets. But **nobody is governing what they actually do with it**. Frameworks like LangChain, CrewAI, AutoGen, and Claude Code give agents the power to execute. Agent Armor gives you the power to control, audit, and approve every single action before it happens. HN Vibes — Week 15, Apr 7–13 2026 GitHub - chojs23/ec: Easy terminal-native 3-way git mergetool vim-like workflow GitHub - SethPyle376/hiraeth: Local AWS emulator focused on fast integration testing, with SQS support, SQLite-backed state, and a debug-friendly web UI. GitHub - JakOb-dotcom/cloud-sandbox-security-analysis: Technical analysis and Proof of Concept (PoC) regarding environment variable exfiltration in containerized cloud sandboxes via side-channel data leaks. Springboards - Flint Alpha Show HN: A simpler coding agent harness GitHub - audiodude/sudomake-friends GitHub - 256thFission/mini-mythos: OSS clone of Anthropic’s Mythos harness to locate C/C++ memory vulnerabilities Show HN: OpenParallax: OS-level privilege separation for AI agent execution Hacker News Sorted - Chrome 应用商店 Show HN: How to Install Docker on Ubuntu 24.04 LTS: Complete 2026 Guide GitHub - himanshudongre/smriti GitHub - sverrirsig/claude-control: macOS desktop dashboard for monitoring and managing multiple Claude Code sessions GitHub - ory/dockertest: Write better integration tests! Dockertest helps you boot up ephermal docker images for your Go tests with minimal work. Chiral - Chrome 应用商店 Show HN: Two Claudes collaborating through shared memory on a $100 mini-PC GitHub - pmichaillat/latex-cv: Minimalist LaTeX template for academic CVs GitHub - oguzbilgic/posse: A web UI for Anthropic Managed Agents. GitHub - sshiraz/depsly: Dependency risk analysis tool for npm packages ABI Add safari/agent-harness — Safari browser automation via safari-mcp by achiya-automation · Pull Request #212 · HKUDS/CLI-Anything GitHub - Halfblood-Prince/trustcheck: Verify PyPI package attestations and improve Python supply-chain security GitHub - oguzbilgic/kern-ai: Agents that do the work and show it. GitHub - bruits/satteri: High-performance Markdown and MDX processing for the JavaScript ecosystem GitHub - tylergibbs1/feedstock: High-performance web crawler and scraper for TypeScript, powered by Bun and Playwright GitHub - Grimm67123/grimmbot: The self-improving sandboxed and open-source AI agent. With persistent memory and scheduling. GitHub - whitevanillaskies/whitebloom: Local whiteboard that blooms. GitHub - hwdsl2/docker-whisper: Docker image for a self-hosted Whisper speech-to-text server with speaker diarization and OpenAI-compatible transcription and translation APIs. Powered by faster-whisper. Supports all Whisper models, NVIDIA GPU (CUDA) acceleration, JSON/SRT/VTT output, SSE streaming, offline mode, and multi-arch (amd64, arm64). GitHub - yisding/reviewwiggum GitHub - MarwanAlsoltany/serrors: Structured errors for Go: sentinel hierarchies, typed data, custom formatting, and slog integration. GitHub - soatok/age-php GitHub - Luthiraa/markitme GitHub - stagas/rtdiff: realtime git diff gui and AI-assisted commits GitHub - tombedor/excalicharts GitHub - wh1le/excalidraw-edit: Open and edit .excalidraw files from the terminal. Offline, auto-saves to disk. MalExt Sentry - Malicious Extension Scanner - Chrome 应用商店 GitHub - syi0808/asciianimesvg: Generate animated ASCII art SVGs from text. CLI, Rust library, WASM, and web editor. GitHub - zaina-ml/ml_forge: A visual-based graph node editor for training computer vision models. GitHub - anakin87/llm-rl-environments-lil-course: 🌱 A little course on Reinforcement Learning Environments for evaluating and training Language Models GitHub - takaakit/superpowers-uml: Superpowers-UML modifies Superpowers to ensure a software development workflow in which AI agents design through UML modeling. AdriByte Studio - Sviluppo Web e Soluzioni Digitali GitHub - chouligi/angel-copilot: Your personalized Angel Investment Advisor Show HN: MoodSense AI (ML and FastAPI and Gradio, Deployed on Hugging Face) Moodsense Ai - a Hugging Face Space by aman179102 GitHub - agenteractai/lodmem: Level Of Detail Context Management for Agents GitHub - ostefani/subnetlens: A fast, concurrent network scanner with a TUI and plain-text CLI, built in Go. It discovers live hosts on your network, scans their open ports, resolves hostnames, and fingerprints operating systems—delivered. Cyber Pulse: Agentic Intel - Apps on Google Play Whisper API: Self-Hostable Speech to Text Transcription The Agent-Web Protocol Stack: A Research Thesis GitHub - msmarkgu/RelayFreeLLM: A restful API designed to route user prompts to various AI model providers. Show HN: Provepy – A Python decorator that proves your code using Lean and LLMs Show HN: Pardonned.com – A searchable database of US Pardons GitHub - patrickdappollonio/dux: Dux is a terminal UI that lets you run multiple AI coding agents side by side, each in its own git worktree, with full companion terminals, macros, commit generation, and a command palette that knows more tricks than you do. kMC Crystal Simulator Show HN: HyperFlow – A self-improving agent framework built on LangGraph GitHub - stef41/vibescore: 🎵 Grade your vibe-coded project. One command, instant letter grade across security, quality, dependencies, and testing. GitHub - stef41/lmscan: 🔍 Detect AI-generated text and fingerprint which LLM wrote it. Open-source GPTZero alternative. Zero dependencies, works offline. imgur.com GitHub - visionscaper/collabmem: Enabling long-term collaboration with Agentic AI - building up episodic and world model memory over time with in-context awareness 在 Steam 上购买 FriedrichAI: Offline AI 立省 10% GitHub - atripati/ark: AI Runtime Kernel — a context operating system for AI agents. Eliminates tool bloat, loads only what’s needed, and gives LLMs their reasoning space back. GitHub - nowork-studio/toprank: Open-source Claude Code skills for SEO, SEM, Google Ads GitHub - tacomanator/sash: Lightweight macOS menu bar app for reliably cycling through windows of the current application. Appents | Social Media Management for Product-First Teams GitHub - pnhoang/youtube-spam-blocker: Automatically detects and hides spam messages in YouTube Live chat. Set rate limits, keyword filters, and block repeat offenders. GitHub - decisionnode/DecisionNode: CLI + Local MCP - A shared structured memory store across Claude Code, Cursor, Windsurf, Antigravity, and every MCP client. Semantically queryable. GitHub - AvaCodeSolutions/django-email-learning: An open source Django app for creating email-based learning platforms with IMAP integration and React frontend components. The $100K Gap in Kubernetes Security Tooling Function Calling Harness: From 6.75% to 100%
skills/boring/README.md at main · ericfitz/skills
efitz · 2026-05-07 · via Hacker News: Show HN

boring — writing-evaluation skill

A skill that evaluates technical business writing — executive briefs, RFCs, status updates, finding writeups, architecture docs, proposals, technical reports — for "boringness" across a 20-sub-dimension taxonomy on four axes: Direction, Density, Texture, and Surprise. Grounded in the MAC model of boredom (Westgate & Wilson, 2018) plus the craft tradition (Gopen-Swan, Williams, Provost, Minto).

Skill entry point: src/SKILL.md. Invoke from a Codex or Claude Code session.

Download

Clone the repository or download the skill as a zip file from releases.

Install

The shipped artifact is a versioned zip in dist/. Build it with:

boring/tools/build.sh
# → boring/dist/boring-<version>.zip

To install into a Claude Code skills directory:

# 1. Copy the zip into your skills dir (user-global shown; project-
#    local would be <repo>/.claude/skills/ instead).
cp boring/dist/boring-<version>.zip ~/.claude/skills/

# 2. Unzip — produces ~/.claude/skills/boring/
cd ~/.claude/skills && unzip boring-<version>.zip && rm boring-<version>.zip

# 3. Build the analyzer's Python venv. Requires `uv`
#    (https://docs.astral.sh/uv/). Takes ~30s the first time.
cd boring && uv sync

To install into a Codex skills directory:

# 1. Copy the zip into your skills dir (user-global shown; project-
#    local would be <repo>/.codex/skills/ instead).
cp boring/dist/boring-<version>.zip ~/.codex/skills/

# 2. Unzip — produces ~/.codex/skills/boring/
cd ~/.codex/skills && unzip boring-<version>.zip && rm boring-<version>.zip

# 3. Build the analyzer's Python venv. Requires `uv`
#    (https://docs.astral.sh/uv/). Takes ~30s the first time.
cd boring && uv sync

In either case, step 3 is technically optional — SKILL.md's setup decision tree runs uv sync on first invocation if the venv is missing — but doing it eagerly fails fast if uv isn't installed or the network is down, instead of discovering that mid-conversation.

Status

v0.1.0 — full pipeline complete. 15 mechanical sub-dimensions run as a Python script (deterministic, locator-rich JSON output); 5 LLM-judged sub-dimensions are handled by the host LLM via the rubrics in src/rubrics/. Calibration thresholds are intuitive defaults, not yet tuned against a labeled corpus of business writing — see docs/calibration-findings-2026-05-04.md for the first calibration attempt and why it punted on threshold updates.

Next steps The skill is undergoing calibration against a hand-labeled corpus of business writing, which will cause an update in the values in configuration.toml that optimize against writing style at the author's employer. The skill runs fine and produces useful output now with intuitive weights, or you can assemble your own internal corpous of "boring" and "not-boring" documents for your organization and perform your own calibration vs. that corpus. Note that "not-boring" does not mean the same thing as "interesting"; the latter concept is heavily weighted in the subject's perceived interest in the subject matter vs. the writing style.

Repository layout

This directory is split into the shipped skill and the dev-side tooling around it:

boring/
├── README.md                   ← this file
├── src/                        ← the skill (everything that ships)
│   ├── SKILL.md                ← entry point: invocation, workflow, rubrics index
│   ├── calibration.toml        ← thresholds + per-genre profiles
│   ├── pyproject.toml          ← Python deps for the analyzer
│   ├── uv.lock
│   ├── docs/
│   │   ├── schema-mechanical.md    ← Phase 1 (analyzer) output schema
│   │   ├── schema-llm.md           ← Phase 2 (LLM judgment) output schema
│   │   └── schema-merged.md        ← Phase 3 (merged) output schema
│   ├── rubrics/                ← Phase 2 judge rubrics (read by the host LLM)
│   │   ├── D1_2_missing_stakes.md
│   │   ├── D1_5_flat_tension.md
│   │   ├── D2_5_obvious_claims.md
│   │   ├── D4_2_no_vivid_imagery.md
│   │   └── D4_3_no_counterintuitive_claims.md
│   └── scripts/
│       └── analyzer/           ← the Python analyzer package
│           ├── __main__.py     ← CLI entry point
│           ├── pipeline.py     ← orchestrator
│           ├── document.py     ← parsing (md / txt / docx / pdf), spaCy caching
│           ├── locator.py      ← composite-locator construction
│           ├── config.py       ← calibration loading + genre overrides
│           ├── checks/         ← one file per check, registered into the pipeline
│           └── common/
│               ├── proselint_wrap.py    ← cached proselint pass + span-offset fix
│               ├── readability.py
│               └── word_lists.py        ← curated phrase tables
├── docs/                       ← dev-side reference (not shipped)
│   ├── research-report.md      ← MAC + craft-tradition grounding, taxonomy
│   ├── decisions.md            ← design decisions log
│   └── calibration-findings-2026-05-04.md
├── samples/                    ← smoke-test fixtures (not shipped)
│   ├── input.md
│   └── output.json
├── tools/                      ← calibration scripts (not shipped)
│   ├── run_corpus.py           ← runs the analyzer over a labeled corpus
│   ├── run_one.py              ← re-runs a single doc, patches results.csv
│   └── analyze_results.py      ← per-check separability + threshold recs
├── calibration/                ← gitignored corpus + per-run outputs
│   ├── boring                  ← corpus of curated documents that are hand-labeled as "boring"
│   ├── not-boring              ← corpus of curated documents that are hand-labeled as "not-boring"
└── dist/                       ← gitignored build output (copy of src/)

To produce a distributable skill, copy src/ into dist/boring/. Everything outside src/ is dev-side and intentionally not shipped.

Quickstart

# from boring/src/ — uv handles the venv + deps (model is bundled
# via pyproject.toml, no separate spaCy install needed)
cd src
uv sync

# run the mechanical analyzer against the bundled sample
uv run python -m analyzer ../samples/input.md --genre executive_brief --output /tmp/result.json

If your IDE (VS Code, ty, Pylance) reports spurious "unresolved import" errors for spacy, proselint, textstat, docx, or pypdf, point the IDE's Python interpreter at boring/src/.venv/bin/python. The pyproject.toml already configures tool.ty.environment, tool.pyright, and tool.ruff for that path; some IDEs also need an explicit interpreter selection.

Genres recognized: executive_brief, architecture_doc, technical_report, finding_writeup, proposal, rfc, status_update. Omit --genre to use default thresholds.

Input formats: .md / .markdown, .txt, .docx, .pdf. PDFs use pypdf for text extraction and carry page_number on every locator. Image-only / scanned PDFs are rejected with a clear error (OCR is not supported).

What the analyzer covers

15 mechanical sub-dimensions across the four axes:

Direction: D1.1 buried thesis, D1.4 no signposting, D1.6 topic- position drift.

Density: D2.1 padding/wordiness, D2.2 nominalization fog, D2.3 passive overhang, D2.4 subject-verb separation, D2.7 hedging clutter, D2.8 throat-clearing.

Texture: D3.1 sentence-length monotony, D3.3 opener monotony, D3.4 paragraph monotony, D3.5 vocabulary flatness.

Surprise: D4.1 no concrete examples, D4.4 no specificity.

The 5 sub-dimensions deferred to the host LLM (handled in Phase 2 of the skill workflow): D1.2 missing stakes, D1.5 flat tension, D2.5 obvious claims, D4.2 no vivid imagery, D4.3 no counterintuitive claims. Their rubrics live in rubrics/.

Adding a new mechanical check

  1. Create a new module in src/scripts/analyzer/checks/ (e.g. d2_6_idea_overload.py).
  2. Define a class with class-level code, name, axis and a run(doc, config) method returning a Finding.
  3. Call register_check(YourCheck()) at the bottom of the file.
  4. Add the import to src/scripts/analyzer/checks/__init__.py.
  5. Add the corresponding threshold block to src/calibration.toml.

The pipeline picks it up automatically.

See also

  • src/SKILL.md — the invocation contract
  • docs/research-report.md — taxonomy and theoretical grounding
  • src/docs/schema-mechanical.md / src/docs/schema-llm.md / src/docs/schema-merged.md — output schemas (shipped with the skill)
  • docs/decisions.md — design decisions log
  • src/calibration.toml — every threshold, with rationale comments