116 lines
5.8 KiB
Python
116 lines
5.8 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'}
|