Gitea actions based, 3rd generation of joint online judge.
https://github.com/joint-online-judge/JOJ3
| _example/simple | ||
| cmd/joj3 | ||
| internal | ||
| pkg/healthcheck | ||
| .drone.yml | ||
| .editorconfig | ||
| .gitignore | ||
| go.mod | ||
| go.sum | ||
| Makefile | ||
| README.md | ||
JOJ3
Quick Start
In order to register sandbox executor, you need to run go-judge before running this program.
$ make clean && make && ./_example/simple/run.sh
rm -rf ./build/*
rm -rf *.out
go build -o ./build/joj3 ./cmd/joj3
++ dirname -- ./_example/simple/run.sh
+ DIRNAME=./_example/simple
+ cd ./_example/simple
+ ./../../build/joj3
+ cat ./joj3_result.json
[{"Name":"compile","Results":[{"Score":100,"Comment":"compile done, executor status: run time: 265269232 ns, memory: 57790464 bytes"}]},{"Name":"run","Results":[{"Score":100,"Comment":"executor status: run time: 2033735 ns, memory: 13225984 bytes"},{"Score":100,"Comment":"executor status: run time: 3117399 ns, memory: 14548992 bytes"}]}]
+ rm -f ./joj3_result.json
+ cd -
Models
The program parse the TOML file to run multiple stages.
Each stage contains a executor and parser.
Executor takes a Cmd and returns a ExecutorResult.
Parser takes a ExecutorResult and its config and returns a ParserResult and bool to indicate whether we should skip the rest stages.
Cmd
Check Cmd in https://github.com/criyle/go-judge#rest-api-interface.
Some difference:
CopyInCwd bool: set totrueto add everything in the current working directory toCopyIn.CopyInCached map[string]string: key: file name in sandbox, value: file name used inCopyOutCached.LocalFile: now support relative path
ExecutorResult
Check Result in https://github.com/criyle/go-judge#rest-api-interface.
ParserResult
Score int: score of the stage.Comment string: comment of the stage.