lederhosen 0.3.2 → 0.3.3

Sign up to get free protection for your applications and to get access to all the features.
data/bin/lederhosen CHANGED
@@ -2,6 +2,4 @@
2
2
 
3
3
  require File.expand_path(File.join(File.dirname(__FILE__), '..', 'lib', 'lederhosen'))
4
4
 
5
- fail "you need to install uclust and have it in your $PATH" if `which uclust` == ''
6
-
7
5
  Lederhosen::CLI.start
data/lederhosen.gemspec CHANGED
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "lederhosen"
8
- s.version = "0.3.2"
8
+ s.version = "0.3.3"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["Austin G. Davis-Richardson"]
12
- s.date = "2012-08-13"
12
+ s.date = "2012-08-14"
13
13
  s.description = "Various tools for OTU clustering"
14
14
  s.email = "harekrishna@gmail.com"
15
15
  s.executables = ["lederhosen"]
@@ -1,4 +1,8 @@
1
1
  module Lederhosen
2
+
3
+ ##
4
+ # The CLI class holds all of the Thor tasks
5
+ #
2
6
  class CLI < Thor
3
7
  include Thor::Actions
4
8
 
@@ -109,10 +109,20 @@ module Lederhosen
109
109
  clusternr = line[1].to_i
110
110
  querylabel = line[8]
111
111
  targetlabel = line[9]
112
- sample = line[8].split(':')[2]
112
+ header = line[8]
113
+
114
+ # get the sample id via regexp match
115
+ # this way more info can be stored in the header.
116
+ sample = line[8].match(/sample=(.*)/)[1]
117
+
118
+ # Need to maintain some backwards compatibility here
119
+ # this is the old way of getting the same id.
120
+ if sample.nil?
121
+ sample = line[8].split(':')[2]
122
+ end
113
123
 
114
124
  # keep track of samples
115
- samples.add sample
125
+ samples.add(sample)
116
126
 
117
127
  # keep track of all samples
118
128
  clusters[:samples].add sample
@@ -33,7 +33,7 @@ module Lederhosen
33
33
  end
34
34
 
35
35
  records.each_slice(2) do |l, r|
36
- output.puts ">#{r.name}:#{File.basename(fasta_file, '.fasta')}\n#{r.sequence.reverse+l.sequence}"
36
+ output.puts ">#{r.name}:split=#{r.sequence.size}:sample=#{File.basename(fasta_file, '.fasta')}\n#{r.sequence.reverse+l.sequence}"
37
37
  end
38
38
  end
39
39
  pbar.finish
@@ -2,7 +2,7 @@ module Lederhosen
2
2
  module Version
3
3
  MAJOR = 0
4
4
  MINOR = 3
5
- PATCH = 2
5
+ PATCH = 3
6
6
 
7
7
  STRING = [MAJOR, MINOR, PATCH].join('.')
8
8
  end
data/lib/lederhosen.rb CHANGED
@@ -7,6 +7,11 @@ require 'set'
7
7
 
8
8
  Dir.glob(File.join(File.dirname(__FILE__), 'lederhosen', '*.rb')).each { |f| require f }
9
9
 
10
+ ##
11
+ # Here I extend the string class to add the to_kmers method
12
+ #
13
+ # Does it really need to be a method of String? Sure, why not?
14
+ #
10
15
  class String
11
16
  def to_kmers(k)
12
17
  return [] if k == 0
metadata CHANGED
@@ -1,118 +1,120 @@
1
- --- !ruby/object:Gem::Specification
1
+ --- !ruby/object:Gem::Specification
2
2
  name: lederhosen
3
- version: !ruby/object:Gem::Version
4
- hash: 23
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.3.3
5
5
  prerelease:
6
- segments:
7
- - 0
8
- - 3
9
- - 2
10
- version: 0.3.2
11
6
  platform: ruby
12
- authors:
7
+ authors:
13
8
  - Austin G. Davis-Richardson
14
9
  autorequire:
15
10
  bindir: bin
16
11
  cert_chain: []
17
-
18
- date: 2012-08-13 00:00:00 Z
19
- dependencies:
20
- - !ruby/object:Gem::Dependency
21
- type: :runtime
22
- requirement: &id001 !ruby/object:Gem::Requirement
12
+ date: 2012-08-14 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: dna
16
+ requirement: !ruby/object:Gem::Requirement
23
17
  none: false
24
- requirements:
25
- - - "="
26
- - !ruby/object:Gem::Version
27
- hash: 7
28
- segments:
29
- - 0
30
- - 0
31
- - 12
18
+ requirements:
19
+ - - '='
20
+ - !ruby/object:Gem::Version
32
21
  version: 0.0.12
33
- version_requirements: *id001
34
- name: dna
35
- prerelease: false
36
- - !ruby/object:Gem::Dependency
37
22
  type: :runtime
38
- requirement: &id002 !ruby/object:Gem::Requirement
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
39
25
  none: false
40
- requirements:
41
- - - ">="
42
- - !ruby/object:Gem::Version
43
- hash: 3
44
- segments:
45
- - 0
46
- version: "0"
47
- version_requirements: *id002
26
+ requirements:
27
+ - - '='
28
+ - !ruby/object:Gem::Version
29
+ version: 0.0.12
30
+ - !ruby/object:Gem::Dependency
48
31
  name: progressbar
49
- prerelease: false
50
- - !ruby/object:Gem::Dependency
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
51
38
  type: :runtime
52
- requirement: &id003 !ruby/object:Gem::Requirement
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
53
41
  none: false
54
- requirements:
55
- - - ">="
56
- - !ruby/object:Gem::Version
57
- hash: 3
58
- segments:
59
- - 0
60
- version: "0"
61
- version_requirements: *id003
42
+ requirements:
43
+ - - ! '>='
44
+ - !ruby/object:Gem::Version
45
+ version: '0'
46
+ - !ruby/object:Gem::Dependency
62
47
  name: thor
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ type: :runtime
63
55
  prerelease: false
64
- - !ruby/object:Gem::Dependency
65
- type: :development
66
- requirement: &id004 !ruby/object:Gem::Requirement
56
+ version_requirements: !ruby/object:Gem::Requirement
67
57
  none: false
68
- requirements:
69
- - - ~>
70
- - !ruby/object:Gem::Version
71
- hash: 31
72
- segments:
73
- - 3
74
- - 12
75
- version: "3.12"
76
- version_requirements: *id004
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ - !ruby/object:Gem::Dependency
77
63
  name: rdoc
78
- prerelease: false
79
- - !ruby/object:Gem::Dependency
64
+ requirement: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ~>
68
+ - !ruby/object:Gem::Version
69
+ version: '3.12'
80
70
  type: :development
81
- requirement: &id005 !ruby/object:Gem::Requirement
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
82
73
  none: false
83
- requirements:
84
- - - ">="
85
- - !ruby/object:Gem::Version
86
- hash: 3
87
- segments:
88
- - 0
89
- version: "0"
90
- version_requirements: *id005
74
+ requirements:
75
+ - - ~>
76
+ - !ruby/object:Gem::Version
77
+ version: '3.12'
78
+ - !ruby/object:Gem::Dependency
91
79
  name: bundler
92
- prerelease: false
93
- - !ruby/object:Gem::Dependency
80
+ requirement: !ruby/object:Gem::Requirement
81
+ none: false
82
+ requirements:
83
+ - - ! '>='
84
+ - !ruby/object:Gem::Version
85
+ version: '0'
94
86
  type: :development
95
- requirement: &id006 !ruby/object:Gem::Requirement
87
+ prerelease: false
88
+ version_requirements: !ruby/object:Gem::Requirement
96
89
  none: false
97
- requirements:
98
- - - ">="
99
- - !ruby/object:Gem::Version
100
- hash: 3
101
- segments:
102
- - 0
103
- version: "0"
104
- version_requirements: *id006
90
+ requirements:
91
+ - - ! '>='
92
+ - !ruby/object:Gem::Version
93
+ version: '0'
94
+ - !ruby/object:Gem::Dependency
105
95
  name: jeweler
96
+ requirement: !ruby/object:Gem::Requirement
97
+ none: false
98
+ requirements:
99
+ - - ! '>='
100
+ - !ruby/object:Gem::Version
101
+ version: '0'
102
+ type: :development
106
103
  prerelease: false
104
+ version_requirements: !ruby/object:Gem::Requirement
105
+ none: false
106
+ requirements:
107
+ - - ! '>='
108
+ - !ruby/object:Gem::Version
109
+ version: '0'
107
110
  description: Various tools for OTU clustering
108
111
  email: harekrishna@gmail.com
109
- executables:
112
+ executables:
110
113
  - lederhosen
111
114
  extensions: []
112
-
113
- extra_rdoc_files:
115
+ extra_rdoc_files:
114
116
  - LICENSE.txt
115
- files:
117
+ files:
116
118
  - .rspec
117
119
  - .rvmrc
118
120
  - Gemfile
@@ -155,37 +157,31 @@ files:
155
157
  - spec/misc_spec.rb
156
158
  - spec/spec_helper.rb
157
159
  homepage: http://audy.github.com/lederhosen
158
- licenses:
160
+ licenses:
159
161
  - MIT
160
162
  post_install_message:
161
163
  rdoc_options: []
162
-
163
- require_paths:
164
+ require_paths:
164
165
  - lib
165
- required_ruby_version: !ruby/object:Gem::Requirement
166
+ required_ruby_version: !ruby/object:Gem::Requirement
166
167
  none: false
167
- requirements:
168
- - - ">="
169
- - !ruby/object:Gem::Version
170
- hash: 3
171
- segments:
168
+ requirements:
169
+ - - ! '>='
170
+ - !ruby/object:Gem::Version
171
+ version: '0'
172
+ segments:
172
173
  - 0
173
- version: "0"
174
- required_rubygems_version: !ruby/object:Gem::Requirement
174
+ hash: 1714359518753916587
175
+ required_rubygems_version: !ruby/object:Gem::Requirement
175
176
  none: false
176
- requirements:
177
- - - ">="
178
- - !ruby/object:Gem::Version
179
- hash: 3
180
- segments:
181
- - 0
182
- version: "0"
177
+ requirements:
178
+ - - ! '>='
179
+ - !ruby/object:Gem::Version
180
+ version: '0'
183
181
  requirements: []
184
-
185
182
  rubyforge_project:
186
183
  rubygems_version: 1.8.24
187
184
  signing_key:
188
185
  specification_version: 3
189
186
  summary: OTU Clustering
190
187
  test_files: []
191
-