Documentation ¶
Overview ¶
Package models defines all the data models used in the database, as well as methods to acquire and modify them.
Index ¶
- func (r *Problem) AdminLink() string
- func BatchAddUsers(db db.DBContext, reset bool, users ...*User) error
- func BatchInsertJobs(db db.DBContext, jobs ...*Job) error
- func CollectUserProblemResults(db db.DBContext, userID string, problems []*Problem) (map[int]*ProblemResult, error)
- func (t *TestGroup) DeleteResults(db db.DBContext) error
- func GetProblemByName(db db.DBContext, contestID int, name string) (*Problem, error)
- func (r *TestGroup) Hidden() bool
- func (r *Problem) Link() string
- func RejudgeCompile(db db.DBContext, subIDs ...int) error
- func RejudgeRun(db db.DBContext, subIDs ...int) error
- func RejudgeScore(db db.DBContext, subIDs ...int) error
- func (r *Problem) Verify() error
- func (p *Problem) WriteFiles(db db.DBContext, files []*File) error
- type Config
- type ContestType
- type JSONProblem
- type JSONProblemResult
- type JSONScoreboard
- type JSONUserResult
- type JobType
- type Language
- type PenaltyPolicy
- type ProblemWithTestGroups
- type QueueOverview
- type Scoreboard
- type ScoreboardViewStatus
- type ScoringMode
- type TestGroupWithTests
- type TestScoringMode
- type UserResult
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func (*Problem) AdminLink ¶ added in v0.6.0
func (r *Problem) AdminLink() string
AdminLink is the link to the problem in the admin panel.
func BatchAddUsers ¶
BatchAddUsers adds users in batch.
func BatchInsertJobs ¶
BatchInsertJobs try to insert all given jobs.
func CollectUserProblemResults ¶
func CollectUserProblemResults(db db.DBContext, userID string, problems []*Problem) (map[int]*ProblemResult, error)
CollectProblemResults collects an user's problem results for a contest. The result map's key is the problem ID.
func (*TestGroup) DeleteResults ¶
DeleteResults deletes all test results of a given test group.
func GetProblemByName ¶
GetProblemByName gets a Problem from the Database by its name and contest.
func (*TestGroup) Hidden ¶
func (r *TestGroup) Hidden() bool
Hidden returns whether the test group is hidden.
func (*Problem) Link ¶ added in v0.6.0
func (r *Problem) Link() string
Link is the link to the problem.
func RejudgeCompile ¶
RejudgeCompile re-compiles all submissions given.
func RejudgeRun ¶
RejudgeRun re-runs all tests for the submissions given.
func RejudgeScore ¶
RejudgeScore re-scores all submissions given.
func (*Problem) WriteFiles ¶
WriteFiles writes the given files as brand new, overwritting the old ones. Note that because of overwritting behaviour, we cannot ensure the validity of the indicies, hence they are not reflected into the *Files.
Types ¶
type Config ¶
type Config struct { SessionKey []byte `db:"session_key"` EnableRegistration bool `db:"enable_registration"` EnableUserCustomization bool `db:"enable_user_customization"` }
Config is the configuation of the server.
func GenerateConfig ¶
GenerateConfig generates a random configuration.
type ContestType ¶
type ContestType string
ContestType is the enum representing the contest type. The contest type determines ONLY how the scoreboard is rendered.
const ( // The contestants are sorted by number of "solved" problems, then by total penalty. ContestTypeUnweighted ContestType = "unweighted" // Problems each have different scores, and penalty only serves as tiebreakers. ContestTypeWeighted ContestType = "weighted" )
type JSONProblem ¶
type JSONProblem struct { ID int `json:"id"` Name string `json:"name"` DisplayName string `json:"display_name"` }
JSONProblem represents a JSON encoded problem metadata.
type JSONProblemResult ¶
type JSONProblemResult struct { Score float64 `json:"score"` Solved bool `json:"solved"` Penalty int `json:"penalty"` FailedAttempts int `json:"failed_attempts"` BestSubmission int64 `json:"best_submission"` }
JSONProblemResult represents a JSON encoded user's result of a problem in the scoreboard.
type JSONScoreboard ¶
type JSONScoreboard struct { ContestID int `json:"contest_id"` ContestType ContestType `json:"contest_type"` Problems []JSONProblem `json:"problems"` Users []JSONUserResult `json:"users"` ProblemFirstSolvers map[int]int64 `json:"problem_first_solvers"` }
JSONScoreboard represents a JSON encoded scoreboard.
type JSONUserResult ¶
type JSONUserResult struct { ID string `json:"id"` DisplayName string `json:"display_name"` Organization string `json:"organization,omitempty"` Rank int `json:"rank"` TotalPenalty int `json:"total_penalty"` SolvedProblems int `json:"solved_problems"` TotalScore float64 `json:"total_score"` ProblemResults map[int]JSONProblemResult `json:"problem_results"` }
JSONUserResult represents a JSON encoded user in the scoreboard.
type JobType ¶
type JobType string
JobType determines the type of the job. This can be: - Compile: highest priority. Compiles a submission into executable bytecode. - Test: run a test. - Score: recalculate the score.
type Language ¶
type Language string
Language represents the language of the submission. The available values depend on the machine the judge is run on.
func LanguageByExt ¶
LanguageByExt returns a language based on the file extension.
type PenaltyPolicy ¶
type PenaltyPolicy string
PenaltyPolicy dictates how the penalty is calculated. There are: - None: no penalty at all (IOI - like). - SubmitTime: minutes passed from the start of the contest, of the submission time. - ICPC: SubmitTime + 20 * (# of past submissions)
const ( PenaltyPolicyNone PenaltyPolicy = "none" PenaltyPolicySubmitTime PenaltyPolicy = "submit_time" PenaltyPolicyICPC PenaltyPolicy = "icpc" )
Defined values for PenaltyPolicy.
type ProblemWithTestGroups ¶
type ProblemWithTestGroups struct { *Problem TestGroups []*TestGroup }
ProblemWithTestGroups is a problem with attached test groups, that will provide score-related statistics.
func CollectTestGroups ¶
func CollectTestGroups(db db.DBContext, problems []*Problem, private bool) ([]*ProblemWithTestGroups, error)
CollectTestGroups collects the test groups for a list of problems.
func (*ProblemWithTestGroups) SubtaskScores ¶
func (p *ProblemWithTestGroups) SubtaskScores() string
SubtaskScores returns the problem's test group scores as a list seperated by forward slash.
func (*ProblemWithTestGroups) TotalScore ¶
func (p *ProblemWithTestGroups) TotalScore() float64
TotalScore returns the problem's maximal total score.
type QueueOverview ¶
QueueOverview gives overview information about the queue of jobs.
func GetQueueOverview ¶
func GetQueueOverview(db db.DBContext) (*QueueOverview, error)
GetQueueOverview gets the current queue overview.
func (*QueueOverview) Total ¶
func (q *QueueOverview) Total() int
Total returns the sum of all queue counts.
type Scoreboard ¶
type Scoreboard struct { Contest *Contest Problems []*Problem UserResults []*UserResult ProblemFirstSolvers map[int]int64 }
Scoreboard is the struct used to render scoreboard
func GetScoreboard ¶
func GetScoreboard(db db.DBContext, contest *Contest, problems []*Problem) (*Scoreboard, error)
Get scoreboard given problems and contest
func (*Scoreboard) CSV ¶
func (s *Scoreboard) CSV(w io.Writer) error
CSV returns the CSV version of the scoreboard, with scores and penalties.
func (*Scoreboard) CSVScoresOnly ¶
func (s *Scoreboard) CSVScoresOnly(w io.Writer) error
CSVScoresOnly returns the CSV version of the scoreboard, with only scores.
func (*Scoreboard) JSON ¶
func (s *Scoreboard) JSON() JSONScoreboard
JSON returns the JSON representation of the scoreboard.
type ScoreboardViewStatus ¶
type ScoreboardViewStatus string
ScoreboardViewStatus is the enum representing the scoreboard view status. scoreboard view status type determines how the scoreboard is accessed.
const ( // This allowes everyone to see the scoreboard ScoreboardViewStatusPublic ScoreboardViewStatus = "public" // This only allowes registered users to see the scoreboard ScoreboardViewStatusUser ScoreboardViewStatus = "user" // There is no scoreboard rendered during the contest ScoreboardViewStatusNoScoreboard ScoreboardViewStatus = "no_scoreboard" )
type ScoringMode ¶
type ScoringMode string
ScoringMode dictates how the best submission is chosen. There are: - Min: The submission with the lowest score is chosen. If on a tie, choose the one with the highest penalty - Best: The submission with the highest score is chosen. If on a tie, choose the one with lowest penalty. - Once: The first (successfully compiled) submission is the best one. - Last: The last submission is the best one. - Decay: The last submission is the best one. The score is modified by the number of submissions before it (0.1 * count), and the time passed (0.7 * time passed in %), to a minimum of 0.3 times the original.
const ( ScoringModeMin ScoringMode = "min" ScoringModeBest ScoringMode = "best" ScoringModeOnce ScoringMode = "once" ScoringModeLast ScoringMode = "last" ScoringModeDecay ScoringMode = "decay" )
Defined values for ScoringMode.
type TestGroupWithTests ¶
type TestGroupWithTests struct { *TestGroup Tests []*Test }
TestGroupWithTests are wrapped test groups with tests included.
func GetProblemTests ¶
func GetProblemTests(db db.DBContext, problemID int) ([]*TestGroupWithTests, error)
GetProblemTests collects test groups and tests from a problem.
func GetProblemTestsMeta ¶
func GetProblemTestsMeta(db db.DBContext, problemID int) ([]*TestGroupWithTests, error)
GetProblemTestsMeta is like GetProblemTests, but inputs and outputs are not included.
func (*TestGroupWithTests) ComputeScore ¶
func (tg *TestGroupWithTests) ComputeScore(results map[int]*TestResult) float64
ComputeScore returns the score of a test group (with tests), given the test results.
type TestScoringMode ¶
type TestScoringMode string
TestScoringMode determines how the score of each test in the group adds up to the total of the group. The schemes are: - Sum: Each test has an equal weight and the score of the group is (sum of test scores / # of tests) * (group score) - Min: The score of the group = min(score of each test) * (group score) - Product: Score of the group = product(score of each test) * (group score)
const ( TestScoringModeSum TestScoringMode = "sum" TestScoringModeMin TestScoringMode = "min" TestScoringModeProduct TestScoringMode = "product" )
All possible values of TestScoringMode.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Command "generate-models" reads the model information from the "models/models.json" file, and generate the relevant "models/generated.go" file.
|
Command "generate-models" reads the model information from the "models/models.json" file, and generate the relevant "models/generated.go" file. |
Package verify implements certain verification methods for simple data structures.
|
Package verify implements certain verification methods for simple data structures. |