This repository is private.
All pages are served over SSL and all pushing and pulling is done over SSH.
No one may fork, clone, or view it unless they are added as a member.
Every repository with this icon (
) is private.
Every repository with this icon (
This repository is public.
Anyone may fork, clone, or view it.
Every repository with this icon (
) is public.
Every repository with this icon (
commit 158c512328937b473f54a8322cf34bb6a3ec0b81
tree a4b0e82d3a17fef0b13a23541274321bfad419d4
parent 8d1fd016351ad811ce26fc69757e5f9764d58aa1 parent 4e118a8971df9678057c2d109b1a4f2e2a4817cb
tree a4b0e82d3a17fef0b13a23541274321bfad419d4
parent 8d1fd016351ad811ce26fc69757e5f9764d58aa1 parent 4e118a8971df9678057c2d109b1a4f2e2a4817cb
djng /
| name | age | message | |
|---|---|---|---|
| |
LICENSE.txt | ||
| |
djng/ | ||
| |
djng_old.py | Sat May 09 04:24:11 -0700 2009 | |
| |
example_forms.py | Tue May 12 11:02:36 -0700 2009 | |
| |
example_hello.py | Mon May 11 10:27:12 -0700 2009 | |
| |
example_middleware.py | Mon May 18 01:46:30 -0700 2009 | |
| |
example_rest_view.py | Tue May 12 01:44:18 -0700 2009 | |
| |
example_services_incomplete.py | Mon May 11 11:17:13 -0700 2009 | |
| |
example_urls.py | ||
| |
planned_services.txt | Thu May 14 04:16:51 -0700 2009 | |
| |
readme.txt | ||
| |
services_api_ideas.txt | Mon May 18 10:17:31 -0700 2009 | |
| |
setup.py |
readme.txt
djng ==== (pronounced "djing", with a mostly-silent "d") Blog entry: http://simonwillison.net/2009/May/19/djng/ Mailing list: http://groups.google.com/group/djng djng is a micro-framework that depends on a macro-framework (Django). My definition of a micro-framework: something that lets you create an entire Python web application in a single module: import djng def index(request): return djng.Response('Hello, world') if __name__ == '__main__': djng.serve(index, '0.0.0.0', 8888) Or if you want hello and goodbye URLs, and a custom 404 page: import djng app = djng.ErrorWrapper( djng.Router( (r'^hello$', lambda request: djng.Response('Hello, world')), (r'^goodbye$', lambda request: djng.Response('Goodbye, world')), ), custom_404 = lambda request: djng.Response('404 error', status=404), custom_500 = lambda request: djng.Response('500 error', status=500) ) if __name__ == '__main__': djng.serve(app, '0.0.0.0', 8888) Under the hood, djng will re-use large amounts of functionality from Django, while re-imagining various aspects of the framework. A djng request object is a Django HttpRequest object; a djng response object is a Django HttpResponse. Django's template language and ORM will be available. Ideally, Django code will run almost entirely unmodified under djng, and vice versa. Services, not Settings ====================== I dislike Django's settings.py file - I often find I want to reconfigure settings at run-time, and I'm not comfortable with having arbitrary settings for so many different aspects of the framework. djng experiments with /services/ in place of settings. Services are bits of shared functionality that djng makes available to applications - for example, caching, templating, ORM-ing and mail-sending. Most of the stuff that Django sets up in settings.py will in djng be set up by configuring services. These services will be designed to be reconfigured at run-time, using a mechanism similar to Django middleware. Some things that live in settings.py that really don't belong there - middleware for example. These will generally be constructed by composing together a djng application in code. I'm still figuring out how the syntax for services should work.








