Sequel 5.5.0 has been released!
= New Features
* The defaults_setter plugin now supports a :cache option, which
will cache default values in the model object's values hash:
Model.plugin :defaults_setter
o = Model.new
o.column # => 1 # default value
o.values # => {}
Model.plugin :defaults_setter, cache: true
o = Model.new
o.column # => 1 # default value
o.values # => {:column => 1}
* The pg_array extension now sets a :callable_default schema entry
for recognized empty array defaults.
* The pg_hstore extension now sets a :callable_default schema entry
for recognized empty hstore defaults.
* The pg_json extension now sets a :callable_default schema entry for
recognized empty json/jsonb array/hash defaults.
* The pg_inet extension now sets a :ruby_default schema entry for
recognized inet/cidr defaults.
* The pg_range extension now sets a :ruby_default schema entry for
recognized range defaults.
* The defaults_setter plugin will now give preference to a
:callable_default schema entry over a :ruby_default schema entry.
Combined with the other changes listed above, this makes default
values recognized by the pg_array, pg_hstore, and pg_json extensions
work well if the defaults_setter :cache option is also used.
= Other Improvements
* The modification_detection plugin no longer breaks column change
detection for new objects.
* Database#copy_table in the postgres adapter now handles errors that
occur when processing rows. Previously, an exception could be
raised on the next query in that case.
* The results of the changed_columns method are now cached in many
places internally where they are called in a loop. This results
in better performance, especially if the modification_detection or
serialization_modification_detection plugins are used.
= Backwards Compatibility
* The pg_interval extension now sets a :ruby_default schema entry for
recognized interval defaults to the same value Sequel would return
if the default value was returned. Previously, Sequel would use a
string in the :ruby_schema schema value.
* String values in hashes returned by Database#schema are now frozen
to prevent possible thread-safety issues and issues with
unintentional modification of a shared string. The hashes
themselves are not frozen and can still be modified.
Thanks,
Jeremy
--
You received this message because you are subscribed to the Google Groups
"sequel-talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
Visit this group at https://groups.google.com/group/sequel-talk.
For more options, visit https://groups.google.com/d/optout.