Python AGPLv3 contest judge backend for the DMOJ site interface. See it in action at dmoj.ca!
A modern online judge and contest platform system, supporting IO-based, interactive, and signature-graded tasks, with runtime data generators and custom output validators. |
The judge implements secure grading on Linux, Windows, and FreeBSD machines.
Linux | Windows | FreeBSD | |
---|---|---|---|
x64 | ✔ | ✔ | ✔ |
x86 | ✔ | ✔ | ¯\_(ツ)_/¯ |
x32 | ✔ | — | — |
ARM | ✔ | — | ❌ |
The DMOJ judge does not need a root user to run on Linux machines: it will run just fine under a normal user.
Supported languages include:
- C++ 0x/11/14/17 (GCC and Clang)
- C 99/11
- Java 7/8/9/10
- Python 2/3
- PyPy 2/3
- Pascal
- Perl
- Mono C#/F#/VB
The following runtimes are also supported, but only on Windows machines:
- Visual C++
- C#
- F#
- VB.NET
The judge can also grade in the languages listed below. These languages are less tested and more likely to be buggy.
- Ada
- AWK
- Clozure Common Lisp
- COBOL
- D
- Dart
- Fortran
- Forth
- Go
- Groovy
- Haskell
- INTERCAL
- Kotlin
- Lua
- NASM
- Nim
- Objective-C
- Octave
- OCaml
- PHP 5/7
- Pike
- Prolog
- Racket
- Ruby 2.1
- Rust
- Scala
- Chicken Scheme
- sed
- Steel Bank Common Lisp
- Swift
- Tcl
- Turing
- V8 JavaScript
- Brain****
On a typical Linux install,
$ git clone https://github.com/DMOJ/judge.git
$ cd judge
$ git submodule update --init --recursive
$ python setup.py develop
This will create two executables in your Python's script directory: dmoj
and dmoj-cli
. dmoj
is used to connect a judge to a DMOJ site instance, while dmoj-cli
provides a command-line interface to a local judge, useful for testing problems.
For more detailed steps, read the Linux Installation or Windows Installation instructions.
$ dmoj --help
usage: dmoj [-h] [-p SERVER_PORT] -c CONFIG [-l LOG_FILE]
[-e ONLY_EXECUTORS | -x EXCLUDE_EXECUTORS] [--no-ansi]
server_host [judge_name] [judge_key]
Spawns a judge for a submission server.
positional arguments:
server_host host to listen for the server
judge_name judge name (overrides configuration)
judge_key judge key (overrides configuration)
optional arguments:
-h, --help show this help message and exit
-p SERVER_PORT, --server-port SERVER_PORT
port to listen for the server
-c CONFIG, --config CONFIG
file to load judge configurations from
-l LOG_FILE, --log-file LOG_FILE
log file to use
-e ONLY_EXECUTORS, --only-executors ONLY_EXECUTORS
only listed executors will be loaded (comma-separated)
-x EXCLUDE_EXECUTORS, --exclude-executors EXCLUDE_EXECUTORS
prevent listed executors from loading (comma-
separated)
--no-ansi disable ANSI output
$ dmoj-cli --help
usage: dmoj-cli [-h] -c CONFIG
[-e ONLY_EXECUTORS | -x EXCLUDE_EXECUTORS]
[--no-ansi] [--no-ansi-emu]
Spawns a judge for a submission server.
optional arguments:
-h, --help show this help message and exit
-c CONFIG, --config CONFIG
file to load judge configurations from
-e ONLY_EXECUTORS, --only-executors ONLY_EXECUTORS
only listed executors will be loaded (comma-separated)
-x EXCLUDE_EXECUTORS, --exclude-executors EXCLUDE_EXECUTORS
prevent listed executors from loading (comma-
separated)
--no-ansi disable ANSI output
--no-ansi-emu disable ANSI emulation on Windows
For info on the problem file format and more, read the documentation.