Skip to content

Commit

Permalink
Django stuff
Browse files Browse the repository at this point in the history
  • Loading branch information
Freddie committed Jul 5, 2010
1 parent da0fa2b commit 20cb869
Show file tree
Hide file tree
Showing 9 changed files with 211 additions and 0 deletions.
Empty file added __init__.py
Empty file.
Empty file added blueprints/__init__.py
Empty file.
5 changes: 5 additions & 0 deletions blueprints/admin.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
from everdi.blueprints.models import BlueprintCopy, Character
from django.contrib import admin

admin.site.register(Character)
admin.site.register(BlueprintCopy)
58 changes: 58 additions & 0 deletions blueprints/models.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
from django.db import models


class Region(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=30)

def __unicode__(self):
return self.name

class Item(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=50)

def __unicode__(self):
return self.name

class ItemPrice(models.Model):
item = models.ForeignKey(Item)
region = models.ForeignKey(Region)
sell_price = models.DecimalField(max_digits=15, decimal_places=2)
sell_volume = models.IntegerField()
buy_price = models.DecimalField(max_digits=15, decimal_places=2)
buy_volume = models.IntegerField()

class Blueprint(models.Model):
id = models.IntegerField(primary_key=True)
#item_id = models.ForeignKey(Item)
components = models.ManyToManyField(Item, through='BlueprintComponent')

production_time = models.IntegerField()
waste_factor = models.IntegerField()

def __unicode__(self):
return self.name

class BlueprintComponent(models.Model):
item = models.ForeignKey(Item)
blueprint = models.ForeignKey(Blueprint)
count = models.IntegerField()

class BlueprintCopy(models.Model):
blueprint = models.ForeignKey(Blueprint)
material_level = models.IntegerField()
productivity_level = models.IntegerField()

class Character(models.Model):
name = models.CharField(max_length=30)
api_key = models.CharField(max_length=64)
industry_skill = models.IntegerField()
production_efficiency_skill = models.IntegerField()
factory_cost = models.DecimalField(max_digits=8, decimal_places=2)
factory_per_hour = models.DecimalField(max_digits=8, decimal_places=2)
sales_tax = models.DecimalField(max_digits=4, decimal_places=2)
brokers_fee = models.DecimalField(max_digits=4, decimal_places=2)

def __unicode__(self):
return self.name
23 changes: 23 additions & 0 deletions blueprints/tests.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
"""
This file demonstrates two different styles of tests (one doctest and one
unittest). These will both pass when you run "manage.py test".
Replace these with more appropriate tests for your application.
"""

from django.test import TestCase

class SimpleTest(TestCase):
def test_basic_addition(self):
"""
Tests that 1 + 1 always equals 2.
"""
self.failUnlessEqual(1 + 1, 2)

__test__ = {"doctest": """
Another way to test that 1 + 1 is equal to 2.
>>> 1 + 1 == 2
True
"""}

1 change: 1 addition & 0 deletions blueprints/views.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Create your views here.
11 changes: 11 additions & 0 deletions manage.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#!/usr/bin/env python
from django.core.management import execute_manager
try:
import settings # Assumed to be in the same directory.
except ImportError:
import sys
sys.stderr.write("Error: Can't find the file 'settings.py' in the directory containing %r. It appears you've customized things.\nYou'll have to run django-admin.py, passing it your settings module.\n(If the file settings.py does indeed exist, it's causing an ImportError somehow.)\n" % __file__)
sys.exit(1)

if __name__ == "__main__":
execute_manager(settings)
96 changes: 96 additions & 0 deletions settings.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
# Django settings for everdi project.

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
('Freddie', '[email protected]'),
)

MANAGERS = ADMINS

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2', # Add 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
'NAME': 'everdi', # Or path to database file if using sqlite3.
'USER': 'freddie', # Not used with sqlite3.
'PASSWORD': '', # Not used with sqlite3.
'HOST': '', # Set to empty string for localhost. Not used with sqlite3.
'PORT': '', # Set to empty string for default. Not used with sqlite3.
}
}

# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# On Unix systems, a value of None will cause Django to use the same
# timezone as the operating system.
# If running in a Windows environment this must be set to the same as your
# system time zone.
TIME_ZONE = None

# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'

SITE_ID = 1

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = False

# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale
USE_L10N = True

# Absolute path to the directory that holds media.
# Example: "/home/media/media.lawrence.com/"
MEDIA_ROOT = ''

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash if there is a path component (optional in other cases).
# Examples: "http://media.lawrence.com", "http://example.com/media/"
MEDIA_URL = ''

# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: "http://foo.com/media/", "/media/".
ADMIN_MEDIA_PREFIX = '/media/'

# Make this unique, and don't share it with anybody.
SECRET_KEY = ')%)w42n83ndwvlrnj99-77@e0)(kcs!$zd%#pcy0&e5x0kwq01'

# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
# 'django.template.loaders.eggs.Loader',
)

MIDDLEWARE_CLASSES = (
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
)

ROOT_URLCONF = 'everdi.urls'

TEMPLATE_DIRS = (
# Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
# Always use forward slashes, even on Windows.
# Don't forget to use absolute paths, not relative paths.
)

INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
# Uncomment the next line to enable the admin:
'django.contrib.admin',
'django.contrib.admindocs',
'everdi.blueprints',
)
17 changes: 17 additions & 0 deletions urls.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
from django.conf.urls.defaults import *

# Uncomment the next two lines to enable the admin:
from django.contrib import admin
admin.autodiscover()

urlpatterns = patterns('',
# Example:
# (r'^everdi/', include('everdi.foo.urls')),

# Uncomment the admin/doc line below and add 'django.contrib.admindocs'
# to INSTALLED_APPS to enable admin documentation:
(r'^admin/doc/', include('django.contrib.admindocs.urls')),

# Uncomment the next line to enable the admin:
(r'^admin/', include(admin.site.urls)),
)

0 comments on commit 20cb869

Please sign in to comment.