pp-roadside-america
Every offbeat roadside attraction on RoadsideAmerica. Trigger phrases: `quirky attractions near me`, `weird roadside stuff in Texas`, `world's largest things nearby`, `offbeat roadside attractions for my road trip`, `biggest tourist traps in a state`, `use roadside-america`, `run roadside-america`.
What this skill does
<!-- GENERATED FILE — DO NOT EDIT.
This file is a verbatim mirror of library/travel/roadside-america/SKILL.md,
regenerated post-merge by tools/generate-skills/. Hand-edits here are
silently overwritten on the next regen. Edit the library/ source instead.
See the repository agent guide, section "Generated artifacts: registry.json, cli-skills/". -->
# Roadside America — Printing Press CLI
## Prerequisites: Install the CLI
This skill drives the `roadside-america-pp-cli` binary. **You must verify the CLI is installed before invoking any command from this skill.** If it is missing, install it first:
1. Install via the Printing Press installer. It defaults binaries to `$HOME/.local/bin` on macOS/Linux and `%LOCALAPPDATA%\Programs\PrintingPress\bin` on Windows:
```bash
npx -y @mvanhorn/printing-press-library install roadside-america --cli-only
```
2. Verify: `roadside-america-pp-cli --version`
3. Ensure the reported install directory is on `$PATH` for the agent/runtime that will invoke this skill.
If the `npx` install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.26.4 or newer). This installs into `$GOPATH/bin` (default `$HOME/go/bin`), so add that directory to `$PATH` instead:
```bash
go install github.com/mvanhorn/printing-press-library/library/travel/roadside-america/cmd/roadside-america-pp-cli@latest
```
If `--version` reports "command not found" after install, the runtime cannot see the binary directory on `$PATH`. Do not proceed with skill commands until verification succeeds.
RoadsideAmerica.com is the web's best catalog of quirky US & Canada tourist attractions, but it has no API and a paywalled app. This CLI turns it into an agent-native, pipe-friendly tool: find what's near a place or coordinates, browse a whole state, pull the full writeup, and slice by superlative categories like biggest/smallest/tallest/weird-food. Everything is cached locally (fresh-on-read), every record links back to its source, and the scraper stays a polite, attributing, user-initiated citizen of the site.
## When to Use This CLI
Use this CLI to discover offbeat, quirky, community-sourced roadside attractions in the US and Canada from RoadsideAmerica.com: what's near a place or coordinates, what's in a given state, the full writeup for a specific attraction, or superlative slices like the biggest/smallest/tallest things and weird food stops. It is ideal for road-trip planning and 'find me something weird nearby' tasks, and it caches everything locally for fast, repeatable, offline-friendly queries.
## Anti-triggers
Do not use this CLI for:
- Do not use for booking, ticketing, hours, or live availability — the data is descriptive, community-sourced, and not real-time.
- Do not treat addresses as authoritative for navigation; verify before driving.
- Do not use outside the US and Canada (the source only covers those).
- Do not use for mainstream tourism, restaurant reviews, or hotels — this is offbeat oddities only.
## Unique Capabilities
These capabilities aren't available in any other tool for this API.
### Local cache intelligence
- **`category`** — Find the biggest, smallest, tallest, or weird-food attractions (and more) by classifying cached attractions locally.
_Reach for this when the user wants superlatives or a themed slice (giants, muffler-men, weird-food) rather than a place- or state-scoped list._
```bash
roadside-america-pp-cli category biggest --json
```
- **`stats`** — Summarize the local cache: counts by state and by category, plus totals.
_Use to understand coverage of the local cache before planning, or to answer 'which state has the most offbeat stuff cached'._
```bash
roadside-america-pp-cli stats --agent
```
- **`random`** — Pick a random offbeat attraction, optionally constrained by state or category.
_Use for serendipity or road-trip inspiration when the user has no specific target._
```bash
roadside-america-pp-cli random --state TX
```
### Route & comparison
- **`trip`** — Collect quirky stops near a list of cities or coordinates in one call, deduped and labeled by stop.
_Reach for this when planning a route and the user wants offbeat stops across several waypoints at once._
```bash
roadside-america-pp-cli trip "Austin, TX" "Waco, TX" --radius 15 --json
```
- **`compare`** — Compare two states by offbeat-attraction count and surface a few top picks from each.
_Use when the user is deciding between regions or wants a quick 'which state is weirder' answer._
```bash
roadside-america-pp-cli compare TX CA
```
## Command Reference
**raw** — Raw RoadsideAmerica.com passthrough (HTML link/page extraction). Prefer the top-level near / state / show / category commands for structured output.
- `roadside-america-pp-cli raw by-state` — Raw attraction links for a US/Canada state (HTML fragment).
- `roadside-america-pp-cli raw detail` — Raw attraction detail page (HTML).
- `roadside-america-pp-cli raw nearby` — Raw nearby attraction links for coordinates (HTML fragment).
### Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
```bash
roadside-america-pp-cli which "<capability in your own words>"
```
`which` resolves a natural-language capability query to the best matching command from this CLI's curated feature index. Exit code `0` means at least one match; exit code `2` means no confident match — fall back to `--help` or use a narrower query.
## Recipes
### Quirky stops near coordinates, agent-friendly fields
```bash
roadside-america-pp-cli near 30.27,-97.74 --radius 25 --agent --select name,city,distance,source_url
```
Pass raw lat,lng to skip geocoding and select only the fields an agent needs.
### Weird food across a cached state
```bash
roadside-america-pp-cli category weird-food --json
```
Classifies cached attractions by food keywords; populate the cache with state/near first.
### Plan offbeat stops across a route
```bash
roadside-america-pp-cli trip "Austin, TX" "Waco, TX" "Dallas, TX" --radius 15 --json
```
Aggregates nearby attractions for each waypoint, deduped and labeled by stop.
### Full writeup with source attribution
```bash
roadside-america-pp-cli show 2055 --json
```
Returns structured name/address/writeup plus the RoadsideAmerica.com source URL.
## Auth Setup
No authentication required.
Run `roadside-america-pp-cli doctor` to verify setup.
## Agent Mode
Add `--agent` to any command. Expands to: `--json --compact --no-input --no-color --yes`.
- **Pipeable** — JSON on stdout, errors on stderr
- **Filterable** — `--select` keeps a subset of fields. Dotted paths descend into nested structures; arrays traverse element-wise. Critical for keeping context small on verbose APIs:
```bash
roadside-america-pp-cli raw by-state --state example-value --agent --select id,name,status
```
- **Previewable** — `--dry-run` shows the request without sending
- **Offline-friendly** — sync/search commands can use the local SQLite store when available
- **Non-interactive** — never prompts, every input is a flag
- **Read-only** — do not use this CLI for create, update, delete, publish, comment, upvote, invite, order, send, or other mutating requests
### Response envelope
Commands that read from the local store or the API wrap output in a provenance envelope:
```json
{
"meta": {"source": "live" | "local", "synced_at": "...", "reason": "..."},
"results": <data>
}
```
Parse `.results` for data and `.meta.source` to know whether it's live or local. A human-readable `N results (live)` summary is printed to stderr only when stdout is a terminal AND no machine-format flag (`--json`, `--csv`, `--compact`, `--quiet`, `--plain`, `--select`) is set — piped/agent consumers and explicit-format runs get pure JSON on stdout.
## Agent Feedback
When you (or the agent) notice something off about this CLI, record it:
```
roadside-america-pp-cli feedback "the -Related in General
modeling-omnistudio-epc-catalog
IncludedSalesforce Industries CME EPC product-modeling skill for Product2-based catalog creation. Use when creating EPC products, configuring product attributes, building offer bundles with Product Child Items, or reviewing EPC DataPack JSON metadata for product catalog changes. TRIGGER when: user creates or updates Product2 EPC records, AttributeAssignment payloads, AttributeMetadata/AttributeDefaultValues, Offer bundles, or ProductChildItem relationships. DO NOT TRIGGER when: designing OmniScripts/FlexCards/Integration Procedures (use building-omnistudio-omniscript, building-omnistudio-flexcard, or building-omnistudio-integration-procedure), implementing Apex business logic (use generating-apex), or troubleshooting deployment pipelines (use deploying-metadata).
relationship-science-coach
IncludedUse this skill for direct, practical adult relationship coaching: couples conflict, repair, trust, marriage, dating, flirting, attachment patterns, emotional connection, sex, desire differences, eroticism, kink negotiation, affection, love languages, breakups, and long-term passion. Draw on Gottman, EFT and Hold Me Tight, attachment science, modern sex research, Perel, Nagoski, Kerner, Schnarch, Love and Stosny, and flexible love-language tools. Be concrete and low-hedge. Redirect only for imminent danger, abuse, coercive control, minors, non-consent, self-harm, stalking, or medical/legal/psychiatric decisions.
building-sf-integrations
IncludedSalesforce integration architecture and runtime plumbing with 120-point scoring. Use this skill to set up Named Credentials, External Credentials, External Services, REST/SOAP callout patterns, Platform Events, and Change Data Capture. TRIGGER when: user sets up Named Credentials, External Services, REST/SOAP callouts, Platform Events, CDC, or touches .namedCredential-meta.xml files. DO NOT TRIGGER when: Connected App/OAuth config (use configuring-connected-apps), Apex-only logic (use generating-apex), or data import/export (use handling-sf-data).
venue-templates
IncludedAccess comprehensive LaTeX templates, formatting requirements, and submission guidelines for major scientific publication venues (Nature, Science, PLOS, IEEE, ACM), academic conferences (NeurIPS, ICML, CVPR, CHI), research posters, and grant proposals (NSF, NIH, DOE, DARPA). This skill should be used when preparing manuscripts for journal submission, conference papers, research posters, or grant proposals and need venue-specific formatting requirements and templates.
let-fate-decide
IncludedDraws the 12 Houses of the Zodiac Tarot spread to inject entropy into planning when prompts are vague, ambiguous, or casually delegated. Interprets the spread to guide next steps. Use when the user says 'let fate decide', 'YOLO', 'whatever', 'idk', or other nonchalant phrases, makes Yu-Gi-Oh references, or when you are about to arbitrarily pick between multiple reasonable approaches. Prefer over ask-questions-if-underspecified when the user's tone is casual or playful rather than precision-seeking.
net-ops
IncludedCross-platform network troubleshooting (Windows, macOS, Linux) via local or remote shell. Use for: DNS broken, can't resolve hostnames, nslookup/dig works but apps fail, NRPT, WFP, scutil, /etc/resolver, systemd-resolved, /etc/resolv.conf, NetworkManager, VPN DNS leak residue (ProtonVPN/Mullvad/WireGuard/AnyConnect), AV/firewall blocking DNS or DoH, Tailscale DNS interaction, intermittent connectivity, remote diagnostics over SSH.