rails_reverse_db 0.0.1.alpha

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.
data/MIT-LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright 2012 Chris McKnight
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,4 @@
1
+ Gem for reverse engineering a mysql or sqlite database
2
+
3
+ Runs the rails scaffolding command with the appropriate arguments
4
+ to generate models, controllers, tests, etc from an existing database
data/README.rdoc ADDED
@@ -0,0 +1,3 @@
1
+ = RailsReverseDb
2
+
3
+ This project rocks and uses MIT-LICENSE.
data/Rakefile ADDED
@@ -0,0 +1,36 @@
1
+ #!/usr/bin/env rake
2
+ begin
3
+ require 'bundler/setup'
4
+ rescue LoadError
5
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
6
+ end
7
+ begin
8
+ require 'rdoc/task'
9
+ rescue LoadError
10
+ require 'rdoc/rdoc'
11
+ require 'rake/rdoctask'
12
+ RDoc::Task = Rake::RDocTask
13
+ end
14
+
15
+ RDoc::Task.new(:rdoc) do |rdoc|
16
+ rdoc.rdoc_dir = 'rdoc'
17
+ rdoc.title = 'RailsReverseDb'
18
+ rdoc.options << '--line-numbers'
19
+ rdoc.rdoc_files.include('README.rdoc')
20
+ rdoc.rdoc_files.include('lib/**/*.rb')
21
+ end
22
+
23
+
24
+
25
+
26
+ Bundler::GemHelper.install_tasks
27
+
28
+ require 'rspec/core/rake_task'
29
+
30
+ RSpec::Core::RakeTask.new(:spec) do |spec|
31
+ spec.pattern = 'spec/*_spec.rb'
32
+ spec.rspec_opts = ['--color']
33
+ end
34
+
35
+
36
+ task :default => :spec
@@ -0,0 +1,11 @@
1
+ module RailsReverseDbHelper
2
+ class RailsReverseDbHelper
3
+ def self.ucwords(str = '')
4
+ str.split(' ').select {|w| w.capitalize! || w }.join(' ');
5
+ end
6
+
7
+ def self.test_singularity(str)
8
+ str.pluralize != str and str.singularize == str
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,14 @@
1
+ require 'rails_reverse_db'
2
+ require 'rails'
3
+ require 'active_model/railtie'
4
+ require 'action_controller/railtie'
5
+
6
+ module RailsReverseDb
7
+
8
+ class Railtie < Rails::Railtie
9
+ rake_tasks do
10
+ load 'rails_reverse_db/tasks/rails_reverse_db_tasks.rake'
11
+ end
12
+ end
13
+
14
+ end
@@ -0,0 +1,9 @@
1
+ require 'rails_reverse_db/rails_reverse_db_helper'
2
+
3
+ namespace :rails_reverse_db do
4
+ desc "Generate scaffolding from tables in database"
5
+ task :scaffold => :environment do
6
+ g = RailsReverseDb::RailsReverseDb.new
7
+ g.run
8
+ end
9
+ end
@@ -0,0 +1,3 @@
1
+ module RailsReverseDb
2
+ VERSION = "0.0.1.alpha"
3
+ end
@@ -0,0 +1,57 @@
1
+ require 'rails_reverse_db/rails_reverse_db_helper'
2
+
3
+ module RailsReverseDb
4
+ require 'rails_reverse_db/railtie.rb' if defined?(Rails)
5
+ class RailsReverseDb
6
+
7
+ delegate :connection, :establish_connection, to: ActiveRecord::Base
8
+
9
+ def initialize
10
+ environments = [Rails.env]
11
+
12
+ configurations = ActiveRecord::Base.configurations.values_at(*environments)
13
+ @configuration = configurations.first
14
+ @pk = 'id'
15
+ establish_connection @configuration
16
+
17
+ # configurations = ActiveRecord::Base.configurations.values_at(*environments)
18
+ # configurations.compact.each do |configuration|
19
+ # yield configuration unless configuration['database'].blank?
20
+ # end
21
+ end
22
+
23
+ def get_tables
24
+ tables = ActiveRecord::Base.connection.execute("SHOW TABLES")
25
+ tables = tables.to_a.map(&:join)
26
+ tables.each do |table|
27
+ end
28
+ tables
29
+ end
30
+
31
+ def run
32
+ tables = self.get_tables
33
+ tables.each do |table|
34
+ if RailsReverseDbHelper::RailsReverseDbHelper.test_singularity(table)
35
+ # already singular
36
+ singular ||= table
37
+ plural ||= table.pluralize()
38
+ else
39
+ # already plural
40
+ singular ||= table.singularize()
41
+ plural ||= table
42
+ end
43
+
44
+ singular = RailsReverseDbHelper::RailsReverseDbHelper.ucwords(singular)
45
+ singular.gsub!(' ', '')
46
+
47
+ eval "class #{singular} < ActiveRecord::Base; set_table_name '#{table}' end"
48
+ klass = eval "#{singular}"
49
+ reverse_command = "rails generate scaffold #{singular} "
50
+ klass.columns.each do |col|
51
+ reverse_command << col.name + ":" + col.type.to_s + " " unless col.name == @pk
52
+ end
53
+ # system reverse_command + opts.skip_migration
54
+ end
55
+ end
56
+ end
57
+ end
metadata ADDED
@@ -0,0 +1,186 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rails_reverse_db
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1.alpha
5
+ prerelease: 6
6
+ platform: ruby
7
+ authors:
8
+ - Chris McKnight
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2012-09-03 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: rails
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ~>
20
+ - !ruby/object:Gem::Version
21
+ version: 3.2.6
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: 3.2.6
30
+ - !ruby/object:Gem::Dependency
31
+ name: rspec-rails
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: '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: '0'
46
+ - !ruby/object:Gem::Dependency
47
+ name: capybara
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '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: '0'
62
+ - !ruby/object:Gem::Dependency
63
+ name: guard-rspec
64
+ requirement: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ! '>='
68
+ - !ruby/object:Gem::Version
69
+ version: '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'
78
+ - !ruby/object:Gem::Dependency
79
+ name: guard-spork
80
+ requirement: !ruby/object:Gem::Requirement
81
+ none: false
82
+ requirements:
83
+ - - ! '>='
84
+ - !ruby/object:Gem::Version
85
+ version: '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: '0'
94
+ - !ruby/object:Gem::Dependency
95
+ name: sqlite3
96
+ requirement: !ruby/object:Gem::Requirement
97
+ none: false
98
+ requirements:
99
+ - - ! '>='
100
+ - !ruby/object:Gem::Version
101
+ version: '0'
102
+ type: :runtime
103
+ prerelease: false
104
+ version_requirements: !ruby/object:Gem::Requirement
105
+ none: false
106
+ requirements:
107
+ - - ! '>='
108
+ - !ruby/object:Gem::Version
109
+ version: '0'
110
+ - !ruby/object:Gem::Dependency
111
+ name: mysql2
112
+ requirement: !ruby/object:Gem::Requirement
113
+ none: false
114
+ requirements:
115
+ - - ! '>='
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :runtime
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ none: false
122
+ requirements:
123
+ - - ! '>='
124
+ - !ruby/object:Gem::Version
125
+ version: '0'
126
+ - !ruby/object:Gem::Dependency
127
+ name: railties
128
+ requirement: !ruby/object:Gem::Requirement
129
+ none: false
130
+ requirements:
131
+ - - ! '>='
132
+ - !ruby/object:Gem::Version
133
+ version: '0'
134
+ type: :runtime
135
+ prerelease: false
136
+ version_requirements: !ruby/object:Gem::Requirement
137
+ none: false
138
+ requirements:
139
+ - - ! '>='
140
+ - !ruby/object:Gem::Version
141
+ version: '0'
142
+ description: Reverse engineer existing databases and generate migrations, models,
143
+ or scaffolding
144
+ email:
145
+ - cmckni3@gmail.com
146
+ executables: []
147
+ extensions: []
148
+ extra_rdoc_files: []
149
+ files:
150
+ - lib/rails_reverse_db/rails_reverse_db_helper.rb
151
+ - lib/rails_reverse_db/railtie.rb
152
+ - lib/rails_reverse_db/tasks/rails_reverse_db_tasks.rake
153
+ - lib/rails_reverse_db/version.rb
154
+ - lib/rails_reverse_db.rb
155
+ - MIT-LICENSE
156
+ - Rakefile
157
+ - README.rdoc
158
+ - README.md
159
+ homepage: http://christophermcknight.us
160
+ licenses: []
161
+ post_install_message:
162
+ rdoc_options: []
163
+ require_paths:
164
+ - lib
165
+ required_ruby_version: !ruby/object:Gem::Requirement
166
+ none: false
167
+ requirements:
168
+ - - ! '>='
169
+ - !ruby/object:Gem::Version
170
+ version: '0'
171
+ segments:
172
+ - 0
173
+ hash: 3402952440522818133
174
+ required_rubygems_version: !ruby/object:Gem::Requirement
175
+ none: false
176
+ requirements:
177
+ - - ! '>'
178
+ - !ruby/object:Gem::Version
179
+ version: 1.3.1
180
+ requirements: []
181
+ rubyforge_project:
182
+ rubygems_version: 1.8.23
183
+ signing_key:
184
+ specification_version: 3
185
+ summary: Reverse Engineer existing databases
186
+ test_files: []