cookiecutter-django/README.rst

111 lines
3.5 KiB
ReStructuredText
Raw Normal View History

2013-08-15 22:32:13 +04:00
cookiecutter-dj-project
=======================
A cookiecutter_ template for Django.
.. _cookiecutter: https://github.com/audreyr/cookiecutter
2013-08-16 15:03:11 +04:00
Features
---------
2013-08-16 15:35:18 +04:00
* Cutting edge: For Django 1.6 and other bleeding edge stuff
* Twitter Bootstrap 3
2013-08-16 15:03:11 +04:00
* Registration via django-allauth
* User avatars via django-avatar
2013-08-16 15:03:11 +04:00
* Procfile for deploying to Heroku
* Heroku optimized requirements
2013-08-16 15:35:18 +04:00
* Basic caching setup
Constraints
-----------
* Only maintained 3rd party libraries are used.
* PostgreSQL everywhere
2013-08-18 13:01:10 +04:00
* Environment variables for configuration (This won't work with Apache/mod_wsgi)
2013-08-16 15:03:11 +04:00
2013-08-18 16:44:28 +04:00
Usage
------
2013-08-16 15:03:11 +04:00
2013-08-18 16:46:20 +04:00
Let's pretend you want to create a Django project called "redditclone". Rather than using `startproject`
and then editing the results to include your name, email, and various configuration issues that always get forgotten until the worst possible moment, get cookiecutter_ to do all the work.
2013-08-18 16:44:28 +04:00
First, get cookiecutter. Trust me, it's awesome::
2013-08-16 15:03:11 +04:00
$ pip install cookiecutter
2013-08-18 16:44:28 +04:00
Now run it against this repo::
$ cookiecutter https://github.com/pydanny/cookiecutter-dj-project.git
You'll be prompted for some questions, answer them, then it will create a Django project for you.
**Warning**: After this point, change 'Daniel Greenfeld', 'pydanny', etc to your own information.
It prompts you for questions. Answer them::
Cloning into 'cookiecutter-dj-project'...
remote: Counting objects: 49, done.
remote: Compressing objects: 100% (33/33), done.
remote: Total 49 (delta 6), reused 48 (delta 5)
Unpacking objects: 100% (49/49), done.
full_name (default is "Your full name here")? Daniel Greenfeld
email (default is "you@example.com")? pydanny@gmail.com
project_name (default is "dj-project")? redditclone
repo_name (default is "dj_project")? redditclone
app_name (default is "djproject")? redditclone
project_short_description (default is "Your project description goes here")? A reddit clone.
release_date (default is "2013-08-15")? 2013-08-15
year (default is "2013")? 2013
version (default is "0.1.0")? 0.3.0
Enter the project and take a look around::
$ cd redditclone/
$ ls
Create a GitHub repo and push it there::
$ git init
$ git add .
$ git commit -m "first awesome commit!"
$ git remote add origin git@github.com:pydanny/redditclone.git
$ git push -u origin master
Now take a look at your repo. Awesome, right?
It's time to write the code!!!
2013-08-16 15:03:11 +04:00
2013-08-16 20:23:22 +04:00
"Your Stuff"
-------------
2013-08-17 14:38:23 +04:00
Scattered throughout the Python and HTML of this project are places marked with "your stuff". This is where third-party libraries are to be integrated with your project.
2013-08-18 22:50:39 +04:00
Not Exactly What You Want?
---------------------------
2013-08-18 22:53:55 +04:00
This is what I want. *It might not be what you want.* Don't worry, you have options:
2013-08-18 22:50:39 +04:00
Fork This
~~~~~~~~~~
If you have differences in your preferred setup, I encourage you to fork this to create your own version.
Once you have your fork working, let me know and I'll add it to a '*Similar Cookiecutter Templates*' list here.
It's up to you whether or not to rename your fork.
If you do rename your fork, I encourage you to submit it to the following places:
* cookiecutter_ so it gets listed in the README as a template.
* The cookiecutter grid_ on Django Packages.
.. _cookiecutter: https://github.com/audreyr/cookiecutter
.. _grid: https://www.djangopackages.com/grids/g/cookiecutter/
Or Submit a Pull Request
~~~~~~~~~~~~~~~~~~~~~~~~~
I also accept pull requests on this, if they're small, atomic, and if they make my own project development
experience better.