- Fix pre-existing lint errors in engine/ modules using ruff --unsafe-fixes - Add hk.pkl with pre-commit and pre-push hooks using ruff builtin - Configure hooks to use 'uv run' prefix for tool execution - Update mise.toml to include hk and pkl tools - All 73 tests pass
116 lines
5.7 KiB
Python
116 lines
5.7 KiB
Python
"""
|
|
Data sources: feed URLs, poetry sources, language mappings, script fonts.
|
|
Pure data — no logic, no dependencies.
|
|
"""
|
|
|
|
# ─── RSS FEEDS ────────────────────────────────────────────
|
|
FEEDS = {
|
|
# Science & Technology
|
|
"Nature": "https://www.nature.com/nature.rss",
|
|
"Science Daily": "https://www.sciencedaily.com/rss/all.xml",
|
|
"Phys.org": "https://phys.org/rss-feed/",
|
|
"NASA": "https://www.nasa.gov/news-release/feed/",
|
|
"Ars Technica": "https://feeds.arstechnica.com/arstechnica/index",
|
|
"New Scientist": "https://www.newscientist.com/section/news/feed/",
|
|
"Quanta": "https://api.quantamagazine.org/feed/",
|
|
"BBC Science": "http://feeds.bbci.co.uk/news/science_and_environment/rss.xml",
|
|
"MIT Tech Review": "https://www.technologyreview.com/feed/",
|
|
# Economics & Business
|
|
"BBC Business": "http://feeds.bbci.co.uk/news/business/rss.xml",
|
|
"MarketWatch": "https://feeds.marketwatch.com/marketwatch/topstories/",
|
|
"Economist": "https://www.economist.com/finance-and-economics/rss.xml",
|
|
# World & Politics
|
|
"BBC World": "http://feeds.bbci.co.uk/news/world/rss.xml",
|
|
"NPR": "https://feeds.npr.org/1001/rss.xml",
|
|
"Al Jazeera": "https://www.aljazeera.com/xml/rss/all.xml",
|
|
"Guardian World": "https://www.theguardian.com/world/rss",
|
|
"DW": "https://rss.dw.com/rdf/rss-en-all",
|
|
"France24": "https://www.france24.com/en/rss",
|
|
"ABC Australia": "https://www.abc.net.au/news/feed/2942460/rss.xml",
|
|
"Japan Times": "https://www.japantimes.co.jp/feed/",
|
|
"The Hindu": "https://www.thehindu.com/news/national/feeder/default.rss",
|
|
"SCMP": "https://www.scmp.com/rss/91/feed",
|
|
"Der Spiegel": "https://www.spiegel.de/international/index.rss",
|
|
# Culture & Ideas
|
|
"Guardian Culture": "https://www.theguardian.com/culture/rss",
|
|
"Aeon": "https://aeon.co/feed.rss",
|
|
"Smithsonian": "https://www.smithsonianmag.com/rss/latest_articles/",
|
|
"The Marginalian": "https://www.themarginalian.org/feed/",
|
|
"Nautilus": "https://nautil.us/feed/",
|
|
"Wired": "https://www.wired.com/feed/rss",
|
|
"The Conversation": "https://theconversation.com/us/articles.atom",
|
|
"Longreads": "https://longreads.com/feed/",
|
|
"Literary Hub": "https://lithub.com/feed/",
|
|
"Atlas Obscura": "https://www.atlasobscura.com/feeds/latest",
|
|
}
|
|
|
|
# ─── POETRY / LITERATURE ─────────────────────────────────
|
|
# Public domain via Project Gutenberg
|
|
POETRY_SOURCES = {
|
|
"Whitman": "https://www.gutenberg.org/cache/epub/1322/pg1322.txt",
|
|
"Dickinson": "https://www.gutenberg.org/cache/epub/12242/pg12242.txt",
|
|
"Whitman II": "https://www.gutenberg.org/cache/epub/8388/pg8388.txt",
|
|
"Rilke": "https://www.gutenberg.org/cache/epub/38594/pg38594.txt",
|
|
"Pound": "https://www.gutenberg.org/cache/epub/41162/pg41162.txt",
|
|
"Pound II": "https://www.gutenberg.org/cache/epub/51992/pg51992.txt",
|
|
"Eliot": "https://www.gutenberg.org/cache/epub/1567/pg1567.txt",
|
|
"Yeats": "https://www.gutenberg.org/cache/epub/38877/pg38877.txt",
|
|
"Masters": "https://www.gutenberg.org/cache/epub/1280/pg1280.txt",
|
|
"Baudelaire": "https://www.gutenberg.org/cache/epub/36098/pg36098.txt",
|
|
"Crane": "https://www.gutenberg.org/cache/epub/40786/pg40786.txt",
|
|
"Poe": "https://www.gutenberg.org/cache/epub/10031/pg10031.txt",
|
|
}
|
|
|
|
# ─── SOURCE → LANGUAGE MAPPING ───────────────────────────
|
|
# Headlines from these outlets render in their cultural home language
|
|
SOURCE_LANGS = {
|
|
"Der Spiegel": "de",
|
|
"DW": "de",
|
|
"France24": "fr",
|
|
"Japan Times": "ja",
|
|
"The Hindu": "hi",
|
|
"SCMP": "zh-cn",
|
|
"Al Jazeera": "ar",
|
|
}
|
|
|
|
# ─── LOCATION → LANGUAGE ─────────────────────────────────
|
|
LOCATION_LANGS = {
|
|
r"\b(?:china|chinese|beijing|shanghai|hong kong|xi jinping)\b": "zh-cn",
|
|
r"\b(?:japan|japanese|tokyo|osaka|kishida)\b": "ja",
|
|
r"\b(?:korea|korean|seoul|pyongyang)\b": "ko",
|
|
r"\b(?:russia|russian|moscow|kremlin|putin)\b": "ru",
|
|
r"\b(?:saudi|dubai|qatar|egypt|cairo|arabic)\b": "ar",
|
|
r"\b(?:india|indian|delhi|mumbai|modi)\b": "hi",
|
|
r"\b(?:germany|german|berlin|munich|scholz)\b": "de",
|
|
r"\b(?:france|french|paris|lyon|macron)\b": "fr",
|
|
r"\b(?:spain|spanish|madrid)\b": "es",
|
|
r"\b(?:italy|italian|rome|milan|meloni)\b": "it",
|
|
r"\b(?:portugal|portuguese|lisbon)\b": "pt",
|
|
r"\b(?:brazil|brazilian|são paulo|lula)\b": "pt",
|
|
r"\b(?:greece|greek|athens)\b": "el",
|
|
r"\b(?:turkey|turkish|istanbul|ankara|erdogan)\b": "tr",
|
|
r"\b(?:iran|iranian|tehran)\b": "fa",
|
|
r"\b(?:thailand|thai|bangkok)\b": "th",
|
|
r"\b(?:vietnam|vietnamese|hanoi)\b": "vi",
|
|
r"\b(?:ukraine|ukrainian|kyiv|kiev|zelensky)\b": "uk",
|
|
r"\b(?:israel|israeli|jerusalem|tel aviv|netanyahu)\b": "he",
|
|
}
|
|
|
|
# ─── NON-LATIN SCRIPT FONTS (macOS) ──────────────────────
|
|
SCRIPT_FONTS = {
|
|
"zh-cn": "/System/Library/Fonts/STHeiti Medium.ttc",
|
|
"ja": "/System/Library/Fonts/ヒラギノ角ゴシック W9.ttc",
|
|
"ko": "/System/Library/Fonts/AppleSDGothicNeo.ttc",
|
|
"ru": "/System/Library/Fonts/Supplemental/Arial.ttf",
|
|
"uk": "/System/Library/Fonts/Supplemental/Arial.ttf",
|
|
"el": "/System/Library/Fonts/Supplemental/Arial.ttf",
|
|
"he": "/System/Library/Fonts/Supplemental/Arial.ttf",
|
|
"ar": "/System/Library/Fonts/GeezaPro.ttc",
|
|
"fa": "/System/Library/Fonts/GeezaPro.ttc",
|
|
"hi": "/System/Library/Fonts/Kohinoor.ttc",
|
|
"th": "/System/Library/Fonts/ThonburiUI.ttc",
|
|
}
|
|
|
|
# Scripts that have no uppercase
|
|
NO_UPPER = {"zh-cn", "ja", "ko", "ar", "fa", "hi", "th", "he"}
|