blob: d9b589cc22aed3b461c86712327b1c4d369fb31d [file] [log] [blame]
Marc Kupietze95108e2019-09-18 13:23:58 +02001#' Class KorAPQuery
2#'
3#' \code{KorAPQuery} objetcs represent the current state of a query to a KorAP server.
4#' New \code{KorAPQuery} objects are typically created by the \code{\link{corpusQuery}} method.
5#'
6#' @include KorAPConnection.R
Marc Kupietze95108e2019-09-18 13:23:58 +02007#' @import httr
8#'
Marc Kupietz4de53ec2019-10-04 09:12:00 +02009#' @include RKorAPClient.R
Marc Kupietz5bbc9db2019-08-30 16:30:45 +020010
Marc Kupietze95108e2019-09-18 13:23:58 +020011#' @export
12KorAPQuery <- setClass("KorAPQuery", slots = c(
Marc Kupietzb8972182019-09-20 21:33:46 +020013 "korapConnection",
Marc Kupietze95108e2019-09-18 13:23:58 +020014 "request",
15 "vc",
16 "totalResults",
17 "nextStartIndex",
18 "fields",
19 "requestUrl",
20 "webUIRequestUrl",
21 "apiResponse",
22 "collectedMatches",
23 "hasMoreMatches"
24))
Marc Kupietz5bbc9db2019-08-30 16:30:45 +020025
Marc Kupietze95108e2019-09-18 13:23:58 +020026#' Method initialize
27#'
28#' @rdname KorAPQuery-class
29#' @param .Object …
Marc Kupietzb8972182019-09-20 21:33:46 +020030#' @param korapConnection KorAPConnection object
Marc Kupietze95108e2019-09-18 13:23:58 +020031#' @param request query part of the request URL
32#' @param vc definition of a virtual corpus
33#' @param totalResults number of hits the query has yielded
34#' @param nextStartIndex at what index to start the next fetch of query results
35#' @param fields what data / metadata fields should be collected
36#' @param requestUrl complete URL of the API request
37#' @param webUIRequestUrl URL of a web frontend request corresponding to the API request
38#' @param apiResponse data-frame representation of the JSON response of the API request
Marc Kupietz7776dec2019-09-27 16:59:02 +020039#' @param hasMoreMatches logical that signals if more query results can be fetched
Marc Kupietze95108e2019-09-18 13:23:58 +020040#' @param collectedMatches matches already fetched from the KorAP-API-server
Marc Kupietz97a1bca2019-10-04 22:52:09 +020041#'
42#' @importFrom tibble tibble
Marc Kupietze95108e2019-09-18 13:23:58 +020043#' @export
44setMethod("initialize", "KorAPQuery",
Marc Kupietzb8972182019-09-20 21:33:46 +020045 function(.Object, korapConnection = NULL, request = NULL, vc="", totalResults=0, nextStartIndex=0, fields=c("corpusSigle", "textSigle", "pubDate", "pubPlace",
Marc Kupietze95108e2019-09-18 13:23:58 +020046 "availability", "textClass", "snippet"),
47 requestUrl="", webUIRequestUrl = "", apiResponse = NULL, hasMoreMatches= FALSE, collectedMatches = NULL) {
48 .Object <- callNextMethod()
Marc Kupietzb8972182019-09-20 21:33:46 +020049 .Object@korapConnection = korapConnection
Marc Kupietze95108e2019-09-18 13:23:58 +020050 .Object@request = request
51 .Object@vc = vc
52 .Object@totalResults = totalResults
53 .Object@nextStartIndex = nextStartIndex
54 .Object@fields = fields
55 .Object@requestUrl = requestUrl
56 .Object@webUIRequestUrl = webUIRequestUrl
57 .Object@apiResponse = apiResponse
58 .Object@hasMoreMatches = hasMoreMatches
59 .Object@collectedMatches = collectedMatches
60 .Object
61 })
Marc Kupietz632cbd42019-09-06 16:04:51 +020062
Marc Kupietze95108e2019-09-18 13:23:58 +020063setGeneric("corpusQuery", function(kco, ...) standardGeneric("corpusQuery") )
64setGeneric("fetchAll", function(kqo, ...) standardGeneric("fetchAll") )
65setGeneric("fetchNext", function(kqo, ...) standardGeneric("fetchNext") )
66setGeneric("fetchRest", function(kqo, ...) standardGeneric("fetchRest") )
Marc Kupietz3f575282019-10-04 14:46:04 +020067setGeneric("frequencyQuery", function(kco, ...) standardGeneric("frequencyQuery") )
Marc Kupietze95108e2019-09-18 13:23:58 +020068
69maxResultsPerPage <- 50
Marc Kupietz62da2b52019-09-12 17:43:34 +020070
Marc Kupietz632cbd42019-09-06 16:04:51 +020071QueryParameterFromUrl <- function(url, parameter) {
72 regex <- paste0(".*[?&]", parameter, "=([^&]*).*")
73 if (grepl(regex, url)) {
74 return(gsub(regex, '\\1', url, perl = TRUE))
75 } else {
76 return("")
77 }
Marc Kupietz5bbc9db2019-08-30 16:30:45 +020078}
79
Marc Kupietz4de53ec2019-10-04 09:12:00 +020080## quiets concerns of R CMD check re: the .'s that appear in pipelines
81if(getRversion() >= "2.15.1") utils::globalVariables(c("."))
Marc Kupietz632cbd42019-09-06 16:04:51 +020082
Marc Kupietze95108e2019-09-18 13:23:58 +020083#' Method corpusQuery
84#'
85#' Perform a corpus query via a connection to a KorAP-API-server.
86#'
87#' @param kco \code{\link{KorAPConnection}} object (obtained e.g. from \code{new("KorAPConnection")}
Akron5e135462019-09-27 16:31:38 +020088#' @param query string that contains the corpus query. The query language depends on the \code{ql} parameter. Either \code{query} must be provided or \code{KorAPUrl}.
Marc Kupietz632cbd42019-09-06 16:04:51 +020089#' @param vc string describing the virtual corpus in which the query should be performed. An empty string (default) means the whole corpus, as far as it is license-wise accessible.
90#' @param KorAPUrl instead of providing the query and vc string parameters, you can also simply copy a KorAP query URL from your browser and use it here (and in \code{KorAPConnection}) to provide all necessary information for the query.
Marc Kupietz7776dec2019-09-27 16:59:02 +020091#' @param metadataOnly logical that determines whether queries should return only metadata without any snippets. This can also be useful to prevent access rewrites. Note that the default value is TRUE, unless the connection is authorized (currently not possible).
Marc Kupietz3c531f62019-09-13 12:17:24 +020092#' @param ql string to choose the query language (see \href{https://github.com/KorAP/Kustvakt/wiki/Service:-Search-GET#user-content-parameters}{section on Query Parameters} in the Kustvakt-Wiki for possible values.
Akron5e135462019-09-27 16:31:38 +020093#' @param fields (meta)data fields that will be fetched for every match.
94#' @param accessRewriteFatal abort if query or given vc had to be rewritten due to insufficent rights (not yet implemented).
Marc Kupietz25aebc32019-09-16 18:40:50 +020095#' @param verbose print some info
Marc Kupietz4de53ec2019-10-04 09:12:00 +020096#' @param as.df return result as data frame instead of as S4 object?
Marc Kupietz3f575282019-10-04 14:46:04 +020097#' @param expand logical that deicdes if \code{query} and \code{vc} parameters are expanded to all of their combinations
98#' @return Depending on the \code{as.df} parameter, a table or a \code{\link{KorAPQuery}} object that, among other information, contains the total number of results in \code{@totalResults}. The resulting object can be used to fetch all query results (with \code{\link{fetchAll}}) or the next page of results (with \code{\link{fetchNext}}).
Marc Kupietze95108e2019-09-18 13:23:58 +020099#' A corresponding URL to be used within a web browser is contained in \code{@webUIRequestUrl}
Marc Kupietz62da2b52019-09-12 17:43:34 +0200100#' Please make sure to check \code{$collection$rewrites} to see if any unforseen access rewrites of the query's virtual corpus had to be performed.
Marc Kupietz632cbd42019-09-06 16:04:51 +0200101#'
102#' @examples
Marc Kupietz603491f2019-09-18 14:01:02 +0200103#' # Fetch metadata of every query hit for "Ameisenplage" and show a summary
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200104#' new("KorAPConnection") %>% corpusQuery("Ameisenplage") %>% fetchAll()
Marc Kupietz3c531f62019-09-13 12:17:24 +0200105#'
Marc Kupietz603491f2019-09-18 14:01:02 +0200106#' # Use the copy of a KorAP-web-frontend URL for an API query of "Ameise" in a virtual corpus
107#' # and show the number of query hits (but don't fetch them).
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200108#'
109#' new("KorAPConnection", verbose = TRUE) %>%
110#' corpusQuery(KorAPUrl =
111#' "https://korap.ids-mannheim.de/?q=Ameise&cq=pubDate+since+2017&ql=poliqarp")
Marc Kupietz3c531f62019-09-13 12:17:24 +0200112#'
Marc Kupietz603491f2019-09-18 14:01:02 +0200113#' # Plot the time/frequency curve of "Ameisenplage"
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200114#' new("KorAPConnection", verbose=TRUE) %>%
115#' { . ->> kco } %>%
116#' corpusQuery("Ameisenplage") %>%
117#' fetchAll() %>%
118#' slot("collectedMatches") %>%
119#' mutate(year = lubridate::year(pubDate)) %>%
Marc Kupietz19e2ebd2019-10-07 11:45:30 +0200120#' dplyr::select(year) %>%
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200121#' group_by(year) %>%
122#' summarise(Count = n()) %>%
123#' mutate(Freq = mapply(function(f, y)
124#' f / corpusStats(kco, paste("pubDate in", y))@tokens, Count, year)) %>%
Marc Kupietz19e2ebd2019-10-07 11:45:30 +0200125#' dplyr::select(-Count) %>%
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200126#' complete(year = min(year):max(year), fill = list(Freq = 0)) %>%
127#' plot(type = "l")
Marc Kupietz37b8ef12019-09-16 18:37:49 +0200128#'
Marc Kupietze95108e2019-09-18 13:23:58 +0200129#' @seealso \code{\link{KorAPConnection}}, \code{\link{fetchNext}}, \code{\link{fetchRest}}, \code{\link{fetchAll}}, \code{\link{corpusStats}}
Marc Kupietz632cbd42019-09-06 16:04:51 +0200130#'
131#' @references
132#' \url{https://ids-pub.bsz-bw.de/frontdoor/index/index/docId/9026}
133#'
Marc Kupietze95108e2019-09-18 13:23:58 +0200134#' @aliases corpusQuery
Marc Kupietz632cbd42019-09-06 16:04:51 +0200135#' @export
Marc Kupietze95108e2019-09-18 13:23:58 +0200136setMethod("corpusQuery", "KorAPConnection",
Marc Kupietz4de53ec2019-10-04 09:12:00 +0200137 function(kco,
138 query = ifelse(missing(KorAPUrl),
139 stop("At least one of the parameters query and KorAPUrl must be specified.", call. = FALSE),
140 httr::parse_url(KorAPUrl)$query$q),
141 vc = ifelse(missing(KorAPUrl), "", httr::parse_url(KorAPUrl)$query$cq),
142 KorAPUrl,
143 metadataOnly = TRUE,
144 ql = ifelse(missing(KorAPUrl), "poliqarp", httr::parse_url(KorAPUrl)$query$ql),
145 fields = c("corpusSigle", "textSigle", "pubDate", "pubPlace",
146 "availability", "textClass", "snippet"),
147 accessRewriteFatal = TRUE,
148 verbose = kco@verbose,
Marc Kupietz3f575282019-10-04 14:46:04 +0200149 expand = length(vc) != length(query),
Marc Kupietz4de53ec2019-10-04 09:12:00 +0200150 as.df = FALSE) {
Marc Kupietz3f575282019-10-04 14:46:04 +0200151 ifelse(length(query) > 1 || length(vc) > 1, {
152 grid <- { if (expand) expand_grid(query=query, vc=vc) else tibble(query=query, vc=vc) }
153 return(
Marc Kupietz4de53ec2019-10-04 09:12:00 +0200154 do.call(rbind,
Marc Kupietz3f575282019-10-04 14:46:04 +0200155 Map(function(q, cq) corpusQuery(kco, query=q, vc=cq, ql=ql,
156 verbose=verbose, as.df = TRUE), grid$query, grid$vc)) %>%
157 remove_rownames()
Marc Kupietz4de53ec2019-10-04 09:12:00 +0200158 )}, {
159 contentFields <- c("snippet")
Marc Kupietz4862b862019-11-07 10:13:53 +0100160 if(metadataOnly) {
161 fields <- fields[!fields %in% contentFields]
162 }
Marc Kupietz4de53ec2019-10-04 09:12:00 +0200163 request <- paste0('?q=', URLencode(query, reserved=TRUE),
164 ifelse(vc != '', paste0('&cq=', URLencode(vc, reserved=TRUE)), ''), '&ql=', ql)
165 webUIRequestUrl <- paste0(kco@KorAPUrl, request)
166 requestUrl <- paste0(kco@apiUrl, 'search', request,
167 '&fields=', paste(fields, collapse = ","),
168 ifelse(metadataOnly, '&access-rewrite-disabled=true', ''))
169 log.info(verbose, "Searching \"", query, "\" in \"", vc, "\"", sep="")
170 res = apiCall(kco, paste0(requestUrl, '&count=0'))
171 log.info(verbose, " took ", res$meta$benchmark, "\n", sep="")
172 ifelse(as.df,
173 return(data.frame(query=query,
174 totalResults=res$meta$totalResults,
175 vc=vc,
176 webUIRequestUrl=webUIRequestUrl, stringsAsFactors = FALSE)),
177 return(KorAPQuery(
178 korapConnection = kco,
179 nextStartIndex = 0,
180 fields = fields,
181 requestUrl = requestUrl,
182 request = request,
183 totalResults = res$meta$totalResults,
184 vc = vc,
185 apiResponse = res,
186 webUIRequestUrl = webUIRequestUrl,
187 hasMoreMatches = (res$meta$totalResults > 0),
188 )))})
189 })
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200190
Marc Kupietz62da2b52019-09-12 17:43:34 +0200191#' Fetch the next bunch of results of a KorAP query.
Marc Kupietze95108e2019-09-18 13:23:58 +0200192#'
Marc Kupietz3f575282019-10-04 14:46:04 +0200193#' \bold{\code{fetchNext}} fetches the next bunch of results of a KorAP query.
194#'
Marc Kupietze95108e2019-09-18 13:23:58 +0200195#' @param kqo object obtained from \code{\link{corpusQuery}}
Marc Kupietz62da2b52019-09-12 17:43:34 +0200196#' @param offset start offset for query results to fetch
197#' @param maxFetch maximum number of query results to fetch
Marc Kupietz25aebc32019-09-16 18:40:50 +0200198#' @param verbose print progress information if true
Marc Kupietze95108e2019-09-18 13:23:58 +0200199#' @return The \code{kqo} input object with updated slots \code{collectedMatches}, \code{apiResponse}, \code{nextStartIndex}, \code{hasMoreMatches}
Marc Kupietz62da2b52019-09-12 17:43:34 +0200200#'
201#' @references
202#' \url{https://ids-pub.bsz-bw.de/frontdoor/index/index/docId/9026}
203#'
Marc Kupietze95108e2019-09-18 13:23:58 +0200204#' @aliases fetchNext
205#' @rdname KorAPQuery-class
Marc Kupietz97a1bca2019-10-04 22:52:09 +0200206#' @importFrom purrr map_dfr
Marc Kupietz19e2ebd2019-10-07 11:45:30 +0200207#' @importFrom dplyr rowwise bind_rows select
Marc Kupietz632cbd42019-09-06 16:04:51 +0200208#' @export
Marc Kupietzf6f71312019-09-23 18:35:27 +0200209setMethod("fetchNext", "KorAPQuery", function(kqo, offset = kqo@nextStartIndex, maxFetch = maxResultsPerPage, verbose = kqo@korapConnection@verbose) {
Marc Kupietze95108e2019-09-18 13:23:58 +0200210 if (kqo@totalResults == 0 || offset >= kqo@totalResults) {
211 return(kqo)
Marc Kupietz62da2b52019-09-12 17:43:34 +0200212 }
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200213
214 page <- 1
215 results <- 0
Marc Kupietz25aebc32019-09-16 18:40:50 +0200216 pubDate <- NULL # https://stackoverflow.com/questions/8096313/no-visible-binding-for-global-variable-note-in-r-cmd-check
Marc Kupietze95108e2019-09-18 13:23:58 +0200217 collectedMatches <- kqo@collectedMatches
Marc Kupietz62da2b52019-09-12 17:43:34 +0200218
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200219 repeat {
Marc Kupietzd0d3e9b2019-09-24 17:36:03 +0200220 res <- apiCall(kqo@korapConnection, paste0(kqo@requestUrl, '&count=', min(ifelse(!is.na(maxFetch), maxFetch - results, maxResultsPerPage), maxResultsPerPage) ,'&offset=', offset + results))
Marc Kupietze95108e2019-09-18 13:23:58 +0200221 if (res$meta$totalResults == 0) { return(kqo) }
222 for (field in kqo@fields) {
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200223 if (!field %in% colnames(res$matches)) {
224 res$matches[, field] <- NA
225 }
226 }
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200227 currentMatches <-
228 kqo@fields %>%
229 map_dfr( ~tibble(!!.x := logical() ) ) %>%
230 bind_rows(res$matches) %>%
Marc Kupietz19e2ebd2019-10-07 11:45:30 +0200231 dplyr::select(kqo@fields)
Marc Kupietz36d12d92019-09-27 18:13:27 +0200232 if ("pubDate" %in% kqo@fields) {
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200233 currentMatches$pubDate <- currentMatches$pubDate %>% as.Date(format = "%Y-%m-%d")
234 factorCols <- currentMatches %>% select(-pubDate) %>% colnames()
Marc Kupietz36d12d92019-09-27 18:13:27 +0200235 } else {
236 factorCols <- colnames(currentMatches)
237 }
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200238 currentMatches[factorCols] <- lapply(currentMatches[factorCols], factor)
Marc Kupietz62da2b52019-09-12 17:43:34 +0200239 if (!is.list(collectedMatches)) {
240 collectedMatches <- currentMatches
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200241 } else {
Marc Kupietz62da2b52019-09-12 17:43:34 +0200242 collectedMatches <- rbind(collectedMatches, currentMatches)
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200243 }
Marc Kupietzc2c59bd2019-08-30 16:50:49 +0200244 if (verbose) {
Marc Kupietzf6f71312019-09-23 18:35:27 +0200245 cat(paste0("Retrieved page ", page, "/", ceiling((res$meta$totalResults) / res$meta$itemsPerPage), ' in ', res$meta$benchmark, '\n'))
Marc Kupietzc2c59bd2019-08-30 16:50:49 +0200246 }
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200247 page <- page + 1
248 results <- results + res$meta$itemsPerPage
Marc Kupietz62da2b52019-09-12 17:43:34 +0200249 if (offset + results >= res$meta$totalResults || (!is.na(maxFetch) && results >= maxFetch)) {
Marc Kupietz5bbc9db2019-08-30 16:30:45 +0200250 break
251 }
252 }
Marc Kupietze95108e2019-09-18 13:23:58 +0200253 nextStartIndex <- min(res$meta$startIndex + res$meta$itemsPerPage, res$meta$totalResults)
254 KorAPQuery(nextStartIndex = nextStartIndex,
Marc Kupietzd0d3e9b2019-09-24 17:36:03 +0200255 korapConnection = kqo@korapConnection,
Marc Kupietze95108e2019-09-18 13:23:58 +0200256 fields = kqo@fields,
257 requestUrl = kqo@requestUrl,
258 request = kqo@request,
259 totalResults = res$meta$totalResults,
260 vc = kqo@vc,
261 webUIRequestUrl = kqo@webUIRequestUrl,
262 hasMoreMatches = (res$meta$totalResults > nextStartIndex),
263 apiResponse = res,
264 collectedMatches = collectedMatches)
265})
Marc Kupietz62da2b52019-09-12 17:43:34 +0200266
267#' Fetch all results of a KorAP query.
Marc Kupietz62da2b52019-09-12 17:43:34 +0200268#'
269#' @examples
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200270#' q <- new("KorAPConnection") %>% corpusQuery("Ameisenplage") %>% fetchAll()
Marc Kupietze95108e2019-09-18 13:23:58 +0200271#' q@collectedMatches
Marc Kupietz62da2b52019-09-12 17:43:34 +0200272#'
Marc Kupietze95108e2019-09-18 13:23:58 +0200273#' @aliases fetchAll
274#' @rdname KorAPQuery-class
Marc Kupietz62da2b52019-09-12 17:43:34 +0200275#' @export
Marc Kupietzf6f71312019-09-23 18:35:27 +0200276setMethod("fetchAll", "KorAPQuery", function(kqo, verbose = kqo@korapConnection@verbose) {
Marc Kupietze95108e2019-09-18 13:23:58 +0200277 return(fetchNext(kqo, offset = 0, maxFetch = NA, verbose = verbose))
278})
279
280#' Fetches the remaining results of a KorAP query.
281#'
282#' @examples
Marc Kupietz69cc54a2019-09-30 12:06:54 +0200283#' q <- new("KorAPConnection") %>% corpusQuery("Ameisenplage") %>% fetchAll()
Marc Kupietze95108e2019-09-18 13:23:58 +0200284#' q@collectedMatches
285#'
286#' @aliases fetchRest
287#' @rdname KorAPQuery-class
288#' @export
Marc Kupietzf6f71312019-09-23 18:35:27 +0200289setMethod("fetchRest", "KorAPQuery", function(kqo, verbose = kqo@korapConnection@verbose) {
Marc Kupietze95108e2019-09-18 13:23:58 +0200290 return(fetchNext(kqo, maxFetch = NA, verbose = verbose))
291})
292
Marc Kupietz3f575282019-10-04 14:46:04 +0200293#' Query relative frequency of search term(s)
294#'
295#' \bold{\code{frequencyQuery}} combines \code{\link{corpusQuery}}, \code{\link{corpusStats}} and
296#' \code{\link{ci}} to compute a table with the relative frequencies and
297#' confidence intervals of one ore multiple search terms across one or multiple
298#' virtual corpora.
299#'
300#' @aliases frequencyQuery
301#' @rdname KorAPQuery-class
302#' @examples
303#' new("KorAPConnection", verbose = TRUE) %>%
304#' frequencyQuery(c("Mücke", "Schnake"), paste0("pubDate in ", 2000:2003))
305#'
306#' @param kco \code{\link{KorAPConnection}} object (obtained e.g. from \code{new("KorAPConnection")}
307#' @param query string that contains the corpus query. The query language depends on the \code{ql} parameter. Either \code{query} must be provided or \code{KorAPUrl}.
Marc Kupietz0c29cea2019-10-09 08:44:36 +0200308#' @param conf.level confidence level of the returned confidence interval (passed throgh \code{\link{ci}} to \code{\link{prop.test}}).
Marc Kupietz3f575282019-10-04 14:46:04 +0200309#' @export
310setMethod("frequencyQuery", "KorAPConnection",
Marc Kupietz0c29cea2019-10-09 08:44:36 +0200311 function(kco, query, vc = "", conf.level = 0.95, ...) {
312 corpusQuery(kco, query, vc, metadataOnly = TRUE, as.df = TRUE, ...) %>%
Marc Kupietz3f575282019-10-04 14:46:04 +0200313 mutate(tokens=corpusStats(kco, vc=vc, as.df=TRUE)$tokens) %>%
Marc Kupietz0c29cea2019-10-09 08:44:36 +0200314 ci(conf.level = conf.level)
Marc Kupietz3f575282019-10-04 14:46:04 +0200315})
316
Marc Kupietze95108e2019-09-18 13:23:58 +0200317#´ format()
318#' @rdname KorAPQuery-class
319#' @param x KorAPQuery object
320#' @param ... further arguments passed to or from other methods
321#' @export
322format.KorAPQuery <- function(x, ...) {
323 cat("<KorAPQuery>\n")
324 q <- x
325 aurl = parse_url(q@request)
326 cat(" Query: ", aurl$query$q, "\n")
327 if (!is.null(aurl$query$vc) && aurl$query$vc != "") {
328 cat("Virtual corpus: ", aurl$query$vc, "\n")
329 }
330 if (!is.null(q@collectedMatches)) {
331 cat("==============================================================================================================", "\n")
332 print(summary(q@collectedMatches))
333 cat("==============================================================================================================", "\n")
334 }
335 cat(" Total results: ", q@totalResults, "\n")
336 cat(" Fetched results: ", q@nextStartIndex, "\n")
Marc Kupietz62da2b52019-09-12 17:43:34 +0200337}
338
Marc Kupietze95108e2019-09-18 13:23:58 +0200339#' show()
Marc Kupietz62da2b52019-09-12 17:43:34 +0200340#'
Marc Kupietze95108e2019-09-18 13:23:58 +0200341#' @rdname KorAPQuery-class
342#' @param object KorAPQuery object
Marc Kupietz62da2b52019-09-12 17:43:34 +0200343#' @export
Marc Kupietze95108e2019-09-18 13:23:58 +0200344setMethod("show", "KorAPQuery", function(object) {
345 format(object)
346})