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