2025-01-12 04:36:52 +08:00

359 lines
13 KiB
R

## ---- echo = FALSE, message = FALSE-------------------------------------------
library(knitr)
knitr::opts_chunk$set(
error = FALSE,
tidy = FALSE,
message = FALSE,
comment = NA,
fig.align = "center")
library(GetoptLong)
## ---- echo = FALSE, out.width = "600px"---------------------------------------
include_graphics("workflow.png")
## ----simple, eval = FALSE-----------------------------------------------------
# library(GetoptLong)
#
# cutoff = 0.05
# GetoptLong(
# "number=i", "Number of items.",
# "cutoff=f", "Cutoff for filtering results.",
# "verbose", "Print message."
# )
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["simple"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
GetoptLong.options("help_style" = "two-column")
local({ eval(parse(text = chunks[["simple"]])) })
GetoptLong.options("__argv_str__" = NULL)
GetoptLong.options("help_style" = "one-column")
## ----template, eval = FALSE---------------------------------------------------
# spec = "
# This is an example of using template to specify options.
#
# Usage: Rscript foo.R [options]
#
# Options:
# <number=i> Number of items.
# <cutoff=f> Cutoff for filtering results.
# <verbose> Print messages.
#
# Contact: name@address
# "
#
# GetoptLong(spec, template_control = list(opt_width = 21))
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["template"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ----print_var, eval = FALSE--------------------------------------------------
# library(GetoptLong)
#
# cutoff = 0.05
# GetoptLong(
# "number=i{1,}", "Number of items.",
# "cutoff=f", "Cutoff for filtering results.",
# "param=s%", "Parameters specified by name=value pairs.",
# "verbose", "Print message."
# )
#
# print(number)
# print(cutoff)
# print(param)
# print(verbose)
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--number 1 2 --param var1=a var2=b --verbose")
local({ eval(parse(text = chunks[["print_var"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ---- eval = FALSE------------------------------------------------------------
# verbose = TRUE
# GetoptLong(
# "verbose!", "Print message."
# )
## ----with_env, eval = FALSE---------------------------------------------------
# opt = new.env()
#
# opt$cutoff = 0.05
# GetoptLong(
# "number=i@", "Number of items.",
# "cutoff=f", "Cutoff for filtering results.",
# "param=s%", "Parameters specified by name=value pairs.",
# "verbose", "Print message.",
#
# envir = opt
# )
# print(as.list(opt))
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--number 1 2 --param var1=a var2=b --verbose")
local({ eval(parse(text = chunks[["with_env"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ----complex_example, eval = FALSE--------------------------------------------
# GetoptLong(
# "count=i", paste("This is a count. This is a count. This is a count.",
# "This is a count. This is a count. This is a count."),
# "number=f", paste("This is a number. This is a number. This is a number.",
# "This is a number. This is a number. This is a number."),
# "array=f@", paste("This is an array. This is an array. This is an array.",
# "This is an array. This is an array. This is an array."),
# "hash=s%", paste("This is a hash. This is a hash. This is a hash.",
# "This is a hash. This is a hash. This is a hash."),
# "verbose!", "Whether show messages",
# "flag", "a non-sense option"
# )
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["complex_example"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ count = 1
number = 0.1
array = c(1, 2)
hash = list("foo" = "a", "bar" = "b")
verbose = TRUE
eval(parse(text = chunks[["complex_example"]]))
})
GetoptLong.options("__argv_str__" = NULL)
## ---- eval = FALSE------------------------------------------------------------
# GetoptLong.options(help_style = "two-column")
# # specifying the defaults
# GetoptLong{
# ...
# }
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
GetoptLong.options("help_style" = "two-column")
local({ count = 1
number = 0.1
array = c(1, 2)
hash = list("foo" = "a", "bar" = "b")
verbose = TRUE
eval(parse(text = chunks[["complex_example"]]))
})
GetoptLong.options("__argv_str__" = NULL)
GetoptLong.options("help_style" = "one-column")
## ----sub_opt, eval = FALSE----------------------------------------------------
# foo = list(a = 1, b = 2)
# GetoptLong(
# "foo=i%", paste("This is foo. This is foo. This is foo. This is foo.",
# "This is foo. This is foo. This is foo. This is foo."),
# "foo$name1", paste("name1 in foo. name1 in foo. name1 in foo. name1 in foo.",
# "name1 in foo. name1 in foo. name1 in foo. name1 in foo."),
# "foo$name2", paste("name2 in foo. name2 in foo. name2 in foo. name2 in foo.",
# "name2 in foo. name2 in foo. name2 in foo. name2 in foo."),
# "bar=s%", paste("This is bar. This is bar. This is bar. This is bar.",
# "This is bar. This is bar. This is bar. This is bar."),
# "bar$name3", paste("name3 in bar. name3 in bar. name3 in bar. name3 in bar.",
# "name3 in bar. name3 in bar. name3 in bar. name3 in bar."),
# "bar$name4", paste("name4 in bar. name4 in bar. name4 in bar. name4 in bar.",
# "name4 in bar. name4 in bar. name4 in bar. name4 in bar.")
# )
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["sub_opt"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ---- eval = FALSE------------------------------------------------------------
# GetoptLong.options(help_style = "two-column")
# GetoptLong{
# ...
# }
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
GetoptLong.options(help_style = "two-column")
local({ eval(parse(text = chunks[["sub_opt"]])) })
GetoptLong.options("__argv_str__" = NULL)
GetoptLong.options(help_style = "one-column")
## ----head_and_foot, eval = FALSE----------------------------------------------
# GetoptLong(
# help_head = "This is a demonstration of adding usage head and foot.",
#
# "number=i", "Number of items.",
# "cutoff=f", "Cutoff for filtering results.",
# "verbose", "Print message.",
#
# help_foot = "Please contact name@address."
# )
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["head_and_foot"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ----grouped_options, eval = FALSE--------------------------------------------
# count = 1
# array = c(0.1, 0.2)
# GetoptLong(
# "--------", "Binary options:",
# "verbose!", "Whether show messages",
# "flag", "a non-sense option",
#
# "-------", "Single-value options:",
# "count=i", paste("This is a count. This is a count. This is a count.",
# "This is a count. This is a count. This is a count."),
# "number=f", paste("This is a number. This is a number. This is a number.",
# "This is a number. This is a number. This is a number."),
#
# "--------", paste("Multiple-vlaue options: long text long text long text",
# " long text long text long text long text long text"),
# "array=f@", paste("This is an array. This is an array. This is an array.",
# "This is an array. This is an array. This is an array."),
# "hash=s%", paste("This is a hash. This is a hash. This is a hash.",
# "This is a hash. This is a hash. This is a hash."),
#
# "-------", "Other options:"
# )
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["grouped_options"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ---- eval = FALSE------------------------------------------------------------
# GetoptLong.options(help_style = "two-column")
# GetoptLong{
# ...
# }
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
GetoptLong.options(help_style = "two-column")
local({ eval(parse(text = chunks[["grouped_options"]])) })
GetoptLong.options("__argv_str__" = NULL)
GetoptLong.options(help_style = "one-column")
## ----complex_template, eval = FALSE-------------------------------------------
# GetoptLong("
# This is a demonstration of using template as the option specification.
#
# Usage: Rscript foo.R [options]
#
# Binary options:
# <verbose!> Whether show messages
# <flag> A non-sense option
#
# Single-value options:
# <count=i> This is a count. This is a count.
# <number=f> This is a number. This is a number.
#
# Multiple-vlaue options:
# <array=f@> This is an array. This is an array.
# <hash=s%> This is a hash. This is a hash.
#
# Questions, please contact your.name@email
# ", template_control = list(opt_width = c(verbose = 23, flag = 23,
# count = 22, number = 22,
# array = 30, hash = 30)
# ))
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["complex_template"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ----template_multi_line, eval = FALSE----------------------------------------
# GetoptLong("
# Usage: Rscript foo.R [options]
#
# <count=i{2,}> This is a count. This is a count. This is a count.
# <#count> This is a count. This is a count.
# <number=f> This is a number. This is a number. This is a number.
# <#number> This is a number. This is a number.
# ", template_control = list(opt_width = c(count = 28, number = 28))
# )
## ---- echo = FALSE------------------------------------------------------------
chunks <- knitr:::knit_code$get()
GetoptLong.options("__argv_str__" = "--help")
local({ eval(parse(text = chunks[["template_multi_line"]])) })
GetoptLong.options("__argv_str__" = NULL)
## ----version, eval = FALSE----------------------------------------------------
# VERSION = "0.0.1"
# GetoptLong(
# "tag=i", "...",
# )
## ---- eval = FALSE------------------------------------------------------------
# GetoptLong.options("config" = "bundling")
# GetoptLong.options("config" = c("no_ignore_case", "bundling"))
## ---- eval = FALSE------------------------------------------------------------
# source_script("foo.R", argv_str = "--cutoff 0.01 --input file=foo.txt --verbose")
## ---- eval = TRUE-------------------------------------------------------------
sessionInfo()
## ---- echo = FALSE, results = "asis"------------------------------------------
get_os <- function(){
sysinf <- Sys.info()
if (!is.null(sysinf)){
os <- sysinf['sysname']
if (os == 'Darwin')
os <- "osx"
} else { ## mystery machine
os <- .Platform$OS.type
if (grepl("^darwin", R.version$os))
os <- "osx"
if (grepl("linux-gnu", R.version$os))
os <- "linux"
}
tolower(os)
}
is.solaris = function() {
os = get_os()
!(os %in% c("windows", "unix", "linux", "osx"))
}
if(is.solaris()) {
cat("**GetoptLong** is not supported on Solaris platform.\n")
} else {
if(!is.solaris()) {
invisible(knit("GetoptLong.Rmd2", "GetoptLong.md2"))
}
if(Sys.info()["user"] == "jokergoo") {
invisible(file.copy("GetoptLong.md2", "/Users/jokergoo/project/GetoptLong/vignettes/GetoptLong.md2", overwrite = TRUE))
}
ln = readLines("GetoptLong.md2")
cat(paste(ln, collapse = "\n"))
}