September 2003 Blog Posts

"ClickOnce" segnatevi questo nome...

Sara' una delle nuove interessanti features di Whidbey... ;-)Volete saperne di piu? click here...  

posted @ Tuesday, September 30, 2003 11:39 PM | Feedback (5)

Chat con il team di VB.NET

Questa sera alle 22 c'e' stata una chat con il team di VB.NET, tra questi Amanda Silver e Paul Vick (PM di VB.NET) ecco alcune parti interessanti (a breve ci sara' comunque tutto il transcript online) PaulV_MS : Q: Are we going to get anonymous methods support as well in vb.net? PaulV_MS : A: Not in this release. It's a very interesting feature that we looked at, but it wasn't a high enough priority when matched against the other stuff we're doing this time. Definitely something we're going to keep our eye on. Amanda_MS : Q: In the future, are we going to...

posted @ Tuesday, September 30, 2003 11:11 PM | Feedback (0)

Libreria per porta parallela

Visto che e' un problema 'sentito' segnalo un interessante libreria per gestire la porta parallela da WIN 98, NT, 2000 and XP attraverso PInvoke

posted @ Saturday, September 27, 2003 10:02 AM | Feedback (0)

Tutto quello che avreste voluto sapere su NGEN...

Jason Zander del CLR Team nel suo blog descrive dettagliatamente l'utility NGEN, da non perdere!

posted @ Thursday, September 25, 2003 10:47 AM | Feedback (2)

CloneCD bloccato dalle legge Europea

"Our software was prohibited by a new European wide copyright law. The industry lobby has won and we practically have lost the rights to develop and distribute our own software which we developed for 6 years." Ecco cosa scrive Elby a proposito della decisione di non distribuire piu' il famoso programma CloneCD. Vero e' che aggiungono anche... "CloneCD will survive under a different team on Antigua (e.g. outside of European and American legislation) at slysoft.com. Registered users get support and updates from now on from slysoft. They will soon publish new versions of CloneCD." Come dire... fatta la legge....

posted @ Tuesday, September 23, 2003 10:05 PM | Feedback (0)

Verisign ci prova...

Provate ad andare su questo sito: www.kjhgdkfjsdftgius.com, non esistendo vi aspettereste il classico errore 404, invece verrete magicamente rimandati ad un nuovo progetto "SiteFinder" di Verisign.Non male come idea per attirare gente nel proprio "portale" forse pero' si e' un po' "abusato" della propria posizione e, non a caso, Verisign si e' gia' beccata una causa da 100 milioni di $$$...Se volete saperne di piu... andate qui

posted @ Sunday, September 21, 2003 7:07 PM | Feedback (0)

I have a brand new toy...

Dopo la mia prima sessione pubblica al workshop del 17 settembre (emozione!) mi son voluto rilassare con il mio nuovo "toy"...Commenti a caldo: Ottimo prodotto, veloce, legge di tutto (ho infilato la mano, mi ha letto pure quella...) firmware upgradabile...Prevedo un grande successo per questo genere di lettori...

posted @ Saturday, September 20, 2003 1:22 AM | Feedback (0)

Winsummit cancellato

Era gia' circolata la notiza... (da amici) pero' ora e' ufficiale, a causa di problemi legati alla societa' organizzatrice DIGICOMP il WinSummit 2003 e' stato cancellato, peccato, i nomi presenti erano sicuramente interessanti...

posted @ Thursday, September 18, 2003 1:29 AM | Feedback (0)

Visual Studio 6 Service Pack 6

A quanto pare il vecchio Visual Studio 6 avra' un nuovo service pack...

posted @ Tuesday, September 16, 2003 11:18 PM | Feedback (0)

Subclassing con NativeWindow

Eseguire il subclassing in NET e' diventato un gioco da ragazzi (o quasi...) basta fare l'override della WndProc e trappare i messaggi interessati, ma se volessi intercettare il messaggio WM_LBUTTONCLICK di un pulsante presente in un form?Si puo' usare la classe NativeWindow che rappresenta una finestra generica con la relativa WndProc e "associarla" alla finestra che vogliamo subclassare. Esempio: public class MySubClass : System.Windows.Forms.NativeWindow{public delegate void MsgTrap (ref System.Windows.Forms.Message m);public event MsgTrap MessageTrapped;private Int32 msgCode;public MySubClass(IntPtr handle, Int32 msgCode ){this.msgCode=msgCode;base.AssignHandle(handle); }protected override void WndProc(ref System.Windows.Forms.Message m){base.WndProc(ref m);if (m.Msg==msgCode) {  MessageTrapped (ref m); }}} Questa classe, che eredita da NativeWindow, genera un evento quando viene intercettato il...

posted @ Tuesday, September 16, 2003 10:11 AM | Feedback (0)

PDC 2003... I'll be there!

Yes!, saro' a PDC 2003 e prevedo parecchi blogs da L.A.... Come potevo non includere il logo 'ufficiale'?...  

posted @ Monday, September 15, 2003 11:03 PM | Feedback (4)

Must Have Utilities...

Ecco qualche utility interessante... Snippet Compiler Utility che vi permette di testare piccole parti di codice senza dovere nemmeno aprire Visual Studio http://www.sliver.com/dotnet/snippetcompiler/   ApiViewer Utility per generare la definizione di tutte le Win32 APIs in formato VB6,VB.NET e C#, include un add-in per C#disponibile anche in Italiano (richiede i runtimes di VB6) http://www.activevb.de/rubriken/apiviewer/index-apiviewereng.html   Problemi con l'installazione di MDAC? http://support.microsoft.com/default.aspx?scid=http://support.microsoft.com:80/support/kb/articles/Q307/2/55.ASP&NoWebContent=1   FileMon http://www.sysinternals.com/ntw2k/source/filemon.shtml

posted @ Sunday, September 14, 2003 10:45 AM | Feedback (0)

This humor brought to you by the Longhorn evangelism team

A quanto pare gli evangelisti hanno anche il tempo per divertirsi...

posted @ Saturday, September 13, 2003 3:22 PM | Feedback (0)

15/09/2003: Office 2003 disponibile!

Come indicato qui, Lunedì prossimo sarà possibile anche agli abbonati MSDN Universal scaricare la versione finale di Office 2003, povero server...

posted @ Friday, September 12, 2003 7:03 PM | Feedback (0)

Mi scusi..., gira su Linux?

Non contenti dei problemi legati ai vari 'gusti' di Windows, a breve dovremo anche vedercela col pinguino... :-)    

posted @ Friday, September 12, 2003 9:42 AM | Feedback (1)

Caricare versioni diverse della stessa Dll

Come fare per caricare versioni diverse e compatibili tra loro della stessa dll statica?Il costruttore dell'attributo DllImport va specificato a design time quindi non possiamo modificarlo durante l'esecuzione del programma.Fortunatamente il CLR carica la Dll da disco solo se non gia' presente in memoria percio' se utilizziamo l'API LoadLibrary() possiamo decidere il percorso dove si trova la dll. Esempio: [DllImport("kernel32.dll")] static extern IntPtr LoadLibrary(string filename);[DllImport("mydll.dll")] static extern bool MyMessageBeep(Int32 uType); IntPtr i=IntPtr.Zero;if (b){IntPtr i=LoadLibrary("C:\\path1\\mydll.dll");}else{IntPtr i=LoadLibrary("C:\\path2\\mydll.dll");}MyMessageBeep(0x40); In questo caso a seconda del flag b, la funzione MessageBeep verra' invocata da una diversa dll.

posted @ Wednesday, September 10, 2003 10:55 AM | Feedback (0)

More on Smartphone SDK

Se siete interessati (oppure semplicemente curiosi) di conoscere meglio alcuni dettagli del nuovo SmartPhone SDK 2003 ecco un articolo interessante. Se avrete il piacere di 'giocarci' un po' e dovreste trovarvi di fronte a varie "NotSupportedException" non preoccupatevi e' il modo scelto dall'SDK di informarvi che quella particolare feature non rispetta i logo requirements  (es: il mainmenu di sinistra non puo' avere dei menuitems...)

posted @ Wednesday, September 10, 2003 9:18 AM | Feedback (0)

Libro su DirectX 9

Se ne e' parlato nel forum di UGI e, 'casualmente' ecco un libro sull'utilizzo di DirectX9 da applicazioni managed scritto da Tom Miller devlead del gruppo ManagedDx. Altro libro sull'argomento quello pubblicato da Alexandre Santos Lobao su APress.

posted @ Sunday, September 7, 2003 9:44 AM | Feedback (4)

SetLastError=True, ma non sempre...

Alex Komissarov mi ha contattato segnalandomi un comportamento anomalo relativo alla Marshal.GetLastWin32Error dopo che ha modificato la mia classe seguendo i dettagli del mio blog di ieri.Dopo qualche scambio di email mi ha fatto notare che la documentazione indica che usando [DllImport] il paramentro SetLastError e' di default False per C# mentre e' True per VB.NET Cito:Indicates whether the callee calls the SetLastError Win32 API function before returning from the attributed method.Remarkstrue to indicate that the callee will call SetLastError; otherwise, false. The default is false, except in Visual Basic. Alla luce di vari test fatti, siamo giunti alla conclusione che la documentazione e'...

posted @ Wednesday, September 3, 2003 3:40 PM | Feedback (0)

Gestione degli errori durante le chiamate a funzioni Win32

L'attributo [DllImport] che normalmente utilizziamo con PInvoke permette di stabilire se un eventuale errore deve essere corredato da informazioni estese che possiamo recuperare attraverso l'API GetLastError e la relativa FormatMessage per ottenere l'equivalente testuale del codice di errore.L'utilizzo della GetLastError non e' pero' corretto in quanto non e' detto (essendoci il CLR di mezzo) che non siano state chiamate altre API dopo la nostra funzione e della quale vogliamo recuperare il codice di errore.Il .NET Framework mette pero' a disposizione tutto il necessario per accedere nel modo corretto al codice di errore settato dalla nostra API attraverso la funzione Marshal.GetLastWin32Error().La funzione citata risolve pero'...

posted @ Tuesday, September 2, 2003 4:45 PM | Feedback (2)