bel 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,106 @@
1
+ # vim: ts=2 sw=2:
2
+ require 'open-uri'
3
+ require_relative './language'
4
+
5
+ class String
6
+ def split_by_last(char=" ")
7
+ pos = self.rindex(char)
8
+ pos != nil ? [self[0...pos], self[pos+1..-1]] : [self]
9
+ end
10
+ end
11
+
12
+ module BEL
13
+ module Namespace
14
+
15
+ NAMESPACE_HASH = {
16
+ HGU95AV2: 'http://resource.belframework.org/belframework/1.0/namespace/affy-hg-u95av2.belns',
17
+ HGU133P2: 'http://resource.belframework.org/belframework/1.0/namespace/affy-hg-u133-plus2.belns',
18
+ HGU133AB: 'http://resource.belframework.org/belframework/1.0/namespace/affy-hg-u133ab.belns',
19
+ MGU74ABC: 'http://resource.belframework.org/belframework/1.0/namespace/affy-mg-u74abc.belns',
20
+ MG430AB: 'http://resource.belframework.org/belframework/1.0/namespace/affy-moe430ab.belns',
21
+ MG4302: 'http://resource.belframework.org/belframework/1.0/namespace/affy-mouse430-2.belns',
22
+ MG430A2: 'http://resource.belframework.org/belframework/1.0/namespace/affy-mouse430a-2.belns',
23
+ RG230AB: 'http://resource.belframework.org/belframework/1.0/namespace/affy-rae230ab-2.belns',
24
+ RG2302: 'http://resource.belframework.org/belframework/1.0/namespace/affy-rat230-2.belns',
25
+ CHEBIID: 'http://resource.belframework.org/belframework/1.0/namespace/chebi-ids.belns',
26
+ CHEBI: 'http://resource.belframework.org/belframework/1.0/namespace/chebi-names.belns',
27
+ EGID: 'http://resource.belframework.org/belframework/1.0/namespace/entrez-gene-ids-hmr.belns',
28
+ GOAC: 'http://resource.belframework.org/belframework/1.0/namespace/go-biological-processes-accession-numbers.belns',
29
+ GO: 'http://resource.belframework.org/belframework/1.0/namespace/go-biological-processes-names.belns',
30
+ GOCCACC: 'http://resource.belframework.org/belframework/1.0/namespace/go-cellular-component-accession-numbers.belns',
31
+ GOCCTERM: 'http://resource.belframework.org/belframework/1.0/namespace/go-cellular-component-terms.belns',
32
+ HGNC: 'http://resource.belframework.org/belframework/1.0/namespace/hgnc-approved-symbols.belns',
33
+ MESHPP: 'http://resource.belframework.org/belframework/1.0/namespace/mesh-biological-processes.belns',
34
+ MESHCL: 'http://resource.belframework.org/belframework/1.0/namespace/mesh-cellular-locations.belns',
35
+ MESHD: 'http://resource.belframework.org/belframework/1.0/namespace/mesh-diseases.belns',
36
+ MGI: 'http://resource.belframework.org/belframework/1.0/namespace/mgi-approved-symbols.belns',
37
+ RGD: 'http://resource.belframework.org/belframework/1.0/namespace/rgd-approved-symbols.belns',
38
+ SCHEM: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-legacy-chemical-names.belns',
39
+ SDIS: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-legacy-diseases.belns',
40
+ NCH: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-named-human-complexes.belns',
41
+ PFH: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-named-human-protein-families.belns',
42
+ NCM: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-named-mouse-complexes.belns',
43
+ PFM: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-named-mouse-protein-families.belns',
44
+ NCR: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-named-rat-complexes.belns',
45
+ PFR: 'http://resource.belframework.org/belframework/1.0/namespace/selventa-named-rat-protein-families.belns',
46
+ SPAC: 'http://resource.belframework.org/belframework/1.0/namespace/swissprot-accession-numbers.belns',
47
+ SP: 'http://resource.belframework.org/belframework/1.0/namespace/swissprot-entry-names.belns'
48
+ }
49
+
50
+ class NamespaceDefinition
51
+ include Enumerable
52
+
53
+ attr_reader :url
54
+ attr_reader :values
55
+
56
+ def initialize(prefix, url)
57
+ @prefix = prefix
58
+ @url = url
59
+ @values = nil
60
+ end
61
+
62
+ def [](value)
63
+ return nil unless value
64
+
65
+ reload(@url) if not @values
66
+ sym = value.to_sym
67
+ Language::Parameter.new(@prefix, sym,
68
+ @values[sym]) if @values.key?(sym)
69
+ end
70
+
71
+ def each &block
72
+ reload(@url) if not @values
73
+ ns = @prefix.to_sym
74
+ @values.each do |val, enc|
75
+ if block_given?
76
+ block.call(Language::Parameter.new(ns, val, enc))
77
+ else
78
+ yield Language::Parameter.new(ns, val, enc)
79
+ end
80
+ end
81
+ end
82
+
83
+ private
84
+ # the backdoor
85
+ def reload(url)
86
+ @values = {}
87
+ open(url).
88
+ drop_while { |i| not i.start_with? "[Values]" }.
89
+ drop(1).
90
+ each do |s|
91
+ val_enc = s.strip!.split_by_last('|').map(&:to_sym)
92
+ @values[val_enc[0]] = val_enc[1]
93
+ end
94
+ end
95
+ end
96
+
97
+ # create classes for each standard prefix
98
+ DEFAULT_NAMESPACES = [
99
+ NAMESPACE_HASH.collect do |prefix, default_url|
100
+ ns_definition = NamespaceDefinition.new(prefix, default_url)
101
+ Namespace.const_set(prefix, ns_definition)
102
+ ns_definition
103
+ end
104
+ ]
105
+ end
106
+ end
@@ -0,0 +1,184 @@
1
+ # vim: ts=2 sw=2:
2
+ require_relative 'grammar/lexer.rb'
3
+ require_relative 'grammar/parser.rb'
4
+
5
+ module BEL
6
+ module Script
7
+ DocumentProperty = Struct.new(:property, :value)
8
+ NamespaceDefinition = Struct.new(:keyword, :url, :default?)
9
+ AnnotationListDefinition = Struct.new(:keyword, :values)
10
+ AnnotationPatternDefinition = Struct.new(:keyword, :pattern)
11
+ AnnotationUrlDefinition = Struct.new(:keyword, :url)
12
+ SetStatementGroup = Struct.new(:name)
13
+ UnsetStatementGroup = Struct.new(:name)
14
+ SetAnnotation = Struct.new(:keyword, :value)
15
+ ParameterDefinition = Struct.new(:namespace, :value)
16
+ TermDefinition = Struct.new(:function, :arguments)
17
+ StatementDefinition = Struct.new(:subject, :rel, :object,
18
+ :comment) do
19
+ def subject_only?
20
+ !rel
21
+ end
22
+ def simple?
23
+ object.is_a? TermDefinition
24
+ end
25
+ def nested?
26
+ object.is_a? StatementDefinition
27
+ end
28
+ end
29
+
30
+ module Parser
31
+
32
+ def self.parse(source)
33
+ return nil if not source
34
+
35
+ antlr_parser = BEL::Script::Parser::Parser.new(source)
36
+ if block_given? then
37
+ yield from_tree(antlr_parser.document.tree)
38
+ else
39
+ from_tree(antlr_parser.document.tree)
40
+ end
41
+ end
42
+
43
+ def self.parse_record(source)
44
+ return nil if not source
45
+
46
+ BEL::Script::Parser::Parser.new(source)
47
+ if block_given?
48
+ source.each_line do |line|
49
+ antlr_parser = BEL::Script::Parser::Parser.new(line)
50
+ record_ret = antlr_parser.record
51
+ if record_ret.tree.length > 0
52
+ yield from_tree(record_ret.tree)
53
+ end
54
+ end
55
+ else
56
+ parsed_lines = []
57
+ source.each_line do |line|
58
+ line.tr!("\r\n", '')
59
+ antlr_parser = BEL::Script::Parser::Parser.new(line)
60
+ record_ret = antlr_parser.record
61
+ if record_ret.tree.length > 0
62
+ parsed_lines << from_tree(record_ret.tree)
63
+ end
64
+ end
65
+ return parsed_lines
66
+ end
67
+ end
68
+
69
+ private
70
+
71
+ def self.from_tree(tree)
72
+ case tree.name
73
+ when 'DOCDEF'
74
+ tree.children.map { |x| from_tree(x) }
75
+ when 'DOCSET_ID'
76
+ BEL::Script::DocumentProperty.new(
77
+ tree.children[0].text,
78
+ tree.children[1].text)
79
+ when 'DOCSET_QV'
80
+ value = tree.children[1].text[1...-1]
81
+ BEL::Script::DocumentProperty.new(
82
+ tree.children[0].text,
83
+ value)
84
+ when 'DOCSET_LIST'
85
+ values = tree.children[1].text[1...-1].split(' ,')
86
+ BEL::Script::DocumentProperty.new(
87
+ tree.children[0].text,
88
+ values)
89
+ when 'NSDEF'
90
+ BEL::Script::NamespaceDefinition.new(
91
+ tree.children[0].text,
92
+ tree.children[1].text,
93
+ false)
94
+ when 'DFLT_NSDEF'
95
+ BEL::Script::NamespaceDefinition.new(
96
+ tree.children[0].text,
97
+ tree.children[1].text,
98
+ true)
99
+ when 'ANNO_DEF_LIST'
100
+ values = tree.children[1].text[1...-1].split(' ,')
101
+ BEL::Script::AnnotationListDefinition.new(
102
+ tree.children[0].text,
103
+ values)
104
+ when 'ANNO_DEF_PTRN'
105
+ BEL::Script::AnnotationListDefinition.new(
106
+ tree.children[0].text,
107
+ tree.children[1].text)
108
+ when 'ANNO_DEF_URL'
109
+ BEL::Script::AnnotationListDefinition.new(
110
+ tree.children[0].text,
111
+ tree.children[1].text)
112
+ when 'ANNO_SET_ID'
113
+ BEL::Script::SetAnnotation.new(
114
+ tree.children[0].text,
115
+ tree.children[1].text)
116
+ when 'ANNO_SET_LIST'
117
+ values = tree.children[1].text[1...-1].split(' ,')
118
+ BEL::Script::SetAnnotation.new(
119
+ tree.children[0].text,
120
+ values)
121
+ when 'ANNO_SET_QV'
122
+ BEL::Script::SetAnnotation.new(
123
+ tree.children[0].text,
124
+ tree.children[1].text)
125
+ when 'SG_SET_ID'
126
+ BEL::Script::SetStatementGroup.new(tree.children[0].text)
127
+ when 'SG_SET_QV'
128
+ value = tree.children[0].text[1...-1]
129
+ BEL::Script::SetStatementGroup.new(value)
130
+ when 'PARAM_DEF_ID'
131
+ if tree.children.length == 2
132
+ BEL::Script::ParameterDefinition.new(
133
+ tree.children[0].text,
134
+ tree.children[1].text)
135
+ else
136
+ BEL::Script::ParameterDefinition.new(
137
+ nil,
138
+ tree.children[0].text)
139
+ end
140
+ when 'PARAM_DEF_QV'
141
+ if tree.children.length == 2
142
+ value = tree.children[1].text[1...-1]
143
+ BEL::Script::ParameterDefinition.new(
144
+ tree.children[0].text,
145
+ value)
146
+ else
147
+ value = tree.children[0].text[1...-1]
148
+ BEL::Script::ParameterDefinition.new(
149
+ nil,
150
+ value)
151
+ end
152
+ when 'TERMDEF'
153
+ func = tree.children[0].text
154
+ args = tree.children[1..-1].map { |x| from_tree(x) }
155
+ BEL::Script::TermDefinition.new(func, args)
156
+ when 'STMTDEF'
157
+ comment = nil
158
+ if tree.children[0].text.start_with? '//'
159
+ comment = tree.children[0].text[2..-1]
160
+ tree.children.shift
161
+ end
162
+
163
+ if tree.children.length == 1
164
+ sub = from_tree(tree.children[0])
165
+ BEL::Script::StatementDefinition.new(sub, nil, nil, comment)
166
+ else
167
+ obj = from_tree(tree.children.pop)
168
+ while tree.children.length > 0
169
+ rel = tree.children.pop
170
+ sub = from_tree(tree.children.pop)
171
+ obj = BEL::Script::StatementDefinition.new(sub, rel, obj)
172
+ end
173
+ obj.comment = comment
174
+ obj
175
+ end
176
+ when 'UNSET_SG'
177
+ BEL::Script::UnsetStatementGroup.new('')
178
+ else
179
+ nil
180
+ end
181
+ end
182
+ end
183
+ end
184
+ end
metadata ADDED
@@ -0,0 +1,148 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: bel
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Anthony Bargnesi
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2013-07-18 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: antlr3
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ~>
20
+ - !ruby/object:Gem::Version
21
+ version: 1.10.0
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ~>
28
+ - !ruby/object:Gem::Version
29
+ version: 1.10.0
30
+ - !ruby/object:Gem::Dependency
31
+ name: rake
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ~>
36
+ - !ruby/object:Gem::Version
37
+ version: 10.1.0
38
+ type: :development
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ~>
44
+ - !ruby/object:Gem::Version
45
+ version: 10.1.0
46
+ - !ruby/object:Gem::Dependency
47
+ name: rspec
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ~>
52
+ - !ruby/object:Gem::Version
53
+ version: 2.14.0
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ~>
60
+ - !ruby/object:Gem::Version
61
+ version: 2.14.0
62
+ - !ruby/object:Gem::Dependency
63
+ name: yard
64
+ requirement: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ~>
68
+ - !ruby/object:Gem::Version
69
+ version: 0.8.7.0
70
+ type: :development
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ none: false
74
+ requirements:
75
+ - - ~>
76
+ - !ruby/object:Gem::Version
77
+ version: 0.8.7.0
78
+ - !ruby/object:Gem::Dependency
79
+ name: rdoc
80
+ requirement: !ruby/object:Gem::Requirement
81
+ none: false
82
+ requirements:
83
+ - - ~>
84
+ - !ruby/object:Gem::Version
85
+ version: 4.0.0
86
+ type: :development
87
+ prerelease: false
88
+ version_requirements: !ruby/object:Gem::Requirement
89
+ none: false
90
+ requirements:
91
+ - - ~>
92
+ - !ruby/object:Gem::Version
93
+ version: 4.0.0
94
+ - !ruby/object:Gem::Dependency
95
+ name: bundler
96
+ requirement: !ruby/object:Gem::Requirement
97
+ none: false
98
+ requirements:
99
+ - - ~>
100
+ - !ruby/object:Gem::Version
101
+ version: 1.3.0
102
+ type: :development
103
+ prerelease: false
104
+ version_requirements: !ruby/object:Gem::Requirement
105
+ none: false
106
+ requirements:
107
+ - - ~>
108
+ - !ruby/object:Gem::Version
109
+ version: 1.3.0
110
+ description: The BEL gem allows the reading, writing, and processing of BEL (Biological
111
+ Expression Language) with a natural DSL.
112
+ email: abargnesi@selventa.com
113
+ executables: []
114
+ extensions: []
115
+ extra_rdoc_files: []
116
+ files:
117
+ - lib/bel.rb
118
+ - lib/bel/grammar/lexer.rb
119
+ - lib/bel/grammar/parser.rb
120
+ - lib/bel/namespace.rb
121
+ - lib/bel/language.rb
122
+ - lib/bel/script.rb
123
+ homepage: https://github.com/OpenBEL/bel.rb
124
+ licenses: []
125
+ post_install_message:
126
+ rdoc_options: []
127
+ require_paths:
128
+ - lib
129
+ required_ruby_version: !ruby/object:Gem::Requirement
130
+ none: false
131
+ requirements:
132
+ - - ! '>='
133
+ - !ruby/object:Gem::Version
134
+ version: '0'
135
+ required_rubygems_version: !ruby/object:Gem::Requirement
136
+ none: false
137
+ requirements:
138
+ - - ! '>='
139
+ - !ruby/object:Gem::Version
140
+ version: '0'
141
+ requirements: []
142
+ rubyforge_project:
143
+ rubygems_version: 1.8.25
144
+ signing_key:
145
+ specification_version: 3
146
+ summary: Process BEL with ruby.
147
+ test_files: []
148
+ has_rdoc: