|
|
|
@ -69,41 +69,43 @@ class ContestPlayer extends Model {
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
async updateScore(judge_state) { |
|
|
|
|
await syzoj.utils.lock('ContestPlayer::updateScore', this.id); |
|
|
|
|
|
|
|
|
|
await this.loadRelationships(); |
|
|
|
|
if (this.contest.type === 'ioi') { |
|
|
|
|
if (judge_state.pending) return; |
|
|
|
|
if (!judge_state.pending) { |
|
|
|
|
if (!this.score_details[judge_state.problem_id]) { |
|
|
|
|
this.score_details[judge_state.problem_id] = { |
|
|
|
|
score: judge_state.score, |
|
|
|
|
judge_id: judge_state.id, |
|
|
|
|
submissions: {} |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (!this.score_details[judge_state.problem_id]) { |
|
|
|
|
this.score_details[judge_state.problem_id] = { |
|
|
|
|
score: judge_state.score, |
|
|
|
|
this.score_details[judge_state.problem_id].submissions[judge_state.id] = { |
|
|
|
|
judge_id: judge_state.id, |
|
|
|
|
submissions: {} |
|
|
|
|
score: judge_state.score, |
|
|
|
|
time: judge_state.submit_time |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
this.score_details[judge_state.problem_id].submissions[judge_state.id] = { |
|
|
|
|
judge_id: judge_state.id, |
|
|
|
|
score: judge_state.score, |
|
|
|
|
time: judge_state.submit_time |
|
|
|
|
}; |
|
|
|
|
let arr = Object.values(this.score_details[judge_state.problem_id].submissions); |
|
|
|
|
arr.sort((a, b) => a.time - b.time); |
|
|
|
|
|
|
|
|
|
let arr = Object.values(this.score_details[judge_state.problem_id].submissions); |
|
|
|
|
arr.sort((a, b) => a.time - b.time); |
|
|
|
|
|
|
|
|
|
let maxScoreSubmission = null; |
|
|
|
|
for (let x of arr) { |
|
|
|
|
if (!maxScoreSubmission || x.score >= maxScoreSubmission.score && maxScoreSubmission.score < 100) { |
|
|
|
|
maxScoreSubmission = x; |
|
|
|
|
let maxScoreSubmission = null; |
|
|
|
|
for (let x of arr) { |
|
|
|
|
if (!maxScoreSubmission || x.score >= maxScoreSubmission.score && maxScoreSubmission.score < 100) { |
|
|
|
|
maxScoreSubmission = x; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = maxScoreSubmission.judge_id; |
|
|
|
|
this.score_details[judge_state.problem_id].score = maxScoreSubmission.score; |
|
|
|
|
this.score_details[judge_state.problem_id].time = maxScoreSubmission.time; |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = maxScoreSubmission.judge_id; |
|
|
|
|
this.score_details[judge_state.problem_id].score = maxScoreSubmission.score; |
|
|
|
|
this.score_details[judge_state.problem_id].time = maxScoreSubmission.time; |
|
|
|
|
|
|
|
|
|
this.score = 0; |
|
|
|
|
for (let x in this.score_details) { |
|
|
|
|
this.score += this.score_details[x].score; |
|
|
|
|
this.score = 0; |
|
|
|
|
for (let x in this.score_details) { |
|
|
|
|
this.score += this.score_details[x].score; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} else if (this.contest.type === 'noi') { |
|
|
|
|
this.score_details[judge_state.problem_id] = { |
|
|
|
@ -115,49 +117,51 @@ class ContestPlayer extends Model {
|
|
|
|
|
this.score += this.score_details[x].score; |
|
|
|
|
} |
|
|
|
|
} else if (this.contest.type === 'acm') { |
|
|
|
|
if (judge_state.pending) return; |
|
|
|
|
|
|
|
|
|
if (!this.score_details[judge_state.problem_id]) { |
|
|
|
|
this.score_details[judge_state.problem_id] = { |
|
|
|
|
accepted: false, |
|
|
|
|
unacceptedCount: 0, |
|
|
|
|
acceptedTime: 0, |
|
|
|
|
judge_id: 0, |
|
|
|
|
submissions: {} |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
if (!judge_state.pending) { |
|
|
|
|
if (!this.score_details[judge_state.problem_id]) { |
|
|
|
|
this.score_details[judge_state.problem_id] = { |
|
|
|
|
accepted: false, |
|
|
|
|
unacceptedCount: 0, |
|
|
|
|
acceptedTime: 0, |
|
|
|
|
judge_id: 0, |
|
|
|
|
submissions: {} |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
this.score_details[judge_state.problem_id].submissions[judge_state.id] = { |
|
|
|
|
judge_id: judge_state.id, |
|
|
|
|
accepted: judge_state.status === 'Accepted', |
|
|
|
|
time: judge_state.submit_time |
|
|
|
|
}; |
|
|
|
|
this.score_details[judge_state.problem_id].submissions[judge_state.id] = { |
|
|
|
|
judge_id: judge_state.id, |
|
|
|
|
accepted: judge_state.status === 'Accepted', |
|
|
|
|
time: judge_state.submit_time |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
let arr = Object.values(this.score_details[judge_state.problem_id].submissions); |
|
|
|
|
arr.sort((a, b) => a.time - b.time); |
|
|
|
|
|
|
|
|
|
this.score_details[judge_state.problem_id].unacceptedCount = 0; |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = 0; |
|
|
|
|
for (let x of arr) { |
|
|
|
|
if (x.accepted) { |
|
|
|
|
this.score_details[judge_state.problem_id].accepted = true; |
|
|
|
|
this.score_details[judge_state.problem_id].acceptedTime = x.time; |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = x.judge_id; |
|
|
|
|
break; |
|
|
|
|
} else { |
|
|
|
|
this.score_details[judge_state.problem_id].unacceptedCount++; |
|
|
|
|
let arr = Object.values(this.score_details[judge_state.problem_id].submissions); |
|
|
|
|
arr.sort((a, b) => a.time - b.time); |
|
|
|
|
|
|
|
|
|
this.score_details[judge_state.problem_id].unacceptedCount = 0; |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = 0; |
|
|
|
|
for (let x of arr) { |
|
|
|
|
if (x.accepted) { |
|
|
|
|
this.score_details[judge_state.problem_id].accepted = true; |
|
|
|
|
this.score_details[judge_state.problem_id].acceptedTime = x.time; |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = x.judge_id; |
|
|
|
|
break; |
|
|
|
|
} else { |
|
|
|
|
this.score_details[judge_state.problem_id].unacceptedCount++; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (!this.score_details[judge_state.problem_id].accepted) { |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = arr[arr.length - 1].judge_id; |
|
|
|
|
} |
|
|
|
|
if (!this.score_details[judge_state.problem_id].accepted) { |
|
|
|
|
this.score_details[judge_state.problem_id].judge_id = arr[arr.length - 1].judge_id; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
this.score = 0; |
|
|
|
|
for (let x in this.score_details) { |
|
|
|
|
if (this.score_details[x].accepted) this.score++; |
|
|
|
|
this.score = 0; |
|
|
|
|
for (let x in this.score_details) { |
|
|
|
|
if (this.score_details[x].accepted) this.score++; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
syzoj.utils.unlock('ContestPlayer::updateScore', this.id); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
getModel() { return model; } |
|
|
|
|