diff --git a/biopet-core/src/main/scala/nl/lumc/sasc/biopet/core/BiopetCommandLineFunction.scala b/biopet-core/src/main/scala/nl/lumc/sasc/biopet/core/BiopetCommandLineFunction.scala index 090b55b1b5a6be93c58f858afc183c69505889dc..bbb4ba0699281f3222cde1763feb294116af8d16 100644 --- a/biopet-core/src/main/scala/nl/lumc/sasc/biopet/core/BiopetCommandLineFunction.scala +++ b/biopet-core/src/main/scala/nl/lumc/sasc/biopet/core/BiopetCommandLineFunction.scala @@ -18,7 +18,7 @@ import java.io.{ File, FileInputStream, PrintWriter } import java.security.MessageDigest import nl.lumc.sasc.biopet.utils.Logging -import org.broadinstitute.gatk.utils.commandline.{ Gather, Input, Output } +import org.broadinstitute.gatk.utils.commandline.{ Input, Output } import org.broadinstitute.gatk.utils.runtime.ProcessSettings import org.ggf.drmaa.JobTemplate @@ -40,6 +40,8 @@ trait BiopetCommandLineFunction extends CommandLineResources { biopetFunction => def defaultRemoteCommand = "bash" private val remoteCommand: String = config("remote_command", default = defaultRemoteCommand) + val preCommands: List[String] = config("pre_commands", default = Nil, freeVar = false) + private def changeScript(file: File): Unit = { val lines = Source.fromFile(file).getLines().toList val writer = new PrintWriter(file) @@ -111,7 +113,7 @@ trait BiopetCommandLineFunction extends CommandLineResources { biopetFunction => * Checks executable. Follow full CanonicalPath, checks if it is existing and do a md5sum on it to store in job report */ protected[core] def preProcessExecutable() { - val exe = BiopetCommandLineFunction.preProcessExecutable(executable) + val exe = BiopetCommandLineFunction.preProcessExecutable(executable, preCommands) exe.path.foreach(executable = _) addJobReportBinding("md5sum_exe", exe.md5.getOrElse("N/A")) } @@ -219,7 +221,8 @@ trait BiopetCommandLineFunction extends CommandLineResources { biopetFunction => */ override final def commandLine: String = { preCmdInternal() - val cmd = cmdLine + + val cmd = preCommands.mkString("\n", "\n", "\n") + + cmdLine + stdinFile.map(file => " < " + required(file.getAbsoluteFile)).getOrElse("") + stdoutFile.map(file => " > " + required(file.getAbsoluteFile)).getOrElse("") addJobReportBinding("command", cmd) @@ -240,13 +243,18 @@ object BiopetCommandLineFunction extends Logging { private[core] val executableCache: mutable.Map[String, String] = mutable.Map() case class Executable(path: Option[String], md5: Option[String]) - def preProcessExecutable(executable: String): Executable = { + def preProcessExecutable(executable: String, pre_commands: List[String] = Nil): Executable = { if (!BiopetCommandLineFunction.executableMd5Cache.contains(executable)) { if (executable != null) { if (!BiopetCommandLineFunction.executableCache.contains(executable)) { try { val buffer = new StringBuffer() - val cmd = Seq("which", executable) + val tempFile = File.createTempFile("which.", ".sh") + val writer = new PrintWriter(tempFile) + pre_commands.foreach(cmd => writer.println(cmd + " > /dev/null 2> /dev/null")) + writer.println(s"which $executable") + writer.close() + val cmd = Seq("bash", tempFile.getAbsolutePath) val process = Process(cmd).run(ProcessLogger(buffer.append(_))) if (process.exitValue == 0) { val file = new File(buffer.toString) diff --git a/biopet-tools/src/main/scala/nl/lumc/sasc/biopet/tools/GensToVcf.scala b/biopet-tools/src/main/scala/nl/lumc/sasc/biopet/tools/GensToVcf.scala index f1ff21dc01f4658e4ad1fd599ae3f5400638d362..f9f9930a0b4947753166408fe61a48f5e23996f0 100644 --- a/biopet-tools/src/main/scala/nl/lumc/sasc/biopet/tools/GensToVcf.scala +++ b/biopet-tools/src/main/scala/nl/lumc/sasc/biopet/tools/GensToVcf.scala @@ -155,7 +155,9 @@ object GensToVcf extends ToolCommand { .make() } - val infoMap = infoHeaderKeys.map(_.map(x => ("GENS_" + x) -> infoValues.get(infoHeaderMap.get(x))).toMap).getOrElse(Map()) + val infoMap = infoHeaderKeys + .map(_.map(x => ("GENS_" + x) -> infoValues.get(infoHeaderMap.get(x)).replaceAll(";", ",")).toMap) + .getOrElse(Map()) val builder = (new VariantContextBuilder) .chr(cmdArgs.contig)