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