Sha256: 48b3ec4e941a5e3a2f44520d9163fb5d6cb6675fbf6370aaad555f9903897956
Contents?: true
Size: 1.96 KB
Versions: 2
Compression:
Stored size: 1.96 KB
Contents
# frozen_string_literal: false # @!parse # class ActiveRecord::Migration # # Change the name and/or schema of a function # # # # @param [#to_s] :name (nil) The qualified name of the function # # @option options [#to_s] :to (nil) The new qualified name for the function # # @return [void] # # # # A function can be renamed by changing both the name # # and the schema (namespace) it belongs to. # # # # If there are no overloaded functions, then you can use a plain name: # # # # ```ruby # # rename_function "math.multiply", to: "public.product" # # ``` # # # # otherwise the types of attributes must be explicitly specified. # # # # ```ruby # # rename_function "math.multiply(int, int)", to: "public.product" # # ``` # # # # Any specification of attributes or returned values in `to:` option # # is ignored because they cannot be changed anyway. # # # # The operation is always reversible. # def rename_function(name, to:); end # end module PGTrunk::Operations::Functions # @private class RenameFunction < Base validates :new_name, presence: true validates :body, :cost, :force, :if_exists, :language, :leakproof, :parallel, :replace_existing, :rows, :security, :strict, :volatility, absence: true def to_sql(_version) [*change_schema, *change_name].join(" ") end def invert q_new_name = "#{new_name.schema}.#{new_name.routine}(#{name.args}) #{name.returns}" self.class.new(**to_h, name: q_new_name.strip, to: name) end private def change_schema return if name.schema == new_name.schema "ALTER FUNCTION #{name.to_sql} SET SCHEMA #{new_name.schema.inspect};" end def change_name return if new_name.routine == name.routine changed_name = name.merge(schema: new_name.schema).to_sql "ALTER FUNCTION #{changed_name} RENAME TO #{new_name.routine.inspect};" end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
pg_trunk-0.2.0 | lib/pg_trunk/operations/functions/rename_function.rb |
pg_trunk-0.1.3 | lib/pg_trunk/operations/functions/rename_function.rb |