Welcome to the major project for CISC/CMPE 204!
Change this README.md file to summarize your project, and provide pointers to the general structure of the repository. How you organize and build things (which files, how you structure things, etc) is entirely up to you! The only things you must keep in place are what is already listed in the Structure section below.
documents
: Contains folders for both of your draft and final submissions. README.md files are included in both.run.py
: General wrapper script that you can choose to use or not. Only requirement is that you implement the one function inside of there for the auto-checks.test.py
: Run this file to confirm that your submission has everything required. This essentially just means it will check for the right files and sufficient theory size.
By far the most reliable way to get things running is with Docker. This section runs through the steps and extra tips to running with Docker. You can remove this section for your final submission, and replace it with a section on how to run your project.
-
First, download Docker https://www.docker.com/get-started
-
Navigate to your project folder on the command line.
-
We first have to build the course image. To do so use the command:
docker build -t cisc204 .
-
Now that we have the image we can run the image as a container by using the command:
docker run -it -v $(pwd):/PROJECT cisc204 /bin/bash
$(pwd)
will be the current path to the folder and will link to the container/PROJECT
is the folder in the container that will be tied to your local directory -
From there the two folders should be connected, everything you do in one automatically updates in the other. For the project you will write the code in your local directory and then run it through the docker command line. A quick test to see if they're working is to create a file in the folder on your computer then use the terminal to see if it also shows up in the docker container.
If you happen to be building and running things on a Mac with an M1 chip, then you will likely need to add the following parameter to both the build and run scripts:
--platform linux/x86_64
For example, the build command would become:
docker build --platform linux/x86_64 -t cisc204 .
In the run script above, the -v $(pwd):/PROJECT
is used to mount the current directory to the container. If you are using a different OS, you may need to change this to the following:
- Windows PowerShell:
-v ${PWD}:/PROJECT
- Windows CMD:
-v %cd%:/PROJECT
- Mac:
-v $(pwd):/PROJECT
Finally, if you are in a folder with a bunch of spaces in the absolute path, then it will break things unless you "quote" the current directory like this (e.g., on Windows CMD):
docker run -it -v "%cd%":/PROJECT cisc204