Web Log di Adrian Florea http://blogs.ugidotnet.org/adrian/Default.aspx "You know you've achieved perfection in design, not when you have nothing more to add, but when you have nothing more to take away." Antoine de Saint-Exupery it-IT Adrian Florea Subtext Version 2.6.0.0 Web Log di Adrian Florea http://blogs.ugidotnet.org/images/RSS2Image.gif http://blogs.ugidotnet.org/adrian/Default.aspx 77 60 Quiz Sharp #72 [junior] Quiz Sharp Test Sharp http://blogs.ugidotnet.org/adrian/archive/2009/05/21/quiz-sharp-72-junior.aspx <p>Il seguente snippet:</p> <p><strong>using</strong> System;<br /> <br /> <strong>interface</strong> IFoo {<br />     IFoo GetInstance();<br /> }<br /> <br /> <strong>partial class</strong> Foo : IFoo {<br />     <strong>public</strong> IFoo GetInstance() {<br />         Console.WriteLine("Ciao");<br />         <strong>return this</strong>;<br />     }<br /> }<br /> <br /> <strong>class</strong> Program {<br />     <strong>static void</strong> Main() {<br />         (<strong>new</strong> Foo()).GetInstance().GetInstance();<br />     }<br /> }</p> <p>stampa:</p> <p><strong>Ciao<br /> Ciao</strong></p> <p>a console. <em>Senza toccare lo snippet</em> ma solo aggiungendone un pezzo, dobbiamo stampare a console:</p> <p><strong>Ciao<br /> <font color="#ff0000">UGIdotNET</font><br /> Ciao</strong></p><img src="http://blogs.ugidotnet.org/adrian/aggbug/96256.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2009/05/21/quiz-sharp-72-junior.aspx Thu, 21 May 2009 11:55:14 GMT http://blogs.ugidotnet.org/adrian/archive/2009/05/21/quiz-sharp-72-junior.aspx#feedback 335 http://blogs.ugidotnet.org/adrian/comments/commentRss/96256.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/96256.aspx Corso Sql Server 2008 Express per gli insegnanti arrivati all'ONI2009 Quiz Sharp Test Sharp Varie RONUA http://blogs.ugidotnet.org/adrian/archive/2009/04/14/corso-sql-server-2008-express-per-gli-insegnanti-arrivati-alloni2009.aspx <p>Ieri e l'altro ieri ho tenuto un corso su Sql Server 2008 Express per 80 insegnanti di informatica arrivati per l'occasione delle Olimpiadi Nazionali di Informatica (ONI2009) che quest'anno sono state ospitate proprio dalla mia citta'. E' stata un'esperienza interessante e inedita perche' parlare di un argomento cosi' "real world" davanti alle migliori menti in ambito pre-universitario vi assicuro che non e' facile. Gente eccezionale, che vive di algoritmi, grafi e C++, un po' lontana purtroppo dalle problematiche dei DB. Ieri, cioe' nel secondo giorno, mi sono dovuto inventare la <a href="http://it.wikipedia.org/wiki/Successione_di_Fibonacci">successione di Fibonacci</a> fatta in SQL...</p> <p><strong>with</strong> fibonacci(f, g) <strong>as </strong>(<br />     <strong>select</strong> 0, 1<br />     <strong>union all</strong><br />     <strong>select</strong> f + g, f + g + g<br />     <strong>from</strong> fibonacci<br />     <strong>where</strong> f + g &lt; 100<br /> )<br /> <strong>select</strong> f<br /> <strong>from</strong> fibonacci<br /> <strong>union all</strong><br /> <strong>select</strong> g<br /> <strong>from</strong> fibonacci<br /> <strong>order by</strong> 1</p> <p>per tenerli svegli ;-) Hanno ricevuto con interesse il compito a casa di risolvere il <a href="http://it.wikipedia.org/wiki/Rompicapo_delle_otto_regine">rompicapo delle otto regine</a> sempre via <a href="http://msdn.microsoft.com/en-us/library/ms190766.aspx">CTE</a> :-) Molto gradito e' stato anche l'argomento sul nuovo tipo <a href="http://technet.microsoft.com/en-us/library/bb677290.aspx">hierarchyid</a> perche' abbastanza vicino al loro lavoro (algoritmi, alberi, etc.). Li sono piaciuti anche i nuovi tipi <em>geography</em> e <em>geometry</em> e l'integrazione del motore con .NET, poi il lavoro con XML, etc. In ogni caso e' stato un corso abbastanza atipico, preparato in un solo sabato, dalle 2 di notte in poi, con la soddisfazione di aver conosciuto di persona quelli che preparano le nuove generazioni di informatici rumeni.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/95948.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2009/04/14/corso-sql-server-2008-express-per-gli-insegnanti-arrivati-alloni2009.aspx Tue, 14 Apr 2009 19:36:52 GMT http://blogs.ugidotnet.org/adrian/archive/2009/04/14/corso-sql-server-2008-express-per-gli-insegnanti-arrivati-alloni2009.aspx#feedback 313 http://blogs.ugidotnet.org/adrian/comments/commentRss/95948.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/95948.aspx MVC versus Document/View in MFC Un po' di storia Pattern Dappertutto GUISA http://blogs.ugidotnet.org/adrian/archive/2009/04/03/mvc-versus-documentview-in-mfc.aspx <p>Sto leggendo il bellissimo libro di <a href="http://blogs.ugidotnet.org/dinoes/">Dino</a> &amp; <a href="http://blogs.ugidotnet.org/pape/">Andrea</a>, "<a href="http://www.amazon.com/Microsoft%C2%AE-NET-Architecting-Applications-PRO-Developer/dp/073562609X/">Microsoft .NET: Architecting Applications for the Enterprise</a>" e mi ha incuriosito questa loro osservazione alla pagina 362: "[...] <em>Microsoft Foundation Classes (MFC) offered more than a decade ago an architecture with some points in common with MVC - particularly, the Document/View (DV) model. DV can be seen as a version of MVC where the view and controller are fused together. </em><strong>We really don't know whether the MFC team intentionally discarded MVC to embrace DV</strong><em>; our feeling, however, is that DV blossomed autonomously during the design by simply applying correctly and diffusely the SoC principle</em>".</p> <p><a href="http://www2.roguewave.com/support/developer/WinResources/mvc.cfm">Sembra</a> che alla PDC del 1995, un membro del team di MFC abbia raccontato proprio la storia del "<em>MVC versus DV</em>" nella scelta architetturale di MFC: "[...] <em>for the controller’s message mapping mechanism, can’t we just reuse MFC’s message map solution? Ideally, yes. But there is one big problem here... A separate controller class for message handlers may sound like a good idea, but MFC was designed in such a way that this was thought impossible. MFC allows commands such as menu picks to be rerouted to non-windows, but not windows messages such as mouse clicks. In MFC, only a CWnd can receive windows messages and only one instance of a CWnd can receive the messages for a real Windows window. Since a controller is meant to be a non-window that can handle windows messages and exist in multiple instances per window, we seem to be stuck! An interesting aside, this problem was sited by an original MFC team member as </em><strong>the main reason Microsoft emulated MVC for the CDocument and CView, but stopped short of implementing a controller</strong><em> (MFC Professional Developers Conference, 1995)</em>". Interessante...</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/95872.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2009/04/03/mvc-versus-documentview-in-mfc.aspx Fri, 03 Apr 2009 22:18:48 GMT http://blogs.ugidotnet.org/adrian/archive/2009/04/03/mvc-versus-documentview-in-mfc.aspx#feedback 271 http://blogs.ugidotnet.org/adrian/comments/commentRss/95872.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/95872.aspx Vita da service pack Carillon .NET Varie Bugs? http://blogs.ugidotnet.org/adrian/archive/2009/03/26/vita-da-service-pack.aspx <p>Ho scoperto una cosa a mio parere strana: un metodo (<a href="http://msdn.microsoft.com/en-us/library/cc491445.aspx">System.Web.UI.WebControls.ParameterCollection.Add(String, DbType, String)</a>) che esiste solo nelle versioni service pack del framework .NET (2.0 SP2, 3.0 SP2, 3.5 SP1) ma non nelle versioni "normali". Mi chiedo come mai se il metodo e' stato introdotto in .NET 2.0 SP2, l'abbiano tolto dalle .NET 3.0 e .NET 3.0 SP1 per reintrodurlo nella .NET 3.0 SP2 per poi toglierlo di nuovo dalla .NET 3.5 e finalmente reintrodurlo nella .NET 3.5 SP1???...</p> <p>[OT] Per i tanti amici milanesi: sono a Milano dall'8 di marzo e torno in Romania settimana prossima, probabilmente mercoledi' - se vi fa piacere magari si organizza un pranzo o una cena!</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/95802.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2009/03/26/vita-da-service-pack.aspx Thu, 26 Mar 2009 14:40:42 GMT http://blogs.ugidotnet.org/adrian/archive/2009/03/26/vita-da-service-pack.aspx#feedback 377 http://blogs.ugidotnet.org/adrian/comments/commentRss/95802.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/95802.aspx Sul cast del foreach Carillon .NET http://blogs.ugidotnet.org/adrian/archive/2009/01/14/sul-cast-del-foreach.aspx <p>Nel suo post di ieri, "<a href="http://blogs.ugidotnet.org/luKa/archive/2009/01/13/foreach-linsidioso.aspx">foreach l'insidioso</a>", Luca si e' chiesto come mai il seguente snippet:</p> <p><strong>using</strong> System.Collections.Generic;<br /> <br /> <strong>interface</strong> IPersistent { }<br /> <strong>class</strong> Invoice : IPersistent { }<br /> <strong>class</strong> Order : IPersistent { }<br /> <br /> <strong>class</strong> Program {<br />     <strong>static void</strong> Main() {<br />         List&lt;IPersistent&gt; changedDocuments = <strong>new</strong> List&lt;IPersistent&gt;();<br />         changedDocuments.Add(<strong>new</strong> Invoice());<br />         changedDocuments.Add(<strong>new</strong> Order());<br />         <strong>foreach</strong> (Invoice changedInvoice <strong>in</strong> changedDocuments) { }<br />     }<br /> }</p> <p>compili. Secondo me, il comportamento del compilatore e' giusto, voluto e documentato. Le specifiche del linguaggio (<strong>15.8.4</strong>, <a href="http://www.ecma-international.org/publications/standards/Ecma-334.htm">ECMA-334</a>), dicono:</p> <p>"A foreach statement of the form</p> <p><strong>foreach</strong>(V v <strong>in</strong> x) <em>embedded-statement</em></p> <p>is then expanded to:</p> <p>{<br />     E e = ((C)(x)).GetEnumerator();<br />     <strong>try</strong> {<br />         V v;<br />         <strong>while</strong> (e.MoveNext()) {<br />             v = (V)(T)e.Current;<br />             <em>embedded-statement</em><br />         }<br />     }<br />     <strong>finally</strong> {<br />         … // Dispose e<br />     }<br /> }</p> <p>The variable e is not visible to or accessible to the expression x or the embedded statement or any other source code of the program. The variable v is read-only in the embedded statement. <font color="#ff0000"><strong>If there is not an explicit conversion from T (the element type) to V (the type in the foreach statement), an error is produced and no further steps are taken</strong>.</font>"</p> <p>Quindi e' la responsabilita' del programmatore quella di assicurarsi che il cast sia valido. Potremmo volere per esempio fare un <em>foreach</em> su tutte le <em>Label</em> nella <em>ControlCollection</em> dei <em>Controls</em> di una <em>Form</em> - sara' il nostro compito quello di "filtrare" gli elementi di tipo <em>Label</em> e fare il <em>foreach</em> soltanto su questi, oppure assicurarsi che nella <em>Controls</em> ci sono solo <em>Label</em>. Perche' il compilatore non ci aiuta? Probabilmente perche' la lista potrebbe essere costruita anche altrove!</p> <p>In ogni caso, se cerchiamo un aiuto da parte dell'intellisense e del compilatore, possiamo sostituire il <em>foreach</em> nello snippet di Luca, con:</p> <p>changedDocuments.ForEach(<strong>delegate</strong>(IPersistent persistent) { });</p> <p>Sorprendemente, otteniamo anche un codice IL piu' piccolo rispetto alla variante con <em>foreach</em>. Il type parameter dell'argomento action del metodo <em>ForEach</em>, e' vincolato ora ad essere identico al type parameter della nostra <em>List</em>, cioe' <em>IPersistent</em>.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/95195.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2009/01/14/sul-cast-del-foreach.aspx Wed, 14 Jan 2009 11:11:13 GMT http://blogs.ugidotnet.org/adrian/archive/2009/01/14/sul-cast-del-foreach.aspx#feedback 96 http://blogs.ugidotnet.org/adrian/comments/commentRss/95195.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/95195.aspx 3rd Italian MDA Forum Adrian GUISA VSX http://blogs.ugidotnet.org/adrian/archive/2008/11/21/3rd-italian-mda-forum.aspx <p>Salire sul <a href="http://mdaforum.soluta.net/agenda.aspx">palco</a> a parlare di DSL Tools subito dopo <a href="http://www.omg.org/~soley/">Richard Mark Soley</a>, <a href="http://www.stephenmellor.com/">Stephen J. Mellor</a> e <a href="http://www.cutter.com/meet-our-experts/rosenm.html">Michael Rosen</a>, giuro che non e' stato facile :) Ottima l'organizzazione dell'evento, nel cinquecentesco <a href="http://www.hotelpalazzostelline.it/">Palazzo delle Stelline</a>, tante discussioni interessantissime sull'MDA, modellizzazione e generazione di codice. Giornata davvero speciale!</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/94728.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/11/21/3rd-italian-mda-forum.aspx Fri, 21 Nov 2008 11:15:24 GMT http://blogs.ugidotnet.org/adrian/archive/2008/11/21/3rd-italian-mda-forum.aspx#feedback 411 http://blogs.ugidotnet.org/adrian/comments/commentRss/94728.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/94728.aspx Quando C# e' piuttosto l'eccezione che la regola Quiz Sharp Carillon .NET Bugs? http://blogs.ugidotnet.org/adrian/archive/2008/11/10/quando-c-e-piuttosto-leccezione-che-la-regola.aspx <p>Il comportamento del compilatore C#, presentato prima <a href="http://blogs.ugidotnet.org/WamBlog/archive/2008/11/01/c-uno-strano-comportamento-con-loverride.aspx">qui</a> da Diego e poi nel mio <a href="http://blogs.ugidotnet.org/adrian/archive/2008/11/09/quiz-sharp-71-overrideoverload.aspx">post precedente</a>, sembra singolare tra gli altri compilatori piu' conosciuti .NET. Il seguente snippet C# entra in stack overflow:</p> <p><strong>using</strong> System;<br /> <br /> <strong>class</strong> Foo {<br />     <strong>public virtual void</strong> Write(<strong>string</strong> s) {<br />         Console.WriteLine("Foo virtual " + s);<br />     }<br /> }<br /> <br /> <strong>class</strong> Bar : Foo {<br />     <strong>public override void</strong> Write(<strong>string</strong> s) {<br />         Console.WriteLine("Bar override " + s);<br />     }<br /> <br />     <strong>public void</strong> Write(<strong>string</strong> s, <strong>params string</strong>[] args) {<br />         Write("Bar overload " + s);<br />     }<br /> }<br /> <br /> <strong>class</strong> Program {<br />     <strong>static void</strong> Main() {<br />         Bar bar = <strong>new</strong> Bar();<br />         bar.Write("Ciao!"); // <font color="#ff0000">Process is terminated due to StackOverflowException</font><br />     }<br /> }</p> <p>mentre per gli altri linguaggi, stampa <em>Bar override Ciao!</em> Di seguito il codice equivalente in Visual Basic .NET, C++/CLI e Visual J#</p> <p><strong>Imports</strong> System<br /> <br /> <strong>Class</strong> Foo<br />     <strong>Public Overridable Sub</strong> Write(<strong>ByVal</strong> s <strong>As String</strong>)<br />         Console.WriteLine("Foo virtual " + s)<br />     <strong>End Sub<br /> End Class<br /> <br /> Class</strong> Bar : <strong>Inherits</strong> Foo<br />     <strong>Public Overrides Sub</strong> Write(<strong>ByVal</strong> s <strong>As String</strong>)<br />         Console.WriteLine("Bar override " + s)<br />     <strong>End Sub<br /> <br />     Public Overloads Sub</strong> Write(<strong>ByVal</strong> s <strong>As String</strong>, <strong>ParamArray</strong> args <strong>As String</strong>())<br />         Write("Bar overload " + s)<br />     <strong>End Sub<br /> End Class<br /> <br /> Module</strong> Program<br />     <strong>Sub</strong> Main<br />         <strong>Dim</strong> bar <strong>As</strong> Bar = <strong>New</strong> Bar<br />         bar.Write("Ciao") ' stampa <font color="#ff0000">Bar override Ciao!</font><br />     <strong>End Sub<br /> End Module</strong></p> <p><strong>using namespace</strong> System;<br /> <br /> <strong>ref class</strong> Foo {<br />     <strong>public</strong>:<br />     <strong>virtual void</strong> Write(String^ s) {<br />         Console::WriteLine("Foo virtual " + s);<br />     }<br /> };<br /> <br /> <strong>ref class</strong> Bar : Foo {<br />     <strong>public</strong>:<br />     <strong>virtual void</strong> Write(String^ s) <strong>override</strong> {<br />         Console::WriteLine("Bar override " + s);<br />     }<br /> <br />     <strong>void</strong> Write(String^ s, ... <strong>array</strong>&lt;String^&gt;^ args) {<br />         Write("Bar overload " + s);<br />     }<br /> };<br /> <br /> <strong>int</strong> main() {<br />     Bar^ bar = <strong>gcnew</strong> Bar;<br />     bar-&gt;Write("Ciao!"); // stampa <font color="#ff0000">Bar override Ciao!</font><br /> };</p> <p><strong>import</strong> System.*;<br /> <br /> <strong>class</strong> Foo {<br />     <strong>public void</strong> Write(String s) {<br />         Console.WriteLine("Foo virtual " + s);<br />     }<br /> }<br /> <br /> <strong>class</strong> Bar <strong>extends</strong> Foo {<br />     <strong>public void</strong> Write(String s) {<br />         Console.WriteLine("Bar override " + s);<br />     }<br />     <strong>public void</strong> Write(String s, /** @attribute ParamArray() */ String[] args) {<br />         Write("Bar overload " + s);<br />     }<br /> }<br /> <br /> <strong>class</strong> Program {<br />     <strong>public static void</strong> main(String[] args) {<br />         Bar bar = <strong>new</strong> Bar();<br />         bar.Write("Ciao"); // stampa <font color="#ff0000">Bar override Ciao!</font><br />     }<br /> }</p> <p>Ho sempre considerato C# come linguaggio "centrale" di .NET, una chiave per capire meglio lo spirito della piattaforma - percio' mi meraviglio quando trovo comportamenti in C# che sono piuttosto l'eccezione anziche' la regola rispetto agli altri linguaggi .NET. A voi quale comportamento sembra piu' corretto/intuitivo?</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/94595.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/11/10/quando-c-e-piuttosto-leccezione-che-la-regola.aspx Mon, 10 Nov 2008 23:46:00 GMT http://blogs.ugidotnet.org/adrian/archive/2008/11/10/quando-c-e-piuttosto-leccezione-che-la-regola.aspx#feedback 225 http://blogs.ugidotnet.org/adrian/comments/commentRss/94595.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/94595.aspx Quiz Sharp #71 [override/overload] Quiz Sharp Carillon .NET http://blogs.ugidotnet.org/adrian/archive/2008/11/09/quiz-sharp-71-overrideoverload.aspx <p><a href="http://blogs.ugidotnet.org/WamBlog/archive/2008/11/01/c-uno-strano-comportamento-con-loverride.aspx">Questo post</a> di Diego Martelli, fattomi notare da un amico, riesce secondo me a sorprendere un comportamento interessante di C#, ovvero il seguente snippet di codice entra in <em>stack overflow</em>:</p> <p><strong>using</strong> System;<br /> <br /> <strong>class</strong> Foo {<br />     <strong>public virtual void</strong> Write(<strong>string</strong> s) {<br />         Console.WriteLine("Foo virtual " + s);<br />     }<br /> }<br /> <br /> <strong>class</strong> Bar : Foo {<br />     <strong>public override void</strong> Write(<strong>string</strong> s) {<br />         Console.WriteLine("Bar override " + s);<br />     }<br /> <br />     <strong>public void</strong> Write(<strong>string</strong> s, <strong>params string</strong>[] args) {<br />         Write("Bar overload " + s);<br />     }<br /> }<br /> <br /> <strong>class</strong> Program {<br />     <strong>static void</strong> Main() {<br />         Bar bar = <strong>new</strong> Bar();<br />         bar.Write("Ciao!");<br />     }<br /> } </p> <p>Probabilmente molti si aspetterebbero che venisse stampato "<strong>Bar override Ciao!</strong>" a console e invece il metodo chiamato e' il <em>Write</em> con l'elenco variabile di parametri e non il metodo in override. Questo comportamento e' dovuto, secondo me, al fatto che abbiamo istanziato <em>bar</em> come:</p> <p>Bar bar = <strong>new</strong> Bar();</p> <p>e non come:</p> <p>Foo bar = <strong>new</strong> Bar();</p> <p>Il metodo <em>Write</em> in override nella classe <em>Bar</em> non fa altro che <em>specializzare</em> il metodo virtuale della classe base <em>Foo</em>, percio' perde nella gara dei metodi in overload della classe <em>Bar</em> perche' <em>Write</em> nella sua <em>forma espansa</em> (ECMA-334, 14.4.2.1) ha un parametro di tipo string e zero elementi nell'array di parametri.</p> <p>Detto questo, ecco il mio quiz: Cosa stampa questo snippet a console?</p> <p><strong>using</strong> System;<br /> <br /> <strong>class</strong> Foo {<br />     <strong>public override string</strong> ToString() {<br />         <strong>return</strong> "override ";<br />     }<br />     <strong>public string</strong> ToString(<strong>params string</strong>[] args) {<br />         <strong>return</strong> "overload ";<br />     }<br /> }<br /> <br /> <strong>class</strong> Program {<br />     <strong>static void</strong> Main() {<br />         Foo foo = <strong>new</strong> Foo();<br />         Console.Write(foo);<br />         Console.WriteLine(foo.ToString());<br />     }<br /> }</p> <p> </p> <ul> <li><strong>A</strong>: override override </li> <li><strong>B</strong>: override overload </li> <li><strong>C</strong>: overload overload </li> </ul> <p> </p> <p>:-)</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/94564.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/11/09/quiz-sharp-71-overrideoverload.aspx Sun, 09 Nov 2008 11:14:21 GMT http://blogs.ugidotnet.org/adrian/archive/2008/11/09/quiz-sharp-71-overrideoverload.aspx#feedback 311 http://blogs.ugidotnet.org/adrian/comments/commentRss/94564.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/94564.aspx IDisposable e le partial class Carillon .NET http://blogs.ugidotnet.org/adrian/archive/2008/10/02/idisposable-e-le-partial-class.aspx <p>Oggi, parlando con il mio collega <a href="http://danielseverin.blogspot.com/">Daniel</a>, e' uscita fuori una situazione interessante. Supponiamo che avete un tool che vi genera una classe partial che implementa IDisposable:</p> <pre>using System; <strong>partial class</strong> Foo : IDisposable { <strong>public void</strong> Dispose() { Console.WriteLine("implicit"); } }</pre> <p>Se volete cambiare il comportamento del Dispose senza toccare il codice generato sopra, basta implementare esplicitamente l'interfaccia IDisposable:</p> <pre><strong>using</strong> System; <strong>partial class</strong> Foo { <strong>void</strong> IDisposable.Dispose() { Console.WriteLine("explicit"); } }</pre> <p>A questo punto uno using(Foo foo = new Foo()){} stampera' <strong>explicit</strong> a console, anziche' <strong>implicit</strong>.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/94230.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/10/02/idisposable-e-le-partial-class.aspx Thu, 02 Oct 2008 03:23:15 GMT http://blogs.ugidotnet.org/adrian/archive/2008/10/02/idisposable-e-le-partial-class.aspx#feedback 116 http://blogs.ugidotnet.org/adrian/comments/commentRss/94230.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/94230.aspx Microsoft Community Influencer Adrian Voi RONUA http://blogs.ugidotnet.org/adrian/archive/2008/09/14/microsoft-community-influencer.aspx <p>Sono tornato ieri sera dal fantastico Microsoft Community Bootcamp dove ho avuto il grande onore di essere nominato Microsoft Community Influencer, un programma locale di Microsoft Romania con cui sono state premiate un numero quasi doppio di persone rispetto al piu' conosciuto programma MVP. La gioia del riconoscimento e quella di passare due splendide giornate in compagnia di tutti i Developer Evangelist, MVP, Community Influencer e Student Partner rumeni e' stata grande quanto la sorpresa. Insieme abbiamo messo a punto un piano per un impegno piu' efficace del nostro contributo perche' la voglia di fare si vedeva negli occhi di tutti. Ringrazio i nuovi amici per avermi ricevuto nella loro famiglia e ovviamente tutti voi per avermi insegnato in tanti anni cosa vuol dire community!</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/94027.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/09/14/microsoft-community-influencer.aspx Sun, 14 Sep 2008 19:41:54 GMT http://blogs.ugidotnet.org/adrian/archive/2008/09/14/microsoft-community-influencer.aspx#feedback 1472 http://blogs.ugidotnet.org/adrian/comments/commentRss/94027.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/94027.aspx Axioms for software architects by software architects Varie GUISA VSX RONUA http://blogs.ugidotnet.org/adrian/archive/2008/09/08/axioms-for-software-architects-by-software-architects.aspx <p>Via <a href="http://memeagora.blogspot.com/2008/08/97-things-every-software-architect.html">questo post</a> di Neal Ford sono arrivato a questo saggissimo wiki: <a href="http://97-things.near-time.net/">97 Things Every Software Architect Should Know</a>. Assolutamente da non perdere! Tre dei principi li ho gia' aggiunti alla mia <a href="http://blogs.ugidotnet.org/adrian/archive/2006/03/03/36066.aspx">collezione sulla semplicita'</a>.</p> <p>[OT]: Venerdi' organizziamo il <a href="http://ronua.ro/CS/forums/thread/206385.aspx">secondo workshop</a> dello user group locale, RONUA Galati, con due presentazioni sullo stesso difficile tema: un'introduzione a DSL Tools e un'altra a VSX. <a href="http://ronua.ro/CS/photos/23_mai_2008_--_galati_ronua_roadshow_2008/default.aspx">Guardate</a> quanta gente e' venuta al primo workshop, tenuto a maggio! Incredibile... Poi sono stato invitato a partecipare questo weekend insieme a tutti gli MVP e Microsoft Influencer rumeni alla quinta edizione di Microsoft Community Bootcamp, organizzata da Microsoft Romania in montagna, ottima opportunita' di conoscerci tutti insieme! Presto mettero' da qualche parte le slide e il codice del workshop e vi aggiornero' su come e' andata al bootcamp - scusate la parte off-topic del post...</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/93965.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/09/08/axioms-for-software-architects-by-software-architects.aspx Mon, 08 Sep 2008 05:05:17 GMT http://blogs.ugidotnet.org/adrian/archive/2008/09/08/axioms-for-software-architects-by-software-architects.aspx#feedback 27 http://blogs.ugidotnet.org/adrian/comments/commentRss/93965.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/93965.aspx How I got Started in Software Development Adrian Varie http://blogs.ugidotnet.org/adrian/archive/2008/07/15/how-i-got-started-in-software-development.aspx <p><a href="http://blogs.ugidotnet.org/rucka/archive/2008/07/15/93411.aspx">Taggato da Gianluca</a>, ecco le mie risposte:</p> <p><strong>A quale età hai cominciato a programmare?</strong></p> <p>A 17 anni, nel lontano agosto del 1985</p> <p><strong>Come hai cominciato a programmare?</strong></p> <p>A giugno di quell'anno (23 anni fa...), avevo vinto la fase provinciale di un concorso di comunicazioni scientifiche (sezione matematica) e come premio mi avevano mandato per 2-3 settimane al 1° campo nazionale di informatica in Romania, a <a href="http://en.wikipedia.org/wiki/C%C3%A2mpulung">Câmpulung Muscel</a>, dove ho avuto la fortuna di conoscere gli <a href="http://ro.wikipedia.org/wiki/Lista_autorilor_de_manuale_de_matematica">autori dei miei manuali di matematica</a>, Gheorghe Rizescu e Octavian Stănăşilă, poi <a href="http://ro.wikipedia.org/wiki/Adrian_Petrescu">Adrian Petrescu</a> che aveva <em>costruito</em> proprio il computer <a href="http://ro.wikipedia.org/wiki/AMIC">aMIC</a> su cui ci insegnarono a programmare in BASIC, poi una ragazza bionda con degli enormi occhioni verdi di cui mi innamorai perdutamente ma ebbi il corraggio di dicchiararle subito il mio impossibile amore ;) Partecipai anche i prossimi anni, '86 e '87, al 2° e al 3° campo nazionale di informatica, stavolta a <a href="http://it.wikipedia.org/wiki/T%C3%A2rgu_Mure%C5%9F">Târgu Mureş</a> dove ho approfondito le mie conoscenze di BASIC ;)</p> <p><strong>Qual’è stato il tuo primo linguaggio di programmazione?</strong></p> <p>BASIC</p> <p><strong>Qual’è stato il primo programma vero che hai scritto?</strong></p> <p>Il primo "vero" programma non ricordo ma il primo programma in assoluto non lo posso scordare: ero curioso di vedere come la funzione f(x)=(1+1/x)^x tende all'infinito verso il numero di Eulero e quindi le disegnai il grafico.</p> <p><strong>Quali linguaggi hai usato da quando hai cominciato a programmare?</strong></p> <p>In ordine temporale: BASIC, FORTRAN, Turbo Pascal, C, dBase IV, Turbo Prolog, C++, Informix NewEra, Object Tcl, Delphi, Informix AppPage, JavaScript, Informix 4GL, Java, C#, VB.NET</p> <p><strong>Quando è stato il tuo primo vero lavoro da programmatore?</strong></p> <p>Direi nel 1996 (dal '92 al '96 ho fatto piu' matematica che informatica, come ricercatore)</p> <p><strong>Con il senno di poi, rifaresti lo stesso il programmatore? Ricominceresti a programmare?</strong></p> <p>Non so, probabilmente no.</p> <p><strong>Se ci fosse una cosa che hai imparato nella tua carriera e che vorresti dire ai giovani programmatori, cosa diresti?</strong></p> <p>Leggere prima la documentazione... ;)</p> <p><strong>Qual’è la cosa più divertente che hai programmato?</strong></p> <p>type foo.cs &gt; foo.cs<br /> csc /t:library foo.cs</p> <p><strong>Adesso è l’ora di taggare qualcun’altro...</strong></p> <p><a href="http://blogs.ugidotnet.org/luKa/">Luca Minudel</a><br /> <a href="http://blogs.ugidotnet.org/rgm/">Gian Maria Ricci</a><br /> <a href="http://blogs.ugidotnet.org/dotnet4ever/">Michele Bernardi</a><br /> <a href="http://sharpreflections.wordpress.com/">Matteo Spreafico</a></p><img src="http://blogs.ugidotnet.org/adrian/aggbug/93416.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/07/15/how-i-got-started-in-software-development.aspx Tue, 15 Jul 2008 08:09:01 GMT http://blogs.ugidotnet.org/adrian/archive/2008/07/15/how-i-got-started-in-software-development.aspx#feedback 180 http://blogs.ugidotnet.org/adrian/comments/commentRss/93416.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/93416.aspx End tag required for HTML SCRIPT element Carillon .NET Varie http://blogs.ugidotnet.org/adrian/archive/2008/07/14/end-tag-required-for-html-script-element.aspx <p>Magari lo sanno tutti ma io ci ho perso mezz'ora per capire dove sta l'errore:</p> <p>&lt;script type="text/javascript" src="foo.js"<strong><font color="#ff0000">&gt;&lt;/script&gt;</font></strong></p> <p>e</p> <p>&lt;script type="text/javascript" src="foo.js" <strong><font color="#ff0000">/&gt;</font></strong></p> <p>non sono uguali! <em>Su IE il tag esplicito di chiusura</em> (la prima variante) <em>e' obbligatorio</em>, mentre Firefox accetta tutte e due le varianti...</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/93398.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/07/14/end-tag-required-for-html-script-element.aspx Mon, 14 Jul 2008 03:23:53 GMT http://blogs.ugidotnet.org/adrian/archive/2008/07/14/end-tag-required-for-html-script-element.aspx#feedback 49 http://blogs.ugidotnet.org/adrian/comments/commentRss/93398.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/93398.aspx I vostri migliori post, da oggi anche in rumeno Adrian Varie Voi GUISA RONUA http://blogs.ugidotnet.org/adrian/archive/2008/06/05/i-vostri-migliori-post-da-oggi-anche-in-rumeno.aspx <p>Oggi ho aperto il mio primo blog in rumeno, a <a href="http://ronua.ro/CS/blogs/adrianf/default.aspx">questo indirizzo</a> su RONUA. Per cominciare, ho deciso di tradurre in rumeno i post piu' interessanti che trovero' nelle varie <a href="http://www.microsoft.com/italy/communities/elenco.mspx">community italiane</a>, per far conoscere ai miei connazionali il grande spirito che ho conosciuto e mi avete regalato negli anni passati con voi. Ogni post sara' fornito ovviamente dal link al post originale, spero di avere il vostro consenso per la traduzione. E chissa', magari si stringono amicizie nuove, etc. Il blog su UGI non finisce qui, salvo completa mancanza di ispirazione :-)</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/92948.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/06/05/i-vostri-migliori-post-da-oggi-anche-in-rumeno.aspx Thu, 05 Jun 2008 23:32:14 GMT http://blogs.ugidotnet.org/adrian/archive/2008/06/05/i-vostri-migliori-post-da-oggi-anche-in-rumeno.aspx#feedback 108 http://blogs.ugidotnet.org/adrian/comments/commentRss/92948.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92948.aspx Lazy loading in una riga Pattern Dappertutto http://blogs.ugidotnet.org/adrian/archive/2008/05/28/lazy-loading-in-una-riga.aspx <p>Carino <a href="http://realfiction.net/?q=node/157">questo</a> modo proposto da <a href="http://realfiction.net/">Frank Quednau</a> di <a href="http://blogs.ugidotnet.org/Markino/archive/2006/01/05/32476.aspx">implementare il lazy loading</a> utilizzando l'operatore di null coalescing (ECMA-334, 14.12) e il fatto che <em>il risultato</em> di un'assegnazione e' il valore assegnato all'operando sinistro (ECMA-334, 14.14.1):</p> <p><strong>internal sealed class</strong> PersonProxy : Person<br /> {<br />     <strong>public override</strong> AddressCollection Addresses<br />     {<br />         <strong>get</strong><br />         {<br />             <strong>return base</strong>.Addresses ?? (<strong>base</strong>.Addresses = <strong>new</strong> PersonDataMapper().GetAddressesByCode(<strong>this</strong>.Code));<br />         }<br />         <strong>set</strong><br />         {<br />             <strong>base</strong>.Addresses = <strong>value</strong>;<br />         }<br />     }<br /> }</p> <p>A me sembra molto espressivo.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/92860.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/05/28/lazy-loading-in-una-riga.aspx Wed, 28 May 2008 23:04:38 GMT http://blogs.ugidotnet.org/adrian/archive/2008/05/28/lazy-loading-in-una-riga.aspx#feedback 108 http://blogs.ugidotnet.org/adrian/comments/commentRss/92860.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92860.aspx Quiz Sharp #70 Quiz Sharp Test Sharp http://blogs.ugidotnet.org/adrian/archive/2008/05/18/quiz-sharp-70.aspx <p>Senza utilizzare stringhe, caratteri, numeri (<em>literals</em>) o file esterni, si chiede di scrivere un programma in C# 3.0 che stampi a console la definizione compilabile di un tipo non vuoto.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/92726.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/05/18/quiz-sharp-70.aspx Sun, 18 May 2008 07:22:45 GMT http://blogs.ugidotnet.org/adrian/archive/2008/05/18/quiz-sharp-70.aspx#feedback 105 http://blogs.ugidotnet.org/adrian/comments/commentRss/92726.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92726.aspx Best practice Path.Combine Carillon .NET Pattern Dappertutto Bugs? http://blogs.ugidotnet.org/adrian/archive/2008/05/04/best-practice-path.combine.aspx <p>Se vogliamo che il nostro codice giri anche su Mono, dobbiamo utilizzare:</p> <p>Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "aaa.bbb")</p> <p>al posto di:</p> <p>AppDomain.CurrentDomain.BaseDirectory + "aaa.bbb"</p> <p>perche' su Mono, <em>BaseDirectory</em> ritorna una stringa che non finisce in <em>Path.DirectorySeparatorChar</em>, mentre su CLR si'. E questo va anche in generale, quando costruiamo il path da piu' pezzi, non solo nel caso della <em>BaseDirectory</em>. Per esempio, chi utilizza <a href="http://www.fyireporting.com/">fyiReporting RDL Project</a> su Mono, dovrebbe modificare la riga 81 nel file Runtime/RdlEngineConfig.cs nei sorgenti del progetto e ricompilare, da:</p> <p>file = dir + "RdlEngineConfig.xml";</p> <p>a:</p> <p>file = Path.Combine(dir, "RdlEngineConfig.xml");</p> <p>perche' la stringa <em>dir</em>, per come e' stata costruita, su CLR finisce in <em>Path.DirectorySeparatorChar</em>, mentre su Mono no. In <a href="http://www.amazon.com/Framework-Standard-Library-Annotated-Reference/dp/0321154894/">SLAR 1</a> alla pagina 360, <a href="http://joelmarcey.com/">Joel Marcey</a> aggiunge questa nota sulla storia del metodo <em>Combine</em>:</p> <blockquote><em>The</em> Combine <em>method had an interesting ride in the standardization process. It was originally part of the </em>Path <em>class, then removed because it was thought to be too platform-specific, then added back because it was decided it was not any more platform-specific than any of the other methods in this class.</em></blockquote><img src="http://blogs.ugidotnet.org/adrian/aggbug/92512.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/05/04/best-practice-path.combine.aspx Sun, 04 May 2008 22:44:32 GMT http://blogs.ugidotnet.org/adrian/archive/2008/05/04/best-practice-path.combine.aspx#feedback 95 http://blogs.ugidotnet.org/adrian/comments/commentRss/92512.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92512.aspx Un'API generico a provider per i metadata dei vari ORM Carillon .NET Pattern Dappertutto VSX http://blogs.ugidotnet.org/adrian/archive/2008/05/03/unapi-generico-a-provider-per-i-metadata-dei-vari-orm.aspx <p>Via <a href="http://weblogs.asp.net/fbouma/archive/2008/05/01/dynamic-data-and-3rd-party-o-r-mappers-is-a-fact.aspx">questo post</a> di <a href="http://weblogs.asp.net/fbouma/">Frans Bouma</a> ho scoperto sotto il namespace <strong>System.Web.DynamicData.ModelProviders</strong> dell'assembly <strong>System.Web.DynamicData.dll</strong> che arriva con l'ultima release della preview di <a href="http://code.msdn.microsoft.com/dynamicdata">ASP.NET Dynamic Data</a>, un'API generico composto da 4 provider per i metadata dei vari ORM (non solo Microsoft): <strong>DataModelProvider</strong>, <strong>TableProvider</strong>, <strong>ColumnProvider</strong> ed <strong>AssociationProvider</strong>. Questo unifica in buona misura le varie API che espongono i metadata degli ORM, per esempio <strong>MetaTable</strong>, <strong>MetaDataMember</strong>, <strong>MetaAssociation</strong> nel caso di LINQ to SQL, oppure quella piu' complessa dell'Entity Framework: <strong>EntitySet</strong>, <strong>EdmMember</strong>, <strong>NavigationProperty</strong>, etc. Frans ha gia' scritto un <em>model provider</em> per il suo <a href="http://www.llblgen.com/">LLBLGen Pro</a>, sarebbe bellissimo averne uno anche per <a href="http://www.nhibernate.org/">NHibernate</a>. E poi mi piacerebbe in futuro vedere questa API staccata dal ASP.NET Dynamics Data con cui non dovrebbe avere tanto in comune.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/92497.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/05/03/unapi-generico-a-provider-per-i-metadata-dei-vari-orm.aspx Sat, 03 May 2008 02:53:11 GMT http://blogs.ugidotnet.org/adrian/archive/2008/05/03/unapi-generico-a-provider-per-i-metadata-dei-vari-orm.aspx#feedback 104 http://blogs.ugidotnet.org/adrian/comments/commentRss/92497.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92497.aspx RONUA Galati Adrian Varie RONUA http://blogs.ugidotnet.org/adrian/archive/2008/04/16/92253.aspx <p>E' dall'anno scorso, da quando sono tornato a casa in Romania, che sogno la costituzione di una filiale locale dello user group rumeno di .NET, <a href="http://ronua.ro/CS/">RONUA</a>. Ed ecco che oggi, il presidente di RONUA, <a href="http://www.aurelian.ro/">Aurelian Popa</a>, mi incarica con l'organizzazione della <a href="http://ronua.ro/CS/forums/130/ShowForum.aspx">nuova community</a>. Lo spazio per gli workshop sara' messo a disposizione grazie all'entusiasmo e all'appoggio di Catalin Arama nell'attrezzatissima sala conferenze del Parco Software di Galati. Una settantina di libri personali li metto a disposizione io per creare una piccola libreria .NET (nella stanza 408 dove <a href="http://www.nexida.com/">lavoro</a> presso lo stesso Parco Software). Sto pensando che potrei trovare degli sponsor per pagare alloggio e trasporto fino in Romania se qualcuno di voi avra' voglia di tenere una sessione .NET qui in Romania, nella mia <a href="http://en.wikipedia.org/wiki/Gala%C5%A3i">citta'</a> sul Danubio, gemellata con Ancona, Brindisi, Jesi e Salerno :-) Vi terro' aggiornati sugli sviluppi della nuova community.</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/92253.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/04/16/92253.aspx Wed, 16 Apr 2008 21:49:22 GMT http://blogs.ugidotnet.org/adrian/archive/2008/04/16/92253.aspx#feedback 85 http://blogs.ugidotnet.org/adrian/comments/commentRss/92253.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92253.aspx Quiz Sharp #69 Quiz Sharp http://blogs.ugidotnet.org/adrian/archive/2008/04/08/92115.aspx Scrivete una proprieta' in cui il body del getter non contenga <strong>return</strong> o <strong>throw</strong>.<img src="http://blogs.ugidotnet.org/adrian/aggbug/92115.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/04/08/92115.aspx Tue, 08 Apr 2008 09:22:00 GMT http://blogs.ugidotnet.org/adrian/archive/2008/04/08/92115.aspx#feedback 105 http://blogs.ugidotnet.org/adrian/comments/commentRss/92115.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/92115.aspx Brian Grunkemeyer sulla storia del TypeCode e dell'interfaccia IConvertible Un po' di storia Carillon .NET http://blogs.ugidotnet.org/adrian/archive/2008/03/17/91755.aspx <p>Visto l'interesse che ha suscitato <a href="http://blogs.ugidotnet.org/adrian/archive/2008/03/12/91669.aspx">l'ultimo post</a>, ho scritto a <a href="http://blogs.msdn.com/brada">Brad Abrams</a> chiedendo conferma per la mia supposizione e dettagli sulla storia dell'interfaccia IValue, lui mi risponde subito indirizzandomi a <a href="http://blogs.msdn.com/bclteam/">Brian Grunkemeyer</a> e stamattina trovo nella mia casella email, scritto da Brian, questo splendido pezzo della storia di .NET:</p> <blockquote> <p>This is a good question. I was digging through the history of this file to see if I could figure out what happened, and it’s not clear. We’ve had this “hole” in the TypeCode enum since October of 2000, and I can’t find an older set of bits. But, I’m sure that comment in IConvertible is right – this used to be TimeSpan. For TimeSpan, it’s possible we thought it would be interesting for a while, then we realized that frankly not that many people need to convert a Decimal to a TimeSpan, then removed it.</p> <p>You might ask why we didn’t “fix” the enum when we removed whichever of these values we had originally added. It turns out that whenever we have a breaking change internally, we need to recompile all the code that might possibly depend on the removed or changed public surface area. For us, that would mean rebuilding everything that might have referred to TypeCode.String, whose value would have changed from 18 to 17. While we do go through that process internally in DevDiv, it is costly &amp; painful for us. Back then with some underdeveloped internal processes, it usually took 2 weeks, then even longer if your change requires a rebuilt compiler to be checked in as a new “safe” build of a compiler. Back in 2000, we were racing to ship as soon as possible (even though we didn’t ship for another year or two), so we wanted to limit churn like this. It’s sometimes easier to not deal with that level of churn in the product.</p> <p>For your other question about IValue, that was the original name for IConvertible. We exposed a Variant type to match OLE Automation’s VARIANT type on the native side, for COM Interop reasons. The VB team actually was thinking that Variant should be conceptually the root of their object hierarchy (at least in terms of how types were exposed in VB 7), but that seemed a little silly. Fortunately, Anders Hejlsberg convinced them to use Object instead and we’d expose IConvertible on the base data types to allow VB users to easily change from one data type to another. So we marked Variant internal &amp; we only use it in a handful of places internally for COM-related functionality.</p> </blockquote><p>Grazie ragazzi!</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/91755.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/03/17/91755.aspx Mon, 17 Mar 2008 19:24:33 GMT http://blogs.ugidotnet.org/adrian/archive/2008/03/17/91755.aspx#feedback 165 http://blogs.ugidotnet.org/adrian/comments/commentRss/91755.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/91755.aspx Sull'enum TypeCode e sull'interfaccia fantoma IValue Un po' di storia Carillon .NET http://blogs.ugidotnet.org/adrian/archive/2008/03/12/91669.aspx <p>Oggi <a href="http://blogs.ugidotnet.org/raffaele/">Raf</a> sul messenger mi chiede se conosco un modo piu' diretto per capire se un tipo sia <a href="http://msdn2.microsoft.com/en-us/library/system.type.isprimitive.aspx">primitivo</a> oppure <strong>String</strong> o <strong>DateTime</strong> (questo per evitare degli <em>if</em>...). Pensandoci un po', arrivo a questa soluzione:</p> <p><strong>(int)Type.GetTypeCode(type) &gt; 2</strong></p> <p>dove <em>type</em> e' il tipo in causa. Lui prova e mi dice che va benissimo mentre io gia' sto pensando di bloggare questa riga di codice :-) L'enum <a href="http://msdn2.microsoft.com/en-us/library/system.typecode.aspx">TypeCode</a> infatti, contiene nella sua lista di valori maggiori a 2 tutti i 12 tipi <strong>primitivi</strong> piu' il <strong>DateTime</strong> e lo <strong>String</strong>, proprio quello che voleva Raf. A questo punto gli chiedo come denominare questa categoria di tipi? Primitivi non sono, <em>built-in</em> (<a href="http://www.ecma-international.org/publications/standards/Ecma-335.htm">ECMA-335</a>, <strong>Partition I</strong>, <strong>8.2.2</strong>) nemmeno, boh... <em>fondamentali</em>? Qui Raf si ricorda che "<em>in una alpha erano refclass adesso non piu'</em>". E poi fa questa osservazione giusta:</p> <p><strong>Raffaele MVP says (4:45 PM):</strong><br /> io comunque metterei &gt;2 e &lt;18<br /> non si sa mai che aggiungano altre enum in futuro<br /> <strong>&lt;drian says (4:46 PM):</strong><br /> hai visto che manca 17?<br /> <strong>Raffaele MVP says (4:46 PM):</strong><br /> non ci ho fatto caso<br /> <strong>&lt;drian says (4:47 PM):</strong><br /> in questo caso, dovrei fare anche != 17, perche' il 17 per adesso manca<br /> e diventa un po' una schifezza<br /> <strong>Raffaele MVP says (4:48 PM):</strong><br /> a questo punto puoi legarlo ad una versione specifica di quell'assembly ma poi non funziona più automaticamente<br /> <strong>Raffaele MVP says (4:49 PM):</strong><br /> o ancora metterlo typesafe<br /> &gt;=boolean &lt;=string<br /> ma c'è sempre il 17 a rompere </p> <p>Spulciando poi i sorgenti di <a href="http://msdn.microsoft.com/net/sscli/">Rotor</a>, trovo questo commento nel file dell'interfaccia <strong>System.IConvertible</strong></p> <p><font color="#339966">// The IValue interface represents an object that contains a value. This<br /> // interface is implemented by the following types in the System namespace:<br /> // <strong>Boolean</strong>, <strong>Char</strong>, <strong>SByte</strong>, <strong>Byte</strong>, <strong>Int16</strong>, <strong>UInt16</strong>, <strong>Int32</strong>, <strong>UInt32</strong>, <strong>Int64</strong>, <strong>UInt64</strong>,<br /> // <strong>Single</strong>, <strong>Double</strong>, <strong>Decimal</strong>, <strong>DateTime</strong>, <font color="#ff0000"><strong>TimeSpan</strong></font>, and <strong>String</strong>. The interface may<br /> // be implemented by other types that are to be considered values.</font> </p> <p>Cosa notate? Esattamente l'elenco di tipi che interessava Raf, nell'ordine di <strong>TypeCode</strong> e... in piu' il <strong><font color="#ff0000">TimeSpan</font></strong> tra il <strong>DateTime</strong> = 16 e lo <strong>String</strong> = 18, cioe' corrispondente proprio al <strong><font color="#ff0000">17</font></strong> che mancava! Questa interfaccia, <strong>IValue</strong>, non esiste piu' nel framework ma alcuni commenti su varie implementazioni del metodo <strong>GetTypeCode()</strong> sono rimasti come:</p> <p><font color="#339966">// IValue implementation</font></p> <p>perche', probabilmente, conteneva questo metodo <strong>GetTypeCode</strong>. Questa ormai e' "<em>archeologia</em>" di .NET! :-) E non e' tutto. Guardate nei commenti dell'enum <strong>System.TypeCode</strong>:</p> <p><font color="#339966">// Note that when an object has a given TypeCode, there is no guarantee that<br /> // the object is an instance of the corresponding System.XXX value class. For<br /> // example, <strong>an object with the type code TypeCode.Int32 might actually be an</strong><br /> // <strong>instance of a nullable 32-bit integer type</strong></font> </p> <p>Questo comportamento non e' piu' vero, perche' il valore di <strong>Type.GetTypeCode(typeof(<font color="#ff0000">int?</font>))</strong> e' <strong>TypeCode.<font color="#ff0000">Object</font></strong>, mentre il valore di <strong>Type.GetTypeCode(typeof(int))</strong> e' <strong>TypeCode.Int32</strong>!</p> <p>Dopo una discussione tecnica con Raf, direi che sia impossibile non cliccare "<strong>New Post</strong>"! :-)</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/91669.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/03/12/91669.aspx Wed, 12 Mar 2008 06:49:00 GMT http://blogs.ugidotnet.org/adrian/archive/2008/03/12/91669.aspx#feedback 113 http://blogs.ugidotnet.org/adrian/comments/commentRss/91669.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/91669.aspx Un DSL per i mapping O/R? VSX http://blogs.ugidotnet.org/adrian/archive/2008/03/04/91491.aspx Guardando in questi giorni <a href="http://tools.hibernate.org/">Hibernate Tools</a>, mi e' piaciuta molto l'idea che sta alla base della la sua architettura: il mapping viene rappresentato da un'istanza del <em>metamodello</em> di Hibernate (classe <strong>org.hibernate.cfg.Configuration</strong> o derivate, equivalente di <strong>NHibernate.Cfg.Configuration</strong>) e da questo <em>modello</em> vengono generati i vari artefatti tramite cosiddetti <em>exporter</em> (per esempio <strong>hbm2java</strong>, <strong>hbm2ddl</strong>, <strong>hbm2hbmxml</strong>, etc), che non sono altro che classi che derivano da <strong>org.hibernate.tool.hbm2x.GenericExporter</strong> e che, insieme a dei template FreeMarker, definiscono in modo straordinariamente flessibile la parte di generazione codice/artefatti. Quindi, al posto della <strong>PO<font color="#ff0000">J</font>OExporter</strong> potremmo avere, perche' no, anche una <strong>PO<font color="#ff0000">C</font>OExporter</strong> per il domain model C#. Sarebbe interessante replicare in NHibernate un'infrastruttura simile, soprattutto adesso quando <a href="http://blogs.msdn.com/garethj/archive/2008/01/31/fun-use-of-t4-to-generate-strongly-typed-web-navigation.aspx">la parte di generazione codice via template T4 si trova gia' inclusa in VS2008</a>. E poi, se tutto questo viene generato da un'istanza di <strong>Configuration</strong>, ci vuole solo un passo per creare un DSL grafico (con l'immenso aiuto di <a href="http://msdn2.microsoft.com/en-us/library/bb126235.aspx">DSL Tools</a>) che rappresenti il mapping (N)Hibernate. E un po' quello che hanno fatto in Java con, per esempio, <a href="http://www.exadel.com/exadelstudio/help/#orm2">Exadel Studio Pro</a>, diventato adesso parte di <a href="http://www.jboss.com/products/devstudio">Jboss Developer Studio</a>. Ma poi, i concetti di mapping sono quasi independenti dagli engine e quindi, perche' non pensare a un tool visuale capace di risolvere la parte mapping per piu' ORM?<img src="http://blogs.ugidotnet.org/adrian/aggbug/91491.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/03/04/91491.aspx Tue, 04 Mar 2008 00:50:22 GMT http://blogs.ugidotnet.org/adrian/archive/2008/03/04/91491.aspx#feedback 111 http://blogs.ugidotnet.org/adrian/comments/commentRss/91491.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/91491.aspx L'OR Designer e' stato scritto con DSL Tools Carillon .NET VSX http://blogs.ugidotnet.org/adrian/archive/2008/01/21/90790.aspx Lo sapevate che l'Object Relational Designer e la parte di generazione di codice per le classi LINQ to SQL in VS2008 sono state scritte utilizzando <a href="http://www.microsoft.com/vstudio/dsltools">Microsoft DSL Tools</a> che fa parte di <a href="http://www.microsoft.com/downloads/details.aspx?familyid=51A5C65B-C020-4E08-8AC0-3EB9C06996F4&amp;displaylang=en">VS SDK</a>? - l'ho scoperto tramite il Reflector mentre <a href="http://www.domainspecificdevelopment.com/">studiavo</a> l'API di questo potentissimo framework che e' DSL Tools: tra le classi che derivano da <strong>Microsoft.VisualStudio.Modeling.ModelElement</strong>, classe fondamentale per la rappresentazione degli elementi di un domain model, si trovano anche le classi internal dell'OR Designer. Questo dovrebbe dare piu' fiduccia a chi inizia o valuta di <a href="http://msdn.com/vsx">estendere Visual Studio</a> per un certo DSL utilizzando DSL Tools! - parti complesse del VS stesso iniziano ad essere sviluppate con questo framework.<img src="http://blogs.ugidotnet.org/adrian/aggbug/90790.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2008/01/21/90790.aspx Mon, 21 Jan 2008 03:29:06 GMT http://blogs.ugidotnet.org/adrian/archive/2008/01/21/90790.aspx#feedback 225 http://blogs.ugidotnet.org/adrian/comments/commentRss/90790.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/90790.aspx code and solutions (and a resume) Quiz Sharp Adrian http://blogs.ugidotnet.org/adrian/archive/2007/12/11/90219.aspx <p>Via <a href="http://infoarena.ro/blog/olimpicul-de-la-facebook">questo post</a> del mio connazionale <a href="http://infoarena.ro/blog">Cosmin Negruseri</a>, sono venuto a conoscenza di questa idea tanto bella quanto semplice ed efficace: proprio nella <a href="http://www.facebook.com/jobs/index.php">pagina Jobs</a> di Facebook c'e' una <a href="http://www.facebook.com/jobs_puzzles/">sezione di programming puzzles</a> belli tosti, provateli per credere. Ogni problema finisce coll'invito:</p> <blockquote>Please send your code and solutions (and a resume) to { (0xFACEB00C &gt;&gt; 2) in decimal format } @ facebook.com</blockquote> <p>Notate "<em>and a resume</em>" messo tra parentesi, per non dire dell'indirizzo email veramente originale ;) Complimenti!</p> <p>(Oggi faccio gli 'anta ;) Non si scherza piu'!)</p><img src="http://blogs.ugidotnet.org/adrian/aggbug/90219.aspx" width="1" height="1" /> Adrian Florea http://blogs.ugidotnet.org/adrian/archive/2007/12/11/90219.aspx Tue, 11 Dec 2007 02:38:41 GMT http://blogs.ugidotnet.org/adrian/archive/2007/12/11/90219.aspx#feedback 272 http://blogs.ugidotnet.org/adrian/comments/commentRss/90219.aspx http://blogs.ugidotnet.org/adrian/services/trackbacks/90219.aspx