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

推荐订阅源

Help Net Security
Help Net Security
U
Unit 42
H
Help Net Security
酷 壳 – CoolShell
酷 壳 – CoolShell
云风的 BLOG
云风的 BLOG
宝玉的分享
宝玉的分享
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Vercel News
Vercel News
Jina AI
Jina AI
Apple Machine Learning Research
Apple Machine Learning Research
B
Blog RSS Feed
T
The Blog of Author Tim Ferriss
WordPress大学
WordPress大学
Recent Announcements
Recent Announcements
罗磊的独立博客
Google DeepMind News
Google DeepMind News
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Hacker News - Newest:
Hacker News - Newest: "LLM"
Recent Commits to openclaw:main
Recent Commits to openclaw:main
PCI Perspectives
PCI Perspectives
L
LangChain Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
S
SegmentFault 最新的问题
C
Cisco Blogs
T
The Exploit Database - CXSecurity.com
P
Proofpoint News Feed
B
Blog
V
Vulnerabilities – Threatpost
Scott Helme
Scott Helme
Google Online Security Blog
Google Online Security Blog
J
Java Code Geeks
E
Exploit-DB.com RSS Feed
The Cloudflare Blog
N
News and Events Feed by Topic
S
Schneier on Security
Cloudbric
Cloudbric
Forbes - Security
Forbes - Security
H
Hacker News: Front Page
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
The Hacker News
The Hacker News
博客园 - 【当耐特】
aimingoo的专栏
aimingoo的专栏
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
P
Palo Alto Networks Blog
GbyAI
GbyAI
AI
AI
T
Threat Research - Cisco Blogs
SecWiki News
SecWiki News
人人都是产品经理
人人都是产品经理

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%
GitHub - AbhishekR3/ps-local: Local Pokémon Showdown app with a battle help screen
3Abhishek · 2026-06-16 · via Hacker News: Show HN

Pokémon Showdown Live Battle Assistant

test Codacy Badge

An Electron app that automatically saves a rich battle log for every Pokémon Showdown battle — a raw protocol dump plus a human-readable breakdown — with zero per-battle action. Play on the live play.pokemonshowdown.com ladder in a native docked window with an integrated battle helper panel that shows the opponent's predicted sets, stats, abilities, and Tera types live.

See It In Action

UI Demo — Live battle with real-time helper predictions

Downloads

OS Minimum Requirements Installation Steps Status
macOS macOS 10.13 High Sierra or later 1. Download .dmg
2. Open it and drag the app to Applications
3. Right-click → Open on first launch (unsigned — no Apple Developer ID)
build-macos
Linux Ubuntu 18.04+ / glibc ≥ 2.17 1. Download .AppImage
2. chmod +x Pokemon.Showdown.Battle.UI.AppImage
3. Run it — no install needed
build-linux
Windows Windows 10 or later 1. Download .exe installer
2. Run the installer and follow the prompts
3. Launch from the Start menu
build-windows
Chromium Extension Chrome / Chromium 88+ 1. Download ps-local-extension.zip
2. Unzip, then go to chrome://extensions → enable Developer mode
3. Click "Load unpacked" and select the unzipped folder
build-chromium-extension

Releases are published automatically by release.yml when a vX.Y.Z tag is pushed.

Installed builds (macOS/Linux/Windows) save logs and read config.json from ~/Documents/ps-local/.

Quickstart (run from source)

Prerequisites:

Tool Version
Node.js ≥ 22.6
npm ≥ 10
Git any modern (submodules)
git clone https://github.com/AbhishekR3/ps-local.git ps-local && cd ps-local
npm run setup:ui    # install showdown-ui dependencies (one-time)
npm start           # launch — connects to live play.pokemonshowdown.com

Log in with your Pokémon Showdown account and play a battle. When it ends (or you close the room past turn 1), two directories appear under logs/:

  • battle_info/ — one .txt file per battle
  • debug/ — structured per-session debug log

Battle Logs

Saved battle log in a text editor

Each finished battle produces one file in logs/battle_info/:

<timestamp>_<roomid>_<p1>_vs_<p2>.txt

Spectated battles get a SPEC_ prefix between the roomid and the player names. The file contains six sections: battle summary, your team, opponent team, field state, turn-by-turn log, and raw protocol. See docs/LOG-FORMAT.md for the full spec.

Debug logging

Every session appends structured logs to logs/debug/showdown-ui-<ts>.log. Set PS_LOG_LEVEL=DEBUG for per-frame detail — useful when no log files appear after a battle:

PS_LOG_LEVEL=DEBUG npm start

Helper Panel

Helper panel — predicted sets, stat bars, ability pills, Tera type

When a battle is open, the right-side panel shows the opponent's Pokémon with predicted sets, stats, abilities, and Tera types. It updates live as the battle progresses.

  • Resizable — drag the divider between the game view and the panel
  • Spectator mode — both players' cards render side by side when watching

Configuration

Copy config.example.json to config.json at the repo root (gitignored):

{
  "timezone": "America/New_York",
  "logLevel": "INFO",
  "saveLogs": true,
  "iconPath": "~/Documents/ps-local/my-icon.png"
}

iconPath sets the live window/taskbar icon (Linux/Windows) and the macOS Dock icon. Falls back to the bundled icon when unset or unreadable.

Environment variable overrides: PS_LOG_LEVEL=DEBUG, PS_TIMEZONE=<iana>.

Privacy

  • Battle traffic and login go to *.psim.us / play.pokemonshowdown.com as on the normal site. The tap only writes battles to logs/battle_info/ on disk — nothing extra is uploaded.
  • Third-party ad and analytics requests (Google, Microsoft/Bing, Venatus, ~50 prebid partners) are cancelled at the Electron session layer before they leave the machine.

Troubleshooting

No log files after a battle. Open DevTools (Electron menu → View → Toggle Developer Tools) and check for [PSH inject] WebSocket created: … | tapped: true, then [PSH inject] battle frame #N during play. If you see tapped: false, the sim socket URL didn't match the tap filter. Run PS_LOG_LEVEL=DEBUG npm start and check logs/debug/ for per-frame counts.

Login issues. Log in through the normal Pokémon Showdown UI in the left panel. Session persists across restarts via the persist:showdown-ui Electron session partition.

Updating Upstream

ps-local wraps two official Pokémon Showdown repositories as git submodules:

Submodule Path Upstream
Server vendor/pokemon-showdown smogon/pokemon-showdown
Client vendor/pokemon-showdown-client smogon/pokemon-showdown-client

Never source-edit anything in vendor/. All customizations live in overlay/.

npm run update-upstream    # bumps both submodules, rebuilds, re-applies overlays, runs helper tests

A weekly CI canary (upstream-canary.yml) runs this automatically and files an upstream-breakage issue on failure. See docs/UPDATE-WORKFLOW.md.

After an upstream bump that changes sets/moves/Pokédex, regenerate the static data bundle:

cd vendor/pokemon-showdown && npm run build && cd ../..
cd helper && node build-data.js

Tests & CI

Command What it runs
npm test Full helper suite (parser / exporter / golden / edge / guards / render / logmeta)
npm run test:smoke One fixture battle → parser → exporter; asserts section anchors
cd helper && node --test test/parser.test.js Single test file

If you intentionally change exporter formatting, refresh the golden: node helper/test/golden.test.js --update.

Build CI runs on showdown-ui/ or helper/extension/ path changes:

CI workflow What it builds Status
build-electron From-source electron-vite build + PS_SMOKE launch smoke build-electron app
build-linux Linux AppImage + tar.gz + xvfb PS_SMOKE launch build-linux
build-windows Windows NSIS installer + portable .exe build-windows
build-macos macOS .dmg + .zip (unsigned) build-macos
build-chromium-extension Extension zip + credential leak-assert build-chromium-extension

Codacy analyzes every push; vendor/ and generated bundles are excluded.

Architecture

showdown-ui/electron/main/index.ts
  ├─ BrowserWindow (React helper panel — right side)
  │     └─ preload/index.ts: exposes psUI API to renderer
  ├─ WebContentsView (psView — left side, live play.pokemonshowdown.com)
  │     └─ preload/ps.ts: installs WebSocket tap → postMessage → ps-frame IPC
  ├─ main: receives ps-frame → BattleTracker + generateBattleLog → logs/battle_info/
  └─ session ad-block: cancels ~55 ad/analytics domains before they leave the machine

The log writer (tap → parser → exporter → logs/) runs in the Electron main process. The React helper panel renders opponent breakdowns in the renderer. Both use the same shared pure libs from helper/extension/lib/.

Directory Structure

showdown-ui/       Primary Electron app (React helper panel + live PS client)
  electron/
    main/          Main process: log writer, IPC, ad blocking, window management
    preload/       index.ts (helper API bridge) + ps.ts (WebSocket tap)
  src/             React renderer (HelperPanel, render.ts, styles)
helper/            WebSocket tap + parser + exporter + data bundle + tests
  extension/lib/   parser.js (BattleTracker), exporter.js, lookup.js — pure shared libs
  extension/data/  Static battle-data bundle (sets, moves, abilities)
overlay/           Config overlays applied to vendor submodules
vendor/            Pristine git submodules (never source-edit)
  ├─ pokemon-showdown/
  └─ pokemon-showdown-client/
app/               Legacy Electron app (local-mode sandbox + PS_SYNTHETIC=1 CI)
logs/
  ├─ battle_info/  Battle logs (.txt)
  └─ debug/        Debug logs
scripts/           Build and orchestration utilities
docs/              Documentation (log format, update workflow, packaging)

Contributing

See CONTRIBUTING.md for local setup, the vendor/ "never source-edit" rule, how to run the tests, and what CI expects from a pull request.

Credits

ps-local builds on the excellent open-source work of the Pokémon Showdown team:

Both projects are published under the MIT license. ps-local adds local logging and a native helper panel on top of this foundation — the core battle simulation, protocol, and UI remain the Showdown team's work.

Special thanks to the Showdown community for maintaining such a robust, open platform for Pokémon competitive play.

License

MIT © Abhishek Ramesh. The wrapped Pokémon Showdown server and client are included only as git submodules under vendor/ and remain under their own (MIT) licenses.