comparison PubchemConn.R @ 0:e66bb061af06 draft

planemo upload for repository https://github.com/workflow4metabolomics/lcmsmatching.git commit 3529b25417f8e1a5836474c9adec4b696d35099d-dirty
author prog
date Tue, 12 Jul 2016 12:02:37 -0400
parents
children 253d531a0193
comparison
equal deleted inserted replaced
-1:000000000000 0:e66bb061af06
1 if ( ! exists('get.pubchem.compound.url')) { # Do not load again if already loaded
2
3 source('BiodbConn.R')
4 source('PubchemCompound.R')
5
6 #####################
7 # CLASS DECLARATION #
8 #####################
9
10 PubchemConn <- setRefClass("PubchemConn", contains = "BiodbConn")
11
12 ##########################
13 # GET ENTRY CONTENT TYPE #
14 ##########################
15
16 PubchemConn$methods( getEntryContentType = function(type) {
17 return(RBIODB.XML)
18 })
19
20 #####################
21 # GET ENTRY CONTENT #
22 #####################
23
24 PubchemConn$methods( getEntryContent = function(type, id) {
25
26 if (type == RBIODB.COMPOUND) {
27
28 # Initialize return values
29 content <- rep(NA_character_, length(id))
30
31 # Request
32 content <- vapply(id, function(x) .self$.scheduler$getUrl(get.entry.url(RBIODB.PUBCHEM, x, content.type = RBIODB.XML)), FUN.VALUE = '')
33
34 return(content)
35 }
36
37 return(NULL)
38 })
39
40 ################
41 # CREATE ENTRY #
42 ################
43
44 PubchemConn$methods( createEntry = function(type, content, drop = TRUE) {
45 return(if (type == RBIODB.COMPOUND) createPubchemCompoundFromXml(content, drop = drop) else NULL)
46 })
47
48 #########################
49 # GET PUBCHEM IMAGE URL #
50 #########################
51
52 get.pubchem.image.url <- function(id) {
53
54 url <- paste0('http://pubchem.ncbi.nlm.nih.gov/image/imgsrv.fcgi?cid=', id, '&t=l')
55
56 return(url)
57 }
58
59 } # end of load safe guard