aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
Commit message (Collapse)AuthorAgeFilesLines
...
| * | | | | | Prevented belongs_to: touch propagating up if there are no changes being savedBrock Trappitt2014-05-211-1/+1
| |/ / / / /
* / / / / / Revert "Revert "Merge pull request #8313 from ↵Rafael Mendonça França2014-05-201-2/+3
|/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | alan/only_save_changed_has_one_objects"" This reverts commit e94e6c27af495a2460c811bb506459f1428dec6b. Conflicts: activerecord/CHANGELOG.md The original commit was reverted only to be safe since #14407 were reported. We don't have any proof we added a regression with the original commit so reverting it now will give us more problem. Closes #14407
* | | | | Delegate `type_cast_for_write` to injected type objectSean Griffin2014-05-204-30/+14
| | | | |
* | | | | Merge pull request #15207 from sgrif/sg-inline-column-helpersRafael Mendonça França2014-05-209-119/+75
|\ \ \ \ \ | | | | | | | | | | | | Inline typecasting helpers from Column to the appropriate types
| * | | | | Inline typecasting helpers from Column to the appropriate typesSean Griffin2014-05-209-119/+75
| | | | | |
* | | | | | Merge pull request #15206 from sgrif/sg-type-map-postgresqlRafael Mendonça França2014-05-203-45/+31
|\ \ \ \ \ \ | | | | | | | | | | | | | | Use the generic type map for PostgreSQL OID registrations
| * | | | | | Use the generic type map for PostgreSQL OID registrationsSean Griffin2014-05-203-45/+31
| |/ / / / /
* / / / / / Delegate predicate methods to injected type object on ColumnSean Griffin2014-05-2011-23/+43
|/ / / / /
* | | | | Use the generic type map object for mysql field lookupsSean Griffin2014-05-203-23/+26
| | | | |
* | | | | Merge pull request #15203 from sgrif/sg-delegate-type-castRafael Mendonça França2014-05-206-74/+6
|\ \ \ \ \ | | | | | | | | | | | | Replace `type_cast` case statement with delegation
| * | | | | Replace `type_cast` case statement with delegationSean Griffin2014-05-206-74/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | All subclasses of column were now delegating `type_cast` to their injected type object. We can remove the overriding methods, and generalize it on the `Column` class itself. This also enabled us to remove several column classes completely, as they no longer had any meaningful behavior of their own.
* | | | | | Merge pull request #15201 from sgrif/sg-types-postgresqlRafael Mendonça França2014-05-203-147/+81
|\ \ \ \ \ \ | | | | | | | | | | | | | | Have Postgres OID types inherit from general types
| * | | | | | Have Postgres OID types inherit from general typesSean Griffin2014-05-203-147/+81
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Using general types where possible. Several more can go away once infinity gets figured out.
* | | | | | | fix multiple hash preloads. Fixes #14994Aaron Patterson2014-05-201-6/+7
| | | | | | |
* | | | | | | Use general types for mysql fieldsSean Griffin2014-05-201-69/+11
| |/ / / / / |/| | | | |
* | | | | | Delegate type_cast to injected type object in mysqlSean Griffin2014-05-206-53/+72
|/ / / / /
* | | | | Merge pull request #15197 from sgrif/sg-delegate-type-cast-sqlite3Yves Senn2014-05-2010-6/+82
|\ \ \ \ \ | | | | | | | | | | | | Delegate `#type_cast` to injected type objects on SQLite3
| * | | | | Delegate `#type_cast` to injected type objects on SQLite3Sean Griffin2014-05-2010-6/+82
| | | | | |
* | | | | | Fixed the inferred table name for HABTM within a schemaEric Chahin2014-05-201-1/+1
|/ / / / / | | | | | | | | | | | | | | | Fixes #14824.
* | | | | docs, `instantiate` expects `String` keys. [Rafal Piekarski & Yves Senn]Yves Senn2014-05-201-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | Closes #15122 Closes #15107
* | | | | Remove :timestamp column typeSean Griffin2014-05-1912-26/+16
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The `:timestamp` type for columns is unused. All database adapters treat them as the same database type. All code in `ActiveRecord` which changes its behavior based on the column's type acts the same in both cases. However, when the type is passed to code that checks for the `:datetime` type, but not `:timestamp` (such as XML serialization), the result is unexpected behavior. Existing schema definitions will continue to work, and the `timestamp` type is transparently aliased to `datetime`.
* | | | | Merge pull request #10798 from ↵Rafael Mendonça França2014-05-191-1/+1
|\ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | jcxplorer/fix-enable_extension-with-table_name_prefix Fix migrations that use enable_extension with table_name_prefix/suffix Conflicts: activerecord/CHANGELOG.md activerecord/lib/active_record/migration.rb
| * | | | | Fix migrations with enable_extensionJoao Carlos2013-05-291-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When using ActiveRecord::Base.table_name_prefix and/or table_name_suffix, extension names got the same treatment as table names when running migrations. This led to migrations that tried to call, for example, enable_extension("prefix_hstore") on the connection.
* | | | | | Delegate `Column#type` to the injected type objectSean Griffin2014-05-1921-71/+258
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The decision to wrap type registrations in a proc was made for two reasons. 1. Some cases need to make an additional decision based on the type (e.g. a `Decimal` with a 0 scale) 2. Aliased types are automatically updated if they type they point to is updated later. If a user or another adapter decides to change the object used for `decimal` columns, `numeric`, and `number` will automatically point to the new type, without having to track what types are aliased explicitly. Everything else here should be pretty straightforward. PostgreSQL ranges had to change slightly, since the `simplified_type` method is gone.
* | | | | | Merge pull request #15168 from ↵Rafael Mendonça França2014-05-191-0/+2
|\ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | eileencodes/return-early-on-delete-and-destroy-methods Return early on delete and destroy methods
| * | | | | | early return on delete and destroy methodseileencodes2014-05-181-0/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When delete or destroy is called on all records nothing is deleted or destroyed. Intead of running through the code and still not deleteing anything, we should early return
* | | | | | | Merge pull request #14126 from schuetzm/index_option_for_columnRafael Mendonça França2014-05-191-6/+13
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Make `:index` in migrations work with all column types
| * | | | | | | Make `:index` in migrations work with all column typesMarc Schütz2014-05-181-6/+13
| |/ / / / / /
* | | | | | | Merge pull request #15160 from sgrif/sg-destructured-eachRafael Mendonça França2014-05-191-4/+4
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Use destructured arguments when looping through pairs
| * | | | | | | Use destructured arguments when looping through pairsSean Griffin2014-05-171-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Minor refactoring of looping behavior for aggregation
* | | | | | | | pg, re-introduce `PostgreSQL::Utils` to unify schema/table extraction.Yves Senn2014-05-194-24/+31
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Partial revert of c0bfc3f412834ffe8327a15ae3a46602cc28e425
* | | | | | | | pg, add missing nodocs for extracted modules.Yves Senn2014-05-195-10/+10
| | | | | | | |
* | | | | | | | Merge pull request #15156 from sgrif/sg-postgres-timestampsYves Senn2014-05-181-6/+3
|\ \ \ \ \ \ \ \ | |_|/ / / / / / |/| | | | | | | PostgreSQL timestamps should always be datetimes
| * | | | | | | PostgreSQL timestamps are always datetimesSean Griffin2014-05-171-6/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The current behavior is that they are treated as `datetime` normally, but if they are part of an array, they are treated as `timestamp`. The only place that seems to be impacted by this is schema dumping, which shouldn't matter since `t.datetime` and `t.timestamp` are equivalent in the `PostgreSQL` adapter, anyway.
* | | | | | | | Add a type object to Column constructorSean Griffin2014-05-179-12/+40
| |/ / / / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Part of #15134. In order to perform typecasting polymorphically, we need to add another argument to the constructor. The order was chosen to match the `oid_type` on `PostgreSQLColumn`.
* | | | | | | Remove dead test code for unsupported adaptersSean Griffin2014-05-173-11/+2
|/ / / / / /
* | | | | | Merge pull request #14428 from jnormore/reset_counters_aliasRafael Mendonça França2014-05-171-5/+10
|\ \ \ \ \ \ | | | | | | | | | | | | | | Updates reset_counters to allow counter name in params
| * | | | | | Updates reset_counters to allow counter name in paramsJason Normore2014-05-161-5/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Add support for counter name to be passed as parameter on `CounterCache::ClassMethods#reset_counters`. This is to be consistent with the other methods in the module that all accept counter name.
* | | | | | | fix typo [ci skip]Vijay Dev2014-05-171-1/+1
|/ / / / / /
* | | | | | Merge pull request #15071 from leafac/issues/11985Rafael Mendonça França2014-05-161-3/+13
|\ \ \ \ \ \ | | | | | | | | | | | | | | Fix `Relation#delete_all` inconsistency
| * | | | | | Fix `Relation#delete_all` inconsistencyLeandro Facchinetti2014-05-161-3/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When relation scopes include one of `uniq`, `group`, `having` or `offset`, the generated query ignores them and that causes unintended records to be deleted. This solves the issue by restricting the deletion when those scopes are present. rails/rails#11985
* | | | | | | Remove unecessary requireArthur Neves2014-05-161-2/+0
| |_|_|_|_|/ |/| | | | |
* | | | | | Remove the assignment for real this time.Zachary Scott2014-05-161-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | cc: https://github.com/rails/rails/commit/a11e2fcff8cdc9691b977d8330abe63024f8c732#commitcomment-6353614 and 0369dbf
* | | | | | prepend mutates the string so we can remove the assignmentRafael Mendonça França2014-05-161-1/+1
| | | | | |
* | | | | | Reuse the force_clear_transaction_record_stateRafael Mendonça França2014-05-161-1/+1
| | | | | |
* | | | | | Missed if :bomb:Rafael Mendonça França2014-05-161-1/+1
| | | | | |
* | | | | | Add a specific method to force the transaction record state clearRafael Mendonça França2014-05-161-5/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We are using that code path in only one place so we should not add a conditional to all the other cases. This will avoid performance regressions on the old paths.
* | | | | | Clear transaction state if callback raise rollbackArthur Neves2014-05-151-1/+1
| | | | | |
* | | | | | Small refactoring on clear_transaction_record_stateArthur Neves2014-05-151-3/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Make sure when we clean the `@_start_transaction_state` var we do it in the same code-path. Also this makes `clear_transaction_record_state`, more consistent with `restore_transaction_record_state`
* | | | | | Changed extract_limit in class Column to return correct mysql float and ↵Aaron Nelson2014-05-161-0/+2
| | | | | | | | | | | | | | | | | | | | | | | | double limits