dna 0.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2) hide show
  1. data/lib/dna.rb +38 -0
  2. metadata +45 -0
data/lib/dna.rb ADDED
@@ -0,0 +1,38 @@
1
+ class Dna # iterator
2
+ include Enumerable
3
+
4
+ def initialize(handle, args={})
5
+ @handle = handle
6
+ end
7
+
8
+ def each
9
+ sequence, header = nil, nil
10
+ @handle.each do |line|
11
+ if line[0].chr == '>'
12
+ yield Dna.new(:name => header, :sequence => sequence) if sequence
13
+ sequence = ''
14
+ header = line[1..-1].strip
15
+ else
16
+ sequence << line.strip.tr(' ','')
17
+ end
18
+ end
19
+ yield Dna.new(:name => header, :sequence => sequence)
20
+ end
21
+ end
22
+
23
+ class Record # nucleotide record
24
+ attr_accessor :name, :sequence
25
+
26
+ def initialize(args={})
27
+ @name = args[:name]
28
+ @sequence = args[:sequence]
29
+ end
30
+
31
+ def to_s
32
+ ">#{@name}\n#{@sequence}\n"
33
+ end
34
+
35
+ def length
36
+ @sequence.length
37
+ end
38
+ end
metadata ADDED
@@ -0,0 +1,45 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: dna
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Austin G. Davis-Richardson
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2010-01-27 00:00:00.000000000 Z
13
+ dependencies: []
14
+ description: for parsing fasta files
15
+ email: harekrishna@gmail.com
16
+ executables: []
17
+ extensions: []
18
+ extra_rdoc_files: []
19
+ files:
20
+ - lib/dna.rb
21
+ homepage: http://github.com/audy/dna
22
+ licenses: []
23
+ post_install_message:
24
+ rdoc_options: []
25
+ require_paths:
26
+ - lib
27
+ required_ruby_version: !ruby/object:Gem::Requirement
28
+ none: false
29
+ requirements:
30
+ - - ! '>='
31
+ - !ruby/object:Gem::Version
32
+ version: '0'
33
+ required_rubygems_version: !ruby/object:Gem::Requirement
34
+ none: false
35
+ requirements:
36
+ - - ! '>='
37
+ - !ruby/object:Gem::Version
38
+ version: '0'
39
+ requirements: []
40
+ rubyforge_project:
41
+ rubygems_version: 1.8.15
42
+ signing_key:
43
+ specification_version: 3
44
+ summary: fasta parser
45
+ test_files: []