mirror of
https://fastgit.cc/github.com/luongnv89/claude-howto
synced 2026-04-21 05:00:28 +08:00
- Translate resources/ (README, QUICK-START, DESIGN-SYSTEM) - Translate scripts/README.md (EPUB builder docs) - Copy docs/ and prompts/ as-is (internal planning + functional prompts) - Copy claude_concepts_guide.md (base for in-place translation) Ref: luongnv89/claude-howto#63
Скрипт збірки EPUB
Збірка EPUB-книги з markdown-файлів Claude How-To.
Функції
- Організує розділи за структурою каталогів (01-slash-commands, 02-memory тощо)
- Рендерить Mermaid-діаграми як PNG-зображення через Kroki.io API
- Асинхронне паралельне завантаження — рендерить усі діаграми одночасно
- Генерує обкладинку з логотипу проєкту
- Конвертує внутрішні markdown-посилання у посилання на розділи EPUB
- Суворий режим помилок — падає, якщо діаграма не може бути відрендерена
Вимоги
- Python 3.10+
- uv
- Інтернет-з'єднання для рендерингу Mermaid-діаграм
Швидкий старт
# Simplest way - uv handles everything
uv run scripts/build_epub.py
Налаштування розробки
# Create virtual environment
uv venv
# Activate and install dependencies
source .venv/bin/activate
uv pip install -r requirements-dev.txt
# Run tests
pytest scripts/tests/ -v
# Run the script
python scripts/build_epub.py
Параметри командного рядка
usage: build_epub.py [-h] [--root ROOT] [--output OUTPUT] [--verbose]
[--timeout TIMEOUT] [--max-concurrent MAX_CONCURRENT]
options:
-h, --help show this help message and exit
--root, -r ROOT Root directory (default: repo root)
--output, -o OUTPUT Output path (default: claude-howto-guide.epub)
--verbose, -v Enable verbose logging
--timeout TIMEOUT API timeout in seconds (default: 30)
--max-concurrent N Max concurrent requests (default: 10)
Приклади
# Build with verbose output
uv run scripts/build_epub.py --verbose
# Custom output location
uv run scripts/build_epub.py --output ~/Desktop/claude-guide.epub
# Limit concurrent requests (if rate-limited)
uv run scripts/build_epub.py --max-concurrent 5
Вивід
Створює claude-howto-guide.epub у кореневому каталозі репозиторію.
EPUB включає:
- Обкладинку з логотипом проєкту
- Зміст з вкладеними секціями
- Весь markdown-контент, конвертований у EPUB-сумісний HTML
- Mermaid-діаграми, відрендерені як PNG-зображення
Запуск тестів
# With virtual environment
source .venv/bin/activate
pytest scripts/tests/ -v
# Or with uv directly
uv run --with pytest --with pytest-asyncio \
--with ebooklib --with markdown --with beautifulsoup4 \
--with httpx --with pillow --with tenacity \
pytest scripts/tests/ -v
Залежності
Керуються через PEP 723 inline script metadata:
| Пакет | Призначення |
|---|---|
ebooklib |
Генерація EPUB |
markdown |
Конвертація Markdown → HTML |
beautifulsoup4 |
Парсинг HTML |
httpx |
Асинхронний HTTP-клієнт |
pillow |
Генерація обкладинки |
tenacity |
Логіка повторних спроб |
Усунення проблем
Збірка падає з мережевою помилкою: Перевірте інтернет-з'єднання та стан Kroki.io. Спробуйте --timeout 60.
Обмеження частоти: Зменште паралельні запити з --max-concurrent 3.
Відсутній логотип: Скрипт генерує текстову обкладинку, якщо claude-howto-logo.png не знайдено.