Konzolový klient pro odesílání open-datových úloh pomocí KSP API.
Tento program lze používat a distribuovat pod licencí MIT (viz soubor LICENSE). Jeho autory jsou organizátoři KSP [email protected].
Pokud najdeš jakoukoliv chybu nebo Tě napadne nějaké vylepšení, dej nám vědět, případně založ issue / pull request v našem GitHubovém projektu https://github.com/ksp/ksp-klient/.
Pro spuštění aplikace potřebuješ mít nainstalované:
- Python verze minimálně 3.6
- pythoní balíček requests -
pip install requests
(případně z balíčkovacího systému vaší linuxové distribuce)
Dále si potřebuješ vygenerovat KSP API token zde (po přihlášení)
a uložit si ho do souboru s názvem ~/.config/ksp-api-token
. Pokud na Tvém počítači pracuje víc lidí,
dej pozor, aby neměli právo tento soubor číst.
- Pokud jsi na Unix-like systému, tak program spustíš jednoduše
příkazem
./ksp-klient.py
. - Pokud program spouštíš na Windows, tak třeba takto:
python3 ksp-klient.py
.
Klient poskytuje základní funkce pro odevzdávání open-datových úloh a nahrazuje webové rozhraní Odevzdávátka.
list
- vypíše všechny úlohy, které lze aktuálně odevzdávat, pokud za list přidáte přepínač -c, tak se vám zobrazí všechny úlohy, které lze odevzdávat do Cvičiště.- použití:
./ksp-klient.py list
nebo./ksp-klient.py list -c
- použití:
series
- vypíše seznam sérií v aktuálním ročníku. Pozor, na rozhraní školních roků mohou být aktuální dva ročníky současně.- použití:
./ksp-klient.py series
- použití:
status
- vypíše stav dané úlohy - název úlohy, kolik jsi dostal bodů, poté následují informace o jednotlivých podúlohách.- použití:
./ksp-klient.py status <úloha>
- příklad:
./ksp-klient.py status 32-Z4-1
- použití:
generate
- vygeneruje a stáhne nový vstup pro danou úlohu a podúlohu. Stažený soubor vypíše na svůj standardní výstup, pokud není uveden název souboru. Jinak se výstup uloží do souboru.- použití:
./ksp-klient.py generate <úloha> <podúloha> [<soubor>]
- příklad:
./ksp-klient.py generate 32-Z4-1 1
- s uložením do souboru:
./ksp-klient.py generate 32-Z4-1 1 01.in
- použití:
submit
- odešle výstup pro určenou podúlohu na server KSP, načež vypíše, jestli byla Tvá odpověď správná a kolik bodů jsi dostal.- U příkazu specifikuješ, jakou úlohu a podúlohu chceš odevzdat a cestu k souboru s odpovědí.
- použití:
./ksp-klient.py submit <úloha> <podúloha> <cesta k souboru>
- příklad:
./ksp-klient.py submit 32-Z4-1 1 01.out
- Pokud chceš zadat výstup přímo z konzole, tak místo souboru uveď
-
- příklad:
./ksp-klient.py submit 32-Z4-1 1 -
run
- pro každou podúlohu dané úlohy stáhne vstup, spustí s ním Tvůj program a výstup programu odešle jako odpověď.- použití:
./ksp-klient.py run <úloha> <argumenty, jak spustit tvůj program>
- příklad pro Python:
./ksp-klient.py run 32-Z4-1 python3 program.py
- příklad pro spustitelný program (třeba přeložené C++):
./ksp-klient.py run 32-Z4-1 ./program
- příklad pro Javu:
./ksp-klient.py run 32-Z4-1 java program
(kdeprogram
je výstup překladačejavac program.java
)
- použití: