- Create Economist SubmissionTracking package correctly: * mainArticle = full blog post content * coverLetter = 216-word SIR— letter * Links to blog post via blogPostId - Archive 'Letter to The Economist' from blog posts (it's the cover letter) - Fix date display on article cards (use published_at) - Target publication already displaying via blue badge Database changes: - Make blogPostId optional in SubmissionTracking model - Economist package ID: 68fa85ae49d4900e7f2ecd83 - Le Monde package ID: 68fa2abd2e6acd5691932150 Next: Enhanced modal with tabs, validation, export 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
27 lines
682 B
Python
27 lines
682 B
Python
""" Exports a no-op 'cython' namespace similar to
|
|
https://github.com/cython/cython/blob/master/Cython/Shadow.py
|
|
|
|
This allows to optionally compile @cython decorated functions
|
|
(when cython is available at built time), or run the same code
|
|
as pure-python, without runtime dependency on cython module.
|
|
|
|
We only define the symbols that we use. E.g. see fontTools.cu2qu
|
|
"""
|
|
|
|
from types import SimpleNamespace
|
|
|
|
|
|
def _empty_decorator(x):
|
|
return x
|
|
|
|
|
|
compiled = False
|
|
|
|
for name in ("double", "complex", "int"):
|
|
globals()[name] = None
|
|
|
|
for name in ("cfunc", "inline"):
|
|
globals()[name] = _empty_decorator
|
|
|
|
locals = lambda **_: _empty_decorator
|
|
returns = lambda _: _empty_decorator
|