setMethod(.srValidity, "SolexaPath", function(object) {
msg <- NULL
if (length(experimentPath(object))!=1)
msg <- c(msg, "SolexaPath 'experimentPath' must be character(1)")
if (is.null(msg)) TRUE else msg
})
SolexaPath <- function(experimentPath=NA_character_,
dataPath=.srPath(experimentPath, "Data"),
scanPath=.srPath(dataPath, "GoldCrest"),
imageAnalysisPath=.srPath(dataPath, "^(C[[:digit:]]|IPAR|Intensities)"),
baseCallPath=.srPath(imageAnalysisPath,
"^(Bustard|BaseCalls)"),
analysisPath=.srPath(baseCallPath,
"^GERALD"),
..., verbose=FALSE)
{
if (verbose) {
.checkPath(experimentPath)
.checkPath(dataPath)
.checkPath(scanPath)
.checkPath(imageAnalysisPath)
.checkPath(baseCallPath)
.checkPath(analysisPath)
}
new("SolexaPath", ..., basePath=experimentPath, dataPath=dataPath,
scanPath=scanPath, imageAnalysisPath=imageAnalysisPath,
baseCallPath=baseCallPath, analysisPath=analysisPath)
}
.make_getter(slotNames("SolexaPath"))
.readIntensities_SolexaPath <-
function(dirPath, pattern=character(0), run, ...)
{
callGeneric(imageAnalysisPath(dirPath)[run], pattern=pattern, ...)
}
setMethod(readIntensities, "SolexaPath", .readIntensities_SolexaPath)
.readPrb_SolexaPath <- function(dirPath, pattern=".*_prb.txt.*", run, ...)
{
if (missing(pattern))
pattern <- ".*_prb.txt.*"
callGeneric(baseCallPath(dirPath)[run], pattern, ...)
}
setMethod(readPrb, "SolexaPath", .readPrb_SolexaPath)
setMethod(readFasta, "SolexaPath",
function(dirPath, pattern=character(0), ..., nrec=-1L, skip=0L)
{
callGeneric(dirPath=analysisPath(dirPath),
pattern=pattern, ..., nrec=nrec, skip=skip)
})
.readFastq_SolexaPath <- function(dirPath,
pattern=".*_sequence.txt$",
run, ...,
qualityType="SFastqQuality") {
dirPath <- analysisPath(dirPath)[run]
if (is.na(dirPath))
.throw(SRError("Input/Output", "'%s' is 'NA' in '%s'",
"analysisPath", "dirPath"))
callGeneric(dirPath, ..., pattern=pattern, qualityType=qualityType)
}
setMethod(readFastq, "SolexaPath", .readFastq_SolexaPath)
setMethod(readQseq, "SolexaPath",
function(dirPath, pattern=".*_qseq.txt.*", run, ...,
as="ShortReadQ", filtered=FALSE, verbose=FALSE)
{
callGeneric(baseCallPath(dirPath)[run], pattern=pattern, ...,
as=as, filtered=filtered, verbose=verbose)
})
.readBaseQuality_SolexaPath <- function(dirPath,
seqPattern=".*_seq.txt.*",
prbPattern=".*_prb.txt.*",
run, ...)
{
dirPath <- baseCallPath(dirPath)[run]
.readBaseQuality_Solexa(dirPath, seqPattern=seqPattern,
prbPattern=prbPattern, ...)
}
setMethod(readBaseQuality, "SolexaPath", .readBaseQuality_SolexaPath)
.readAligned_SolexaPath <- function(dirPath,
pattern=".*_export.txt.*",
run, ...)
{
dirPath <- analysisPath(dirPath)[run]
.readAligned_character(dirPath, pattern, type="SolexaExport", ...)
}
setMethod(readAligned, "SolexaPath", .readAligned_SolexaPath)
.qa_SolexaPath <- function(dirPath, pattern=character(0),
run, ...)
{
dirPath <- analysisPath(dirPath)[run]
if (missing(pattern))
pattern <- ".*_export.txt$"
callGeneric(dirPath, pattern, type="SolexaExport", ...)
}
setMethod(qa, "SolexaPath", .qa_SolexaPath)
setMethod(report, "SolexaPath",
function (x, ..., dest = tempfile(), type="html")
{
callGeneric(qa(x, ...), dest=dest, type=type)
})
setMethod(show, "SolexaPath", function(object) {
callNextMethod()
.show_additionalPathSlots(object)
})
setMethod(detail, "SolexaPath", function(x, ...) {
callNextMethod()
.detail_additionalPathSlots(x)
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.