2016-09-25 09:00:52 +00:00
|
|
|
from django.db import models
|
2017-01-23 08:48:04 +00:00
|
|
|
from jsonfield import JSONField
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
from account.models import User
|
2017-02-17 12:14:03 +00:00
|
|
|
from contest.models import Contest
|
2016-09-25 09:00:52 +00:00
|
|
|
from utils.models import RichTextField
|
|
|
|
|
|
|
|
|
|
|
|
class ProblemTag(models.Model):
|
|
|
|
name = models.CharField(max_length=30)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table = "problem_tag"
|
|
|
|
|
|
|
|
|
2017-02-02 08:59:15 +00:00
|
|
|
class ProblemRuleType(object):
|
|
|
|
ACM = "ACM"
|
|
|
|
OI = "OI"
|
|
|
|
|
|
|
|
|
2017-05-01 05:03:48 +00:00
|
|
|
class ProblemDifficulty(object):
|
|
|
|
High = "High"
|
|
|
|
Mid = "Mid"
|
|
|
|
Low = "Low"
|
|
|
|
|
|
|
|
|
2016-09-25 09:00:52 +00:00
|
|
|
class AbstractProblem(models.Model):
|
2017-02-02 08:59:15 +00:00
|
|
|
title = models.CharField(max_length=128)
|
2016-09-25 09:00:52 +00:00
|
|
|
# HTML
|
|
|
|
description = RichTextField()
|
2017-02-02 08:59:15 +00:00
|
|
|
input_description = RichTextField()
|
|
|
|
output_description = RichTextField()
|
2016-09-25 09:00:52 +00:00
|
|
|
# [{input: "test", output: "123"}, {input: "test123", output: "456"}]
|
2017-02-02 08:59:15 +00:00
|
|
|
samples = JSONField()
|
|
|
|
test_case_id = models.CharField(max_length=32)
|
|
|
|
test_case_score = JSONField()
|
2016-09-25 09:00:52 +00:00
|
|
|
hint = RichTextField(blank=True, null=True)
|
2017-02-02 08:59:15 +00:00
|
|
|
languages = JSONField()
|
2017-02-06 07:46:17 +00:00
|
|
|
template = JSONField()
|
2016-09-25 09:00:52 +00:00
|
|
|
create_time = models.DateTimeField(auto_now_add=True)
|
|
|
|
# we can not use auto_now here
|
|
|
|
last_update_time = models.DateTimeField(blank=True, null=True)
|
|
|
|
created_by = models.ForeignKey(User)
|
|
|
|
# ms
|
|
|
|
time_limit = models.IntegerField()
|
|
|
|
# MB
|
|
|
|
memory_limit = models.IntegerField()
|
|
|
|
# special judge related
|
|
|
|
spj = models.BooleanField(default=False)
|
2017-02-02 08:59:15 +00:00
|
|
|
spj_language = models.CharField(max_length=32, blank=True, null=True)
|
2016-09-25 09:00:52 +00:00
|
|
|
spj_code = models.TextField(blank=True, null=True)
|
|
|
|
spj_version = models.CharField(max_length=32, blank=True, null=True)
|
2017-02-02 08:59:15 +00:00
|
|
|
rule_type = models.CharField(max_length=32)
|
2016-09-25 09:00:52 +00:00
|
|
|
visible = models.BooleanField(default=True)
|
2017-02-02 08:59:15 +00:00
|
|
|
difficulty = models.CharField(max_length=32)
|
|
|
|
tags = models.ManyToManyField(ProblemTag)
|
|
|
|
source = models.CharField(max_length=200, blank=True, null=True)
|
2017-08-26 00:41:29 +00:00
|
|
|
submission_number = models.BigIntegerField(default=0)
|
|
|
|
accepted_number = models.BigIntegerField(default=0)
|
2017-08-15 13:05:41 +00:00
|
|
|
# {0: 0, 1: 0, 2: 0, 3: 0 ...}
|
|
|
|
# the first number means JudgeStatus, the second number present count
|
|
|
|
statistic_info = JSONField(default={})
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table = "problem"
|
|
|
|
abstract = True
|
|
|
|
|
|
|
|
def add_submission_number(self):
|
2017-08-26 00:41:29 +00:00
|
|
|
self.submission_number = models.F("submission_number") + 1
|
|
|
|
self.save(update_fields=["submission_number"])
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
def add_ac_number(self):
|
2017-08-26 00:41:29 +00:00
|
|
|
self.accepted_number = models.F("accepted_number") + 1
|
|
|
|
self.save(update_fields=["accepted_number"])
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Problem(AbstractProblem):
|
2017-02-09 08:47:08 +00:00
|
|
|
_id = models.CharField(max_length=24, unique=True, db_index=True)
|
2017-02-17 12:14:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ContestProblem(AbstractProblem):
|
|
|
|
_id = models.CharField(max_length=24, db_index=True)
|
|
|
|
contest = models.ForeignKey(Contest)
|
|
|
|
# 是否已经公开了题目,防止重复公开
|
|
|
|
is_public = models.BooleanField(default=False)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table = "contest_problem"
|
2017-05-01 05:03:48 +00:00
|
|
|
unique_together = (("_id", "contest"),)
|