Skip to content

Import your vJudge solutions to actual online judges. Currently supports UVa, CodeForces, SPOJ, and CodeForces GYM.

License

Notifications You must be signed in to change notification settings

m-s-abeer/vjudge-to-oj

Repository files navigation

vjudge-to-oj

made-with-python GitHub license GitHub forks GitHub stars Hits

Competitive programmers spend hundreds and thousands of hours practicing programming problems and participating contests. Vjudge has been an amazing platform for participating/hosting programming contests and problem-solving.

However, there can be scenarios where you'd like to add vjudge solutions to the actual judge profiles specifically. I personally felt the need of it along with some of my friends and colleagues. It's a tiresome job to submit all the solved problems of vjudge to the actual judges. This here is a small approach to get such works done easily.

Current solution will only work for UVa, CodeForces, LightOj and SPOJ. So far, it's pretty much stable and working just fine. It's roughly written and tested. But hey, it works!!!

With enough response and your contribution I hope to add some more judges here as well. Huge thanks to all who contributed so far to my fun projects.

Let me know if you have any questions/suggestions/feedbacks or simply if you liked it.

Email: [email protected]

Hope you enjoy. <3


Installation Guide:

With poetry(Easier):-

  1. Download/clone the repository from github using git:-
    • Run git clone https://github.com/m-s-abeer/vjudge-to-oj.git from your cmd/terminal in your specified directory.
  2. Download and install python ^3.10 from here:- https://www.python.org/downloads/
  3. Make sure you are using the desired python version by running python --version
  4. Download and install python-poetry
  5. Get inside project vjudge-to-oj and then write poetry install on cmd/terminal. This should install all the dependencies/packages.

Without poetry:-

  1. Download/clone the repository from github using git:-
    • Run git clone https://github.com/m-s-abeer/vjudge-to-oj.git from your cmd/terminal in your specified directory.
  2. Download and install python ^3.10 from here:- https://www.python.org/downloads/
  3. Make sure you are using the desired python version by running python --version
  4. Get inside project vjudge-to-oj
  5. Write python -m venv .venv to create a python environment inside project.
  6. Write source ./.venv/activate for Linux, MacOS, WSL. For windows write .\.venv\Scripts\activate to activate the python environment
  7. Run pip install --upgrade pip and then pip install -r requirements.txt to install all the dependencies/packages

Set your .env file:-

  1. Create a file named .env in the project directory.
  2. Copy the contents of .env.example and paste it in .env file.
  3. Read the comments in .env file and set the values accordingly.

How it should work:

  1. Complete the #installation-guide and run the following command inside project root from cmd/terminal to activate the environment:-
    • Poetry users: poetry shell
    • Linux, MacOS, WSL users: source ./.venv/bin/activate
    • Windows users: .\.venv\Scripts\activate
  2. Make sure you have set the values in .env file correctly.
  3. Run python main.py from the project root
  4. The program will automatically download your Accepted solutions from vjudge and then submit them one by one and store the submitted solutions to another folder(modules>Submitted>UVA>).
  5. It'll show you the status report as it runs. It may look messy, but it actually helps you see what's going on.
  • No login data is bypassed/redirected to anywhere else. Vjudge login data is stored inside "vjudge-to-oj>modules>cookies" this directory. You can empty that folder if you're concerned or have issues logging in.

N.B: Please don't run it when the corresponding judge is already busy and many submissions are already in queue. It's built only for personal uses. This program is in no way meant to hamper the solving environment of a judging platform.

About

Import your vJudge solutions to actual online judges. Currently supports UVa, CodeForces, SPOJ, and CodeForces GYM.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published