diff options
author | Kasper Timm Hansen <kaspth@gmail.com> | 2019-03-08 11:53:16 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-03-08 11:53:16 +0100 |
commit | 199de6bee261dd816b68c841c7775fdcd02b68d2 (patch) | |
tree | 84f2ba3f646ee239dd5d78e13e3926559ca071f2 /railties/lib | |
parent | 4b68e6dbf40558e06a5ceb2b9e1642d798b188ad (diff) | |
parent | dcbb79d680da7742b235b278866850d5bafb8e0b (diff) | |
download | rails-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.rb | 14 |
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 |