mddb 0.0.25 → 0.0.26

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.
@@ -1,57 +1,72 @@
1
1
  #!/usr/bin/env ruby
2
+ require 'trollop'
3
+
4
+
2
5
  catch :shit_user do
3
6
  def start_console
7
+ opts = Trollop::options do
8
+ opt :pid, "Choose a PID", :type => :int
9
+ opt :file, "Choose a file", :type => String
10
+ opt :output, "Enable output"
11
+ end
4
12
  require 'mddb'
5
13
  require 'mddb/point'
6
14
  require 'irb'
7
15
  require 'irb/completion'
8
- ARGV.shift
9
- file = ARGV.shift
10
- if ARGV.empty?
11
- puts "Hey i need a pid"
12
- throw :shit_user
13
- else
14
- pid = ARGV.shift.to_i
15
- end
16
- begin
17
- last_frame = Frame.where(:pid => pid).sort(:fid.desc).first.fid
18
- rescue
19
- last_frame = 0
16
+ if opts[:pid].nil?
17
+ $stderr.puts "please specify a PID. see --help"
18
+ abort
19
+ elsif opts[:file].nil?
20
+ $stderr.puts "please specify a file. see --help"
21
+ abort
20
22
  end
21
- puts "loading xyz"
22
- c = YAML.load File.open('config.yml').read
23
- sim = c['simulation']
24
- objects = sim['objects']
25
- objects.keys.each do |key|
26
- unless Object.const_defined?(key.capitalize)
27
- puts "No model for #{key}! Please create one!"
23
+ pid = opts[:pid]
24
+ if File.exists? opts[:file]
25
+ begin
26
+ last_frame = Frame.where(:pid => pid).sort(:fid.desc).first.fid
27
+ rescue
28
+ last_frame = 0
28
29
  end
29
- objects[key]['atom'].each do |a|
30
- unless Object.const_defined?(a.capitalize)
31
- puts "No model for #{a}! Please create one!"
30
+ $stderr.puts "loading xyz"
31
+ c = YAML.load File.open('config.yml').read
32
+ sim = c['simulation']
33
+ objects = sim['objects']
34
+ objects.keys.each do |key|
35
+ unless Object.const_defined?(key.capitalize)
36
+ $stderr.puts "No model for #{key}! Please create one!"
37
+ end
38
+ objects[key]['atom'].each do |a|
39
+ unless Object.const_defined?(a.capitalize)
40
+ $stderr.puts "No model for #{a}! Please create one!"
41
+ end
32
42
  end
33
43
  end
34
- end
35
- puts "parsing"
36
- p = Mddb::Parser::Parser.new file
37
- fid = 1 + last_frame
38
- p.each_frame do |f|
39
- puts "Frame: #{fid}"
40
- frame = Frame.new :fid => fid, :pid => pid
41
- objects.keys.each do |mol|
42
- (objects[mol]['start']..(objects[mol]['start']+objects[mol]['count']) - 1).to_a.each do |i|
43
- m = Object.const_get(mol.capitalize).new :mid => i, :fid => fid, :pid => pid
44
- objects[mol]['atom'].each_with_index do |a,z|
45
- line = z*objects[mol]['count'] + i
46
- a = Object.const_get(a.capitalize).new :aid => (z+1), :position => f[line-1], :fid => fid, :pid => pid
47
- m.atoms << a
44
+ $stderr.puts "parsing"
45
+ p = Mddb::Parser::Parser.new opts[:file]
46
+ fid = 1 + last_frame
47
+ p.each_frame do |f|
48
+ $stderr.puts "Frame: #{fid}"
49
+ frame = Frame.new :fid => fid, :pid => pid
50
+ objects.keys.each do |mol|
51
+ (objects[mol]['start']..(objects[mol]['start']+objects[mol]['count']) - 1).to_a.each do |i|
52
+ m = Object.const_get(mol.capitalize).new :mid => i, :fid => fid, :pid => pid
53
+ objects[mol]['atom'].each_with_index do |a,z|
54
+ line = z*objects[mol]['count'] + i
55
+ a = Object.const_get(a.capitalize).new :aid => (z+1), :position => f[line-1], :fid => fid, :pid => pid
56
+ m.atoms << a
57
+ end
58
+ m.save
59
+ frame.send(mol.pluralize) << m
48
60
  end
49
- m.save
50
- frame.send(mol.pluralize) << m
51
61
  end
62
+ frame.save
63
+ fid +=1
64
+ end
65
+ if opts[:output]
66
+ puts "#{opts[:pid]}"
67
+ puts "#{last_frame + 1}"
68
+ puts "#{fid - 1}"
52
69
  end
53
- frame.save
54
- fid +=1
55
70
  end
56
71
 
57
72
  end
@@ -59,5 +74,5 @@ end
59
74
  if File.exists? 'config.yml'
60
75
  start_console
61
76
  else
62
- puts "Your not in the project root directory"
77
+ $stderr.puts "Your not in the project root directory"
63
78
  end
data/lib/mddb/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Mddb
2
- VERSION = "0.0.25"
2
+ VERSION = "0.0.26"
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: mddb
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.25
4
+ version: 0.0.26
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-03-22 00:00:00.000000000Z
12
+ date: 2012-03-23 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: rspec
16
- requirement: &70265779694900 !ruby/object:Gem::Requirement
16
+ requirement: &70215825876300 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :development
23
23
  prerelease: false
24
- version_requirements: *70265779694900
24
+ version_requirements: *70215825876300
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: mongo_mapper
27
- requirement: &70265779694480 !ruby/object:Gem::Requirement
27
+ requirement: &70215825875880 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *70265779694480
35
+ version_requirements: *70215825875880
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: hirb
38
- requirement: &70265779694060 !ruby/object:Gem::Requirement
38
+ requirement: &70215825875460 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '0'
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *70265779694060
46
+ version_requirements: *70215825875460
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: thor
49
- requirement: &70265779693640 !ruby/object:Gem::Requirement
49
+ requirement: &70215825875040 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '0'
55
55
  type: :runtime
56
56
  prerelease: false
57
- version_requirements: *70265779693640
57
+ version_requirements: *70215825875040
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: micro-optparse
60
- requirement: &70265779724180 !ruby/object:Gem::Requirement
60
+ requirement: &70215825874620 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :runtime
67
67
  prerelease: false
68
- version_requirements: *70265779724180
68
+ version_requirements: *70215825874620
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: resque
71
- requirement: &70265779723760 !ruby/object:Gem::Requirement
71
+ requirement: &70215825874200 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '0'
77
77
  type: :runtime
78
78
  prerelease: false
79
- version_requirements: *70265779723760
79
+ version_requirements: *70215825874200
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: bson_ext
82
- requirement: &70265779723340 !ruby/object:Gem::Requirement
82
+ requirement: &70215825873780 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ! '>='
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: '0'
88
88
  type: :runtime
89
89
  prerelease: false
90
- version_requirements: *70265779723340
90
+ version_requirements: *70215825873780
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: require_all
93
- requirement: &70265779722920 !ruby/object:Gem::Requirement
93
+ requirement: &70215825873360 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ! '>='
@@ -98,7 +98,7 @@ dependencies:
98
98
  version: '0'
99
99
  type: :runtime
100
100
  prerelease: false
101
- version_requirements: *70265779722920
101
+ version_requirements: *70215825873360
102
102
  description: MDDB makes analysing molecular dynamics simulations easy
103
103
  email:
104
104
  - thom.mulvaney@gmail.com