-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbatch_correction_docker_wrapper.R
executable file
·76 lines (64 loc) · 3.31 KB
/
batch_correction_docker_wrapper.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#!/usr/bin/env Rscript
################################################################################################
# batch_correction_main_wrapper #
# #
# Author: Nils Paulhe #
# User: Galaxy #
# Original data: -- #
# Starting date: 2017-12-11 #
# Version 1: 2017-12-11 #
# #
# #
# #
################################################################################################
library(batch) #necessary for parseCommandArgs function
##------------------------------
## init. prog. constants
##------------------------------
argv.wrapper <- commandArgs(trailingOnly = FALSE)
script.path <- sub("--file=", "", argv.wrapper[grep("--file=", argv.wrapper)])
prog.name <- basename(script.path)
##------------------------------
## init. functions
##------------------------------
script_bypass <- function(other.script.name) {
initial.options <- commandArgs(trailingOnly = FALSE)
file.arg.name <- "--file="
script.name <- sub(file.arg.name, "", initial.options[grep(file.arg.name, initial.options)])
script.basename <- dirname(script.name)
other.script.fullpath <- paste(sep="/", script.basename, other.script.name)
other.script.cmd <- paste(sep=" ", "Rscript", other.script.fullpath, "-h")
system(other.script.cmd, wait=TRUE)
}
source_wrapper <- function(other.script.name){
initial.options <- commandArgs(trailingOnly = FALSE)
file.arg.name <- "--file="
script.name <- sub(file.arg.name, "", initial.options[grep(file.arg.name, initial.options)])
script.basename <- dirname(script.name)
other.script.fullpath <- paste(sep="/", script.basename, other.script.name)
source(other.script.fullpath)
}
##------------------------------
## Test Help
##------------------------------
if (length(grep('-h', argv.wrapper)) > 0) {
cat("Usage: Rscript ",
prog.name,
"{args} \n",
"parameters: \n",
"\t-h: display this help message, call all scripts with the same option and exit (optional) \n",
"\t--loess \"TRUE\": call the script as \"batch_correction_all_loess_wrapper.R\"; otherwise call it as \"batch_correction_wrapper.R\" one (optional) \n",
"for other parameters, please refer to each script specific options and parameters. \n",
"\n")
script_bypass("batch_correction_all_loess_wrapper.R")
script_bypass("batch_correction_wrapper.R")
quit(status = 0)
}
##------------------------------
## check if loess or normal
##------------------------------
if (length(grep('--loess', argv.wrapper)) > 0) {
source_wrapper("batch_correction_all_loess_wrapper.R")
} else {
source_wrapper("batch_correction_3Lwrapper.R")
}