remove is_deferrable from default rel options to maintain principle of least surprise...
[dbsrgits/DBIx-Class-Schema-Loader.git] / Changes
CommitLineData
af6c2665 1Revision history for Perl extension DBIx::Class::Schema::Loader
a78e3fed 2
45a380dc 3 - remove is_deferrable from default rel options to maintain
4 principle of least surprise when round-tripping to deploy()
8a64178e 5 - rewrite datetime default functions as \'CURRENT_TIMESTAMP' where
6 possible (except for Sybase ASE) to ease cross-deployment
4337bddf 7 - use column_info instead of select to get Oracle column list (RT#42281)
be72dba7 8 - match quotes in MySQL parser in more places (RT#42101)
ae32aaf6 9 - fix unique detection in DB2 for multiple schemas (RT#39622)
9fdf3d5b 10 - fix column name collisions with methods (RT#49443)
3de915bc 11 - fix loading MySQL views on older MySQL versions (RT#47399)
12
5afd3e72 130.06001 2010-04-10 01:31:12
81ade4d9 14 - fix type info for MSSQL
103e90da 15 - fix MSSQL collation detection on freetds tds version 8.0
16
231688f8 170.06000 2010-04-06 01:12:25
26334ec1 18 - better type info for MySQL
19 - initial MySQL data type tests (jhannah)
2a8e93e9 20 - don't set result_namespace if it's 'Result'
9dc968df 21 - support for MSSQL databases with case sensitive collation, manually
22 overridable with 'case_sensitive_collation' option
71a6e88a 23 - do not try to detect driver and rebless when used with a custom
9dc968df 24 'loader_class'
bfb43060 25 - suppress 'bad table or view' warnings for filtered tables/views
27305cc1 26 - croak if several tables reduce to an identical moniker (ribasushi)
05f25b42 27 - better type info for Sybase ASE
df956aad 28 - better type info for Pg: sets sequence for serials, handles numerics
29 without precision
acfcc1fb 30 - better _tables_list for MSSQL
26da4cc3 31 - pick up views in SQLite too
32 - better rel inflection using Lingua::EN::Inflect::Phrase
53ef681d 33 - cascade_delete and cascade_copy are turned off for has_many/might_have
ee07e280 34 by default, and belongs_to has on_delete => 'CASCADE', on_update =>
35 'CASCADE' and is_deferrable => 1 by default, overridable via
36 relationship_attrs
37 - added config_file option for loading loader options from a file
0faae4b8 38 - set inflate_datetime => 1 for 'AS getdate()' computed columns in
39 Sybase
cf0ba25b 40 - Firebird support
829f17e3 41 - use introspection pragmas instead of regexes to introspect SQLite
42 (hobbs)
f170d55b 43 - generate POD for refs correctly from column_info
9dc968df 44 - fix tables list, fk introspection and type info for SQL Anywhere
05c54730 45
e42ec4ef 460.05003 2010-02-20 05:19:51
d8cbfbb8 47 - support for custom_column_info, datetime_timezone and datetime_locale
48 (rbo)
9fd0726a 49 - improve parsing of SQLite tables when a column definition
50 spans multiple lines (hobbs)
db36a574 51 - fix missing trailing _id stripping for some relationship
52 names (rbuels)
0547c283 53 - fixed accessor POD bug, was not dereferencing scalar refs
54 before printing (rbuels)
db36a574 55
83b38372 560.05002 2010-02-15 10:17:47
8793567f 57 - support for SQLAnywhere via DBD::SQLAnywhere and ODBC
83b38372 58 - fix picking up quoted tables for SQLite (RT#54538) patch from schwern
2a5dcfb3 59 - validate class/component loader_options to make sure classes
83b38372 60 are available before generating the schema, patch from bphillips
2a5dcfb3 61
dc767cd3 620.05001 2010-02-05 14:29:27
41968729 63 - correct default_value for all backends with common tests
64 - fix bug with quoted Pg tables from $dbh->tables (RT#54338)
65 - add inflate_datetime => 0 to 'timestamp' types for Sybase
66
ca7feebf 670.05000 2010-02-01 09:24:24
f730e1b6 68 - better data_type, default_value and size for Sybase
492dce8d 69 - added 'generate_pod' option, defaults to on
43b982ea 70 - added 'pod_comment_mode' and 'pod_comment_spillover_length' to
71 control table comment generation (waawaamilk)
492dce8d 72
04e60ed2 730.04999_14 2010-01-14 06:47:07
540a8149 74 - use_namespaces now default, with upgrade/downgrade support
805dbe0a 75 - filter out un-selectable tables/views
d4d1a665 76 - fix NUMERIC/DECIMAL size column_info for postgres
59f54738 77 - now mentions skip_load_external feature in comments (jhannah)
78 - moniker_map POD correction (jhannah)
d4d1a665 79
1fa18849 800.04999_13 2010-01-03 12:32:25
afb4c5bc 81 - exclude 'size' column_info for postgres when unnecessary, and
82 use the correct precision for varying types (except NUMERIC)
30a4c064 83 - 'naming' attribute and backward compatibility with 0.04006
7b505bbd 84 - added relationship_attrs option for setting attributes in
85 generated relationships
72cd9295 86 - added overwrite_modifications option that ignores md5sums on
87 generated code
33fb8fa0 88 - added skip_load_external (jhannah)
1fa18849 89 - remove Class::Data::Accessor and Class::Accessor::Fast and switch
33fb8fa0 90 everything to Class::Accessor::Grouped (jhannah)
46065bcb 91 - better handling of db_schema for Oracle, based on (RT#35732)
92
0a701ff3 930.04999_12 2009-11-30 23:36:14
309e2aa1 94 - fix MySQL rel introspection with on_connect_call =>
95 'set_strict_mode' (RT#52087)
96 - now using base 'DBIx::Class::Core' for Results (RT#52141)
97
a06118a6 980.04999_11 2009-11-29 18:08:46
fbcfebdd 99 - added patch to generate POD from postgres by Andrey Kostenko (GUGU)
4daef04f 100 - added test for norewrite feature
5c6fb0a1 101 - fix default_value for MSSQL
102
b1ad1a84 1030.04999_10 2009-10-31 12:28:53
8803e4ed 104 - patch from Robert Bohne to make _table_uniq_info more correct for
105 Oracle
b1ad1a84 106 - fix data_type for identity columns with MSSQL
8803e4ed 107
c25ff208 1080.04999_09 2009-10-08
79193756 109 - Only redump the files when something has actually changed
b4dcbcc5 110 - Place a warning at the top of the files saying 'do not modify' to
111 match the one at the bottom of the auto-gen'd section
79193756 112
c25ff208 1130.04999_08 2009-08-28
6ae3f335 114 - Replace UNIVERSAL::require with Class::C3::Componentised
3f4461a5 115 - Add Sybase/MSSQL support through DBD::Sybase
1bcb47d3 116 - use $dbh->get_info(29/41) for qote_car/name_sep if available (semifor)
bfe03a54 117 - add MSSQL support through DBD::ODBC
1bcb47d3 118 - support MSSQL table names with a '.' in the name
119 - support MySQL CURRENT_TIMESTAMP()
6ae3f335 120
c25ff208 1210.04999_07 2009-04-18
a28b70f1 122 - Add result_base_class and schema_base_class options (RT #43977)
d70c335f 123 - Ignore duplicate uniq indices (including duplicates of the PK).
632cb26f 124 - Fix for DBD::SQLite 1.20
706ef173 125 - Fix for DBIx::Class 0.08100
76c488a6 126
c25ff208 1270.04999_06 Tue Nov 11, 2008
22270947 128 - Singularise table monikers by default
e7886624 129 - Strip trailing _id from single-column belongs_to relationships
ff746964 130 - Add "dbicdump" script for easy commandline dumping
af31090c 131 - Throw out the in-memory class generation, just dump to a temporary
132 directory if the user didn't specify one
c7bf4194 133 - Fix Oracle constraint and auto-increment detection for non-owned schemas
134 (RT #35732)
c25ff208 135 - Handle ResultSetManager deprecation warning in common tests
22270947 136
c25ff208 1370.04999_05 Mon Apr 14, 2008
072d5aae 138 - Fix limiting table list to the specified schema for DB2
7a930e63 139 - Default db_schema to the username for DB2
29ddb54c 140 - Allow specifying a custom loader_class, overriding the
141 storage_type-based detection
565ca24d 142 - Cosmetic fixes to dumping of externally defined classes
2a620a1b 143 - Make ResultSetManager notice externally defined :ResultSet methods
2328d1fc 144 - Fix test failure for non-InnoDB MySQL due to wrong skip count
390bbe3f 145 - Fix base class ordering in dumped classes
146 - Run the common tests against both dynamic and dumped versions of
147 the schema
072d5aae 148
c25ff208 1490.04999_04 Wed Mar 12, 2008
772cfe65 150 - Add is_auto_increment detecton for DB2
151
c25ff208 1520.04999_03 Wed Mar 12, 2008
28357fd3 153 - Fix DB2 support
154
c25ff208 1550.04999_02 Tue Feb 12, 2008
fb328d1a 156 - Add is_auto_increment detection for Oracle
d87d939a 157 - Unnhide the Oracle module now that the CPAN perms are sorted
158 out. Thanks to Tsunoda Kazuya for the quick response.
fb328d1a 159
c25ff208 1600.04999_01 Tue Feb 5, 2008
e7213f4f 161 - Mark foreign key columns with is_foreign_key => 1
c5baf131 162 - Add support for vendor-specific extra column attributes.
8fdd52a2 163 - Add support for extra => { unsigned => 1 } for MySQL.
46bef65f 164 - Add support for enum value lists for MySQL
7dba7c70 165 - Set join_type => 'LEFT OUTER' for nullable foreign keys
166 (patch from Bernhard Weißhuhn)
78b7ccaa 167 - Set is_auto_increment for auto-increment columns (RT #31473)
168 (Only SQLite, MySQL and PostgreSQL are currently supported)
af99957c 169 - Generate one-to-one accessors for unique foreign keys (ilmari)
a1726271 170 - Add support for load_namespaces-style class layout
45f3698a 171 - Fix test skip count for main skip_rels block
a1726271 172 - Fix auto-inc column creation for the Oracle tests
75a0d986 173 - Fix column ordering in unique constraints for Oracle
2ffd6b4c 174 - Fix Win32 test skip counts for good (RT #30568, Kenichi Ishigaki)
d0e184e9 175 - Default Oracle db_schema to db username (patch
176 from Johannes Plunien)
af99957c 177
c25ff208 1780.04003 Wed Oct 4, 2007
f1f25439 179 - Prevent users from running Kwalitee test automatically
9616156f 180 - Fix extra whitespace being added to output on
181 regeneration (from ilmari)
182
c25ff208 1830.04002 Tue Jul 24, 2007
c39e3507 184 - rescan method now returns the actual list of new tables
185 loaded (previously, the return value wasn't taking
186 constraint/exclude into account, even though the meat
187 of the operation was).
188 - Hid the Oracle module so that search.cpan.org will stop
189 ignoring this package, temporary fix until perms are
190 sorted out
1c1efbce 191 - Fix Win32 test skip counts (RT #27715, Alexandr Ciornii)
192 - Fix a small output quoting bug (RT #28073, Tokuhiro Matsuno)
09c19d42 193
c25ff208 1940.04001 Tue Jun 26, 2007
28b4691d 195 - Deprecated dump_overwrite. The changed behavior from
196 0.03xxx was confusing.
197 - Added new option really_erase_my_files, which does what
198 dump_overwrite did in 0.04000, which is not what it did
199 in 0.03xxx.
200
c25ff208 2010.04000 Thu Jun 7, 2007
7507c8ce 202 - Added some env vars for controlling the Makefile.PL feature
203 questions, to make automation easier.
204
c25ff208 2050.03999_02 Tue May 22, 2007
3fe9c5d9 206 - Converted to Module::Install
207
c25ff208 2080.03012 Tue May 22, 2007
0c0a7757 209 - Relationship names for multiple multi-col rels between
210 the same table fixed by ilmari
211 - Fix from Marc Espie for CREATE TABLE 'foo' for SQLite
522ee84e 212 - skip ^sqlite_ tables in SQLite (thanks chromatic)
213
c25ff208 2140.03999_01 Sat Apr 14 19:57:40 GMT 2007
e7262300 215 - Added *experimental* Oracle support from work done
216 by Tsunoda Kazuya some months ago. Not well tested.
7fa9a8b1 217 - Added "rescan" schema (and loader) method, which picks
218 up newly created tables at runtime
7cab3ab7 219 - Made dump_to_dir / dump_overwrite much more intelligent
220 (they now preserve customizations by default)
fd589700 221 - Added support for DBI's new standard "statistics_info"
222 method to gather unique key info (only supported by
79fe0081 223 DBD::Pg trunk afaik)
12af3806 224 - columns_info_for imported from DBIx::Class
225 - relationships are now on by default, use skip_relationships
226 to disable them
227 - Removed previously deprecated methods/options
32f784fc 228 - Added $VERSION to all packages in this dist
229
c25ff208 2300.03011 Sat Apr 14 19:03:07 UTC 2007
050003c5 231 - fix case-sensitivity in UNIQUE parsing for SQLite
232
c25ff208 2330.03010 Thu Mar 29 12:36:19 UTC 2007
518472fa 234 - Workaround for new incompatible changes in DBD::mysql's "tables"
235 method, which was causing us to find no tables w/ DBD::mysql
236 4.002+
a0cc2498 237 - Fixed quoting problem in _table_columns (could cause crash when
238 dumping/doing a static create) (from ash)
239
c25ff208 2400.03009 Wed Nov 15 14:03:37 UTC 2006
a0cc2498 241 - fix for rt.cpan.org #22425 (use File::Spec where appropriate)
242 - use full instead of short classnames in relationships (from victori)
01de2418 243
c25ff208 2440.03008 Fri Oct 20 18:08:20 UTC 2006
88603c41 245 - fix for rt.cpan.org #21084 (dump_overwrite pathological output recursion)
246 - fix for rt.cpan.org #21758 (mysql reserved words as table names)
247 - fix for rt.cpan.org #21025 (SQLite FK parsing)
248 - workaround for rt.cpan.org #21746 ($Class::Accessor::Fast::VERSION issues)
249
c25ff208 2500.03007 Thu Jul 27 16:19:59 UTC 2006
e682950b 251 - Kill erroneous warning about connect/loader_options order (the real
252 case is warned about elsewhere)
253 - Fix t/22dump to work around ActiveState issues
254
c25ff208 2550.03006 Wed Jul 26 00:14:58 UTC 2006
520107ef 256 - Fixed column-case issue w/ columns_info_for
257
c25ff208 2580.03005 Wed Jul 19 15:09:30 UTC 2006
8ac8926d 259 [ Pretty much everything in this release originates from nilsonsfj patches ]
260 - bugfix: mysql unique constraint code had an
261 obvious but longstanding error
262 - bugfix: columns were being specified out-of-order,
263 bug was introduced in the 0.03004 column metadata
264 dumping feature
02356864 265 - dump code now skips+warns instead of dies when
8ac8926d 266 dump_overwrite not set
02356864 267
c25ff208 2680.03004 Tue Jul 11 04:38:09 UTC 2006
d65cda9e 269 - make_schema_at efficiency improvements
270 - improved debugging output
271 - column metadata now included in dumped schemas
d65cda9e 272 - Carp::Clan added, and some dies converted to croaks
273 - no longer overwrites files when dumping, unless asked
274 to do so via the dump_overwrite option
275 - loader_options can now be embedded in the connection info
276 - Documentation improvements
71b997e9 277 - Deprecation notices updated, most things that became
278 "deprecated" in 0.03 are now marked for death in 0.04000
279 - All deprecated usage patterns should now generate annoying
280 warnings (most did before).
281 - Somewhat improved test coverage
d65cda9e 282
c25ff208 2830.03003 Tue Jun 6 02:22:49 UTC 2006
e50425a9 284 - Fix inclusion of external add-on class definitions
285 in dump_to_dir output.
286
c25ff208 2870.03002 Tue Jun 6 01:27:25 UTC 2006
fc2b71fd 288 - rethrow exceptions that occur during make_schema_at
289
c25ff208 2900.03001 Mon Jun 5 23:17:57 UTC 2006
8f9d7ce5 291 - load_from_connection deprecation notice now mentions
292 upgrading Catalyst::Model::DBIC::Schema if that module
293 seems to be in use.
5223f24a 294 - DBIx::Class required version number fixed
295 - Loader statement caching for better load-time performance
296 - Improved Pg unique index loader, based on RDBO
297
c25ff208 2980.03000 Tue May 23 12:56:05 UTC 2006
074e81cd 299 - weakened the circular schema reference
300
c25ff208 3010.02999_10 Mon May 22 18:58:20 UTC 2006
996be9ee 302 - a few more small bugfixes
303 - more dump/debug improvements
304 - new exportable function "make_schema_at"
305
c25ff208 3060.02999_09 Sun May 21 23:26:58 UTC 2006
996be9ee 307 - More docs improvements
308 - default uniq_info just warns and returns nothing now,
309 instead of dying. In theory, this allows unsupported
310 DBD drivers to potentially work with this module, if
311 the generic methods happen to work for that vendor.
312 - New tests for the various current and legacy/deprecated
313 methods of connecting a Schema::Loader class/object.
314 - Bugfix to the new runtime object connect/load code.
315
c25ff208 3160.02999_08 Sat May 20 22:36:45 UTC 2006
996be9ee 317 - support for dumping to a directory for
318 conversion to manual DBIx::Class::Schema
319 - improved debugging output
320 - more documentation updates
321 - more backwards compatibility fixes
322 - runtime connection definitions (and cloning) work fine now.
323 - A couple of bugfixes related to db vendor "schemas", including
324 a fix for http://rt.cpan.org/Public/Bug/Display.html?id=19164
325
c25ff208 3260.02999_06 Thu May 18 16:32:41 UTC 2006
996be9ee 327 - backwards compat with all earlier versions
328 - no longer requires schema class to have a connection
329 - correctly determine source class names in the rel code generator
330 - fixed mysql testing w/o InnoDB
331 - Writing guide updated
332 - docs updated
333 - various trivial updates / fixes
334
c25ff208 3350.02999_05 Sun Mar 26 06:46:09 UTC 2006
996be9ee 336 - bugfixes to constraint/exclude code
337 - friendly warnings if we don't find any tables
338 - inflect_map becomes inflect_plural and inflect_singular
339 - Singularize relationship names where appropriate
340 - Test updates
341 - Supports multiple rels between the same pair of tables
342
c25ff208 3430.02007 Wed Mar 22 06:03:53 UTC 2006
ac890564 344 - Backported Class::C3::reinitialize changes from -refactor
a0cc2498 345 branch, resulting in significantly reduced load time
09d632a1 346
c25ff208 3470.02006 Fri Mar 17 04:55:55 UTC 2006
ac5ad557 348 - Fix long-standing table/col-name case bugs
349
c25ff208 3500.02999_04 Fri Mar 17 03:55:09 UTC 2006
996be9ee 351 - Fixed case-sensitivity issues for table/col names
352 - Punt columns_info_for to ->storage
353 - Large loading speedup (get rid of redundant C3 reinits)
354 - Removed TEST_POD checks
355 - Removed unneccesary storage->disconnect
356
c25ff208 3570.02999_03 Mon Mar 13 15:01:11 UTC 2006
996be9ee 358 - Added EXAMPLE section to pod [Kieren Diment]
359 - Invasive heavy changes to the DBI- and vendor-specific code
360 (expect some breakage in some cases until this settles down)
361 - Support for loading UNIQUE constraints
362 - Tests cleaned up a bit
363 - Relationship building seperated out into it's own file for
364 the changes that are coming, but still does basically what
365 it did before (this work is the next step).
366
c25ff208 3670.02999_02 Sat Mar 4 16:53:21 UTC 2006
996be9ee 368 - Merged in relevant changes from trunk since the split
369
c25ff208 3700.02005 Mon Feb 27 23:53:17 UTC 2006
d161cb49 371 - Move the external file loading to after everything else
a0cc2498 372 loader does, in case people want to define, override, or
373 build on top of the rels.
d161cb49 374
c25ff208 3750.02004 Mon Feb 27 23:53:17 UTC 2006
1b311bbb 376 - Minor fix to debugging message for loading external files
377
c25ff208 3780.02999_01 Sun Feb 28 00:24:00 UTC 2006
996be9ee 379 - Shuffle the modules around
380 - Make ourselves theoretically storage_type-agnostic
381 - Remove the _db_classes stuff, bump PK::Auto to Base
382 - Change default inflections to Lingua::EN::Inflect::Number::to_PL()
383
c25ff208 3840.02003 Sun Feb 19 20:42:01 UTC 2006
1031d4f6 385 - Deprecated arguments: dsn, user, password, options
386 - New argument: connect_info
387
c25ff208 3880.02002 Sat Feb 18 19:53:12 UTC 2006
4350370d 389 - Added moniker_map and inflect_map
390
c25ff208 3910.02001 Fri Feb 17 20:25:40 UTC 2006
c2849787 392 - tests fixed up a bit
17725ccb 393 - auto-loading of on-disk class definitions layered on top
394 of the generated definitions (create Foo::Schema::Bar, then
395 also try to ->require it if it exists on disk).
396 - new parameters components and resultset_components, which do
397 the obvious for the generated table classes.
398 - DBIx::Class pre-req bumped to 0.05006, since Schema::Loader
399 is virtually gauranteed to cause subtle mod_perl problems
400 without those fixes.
c2849787 401
c25ff208 4020.02000 Sun Feb 12 22:43:47 UTC 2006
89ecd854 403 - Just docs/version update, 0.01004 code released as 0.02000
404
c25ff208 4050.01004 Tue Feb 7 03:58:01 UTC 2006
738705c6 406 - No longer tries to parse out the table name from the dsn for mysql,
407 was unneccesary vestigial code from previous method.
408
c25ff208 4090.01003 Mon Feb 6 14:57:56 UTC 2006
c5de0b0c 410 - Fixed the has_many side of _make_cond_rel
411
c25ff208 4120.01002 Fri Feb 3 23:14:38 UTC 2006
f654c972 413 - Email address typo :(
414
c25ff208 4150.01001 Fri Feb 3 05:15:41 UTC 2006
457eb8a6 416 - Fixed up some documentation issues
417 - Load C3 at the right time
418
aec93e93 4190.01 Fri Feb 3 01:53:46 UTC 2006
420 - original release
421 - created from DBIx::Class::Loader 0.14