aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib
diff options
context:
space:
mode:
authorKasper Timm Hansen <kaspth@gmail.com>2019-03-08 11:53:16 +0100
committerGitHub <noreply@github.com>2019-03-08 11:53:16 +0100
commit199de6bee261dd816b68c841c7775fdcd02b68d2 (patch)
tree84f2ba3f646ee239dd5d78e13e3926559ca071f2 /railties/lib
parent4b68e6dbf40558e06a5ceb2b9e1642d798b188ad (diff)
parentdcbb79d680da7742b235b278866850d5bafb8e0b (diff)
downloadrails-199de6bee261dd816b68c841c7775fdcd02b68d2.tar.gz
rails-199de6bee261dd816b68c841c7775fdcd02b68d2.tar.bz2
rails-199de6bee261dd816b68c841c7775fdcd02b68d2.zip
Merge pull request #35522 from gmcgibbon/rails_db_system_change_versioning
Add version awareness to rails db:system:change
Diffstat (limited to 'railties/lib')
-rw-r--r--railties/lib/rails/generators/rails/db/system/change/change_generator.rb14
1 files changed, 12 insertions, 2 deletions
diff --git a/railties/lib/rails/generators/rails/db/system/change/change_generator.rb b/railties/lib/rails/generators/rails/db/system/change/change_generator.rb
index 63849eb18d..24db92fad7 100644
--- a/railties/lib/rails/generators/rails/db/system/change/change_generator.rb
+++ b/railties/lib/rails/generators/rails/db/system/change/change_generator.rb
@@ -35,8 +35,9 @@ module Rails
end
def edit_gemfile
- database_gem_name, _ = gem_for_database
- gsub_file("Gemfile", all_database_gems_regex, database_gem_name)
+ name, version = gem_for_database
+ gsub_file("Gemfile", all_database_gems_regex, name)
+ gsub_file("Gemfile", gem_entry_regex_for(name), gem_entry_for(name, *version))
end
private
@@ -48,6 +49,15 @@ module Rails
all_database_gem_names = all_database_gems.map(&:first)
/(\b#{all_database_gem_names.join('\b|\b')}\b)/
end
+
+ def gem_entry_regex_for(gem_name)
+ /^gem.*\b#{gem_name}\b.*/
+ end
+
+ def gem_entry_for(*gem_name_and_version)
+ gem_name_and_version.map! { |segment| "'#{segment}'" }
+ "gem #{gem_name_and_version.join(", ")}"
+ end
end
end
end