Fixing MR-340, if ?Errors doesn't work correctly.
[castle.git] / MonoRail / Changes.txt
blob962e1f486cc46bc31dc7717328529d9da946c87f
1 Change history\r
2 --------------\r
3 \r
4 Release Candidate 3\r
5 ===================\r
6 \r
7 - Added IDisposable/Dispose back to the controller\r
8 \r
9 - Applied Lee Henson's patch adding generic overloads to ReflectionHelper\r
11 - Added a few more RenderView overloads that take a mimeType to configure the Response.ContentType\r
13 - If the controller cannot be found, MR searches for a special rescue "rescues/404" before throwing throwing an exception.\r
15 - If an action could not be found, we go through normal path an use a general rescue if it can be found for the controller. \r
17 - UrlHelper change: Now if the param encode wasn't set, UrlHelper assumes it's true.\r
19 - Applied patch by Oleg Snurnikov fixing MR-319\r
20   "MockResponse - basic implementation of Redirect, Write, BinaryWrite and Clear overloads"\r
22 - Applied patch by Chirs Ortman fixing MR-296\r
23   "Dont get validation summary when binding with AR attribute but controller inherits smart dispatcher controller"\r
25 - Applied patch by Rafael Teixeira fixing MR-298\r
26   "ColumnRenderer with an empty enumeration still renders table start and end sections"\r
28 - Fixed MR-300\r
29   "DataBindAttribute in a ARSmartDispatcherController inherit the behavior from ARDataBinder"\r
31 - Applied minor patch by James Su fixing MR-303\r
32   "Behavior is not consistent between FormToAttributed and LinkToAttributed in HtmlHelper"\r
34 - Applied goodwill's patch adding cookie support to BaseControllerTest MR-304\r
36 - Applied goodwill's patch fixing MR-305\r
37   "fValidate fix a bug on unassociated label for element"\r
39 - Applied Oleg Snurnikov's patch fixing MR-306\r
40   "PrototypeWebValidator - regular expression validation"\r
42 - Fixed MR-311 \r
43   "The '\' character in templates goes unescaped when processed via NJS"\r
45 - The DefaultUrlBuilder now accepts a basePath parameter, which basically overrides the path information.\r
47 - Fixed MR-317\r
48   "ARDataBind handles BelongsTo attribute in Nested component incorrectly."\r
50 - FlashBinderAttribute was removed as I doesnt work with the new \r
51   MonoRail design (changed to make the cache support work)\r
53 - Applied Tim Haines' patch adding TextAreaValue to FormHelper \r
55 - Fixed MR-281 \r
56   "View components params problem"\r
58 - Applied Markus Zywitza's patch adding a Fold method to TextHelper. \r
59   His description "Shortens a text to the specified length (using full words only and\r
60 adding an ellipsis at the end) and wraps it into a span-element that\r
61 has the title-property with the full text associated. This is\r
62 convenient for displaying properties in tables that might have very\r
63 much content (desription fields etc.) without destroying the table's\r
64 layout. Due to the title-property of the surrounding span-element, the\r
65 full text is displayed in the browser while hovering over the\r
66 shortened text."\r
68 - Applied Aaron Jensen's patch fixing MR-288\r
69   "ApplicationPhysicalPath returns request path instead of / path"\r
71 - Fixed MR-284\r
72   "MockServerUtility.MapPath throws NotImplementedException"\r
74 - Applied Bill Pierce's patch fixing MR-278\r
75   "Add UrlDecode to IServerUtility"\r
77 - Applied Bryan Brown's patch fixing MR-273. This one adds a new attribute to \r
78   the routing configuration node: 'excludeAppPath'\r
79   "Automatically handle ApplicationPath in the routing module"\r
81 - Applied goodwill's patch fixing MR-275\r
82   "DefaultRailsEngineContext triggers RTE on ApplicationPhysicalPath \r
83    when running under ASPX Dev Server with virtual directory"\r
85 - Changed the BaseControllerTest vdir to "" instead "/"\r
87 - Added the Declare(String variable) to IJSGenerator inteface\r
89 - Applied Tim Haines' patch changing FormHelper to make calls to FormatIfNecessary \r
91 - Applied chris ortman's patch fixing MR-271\r
92   "AdditionalSources not loaded when using the viewEngines element"\r
94 - Applied Ricardo Stuven's patch fixing MR-258\r
95   "JSON serialization in Ajax calls"\r
97 - Applied goodwill's patch fixing MR-212\r
98   "Script Helpers (e.g. $Scriptaculous) installscript function clear flash unexpected"\r
100 - Applied Georges Benatti's patch \r
101   adding the attribute matchHostNameAndPath to the routing node on the configuration. \r
102   \r
103   If set to 'true', the regular expression is matched against the whole url. Defaults to 'false'\r
105 - Added ability to customise Next/Prev links in DiggStylePagination.\r
106    Patch from Markus Zywitza.\r
108 - Applied Mathias Doenitz's patch fixing MR-265\r
109   "(Re)enable initialization of Controller.AreaName, Controller.Name and Controller.Action before invoking Controller.Initialize()."\r
111 - Applied Adam Tybor's patch fixing MR-266\r
112   "Fix for GetErrorSummary() throwing an KeyNotFoundException for SmartDispatch Controller and Binder"\r
114 - Fixed MR-260\r
115   "PropertyBag in WizardStep is null when access via key"\r
117 - Applied Kyle Marshall's patch fixing MR-261\r
118   "The default ValidatorRegistry is not overriddable in the monorail configuration"\r
120 - Add support to BaseControllerTest (well MockRequest actually) for Mocking Url Referer. Patch from Colin Ramsay. \r
122 - Fix SupportsSection implementation in ViewComponent (was comparing section name equality against StringComparer.InvariantCultureIgnoreCase). \r
123   Also add a SupportsSection implementation to DiggStylePagination. Patches from Tim Haines. \r
125 - Small change to DiggStylePagination to allow supplying querystring parameters in the url. Suggested by kalle.stenflo@gmail.com.\r
127 - Applied Tim Haines' patch adding BindObject overloads that accept the AutoLoadBehavior enum, \r
128   to the ARSmartDispatcherController \r
130 - Changes from Lee Henson to add WizardStep support to TestSupport and provide a Generic BaseControllerTest. \r
132 - Patch from Maruis Marais allowing BuildFormRemoteTag to gracefully degrade when JavaScript is disabled. \r
134 - Patch from Lee Henson fixing regression introduced in 3783 in Prototype Validator. (Could not use hyphens in element id's). \r
136 - Fixed MR-241 \r
137   "When Windsor integration is enabled, the ControllerTree is empty"\r
139 - Apply patches from Tim Haynes. \r
140   "add a renderIfOnlyOnePage property to the DiggStylePagination View Component"\r
141   "Add NewRootInstanceIfInvalidKey AutoloadBehaviour to Castle.MonoRail.ActiveRecordSupport"\r
143 - Applied Goodwill's patch adding PersisteFlashFilter and the fValidate's localization support. Fixed MR-246.\r
145 - Fixed the use of Scaffolding without Layouts (MR-251).\r
147 - Added support for eager fetching of lazy collections, in [ARFetch] attribute.\r
149 - Added support for auto load bevahior configuration when invokling the BindObject in the   ARSmartDispatcherController\r
151 - Added support for different access and naming strategies in the ARDatabind attribute.\r
153 - Applied Matt Berther's patch adding LoggingExceptionHandler and FilteredExceptionHandler.\r
155 - Applied chris ortman's patch fixing MR-242\r
156   "FormHelper.LabelFor does not generate valid HTML when attributes are supplied"\r
158 - Applied bonskijr's patch fixing MR-234\r
159   "Under some circunstances ColumnRenderer generates invalid html"\r
161 - Applied Marc-André's patch fixing MR-238\r
162   "HtmlHelper.LinkTo: bugs- don't function when existing a area"\r
164 - Applied Aaron Jensen's patch fixing the Resource Manager usage \r
165   Changed from ResourceSet to ResourceManager\r
167 - Applied Lee Henson's patch adding the 'onCreateAdvice'\r
168   to PrototypeWebValidator\r
170 - Applied Chris Ortman's patch fixing MR-235\r
171   "Allow overriding of select generation in FormHelper"\r
173 - Added Item(string id) overload to Checkboxlist\r
174   Used to generate a checkbox with the specified id. Useful to label for='id' constructions\r
176 - Added the Expect property to the ARDataBindAttr. Now it will clear the collections \r
177   that are declared as expected, if not can be found on the resquest params. (MR-163)\r
179 - Applied Colin Ramsay's patch fixing MR-232\r
180   "HtmlHelper.InputButton should create <button> not <input type="button">"\r
182 - Fixed MR-228\r
183   "incorrect component configuration results in an 'The container seems to be unavailable \r
184    in your HttpApplication subclass' exception"\r
186 - Applied Bart Reyserhove's patch fixing MR-226 \r
187   "ARDataBinder has problems when using generic collections"\r
189 - Applied Jacob Lewallen's patch adding a new attribute (ViewComponentAttribute) used\r
190   to name view components. The behavior is changed to strip the 'Component' suffix from the class name as well.\r
192 - Applied Ernst Naezer's patch fixing MR-191\r
193   "Add TransformFilter support to MR"\r
195 - Applied Lee Henson's patch fixing MR-222\r
196   "Use of IRailsEngineContext.Items"\r
198 - Fixed MR-224\r
199   "ARDataBindAttribute does not set the Controllers validator on it's DataBinder"\r
201 - Fixed MR-219\r
202   "FormHelper.Select with an interface datasource throws an Object mismatch exception."\r
204 - Applied chris ortman's patch fixing MR-188\r
205   "Allow the #component directive to support variables for the component name"\r
207 - Fixed MR-208\r
208   "Using a lazy loaded nested object, "Ambiguous match found" exception occures when \r
209    trying to use FormHelper to render control for the nested objects property."\r
211 - Applied goodwill's patch fixing MR-213\r
212   "DiggStylePagination has a typo which prevents the code from build"\r
214 - Applied Edward Kreis' patch fixing MR-214\r
215   "ARDataBinding and joined subclasses with derived BelongsTo, HasMany, HasAndBelongsToMany proeprties"\r
217 - Fixed MR-217 \r
218   "fValidate box message contains <BR/> if being triggered twice"\r
220 - Fixed MR-221\r
221   "HtmlHelper.LinkToAttributed bug"\r
223 - Applied Jacob Lewallen's patch adding an optional attribute to define a view component's name\r
224   The patch also introduces a IViewComponentTree.\r
226 - Added 'noaction' parameter to FormHelper.FormTag to prevent action attribute generation\r
228 - Added Select list from Enum.\r
230         in controller:\r
231                 PropertyBag.Add("colors",Enum.GetValues(typeof(ColorEnum)));\r
233         in view:\r
234                 $Form.Select("Color", $colors)\r
236 - Applied Chris Ortman's patch adding MooHelper/JS generation based on it.\r
238 - Applied Jacob Lewallen's patch adding virtuals to some FormHelper methods\r
240 - Applied Patrick McEvoy's patch with a new approach to delete cookies\r
242 - Added \r
244         SmartDispatcherController.ValidationSummaryPerInstance : IDictionary\r
245         SmartDispatcherController.GetErrorSummary(object instance) : ErrorSummary\r
246         SmartDispatcherController.HasValidationError(object instance) : bool\r
247         \r
248   Those can be used if DataBinder is configured to validate\r
250 - Added Controller.RedirectToReferer\r
252 - Configuration changed, added defaultUrls section (see monorail_configuration_ref.txt)\r
254 - Added Controller.RenderMailMessage(string templateName, bool doNotApplyLayout) overload\r
256 - Added static accessor support to NVelocity view engine. Default helpers are \r
257   the Common System Types in dotnet (i.e. Double, String, Decimal, etc.)\r
258   \r
259     In your template: $String.Concat("foo","bar","me","please:",$Double.Epsilon)\r
260     (dotnet 2 only.)\r
262 - Added better ControllerBinder support for indexed property expressions.\r
263    This allows you to pass DataKeys as your action arguments\r
265 - Applied Freyr Magnússon's patch fixing MR-206 \r
266   "ARBadaBinder does not resolve primary key for discriminator subclass from parent"\r
268 - Retrieve target properties on demand for ControllerBinders ActionArgument editor\r
270 - Added ControllerBinder Extender Control for WebForm views to eliminate the\r
271    need to add event handlers in the codebehind that call Controller.Send\r
273 - Brail now has Ruby's like symbols, using @symbol.\r
274     For instance, component DiggStylePagination, ${ @useInlineStyle : true }\r
275         \r
276 - Brail can now accept " inside a ${ }, which used to break the parser previously.\r
278 - Added IViewComponentContext.RenderView(name, textwriter)\r
280 - Fixed MR-201\r
281   "DiggStylePagination.Initialize() doesn't check useInlineStyle parameter"\r
283 - Added FormHelper.HiddenField("key", value) overload\r
285 - Added 'valueformat' to SetOperations (affects FormHelper.Select, Checkboxlist)\r
287 - Fixed MR-197\r
288   "Exception thrown by AccessibleThrough are not caught by rescues"\r
290 - Added 'textformat' support to the all FormHelper operations (that create input elements).\r
292 - Added BrailJS Support, allowing to generate javascript via brail scripts.\r
293  Note; BrailJS scripts do not need <?brail ?> and any output statements there will be ignored.\r
294   They are used strictly to create the generator.\r
296 - Changed Brail extention from Boo to Brail / BrailJS\r
298 - Added mask support to FormHelper field elements\r
300 - Added FormHelper.PasswordNumberField\r
302 - Refactored FormHelper to support other approaches to extract values from instance.\r
303   Now it supports DataRows, DataRowViews and reflection\r
305 - Added ColumnRenderer view component\r
307 - Added DiggStylePagination ViewComponent, based on Alex Henderson work. \r
308   See http://blog.bittercoder.com/PermaLink,guid,579711a8-0b16-481b-b52b-ebdfa1a7e225.aspx\r
310 - Added PaginationHelper.CreateCustomPage\r
311   \r
312   This is only useful if the application code takes care of slicing (select top and etc)\r
314 - Added formatting support to SetOperations (affects FormHelper.Select, Checkboxlist)\r
315   \r
316   Example:\r
317   \r
318   $Form.Select("price", [1..100], "%{textformat='C'}")\r
319   \r
320   This will render a select with options like\r
321   \r
322   <option value="1">$1.00</option>\r
323   <option value="2">$2.00</option>\r
324   <option value="3">$3.00</option>\r
325   ...\r
327 - Added ScriptaculousHelper, deprecated Effects2Helper\r
329 - Extract Behaviour related operations from AjaxHelper into BehaviourHelper\r
331 - Added BehaviourHelper\r
333 - Added UpdatePage and UpdatePageTag ViewComponents. Both allow you to have a "page"\r
334   which is a JS generator. It evaluates the view component body to generate the JS.\r
335   \r
336   Example:\r
337   \r
338 #blockcomponent(UpdatePageTag)\r
339 $page.el('products').style.bgcolor.set('"white"')\r
340 #end\r
343 #blockcomponent(UpdatePage)\r
344 $page.el('products').style.bgcolor.set('"white"')\r
345 #end\r
347 - Added FormHelper.NumberField() which renders a 'input text' with a javascript that\r
348   prevents chars other than numbers (and period) from being entered.\r
350         You can optionally pass an <c>exceptions</c> value through the dictionary.\r
351         It must be a comma separated list of chars that can be accepted on the field. \r
353 - Added FormHelper scripts:\r
355   View must use FormHelper.InstallScripts()\r
357 - Refactored generation of script blocks\r
359 - Created stub for UrlForHelper\r
361 - Helpers are added with a less verbose name \r
362   FormHelper and Form, AjaxHelper and Ajax are made available to the view\r
364 - Added AuthenticatedContent ViewComponent that allows context to be \r
365   render based on the user state (authenticated or anonymous)\r
367 - Removed CompositeViewEngine as it's useless now that we support multiple view engines\r
369 - Multiple view engine support:\r
370   Configuration schema changed, see monorail_configuration_ref.txt for more information\r
372 - Introduced IViewEngineManager that sits between the controller and the view engines\r
373   deciding which view engine will be used output the contents\r
375 - Applied patch by Luke Melia for MR-192: \r
376   "Add TextHelper"\r
378 - Introduced IPaginatedPage.HasPage(), useful for Google-like pagination.\r
380 - PaginationHelper.CreatePagination<T>() now accepts ICollection<T> as a parameter.\r
382 - New method PaginationHelper.CreatePageLinkWithCurrentQueryString().\r
383   Creates a page link, copying the current QueryString parameters as well.\r
385 - Enhanced AbstractHelper.BuildQueryString to support multi-value query strings:\r
386   IDictionary dict = new Hashtable();\r
387   dict.Add("id", 5);\r
388   dict.Add("selectedItem", new int[] { 2, 4, 99 });\r
389   string queryString = BuildQueryString(dict);\r
390   // should result in: "id=5&amp;selectedItem=2&amp;selectedItem=4&amp;selectedItem=99&amp;"\r
392 - FormHelper.Select() - applied patch from James Sapara allowing firstoptionvalue to be set to \r
393   something other than null. \r
395 - Restored property IsPostback checking (For use with WebFormViewEngine).\r
397 - Restored support for passing additional arguments to a controller\r
398   via Send and use a dictionary to supply that information.\r
400 - Applied patch by Andrew Peters fixing MR-182\r
401   "Adds FormTo and LinkToWithPost methods to HtmlHelper"\r
403 - Fixed MR-180\r
404   "Url Tokenizer Bug at Turkish Culture Info"\r
406 - Properly quote file/directory arguments in Pre/Post Build Events to accomodate\r
407   names with spaces.\r
408   Also added some missing files to TestSiteWindsor-vs2005 Project\r
410 - Removed DetermineIfPostBack due to side effects when using a custom upload approach\r
411   Also removed PreRequestHandler setting the session as it wasn't really necessary using\r
412   this event for that. Moved to the handler.\r
414 - Included abstract Filter class, just as a helper to implement filters \r
415   with a better interface (instead of IFilter.Process)\r
417 - Fixed MR-165 "DataBind doesn't bind NullableDateTime"\r
419 - Fixed MR-169\r
420   "Scarfold record modification results exception Can't edit without \r
421   the proper id when validation is failed in the defined validation rule"\r
423 - Fixed MR-168 \r
424   "ValidateEmail attribute does not work properly in Monorail Scarfold"\r
426 - Introduced CacheAttribute which can be used on actions to configure \r
427   the underlying HttpCachePolicy\r
429 - Modified WizardActionProvider to use ControllerLifecycleExecutor\r
431 - Modified EngineContextModule a MonoRailHttpHandler to use ControllerLifecycleExecutor\r
433 - Refactored controller. Extracted process to ControllerLifecycleExecutor\r
435 - Changed ExecuteEnum.Always to include 'StartRequest'\r
437 - Added Filter step: StartRequest\r
439   This step runs on the ResolveRequestCache, and is suitable \r
440   for authentication. However, a session will not be available.\r
442 - Fixed MR-158\r
443   "IRequest/Controller must expose the Http method"\r
444   \r
445   Added the following properties to the Controller class:\r
446     IsPost/IsGet/IsPut/IsHead\r
448 - Fixed problem with view components reported by Ernst Naezer. The problem\r
449   is that the view component were cached, and instances shared during \r
450   template executions.\r
452 - Introduced smtpPort, smtpUsername, smtpPassword configuration to <monorail> node\r
454 - Introduced a PageSize property on the IPaginatedPage.\r
457 Release Candidate 2\r
458 ===================\r
460 - Applied patch by Ivan Porto Carrero fixing MR-158\r
461   "Validation throws errors when using group box."\r
462   \r
463   Quoting description:\r
464   \r
465         "When validating with the option of using a group box then the valdation routine throws an error.\r
466         The error is only thrown after the valdation failed for a couple of controls in the form. And when those errors are corrected and the form gets validated again that's when the error occurs\r
468         "I also added functionality to have a header in the group error box. I also added the possibility to have a separate error label to append to.\r
469         For this I added 2 properties to the config of the validation library.\r
470         The first property is boxErrorHeadingClass and the second one is errorSelectorCssClass\r
472         "In the core script I added 5 lines or so to add this functionality. "\r
474 - Applied patch by Nick Hemsley fixing MR-157\r
475   "add fromNameValueCollection method for creating IDictionary instances from (i.e.) Context.Params, or Request.QueryString"\r
476   \r
477   Method was renamed to FromNameValueCollection\r
479 - Introduced ARPagination.CreatePagination<T>(SimpleQuery<T>). Looks like it can be\r
480   extended later for the non-generic SimpleQuery.\r
482 - Made all Helpers that install javascript code use the same signature Helper.InstallScripts(). Should we mandate an interface?\r
484 - Fixed the GenerateJSProxy(string proxyName, string controller), which was passing a null areaName;\r
486 - Fixed the conflict between the Array.reduce function of Prototype e fValidate scripts (MR-166).\r
489 Release Candidate 1\r
490 ===================\r
492 - ARDataBinder was ovewriting ids on belongs to relations causing\r
493   NHibernate to throw exception. Fixed and added test cases\r
495 - Fixed binder problem (MR-161)\r
497 - Fixed Perfomance issue with Brail and sub views due to cache key normalization issues.\r
499 - Added logging to Brail, configured using the normal Castle's cofniguration mechansim\r
501 - Added support to passing parameters from the view to the layout, enabling a captureFor component in the view to be used in the layout\r
503 - Started refactoring ARScaffold to rely on FormHelper\r
505 - Small refactor on ARScaffold support to make it work with\r
506   . ARDataBinder\r
507   . The new Binder implementation\r
509 - Changed MonoRailContainer to save the configuration. On mono\r
510   a copy is created everytime the config is requested, leading a big problems\r
512 - Fixed MR-155\r
513   "Cast exception with configuration"\r
515 - Added two more events to ExtensionManager: Authorize and Authenticate.\r
516   That allows authentication/authorization extensions to MonoRail that won't\r
517   rely on filters\r
519 - Applied Jochen Grefe's patch fixing NVelocity-3\r
520   "#include not working for nvelocity"\r
522 - Another attempt to MR-152 "Error while initializing MonoRail services"\r
524   Separated container implementation from module. But it's important that \r
525   the module subscribe the events, so the container can delegate event invocations \r
526   to the extension manager\r
528 - Fixed MR-152 "Error while initializing MonoRail services"\r
530 - Applied midas's patch fixing MR-113\r
531   "change collected view name in assembly to lower"\r
533 - Applied Don Morrison's patch fixing MR-150\r
534   "Patch to fix problem with ARDataBinder and ARFetcher when dealing with joined subclasses."\r
536 - Added support for null property handling in Brail.\r
537         ${objMayBeNull.Name} -- will throw if null\r
538         ${ IgnoreNull(objMayBeNull).Name } -- will return empty string when null\r
539         \r
540 -- Breaking change in Brail. Removed <? ?> as markers for code blocks. This was done to allow handling of xml processing instructions (<?xml ?> for instnace).\r
541         Use <?brail ?> markers instead.\r
543 - Applied Marc-André's patch fixing MR-149\r
544   "[TestSupport] Verb not specified for Get request"\r
546 - Applied Ernst Naezer's patch that fixes MR-95 \r
547   "Update ProtoType/Scriptaculous js libraries to latest version"\r
548   \r
549   Prototype library updated to version 1.5.0_rc1\r
550   script.aculo.us updated to 1.6.4\r
552 - Added watir tests for JS proxies (fixes MR-142 "Write test cases for AjaxHelper.GenerateJSProxy()")\r
554 - Added watir tests for Ajax support\r
556 - Changed Ajax helper to default to parameters:'value=' + value instead of parameters:value.\r
557   This old way was causing null keys on the form dictionary and thus being ignored by \r
558   the databinder\r
560 - Fixed MR-106\r
561   "Apply Sean's suggestions"\r
562   \r
563   Component 'ChildContentComponent' introduced, plus a few test cases for it.\r
565 - Fixed MR-101\r
566   "Seems Wizard Controller can't define Area"\r
568 - Fixed MR-128\r
569   "Introduce the notion of conditions to WizardStepPage"\r
570   \r
571   Introduced IsPreConditionSatisfied to WizardStepPage\r
573 - Fixed MR-129\r
574   "Add log support as discussed on the mailing list"\r
576 - Added Logger property to Controller\r
578 - Added more logging information to the request lifecycle\r
580 - Logging support: Important services are now logging what they are doing. \r
581   Verbose logging happens at Debug Level. Error level is used for exceptions\r
583 - Refactored: The EngineContextModule was simplified. Now its duty is to \r
584   instantiate the services and invoke the lifecycle methods. Each service uses\r
585   its lifecycle methods to reference other services and obtain its configuration\r
587 - Refactored: replaceable services were moved to Services namespace\r
589 - Refactored: interfaces meant to be public were moved from Internal \r
590   namespace to the root\r
592 - Fixed MR-126\r
593   "PaginationHelper must support IList<T>"\r
595 - Fixed MR-146\r
596   "FormHelper must be able to handle IList<T>"\r
598 - Fixed MR-145 \r
599   "Change node/section name from monoRail to monorail on configuration file"\r
600   \r
601   Now on the configuration, use <monorail> instead of <monoRail>\r
603 - Included Test site for ActiveRecord support project, watir tests included\r
605 - Refactored ARDataBinder to support HasMany and HasAndBelongsToMany\r
607 - Applied Ernst Naezer <enix@ch10.shuis.tudelft.nl>'s patch fixing build\r
609 - Introduced [AjaxAction] attribute. Any action marked with this attribute\r
610   can be accessed on client-side scripting using a JavaScript proxy, like\r
611   this:\r
613      $ajaxHelper.getJavascriptFunctions()\r
614        ## MANDATORY, must come before any call to generateJSProxy\r
616      $ajaxHelper.generateJSProxy('thisController')\r
617        ## will declare an object named "thisController", allowing access\r
618        ## to all [AjaxAction]s on the current controller\r
620      $ajaxHelper.generateJSProxy('util', 'lists', 'myLists')\r
621        ## will declare an object named "myLists", allowing access\r
622        ## to all [AjaxAction]s on the controller named 'lists', in the 'util' area\r
624   Note that proxies can perform synchronous (blocking) or asynchronous (non-blocking) calls.\r
625   For asynchronous calls, you must always supply a JavaScript function as an additional\r
626   last parameter. When that parameter is absent, the proxy will perform a synchronous call.\r
628      [AjaxAction] public void Sum(int num1, int num2) { RenderText(Convert.ToString(num1 + num2)); }\r
630   You can write:\r
632      // synchronous call\r
633      $('result').value = myLists.sum($('num1').value, $('num2').value);\r
635   Or:\r
637      // asynchronous call\r
638      myLists.sum($('num1').value, $('num2').value, function(t) { $('result').value = t.responseText; });\r
640   Being:\r
642      $('num1').value     = the value of an input with id=num1\r
643      $('num2').value     = the value of an input with id=num2\r
644      function(t) { ... } = the callback\r
645      t.responseText      = any text that the action could have rendered\r
647 - Applied Marc-André's patch fixing MR-140\r
648   "ARDataBindAttribute doesn't  use the controller's DataBinder"\r
650 - Updated AbstractServiceContainer to support adding/removing services.\r
652 - MonoRails services now accept and IServiceContainer instead of an\r
653   IServiceProvider to be able to add services if desired.\r
655 - Small refactor of Controller to to accomodate passing action arguments.\r
657 - Updated SmartDispatchController to utilize HttpRequest parameters when\r
658   additional arguments are supplied via a Send.\r
660 - Applied patch by Freyr Magnússon <freyr.magnusson@gmail.com> fixing MR-139\r
661   "ExceptionChainingExtension doesn´t handle unhandled exceptions"\r
662   \r
663   Which also introduces a new feature:\r
665 Controllers can request IExceptionProcessor through IServiceProvider\r
666 and invoke the handlers to process an exception. For example:\r
668 public void BuyMercedes()\r
670                 try\r
671                 {\r
672                         ...\r
673                 }\r
674                 catch(Exception ex)\r
675                 {\r
676                         IExceptionProcessor exProcessor = (IExceptionProcessor) ServiceProvider.GetService(typeof(IExceptionProcessor));\r
677                         exProcessor.ProcessException(ex);\r
679                         RenderView("CouldNotBuyMercedes");\r
680                 }\r
683 - Changed DataBinder behavior to return empty arrays, instead of null arrays, \r
684   when the IBindingDataSourceNode is null\r
686 - Applied patch by  Bryan Brown fixing MR-138\r
687   "patch to fix formhelper.LabelFor to use IDictionary"\r
689 - Applied Freyr Magnússon's patch fixing MR-137\r
690   "Databinding through DataBindAttribute does not register errors with SmartDispatcherController"\r
692 - Applied peter dol's patch fixing MR-136\r
693   "An overload for ButtonToRemote that accepts htmloptions"\r
695 - WizardStepPage: added more redirect overloads to allow parameters to be \r
696   specified\r
698 - AR Support: Added support to deal with ICollection<T> containers\r
700 - Applied Marc-Andre's patch fixing MR-133\r
701   "TestSupport not working under Mono"\r
703 - Removed PropertyBag.Clear() in Controller.cs to restore the ability to\r
704   update the PropertyBag in filters.\r
706 - Applied Colin Ramsay <castleproject-devel@happyandlost.co.uk> patch making\r
707   the _selectedViewName field accessible through a public property.\r
709 - Checked in changes to better support ASP.NET Views\r
711 - Refactor FormHelper to use a common code to CheckboxList and Select. \r
712   Added support mentioned in MR-130\r
714 - Introduced CreateCheckboxList. See preliminary documentation at \r
715     http://www.castleproject.org/index.php/MonoRail:FormHelper#CheckboxList\r
717 - Applied Colin Ramsay <castleproject-devel@happyandlost.co.uk> patch adding more\r
718   asserts to TestSupport.AbstractMRTestCase and refactored some other things\r
720 - MR-125 testsupport doesn't handle posting to smart dispatcher controller \r
721   Fixed by Andrei Shires <andrei@internetware.co.uk>\r
723 - FormHelper: Now it can fill parameters with the values from the Request.Params\r
725 - FormHelper: fixed Checkbox behavior with databinder by adding a hidden \r
726   field with the same name but carrying the 'false' value. The false value\r
727   can be overriden with a key 'falseValue' if you're working with a non-boolean\r
728   \r
729   For example\r
730   \r
731   FormHelper.CheckboxField("some.property")\r
732   \r
733   Will render\r
734   \r
735   <input type="checkbox" id="some_property" name="some.property" value="true" />\r
736   <input type="hidden" id="some_propertyH" name="some.property" value="false" />\r
739   FormHelper.CheckboxField("acceptDisclaimer", %{trueValue = 'accept', hiddenValue = 'reject'})\r
740   \r
741   Will render\r
742   \r
743   <input type="checkbox" id="acceptDisclaimer" name="acceptDisclaimer" value="accept" />\r
744   <input type="hidden" id="acceptDisclaimerH" name="acceptDisclaimer" value="reject" />\r
747 - Applied Ernst Naezer's patch to allow MR to throw a descriptive\r
748   exception message when two helpers are registered using the same key\r
750 - Added a hack to the WebFormsViewEngine to accomodate different behavior\r
751   with respect to invoking PageParser.GetCompiledInstance on ASP.NET 2.0\r
753 - Added support for defaultValue attribute to FormHelper, which specificy\r
754   what the value should be if the target evaluates to null.\r
756 - Added indexed properties support to FormHelper\r
758   When the target is an array you can\r
759   \r
760     PropertyBag.Add("roles", Roles.FindAll());\r
761     --\r
762     FormHelper.TextField("roles[0].Id")\r
763   \r
764   Which will output\r
765   \r
766     <input type="text" id="roles_0_Id" name="roles[0].Id" value="1" />\r
768   The indexed property can be nested\r
770     PropertyBag.Add("user", User.Find(1));\r
771     --\r
772     FormHelper.TextField("user.roles[0].Id")\r
774     <input type="text" id="user_roles_0_Id" name="user.roles[0].Id" value="1" />\r
776 - Added RadioField(String target, object valueToSend, [IDictionary attributes]) to FormHelper\r
778   The radio will be marked with checked="checked" if the value collected \r
779   from the target matches the valueToSend parameter\r
781 - Fixed RedirectToAction on WizardStepPage. Now it produces a correct action url.\r
783 - Changed WizardStepPage.InternalRedirectToStep to simply RedirectToStep\r
785 - Changed SmartDispatcherController.BuildMethodArguments. Now it tests if the conversion \r
786   succeeded before setting the value on the array.\r
788 - Introduced IWizardPageFactory on WindsorExtension, so a Wizard controller doesn't\r
789   need to reference the IKernel directly\r
791 - Some optimization on Redirect* methods on Controller class. Now they accept\r
792   an IDictionary as a parameter specifier (in addition to NameValueCollection).\r
793   \r
794 - Refactored ControllerDescriptorBuilder (renamed to ControllerDescriptorProvider)\r
795   to use child providers to obtain descriptor. Attributes are now descriptors builders\r
796   and that allows one to come up with custom attributes like\r
798   public class MyAttribute : Attribute, ILayoutDescriptorBuilder, IHelperDescriptorBuilder\r
799   {\r
800      public LayoutDescriptor BuildLayoutDescriptor() \r
801      {\r
802        return new LayoutDescriptor("mylayout");\r
803      }\r
805      public HelperDescriptor[] BuildHelperDescriptors()\r
806      {\r
807        return new HelperDescriptor[] { new HelperDescriptor(typeof(MyHelper)) };\r
808      }\r
809   }\r
811   Kudos to Fabio by coming up with the idea.\r
813 - ViewComponents: added subsection support\r
815   (Using nvelocity as example)\r
816   \r
817   #blockcomponent(GridComponent)\r
818     #header\r
819       <th>Name</th>\r
820     #end\r
821     \r
822     #footer\r
823       Showing record $startrecord to $total\r
824     #end\r
825     \r
826     #item\r
827       <td>$item.Name</td>\r
828     #end\r
830     #empty\r
831       <td>No records found</td>\r
832     #end\r
833   #end\r
834   \r
835   On the code you can use\r
837         public override bool SupportsSection(String name)\r
838         {\r
839                 return name == "header" || name == "item" || name == "footer" || \r
840                         name == "empty";\r
841         }\r
843         public override void Render()\r
844         {\r
845                 ICollection source = (ICollection) ComponentParams["source"];\r
847                 StartTable();\r
849                 Context.RenderSection("header");\r
851                 if (source != null && source.Count != 0)\r
852                 {\r
853                         foreach(object item in source)\r
854                         {\r
855                                 PropertyBag["item"] = item;\r
856                                 \r
857                                 RenderText("<tr>");\r
858                                 \r
859                                 Context.RenderSection("item");\r
860                                 \r
861                                 RenderText("</tr>");\r
862                         }\r
863                 }\r
864                 else\r
865                 {\r
866                         RenderText("<tr>");\r
867                         Context.RenderSection("empty");\r
868                         RenderText("</tr>");\r
869                 }\r
871                 Context.RenderSection("footer");\r
873                 EndTable();\r
874         }\r
876 - ViewComponent on NVelocity: added to support to interpolation on component parameters. \r
878   Action:\r
879   \r
880     public void List()\r
881     {\r
882       PropertyBag.Add("customers", Customer.FindAll());\r
883     }\r
885   View:\r
887     #blockcomponent(GridComponent with "source=$customers")\r
888   \r
889     #end\r
890   \r
891   ViewComponent code:\r
892   \r
893     public override void Render()\r
894     {\r
895       IList items = (IList) ComponentParams["source"];\r
896     \r
897       foreach(object item in items)\r
898       {\r
899         Context.ContextVars["item"] = item;\r
900         // Do something like rendering the body\r
901       }\r
902     }\r
904 - Configuration changed:\r
906   . Added <cacheprovider> node\r
907   . Added <additionalSources> node under <viewEngine>\r
909   Example:\r
910   \r
911   <monoRail>\r
912     <cacheProvider type="my custom implementation"/>\r
913     \r
914     <viewEngine viewPathRoot="views" customEngine="Castle.MonoRail.Framework.Views.NVelocity.NVelocityViewEngine, Castle.MonoRail.Framework.Views.NVelocity">\r
915       <additionalSources>\r
916         <assembly name="MyAssembly" namespace="My.Assembly" />\r
917       </additionalSources>\r
918     </viewEngine>\r
919   </monoRail>\r
921 - IViewEngine refactored to use the IViewSourceLoader to locate views\r
923 - Introduced IViewSourceLoader and IViewSource. The former represents an approach to load\r
924   views. The default implementation is FileAssemblyViewSourceLoader which first look ups \r
925   the file system then the configured assemblies for the specified view\r
927 - ICacheProvider service introduced (available on IServiceProvider implementation).\r
928   Two implementations available: \r
929   \r
930   . DefaultCacheProvider which uses the HttpContext.Cache\r
931   . WeakReferenceCacheProvider which uses a hashtable with WeakReferences as entries\r
933 - Warning about Nullables and SmartDispatcher arguments. The behavior has changed a\r
934   little\r
935   \r
936   . In the past, if the value for a nullable was not present, that was accepted and\r
937     the nullable was initialized with HasData=false\r
938   . Now the value mustn't be present, but the entry must be present\r
939   \r
940   For example\r
941   \r
942   Controller Action:\r
943   \r
944         public void Transfer(NullableDouble amount)\r
945         {\r
946                 ...\r
947         }\r
948   \r
949   If you invoke it with Controller/Transfer.rails you'll get an exception\r
950   \r
951   If you invoke it with Controller/Transfer.rails?amount= then it's ok\r
953   If you invoke it with Controller/Transfer.rails?amount=10 is obviously ok too.\r
955 - Removed Obsolete members of ExecuteEnum. If you were using\r
957   . ExecuteEnum.Before, change to ExecuteEnum.BeforeAction\r
958   . ExecuteEnum.After, change to ExecuteEnum.AfterAction or ExecuteEnum.AfterRendering\r
959   . ExecuteEnum.Around, change to ExecuteEnum.Always or combine the flags\r
961 - Refactored DefaultRailsEngineContext and EngineContextModule. Now EngineContextModule\r
962   is also a ServiceContainer. When a DefaultRailsEngineContext is created we pass\r
963   the EngineContextModule as a parent container. \r
964   \r
965   This saves us some cycles of registering\r
966   the services on every single DefaultRailsEngineContext instance.\r
968 - Added attribute 'checkClientIsConnected' to monoRail configuration check. If \r
969   'true' the controller class will always check IsClientConnected on\r
970   \r
971   - InternalSend (beginning)\r
972   - Before Staring filter process \r
973   - Before invoking the view engine\r
974   \r
975   The default value is 'false'\r
976   \r
977   (kudos to Ahmed)\r
979 - Removed AutoLoadUnlessKeyIs and NullIfKeyIs from ARDataBinder. Added enum \r
980   AutoLoadBehavior to replace them:\r
982   AutoLoadBehavior.Never (default): Means that no autoload should be perform on the target\r
983     type nor on nested types.\r
984       \r
985   AutoLoadBehavior.Always: Means that autoload should be used for the target type\r
986     and the nested types (if present). This demands that the primary key be present on the http request\r
987   \r
988   AutoLoadBehavior.NewInstanceIfInvalidKey: Means that we should autoload, but if the key is \r
989     invalid, like null, 0 or an empty string, then just create a new instance of the target type.\r
990   \r
991   AutoLoadBehavior.NullIfInvalidKey: Means that we should autoload, but if the key is \r
992     invalid, like null, 0 or an empty string, then just return null\r
994 - Added support for AccessibleThrough(Verb.Post, or Verb.Get) to restrict the type of access a controller action requires.\r
996 - Added suport for InPlaceRenderView for Brail\r
998 - Added <? ?> tags for Brail, to match the php style.\r
1000 - Added RemoveCookie() method to IResponse\r
1002 - Fixed a bug in Brail's ViewComponents, where a parameter was search using case sensitive search.\r
1004 - Fixed a bug in ARFetch, where if the parameter was an array and the parameters didn't appear, a null reference would be thrown. Now it's returning an empty array.\r
1006 - Updated boo binaries, should fix the problems with the build on machines with only one framework installed.\r
1008 - Fixed a bug in Brail where a new line was required before a method call was recognized\r
1010 - Added support for optional parameters in Brail, using the syntax ?foo will return null if the value was not set (instead of throwing.)\r
1012 - Fixed a bug where Brail would throw on Empty Views.\r
1014 - Added support for AutoLoadUnlessKeyIs in ARDataBinder - will load the object unless the key is a specific value\r
1015  Usages: public void Save([ARDataBinder(AutoLoadUnlessKeyIs=0)] User user) \r
1017 - Added checks for null id when doing data binding.\r
1019 - Removed useless error handling from Brail, now you'll get the normal ASP.Net Yellow Screen Of Death on errors. More consistent with the rest of the framework.\r
1021 - Added support for <?brail ?> tags for Brail, so it can be valid XML documents\r
1023 - Added logging for Brail, so you can see the Boo code the preprocessor is generating.\r
1025 - Added more verbose output to compiler errors in Brail.\r
1027 - Changed the way Brail name the generated class, now the chances for name clashes are much lower. (View: Users.boo and a parameter Users will not cause problems).\r
1029 - Fixed a bug with Brail not picking up changes that occured by VS.Net\r
1031 - Fixed bug with NVelocity components that caused an InvalidCastException to be thrown by the Render method if there was something other than an IRailsEngineContext occupying the "context" key.\r
1033 - MonoRail is now CLSCompliant (kudos to Roelof Blom <roelof.blom@gmail.com>)\r
1035 - Breaking change: now MonoRail requires that you add the following module to web.config:\r
1037         <system.web>\r
1038                 <httpModules>\r
1039                         <add name="monorail" type="Castle.MonoRail.Framework.EngineContextModule, Castle.MonoRail.Framework" />\r
1040                 </httpModules>\r
1041         </system.web>\r
1043 - Configuration nodes and attributes changes:\r
1044   - mailto to mailTo \r
1045   - mailfrom to mailFrom\r
1046   - customsession to customSession\r
1048 - SmartViewComponent removed\r
1050 - DataBinder refactored out. Now implementation lies on Castle.Components.Binder\r
1051   + Big performance improvement\r
1053 - ARDataBinder now issues a FindByPK for nested objects if the keys differs (existing object with \r
1054   form fields)\r
1056 - SmartDispatcherController: now there's no hardcode reference to DataBind, ARDataBind or ARFetch attributes. \r
1057   They only must implement the interface IParameterBinding. This opens an interesting extension point\r
1058   for users willing to create their own logic to binding form/querystring parameters to their data components\r
1060 - Controller: Added RedirectToAction(String action, params String[] queryStringParameters)\r
1061   example:  RedirectToAction("edit", "id=" + id, "error=couldn't update the row");\r
1063 - Added FlashBinderAttribute (being evaluated)\r
1065 - Added FormHelper (being evaluated)\r
1067 - Added CaptureFor component\r
1069 - Renamed ARPager splitted into ARPaginationHelper and ARPager\r
1071 - ARDataBinder is now able to deal with HasAndBelongsToMany relations. \r
1072   This works in two ways. Suppose you have a Product class with a relation HasAndBelongsToMany to Category.\r
1073   \r
1074   If you send the following fields from a form:\r
1075     \r
1076     product.categories.id=1 \r
1077     product.categories.id=2\r
1078     \r
1079   ARDataBinder will ignore the AutoLoad property and always populate the Categories \r
1080   collection on the product class with the result of FindByPrimaryKey of the categories.\r
1081   Any other field will be ignored, for example product.categories.name will not be bound\r
1082   \r
1083   However, if you send the values like\r
1084   \r
1085     product.categories[0].id=1 \r
1086     product.categories[1].id=2\r
1087     \r
1088   Then ARDataBinder will use the usual path, not ignoring the AutoLoad.\r
1089   \r
1090   This behavior is being evaluated.\r
1092 - Removed AbstractExtension\r
1094 - Extension now uses events (See ExtensionManager)\r
1096 - Interface IMonoRailExtension changed (has only Init method now)\r
1098 - Refactored IParameterBinder in order to make it participate on calculations points.\r
1100 - Introduced WindsorMonoRailSectionHandler which has the support for statements similar to those supported\r
1101   by windsor's XmlInterpreter\r
1102   \r
1103 - Added ARDataBindAttribute.NullWhenPrimaryKey which forces the databinder to\r
1104   ignore and do not load a record if the retrieved PK has the value assigned to this\r
1105   property (kudos to Roelof Blom <roelof.blom@gmail.com>)\r
1107 Beta 5\r
1108 ======\r
1110 ** Core ** \r
1112 - Fixed Flash (it now persists the new entries between requests)  (by Ahmed)\r
1114 - Added FilterAttribute.ExecutionOrder, the default value is Int32.MaxValue \r
1115   so the less the value higher will be the filter priority\r
1117 - Added Controller.RedirectToAction(String actionName)\r
1119 - Added Controller.RedirectToAction overloads (by Fabio Batista)\r
1121 - Controller.Redirect(String) is now virtual, and it's called by all Redirect* methods (by Fabio Batista)\r
1123 - Moved action collection to ControllerMetaDescriptor class, using new method that does not require ScreenCommonPublicMethods.\r
1125 - Moved ControllerDescriptorBuilder creation to ProcessEngineFactory to ensure ControllerDescriptors are only created once\r
1127 - ITrace and Trace property added to IRailsEngineContext (kudos to Chad Humphries)\r
1129 - Hierarchy of areas support (kudos to Fabio Batista)\r
1131 - Support for [Layout] attribute on Actions, so actions can override \r
1132   the Controller's specified layout (by Fabio Batista, rev 1459)\r
1134 - PaginationHelper introduced: paginates objects that implements IList, and supports caching.\r
1136 - ARPager introduced: allows you to specify a custom NHibernate HQL Query or an NHibernate Criteria\r
1137   (using Expression.Eq, à là ActiveRecord's FindAll()) and fetch the results with pagination.\r
1138   (by Fabio Batista)\r
1140 - Added IServerUtility.JavaScriptEscape() (kudos to Chad Humphries)\r
1142 - Added DataBindAttribute.Exclude - A comma separated list of property names \r
1143   to exclude from databinding (kudos to Chad Humphries)\r
1145 - Added IResponse.BinaryWrite() and CreateCookie( HttpCookie ) overload\r
1147 - Added IServerUtility.MapPath()\r
1149 - Added IRailsContext.ApplicationPhysicalPath\r
1151 - Added to HtmlHelper:\r
1152   - InputCheckbox\r
1153   - InputRadio\r
1154   - InputFile\r
1155   - InputButton\r
1156   - Form(action, attribtes) overload\r
1158 - Added more fine-grained support for ExecuteEnum in Filters (by Fabio Batista, rev 1286-1287)\r
1160     The values are now: BeforeAction, AfterAction, AfterRendering and Always.\r
1161   \r
1162 - Support for nullable types in SmartDispatcherController, useful for\r
1163   detecting missing ValueType parameters. Works with Nullables library, still\r
1164   not working on .NET 2.0 Nullables (by Fabio Batista, rev 1297 and 1363)\r
1166   Example of use:\r
1168     // .NET 1.1\r
1169     public void CreateTicket(string name, NullableDateTime date, NullableInt32 priority)\r
1170     {\r
1171       if (name == null || name.Length == 0) throw new MissingFieldException();\r
1172       if (!date.HasValue) throw new MissingFieldException();\r
1173       if (!priority.HasValue) throw new MissingFieldException();\r
1174     }\r
1176     // .NET 2.0 (NOT WORKING YET)\r
1177     public void CreateTicket(string name, DateTime? date, int? priority)\r
1178     {\r
1179       if (name == null || name.Length == 0) throw new MissingFieldException();\r
1180       if (!date.HasValue) throw new MissingFieldException();\r
1181       if (!priority.HasValue) throw new MissingFieldException();\r
1182     }\r
1184 - Broaded support for Enums. They can be specified by number or by text (by Fabio Batista, rev 1203)\r
1186   public enum MyEnum {\r
1187     First = 1,\r
1188     Second = 2\r
1189   }\r
1190   \r
1191   <input type="hidden" name="myEnumValue" value="1" />\r
1192   <input type="hidden" name="myOtherEnumValue" value="seCoNd" />\r
1193   \r
1194   public void TestEnumValues(MyEnum myEnumValue, MyEnum myOtherEnumValue)\r
1195   {\r
1196     if (myEnumValue == MyEnum.First) // ok\r
1197     if (myOtherEnumValue == MyEnum.Second) // ok\r
1198   }\r
1200 - Support for ActiveRecord fetching in Castle.MonoRail.ActiveRecordSupport\r
1201   (by Fabio Batista, rev. 1380).\r
1202         \r
1203         Mainly for those unconfortable with direct binding of form values\r
1204         to ActiveRecord objects. This attribute only fetches the ActiveRecord based\r
1205         on its Primary Key, nothing more.\r
1206         \r
1207         Usage:\r
1208         \r
1209                 public class MyCrudExample : ARSmartDispatchController\r
1210                 {\r
1211                         // simple usage.\r
1212                         public void Save( [ARFetch] Example example, string name, ...)\r
1213                         {\r
1214                                 example.Name = name;\r
1215                                 // ...\r
1216                                 \r
1217                                 example.Save();\r
1218                         }\r
1220                         // using a different request parameter, instead of the action's parameter name\r
1221                         public void Save( [ARFetch("primaryKey")] Example example, string name, ...)\r
1222                         {\r
1223                                 example.Name = name;\r
1224                                 // ...\r
1225                                 \r
1226                                 example.Save();\r
1227                         }\r
1229                         // ignoring invalid primary keys\r
1230                         public void Save( [ARFetch(Require=false)] Example example, string name, ...)\r
1231                         {\r
1232                                 example.Name = name;\r
1233                                 // ...\r
1234                                 \r
1235                                 example.Save();\r
1236                         }\r
1238                         // not creating new records automatically, when the parameter is empty or null\r
1239                         public void Save( [ARFetch(Create=false)] Example example, string name, ...)\r
1240                         {\r
1241                                 if (example == null)\r
1242                                         example = new Example(someRequiredConstructorParameter);\r
1243                                 \r
1244                                 example.Name = name;\r
1245                                 // ...\r
1246                                 \r
1247                                 example.Save();\r
1248                         }\r
1250                         // fetching a list of Active Records\r
1251                         public void Delete( [ARFetch("selected")] Example[] examples )\r
1252                         {\r
1253                                 foreach (Example example in examples)\r
1254                                         example.Delete();\r
1255                         }\r
1256                 }\r
1258 - Support for smart arrays (aside from primitives) (kudos do Ahmed)\r
1260   Quoting the explanation:\r
1261   \r
1262 Suppose you have this class:\r
1264  \r
1265 class Person\r
1267   public string Name {get;set;}\r
1269   public int Age {get;set;}\r
1272 With the following view \r
1274   <input name="Person[0].Name"   value="John">\r
1275   <input name="Person[0].Age"    value="30">\r
1276   <input name="Person[1].Name"   value="Mary">\r
1277   <input name="Person[1].Age"    value="25">\r
1279 Now you can specify the DataBinderAttribute to an array element in your controller:\r
1281 public void SavePeople( [DataBinder(Prefix=”People”)] Person[] people )\r
1283   // you should be able to access the people as an Person array\r
1285   Assert.IsTrue( people[0].Name == “John” );\r
1286   Assert.IsTrue( people[1].Name == “Mary” );\r
1289 There are a couple extra things, first you can specify an “ignore” attribute to any element in which that case the data binder will completely ignore the element\r
1291   <input name="Person[0].Name"   value="John">\r
1292   <input name="Person[0].Age"    value="30">\r
1293   <input name="Person[0]@ignore" value="yes">\r
1294   <input name="Person[1].Name"   value="Mary">\r
1295   <input name="Person[1].Age"    value="25">\r
1297 In the previous html code, the people array in the controller will only have one element (Mary).\r
1299 Notice that I reserved the @ sign as a special character to add metadata to any element, right now the only attributes supported are “ignore” and “count”.\r
1301 The count attribute serves as a performance optimization when your elements are keyed using sequential integers, for example:\r
1303   <input name="Person@count"   value="5">\r
1304   <input name="Person[0].Name" value="John">\r
1305   <input name="Person[1].Name" value="James">\r
1306   <input name="Person[2].Name" value="Jeff">\r
1307   <input name="Person[3].Name" value="Geoff">\r
1308   <input name="Person[4].Name" value="Jeffrey">\r
1310 ** Ajax Helper **\r
1311    \r
1312 - AjaxHelper2 renamed to AjaxHelper. The old one was renamed to AjaxHelperOld\r
1314 - Two more callbacks supported: onSuccess and onFailure. For example\r
1316   $AjaxHelper.BuildFormRemoteTag( $DictHelper.CreateDict("url=something.rails", "OnSuccess=myjavascriptfunction();", "OnFailure=otherfunction(request)" ) );\r
1317   \r
1318   Do not confuse it with 'success' and 'failure' keys, though. Those means the id of elements\r
1319   to be updated in the event of success and failure.\r
1322 ** NVelocity View Engine **\r
1324 - Added support for global macros. Every *.vm file which is placed in the Views/macros directory\r
1325   will be scanned for macros (by Fabio Batista, rev. 1374)\r
1327 ** Brail View Engine **\r
1329 - Upgraded to use Boo 0.75, should solve the problem that Brail had with breaking tests.\r
1331 ** Scaffolding support **\r
1333 - huge refactoring\r
1334 - It's now using templates\r
1337 ** Test support **\r
1339 - Introduced Castle.MonoRail.TestSupport\r
1342 ** Bug fixes **\r
1344 MR-68   PreSendView is not being invoked by NVelocityViewEngine\r
1345         http://support.castleproject.org/jira/browse/MR-68\r
1346 MR-66   DataBinder and ConvertUtils should support TypeConverters\r
1347         http://support.castleproject.org/jira/browse/MR-66\r
1348 MR-64   DataBinder.Convert should support decimal\r
1349         http://support.castleproject.org/jira/browse/MR-64\r
1350 MR-58   AbstractHelper generates invalid XHTML\r
1351         http://support.castleproject.org/jira/browse/MR-58\r
1352 MR-57   Wrong urls are crashing UrlTokenizer\r
1353         http://support.castleproject.org/jira/browse/MR-57\r
1354 MR-52   Support for real Flash feature\r
1355         http://support.castleproject.org/jira/browse/MR-52\r
1356 MR-49   Remove public properties from the list of available actions (Controller.cs)\r
1357         http://support.castleproject.org/jira/browse/MR-49\r
1358 MR-30   MR should not accept incorrect urls\r
1359         http://support.castleproject.org/jira/browse/MR-30\r
1362 Beta 4\r
1363 ======\r
1365 - Added useWindsorIntegration attribute to monoRail configuration section\r
1367 Beta 3\r
1368 ======\r
1370 - Databind\r
1371 - Initial Scaffolding support\r
1372 - Routing feature\r
1373 - Localization support\r
1374 - More helpers and improvements\r
1377 Beta 2\r
1378 ====== \r
1380 - Few bug corrections\r
1381 - Applied patch from Dru Sellers: NVelocityViewEngine adds a $siteRoot exposing the Request.ApplicationPath\r