paraphraser 0.2.3 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/VERSION +1 -1
- data/lib/paraphraser/convertor.rb +33 -18
- data/lib/paraphraser/kernel_ext.rb +13 -0
- data/lib/paraphraser/railties/paraphraser.rake +2 -6
- data/paraphraser.gemspec +3 -2
- metadata +6 -5
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.
|
1
|
+
1.0.0
|
@@ -1,3 +1,5 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'kernel_ext'))
|
2
|
+
|
1
3
|
module Paraphraser
|
2
4
|
class Convertor
|
3
5
|
|
@@ -10,23 +12,48 @@ module Paraphraser
|
|
10
12
|
class << self
|
11
13
|
|
12
14
|
def convert
|
15
|
+
exit(0) unless agree_to_proceed?
|
16
|
+
|
17
|
+
Rake::Task['db:drop'].invoke
|
18
|
+
Rake::Task['db:create'].invoke
|
19
|
+
|
13
20
|
with_activerecord_stubbed do
|
21
|
+
announce "CreateSchemaMigrations"
|
14
22
|
migrations.each do |migration|
|
15
23
|
announce "#{migration.version} : #{migration.name}"
|
16
24
|
migration.migrate(direction)
|
17
25
|
update_schema_migrations_table(migration.version)
|
18
26
|
end
|
19
27
|
end
|
28
|
+
|
29
|
+
print_without_file_output "\nWe're done! You could either copy the output above or give ./migration.sql for *the dba review*\n\n"
|
20
30
|
end
|
21
31
|
|
22
32
|
private
|
23
33
|
|
34
|
+
def agree_to_proceed?
|
35
|
+
print_without_file_output "\nThe way paraphraser works, it will drop and re-create a database and will output the migration sql in the process.\n" +
|
36
|
+
"All data in #{::Rails.configuration.database_configuration[::Rails.env]['database']} at #{::Rails.configuration.database_configuration[::Rails.env]['host'] || 'localhost'} will be wiped-out. proceed? (Y/n): "
|
37
|
+
choice = STDIN.gets.chomp
|
38
|
+
|
39
|
+
case(choice)
|
40
|
+
when 'Y' then
|
41
|
+
return true
|
42
|
+
when 'n', 'no', 'No' then
|
43
|
+
print_without_file_output "\nYou can choose to run against a different Rails.env by passing an argument to paraphraser as, rake 'db:paraphrase:all[test]'\n\n"
|
44
|
+
return false
|
45
|
+
else
|
46
|
+
print_without_file_output "\nYour input was neither 'Yes' nor 'n', so exiting.\n\n"
|
47
|
+
return false
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
24
51
|
def connection
|
25
52
|
ActiveRecord::Base.connection
|
26
53
|
end
|
27
54
|
|
28
55
|
def migrations
|
29
|
-
|
56
|
+
@@migrations ||= ActiveRecord::Migrator.new(direction, migrations_path).migrations
|
30
57
|
end
|
31
58
|
|
32
59
|
def with_activerecord_stubbed(&block)
|
@@ -36,22 +63,11 @@ module Paraphraser
|
|
36
63
|
end
|
37
64
|
|
38
65
|
def apply_overrides
|
39
|
-
connection.class.send(:define_method, :
|
40
|
-
print "#{sql};\n"
|
41
|
-
|
42
|
-
end
|
43
|
-
connection.class.send(:define_method, :initialize_schema_migrations_table) { }
|
44
|
-
connection.class.send(:define_method, :tables) { |*args| [] }
|
45
|
-
connection.class.send(:define_method, :index_name_exists?) {|*args| false }
|
46
|
-
connection.class.send(:define_method, :rename_column) do |table_name, column_name, new_column_name|
|
47
|
-
execute "ALTER TABLE #{quote_table_name(table_name)} RENAME COLUMN #{quote_column_name(column_name)} TO #{quote_column_name(new_column_name)}"
|
48
|
-
end
|
49
|
-
connection.class.send(:define_method, :change_column) do |table_name, column_name, type, options = {}|
|
50
|
-
execute "ALTER TABLE #{quote_table_name(table_name)} ALTER COLUMN #{quote_column_name(column_name)} TYPE #{type_to_sql(type, options[:limit], options[:precision], options[:scale])}"
|
51
|
-
end
|
52
|
-
connection.class.send(:define_method, :change_column_default) do |table_name, column_name, default|
|
53
|
-
execute "ALTER TABLE #{quote_table_name(table_name)} ALTER COLUMN #{quote_column_name(column_name)} SET DEFAULT #{quote(default)}"
|
66
|
+
connection.class.send(:define_method, :execute_with_paraphrasing) do |sql, name = nil|
|
67
|
+
print "#{sql};\n" and STDOUT.flush unless sql =~ /^SHOW/
|
68
|
+
execute_without_paraphrasing sql, name
|
54
69
|
end
|
70
|
+
connection.class.send(:alias_method_chain, :execute, :paraphrasing)
|
55
71
|
end
|
56
72
|
|
57
73
|
def update_schema_migrations_table(version)
|
@@ -63,7 +79,6 @@ module Paraphraser
|
|
63
79
|
print "\n-- %s %s\n" % [text, "-" * length]
|
64
80
|
end
|
65
81
|
|
66
|
-
end
|
67
|
-
|
82
|
+
end
|
68
83
|
end
|
69
84
|
end
|
@@ -2,14 +2,10 @@ namespace :db do
|
|
2
2
|
namespace :paraphrase do
|
3
3
|
|
4
4
|
desc 'provides a rake task to convert all migrations to sql statements for *the dba*.'
|
5
|
-
task :all => :environment do
|
5
|
+
task :all, [:rails_env] => :environment do |t, args|
|
6
|
+
Rails.env = args[:rails_env] || 'test'
|
6
7
|
Paraphraser::Convertor.convert
|
7
8
|
end
|
8
9
|
|
9
|
-
desc 'provides a rake task to convert all migrations in range to sql statements for *the dba*.'
|
10
|
-
task :in_range => :environment do
|
11
|
-
Paraphraser::Convertor.convert
|
12
|
-
end
|
13
|
-
|
14
10
|
end
|
15
11
|
end
|
data/paraphraser.gemspec
CHANGED
@@ -5,11 +5,11 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = %q{paraphraser}
|
8
|
-
s.version = "0.
|
8
|
+
s.version = "1.0.0"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["Vinay Patel"]
|
12
|
-
s.date = %q{
|
12
|
+
s.date = %q{2011-01-05}
|
13
13
|
s.description = %q{provides a rake task to convert migrations to sql statements for *the dba*.}
|
14
14
|
s.email = %q{mail@vinayvinay.com}
|
15
15
|
s.extra_rdoc_files = [
|
@@ -26,6 +26,7 @@ Gem::Specification.new do |s|
|
|
26
26
|
"VERSION",
|
27
27
|
"lib/paraphraser.rb",
|
28
28
|
"lib/paraphraser/convertor.rb",
|
29
|
+
"lib/paraphraser/kernel_ext.rb",
|
29
30
|
"lib/paraphraser/railtie.rb",
|
30
31
|
"lib/paraphraser/railties/paraphraser.rake",
|
31
32
|
"paraphraser.gemspec",
|
metadata
CHANGED
@@ -3,10 +3,10 @@ name: paraphraser
|
|
3
3
|
version: !ruby/object:Gem::Version
|
4
4
|
prerelease: false
|
5
5
|
segments:
|
6
|
+
- 1
|
6
7
|
- 0
|
7
|
-
-
|
8
|
-
|
9
|
-
version: 0.2.3
|
8
|
+
- 0
|
9
|
+
version: 1.0.0
|
10
10
|
platform: ruby
|
11
11
|
authors:
|
12
12
|
- Vinay Patel
|
@@ -14,7 +14,7 @@ autorequire:
|
|
14
14
|
bindir: bin
|
15
15
|
cert_chain: []
|
16
16
|
|
17
|
-
date:
|
17
|
+
date: 2011-01-05 00:00:00 -06:00
|
18
18
|
default_executable:
|
19
19
|
dependencies:
|
20
20
|
- !ruby/object:Gem::Dependency
|
@@ -66,6 +66,7 @@ files:
|
|
66
66
|
- VERSION
|
67
67
|
- lib/paraphraser.rb
|
68
68
|
- lib/paraphraser/convertor.rb
|
69
|
+
- lib/paraphraser/kernel_ext.rb
|
69
70
|
- lib/paraphraser/railtie.rb
|
70
71
|
- lib/paraphraser/railties/paraphraser.rake
|
71
72
|
- paraphraser.gemspec
|
@@ -85,7 +86,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
85
86
|
requirements:
|
86
87
|
- - ">="
|
87
88
|
- !ruby/object:Gem::Version
|
88
|
-
hash:
|
89
|
+
hash: 848231213
|
89
90
|
segments:
|
90
91
|
- 0
|
91
92
|
version: "0"
|