Document the horrible, changelog. I'm going to merge this and fix a real issue as...
[catagits/Catalyst-Runtime.git] / Changes
1 # This file documents the revision history for Perl extension Catalyst.
2
3  New features:
4   - An 'action_class' method has been added to Catalyst::Controller to
5     allow controller base classes, roles or traits
6     (e.g. Catalyst::Controller::ActionRole) to more easily override
7     the default action creation.
8
9  Bug fixes:
10   - Fix the --mech and --mechanize options to the myapp_create.pl script
11     to operate correctly by fixing the options passed down into the script.
12   - Fix controllers with no method attributes (where the action definitions
13     are entirely contained in config). RT#58057
14
15  Documentation:
16   - Fix missing - in the docs when describing the --mechanize option at one
17     point.
18   - Explained the common practice how to access the component's config
19     values.
20   - Fixed typo in Catalyst/Script/Server.pm (RT #58474)
21
22 5.80024 2010-05-15 11:55:44
23
24   Bug fixes:
25    - Revert the path resolution behaviour to how it used to work before
26      Catalyst 5.80014_02, so that application paths are (by default)
27      resolved from $ENV{PATH_INFO} and $ENV{SCRIPT_NAME}. This fixes backward
28      compatibility breakage seen by a number of people since that release
29      with mod_rewrite and SSI.
30
31   New features:
32    - Add a use_request_uri_for_path config setting to optionally
33      use the (more correct) $ENV{REQUEST_URI} path resolution behaviour.
34
35   Documentation:
36    - Clarify the documentation for the Catalyst::Stats interface.
37    - Copious documentation about the use_request_uri_for_path feature
38      and the implications of setting this to true/false in
39      Catalyst::Engine::CGI
40
41 5.80023 2010-05-07 23:50:27
42
43   Bug fixes:
44    - Ensure to always cleanup temporary uploaded files in all cases, even
45      when exceptions occur during request processing, using HTTP::Body's
46      ->cleanup feature. (RT#41442)
47    - Ensure that Catalyst::Engine::HTTP's options hash is defined before
48      dereferencing it. (RT#49267)
49    - Fix regex special characters in REDIRECT_URL variable breaking
50      the request base. (2nd part of RT#24951)
51    - Fix not stripping backslashes in DispatchType::Regex::uri_for_action
52
53   New features:
54    - Setting __PACKAGE__->config(enable_catalyst_header => 1); in your MyApp.pm
55      now enables the X-Catalyst header being printed when not in debug mode.
56    - Require CGI::Simple::Cookie version 1.109 to ensure support for the
57      HttpOnly flag
58    - Allow the myapp_test.pl script to be given a list of paths which it
59      will retrieve all of. (RT#53653)
60    - Allow parameterized roles to be applied as plugins.
61    - Allow requiring minimum versions of plugins when loading them.
62
63   Documentation:
64    - The Catalyst::Test::get method is documented as returning the raw
65      response bytes without any character decoding (RT#53678)
66
67   Cleanups:
68    - Removal of $Catalyst::PRETTY_VERSION. Future releases will always have the
69      full and unmangled version number, including trailing zeroes, in
70      $Catalyst::VERSION.
71
72 5.80022 2010-03-28 19:43:01
73
74   New features:
75    - Log an extra line in debug mode with the response status code,
76      the content type and content length if available.
77
78   Refactoring / optimizations:
79    - Display of the end of hit debug messages has been factored out into
80      log_headers, log_request, log_request_headers, log_response,
81      log_response_status_line and log_response_headers methods so that
82      plugins which customise how much information is shown on the debug
83      screen as easy to write.
84    - Make all logging of request and response state get the information from
85      $c->dump_these so that there is a unified point from which to hook
86      in parameter filtering (for example).
87    - $c->model/view/controller have become a lot faster for non-regexp names
88      by using direct hash lookup instead of looping.
89    - IP address => hostname mapping for the server is only done once and cached
90      by Catalyst::Engine::HTTP to somewhat mitigate the problem of people
91      developing on machines pointed at slow DNS servers.
92
93   Bugs fixed:
94     - DispatchType::Index's uri_for_action only returns for actions registered
95       with it (prevents 'index :Path' or similar resolving to the wrong URI)
96     - Make sure to construct Upload objects properly, even if there are
97       multiple Content-Type headers (Closes RT#55976).
98
99 5.80021 2010-03-03 23:02:01
100
101   Bug fixed:
102    - $c->uri_for will now escape unsafe characters in captures
103      ($c->request->captures) and correctly encode utf8 charracters.
104
105 5.80020 2010-02-04 06:51:18
106
107   New features:
108     - Allow components to specify additional components to be set up by
109       overriding the expand_modules method. (Oliver Charles)
110
111 5.80019 2010-01-29 01:04:09
112
113   Bug fixed:
114    - Calls to $c->uri_for with private paths as strings (e.g.
115      $c->uri_for('controller/action', 'arg1', 'arg2') ) no longer have
116      / encoded to %2F. This is due to $c->uri_for('static', 'css/foo', $bar)
117      which should not be encoded.
118      Calls with an action object (rather than a string), or uri_for action
119      will still encode / in args and captures to %2F
120
121    - The above noted / => %2F encoding in uri_for_action or uri_for with
122      an action object has been fixed to not just encode the first slash in
123      any set of args/captures.
124
125    - nginx and lighttpd FCGI requests with URI encoded sections as the first
126      path part have been fixed to operate correctly.
127
128    - A source of bogus warnings in Catalyst::Component::BUILDARGS has been
129      removed.
130
131   Documentation:
132    - Improve the documentation about -Home and how Catalyst finds the home path
133      for applications.
134    - Various minor typo fixes.
135
136   New features:
137    - Allow passing additional arguments to action constructors.
138
139 5.80018 2010-01-12 22:24:20
140
141   Bug fixed:
142    - Call ->canonical on URI derived from $ENV{REQUEST_URI} to get
143      paths correctly decoded. This bug was previously hidden by a bug
144      in HTTP::Request::AsCGI.
145
146   Documentation:
147    - Clarify that uri_for_action works on private paths, with example.
148    - Clarify documentation about debug
149
150   Deprecations:
151    - Saying use Catalyst::Test; (without an application name or () to stop
152      the importer running is now deprecated and will issue a warning.
153      You should be saying use Catalyst::Test ();
154
155 5.80017 2010-01-10 02:27:29
156
157   Documentation:
158    - Fix docs for ->forward method when passed a class name - this should
159      be a component name (e.g. View::HTML, not a full class name, like
160      MyApp::View::HTML).
161
162   Bug fixes:
163    - --daemon and -d options to Catalyst::Script::FastCGI are fixed.
164    - Fix the debug dump for applications which use Catalyst::Plugin::Session
165      (RT#52898)
166    - Fix regression in the case where mod_rewrite is being used to rewrite
167      requests into a path below your application base introduced with the
168      %2F related fixes in 5.80014_02.
169    - Do not crash on SIGHUP if Catalyst::Engine::HTTP->run is not passed the
170      argv key in the options hash.
171    - Correctly pass the arguments to Catalyst::Script::Server through to
172      Catalyst::Engine::HTTP->run so that the server can restart itself
173      with the correct options on SIGHUP.
174    - Require new MooseX::MethodAttributes to be compatible with Moose
175      versions >= 0.93_01
176    - Require new MooseX::Role::WithOverloading to be compatible with Moose
177      versions >= 0.93_01
178
179   Cleanups:
180     - Stop suppressing warnings from Class::C3::Adopt::NEXT now that most plugins
181       have been updated to not use NEXT. If you get warnings then please upgrade
182       your components or log a bug with the component author if an upgrade is
183       not available. The Class::C3::Adopt::NEXT documentation contains information
184       about how to suppress the warnings in your application if you need to.
185
186 5.80016 2009-12-11 23:23:33
187
188   Bug fixes:
189
190    - Fix slurping a file to work correctly with binary on Win32 in the
191      encoding test controller.
192
193   Bug fixes in the new scripts (for applications which have been upgraded):
194
195    - Allow --restartdirectory as an option for the Server script, for
196      backwards compatibility. (Dave Rolsky)
197    - The --host option for the server script defaulted to localhost, rather
198      than listening on all interfaces, which was the previous default. (Dave
199      Rolsky)
200    - Restore -p option for pid file in the FastCGI server script.
201    - Fix the script environment variables MYAPP_PORT and MYAPP_RELOAD RT#52604
202    - Fix aliasing applications under non-root paths with mod_rewrite in
203      some apache versions where %ENV{SCRIPT_NAME} is set to the real name of
204      the script, by using $ENV{REDIRECT_URL} which contains the non-rewritten
205      URI.
206    - Fix usage display when myapp_create.pl is run with no arguments. RT#52630
207
208   New features:
209
210    - The __MOP__ hash element is suppressed from being dumped fully
211      (and instead stringified) when dumping the error screen to be
212      less packed with information of no use.
213
214   Documentation:
215
216    - Fix Pod nits (RT#52370)
217
218 5.80015 2009-12-02 15:13:54
219   Bug fixes:
220    - Fix bug in Catalyst::Engine which would cause a request parsing to end
221      prematurely in the hypothetical case where calling $engine->read returned
222      the single character '0'.
223    - Fix failing tests when combined with new HTTP::Request::AsCGI
224
225   Documentation:
226    - Improved documentation on read and read_chunk methods in Catalyst::Engine.
227    - Fix reversal of SCRIPT_NAME and PATH_INFO in previously correct nginx
228      FastCGI documentation introduced in _02.
229
230 5.80014_02 2009-12-01 00:55:23
231   Bug fixes:
232    - Fix reporting the wrong Content-Length if the response body is an
233      upgraded string. Strings mean the same thing whether or not they are
234      upgraded, may get upgraded even after they are encoded, and will
235      produce the same output either way, but bytes::length returns too big
236      values for upgraded strings containing characters >127
237    - Fix t/live_fork.t with bleadperl (RT#52100)
238    - Set $ENV{PATH_INFO} from $ENV{REQUEST_URI} combined with
239      $ENV{SCRIPT_NAME} if possible. This is many web servers always fully
240      decode PATH_INFO including URI reserved characters. This allows us to
241      tell foo%2cbar from foo%252cbar, and fixes issues with %2F in paths
242      being incorrectly decoded, resulting in too many path parts (rather
243      than 1 path part containing a /, on some web servers (at least nginx).
244      (RT#50082)
245    - Require new HTTP::Request::AsCGI so that it fully decodes $ENV{PATH_INFO}
246      in non CGI contexts. (RT#50082)
247
248   Refactoring / cleanups:
249    - NoTabs and Pod tests moved to t/author so that they're not run
250      (and then skipped) normally.
251
252   Documentation:
253     - Fix Pod nits in Catalyst::Response (RT#51818)
254
255 5.80014_01 2009-11-22 20:01:23
256
257   Bug fixes:
258    - Filehandle now forced to binmode in CGI and FastCGI engines. This appears
259      to correct some UTF-8 issues, but may break people's code which relies
260      on the old behaviour.
261
262   Refactoring / cleanups:
263    - Plugins which inherit from Catalyst::Controller or Catalyst::Component
264      are deprecated and now issue warnings.
265
266 5.80014 2009-11-21 02:51:14
267
268    Bug fixes:
269     - Require MooseX::MethodAttributes 0.17. This in turn requires new
270       MooseX::Types to stop warnings in Moose 0.91, and correctly supports
271       role combination of roles containing attributed methods.
272     - Catalyst::Dispatcher::dispatch_types no longer throws deprecated warnings
273       as there is no recommended alternative.
274     - Improved the suggested fix warning when component resolution uses regex
275       fallback for fully qualified component names.
276     - Catalyst::Test::local_request sets ->request on the response.
277     - Log flush moved to the end of setup so that roles and plugins which
278       hook setup_finalize can log things and have them appear in application
279       startup, rather than with the first hit.
280     - Require a newer version of LWP to avoid failing tests.
281     - Stop warnings when actions are forwarded to during dispatch.
282     - Remove warnings for using Catalyst::Dispatcher->dispatch_types as this is a
283       valid method to publicly call on the dispatcher.
284     - Args ($c->request->args) and CaptureArgs ($c->request->captrues)
285       passed to $c->uri_for with an action object ($c->action) will now
286       correctly round-trip when args or captures contain / as it is now
287       correctly uri encoded to %2F.
288
289   Documentation:
290     - Document no-args call to $c->uri_for.
291     - Document all top level application configuration parameters.
292     - Clarify how to fix actions in your application class (which is
293       deprecated and causes warnings).
294     - Pod fixes for ContextClosure.
295     - Fix documentation for go/visit to reference captures and arguments
296       in the correct order.
297     - Update $c->forward and $c->state documentation to address scalar
298       context.
299     - Pod fix in Catalyst::Request (RT#51490)
300     - Pod fixes to refer to ::Controller:: rather than ::C:: as the latter
301       is deprecated (RT#51489)
302
303   New features:
304     - Added disable_component_resolution_regex_fallback config option to
305       switch off (deprecated) regex fallback for component resolution.
306     - Added an nginx-specific behavior to the FastCGI engine to allow
307       proper PATH_INFO and SCRIPT_NAME processing for non-root applications
308     - Enable Catalyst::Utils::home() to find home within Dist::Zilla built
309       distributions
310     - Added the Catalyst::Exception::Interface role defining the interface
311       exception classes need to implement.
312     - Added Catalyst::Exception::Basic as a basic implementation of
313       Catalyst::Exception::Interface and made the existing exception classes
314       use it.
315
316   Refactoring / cleanups:
317     - Remove documentation for the case_sensitive setting
318     - Warning is now emitted at application startup if the case_sensitive
319       setting is turned on. This setting is not used by anyone, not
320       believed to be useful and adds unnecessary complexity to controllers
321       and the dispatcher. If you are using this setting and have good reasons
322       why it should stay then you need to be shouting, now.
323     - Writing to $c->req->body now fails as doing this never makes sense.
324
325 5.80013 2009-09-17 11:07:04
326
327    Bug fixes:
328      - Preserve immutable_options when temporarily making a class mutable in
329        Catalyst::ClassData as this is needed by new Class::MOP.
330        This could have potentially caused issues when using the deprecated runtime
331        plugins feature in an application with plugins which define their own new
332        method.
333      - Require new Moose version and new versions of various dependencies
334        to avoid warnings from newest Moose release.
335      - Fix go / visit expecting captures and arguments in reverse order.
336
337   Documentation:
338      - Rework the $c->go documentation to make it more clear.
339      - Additional documentation in Catalyst::Upgrading covering more deprecation
340        warnings.
341
342   Refactoring / cleanups:
343      - Action methods in the application class are deprecated and applications
344        using them will now generate a warning at startup.
345      - The -short option has been removed from catalyst.pl, stopping new
346        applications from being generated using the ::[MVC]:: naming scheme as
347        this is deprecated and generates warnings. RT#49771
348
349 5.80012 2009-09-09 19:09:09
350
351   Bug fixes:
352      - Fix t/optional_http-server.t test.
353      - Fix t/optional_http-server-restart.t test.
354      - Fix duplicate components being loaded at setup time, each component is
355        now loaded at most once + tests.
356      - Fix backward compatibility - hash key configured actions are stored in
357        is returned to 'actions'.
358      - Fix get_action_methods returning duplicate methods when a method is both
359        decorated with method attributes and set as an action in config.
360
361   Refactoring / cleanups:
362      - Reduce minimum supported perl version from 5.8.6 to 5.8.4 as there are
363        many people still running/testing this version with no known issues.
364
365   Tests:
366      - Make the optional_http_server.t test an author only test which must be
367        run by authors to stop it being broken again.
368      - Fix recursion warnings in the test suites.
369
370 5.80011 2009-08-23 13:48:15
371
372   Bug fixes:
373       - Remove leftovers of the restarter engine. The removed code caused test
374         failures, which weren't apparent for anyone still having an old version
375         installed in @INC.
376
377 5.80010 2009-08-21 23:32:15
378
379   Bug fixes:
380       - Fix and add tests for a regression introduced by 5.80008.
381         Catalyst::Engine is now able to send out data from filehandles larger
382         than the default chunksize of 64k again.
383
384 5.80009 2009-08-21 22:21:08
385
386   Bug fixes:
387       - Fix and add tests for generating inner packages inside the COMPONENT
388         method, and those packages being correctly registered as components.
389         This fixes Catalyst::Model::DBIC among others.
390
391 5.80008 2009-08-21 17:47:30
392
393   Bug fixes:
394        - Fix replace_constructor warning to actually work if you make your
395          application class immutable without that option.
396        - Depend on Module::Pluggable 3.9 to prevent a bug wherein components
397          in inner packages might not be registered. This especially affected
398          tests.
399        - Catalyst::Engine::FastCGI - relax the check for versions of Microsoft
400          IIS. Provides compatibility with Windows 2008 R2 as well as
401          (hopefully) future versions.
402        - In tests which depend on the values of environment variables,
403          localise the environment, then delete only relevant environment
404          variables (RT#48555)
405        - Fix issue with Engine::HTTP not sending headers properly in some cases
406          (RT#48623)
407        - Make Catalyst::Engine write at least once when finalizing the response
408          body from a filehandle, even if the write is empty. This avoids fail
409          when trying to send out an empty response body from a filehandle.
410        - Catalyst::Engine::HTTP - Accept a fully qualified absolute URI in the
411          Request-URI of the Request-Line
412
413   Refactoring / cleanups:
414        - Deleted the Restarter engine and its Watcher code. Use the
415          new Catalyst::Restarter in a recent Catalyst::Devel instead.
416        - New unit test for Catalyst::Action 'unit_core_action.t'
417        - Bump minimum supported perl version from 5.8.1 to 5.8.6 as there are
418          known issues with 5.8.3.
419        - Debug output uses dynamic column sizing to create more readable output
420          when using a larger $ENV{COLUMNS} setting. (groditi)
421
422   New features:
423        - Added private_path method for Catalyst::Action
424        - Allow uri_for($controller_instance) which will produce a URI
425          for the controller namespace
426        - Break setup_components into two more parts: locate_components and
427          expand_component_module (rjbs)
428        - Allow Components to return anon classed from their COMPONENT method
429          correctly, and have action registration work on Controllers returned
430          as such by adding a catalyst_component_name accessor for all components
431          which returns the component instance's name to be used when building
432          actions etc.
433        - Adding X-Forwarded-Port to allow the frontend proxy to dictate the
434          frontend port (jshirley)
435        - Added Catalyst::Stats->created accessor for the time at the start of
436          the request.
437
438   Documentation:
439        - Fix POD to refer to ->config(key => $val), rather than
440          ->config->{key} = $val, as the latter form is deprecated.
441        - Clearer docs for the 'uri_for' method.
442        - Fix POD refering to CGI::Cookie. We're using CGI::Simple::Cookie.
443          (Forrest Cahoon)
444
445 5.80007 2009-06-30 23:54:34
446
447   Bug fixes:
448        - Don't mangle query parameters passed to uri_for
449          - Tests for this (Byron Young + Amir Sadoughi)
450        - Inherited controller methods can now be specified in
451          config->{action(s)}
452        - Assigning an undef response body no longer produces warnings
453        - Fix C3 incompatibility bug caused if you use Moose in MyApp.pm and
454          add Catalyst to the right hand side of this in @ISA.
455        - Make Catalyst.pm implement the Component::ApplicationAttribute
456          interface so defining actions in MyApp.pm works again, if the
457          actions have attributes that cause $self->_application to be used
458          (like ActionClass).
459
460   New features:
461        - Add optional second argument to uri_with which appends to existing
462          params rather than replacing them. (foo=1 becomes foo=1&foo=2 when
463          uri_with({ foo => 2 }, { mode => 'append' }) is called on a foo=1
464          URI.
465
466 5.80006 2009-06-29 23:37:47
467
468   Bug fixes:
469         - Revert change to URL encode things passed into $c->uri_for
470           Args and CaptureArgs as this causes breakage to pre-existing
471           applications.
472         - Remove use of Test::MockObject as it doesn't install from CPAN
473           in some environments.
474         - Remove use of dclone to deep copy configs and replace with
475           Catalyst::Utils::merge_hashes which has the same effect, of
476           ensuring child classes don't inherit their parent's config,
477           except works correctly with closures.
478         - Add Class::C3::reinitialize into Catalyst::Test to avoid weird
479           bugs in ctx_request (bokutin in RT#46459)
480         - Fix issues with _parse_PathPrefix_attr method in Catalyst::Controller
481           (jasonk in RT#42816)
482         - Fix bugs with action sorting:
483           - Path actions sorted so that the most specific wins.
484           - Action methods named default and index fixed.
485
486   New features:
487         - Use ~ as prefix for plugins or action classes which are located in
488           MyApp::Plugin / MyApp::Action (mo)
489         - Controller methods without attributes are now considered actions if
490           they are specified in config->{action(s)} (mo)
491         - Add Catalyst::Component::ContextClosure as an easy way to create code
492           references, that close over the context, without creating leaks.
493
494   Refactoring / cleanups:
495         - Clean namespaces in Catalyst::Exception*.
496         - Turn Catalyst::Exception into an actual class and make the throw
497           method create instances of it. They can still be used as normal
498           strings, as before, as they are overloaded to stringify to their
499           error message.
500         - Add a rethrow method to Catalyst::Exception.
501         - Add Catalyst::Exception::Detach and ::Go, and refactor detach() and
502           go() to use them instead of magic, global strings.
503           Fixes RT#47366
504         - Clean up getting metaclass instance and making app class immutable
505           again in Catalyst::Test
506
507 5.80005 2009-06-06 14:40:00
508
509   Behaviour changes:
510         - Arguments ($c->req->args) in Chained dispatch are now automatically
511           URL decoded to be consistent with Local/Path dispatch
512
513   Documentation:
514         - Clarify correct techniques for Moose controllers (domm)
515
516   Bug fixes:
517         - Further change pushing 'env' attribute down into Catalyst::Engine
518           to make $c->engine->env work in all cases (kmx)
519         - Also fix $c->engine->env in Catalyst::Test tests (kmx)
520           - Tests for this
521         - Fix Catalyst failing to start if any plugin changed $_ whilst
522           loading
523           - Tests for this
524         - Be stricter about arguments to Args attributes for Chained actions,
525           so that they blow up on load instead of causing undefined behavior
526           later on
527           - Tests for this
528         - Prefer Path actions with a smaller (or set) number of Args (caelum)
529           Bug reported here: http://stackoverflow.com/questions/931653/catalyst-action-that-matches-a-single-file-in-the-root-directory/933181#933181
530           - Tests for this
531
532    New features:
533         - Add $c->req->remote_user to disambiguate from $c->req->user (dwc)
534         - Require MooseX::MethodAttributes 0.12 so that action methods
535           (with attributes) can be used in / composed from Moose roles.
536         - Allow the generation of cookies with the HTTPOnly flag set
537           in Catalyst::Engine (kmx)
538
539 5.80004 2009-05-18 17:03:23
540         - Rename the actions attribute in Catalyt::Controller to
541           _controller_actions to avoid name clashes with application
542           controller naming. (random)
543         - Test for using Moose in components which have a non-Moose base class
544           Fixed by 349cda in Moose 0.78
545         - Fix deprecation message for Catalyst::Dispatcher to refer
546           to the class actually calling the deprecated method. RT#45741
547         - Clarify limitations of $request->base and $request->secure.
548           (Phil Mitchell)
549         - Add 'use Catalyst' to documentation for a Moose MyApp class as
550           noted by dmaki.
551         - Fix so that / (and other special characters) are URL encoded when
552           passed into $c->uri_for as Args/CaptureArgs
553         - Fix development server so that $c->engine->env returns the correct
554           environment
555         - Require Moose 0.78 to fix metaclass incompatibility issues
556         - Require MooseX::MethodAttributes 0.10 and use
557           Moose::Meta::Class->initialize rather than Moose->init_meta to fix
558           bugs related to having a 'meta' method in your controller
559         - Fix cases where your application failing to compile could cause perl
560           to report 'Unknown Error'
561         - Support adding Moose::Roles to the plugin list. These are applied to
562           MyApp after plugins have been pushed onto @ISA
563         - Fix calling $c->req->parameters as the first thing you do when
564           parse_on_demand is on
565
566 5.80003 2009-04-29 16:23:53
567         - Various POD tweaks. (hdp, dandv)
568         - Fix formatting error in the regex fallback warning.
569         - Convert the dispatcher's and restarter engine's BUILD method to
570           attribute builders to not override the BUILD method from
571           MooseX::Emulate::Class::Accessor::Fast.
572         - Fix classes without metaclasses restarting, when not using
573           B::Hooks::OP::Check::StashChange
574         - Fix the unattached chain debug table for endpoints with no
575           parents at all.
576         - Turn off test aggregation by default. Only aggregate if the
577           AGGREGATE_TESTS environment variable is set and a recent
578           Test::Aggregate is available.
579         - Bump to MooseX::MethodAttributes 0.09, to gain the
580           get_nearest_methods_with_attributes method allowing methods without
581           attributes in a subclass to override those with attributes in a
582           superclass. This fixes CatalystX::CRUD's method of overriding /
583           disabling functionality from base controllers.
584         - Bump HTTP::Request::AsCGI dependency to avoid broken version
585         - Bump Moose dependency to latest version to fix metaclass
586           incompatibility issues in some cases.
587         - Additional tests for setup_stats method.
588         - Fix log levels in Catalyst::Log to be properly additive.
589         - Fix RT#43375 by sorting results before testing them
590         - Fixes for uri_for_action when using Catalyst::DispatchType::Regex
591           + tests from RT#39369 (norbi)
592         - Partial rewrite and reoganisation of the C3 docs in
593           Catalyst::Upgrading based on feedback from kiffin
594         - If you make your application class immutable and turn off
595           constructor inlining, Catalyst will die and tell you pass
596           the (replace_constructor => 1) argument to
597           make_immutable. (Dave Rolsky)
598
599 5.80002 2009-04-22 01:28:36
600         - Fix CATALYST_DEBUG and MYAPP_DEBUG environment variables
601           turning debuging on if defined, rather than if set.
602           They now force debugging on or off, taking precedence over
603           configuration in your application.
604           - Tests for this
605         - pass replace_constructor to the immutable call to ensure
606           applications get a Moose constructor rather than a C::A one
607         - Fix issues with restarting the application class due to C3 failures
608           on perl 5.10
609         - Work around issues in Moose with initialization order of multiple
610           levels of non-Moose classes inheriting from a Moose class
611           - Test for this
612         - Add backwards compatibility method for Catalyst::Log->body, which
613           has been made private
614         - Fix so that calling $c->req->parameters(undef) does not flatten
615           the request parameters with undef + test
616         - Fix so that width of table of unattached actions for debugging
617           ::DispatchType::Chained varies according to your terminal width
618           (Oleg Kostyuk)
619         - Fix warning message about linearized @ISA in Catalyst::Component
620           (Emanuele Zeppieri)
621         - Require MX::MethodAttributes 0.06 to avoid issues with saying
622           use base 'Catalyst::Controller'; use Moose; losing actions
623         - Fix all of's typos in ::Upgrading and ::Delta (hobbs)
624
625 5.80001 2009-04-18 22:18
626         - Don't inline the constructor for Catalyst::Log to avoid a
627           warning on recent Moose versions.
628         - Add delta documentation
629         - Clean up recursion errors
630         - Extra cross links in dispatch types POD (Ian Wells)
631         - Test uri_with clears query params when they are set to undef
632           (Ian Wells)
633         - Complain about old Catalyst::Devel versions which generated
634           ->setup(qw/-Debug... etc. as this is not recommended
635
636 5.8000_07 2009-04-12 13:37
637         - Add the Catalyst::Dispatcher->dispatch_type method (ash)
638         - Throw an exception rather than loading an app if an action
639           tries to chain to itself
640           - Tests for this
641         - Change the $c->visit and $c->go methods to optionally take
642           CaptureArgs, making them useful to call ActionChains with
643           - Tests for this (radek)
644         - Fix _invoke_as_component method to find the proper action instance
645           for dispatchable actions so that ->visit or ->going to ActionChains
646           with qw/Class::Name method_name/ works correctly
647           - Tests for this (radek)
648         - Added Catalyst::Test::ctx_request to be able to inspect
649           the context object after a request is made (Jos Boumans)
650         - debug() POD rewrite (jhannah)
651         - Change the warning when you have conflicting components to
652           present a list
653         - Move NEXT use and testing deprecated features out to its own
654           test application so that the main TestApp isn't polluted with
655           spurious warnings
656         - Add a warning for the old ::[MVC]:: style naming scheme
657           - Test for this
658         - Kill Class::C3::Adopt::NEXT warnings for the Catalyst:: namespace
659           in production versions
660         - Tidy up Catalyst::ClassData to ensure that all components get
661           the correct metaclass
662         - Make MyApp.pm restartable by unsetting setup_finished in
663           the restarter process
664         - Non-naive implementation of making mutable on restart using
665           B::Hooks::OP::Check::StashChange if installed
666           - Tests for this
667         - Naive implementation of making all components mutable in the
668           forked restart watcher process so native Moose apps using
669           immutable restart correctly.
670           - Tests for this
671         - Bump Moose dependency to 0.70 so that we avoid nasty surprises
672           with is_class_loaded and perl 5.80 when you Moosify MyApp.pm
673         - Clarify that request arguments aren't unescaped automatically
674           (Simon Bertrang) (Closes RT#41153)
675         - Don't require C3 for the MRO test
676         - Bump MX::Emulate::CAF prereq to support list assignment
677         - Remove useless column in chained action debug table.
678         - namespace::clean related cleanups
679         - Import related cleanups and consistency fixes
680         - Fix test suite TestApp /dump/env action
681         - Add $res->code as alias for $res->status
682         - Make Catalyst::ClassData compatible with the latest Class::MOP::Class
683           changes. Also depend on the latest Class::MOP.
684         - Add $c->uri_for_action method.
685         - Don't stringify the meta method. Use its name instead.
686         - Use MooseX::MethodAttributes::Inheritable to contain action
687           attributes. This means that attributes are now represented in the MOP,
688           allowing method modifiers on actions to work as expected.
689         - Provide a reasonable API in Catalyst::Controller for working with
690           and registering actions, allowing a controller sub-class to replace
691           subroutine attributes for action declerations with an alternate
692           syntax.
693         - Instantiate correct sub-class of Moose::Meta::Class for non-Moose
694           components where Catalyst forces the creation of a metaclass instance.
695           This is more correct, and avoids metaclass incompatibility in complex
696           cases
697           - Tests for this
698         - Use of deprecated Catalyst::Base now warns.
699         - Add uri_with tests
700
701 5.8000_06 2009-02-04 21:00
702         - Disallow writing to config after setup
703         - Disallow calling setup more than once
704         - Documentation fix regarding overloading of Engine and Dispatcher
705           instances
706         - Several documentation typo fixes
707         - Stop Makefile.PL from warning about versions that fixed a conflict
708         - Improved upgrading documentation
709         - Seed the RNG in each FastCGI child process (Andrew Rodland)
710         - Properly report dynamic bind port for the development server
711           (Closes RT#38544)
712         - Use the way documented by IO::Socket::INET to get the error message
713           after trying to create a listening socket (Closes RT#41828)
714         - Don't ignore SIGCHLD while handling requests with the dev server
715           (Closes RT#42962)
716
717 5.8000_05 2008-29-01 00:00
718         - Text::SimpleTable's go as wide as $ENV{COLUMNS} (jhannah)
719           Patch written by Oleg Kostyuk <cub.uanic@gmail.com>
720         - Improve docs for visit (mateu)
721         - Add docs for finalize hook (dhoss)
722         - Added ru/ua translations to error page
723         - Improve the clarity and verbosity of the warning when component
724           resolution uses regex fallback. (jhannah)
725         - Handle leading CRLF in HTTP requests sometimes sent by IE6 in
726           keep-alive requests.
727         - Fixes for FastCGI with IIS 6.0 (janus)
728         - Passing request method exported by Catalyst::Test an extra
729           parameter used to be ignored, but started breaking if the parameter
730           was not a hash in 5.8000_04. Extra parameter is now ignored if
731           it isn't a hashref
732         - Fix request argumentss getting corrupted if you override the
733           dispatcher and call an action which detaches (for
734           Catalyst::Plugin::Authorization::ACL)
735         - Fix calling use Catalyst::Test 'MyApp' 'foo' which used to work,
736           but stopped as the 2nd parameter can be an options hash now
737         - Bump Moose dependency to fix make_immutable bug
738         - Use compile time extends in Catalyst::Controller
739         - Make Catalyst::Request::uploads attribute non-lazy, to fix
740           test for Catalyst-Engine-Apache
741         - Bump version of MooseX::Emulate::Class::Accessor::Fast
742         - Stop using MooseX::Adopt::Class::Accessor::Fast by default, to stop
743           breaking other packages which use Class::Accessor::Fast
744         - Remove unused action_container_class attribute from
745           Catalyst::Dispatcher
746         - Replace {_body} instance access with calls to _body accessors
747         - Add backwards compatibility alias methods for private attributes on
748           Catalyst::Dispatcher which used to be public. Needed by
749           Catalyst::Plugin::Server and  Catalyst::Plugin::Authorization::ACL
750         - Fix return value of $c->req->body, which delegates to the body
751           method on the requests HTTP::Body instance
752           - Test for this
753         - Fix calling $c->req->body from inside an overridden prepare_action
754           method in a plugin, as used by Catalyst::Plugin::Server
755           - Test for this
756         - Fix assignment to Catalyst::Dispatcher's preload_dispatch_types and
757           postload_dispatch_types attributes - assigning a list should later
758           return a listref. Fixes Catalyst::Plugin::Server.
759           - Tests for this
760         - Change streaming test to serve itself rather than 01use.t, making
761           test sync for engines easier
762         - Refactor capturing of $app from Catalyst::Controller into
763           Catalyst::Component::ApplicationAttribute for easier reuse in other
764           components
765         - Make the test suites YAML dependency optional
766         - Make debug output show class name for the engine and dispatcher
767           rather than the stringified ref.
768         - Make MyApp immutable at the end of the scope after the setup
769           method is called, fixing issues with plugins which have their
770           own new methods by inlining a constructor on MyApp
771           - Test for this and method modifiers in MyApp
772         - Fix bug causing Catalyst::Request::Upload's basename method
773           to return undef
774           - Test for this (Carl Franks)
775         - Fix loading of classes which do not define any symbols to not
776           die, as it didn't in 5.70
777           - Test for this
778         - Bump MooseX::Emulate::Class::Accessor::Fast dependency
779           to force new version which fixes a lot of plugins
780         - Make log levels additive, and add documentation and tests
781           for the setup_log method, which previously had none.
782           Sewn together by from two patches provided by David E. Wheeler
783         - Switch an around 'new' in Catalyst::Controller to a BUILDARGS
784           method as it's much neater and more obvious what is going on
785         - Add a clearer method on request and response _context
786           attributes, and use if from ::Engine rather than deleting
787           the key from the instance hash
788         - Use handles on tree attribute of Catalyst::Stats to replace
789           trivial delegation methods
790         - Change the following direct hash accesses into attributes:
791           Catalyst::Engine: _prepared_write
792           Catalyst::Engine::CGI: _header_buf
793           Catalyst::Engine::HTTP: options, _keepalive, _write_error
794           Catalyst::Request: _path
795           Catalyst::Stats: tree
796         - Fix issues in Catalyst::Controller::WrapCGI
797           and any other components which import (or define) their
798           own meta method by always explicitly calling
799           Class::MOP::Object->meta inside Catalyst
800           - Add test for this
801         - Add test case for the bug which is causing the
802           Catalyst::Plugin::Authentication tests to fail
803         - Fix a bug in uri_for which could cause it to generate paths
804           with multiple slashes in them.
805           - Add test for this
806         - Fix SKIP block name in t/optional_http-server-restart.t,
807           stopping 'Label not found for "last SKIP"' error from
808           Test::More
809         - Workaround max_redirect 0 bug in LWP
810         - Move live_engine_response_print into aggregate
811         - Fix dependency bug, s/parent/base/ in new test
812         - Fix optional tests to run the live tests in the aggregate
813           dir
814         - Fix Catalyst->go error in remote tests
815         - Fix upload test to work with remote servers, don't check for
816           deleted files
817         - Fix engine_request_uri tests to work on remote server with
818           different URI
819
820 5.8000_04  2008-12-05 12:15:00
821         - Silence Class::C3::Adopt::NEXT warnings in the test suite
822         - Fix loads of 'used once, possible typo' warnings
823         - Additional tests to ensure upload temp files are deleted
824         - Remove use of NEXT from the test suite, except for one case
825           which tests if Class::C3::Adopt::NEXT is working
826         - Use a predicate to avoid recursion in cases where the uri
827           method is overridden by a plugin, and calls the base method,
828           for example Catalyst::Plugin::SmartURI
829           - Test for this (caelum)
830         - Compose the MooseX::Emulate::Class::Accessor::Fast role to
831           Catalyst::Action, Catalyst::Request, and all other modules which
832           inherit from Class::Accessor::Fast in 5.70.
833           This fixes:
834             - Catalyst::Controller::HTML::FormFu (zamolxes)
835             - Catalyst::Request::REST
836           - Test for this
837         - Make hostname resolution lazy (Marc Mims)
838         - Support mocking virtualhosts in test suite (Jason Gottshall)
839         - Add README
840         - Fix TODO list
841         - Use Class::C3::Adopt::NEXT
842         - Ignore C3 warnings on 5.10 when testing ensure_class_loaded
843         - Add TODO test for chained bug (gbjk)
844         - Fix list address in documentation (zarquon)
845         - Fix ACCEPT_CONTEXT on MyApp, called as a class method
846            - Test for this
847         - Bump MooseX::Emulate::Class::Accessor::Fast version requirement to
848           get more back compatibility
849         - Improve documentation for $req->captures (caelum)
850         - Fix a bug in Catalyst::Stats, stopping garbage being inserted into
851           the stats if a user calls begin => but no end => (jhannah)
852            - Test for this (jhannah)
853         - Trim lines sooner in stats to avoid ugly Text::SimpleTable wrapping
854           (jhannah)
855         - Change Catalyst::ClassData to tweak the symbol table inline for
856           performance after profiling
857         - Fix POD typo in finalize_error (jhannah)
858         - Add tests to ensure that we delete the temp files created by
859           HTTP::Body's OctetStream parser
860
861 5.8000_03 2008-10-14 14:13:00
862         - Fix forwarding to Catalyst::Action objects.
863         - Fix links to the mailing lists (RT #39754 and Florian Ragwitz).
864         - Use Class::MOP instead of Class::Inspector.
865         - Change Catalyst::Test to use Sub::Exporter.
866         - Fixed typo in Engine::HTTP::Restarter::Watcher causing -r to complain.
867
868 5.8000_02 2008-10-14 07:59:00
869        - Fix manifest
870
871 5.8000_01 2008-10-13 22:52:00
872         - Port to Moose
873         - Added test for action stringify
874         - Added test for component instances getting $self->{value} from config.
875         - Add Catalyst::Response->print() method
876         - Optionally aggregate tests using Test::Aggregate.
877         - Additional docs for uri_for to mention how to use $c->action and
878           $c->req->captures (jhannah)
879         - List unattached chained actions in Debug mode.
880         - Pod formatting fix for Engine::FastCGI (Oleg Kostyuk).
881         - Add visit, a returning ->go
882
883 5.7XXXXXX XXXX
884         - Workaround change in LWP that broke a cookie test (RT #40037)
885         - Back out go() since that feature's been pushed to 5.80
886         - Fix some Win32 test failures
887         - Add pt translation of error message (wreis)
888         - Make :Chained('../action') work
889         - Add test actions
890         - Chained doc improvements (rev 8326-8328)
891
892 5.7099_03 2008-07-20 10:10:00
893         - Fix regressions for regexp fallback in model(), view() and controller()
894         - Added the supplied argument to the regexp fallback warning for easier
895           debugging
896         - Ensure ACCEPT_CONTEXT is called for results from component()
897
898 5.7099_02 2008-07-16 19:10:00
899         - Added PathPrefix attribute
900         - Removed Catalyst::Build; we've long since moved to Module::Install
901         - Updated Catalyst::Test docs to mention the use of HTTP::Request
902           objects
903
904 5.7099_01 2008-06-25 22:36:00
905         - Refactored component resolution (component(), models(), model(), et al). We now
906           throw warnings for two reasons:
907           1) model() or view() was called with no arguments, and two results are returned
908              -- set default_(model|view), current_(model|view) or current_(model|view)_instance
909              instead
910           2) you call a component resolution method with a string, and it resorts to a regexp
911              fallback wherein a result is returned -- if you really want to search, call the
912              method with a regex as the argument
913         - remove 0-length query string components so warnings aren't thrown (RT #36428)
914         - Update HTTP::Body dep so that the uploadtmp config value will work (RT #22540)
915         - Fix for LocalRegex when used in the Root controller
916         - Get some of the optional_* tests working from dirs with spaces (RT #26455)
917         - Fix Catalyst::Utils::home() when application .pm is in the current dir (RT #34437)
918         - Added the ability to remove parameters in req->uri_with() by passing in
919           an undef value (RT #34782)
920         - Added $c->go, to do an internal redispatch to another action, while retaining the
921           contents of the stash
922
923 5.7014  2008-05-25 15:26:00
924         - Addition of .conf in restart regex in Catalyst::Engine::HTTP::Restarter::Watcher
925         - Fix regression for relative uri_for arguments after a forward()
926           introduced in 5.7013 (Peter Karman)
927         - Fix regression for "sub foo : Path {}" in the root controller which
928           was introduced when attempting to allow "0" as a Path.
929
930 5.7013  2008-05-16 18:20:00
931         - Provide backwards compatability methods in Catalyst::Stats
932         - Fix subdirs for scripts that run in subdirs more than one level deep.
933         - Added test and updated docs for handling the Authorization header
934           under mod_fastcgi/mod_cgi.
935         - Fixed bug in HTTP engine where the connection was not closed properly if the
936           client disconnected before sending any headers. (Ton Voon)
937         - POD fix, IO::FileHandle => IO::Handle (RT #35690)
938         - Fix grammar on welcome page (RT #33236)
939         - Fix for Path('0') handling (RT #29334)
940         - Workaround for Win32 and c3_mro.t (RT #26452, tested by Kenichi Ishigaki)
941         - Fix for encoding query parameters
942         - Fix Chained multiple test
943
944 5.7012  2007-12-16 23:44:00
945         - Fix uri_for()'s and uri_with()'s handling of multibyte chars
946           (Daisuke Murase)
947         - Fix __PACKAGE__->config->{foo} = 'bar' case with subclassing
948         - Add Catalyst::Stats (Jon Schutz)
949         - Fixed a bug where ?q=bar=baz is decoded as q=>'bar', not 'bar=baz'.
950           (Tatsuhiko Miyagawa, Masahiro Nagano)
951         - Fixed a bug where -rr (restart regex) command line option could cause
952           shell errors. (Aristotle Pagaltzis, Chisel Wright)
953
954 5.7011  2007-10-18 20:40:00
955         - Allow multiple restart directories and added option to follow
956           symlinks in the HTTP::Restarter engine (Sebastian Willert)
957         - Fixed t/optional_http-server-restart.t so it actually tests
958           if the server restarted or notified of an error (Sebastian Willert)
959         - Return child PID from the HTTP engine when run with the 'background' option.
960           (Emanuele Zeppieri)
961         - Fixed bug in HTTP engine where writes could fail with
962           'Resource temporarily unavailable'.
963         - Fixed bug where %2b in query parameter is doubly decoded to ' ', instead of '+'
964           (RT #30087, Gavin Henry, Tatsuhiko Miyagawa, Oleg Pronin)
965         - Fixed bug where req->base and req->uri would include a port number when running
966           in SSL mode.
967         - Removed unnecessary sprintf in debug mode that caused warnings on locales where
968           commas are used for decimal markers.
969         - Improved error message for case when server picks up editor save
970           files as module names. (James Mastros)
971
972 5.7010  2007-08-22 07:41:00
973         - Resource forks in 5.7009
974
975 5.7009  2007-08-22 00:14:00
976         - Moved Manual.pod to Manual.pm and clarified status of
977           Catalyst-Manual dist
978         - Doc patches to Catalyst::Controller
979         - remove ignore_loaded from plugin load, commenting why
980         - document the ignore_loaded feature in Catalyst::Utils
981         - Add testing of inline plugins.
982
983 5.7008  2007-08-13 08:40:00
984         - Added $c->request->query_keywords for getting the keywords
985           (a query string with no parameters).
986         - Add undef warning for uri_for.
987         - Fix bug where a nested component would be setup twice.
988         - Make ensure_class_loaded behave better with malformed class name.
989         - Make _register_plugin use ensure_class_loaded.
990         - Remove 'Argument "??" isn't numeric in sprintf' warning.
991           (Emanuele Zeppieri)
992         - Fixed a bug where Content-Length could be set to 0 if a filehandle
993           object in $c->response->body did not report a size.
994         - Fixed issue where development server running in fork mode did not
995           properly exit after a write error.
996           (http://rt.cpan.org/Ticket/Display.html?id=27135)
997         - Remove warning for captures that are undef.
998         - Fixed $c->read and parse_on_demand mode.
999         - Fixed a bug with the HTTP engine where very large response bodies
1000           would not be sent properly.
1001
1002 5.7007  2007-03-13 14:18:00
1003         - Many performance improvements by not using URI.pm:
1004           * $c->uri_for (approx. 8x faster)
1005           * $c->engine->prepare_path (approx. 27x faster)
1006           * $c->engine->prepare_query_parameters (approx. 5x faster)
1007         - Updated HTTP::Body dependency to 0.9 which fixes the following issues:
1008           * Handle when IE sometimes sends an extra CRLF after the POST body.
1009           * Empty fields in multipart/form-data POSTs are no longer ignored.
1010           * Uploaded files with the name "0" are no longer ignored.
1011         - Sending SIGHUP to the dev server will now cause it to restart.
1012         - Allow "0" for a path in uri_for.
1013         - Performance and stability improvements to the built-in HTTP server.
1014         - Don't ignore file uploads if form contains a text field with the same name.
1015           (Carl Franks)
1016         - Support restart_delay of 0 (for use in the POE engine).
1017         - Skip body processing if we don't have a Content-Length header.
1018           Results in about a 9% performance increase when handling GET/HEAD
1019           requests.
1020         - Add a default body to redirect responses.
1021         - MyApp->model/view now looks at MyApp->config->{default_view/model}
1022           (Bogdan Lucaciu)
1023
1024 5.7006   2006-11-15 14.18
1025         - Updated manifest
1026         - Fix Slurp dependency
1027         - Updated HTTP::Body dependency to 0.6, 0.5 can break on large POST
1028           requests.
1029         - Skip utf8 fix for undef values in uri_with() and uri_for()
1030
1031 5.7005   2006-11-07 19:37:35
1032         - Fixed lighttpd tests to be properly skipped.
1033         - Moved IE workarounds to exist only in the HTTP engine.
1034         - Added installation instructions (from Catalyst-Manual dist)
1035
1036 5.7004   2006-11-06 20:48:35
1037         - Fix Engine::HTTP crash when using IE. (Jesper Krogh, Peter Edwards)
1038         - clean up Catalyst::Utils to handle some edge cases
1039         - Properly work around lighttpd PATH_INFO vs. SCRIPT_NAME bug
1040           (Mark Blythe)
1041         - add _application accessor to Catalyst::Base
1042         - Support current_view
1043         - Allow use of Catalyst::Test without app name (Ton Voon, Altinity)
1044         - Catalyst::Manual moved to its own package
1045         - Add option to FastCGI engine to send errors to stdout, not the web server
1046         - Use Module::Install's auto_install to install prerequisite modules
1047         - various documentation fixes and improvements
1048
1049 5.7003   2006-09-21 16:29:45
1050         - Additions and updates to tutorial
1051
1052 5.7002   2006-09-17 19:35:32
1053         - unescape captures to match args
1054         - fix for relative Chained under namespace '' (root)
1055         - fix for hashrefs in action attributes from config
1056         - fix for Chained to require correct number of CaptureArgs
1057
1058 5.7001   2006-07-19 23:46:54
1059         - fix for component loading
1060         - uri_for and uri_with now behave as they used to with non-
1061           array references
1062
1063 5.7000   2006-07-07 08:08:08
1064         - fix FCGI.pm warning message with FastCGI engine
1065         - bumped inc::Module::Install to 0.63 in Makefile.PL
1066         - fixes to uri_for_action for DispatchType::Chained
1067         - Further doc work.
1068         - Minor code cleanups
1069         - Changed catalyst.pl to depend on Catalyst::Devel
1070
1071 5.70_03  2006-06-28 16:42:00
1072         - fixup to registered plugins debug at app startup
1073         - refactored Catalyst::Utils::home
1074
1075 5.70_02  2006-06-27 11:51:00
1076         - Updated tutorial.
1077
1078 5.70_01  2006-06-26 10:49:00
1079
1080         - fixed a Catalyst::Base bug causing duplicate action registrations
1081         - modified DispatchTypes to support multiple registrations
1082         - added Catalyst::Runtime module as dist marker
1083         - added Catalyst::ActionChain and Chained DispatchType
1084         - removed retarded registration requirement in dispatcher
1085         - removed Module::Pluggable::Fast hack in favor of
1086           Module::Pluggable::Object
1087         - extended uri_for, added dispatcher->uri_for_action
1088         - added Catalyst::Base->action_for('methodname')
1089         - checked and tested :Args multimethod dispatch
1090         - added ability to set action attributes from controller config
1091         - added merge_config_hashes() as a convenience method
1092         - Swapped out CGI::Cookie in favour of CGI::Simple::Cookie
1093         - Removed test dependencies on Test::NoWarnings, Test::MockObject
1094         - Removed dependency on UNIVERSAL::require
1095         - Split out Catalyst::Helper into a new distribution
1096         - un-bundled the plugins as they are now pre-reqs for Catalyst::Helper
1097         - nuked each() out of core with prejudice (due to lurking buglets)
1098         - Added tests from phaylon for dispatcher precedence
1099         - Use Class::Inspector->loaded($class) instead of $class->can('can')
1100         - Added ActionClass attribute
1101         - Removed Test::WWW::Mechanize::Catalyst from Makefile.PL (circular dep)
1102         - Updated docs for Catalyst::Component
1103         - Separated execute and dispatch on Catalyst::Action
1104         - cleaned up logging and debug output
1105         - significant documentation revisions
1106         - Added warning for setup being called twice
1107         - Fix pod to use DBIC::Schema instead of DBIC model
1108         - Fix ->config failing to copy _config for subclassing
1109         - Updated log format
1110         - Updated debug dump
1111
1112 5.6902  2006-05-04 13:00:00
1113         - Remove tarballs and OSX metadata files.
1114
1115 5.6901  2006-05-03 11.17:00
1116         - Module::Install didn't overwrite META.yml.
1117
1118 5.6900  2006-05-03 11.17:00
1119         - Stupid pause indexer can't count.
1120         - Better fix for Catalyst::Test
1121         - more tests.
1122
1123 5.682   2006-04-27 13:51:00
1124         - Damn OSX attributes again :(
1125
1126 5.681   2006-04-27 08:47:00
1127         - Updated manifest.
1128         - Add basename to core . (Deprecates Catalyst::Plugin::Basename)
1129
1130 5.68    2006-04-26 12:23:00
1131         - ConfigLoader: Updated to version 0.06
1132         - fixed undef warnings in uri_for() and uri_with()
1133         - Fixed Catalyst::Test to report errors on failed Class load
1134
1135 5.678   2006-04-24 12:30:00
1136         - Re-release of 5.67 without OSX metadata files.
1137
1138 5.67    2006-04-23 08:50:00
1139         - Added $c->req->uri_with() helper
1140         - ConfigLoader: Updated to version 0.05
1141         - Fix up Engine to avoid a new 5.8.8 warning
1142         - Added app name with :: support for PAR
1143         - Added $c->models/views/controllers
1144         - Static::Simple: Unescape the URI path before looking for the file.
1145           This fixes issues with files that have spaces.
1146         - Looping and recursion tests plus a fix
1147         - Added lots of API documentation. Refactored main pod.
1148         - Changed default behaviors for $c->model/$c->controller/$c->view
1149           to more sane settings.
1150         - added the clear_errors method - an alias for error(0)
1151         - Added tmpdir option for uploads (woremacx)
1152         - Applied patch from GEOFFR to allow normal filehandles.
1153         - Refactored Dispatcher internals for better readability and speedup
1154           (stress tests run 12% faster)
1155         - Allow $c->error to run as a class method
1156
1157 5.66    2006-03-10 17:48:00
1158         - Added Test::WWW::Mechanize::Catalyst support
1159         - Cleaned generated tests
1160         - Added Root controller concept
1161         - Updated ConfigLoader plugin to version 0.04
1162
1163 5.65    2006-02-21 10:34:00
1164         - Added plugin introspection.
1165         - Support optional hashref as last param for parameters in uri_for.
1166         - Updated tutorial to be more complete.
1167         - Applied args patch from antirice (Fixes Ticket #67)
1168
1169 5.64    2006-02-07 20:29:00
1170         - Fixed bug in FastCGI proc manager mode where pm_post_dispatch
1171           was not run. (Eric Wong)
1172         - Cleaned up generated tests
1173         - Updated YAML support to use ConfigLoader
1174         - Fixed path dispatch to canonicalise correctly
1175             (see http://dev.catalyst.perl.org/ticket/62)
1176         - Added Catalyst::Manual::About
1177
1178 5.63    2006-01-22 00:00:00
1179         - Updated prereq versions
1180
1181 5.62    2006-01-17 16:30:00
1182         - Large update to the tutorial (castaway)
1183         - Added YAML config support
1184         - Added COMPONENT() and ACCEPT_CONTEXT() support
1185         - Action list in debug mode is now displayed as a tree in the
1186           correct execution order.
1187         - Fixed engine detection to allow custom mod_perl engines.
1188         - Static::Simple: Fixed bug in ignore_dirs under win32.
1189         - Display version numbers of loaded plugins. (Curtis Poe)
1190         - Added class and method for caught exception messages.
1191         - Updated PAR support to use "make catalyst_par",
1192           packages are no longer written by Makefile.PL.
1193         - Automatically determine Content-Length when serving a
1194           filehandle.
1195         - Exceptions now return status 500.
1196         - Updated for Module::Install 0.44.
1197         - Fixed additional file installation for multi level app names.
1198         - Added REDIRECT_URL support for applications running behind
1199           a RewriteRule in Apache. (Carl Franks)
1200         - Fixed FastCGI engine under win32. (Carl Franks)
1201         - FastCGI doc updates (Bill Moseley)
1202         - Bugfix for $c->model and friends (defined).
1203
1204 5.61    2005-12-02 00:00:00
1205         - Fixed ExtUtils::AutoInstall Bootstrap Code in Makefile.PL
1206
1207 5.60    2005-12-01 22:15:00
1208         - Fixed Path and index actions in the appclass,
1209           including those that attach to /
1210         - Index is now weighted higher than Path
1211         - Fixed restarter and -d debug switch in server.pl.
1212         - Added a warning if you attempt to retrieve a parameter
1213           using $c->req->params('foo').
1214         - Fixed the Module::Install::Catalyst @ISA bug
1215
1216 5.59    2005-11-30 13:25:00
1217         - Fixed shebang line for generated scripts
1218         - Fixed forward to classes ($c->forward(qw/MyApp foo/))
1219         - Wrap use block in begin to quelch C:C3 warnings
1220         - Removed scrollbar from debug output
1221         - Fixed catalyst_par_core() and catalyst_par_multiarch()
1222
1223 5.58    2005-11-24 10:51:00
1224         - Added ExtUtils::AutoInstall support
1225         - Allow overriding path in Catalyst::Helper.
1226         - Added -makefile to catalyst.pl to generate a new Makefile.PL.
1227         - Restored Catalyst::Build with a deprecation notice.
1228         - Improved PAR support
1229         - Replaced -short with auto-detection
1230         - Fixed prereqs, added File::Copy::Recursive
1231         - Static::Simple changes:
1232             - Made prepare_action play nice with other plugins by not short-
1233               circuiting.
1234             - Added tmpl to the ignored extensions.
1235             - Fixed security problem if req->path contained '..'.
1236
1237 5.57    2005-11-20 22:45:00
1238         - Updated uri_for to accept undef actions
1239         - Switched to Module::Install
1240         - Renamed tests for easier editing
1241         - Reformatted documentation
1242         - Renamed -nonew to -force
1243         - Added PAR support
1244         - Added keep-alive support and bug fixes to HTTP engine.
1245           (Sascha Kiefer)
1246         - Added daemonize option to FastCGI engine. (Sam Vilain)
1247
1248 5.56   2005-11-16 10:33:00
1249         - Fixed FastCGI engine to not clobber the global %ENV on each
1250           request. (Sam Vilain)
1251         - Updated benchmarking to work with detach
1252         - Fixed dispatcher, so $c->req->action(undef) works again
1253         - Updated Catalyst::Test to use HTTP::Request::AsCGI
1254         - Added -pidfile to external FastCGI server.
1255
1256 5.55    2005-11-15 12:55:00
1257         - Fixed multiple cookie handling
1258
1259 5.54    2005-11-14 22:55:00
1260         - Fixed a Module::Pluggable::Fast related bug
1261
1262 5.53    2005-11-14 15:55:00
1263         - Removed t/04prereq.t that was testing for non-required
1264           modules.
1265
1266 5.52    2005-11-14 10:57:00
1267         - Strip '..'s in static urls to fix security issue.
1268
1269 5.51    2005-11-14 00:45:00
1270         - Changed uri_for to use namespace instead of match.
1271
1272 5.50    2005-11-13 20:45:00
1273         - Fixed minor bugs.
1274         - Updated docs.
1275
1276 5.49_05 2005-11-12 20:45:00
1277         - Large update to the documentation. (David Kamholz)
1278         - Fixed args handling in forward()
1279         - Fixed forwarding to classes
1280         - Fixed catalyst.pl-generated Build.PL Makefile section.
1281         - Fixed relative forwarding
1282         - Fixed forward arrows in debug output
1283
1284 5.49_04 2005-11-09 23:00:00
1285         - Made context, dispatcher, engine, request and response classes
1286           configurable.
1287         - Added $c->stack.
1288         - Fixed dispatcher to ignore unknown attributes.
1289         - Improved format of startup debug log.
1290         - Updated built in server to restart on win32. (Will Hawes)
1291         - Fixed streaming write from a filehandle to stop writing
1292           if the browser is closed.
1293         - Added $c->controller, $c->model and $c->view shortcuts.
1294         - Switched to Text::SimpleTable.
1295
1296 5.49_03 2005-11-03 12:00:00
1297         - Fixed $c->req->{path} for backwards-compatibility.
1298         - Allow debug to be disabled via ENV as well as enabled.
1299         - Added -scripts option to catalyst.pl for script updating
1300         - Changed helpers to default to long types, Controller instead of C
1301         - Added Catalyst::Controller, Catalyst::Model and Catalyst::View
1302           base classes
1303         - Added JavaScript to debug screen to show and hide specific dumps
1304         - Added _DISPATCH, _BEGIN, _AUTO, _ACTION and _END actions
1305         - Added multi process external FastCGI support
1306           (see myapp_fastcgi.pl -help) (Sam Vilain)
1307         - Restarter process in HTTP engine now properly exits when the
1308           parent app is shut down.
1309         - Improved performance of restarter loop while watching for
1310           changed files.
1311         - Restarter will now detect new files added to an app on systems
1312           that change directory mtimes when new files are created.
1313         - Restarter now properly handles modules that are deleted from an
1314           application.
1315         - Fixed memory leak in TestApp.
1316
1317 5.49_02 2005-10-26 12:39:00
1318         - Whole new dispatcher!
1319         - Added index action
1320         - Added path_to method
1321         - Added support for passing an IO::Handle object to $c->res->body.
1322           (Andrew Bramble)
1323         - Added a new welcome screen.
1324         - Included Catalyst buttons and icons in helper.
1325         - Added Static::Simple plugin to core.
1326         - Added self restarting test server
1327         - Added filename to debug output for uploaded files.
1328         - Fixed forwarding with embedded arguments.
1329         - Fixed handling of escaped query strings.
1330         - Added upload parameters back into $c->req->params.
1331         - Added multiple paths support to dispatcher
1332         - Fixed bug in req->path where changing the path added a trailing
1333           slash.
1334         - Removed req->handle and res->handle
1335         - Added prepare_body_chunk method as a hook for upload progress.
1336         - Fixed bug in uri_for method when base has no path.
1337         - Added automated tests for HTTP, CGI, and FastCGI servers.
1338
1339 5.49_01 2005-10-10 10:15:00
1340         - Refactored all internals, should be 99% compatible to previous
1341           versions.
1342         - *IMPORTANT* The Apache engines have been moved to a separate package
1343           for this release.  Please install Catalyst::Engine::Apache if you
1344           need Apache support.
1345
1346         - Added support for calling forward with arguments in the path, i.e.
1347           $c->forward('/foo/bar/arg1/arg2')
1348         - Made $c->req->uri a URI object, added req->path_info for CGI compat.
1349           Raw query string is available as $c->req->uri->query.
1350         - Made $c->req->base a URI object.
1351         - Parameters with multiple values (?a=1&a=2) now display properly
1352           in the debug output.
1353         - Semi-colon separators in query strings now work properly.
1354         - Expanded documentation of catalyst.pl (Andrew Ford)
1355         - Added support for running as a backend server behind a frontend
1356           proxy so req->base and req->address are set properly.
1357         - Added an 'abort' method to the Log api, so that you can
1358           kill loggging for a whole request.
1359         - Added $c->uri_for method to simplify url handling.
1360         - Added more tests and reorganized the t directory.
1361         - Reimplemented core engines, all are now CGI based for better test
1362           coverage and maintainability.
1363         - Added fork support to built in test server.
1364         - Fixed all memory leaks.
1365         - Thread-related bug fixes and tests.  We now believe the Catalyst
1366           core to be thread-safe.
1367         - Added streaming IO support through $c->req->read() and
1368           $c->res->write()
1369         - Added MyApp->config->{parse_on_demand} (streaming input)
1370         - Added $c->req->handle and $c->res->handle
1371         - Improved documentation
1372         - Fixed mkpath in Catalyst::Helper (Autrijus Tang)
1373         - Fixed bug in dispatcher where an invalid path could call a valid
1374           action. (Andy Grundman)
1375         - Fixed Helper so it works with CRLF line-endings. (Andy Grundman)
1376
1377 5.33  2005-08-10 15:25:00
1378         - Now with updated manifest.
1379
1380 5.32  2005-08-10 15:10:00
1381         - Dispatcher might fail if object returns false.
1382
1383 5.31  2005-06-04 12:35:00 (never released to CPAN)
1384
1385         - helpers now create .new files where files already exist and differ
1386         - fixed $Data::Dumper::Terse (Robin Berjon)
1387         - added arguments for detach
1388         - new credits section in POD
1389         - fixed detach to allow relative action names (Matt and Robert)
1390         - added the ability to have whitespaces in Path( '' ) and Regex( '' )
1391
1392 5.30  2005-06-04 12:35:00
1393
1394         - Fixed a bug where it was not possible to $c->forward to a
1395           component
1396           that was not inheriting from Catalyst::Base.
1397         - Fix for inheritance bug.
1398         - Allow forward with arguments.
1399         - Updated cookbook
1400         - Allow overriding home/root in config.
1401         - make module build cons README automatically.
1402         - prettify home path by resolving '..' (Andy Grundman)
1403         - improved helper templates a bit, new naming scheme for tests.
1404         - added support for case sensitivity, MyApp->config->{case_sensitive}
1405         - added $c->detach for non-returning forwards
1406         - added unified error handling, Catalyst::Exception
1407         - added section on param handling in Intro.pod
1408         - added $c->request->cookie
1409         - added Catalyst::Setup
1410         - refactored Catalyst::import()
1411         - improved rendering of error messages in debug mode
1412         - fixed a bug in Catalyst::Helper::mk_dir
1413         - further doc changes, esp. to Intro.pod
1414
1415 5.23  2005-06-03 02:30:00
1416         - added support for non Catalyst::Base components to live in namespace
1417         - improved concurrency connections in Catalyst::Engine::HTTP::Daemon
1418
1419 5.22  2005-05-26 14:24:00
1420         - improved base locating in MP engines
1421         - improved error messages in C::E::HTTP::Daemon
1422         - hostnames are now resolved on demand unless provided by engine
1423         - fixed memory leak in $c->execute (Michael Reece, Matt S Trout)
1424
1425 5.21  2005-05-24 14:56:00
1426         - fixed a bug in https detection
1427         - fixed auto chain finally
1428         - added MYAPP_HOME and CATALYST_HOME environment variables
1429
1430 5.20  2005-05-18 19:52:00
1431         - improved uploads and parameters
1432         - added $c->req->protocol and $c->req->secure
1433         - added $c->req->user and $c->req->uri
1434         - improved error message when forwarding to unknown module
1435         - fixed win32 installer
1436         - added deep recursion detection
1437         - fixed auto actions
1438         - fixed inheritance in dispatcher
1439         - allow whitespaces between brackets and quoted string
1440           in Path and Regex attributes
1441         - new helper templates
1442         - installer now supports install_base and destdir
1443         - allow multiple Catalyst apps to run on the same mod_perl
1444           instance (not the same app!)
1445         - fixed MP2 engines
1446         - removed apreq dependency from all MP engines
1447         - added support for MP registry scripts
1448         - added support for LocationMatch and ScriptAliasMatch in MP engines
1449         - added SpeedyCGI engine
1450
1451 5.10  2005-04-23 11:16:00
1452         - updated dependencies to require latest module::pluggable::fast
1453         - new installer for templates and stuff using Module::Build
1454         - scripts are now prefixed, for being installable
1455         IMPORTANT: You have to regenerate the script directory,
1456         remove Makefile.PL and add Build.PL
1457         - Added compat to install Module::Build if required.
1458         - Improved: Params handling with MP engines
1459         - Fixed: Params handling on POST with CGI engine (Andy Grundman)
1460         - Fixed: Helper.pm on Win32 (Matt S Trout)
1461
1462 5.03  2005-04-19 20:35:00 (Revision 462)
1463         - fixed Test example (Torsten Seeman)
1464         - added Plugins chapter to manual
1465         - applied doc patch from Robert Boone <robert@rlb3.com>
1466         - improved Dispatcher error messages.
1467         - refactored so we don't need to include helper from
1468           Catalyst.pm - Fixes issues with FindBin
1469         - applied HTTP.pm patch from Andy Grundman <andy@hybridized.org>
1470         - added plugin() method for instant plugins
1471         - FCGI is no more considered experimental
1472
1473 5.02  2005-04-18 10:00:00
1474         - fixed manifest
1475
1476 5.01  2005-04-17 23:00:00
1477         - some documentation bugs fixed
1478         - added Catalyst::Utils
1479         - fixed regexp bug (Matt S Trout)
1480         - fixed upload bug with MP19
1481         - added $c->req->body
1482         - aliased $c->res->output to $c->res->body
1483         - Read AUTHOR from passwd or $ENV{AUTHOR} when
1484           generating code.
1485         - extended attribute handling
1486         - added global config for components
1487
1488 5.00  2005-04-15 18:00:00
1489         - new core to support inheritance trees
1490         - new syntax for action declaration
1491         - new helper system using TT2
1492         - problems with mod_perl2 fixed
1493         - added Test::Pod support
1494         - added new server backend with HTTP/1.1 support
1495         - added option to run tests against a remote server
1496         - renamed errors() to error()
1497         - more better docs
1498         - countless minor improvements
1499           IMPORTANT: This release is very incompatible to previous ones
1500           and you have to regenerate the helper scripts again...
1501
1502 4.34  2005-03-23 07:00:00 2005
1503         - added some messages to Makefile.PL
1504         - added Catalyst::Engine::Test
1505         - added Catalyst::Engine::CGI::NPH
1506         - simplified Catalyst::Log to be easier to implement/subclass
1507         - added cgi.pl
1508         - updated Catalyst::Test to use Catalyst::Engine::Test
1509         - updated helper scripts
1510           IMPORTANT: this will be the last time you'll have to regenerate
1511           the script directory. We promise!
1512
1513 4.33  2005-03-23 01:00:00 2005
1514         - documented the log() accessor method in Catalyst (Andrew Ford)
1515         - added optional arguments to Catalyst::Log methods (Andrew Ford)
1516         - removed cgi-server.pl
1517         - added fcgi.pl and Catalyst::Engine::FCGI
1518         - fixed an undef durng make test (Dan Sully)
1519         - new path test (Christian Hansen)
1520           IMPORTANT: you have to regenerate the script directory again
1521
1522 4.32  2005-03-22 02:10:00 2005
1523         - made a damn typo *AAAAAAAAAAAAAAHHHH!!!*
1524
1525 4.31  2005-03-22 02:00:00
1526         - fixed inheritance (Christian Hansen)
1527         - previous release was borked!
1528           fixed that, but you have to regenerate the scripts again :(
1529
1530 4.30  2005-03-21 23:00:00
1531         - more documentation (Andrew Ford)
1532         - added connection informations (Christian Hansen)
1533         - HTTP::Request support in Catalyst::Test (Christian Hansen)
1534         - moved cgi.pl to nph-cgi.pl
1535         - added Catalyst::Engine::Server (Christian Hansen)
1536         - removed Catalyst::Test::server
1537         - updated helper scripts
1538           IMPORTANT: note that you have to regenerate script/server.pl,
1539           script/cgi-server.pl and script/cgi.pl (now nph-cgi.pl)
1540
1541 4.28  2005-03-19 22:00:00
1542         - fixed isa tree (Christian Hansen)
1543         - added script/cgi-server.pl, so no more server restarting after
1544           code changes
1545         - reworked documentation (Andrew Ford <A.Ford@ford-mason.co.uk>)
1546
1547 4.27  2005-03-19 01:00:00
1548         - debug message for parameters
1549         - Fix redirects (Christian Hansen <ch@ngmedia.com>)
1550         - some random fixes
1551         - new helper api for Catalyst::Helper::* support
1552           you have to update script/create.pl to use it
1553
1554 4.26  2005-03-16 10:00:00
1555         - fixed the weird bug that caused regex actions to fail on every
1556           second request
1557         - more debug messages
1558         - 100% pod coverage.
1559
1560 4.25  2005-03-12 18:00:00
1561         - correct perl pathes for helper generated scripts (Tatsuhiko Miyagawa)
1562         - improved cgi engine docs (Christoper Hicks)
1563
1564 4.24  2005-03-12 01:00:00
1565         - updated cookbook example
1566         - fixed base for apache and https (Andrew Ruthven)
1567
1568 4.23  2005-03-09 20:00:00
1569         - no more regex actions in forward
1570         - added support for test directories t/m, t/v and t/c
1571
1572 4.22  2005-03-08 20:00:00
1573         - catch errors in application class
1574         - handle die properly.
1575
1576 4.21  2005-03-05 17:00:00
1577         - fixed docs
1578
1579 4.20  2005-03-04 22:00:00
1580         - moved bin to script
1581
1582 4.13  2005-03-03 11:00:00
1583         - improved documentation
1584         - pod coverage test for helper generated apps
1585         - new helper api
1586
1587 4.12  2005-03-02 11:00:00 2005
1588         - server_base sucks, removed
1589         - added $c->log->dump()
1590
1591 4.11  2005-03-02 11:00:00 2005
1592         - removed some warnings
1593         - improved docs
1594         - private prefixed actions override private non prefixed actions
1595         - added server_base
1596         - updated Catalyst::Manual::Intro
1597
1598 4.10  2005-03-02 10:00:00 2005
1599         - improved documentation
1600         - fixed upload bug
1601         - fixed prefixed private actions bug
1602         - fixed more little bugs
1603
1604 4.01  2005-03-01 10:00:00 2005
1605         - improved documentation
1606         - documentation fixes (Johan Lindstrom)
1607
1608 4.00  2005-02-27 22:00:00
1609         - more verbose debug messages, especially for forward()
1610         - implemented prefixed prvate actions, icluding built in
1611           !?default, !?begin and !?end
1612         - new Catalyst::Manual::Intro
1613         - new helpers, bin/catalyst
1614         - helper api
1615
1616 3.11  2005-02-23 21:00:00
1617         - added dependency to UNIVERSAL::require (Marcus Ramberg)
1618         - added a little workaround for a warning in Catalyst::Test
1619           (Marcus Ramberg)
1620         - improved documentation for actions
1621
1622 3.10  2005-02-19 20:00:00
1623         - removed roles management from Catalyst::Engine
1624           and added it to Catalyst::Plugin::Authentication::CDBI
1625
1626 3.04  2005-02-17 21:00:00
1627         - error reporting for app class
1628         - no more engine debug messages
1629         - class->method forwards get resolved now
1630
1631 3.03  2005-02-16 23:00:00
1632         - friendlier statistics
1633
1634 3.02  2005-02-16 22:00:00
1635         - fixed unintialized actions (Marcus Ramberg)
1636
1637 3.01  2005-02-16 20:30:00
1638         - better statistics
1639
1640 3.00  2005-02-16 20:00:00
1641         - real version number for CPAN.pm
1642         - fixed redirect in CGI engine
1643         - more statistics in debug logs
1644         - ? prefix for forward()
1645
1646 2.99_15  2005-02-02 22:00:00
1647         - support for short namespaces, MyApp::M, MyApp::V and MyApp::C
1648         - Replaced "Catched" with "Caught" in Catalyst::Engine
1649           (Gary Ashton Jones)
1650         - replaced _ with ! for private actions
1651         - added ? for prefixed actions
1652         - misc improvememts
1653
1654 2.99_14  2005-01-31 22:00:00 2005
1655         - arguments for _default
1656         - $c->entrance removed for more flexibility
1657         - added $c->req->method
1658
1659 2.99_13  2005-01-30 18:00:00 2005
1660         - POD fixes and improvements
1661
1662 2.99_12  2005-01-28 22:00:00 2005
1663         - first development release