summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Dockerfile11
-rw-r--r--Smarker/misc_classes.py14
-rw-r--r--Smarker/smarker.py (renamed from Smarker/mark.py)10
3 files changed, 35 insertions, 0 deletions
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 0000000..b688e0c
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,11 @@
+FROM ubuntu:latest
+MAINTAINER Eden Attenborough "gae19jtu@uea.ac.uk"
+ENV TZ=Europe/London
+RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
+RUN apt-get update -y
+RUN apt-get install -y python3-pip python3-dev build-essential texlive-base wkhtmltopdf
+COPY ./Smarker /Smarker
+WORKDIR /Smarker
+RUN pip3 install -r requirements.txt
+ENTRYPOINT ["python3"]
+CMD ["smarker.py"] \ No newline at end of file
diff --git a/Smarker/misc_classes.py b/Smarker/misc_classes.py
index 09c3a7d..17ad36a 100644
--- a/Smarker/misc_classes.py
+++ b/Smarker/misc_classes.py
@@ -1,4 +1,5 @@
from dataclasses import dataclass
+import argparse
import tempfile
import zipfile
import shutil
@@ -19,6 +20,19 @@ latex_jinja_env = jinja2.Environment(
loader = jinja2.FileSystemLoader(os.path.abspath(os.path.join(os.path.split(__file__)[0], "templates")))
)
+class EnvDefault(argparse.Action):
+ def __init__(self, envvar, required=True, default=None, **kwargs):
+ if not default and envvar:
+ if envvar in os.environ:
+ default = os.environ[envvar]
+ if required and default:
+ required = False
+ super(EnvDefault, self).__init__(default=default, required=required,
+ **kwargs)
+
+ def __call__(self, parser, namespace, values, option_string=None):
+ setattr(namespace, self.dest, values)
+
@dataclass
class ExtractZipToTempDir(tempfile.TemporaryDirectory):
zip_file:str
diff --git a/Smarker/mark.py b/Smarker/smarker.py
index e8070f8..106d426 100644
--- a/Smarker/mark.py
+++ b/Smarker/smarker.py
@@ -69,18 +69,24 @@ if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument(
"-a", "--assessment",
+ action = misc_classes.EnvDefault,
+ envvar = "assessment",
help = "Path to an assessment .yml file",
type = os.path.abspath,
required = True
)
parser.add_argument(
"-s", "--submission",
+ action = misc_classes.EnvDefault,
+ envvar = "submission",
help = "Path to a zip of a student's code",
type = os.path.abspath,
required = True
)
parser.add_argument(
"-f", "--format",
+ action = misc_classes.EnvDefault,
+ envvar = "format",
help = "Output format type",
type = str,
choices = ["yaml", "json", "pdf"] + [os.path.splitext(f)[0] for f in os.listdir(os.path.join(os.path.split(__file__)[0], "templates"))],
@@ -88,6 +94,8 @@ if __name__ == "__main__":
)
parser.add_argument(
"-o", "--out",
+ action = misc_classes.EnvDefault,
+ envvar = "out",
help = "Path to write the output to, or, by default write to stdout. 'auto' automatically generates a file name.",
default = "stdout",
)
@@ -96,6 +104,8 @@ if __name__ == "__main__":
for option in config.options(section):
parser.add_argument(
"--%s_%s" % (section, option),
+ action = misc_classes.EnvDefault,
+ envvar = "--%s_%s" % (section, option),
default = config.get(section, option),
help = "Optional argument inherited from config file. Read smarker.conf for details."
)