jsonhwparser {TexExamRandomizer} | R Documentation |
Json Homework Parser
Description
This function takes a series of options as obtained from parse_args
through the parameter opt
. The "examples" section provides all the options that it can parse.
From within those options, a --file
option is mandatory.
The file option provides a 'LaTeX' file name in which to search for lines on the preamble %!TexExamRandomizer
within the first 200 lines.
With those options that it finds through tags, it passes the function GenerateHomework
.
Note that the tags must respect the JSON format, that is. It needs to be written within double quotes.
Usage
jsonhwparser(opt)
Arguments
opt |
Options as parsed from |
Details
It acts similarly to link{jsonexamparser}
, but with the exception of not providing any randomiation option, it only provides the personalization options.
Look at vignette("ExamOptions", package = "TexExamRandomizer")
to see the details of the options that it accepts.
See Also
Other jsoncompiler:
ParsePreambleForOptions()
,
compilation_options()
,
jsonexamparser()
Examples
## Not run:
#!/bin/Rscript
#This example showcases the type of script this jsonparser might be used on.
# You can still use it without a script,
# just by adding a list that has the same names as the list provided in opt
library(optparse)
option_list <- list(
make_option(
c("--file"),
action = "store",
default = NULL,
type = 'character',
help = "Filename of the Tex File"
),
make_option(
c("--table"),
action = "store",
default = NULL,
type = 'character',
help = "Filename of the table to break down. It overwrites the values written on the file"
),
make_option(
c("-s", "--seed"),
action = "store",
default = NULL,
type = "integer",
help = "Seed for any randomization done"
),
make_option(
c("-c", "--compile"),
action = "store_true",
default = FALSE,
type = "logical",
help = "Should the output folder be compiled or not"
),
make_option(
c("--xelatex"),
action = "store_true",
default = FALSE,
type = "logical",
help = "Should we use xelatex to compile or not"
),
make_option(
c("-d", "--debug"),
action = "store_true",
default = FALSE,
type = "logical",
help = "If debugging, it doesn't remove auxiliary files"
)
)
#### PARSING OPTIONS ####
####
opt <-
parse_args(
OptionParser(option_list = option_list),
positional_arguments = TRUE
)
# Let's assume the file was the example file
testfile <-
system.file(
"extdata",
"ExampleTexDocuments",
"exam_testing_nquestions.tex", #Test exam that doesn't require a table
package = "TexExamRandomizer")
# To prevent modifying the file system in examples
temporalfile <- paste(tempfile(), ".tex", sep = "")
file.copy(testfile, temporalfile)
opt$options$file <- temporalfile
jsonhwparser(opt)
## End(Not run)