本文整理汇总了Golang中GoOnlineJudge/model.SolutionModel类的典型用法代码示例。如果您正苦于以下问题:Golang SolutionModel类的具体用法?Golang SolutionModel怎么用?Golang SolutionModel使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了SolutionModel类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: List
func (this *RanklistController) List(w http.ResponseWriter, r *http.Request) {
class.Logger.Debug("RankList")
this.InitContest(w, r)
qry := make(map[string]string)
qry["module"] = strconv.Itoa(config.ModuleC)
qry["mid"] = strconv.Itoa(this.Cid)
qry["/sort"] = "resort"
solutionModel := model.SolutionModel{}
solutionList, err := solutionModel.List(qry)
if err != nil {
http.Error(w, err.Error(), 400)
return
}
UserMap := make(map[string]*userRank)
var pro *probleminfo
var user *userRank
for _, v := range solutionList {
user = UserMap[v.Uid]
if user == nil {
user = &userRank{}
UserMap[v.Uid] = user
user.ProblemList = make([]*probleminfo, len(this.Index), len(this.Index))
}
user.Uid = v.Uid
pid := this.Index[v.Pid]
pro = user.ProblemList[pid]
if pro == nil {
pro = &probleminfo{}
user.ProblemList[pid] = pro
}
if pro.Judge == config.JudgeAC {
continue
}
pro.Pid = pid
if v.Judge != config.JudgeAC && v.Judge != config.JudgePD && v.Judge != config.JudgeRJ {
pro.Count++
pro.Time += 20 * 60 //罚时20分钟
} else if v.Judge == config.JudgeAC {
pro.Time += v.Create - this.ContestDetail.Start
pro.Judge = config.JudgeAC
user.Time += pro.Time
user.Solved += 1
}
}
UserList := newSorter(UserMap)
sort.Sort(UserList)
this.Data["UserList"] = UserList
this.Data["IsContestRanklist"] = true
this.Data["Cid"] = this.Cid
this.Data["ProblemList"] = this.Index
err = this.Execute(w, "view/layout.tpl", "view/contest/ranklist.tpl")
if err != nil {
http.Error(w, "tpl error", 500)
return
}
return
}
示例2: List
func (this *StatusController) List(w http.ResponseWriter, r *http.Request) {
class.Logger.Debug("Contest Status List")
this.InitContest(w, r)
solutionModel := model.SolutionModel{}
qry := make(map[string]string)
qry["module"] = strconv.Itoa(config.ModuleC)
qry["mid"] = strconv.Itoa(this.Cid)
solutionList, err := solutionModel.List(qry)
if err != nil {
http.Error(w, "load error", 400)
return
}
for i, v := range solutionList {
solutionList[i].Pid = this.Index[v.Pid]
}
this.Data["Solution"] = solutionList
this.Data["Privilege"] = this.Privilege
this.Data["IsContestStatus"] = true
err = this.Execute(w, "view/layout.tpl", "view/contest/status_list.tpl")
if err != nil {
http.Error(w, "tpl error", 500)
return
}
}
示例3: Code
//@URL: /contests/(\d+)/status/(\d+)/code @method:GET
func (sc *ContestStatus) Code(Cid string, Sid string) {
restweb.Logger.Debug("Status Code")
sc.InitContest(Cid)
sid, err := strconv.Atoi(Sid)
if err != nil {
sc.Error("args error", 400)
return
}
solutionModel := model.SolutionModel{}
one, err := solutionModel.Detail(sid)
if err != nil {
sc.Error(err.Error(), 500)
return
}
if one.Error != "" {
one.Code += "\n/*\n" + one.Error + "\n*/"
}
if one.Uid == sc.Uid || sc.Privilege >= config.PrivilegeTC {
sc.Output["Solution"] = one
sc.Output["Privilege"] = sc.Privilege
sc.Output["Title"] = "View Code"
sc.Output["IsCode"] = true
sc.Output["Pid"] = sc.Index[one.Pid]
sc.RenderTemplate("view/layout.tpl", "view/contest/status_code.tpl")
} else {
sc.Err400("Warning", "You can't see it!")
}
}
示例4: Code
func (this *StatusController) Code(w http.ResponseWriter, r *http.Request) {
class.Logger.Debug("Status Code")
this.Init(w, r)
this.InitContest(w, r)
args := this.ParseURL(r.URL.String())
sid, err := strconv.Atoi(args["sid"])
if err != nil {
http.Error(w, "args error", 400)
return
}
solutionModel := model.SolutionModel{}
one, err := solutionModel.Detail(sid)
if err != nil {
http.Error(w, err.Error(), 500)
return
}
if one.Uid == this.Uid || this.Privilege > config.PrivilegeTC {
this.Data["Solution"] = one
this.Data["Privilege"] = this.Privilege
this.Data["Title"] = "View Code"
this.Data["IsCode"] = true
err = this.Execute(w, "view/layout.tpl", "view/contest/status_code.tpl")
if err != nil {
class.Logger.Debug(err)
http.Error(w, "tpl error", 500)
return
}
}
}
示例5: Detail
func (this *UserController) Detail(w http.ResponseWriter, r *http.Request) {
class.Logger.Debug("User Detail")
this.Init(w, r)
args := this.ParseURL(r.URL.String())
uid := args["uid"]
userModel := model.UserModel{}
one, err := userModel.Detail(uid)
if err != nil {
http.Error(w, err.Error(), 400)
return
}
this.Data["Detail"] = one
solutionModle := model.SolutionModel{}
solvedList, err := solutionModle.Achieve(uid)
if err != nil {
http.Error(w, err.Error(), 400)
return
}
this.Data["List"] = solvedList
//class.Logger.Debug(solvedList)
this.Data["Title"] = "User Detail"
if uid != "" && uid == this.Uid {
this.Data["IsSettings"] = true
this.Data["IsSettingsDetail"] = true
}
err = this.Execute(w, "view/layout.tpl", "view/user_detail.tpl")
if err != nil {
http.Error(w, err.Error(), 500)
return
}
}
示例6: Code
//@URL: /status/code @method: GET
func (sc *StatusController) Code() {
restweb.Logger.Debug("Status Code")
sid, err := strconv.Atoi(sc.Input.Get("sid"))
if err != nil {
http.Error(sc.W, "args error", 400)
return
}
solutionModel := model.SolutionModel{}
one, err := solutionModel.Detail(sid)
if err != nil {
http.Error(sc.W, err.Error(), 400)
return
}
if one.Error != "" {
one.Code = one.Code + "\n/*\n" + one.Error + "*/\n"
}
if one.Uid == sc.Uid || sc.Privilege > config.PrivilegePU || one.Share {
sc.Output["Solution"] = one
sc.Output["Title"] = "View Code"
sc.Output["IsCode"] = true
sc.RenderTemplate("view/layout.tpl", "view/status_code.tpl")
} else {
sc.Err400("Warning", "You can't see it!")
}
}
示例7: GetCount
func (this *Contest) GetCount(qry map[string]string) (int, error) {
if qry == nil {
qry = make(map[string]string)
}
qry["module"] = strconv.Itoa(config.ModuleC)
qry["mid"] = strconv.Itoa(this.Cid)
solutionModel := model.SolutionModel{}
count, err := solutionModel.Count(qry)
if err != nil {
return 0, err
}
return count, nil
}
示例8: Init
func (s *solution) Init(info Info) {
logger.Println(info)
solutionModel := model.SolutionModel{}
sol, err := solutionModel.Detail(info.Sid)
if err != nil {
logger.Println(err)
return
}
s.Solution = *sol
s.OJ = info.OJ
s.Vid = info.Pid
}
示例9: ranklist
//ranklist 实时计算排名
func (rc *ContestRanklist) ranklist() UserSorter {
qry := make(map[string]string)
qry["module"] = strconv.Itoa(config.ModuleC)
qry["mid"] = strconv.Itoa(rc.Cid)
qry["sort"] = "resort"
solutionModel := model.SolutionModel{}
solutionList, err := solutionModel.List(qry)
if err != nil {
restweb.Logger.Debug(err)
return nil
}
UserMap := make(map[string]*userRank)
var pro *probleminfo
var user *userRank
for _, v := range solutionList {
user = UserMap[v.Uid]
if user == nil {
user = &userRank{}
UserMap[v.Uid] = user
user.ProblemList = make([]*probleminfo, len(rc.Index), len(rc.Index))
}
user.Uid = v.Uid
pid := rc.Index[v.Pid]
pro = user.ProblemList[pid]
if pro == nil {
pro = &probleminfo{}
user.ProblemList[pid] = pro
}
if pro.Judge == config.JudgeAC {
continue
}
pro.Pid = pid
if v.Judge != config.JudgeAC && v.Judge != config.JudgePD && v.Judge != config.JudgeRJ && v.Judge != config.JudgeNA {
pro.Count++
pro.Time += 20 * 60 //罚时20分钟
} else if v.Judge == config.JudgeAC {
user.Time += pro.Time
pro.Time = v.Create - rc.ContestDetail.Start
pro.Judge = config.JudgeAC
user.Time += pro.Time
user.Solved += 1
}
}
UserList := newSorter(UserMap)
sort.Sort(UserList)
return UserList
}
示例10: Detail
//@URL: /users/(.+) @method: GET
func (uc *UserController) Detail(uid string) {
restweb.Logger.Debug("User Detail", uid)
userModel := model.UserModel{}
one, err := userModel.Detail(uid)
if err != nil {
uc.Error(err.Error(), 400)
return
}
uc.Output["Detail"] = one
solutionModle := model.SolutionModel{}
solvedList, err := solutionModle.Achieve(uid, config.ModuleP, config.ModuleP)
if err != nil {
uc.Error(err.Error(), 400)
return
}
type IPs struct {
Time int64
IP string
}
var ips []IPs
ipo := IPs{}
for i, lenth := 0, len(one.IPRecord); i < lenth; i++ {
ipo.Time = one.TimeRecord[i]
ipo.IP = one.IPRecord[i]
ips = append(ips, ipo)
}
achieveList := sort.IntSlice(solvedList)
achieveList.Sort()
uc.Output["List"] = achieveList
uc.Output["IpList"] = ips
uc.Output["Title"] = "User Detail"
if uid != "" && uid == uc.Uid {
uc.Output["IsSettings"] = true
uc.Output["IsSettingsDetail"] = true
}
uc.RenderTemplate("view/layout.tpl", "view/user_detail.tpl")
}
示例11: Settings
func (this *UserController) Settings(w http.ResponseWriter, r *http.Request) {
class.Logger.Debug("User Settings")
this.Init(w, r)
if this.Privilege == config.PrivilegeNA {
this.Data["Title"] = "Warning"
this.Data["Info"] = "You must login!"
err := this.Execute(w, "view/layout.tpl", "view/400.tpl")
if err != nil {
http.Error(w, "tpl error", 500)
return
}
return
}
userModel := model.UserModel{}
one, err := userModel.Detail(this.Uid)
if err != nil {
http.Error(w, err.Error(), 400)
return
}
this.Data["Detail"] = one
solutionModel := model.SolutionModel{}
solvedList, err := solutionModel.Achieve(this.Uid)
if err != nil {
http.Error(w, err.Error(), 400)
return
}
this.Data["List"] = solvedList
this.Data["Title"] = "User Settings"
this.Data["IsSettings"] = true
this.Data["IsSettingsDetail"] = true
err = this.Execute(w, "view/layout.tpl", "view/user_detail.tpl")
if err != nil {
http.Error(w, "tpl error", 500)
return
}
}
示例12: UpdateSolution
//UpdateSolution 更新判题结果
func (this *solution) UpdateSolution() {
sid, err := strconv.Atoi(strconv.Itoa(this.Sid))
solutionModel := model.SolutionModel{}
ori, err := solutionModel.Detail(sid)
if err != nil {
logger.Println(err)
return
}
ori.Judge = this.Judge
ori.Time = this.Time
ori.Memory = this.Memory
ori.Sim = this.Sim
ori.Sim_s_id = this.Sim_s_id
ori.Error = this.Error
err = solutionModel.Update(sid, *ori)
if err != nil {
logger.Println(err)
return
}
}
示例13: UpdateRecord
func (this *solution) UpdateRecord() {
if this.Module != config.ModuleP {
return
}
solutionModel := model.SolutionModel{}
qry := make(map[string]string)
qry["module"] = strconv.Itoa(config.ModuleP)
qry["action"] = "submit"
qry["pid"] = strconv.Itoa(this.Pid)
submit, _ := solutionModel.Count(qry)
qry["action"] = "solve"
solve, _ := solutionModel.Count(qry)
proModel := model.ProblemModel{}
err := proModel.Record(this.Pid, solve, submit)
if err != nil {
logger.Println(err)
}
qry["action"] = "submit"
qry["uid"] = this.Uid
delete(qry, "pid")
delete(qry, "module")
submit, _ = solutionModel.Count(qry)
solvelist, err := solutionModel.Achieve(this.Uid, config.ModuleP, config.ModuleP)
if err != nil {
logger.Println(err)
}
solve = len(solvelist)
userModel := model.UserModel{}
err = userModel.Record(this.Uid, solve, submit)
if err != nil {
logger.Println(err)
}
}
示例14: Rejudge
func (this *ProblemController) Rejudge(w http.ResponseWriter, r *http.Request) {
class.Logger.Debug("Problem Rejudge")
this.Init(w, r)
if this.Privilege < config.PrivilegeTC {
this.Err400(w, r, "Warning", "Error Privilege to Rejudge problem")
return
}
args := this.ParseURL(r.URL.String())
types := args["type"]
id, err := strconv.Atoi(args["id"])
if err != nil {
http.Error(w, "args error", 400)
return
}
hint := make(map[string]string)
if types == "Pid" {
pid := id
proModel := model.ProblemModel{}
pro, err := proModel.Detail(pid)
if err != nil {
class.Logger.Debug(err)
hint["info"] = "Problem does not exist!"
b, _ := json.Marshal(&hint)
w.WriteHeader(400)
w.Write(b)
return
}
qry := make(map[string]string)
qry["pid"] = strconv.Itoa(pro.Pid)
solutionModel := model.SolutionModel{}
list, err := solutionModel.List(qry)
for i := range list {
sid := list[i].Sid
time.Sleep(1 * time.Second)
go func() {
cmd := exec.Command("./RunServer", "-sid", strconv.Itoa(sid), "-time", strconv.Itoa(pro.Time), "-memory", strconv.Itoa(pro.Memory), "-rejudge", strconv.Itoa(1)) //Run Judge
err = cmd.Run()
if err != nil {
class.Logger.Debug(err)
}
}()
}
} else if types == "Sid" {
sid := id
solutionModel := model.SolutionModel{}
sol, err := solutionModel.Detail(sid)
if err != nil {
class.Logger.Debug(err)
hint["info"] = "Solution does not exist!"
b, _ := json.Marshal(&hint)
w.WriteHeader(400)
w.Write(b)
return
}
problemModel := model.ProblemModel{}
pro, err := problemModel.Detail(sol.Pid)
if err != nil {
http.Error(w, err.Error(), 500)
return
}
go func() {
cmd := exec.Command("./RunServer", "-sid", strconv.Itoa(sid), "-time", strconv.Itoa(pro.Time), "-memory", strconv.Itoa(pro.Memory), "-rejudge", strconv.Itoa(1)) //Run Judge
err = cmd.Run()
if err != nil {
class.Logger.Debug(err)
}
}()
}
}
示例15: List
//@URL: /status @method: GET
func (sc *StatusController) List() {
restweb.Logger.Debug("Status List")
searchUrl := ""
qry := make(map[string]string)
// Search
if v, ok := sc.Input["uid"]; ok {
searchUrl += "uid=" + v[0] + "&"
sc.Output["SearchUid"] = v[0]
qry["uid"] = v[0]
}
if v, ok := sc.Input["pid"]; ok {
searchUrl += "pid=" + v[0] + "&"
sc.Output["SearchPid"] = v[0]
qry["pid"] = v[0]
}
if v, ok := sc.Input["judge"]; ok {
searchUrl += "judge=" + v[0] + "&"
sc.Output["SearchJudge"+v[0]] = v[0]
qry["judge"] = v[0]
}
if v, ok := sc.Input["language"]; ok {
searchUrl += "language=" + v[0] + "&"
sc.Output["SearchLanguage"+v[0]] = v[0]
qry["language"] = v[0]
}
sc.Output["URL"] = "/status?" + searchUrl
// Page
qry["page"] = "1"
if v, ok := sc.Input["page"]; ok {
qry["page"] = v[0]
}
solutionModel := model.SolutionModel{}
qry["module"] = strconv.Itoa(config.ModuleP)
qry["action"] = "submit"
count, err := solutionModel.Count(qry)
if err != nil {
sc.Error(err.Error(), 400)
return
}
var pageCount = (count-1)/config.SolutionPerPage + 1
page, err := strconv.Atoi(qry["page"])
if err != nil {
sc.Error("args error", 400)
return
}
if page > pageCount {
sc.Error("args error", 400)
return
}
qry["offset"] = strconv.Itoa((page - 1) * config.SolutionPerPage)
qry["limit"] = strconv.Itoa(config.SolutionPerPage)
pageData := sc.GetPage(page, pageCount)
for k, v := range pageData {
sc.Output[k] = v
}
list, err := solutionModel.List(qry)
if err != nil {
sc.Error(err.Error(), 500)
return
}
sc.Output["Solution"] = list
sc.Output["Title"] = "Status List"
sc.Output["IsStatus"] = true
sc.Output["Privilege"] = sc.Privilege
sc.Output["Uid"] = sc.Uid
sc.RenderTemplate("view/layout.tpl", "view/status_list.tpl")
}