- Applied Mike Nichols' patch adding two more events to the extension manager.
[castle.git] / MonoRail / Changes.txt
blobe3ddf56e7b9e27273ceaebcd6f85c0840d35d4e6
1 1.0\r
2 ===\r
3 \r
4 - Applied Mike Nichols' patch adding two more events to the extension manager.\r
5 \r
6 - Applied Felix Gartsman's patch fixing MR-387\r
7   "ViewComponent selective caching"\r
8 \r
9 - Applied Felix Gartsman's patch fixing MR-368\r
10   "Added DetachedCriteria support to ARPaginationHelper/ARPaginableCriteria"\r
12 - Applied Gauthier Segay's patch fixing MR-384\r
13   "GenericCustomPage<T> should rely on IEnumerable<T> instead of IList<T> for it's datasource"\r
15 - Applied James Curran's patch fixing MR-347\r
16   "Cannot specify a default value for ViewComponentParameterAttribute"\r
18 - Applied Adam Tybor's patch fixing MR-370\r
19   "RouteContext and Http Method Filtering for PatternRule"\r
21 - Applied Daniel Jin's patch fixing MR-372\r
22   "add monorail configuration section to set the useExtensions option on DefaultUrlBuilder"\r
24 - Fixed MR-84\r
25   "Nested classes are mapped wrongly to form fields"\r
27 - Applied Kode Khan's patch changing logger creation to use type instead of controller's name\r
29 - Implemented support for view component caching. Just use the attribute \r
30   ViewComponentDetails and its properties (cache, cachekeygenerator)\r
32 - Applied Michael Sanford's patch which adds image button support to FormHelper.\r
34 - Applied Rafael Teixeira's patch fixing MR-357\r
35   "ViewEngineBase.IsTemplateForJSGeneration(String templateName) returns \r
36    true for a templateName with an incorrect extension"\r
38 - Added support for Composite Key in Formhelper select\r
40 - Applied Chris Ortman's patch with changes for the REST support (MR-333)\r
42 - Applied Nick Hemsley's patch adding support for rescue controllers (MR-332)\r
43   "add RescueController to RescueAttribute"\r
45 - Applied suggestion by Daniel D to fix MR-329\r
46   "Impossible to Context.Response.Redirect to any controller in empty Area from controller placed in some Area."\r
48 - Applied minor patch by Ken Egozi fixing MR-328\r
49   "In PrototypeWebValidation, SameAsValidator and NotSameAsValidator \r
50    are forcing a locase id for text fields"\r
52 - Applied minor patch by Nick Hemsley fixing MR-325\r
53   "DictHelper.FromNameValueCollection: persist arrays correctly"\r
55 - Added LocalExceptionFilterHandler\r
57 - Applied Robert Ream's patch which allows [DefaultAction] to be applied to Actions. This means that no strings are required. \r
59 - BaseControllerTest supports the ContextInitializer delegate, which makes it easier to modify the MockRailsEngineContext\r
61 Release Candidate 3\r
62 ===================\r
64 - Added IDisposable/Dispose back to the controller\r
66 - Applied Lee Henson's patch adding generic overloads to ReflectionHelper\r
68 - Added a few more RenderView overloads that take a mimeType to configure the Response.ContentType\r
70 - If the controller cannot be found, MR searches for a special rescue "rescues/404" before throwing throwing an exception.\r
72 - 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
74 - UrlHelper change: Now if the param encode wasn't set, UrlHelper assumes it's true.\r
76 - Applied patch by Oleg Snurnikov fixing MR-319\r
77   "MockResponse - basic implementation of Redirect, Write, BinaryWrite and Clear overloads"\r
79 - Applied patch by Chirs Ortman fixing MR-296\r
80   "Dont get validation summary when binding with AR attribute but controller inherits smart dispatcher controller"\r
82 - Applied patch by Rafael Teixeira fixing MR-298\r
83   "ColumnRenderer with an empty enumeration still renders table start and end sections"\r
85 - Fixed MR-300\r
86   "DataBindAttribute in a ARSmartDispatcherController inherit the behavior from ARDataBinder"\r
88 - Applied minor patch by James Su fixing MR-303\r
89   "Behavior is not consistent between FormToAttributed and LinkToAttributed in HtmlHelper"\r
91 - Applied goodwill's patch adding cookie support to BaseControllerTest MR-304\r
93 - Applied goodwill's patch fixing MR-305\r
94   "fValidate fix a bug on unassociated label for element"\r
96 - Applied Oleg Snurnikov's patch fixing MR-306\r
97   "PrototypeWebValidator - regular expression validation"\r
99 - Fixed MR-311 \r
100   "The '\' character in templates goes unescaped when processed via NJS"\r
102 - The DefaultUrlBuilder now accepts a basePath parameter, which basically overrides the path information.\r
104 - Fixed MR-317\r
105   "ARDataBind handles BelongsTo attribute in Nested component incorrectly."\r
107 - FlashBinderAttribute was removed as I doesnt work with the new \r
108   MonoRail design (changed to make the cache support work)\r
110 - Applied Tim Haines' patch adding TextAreaValue to FormHelper \r
112 - Fixed MR-281 \r
113   "View components params problem"\r
115 - Applied Markus Zywitza's patch adding a Fold method to TextHelper. \r
116   His description "Shortens a text to the specified length (using full words only and\r
117 adding an ellipsis at the end) and wraps it into a span-element that\r
118 has the title-property with the full text associated. This is\r
119 convenient for displaying properties in tables that might have very\r
120 much content (desription fields etc.) without destroying the table's\r
121 layout. Due to the title-property of the surrounding span-element, the\r
122 full text is displayed in the browser while hovering over the\r
123 shortened text."\r
125 - Applied Aaron Jensen's patch fixing MR-288\r
126   "ApplicationPhysicalPath returns request path instead of / path"\r
128 - Fixed MR-284\r
129   "MockServerUtility.MapPath throws NotImplementedException"\r
131 - Applied Bill Pierce's patch fixing MR-278\r
132   "Add UrlDecode to IServerUtility"\r
134 - Applied Bryan Brown's patch fixing MR-273. This one adds a new attribute to \r
135   the routing configuration node: 'excludeAppPath'\r
136   "Automatically handle ApplicationPath in the routing module"\r
138 - Applied goodwill's patch fixing MR-275\r
139   "DefaultRailsEngineContext triggers RTE on ApplicationPhysicalPath \r
140    when running under ASPX Dev Server with virtual directory"\r
142 - Changed the BaseControllerTest vdir to "" instead "/"\r
144 - Added the Declare(String variable) to IJSGenerator inteface\r
146 - Applied Tim Haines' patch changing FormHelper to make calls to FormatIfNecessary \r
148 - Applied chris ortman's patch fixing MR-271\r
149   "AdditionalSources not loaded when using the viewEngines element"\r
151 - Applied Ricardo Stuven's patch fixing MR-258\r
152   "JSON serialization in Ajax calls"\r
154 - Applied goodwill's patch fixing MR-212\r
155   "Script Helpers (e.g. $Scriptaculous) installscript function clear flash unexpected"\r
157 - Applied Georges Benatti's patch \r
158   adding the attribute matchHostNameAndPath to the routing node on the configuration. \r
159   \r
160   If set to 'true', the regular expression is matched against the whole url. Defaults to 'false'\r
162 - Added ability to customise Next/Prev links in DiggStylePagination.\r
163    Patch from Markus Zywitza.\r
165 - Applied Mathias Doenitz's patch fixing MR-265\r
166   "(Re)enable initialization of Controller.AreaName, Controller.Name and Controller.Action before invoking Controller.Initialize()."\r
168 - Applied Adam Tybor's patch fixing MR-266\r
169   "Fix for GetErrorSummary() throwing an KeyNotFoundException for SmartDispatch Controller and Binder"\r
171 - Fixed MR-260\r
172   "PropertyBag in WizardStep is null when access via key"\r
174 - Applied Kyle Marshall's patch fixing MR-261\r
175   "The default ValidatorRegistry is not overriddable in the monorail configuration"\r
177 - Add support to BaseControllerTest (well MockRequest actually) for Mocking Url Referer. Patch from Colin Ramsay. \r
179 - Fix SupportsSection implementation in ViewComponent (was comparing section name equality against StringComparer.InvariantCultureIgnoreCase). \r
180   Also add a SupportsSection implementation to DiggStylePagination. Patches from Tim Haines. \r
182 - Small change to DiggStylePagination to allow supplying querystring parameters in the url. Suggested by kalle.stenflo@gmail.com.\r
184 - Applied Tim Haines' patch adding BindObject overloads that accept the AutoLoadBehavior enum, \r
185   to the ARSmartDispatcherController \r
187 - Changes from Lee Henson to add WizardStep support to TestSupport and provide a Generic BaseControllerTest. \r
189 - Patch from Maruis Marais allowing BuildFormRemoteTag to gracefully degrade when JavaScript is disabled. \r
191 - Patch from Lee Henson fixing regression introduced in 3783 in Prototype Validator. (Could not use hyphens in element id's). \r
193 - Fixed MR-241 \r
194   "When Windsor integration is enabled, the ControllerTree is empty"\r
196 - Apply patches from Tim Haynes. \r
197   "add a renderIfOnlyOnePage property to the DiggStylePagination View Component"\r
198   "Add NewRootInstanceIfInvalidKey AutoloadBehaviour to Castle.MonoRail.ActiveRecordSupport"\r
200 - Applied Goodwill's patch adding PersisteFlashFilter and the fValidate's localization support. Fixed MR-246.\r
202 - Fixed the use of Scaffolding without Layouts (MR-251).\r
204 - Added support for eager fetching of lazy collections, in [ARFetch] attribute.\r
206 - Added support for auto load bevahior configuration when invokling the BindObject in the   ARSmartDispatcherController\r
208 - Added support for different access and naming strategies in the ARDatabind attribute.\r
210 - Applied Matt Berther's patch adding LoggingExceptionHandler and FilteredExceptionHandler.\r
212 - Applied chris ortman's patch fixing MR-242\r
213   "FormHelper.LabelFor does not generate valid HTML when attributes are supplied"\r
215 - Applied bonskijr's patch fixing MR-234\r
216   "Under some circunstances ColumnRenderer generates invalid html"\r
218 - Applied Marc-André's patch fixing MR-238\r
219   "HtmlHelper.LinkTo: bugs- don't function when existing a area"\r
221 - Applied Aaron Jensen's patch fixing the Resource Manager usage \r
222   Changed from ResourceSet to ResourceManager\r
224 - Applied Lee Henson's patch adding the 'onCreateAdvice'\r
225   to PrototypeWebValidator\r
227 - Applied Chris Ortman's patch fixing MR-235\r
228   "Allow overriding of select generation in FormHelper"\r
230 - Added Item(string id) overload to Checkboxlist\r
231   Used to generate a checkbox with the specified id. Useful to label for='id' constructions\r
233 - Added the Expect property to the ARDataBindAttr. Now it will clear the collections \r
234   that are declared as expected, if not can be found on the resquest params. (MR-163)\r
236 - Applied Colin Ramsay's patch fixing MR-232\r
237   "HtmlHelper.InputButton should create <button> not <input type="button">"\r
239 - Fixed MR-228\r
240   "incorrect component configuration results in an 'The container seems to be unavailable \r
241    in your HttpApplication subclass' exception"\r
243 - Applied Bart Reyserhove's patch fixing MR-226 \r
244   "ARDataBinder has problems when using generic collections"\r
246 - Applied Jacob Lewallen's patch adding a new attribute (ViewComponentAttribute) used\r
247   to name view components. The behavior is changed to strip the 'Component' suffix from the class name as well.\r
249 - Applied Ernst Naezer's patch fixing MR-191\r
250   "Add TransformFilter support to MR"\r
252 - Applied Lee Henson's patch fixing MR-222\r
253   "Use of IRailsEngineContext.Items"\r
255 - Fixed MR-224\r
256   "ARDataBindAttribute does not set the Controllers validator on it's DataBinder"\r
258 - Fixed MR-219\r
259   "FormHelper.Select with an interface datasource throws an Object mismatch exception."\r
261 - Applied chris ortman's patch fixing MR-188\r
262   "Allow the #component directive to support variables for the component name"\r
264 - Fixed MR-208\r
265   "Using a lazy loaded nested object, "Ambiguous match found" exception occures when \r
266    trying to use FormHelper to render control for the nested objects property."\r
268 - Applied goodwill's patch fixing MR-213\r
269   "DiggStylePagination has a typo which prevents the code from build"\r
271 - Applied Edward Kreis' patch fixing MR-214\r
272   "ARDataBinding and joined subclasses with derived BelongsTo, HasMany, HasAndBelongsToMany proeprties"\r
274 - Fixed MR-217 \r
275   "fValidate box message contains <BR/> if being triggered twice"\r
277 - Fixed MR-221\r
278   "HtmlHelper.LinkToAttributed bug"\r
280 - Applied Jacob Lewallen's patch adding an optional attribute to define a view component's name\r
281   The patch also introduces a IViewComponentTree.\r
283 - Added 'noaction' parameter to FormHelper.FormTag to prevent action attribute generation\r
285 - Added Select list from Enum.\r
287         in controller:\r
288                 PropertyBag.Add("colors",Enum.GetValues(typeof(ColorEnum)));\r
290         in view:\r
291                 $Form.Select("Color", $colors)\r
293 - Applied Chris Ortman's patch adding MooHelper/JS generation based on it.\r
295 - Applied Jacob Lewallen's patch adding virtuals to some FormHelper methods\r
297 - Applied Patrick McEvoy's patch with a new approach to delete cookies\r
299 - Added \r
301         SmartDispatcherController.ValidationSummaryPerInstance : IDictionary\r
302         SmartDispatcherController.GetErrorSummary(object instance) : ErrorSummary\r
303         SmartDispatcherController.HasValidationError(object instance) : bool\r
304         \r
305   Those can be used if DataBinder is configured to validate\r
307 - Added Controller.RedirectToReferer\r
309 - Configuration changed, added defaultUrls section (see monorail_configuration_ref.txt)\r
311 - Added Controller.RenderMailMessage(string templateName, bool doNotApplyLayout) overload\r
313 - Added static accessor support to NVelocity view engine. Default helpers are \r
314   the Common System Types in dotnet (i.e. Double, String, Decimal, etc.)\r
315   \r
316     In your template: $String.Concat("foo","bar","me","please:",$Double.Epsilon)\r
317     (dotnet 2 only.)\r
319 - Added better ControllerBinder support for indexed property expressions.\r
320    This allows you to pass DataKeys as your action arguments\r
322 - Applied Freyr Magnússon's patch fixing MR-206 \r
323   "ARBadaBinder does not resolve primary key for discriminator subclass from parent"\r
325 - Retrieve target properties on demand for ControllerBinders ActionArgument editor\r
327 - Added ControllerBinder Extender Control for WebForm views to eliminate the\r
328    need to add event handlers in the codebehind that call Controller.Send\r
330 - Brail now has Ruby's like symbols, using @symbol.\r
331     For instance, component DiggStylePagination, ${ @useInlineStyle : true }\r
332         \r
333 - Brail can now accept " inside a ${ }, which used to break the parser previously.\r
335 - Added IViewComponentContext.RenderView(name, textwriter)\r
337 - Fixed MR-201\r
338   "DiggStylePagination.Initialize() doesn't check useInlineStyle parameter"\r
340 - Added FormHelper.HiddenField("key", value) overload\r
342 - Added 'valueformat' to SetOperations (affects FormHelper.Select, Checkboxlist)\r
344 - Fixed MR-197\r
345   "Exception thrown by AccessibleThrough are not caught by rescues"\r
347 - Added 'textformat' support to the all FormHelper operations (that create input elements).\r
349 - Added BrailJS Support, allowing to generate javascript via brail scripts.\r
350  Note; BrailJS scripts do not need <?brail ?> and any output statements there will be ignored.\r
351   They are used strictly to create the generator.\r
353 - Changed Brail extention from Boo to Brail / BrailJS\r
355 - Added mask support to FormHelper field elements\r
357 - Added FormHelper.PasswordNumberField\r
359 - Refactored FormHelper to support other approaches to extract values from instance.\r
360   Now it supports DataRows, DataRowViews and reflection\r
362 - Added ColumnRenderer view component\r
364 - Added DiggStylePagination ViewComponent, based on Alex Henderson work. \r
365   See http://blog.bittercoder.com/PermaLink,guid,579711a8-0b16-481b-b52b-ebdfa1a7e225.aspx\r
367 - Added PaginationHelper.CreateCustomPage\r
368   \r
369   This is only useful if the application code takes care of slicing (select top and etc)\r
371 - Added formatting support to SetOperations (affects FormHelper.Select, Checkboxlist)\r
372   \r
373   Example:\r
374   \r
375   $Form.Select("price", [1..100], "%{textformat='C'}")\r
376   \r
377   This will render a select with options like\r
378   \r
379   <option value="1">$1.00</option>\r
380   <option value="2">$2.00</option>\r
381   <option value="3">$3.00</option>\r
382   ...\r
384 - Added ScriptaculousHelper, deprecated Effects2Helper\r
386 - Extract Behaviour related operations from AjaxHelper into BehaviourHelper\r
388 - Added BehaviourHelper\r
390 - Added UpdatePage and UpdatePageTag ViewComponents. Both allow you to have a "page"\r
391   which is a JS generator. It evaluates the view component body to generate the JS.\r
392   \r
393   Example:\r
394   \r
395 #blockcomponent(UpdatePageTag)\r
396 $page.el('products').style.bgcolor.set('"white"')\r
397 #end\r
400 #blockcomponent(UpdatePage)\r
401 $page.el('products').style.bgcolor.set('"white"')\r
402 #end\r
404 - Added FormHelper.NumberField() which renders a 'input text' with a javascript that\r
405   prevents chars other than numbers (and period) from being entered.\r
407         You can optionally pass an <c>exceptions</c> value through the dictionary.\r
408         It must be a comma separated list of chars that can be accepted on the field. \r
410 - Added FormHelper scripts:\r
412   View must use FormHelper.InstallScripts()\r
414 - Refactored generation of script blocks\r
416 - Created stub for UrlForHelper\r
418 - Helpers are added with a less verbose name \r
419   FormHelper and Form, AjaxHelper and Ajax are made available to the view\r
421 - Added AuthenticatedContent ViewComponent that allows context to be \r
422   render based on the user state (authenticated or anonymous)\r
424 - Removed CompositeViewEngine as it's useless now that we support multiple view engines\r
426 - Multiple view engine support:\r
427   Configuration schema changed, see monorail_configuration_ref.txt for more information\r
429 - Introduced IViewEngineManager that sits between the controller and the view engines\r
430   deciding which view engine will be used output the contents\r
432 - Applied patch by Luke Melia for MR-192: \r
433   "Add TextHelper"\r
435 - Introduced IPaginatedPage.HasPage(), useful for Google-like pagination.\r
437 - PaginationHelper.CreatePagination<T>() now accepts ICollection<T> as a parameter.\r
439 - New method PaginationHelper.CreatePageLinkWithCurrentQueryString().\r
440   Creates a page link, copying the current QueryString parameters as well.\r
442 - Enhanced AbstractHelper.BuildQueryString to support multi-value query strings:\r
443   IDictionary dict = new Hashtable();\r
444   dict.Add("id", 5);\r
445   dict.Add("selectedItem", new int[] { 2, 4, 99 });\r
446   string queryString = BuildQueryString(dict);\r
447   // should result in: "id=5&amp;selectedItem=2&amp;selectedItem=4&amp;selectedItem=99&amp;"\r
449 - FormHelper.Select() - applied patch from James Sapara allowing firstoptionvalue to be set to \r
450   something other than null. \r
452 - Restored property IsPostback checking (For use with WebFormViewEngine).\r
454 - Restored support for passing additional arguments to a controller\r
455   via Send and use a dictionary to supply that information.\r
457 - Applied patch by Andrew Peters fixing MR-182\r
458   "Adds FormTo and LinkToWithPost methods to HtmlHelper"\r
460 - Fixed MR-180\r
461   "Url Tokenizer Bug at Turkish Culture Info"\r
463 - Properly quote file/directory arguments in Pre/Post Build Events to accomodate\r
464   names with spaces.\r
465   Also added some missing files to TestSiteWindsor-vs2005 Project\r
467 - Removed DetermineIfPostBack due to side effects when using a custom upload approach\r
468   Also removed PreRequestHandler setting the session as it wasn't really necessary using\r
469   this event for that. Moved to the handler.\r
471 - Included abstract Filter class, just as a helper to implement filters \r
472   with a better interface (instead of IFilter.Process)\r
474 - Fixed MR-165 "DataBind doesn't bind NullableDateTime"\r
476 - Fixed MR-169\r
477   "Scarfold record modification results exception Can't edit without \r
478   the proper id when validation is failed in the defined validation rule"\r
480 - Fixed MR-168 \r
481   "ValidateEmail attribute does not work properly in Monorail Scarfold"\r
483 - Introduced CacheAttribute which can be used on actions to configure \r
484   the underlying HttpCachePolicy\r
486 - Modified WizardActionProvider to use ControllerLifecycleExecutor\r
488 - Modified EngineContextModule a MonoRailHttpHandler to use ControllerLifecycleExecutor\r
490 - Refactored controller. Extracted process to ControllerLifecycleExecutor\r
492 - Changed ExecuteEnum.Always to include 'StartRequest'\r
494 - Added Filter step: StartRequest\r
496   This step runs on the ResolveRequestCache, and is suitable \r
497   for authentication. However, a session will not be available.\r
499 - Fixed MR-158\r
500   "IRequest/Controller must expose the Http method"\r
501   \r
502   Added the following properties to the Controller class:\r
503     IsPost/IsGet/IsPut/IsHead\r
505 - Fixed problem with view components reported by Ernst Naezer. The problem\r
506   is that the view component were cached, and instances shared during \r
507   template executions.\r
509 - Introduced smtpPort, smtpUsername, smtpPassword configuration to <monorail> node\r
511 - Introduced a PageSize property on the IPaginatedPage.\r
514 Release Candidate 2\r
515 ===================\r
517 - Applied patch by Ivan Porto Carrero fixing MR-158\r
518   "Validation throws errors when using group box."\r
519   \r
520   Quoting description:\r
521   \r
522         "When validating with the option of using a group box then the valdation routine throws an error.\r
523         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
525         "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
526         For this I added 2 properties to the config of the validation library.\r
527         The first property is boxErrorHeadingClass and the second one is errorSelectorCssClass\r
529         "In the core script I added 5 lines or so to add this functionality. "\r
531 - Applied patch by Nick Hemsley fixing MR-157\r
532   "add fromNameValueCollection method for creating IDictionary instances from (i.e.) Context.Params, or Request.QueryString"\r
533   \r
534   Method was renamed to FromNameValueCollection\r
536 - Introduced ARPagination.CreatePagination<T>(SimpleQuery<T>). Looks like it can be\r
537   extended later for the non-generic SimpleQuery.\r
539 - Made all Helpers that install javascript code use the same signature Helper.InstallScripts(). Should we mandate an interface?\r
541 - Fixed the GenerateJSProxy(string proxyName, string controller), which was passing a null areaName;\r
543 - Fixed the conflict between the Array.reduce function of Prototype e fValidate scripts (MR-166).\r
546 Release Candidate 1\r
547 ===================\r
549 - ARDataBinder was ovewriting ids on belongs to relations causing\r
550   NHibernate to throw exception. Fixed and added test cases\r
552 - Fixed binder problem (MR-161)\r
554 - Fixed Perfomance issue with Brail and sub views due to cache key normalization issues.\r
556 - Added logging to Brail, configured using the normal Castle's cofniguration mechansim\r
558 - 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
560 - Started refactoring ARScaffold to rely on FormHelper\r
562 - Small refactor on ARScaffold support to make it work with\r
563   . ARDataBinder\r
564   . The new Binder implementation\r
566 - Changed MonoRailContainer to save the configuration. On mono\r
567   a copy is created everytime the config is requested, leading a big problems\r
569 - Fixed MR-155\r
570   "Cast exception with configuration"\r
572 - Added two more events to ExtensionManager: Authorize and Authenticate.\r
573   That allows authentication/authorization extensions to MonoRail that won't\r
574   rely on filters\r
576 - Applied Jochen Grefe's patch fixing NVelocity-3\r
577   "#include not working for nvelocity"\r
579 - Another attempt to MR-152 "Error while initializing MonoRail services"\r
581   Separated container implementation from module. But it's important that \r
582   the module subscribe the events, so the container can delegate event invocations \r
583   to the extension manager\r
585 - Fixed MR-152 "Error while initializing MonoRail services"\r
587 - Applied midas's patch fixing MR-113\r
588   "change collected view name in assembly to lower"\r
590 - Applied Don Morrison's patch fixing MR-150\r
591   "Patch to fix problem with ARDataBinder and ARFetcher when dealing with joined subclasses."\r
593 - Added support for null property handling in Brail.\r
594         ${objMayBeNull.Name} -- will throw if null\r
595         ${ IgnoreNull(objMayBeNull).Name } -- will return empty string when null\r
596         \r
597 -- Breaking change in Brail. Removed <? ?> as markers for code blocks. This was done to allow handling of xml processing instructions (<?xml ?> for instnace).\r
598         Use <?brail ?> markers instead.\r
600 - Applied Marc-André's patch fixing MR-149\r
601   "[TestSupport] Verb not specified for Get request"\r
603 - Applied Ernst Naezer's patch that fixes MR-95 \r
604   "Update ProtoType/Scriptaculous js libraries to latest version"\r
605   \r
606   Prototype library updated to version 1.5.0_rc1\r
607   script.aculo.us updated to 1.6.4\r
609 - Added watir tests for JS proxies (fixes MR-142 "Write test cases for AjaxHelper.GenerateJSProxy()")\r
611 - Added watir tests for Ajax support\r
613 - Changed Ajax helper to default to parameters:'value=' + value instead of parameters:value.\r
614   This old way was causing null keys on the form dictionary and thus being ignored by \r
615   the databinder\r
617 - Fixed MR-106\r
618   "Apply Sean's suggestions"\r
619   \r
620   Component 'ChildContentComponent' introduced, plus a few test cases for it.\r
622 - Fixed MR-101\r
623   "Seems Wizard Controller can't define Area"\r
625 - Fixed MR-128\r
626   "Introduce the notion of conditions to WizardStepPage"\r
627   \r
628   Introduced IsPreConditionSatisfied to WizardStepPage\r
630 - Fixed MR-129\r
631   "Add log support as discussed on the mailing list"\r
633 - Added Logger property to Controller\r
635 - Added more logging information to the request lifecycle\r
637 - Logging support: Important services are now logging what they are doing. \r
638   Verbose logging happens at Debug Level. Error level is used for exceptions\r
640 - Refactored: The EngineContextModule was simplified. Now its duty is to \r
641   instantiate the services and invoke the lifecycle methods. Each service uses\r
642   its lifecycle methods to reference other services and obtain its configuration\r
644 - Refactored: replaceable services were moved to Services namespace\r
646 - Refactored: interfaces meant to be public were moved from Internal \r
647   namespace to the root\r
649 - Fixed MR-126\r
650   "PaginationHelper must support IList<T>"\r
652 - Fixed MR-146\r
653   "FormHelper must be able to handle IList<T>"\r
655 - Fixed MR-145 \r
656   "Change node/section name from monoRail to monorail on configuration file"\r
657   \r
658   Now on the configuration, use <monorail> instead of <monoRail>\r
660 - Included Test site for ActiveRecord support project, watir tests included\r
662 - Refactored ARDataBinder to support HasMany and HasAndBelongsToMany\r
664 - Applied Ernst Naezer <enix@ch10.shuis.tudelft.nl>'s patch fixing build\r
666 - Introduced [AjaxAction] attribute. Any action marked with this attribute\r
667   can be accessed on client-side scripting using a JavaScript proxy, like\r
668   this:\r
670      $ajaxHelper.getJavascriptFunctions()\r
671        ## MANDATORY, must come before any call to generateJSProxy\r
673      $ajaxHelper.generateJSProxy('thisController')\r
674        ## will declare an object named "thisController", allowing access\r
675        ## to all [AjaxAction]s on the current controller\r
677      $ajaxHelper.generateJSProxy('util', 'lists', 'myLists')\r
678        ## will declare an object named "myLists", allowing access\r
679        ## to all [AjaxAction]s on the controller named 'lists', in the 'util' area\r
681   Note that proxies can perform synchronous (blocking) or asynchronous (non-blocking) calls.\r
682   For asynchronous calls, you must always supply a JavaScript function as an additional\r
683   last parameter. When that parameter is absent, the proxy will perform a synchronous call.\r
685      [AjaxAction] public void Sum(int num1, int num2) { RenderText(Convert.ToString(num1 + num2)); }\r
687   You can write:\r
689      // synchronous call\r
690      $('result').value = myLists.sum($('num1').value, $('num2').value);\r
692   Or:\r
694      // asynchronous call\r
695      myLists.sum($('num1').value, $('num2').value, function(t) { $('result').value = t.responseText; });\r
697   Being:\r
699      $('num1').value     = the value of an input with id=num1\r
700      $('num2').value     = the value of an input with id=num2\r
701      function(t) { ... } = the callback\r
702      t.responseText      = any text that the action could have rendered\r
704 - Applied Marc-André's patch fixing MR-140\r
705   "ARDataBindAttribute doesn't  use the controller's DataBinder"\r
707 - Updated AbstractServiceContainer to support adding/removing services.\r
709 - MonoRails services now accept and IServiceContainer instead of an\r
710   IServiceProvider to be able to add services if desired.\r
712 - Small refactor of Controller to to accomodate passing action arguments.\r
714 - Updated SmartDispatchController to utilize HttpRequest parameters when\r
715   additional arguments are supplied via a Send.\r
717 - Applied patch by Freyr Magnússon <freyr.magnusson@gmail.com> fixing MR-139\r
718   "ExceptionChainingExtension doesn´t handle unhandled exceptions"\r
719   \r
720   Which also introduces a new feature:\r
722 Controllers can request IExceptionProcessor through IServiceProvider\r
723 and invoke the handlers to process an exception. For example:\r
725 public void BuyMercedes()\r
727                 try\r
728                 {\r
729                         ...\r
730                 }\r
731                 catch(Exception ex)\r
732                 {\r
733                         IExceptionProcessor exProcessor = (IExceptionProcessor) ServiceProvider.GetService(typeof(IExceptionProcessor));\r
734                         exProcessor.ProcessException(ex);\r
736                         RenderView("CouldNotBuyMercedes");\r
737                 }\r
740 - Changed DataBinder behavior to return empty arrays, instead of null arrays, \r
741   when the IBindingDataSourceNode is null\r
743 - Applied patch by  Bryan Brown fixing MR-138\r
744   "patch to fix formhelper.LabelFor to use IDictionary"\r
746 - Applied Freyr Magnússon's patch fixing MR-137\r
747   "Databinding through DataBindAttribute does not register errors with SmartDispatcherController"\r
749 - Applied peter dol's patch fixing MR-136\r
750   "An overload for ButtonToRemote that accepts htmloptions"\r
752 - WizardStepPage: added more redirect overloads to allow parameters to be \r
753   specified\r
755 - AR Support: Added support to deal with ICollection<T> containers\r
757 - Applied Marc-Andre's patch fixing MR-133\r
758   "TestSupport not working under Mono"\r
760 - Removed PropertyBag.Clear() in Controller.cs to restore the ability to\r
761   update the PropertyBag in filters.\r
763 - Applied Colin Ramsay <castleproject-devel@happyandlost.co.uk> patch making\r
764   the _selectedViewName field accessible through a public property.\r
766 - Checked in changes to better support ASP.NET Views\r
768 - Refactor FormHelper to use a common code to CheckboxList and Select. \r
769   Added support mentioned in MR-130\r
771 - Introduced CreateCheckboxList. See preliminary documentation at \r
772     http://www.castleproject.org/index.php/MonoRail:FormHelper#CheckboxList\r
774 - Applied Colin Ramsay <castleproject-devel@happyandlost.co.uk> patch adding more\r
775   asserts to TestSupport.AbstractMRTestCase and refactored some other things\r
777 - MR-125 testsupport doesn't handle posting to smart dispatcher controller \r
778   Fixed by Andrei Shires <andrei@internetware.co.uk>\r
780 - FormHelper: Now it can fill parameters with the values from the Request.Params\r
782 - FormHelper: fixed Checkbox behavior with databinder by adding a hidden \r
783   field with the same name but carrying the 'false' value. The false value\r
784   can be overriden with a key 'falseValue' if you're working with a non-boolean\r
785   \r
786   For example\r
787   \r
788   FormHelper.CheckboxField("some.property")\r
789   \r
790   Will render\r
791   \r
792   <input type="checkbox" id="some_property" name="some.property" value="true" />\r
793   <input type="hidden" id="some_propertyH" name="some.property" value="false" />\r
796   FormHelper.CheckboxField("acceptDisclaimer", %{trueValue = 'accept', hiddenValue = 'reject'})\r
797   \r
798   Will render\r
799   \r
800   <input type="checkbox" id="acceptDisclaimer" name="acceptDisclaimer" value="accept" />\r
801   <input type="hidden" id="acceptDisclaimerH" name="acceptDisclaimer" value="reject" />\r
804 - Applied Ernst Naezer's patch to allow MR to throw a descriptive\r
805   exception message when two helpers are registered using the same key\r
807 - Added a hack to the WebFormsViewEngine to accomodate different behavior\r
808   with respect to invoking PageParser.GetCompiledInstance on ASP.NET 2.0\r
810 - Added support for defaultValue attribute to FormHelper, which specificy\r
811   what the value should be if the target evaluates to null.\r
813 - Added indexed properties support to FormHelper\r
815   When the target is an array you can\r
816   \r
817     PropertyBag.Add("roles", Roles.FindAll());\r
818     --\r
819     FormHelper.TextField("roles[0].Id")\r
820   \r
821   Which will output\r
822   \r
823     <input type="text" id="roles_0_Id" name="roles[0].Id" value="1" />\r
825   The indexed property can be nested\r
827     PropertyBag.Add("user", User.Find(1));\r
828     --\r
829     FormHelper.TextField("user.roles[0].Id")\r
831     <input type="text" id="user_roles_0_Id" name="user.roles[0].Id" value="1" />\r
833 - Added RadioField(String target, object valueToSend, [IDictionary attributes]) to FormHelper\r
835   The radio will be marked with checked="checked" if the value collected \r
836   from the target matches the valueToSend parameter\r
838 - Fixed RedirectToAction on WizardStepPage. Now it produces a correct action url.\r
840 - Changed WizardStepPage.InternalRedirectToStep to simply RedirectToStep\r
842 - Changed SmartDispatcherController.BuildMethodArguments. Now it tests if the conversion \r
843   succeeded before setting the value on the array.\r
845 - Introduced IWizardPageFactory on WindsorExtension, so a Wizard controller doesn't\r
846   need to reference the IKernel directly\r
848 - Some optimization on Redirect* methods on Controller class. Now they accept\r
849   an IDictionary as a parameter specifier (in addition to NameValueCollection).\r
850   \r
851 - Refactored ControllerDescriptorBuilder (renamed to ControllerDescriptorProvider)\r
852   to use child providers to obtain descriptor. Attributes are now descriptors builders\r
853   and that allows one to come up with custom attributes like\r
855   public class MyAttribute : Attribute, ILayoutDescriptorBuilder, IHelperDescriptorBuilder\r
856   {\r
857      public LayoutDescriptor BuildLayoutDescriptor() \r
858      {\r
859        return new LayoutDescriptor("mylayout");\r
860      }\r
862      public HelperDescriptor[] BuildHelperDescriptors()\r
863      {\r
864        return new HelperDescriptor[] { new HelperDescriptor(typeof(MyHelper)) };\r
865      }\r
866   }\r
868   Kudos to Fabio by coming up with the idea.\r
870 - ViewComponents: added subsection support\r
872   (Using nvelocity as example)\r
873   \r
874   #blockcomponent(GridComponent)\r
875     #header\r
876       <th>Name</th>\r
877     #end\r
878     \r
879     #footer\r
880       Showing record $startrecord to $total\r
881     #end\r
882     \r
883     #item\r
884       <td>$item.Name</td>\r
885     #end\r
887     #empty\r
888       <td>No records found</td>\r
889     #end\r
890   #end\r
891   \r
892   On the code you can use\r
894         public override bool SupportsSection(String name)\r
895         {\r
896                 return name == "header" || name == "item" || name == "footer" || \r
897                         name == "empty";\r
898         }\r
900         public override void Render()\r
901         {\r
902                 ICollection source = (ICollection) ComponentParams["source"];\r
904                 StartTable();\r
906                 Context.RenderSection("header");\r
908                 if (source != null && source.Count != 0)\r
909                 {\r
910                         foreach(object item in source)\r
911                         {\r
912                                 PropertyBag["item"] = item;\r
913                                 \r
914                                 RenderText("<tr>");\r
915                                 \r
916                                 Context.RenderSection("item");\r
917                                 \r
918                                 RenderText("</tr>");\r
919                         }\r
920                 }\r
921                 else\r
922                 {\r
923                         RenderText("<tr>");\r
924                         Context.RenderSection("empty");\r
925                         RenderText("</tr>");\r
926                 }\r
928                 Context.RenderSection("footer");\r
930                 EndTable();\r
931         }\r
933 - ViewComponent on NVelocity: added to support to interpolation on component parameters. \r
935   Action:\r
936   \r
937     public void List()\r
938     {\r
939       PropertyBag.Add("customers", Customer.FindAll());\r
940     }\r
942   View:\r
944     #blockcomponent(GridComponent with "source=$customers")\r
945   \r
946     #end\r
947   \r
948   ViewComponent code:\r
949   \r
950     public override void Render()\r
951     {\r
952       IList items = (IList) ComponentParams["source"];\r
953     \r
954       foreach(object item in items)\r
955       {\r
956         Context.ContextVars["item"] = item;\r
957         // Do something like rendering the body\r
958       }\r
959     }\r
961 - Configuration changed:\r
963   . Added <cacheprovider> node\r
964   . Added <additionalSources> node under <viewEngine>\r
966   Example:\r
967   \r
968   <monoRail>\r
969     <cacheProvider type="my custom implementation"/>\r
970     \r
971     <viewEngine viewPathRoot="views" customEngine="Castle.MonoRail.Framework.Views.NVelocity.NVelocityViewEngine, Castle.MonoRail.Framework.Views.NVelocity">\r
972       <additionalSources>\r
973         <assembly name="MyAssembly" namespace="My.Assembly" />\r
974       </additionalSources>\r
975     </viewEngine>\r
976   </monoRail>\r
978 - IViewEngine refactored to use the IViewSourceLoader to locate views\r
980 - Introduced IViewSourceLoader and IViewSource. The former represents an approach to load\r
981   views. The default implementation is FileAssemblyViewSourceLoader which first look ups \r
982   the file system then the configured assemblies for the specified view\r
984 - ICacheProvider service introduced (available on IServiceProvider implementation).\r
985   Two implementations available: \r
986   \r
987   . DefaultCacheProvider which uses the HttpContext.Cache\r
988   . WeakReferenceCacheProvider which uses a hashtable with WeakReferences as entries\r
990 - Warning about Nullables and SmartDispatcher arguments. The behavior has changed a\r
991   little\r
992   \r
993   . In the past, if the value for a nullable was not present, that was accepted and\r
994     the nullable was initialized with HasData=false\r
995   . Now the value mustn't be present, but the entry must be present\r
996   \r
997   For example\r
998   \r
999   Controller Action:\r
1000   \r
1001         public void Transfer(NullableDouble amount)\r
1002         {\r
1003                 ...\r
1004         }\r
1005   \r
1006   If you invoke it with Controller/Transfer.rails you'll get an exception\r
1007   \r
1008   If you invoke it with Controller/Transfer.rails?amount= then it's ok\r
1010   If you invoke it with Controller/Transfer.rails?amount=10 is obviously ok too.\r
1012 - Removed Obsolete members of ExecuteEnum. If you were using\r
1014   . ExecuteEnum.Before, change to ExecuteEnum.BeforeAction\r
1015   . ExecuteEnum.After, change to ExecuteEnum.AfterAction or ExecuteEnum.AfterRendering\r
1016   . ExecuteEnum.Around, change to ExecuteEnum.Always or combine the flags\r
1018 - Refactored DefaultRailsEngineContext and EngineContextModule. Now EngineContextModule\r
1019   is also a ServiceContainer. When a DefaultRailsEngineContext is created we pass\r
1020   the EngineContextModule as a parent container. \r
1021   \r
1022   This saves us some cycles of registering\r
1023   the services on every single DefaultRailsEngineContext instance.\r
1025 - Added attribute 'checkClientIsConnected' to monoRail configuration check. If \r
1026   'true' the controller class will always check IsClientConnected on\r
1027   \r
1028   - InternalSend (beginning)\r
1029   - Before Staring filter process \r
1030   - Before invoking the view engine\r
1031   \r
1032   The default value is 'false'\r
1033   \r
1034   (kudos to Ahmed)\r
1036 - Removed AutoLoadUnlessKeyIs and NullIfKeyIs from ARDataBinder. Added enum \r
1037   AutoLoadBehavior to replace them:\r
1039   AutoLoadBehavior.Never (default): Means that no autoload should be perform on the target\r
1040     type nor on nested types.\r
1041       \r
1042   AutoLoadBehavior.Always: Means that autoload should be used for the target type\r
1043     and the nested types (if present). This demands that the primary key be present on the http request\r
1044   \r
1045   AutoLoadBehavior.NewInstanceIfInvalidKey: Means that we should autoload, but if the key is \r
1046     invalid, like null, 0 or an empty string, then just create a new instance of the target type.\r
1047   \r
1048   AutoLoadBehavior.NullIfInvalidKey: Means that we should autoload, but if the key is \r
1049     invalid, like null, 0 or an empty string, then just return null\r
1051 - Added support for AccessibleThrough(Verb.Post, or Verb.Get) to restrict the type of access a controller action requires.\r
1053 - Added suport for InPlaceRenderView for Brail\r
1055 - Added <? ?> tags for Brail, to match the php style.\r
1057 - Added RemoveCookie() method to IResponse\r
1059 - Fixed a bug in Brail's ViewComponents, where a parameter was search using case sensitive search.\r
1061 - 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
1063 - Updated boo binaries, should fix the problems with the build on machines with only one framework installed.\r
1065 - Fixed a bug in Brail where a new line was required before a method call was recognized\r
1067 - Added support for optional parameters in Brail, using the syntax ?foo will return null if the value was not set (instead of throwing.)\r
1069 - Fixed a bug where Brail would throw on Empty Views.\r
1071 - Added support for AutoLoadUnlessKeyIs in ARDataBinder - will load the object unless the key is a specific value\r
1072  Usages: public void Save([ARDataBinder(AutoLoadUnlessKeyIs=0)] User user) \r
1074 - Added checks for null id when doing data binding.\r
1076 - 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
1078 - Added support for <?brail ?> tags for Brail, so it can be valid XML documents\r
1080 - Added logging for Brail, so you can see the Boo code the preprocessor is generating.\r
1082 - Added more verbose output to compiler errors in Brail.\r
1084 - 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
1086 - Fixed a bug with Brail not picking up changes that occured by VS.Net\r
1088 - 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
1090 - MonoRail is now CLSCompliant (kudos to Roelof Blom <roelof.blom@gmail.com>)\r
1092 - Breaking change: now MonoRail requires that you add the following module to web.config:\r
1094         <system.web>\r
1095                 <httpModules>\r
1096                         <add name="monorail" type="Castle.MonoRail.Framework.EngineContextModule, Castle.MonoRail.Framework" />\r
1097                 </httpModules>\r
1098         </system.web>\r
1100 - Configuration nodes and attributes changes:\r
1101   - mailto to mailTo \r
1102   - mailfrom to mailFrom\r
1103   - customsession to customSession\r
1105 - SmartViewComponent removed\r
1107 - DataBinder refactored out. Now implementation lies on Castle.Components.Binder\r
1108   + Big performance improvement\r
1110 - ARDataBinder now issues a FindByPK for nested objects if the keys differs (existing object with \r
1111   form fields)\r
1113 - SmartDispatcherController: now there's no hardcode reference to DataBind, ARDataBind or ARFetch attributes. \r
1114   They only must implement the interface IParameterBinding. This opens an interesting extension point\r
1115   for users willing to create their own logic to binding form/querystring parameters to their data components\r
1117 - Controller: Added RedirectToAction(String action, params String[] queryStringParameters)\r
1118   example:  RedirectToAction("edit", "id=" + id, "error=couldn't update the row");\r
1120 - Added FlashBinderAttribute (being evaluated)\r
1122 - Added FormHelper (being evaluated)\r
1124 - Added CaptureFor component\r
1126 - Renamed ARPager splitted into ARPaginationHelper and ARPager\r
1128 - ARDataBinder is now able to deal with HasAndBelongsToMany relations. \r
1129   This works in two ways. Suppose you have a Product class with a relation HasAndBelongsToMany to Category.\r
1130   \r
1131   If you send the following fields from a form:\r
1132     \r
1133     product.categories.id=1 \r
1134     product.categories.id=2\r
1135     \r
1136   ARDataBinder will ignore the AutoLoad property and always populate the Categories \r
1137   collection on the product class with the result of FindByPrimaryKey of the categories.\r
1138   Any other field will be ignored, for example product.categories.name will not be bound\r
1139   \r
1140   However, if you send the values like\r
1141   \r
1142     product.categories[0].id=1 \r
1143     product.categories[1].id=2\r
1144     \r
1145   Then ARDataBinder will use the usual path, not ignoring the AutoLoad.\r
1146   \r
1147   This behavior is being evaluated.\r
1149 - Removed AbstractExtension\r
1151 - Extension now uses events (See ExtensionManager)\r
1153 - Interface IMonoRailExtension changed (has only Init method now)\r
1155 - Refactored IParameterBinder in order to make it participate on calculations points.\r
1157 - Introduced WindsorMonoRailSectionHandler which has the support for statements similar to those supported\r
1158   by windsor's XmlInterpreter\r
1159   \r
1160 - Added ARDataBindAttribute.NullWhenPrimaryKey which forces the databinder to\r
1161   ignore and do not load a record if the retrieved PK has the value assigned to this\r
1162   property (kudos to Roelof Blom <roelof.blom@gmail.com>)\r
1164 Beta 5\r
1165 ======\r
1167 ** Core ** \r
1169 - Fixed Flash (it now persists the new entries between requests)  (by Ahmed)\r
1171 - Added FilterAttribute.ExecutionOrder, the default value is Int32.MaxValue \r
1172   so the less the value higher will be the filter priority\r
1174 - Added Controller.RedirectToAction(String actionName)\r
1176 - Added Controller.RedirectToAction overloads (by Fabio Batista)\r
1178 - Controller.Redirect(String) is now virtual, and it's called by all Redirect* methods (by Fabio Batista)\r
1180 - Moved action collection to ControllerMetaDescriptor class, using new method that does not require ScreenCommonPublicMethods.\r
1182 - Moved ControllerDescriptorBuilder creation to ProcessEngineFactory to ensure ControllerDescriptors are only created once\r
1184 - ITrace and Trace property added to IRailsEngineContext (kudos to Chad Humphries)\r
1186 - Hierarchy of areas support (kudos to Fabio Batista)\r
1188 - Support for [Layout] attribute on Actions, so actions can override \r
1189   the Controller's specified layout (by Fabio Batista, rev 1459)\r
1191 - PaginationHelper introduced: paginates objects that implements IList, and supports caching.\r
1193 - ARPager introduced: allows you to specify a custom NHibernate HQL Query or an NHibernate Criteria\r
1194   (using Expression.Eq, à là ActiveRecord's FindAll()) and fetch the results with pagination.\r
1195   (by Fabio Batista)\r
1197 - Added IServerUtility.JavaScriptEscape() (kudos to Chad Humphries)\r
1199 - Added DataBindAttribute.Exclude - A comma separated list of property names \r
1200   to exclude from databinding (kudos to Chad Humphries)\r
1202 - Added IResponse.BinaryWrite() and CreateCookie( HttpCookie ) overload\r
1204 - Added IServerUtility.MapPath()\r
1206 - Added IRailsContext.ApplicationPhysicalPath\r
1208 - Added to HtmlHelper:\r
1209   - InputCheckbox\r
1210   - InputRadio\r
1211   - InputFile\r
1212   - InputButton\r
1213   - Form(action, attribtes) overload\r
1215 - Added more fine-grained support for ExecuteEnum in Filters (by Fabio Batista, rev 1286-1287)\r
1217     The values are now: BeforeAction, AfterAction, AfterRendering and Always.\r
1218   \r
1219 - Support for nullable types in SmartDispatcherController, useful for\r
1220   detecting missing ValueType parameters. Works with Nullables library, still\r
1221   not working on .NET 2.0 Nullables (by Fabio Batista, rev 1297 and 1363)\r
1223   Example of use:\r
1225     // .NET 1.1\r
1226     public void CreateTicket(string name, NullableDateTime date, NullableInt32 priority)\r
1227     {\r
1228       if (name == null || name.Length == 0) throw new MissingFieldException();\r
1229       if (!date.HasValue) throw new MissingFieldException();\r
1230       if (!priority.HasValue) throw new MissingFieldException();\r
1231     }\r
1233     // .NET 2.0 (NOT WORKING YET)\r
1234     public void CreateTicket(string name, DateTime? date, int? priority)\r
1235     {\r
1236       if (name == null || name.Length == 0) throw new MissingFieldException();\r
1237       if (!date.HasValue) throw new MissingFieldException();\r
1238       if (!priority.HasValue) throw new MissingFieldException();\r
1239     }\r
1241 - Broaded support for Enums. They can be specified by number or by text (by Fabio Batista, rev 1203)\r
1243   public enum MyEnum {\r
1244     First = 1,\r
1245     Second = 2\r
1246   }\r
1247   \r
1248   <input type="hidden" name="myEnumValue" value="1" />\r
1249   <input type="hidden" name="myOtherEnumValue" value="seCoNd" />\r
1250   \r
1251   public void TestEnumValues(MyEnum myEnumValue, MyEnum myOtherEnumValue)\r
1252   {\r
1253     if (myEnumValue == MyEnum.First) // ok\r
1254     if (myOtherEnumValue == MyEnum.Second) // ok\r
1255   }\r
1257 - Support for ActiveRecord fetching in Castle.MonoRail.ActiveRecordSupport\r
1258   (by Fabio Batista, rev. 1380).\r
1259         \r
1260         Mainly for those unconfortable with direct binding of form values\r
1261         to ActiveRecord objects. This attribute only fetches the ActiveRecord based\r
1262         on its Primary Key, nothing more.\r
1263         \r
1264         Usage:\r
1265         \r
1266                 public class MyCrudExample : ARSmartDispatchController\r
1267                 {\r
1268                         // simple usage.\r
1269                         public void Save( [ARFetch] Example example, string name, ...)\r
1270                         {\r
1271                                 example.Name = name;\r
1272                                 // ...\r
1273                                 \r
1274                                 example.Save();\r
1275                         }\r
1277                         // using a different request parameter, instead of the action's parameter name\r
1278                         public void Save( [ARFetch("primaryKey")] Example example, string name, ...)\r
1279                         {\r
1280                                 example.Name = name;\r
1281                                 // ...\r
1282                                 \r
1283                                 example.Save();\r
1284                         }\r
1286                         // ignoring invalid primary keys\r
1287                         public void Save( [ARFetch(Require=false)] Example example, string name, ...)\r
1288                         {\r
1289                                 example.Name = name;\r
1290                                 // ...\r
1291                                 \r
1292                                 example.Save();\r
1293                         }\r
1295                         // not creating new records automatically, when the parameter is empty or null\r
1296                         public void Save( [ARFetch(Create=false)] Example example, string name, ...)\r
1297                         {\r
1298                                 if (example == null)\r
1299                                         example = new Example(someRequiredConstructorParameter);\r
1300                                 \r
1301                                 example.Name = name;\r
1302                                 // ...\r
1303                                 \r
1304                                 example.Save();\r
1305                         }\r
1307                         // fetching a list of Active Records\r
1308                         public void Delete( [ARFetch("selected")] Example[] examples )\r
1309                         {\r
1310                                 foreach (Example example in examples)\r
1311                                         example.Delete();\r
1312                         }\r
1313                 }\r
1315 - Support for smart arrays (aside from primitives) (kudos do Ahmed)\r
1317   Quoting the explanation:\r
1318   \r
1319 Suppose you have this class:\r
1321  \r
1322 class Person\r
1324   public string Name {get;set;}\r
1326   public int Age {get;set;}\r
1329 With the following view \r
1331   <input name="Person[0].Name"   value="John">\r
1332   <input name="Person[0].Age"    value="30">\r
1333   <input name="Person[1].Name"   value="Mary">\r
1334   <input name="Person[1].Age"    value="25">\r
1336 Now you can specify the DataBinderAttribute to an array element in your controller:\r
1338 public void SavePeople( [DataBinder(Prefix=”People”)] Person[] people )\r
1340   // you should be able to access the people as an Person array\r
1342   Assert.IsTrue( people[0].Name == “John” );\r
1343   Assert.IsTrue( people[1].Name == “Mary” );\r
1346 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
1348   <input name="Person[0].Name"   value="John">\r
1349   <input name="Person[0].Age"    value="30">\r
1350   <input name="Person[0]@ignore" value="yes">\r
1351   <input name="Person[1].Name"   value="Mary">\r
1352   <input name="Person[1].Age"    value="25">\r
1354 In the previous html code, the people array in the controller will only have one element (Mary).\r
1356 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
1358 The count attribute serves as a performance optimization when your elements are keyed using sequential integers, for example:\r
1360   <input name="Person@count"   value="5">\r
1361   <input name="Person[0].Name" value="John">\r
1362   <input name="Person[1].Name" value="James">\r
1363   <input name="Person[2].Name" value="Jeff">\r
1364   <input name="Person[3].Name" value="Geoff">\r
1365   <input name="Person[4].Name" value="Jeffrey">\r
1367 ** Ajax Helper **\r
1368    \r
1369 - AjaxHelper2 renamed to AjaxHelper. The old one was renamed to AjaxHelperOld\r
1371 - Two more callbacks supported: onSuccess and onFailure. For example\r
1373   $AjaxHelper.BuildFormRemoteTag( $DictHelper.CreateDict("url=something.rails", "OnSuccess=myjavascriptfunction();", "OnFailure=otherfunction(request)" ) );\r
1374   \r
1375   Do not confuse it with 'success' and 'failure' keys, though. Those means the id of elements\r
1376   to be updated in the event of success and failure.\r
1379 ** NVelocity View Engine **\r
1381 - Added support for global macros. Every *.vm file which is placed in the Views/macros directory\r
1382   will be scanned for macros (by Fabio Batista, rev. 1374)\r
1384 ** Brail View Engine **\r
1386 - Upgraded to use Boo 0.75, should solve the problem that Brail had with breaking tests.\r
1388 ** Scaffolding support **\r
1390 - huge refactoring\r
1391 - It's now using templates\r
1394 ** Test support **\r
1396 - Introduced Castle.MonoRail.TestSupport\r
1399 ** Bug fixes **\r
1401 MR-68   PreSendView is not being invoked by NVelocityViewEngine\r
1402         http://support.castleproject.org/jira/browse/MR-68\r
1403 MR-66   DataBinder and ConvertUtils should support TypeConverters\r
1404         http://support.castleproject.org/jira/browse/MR-66\r
1405 MR-64   DataBinder.Convert should support decimal\r
1406         http://support.castleproject.org/jira/browse/MR-64\r
1407 MR-58   AbstractHelper generates invalid XHTML\r
1408         http://support.castleproject.org/jira/browse/MR-58\r
1409 MR-57   Wrong urls are crashing UrlTokenizer\r
1410         http://support.castleproject.org/jira/browse/MR-57\r
1411 MR-52   Support for real Flash feature\r
1412         http://support.castleproject.org/jira/browse/MR-52\r
1413 MR-49   Remove public properties from the list of available actions (Controller.cs)\r
1414         http://support.castleproject.org/jira/browse/MR-49\r
1415 MR-30   MR should not accept incorrect urls\r
1416         http://support.castleproject.org/jira/browse/MR-30\r
1419 Beta 4\r
1420 ======\r
1422 - Added useWindsorIntegration attribute to monoRail configuration section\r
1424 Beta 3\r
1425 ======\r
1427 - Databind\r
1428 - Initial Scaffolding support\r
1429 - Routing feature\r
1430 - Localization support\r
1431 - More helpers and improvements\r
1434 Beta 2\r
1435 ====== \r
1437 - Few bug corrections\r
1438 - Applied patch from Dru Sellers: NVelocityViewEngine adds a $siteRoot exposing the Request.ApplicationPath\r