throw; ou throw ex; in .Net

Je voulais catcher une exception pour la loger mais ensuite continuer le traitement, et je pensais quand utilisant throw ex j'allais continuer la propagation de celle-çi.

Mais en faite pas vraiment, car implicitement le framework relance un exception ce qui fait que l'on perd le contexte (Stack trace par exemple).

Donc en cherchant un peu il suffit d'utiliser throw tout court ;-)

Basically MSIL (CIL) has two instructions - "throw" and "rethrow" and guess what

  • C#'s "throw ex;" gets compiled into MSIL's "throw"
  • C#'s "throw;" into MSIL "rethrow"!

[...] So you just better know this stuff - use "throw;" to re-throw an exception in .NET.

Source : http://www.tkachenko.com/blog/archives/000352.html

Le don d'organes, faite connaître votre volonté à vos proches

 Il est primordial de faire connaître à vos proche de votre vivant votre volonté de donner vos organes pour qu'ils puissent en témoigner.

Afin de partager avec le plus grand nombre de personne votre choix concernant le don de vos organes, j'ai developpé un site qui vous permet de diffuser votre message sur Twitter et/ou HelloTipi.

Vous n'avez plus qu'as vous connecter et exprimer votre choix.

 

 

Plugin Yourls pour Seesmic Desktop 2

Je ne m'arrête plus :-)

En même temps c'est si facile ! Après le plugin AutoFF pour Seesmic Desktop 2, je me suis penché sur Yourls.
Ce script php permet d'implémenter votre propre raccourcisseur d'url, et il à le mérite d'avoir une api !
J'ai donc crée un plugin Seesmic qui vous permettra d'utiliser vos propres urls dans vos messages twitter, Facebook ou autres réseaux sociaux supporté par Seesmic Desktop 2.

Pour l’installer c’est par ici : Fichier XAP à copier dans le répertoire plugin de seesmic 

Puis aller dans les settings pour configurer votre signature (http://mondomaine.com/admin/tools.php) et l'url du script api de Yourls (http://mondomaine.com/yourls-api.php)
Ensuite regarder dans la zone « link»

(download)
N’hésité pas à laissée vos impressions / questions. 



I never stop :-)

At the same time it's so easy! After the plugin AutoFF Seesmic Desktop 2, I have studied Yourls.
This php script allows you to implement your own url shorteners, and it have an API !
So I created a Seesmic plugin that allows you to use your own urls in your posts twitter, Facebook or other social networks supported by Seesmic Desktop 2.

To install : copy this XAP file to the seesmic plugin directory

Then go into the settings to configure your signature (http://mydomain.com/admin/tools.php) and Yourls script API url (http://mydomain.com/yourls-api.php)
Then look in the area "link"

Feel free to let your impressions / questions.

Plugin HelloTipi pour Picasa


Voila un plugin qui ajoute un bouton "HelloTipi" dans Picasa, vous permettant ainsi d'envoyer vos photos sur votre site de famille.

L'avantage est de pouvoir utiliser tout les outils de retouche, d'organisation de Picasa et de mettre à jour plus simplement vos albums HelloTipi.

L'installation se trouve sur cette page

HelloTipi Photo Downloader

Après mon application WPF HelloTipi Photos Uploader voila en Silverlight HelloTipi Photos Downloader.

Cette application Silverlight à été developpé dans le cadre d'un concours lancé sur le blog de Mrboo, fondateur d'HelloTipi.

Cette application à été réalisé avec VS 2010 en C# et Silverlight 4

Pour plus d'infos et voir l'appli c'est ici.

Plugin AutoFF pour Seesmic Desktop 2

Après mon plugin HelloTipi pour Seesmic Desktop 2. Je me suis amusé à faire quelque chose de plus simple.
Encore basé sur un site de Mrboo : AutoFF.
Ce plugin vous permettras de générer automatiquement votre liste de #FF ou #FollowFriday (vous avez le choix dans les settings).

Pour l'installer c'est par ici : Fichier XAP à copier dans le répertoire plugin de seesmic Ensuite regarder dans la zone "more"

N'hésite pas à laissée vos impressions / questions.



After my plugin HelloTipi for Seesmic Hellotipi Desktop 2. I enjoyed making something more simple.
Still based on a site Mrboo : AutoFF.
This plugin will automatically generate your #FF or#FollowFriday list (you can choose in the settings).

To install copy this XAP file to the seesmic plugin directory Then look in the area "more" 

Présentation du plugin HelloTipi pour Seesmic Desktop 2 au reMIX 2010

Le 26 Mai c'est déroulé le reMIX2010 de Microsoft. A cette occasion Loïc Lemeur fesait une démonstration du petit dernier de la gamme Seesmic : Seesmic Dektop 2 entièrement developpé en Silverlight et utilisant le framework MEF.

Il se trouve que j'avais commencé à developper un plugin sur cette plateforme pour HelloTipi.
Et comme le WEB est petit, le fondateur de HelloTipi MrBoo connaissait Loïc et lui as fait part de mon plugin, Loïc à été emballé et nous as proposé de l'accompagner sur scène lors de cette conférence afin de présenter mon travail.
Je remercie donc Loïc de m'avoir permis de parler 2 minutes sur scène, quoique finalement après avoir vu la vidéo et surtout entendu ma voix... :-)

Photo souvenir : 

Loic-ptirouz-mrboo

Visual Studio 2010 RC & SilverLight 4 RC & WCF RIA Services RC

Tout est dans le titre, enfin on peut utiliser la version Visual Studio 2010 RC pour faire du RIA Services avec Silverlight 4 RC, ça a été annoncé au MIX 10 et relayé ici et  et sûrement autre part.
Au vu de cette nouvelle je m'empresse de tout télécharger et de tout installer comme expliqué dans les blog cité précédemment :

Bref récap :

1 - Désinstaller visual Studio 2010 Beta 2
2 - Désinstaller WCF ria Service si vous l'aviez déjà
3 - Installer Visual Studio 2010 RC et le framework 4.0
4 - Installer Microsoft Silverlight 4 Tools for Visual Studio 2010 RC (Dedans il y a le runtime et le sdk)
5 - Installer WCF RIA Service RC 6 - Installer WCF RIA Services Toolkit C'était la partie facile (mais longue). 

Ensuite tout content j'ouvre le projet bien entamé en Visual studio 2010 beta 2 + Silverlight 4 beta + WCF Ria Service beta, et là c'est moins drôle, ça ne compile pas, pleins d'erreurs, après un moment d'angoisse, je regarde de plus près.
Il s'avère que les noms des assembly ont changé (merci pour la blague microsoft) , plus de System.Windows.Ria et ses copines.
Je cherche donc sur le net mais rien, je regarde donc de plus près et répare les dégâts en cherchant avec l'Object Browser de Visual Studio où sont passés mes petits.
Je décide de tout noter pour peut-être aider certaines personnes dans le même cas que moi, voici donc les changements que j'ai dû effectuer pour pouvoir enfin recompiler mon projet.
Les modifications présentées ici n'ont rien d'exhaustif

Coté client (App)

3 nouvelles assembly de base sont à  ajouter au référence du projet :

C:\Program Files\Microsoft SDKs\RIA Services\v1.0\Libraries\Silverlight :
- System.ServiceModel.DomainServices.Client
- System.ServiceModel.DomainServices.Client.Web
et celle de silverlight 4 (C:\Program Files\Microsoft SDKs\Silverlight\v4.0\Libraries\Client) :
- System.ServiceModel.Web.Extensions.dll

les 2 premières sont situées là : C:\Program Files\Microsoft SDKs\RIA Services\v1.0\Libraries\Silverlight et la troisième là C:\Program Files\Microsoft SDKs\Silverlight\v4.0\Libraries\Client

  • System.ServiceModel.DomainServices.Client.dll
  • System.ServiceModel.DomainServices.Client.Web.dll
  • System.ServiceModel.Web.Extensions.dll

Ensuite vous devez remplacer les using (un petit coup de find/replace) :
"System.Windows.Ria" par "System.ServiceModel.DomainServices.Client"
"System.Windows.Ria.ApplicationServices" par "System.ServiceModel.DomainServices.Client.ApplicationServices"
Ensuite si vous avez utilisé les DomainDataSource il faut dans un premier temps référencer System.Windows.Controls.dll situé dans C:\Program Files\Microsoft SDKs\Silverlight\v4.0\Libraries\Client
et ensuite modifier la déclaration du namespace dans les fichiers XAML :

xmlns:riaControls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Ria"

devient

xmlns:riaControls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.DomainServices"

du coté de l'app.xaml il est aussi nécessaire de modifier le namespace qui sert à l'authentification :

xmlns:appsvc="clr-namespace:System.Windows.Ria.ApplicationServices;assembly=System.Windows.Ria"

devient

xmlns:appsvc="clr-namespace:System.ServiceModel.DomainServices.Client.ApplicationServices;assembly=System.ServiceModel.DomainServices.Client.Web"

Coté Serveur (App.web)

Ici aussi il y a du changement, au revoir :

  • System.Web.DomainServices.dll
  • System.Web.Ria .dll

Il faut dorénavant référencer :

  • System.ServiceModel.DomainServices.Server.dll
  • System.ServiceModel.DomainServices.Hosting.dll

Et si vous faites de l'Entity System.Web.DomainServices.EntityFramework devient System.ServiceModel.DomainServices.EntityFramework.dll
Ensuite vous devez encore remplacer les using :
"System.Web.DomainServices" par "System.ServiceModel.DomainServices.Hosting"
"System.Web.Ria" par "System.ServiceModel.DomainServices.Server"
"System.Web.Ria.ApplicationServices" par " System.ServiceModel.DomainServices.Server.ApplicationService"

Dernière étape (pour moi et ce projet en particulier, je l'espère pour vous aussi) : Quelques petites modifications dans le Web.config :

<add name="DomainServiceModule" type="System.Web.Ria.Services.DomainServiceHttpModule, System.Web.Ria ...

devient

<add name="DomainServiceModule" type="System.ServiceModel.DomainServices.Hosting.DomainServiceHttpModule, System.ServiceModel.DomainServices.Hosting .../>

Voilà après ça, mon projet compilait et marchait de nouveau, j'espère avoir été assez clair et que ça pourra vous dépanner si vous êtes dans le besoin.

Dégage Sale Programmeur (par Codingly)

Un petit article bien sympathique (via @pocarles) qui je pense est proche de la réalité sur le métier de Développeur : http://codingly.com/2008/12/29/degage-sale-programmeur/ 

Pour ma part cela fait plus de 10 ans que je développe pour gagner ma vie, mais j'ai commencé beaucoup plus tôt (je suis encore newbie par rapport à d'autre je sais) :
mon premier programme il me semble était une application pour gérer mon argent de poche, développer en basic sur mon 386.

Depuis je continue de développer en dehors du travaille, juste pour mon plaisir, pour plusieurs raisons :

  • Tester les nouveaux langages / nouvelles méthodes, la veille est une partie importante du travail de développeur.
  • La satisfaction de créer quelque chose qui fonctionne, qui pourrais aider des gens ou leur simplifier la tâche.

Et même si c'est parfois difficile, quand on arrive au bout de son développement et que le produit fonctionne, on as un sentiment d'accomplissement qui fait du bien.

Puis suivent les coups de fils des clients ... là c'est une autre histoire ...

Vectra386-290x300

Widget Tumblr LastFM et Ajax en Cross Domain

J'ai voulu ajouter à mon Tumblr un nouveau widget affichant mes coups de coeur musical sur LastFM. Pour cela j'ai :

  1. Besoin de récupérer le flux rss sur LastFM
  2. Le parser
  3. Afficher une liste des n derniers coup de coeurs
  4. Intégration dans votre template Tumblr

1 - Récupération du flux J'avais réalisé en local un code javascript qui marchait très bien, avec une XmlHttpRequest qui récupérait en GET le contenu du flux rss.

Mais une fois inclut dans mon Template ça ne fonctionnait plus, la faute au Cross Domain qui n'est pas autoriser dans la version 1 de XmlHttpRequest.

Après avoir chercher divers solutions, je suis tombé sur le site du zéro avec une explication simple, utiliser le level 2 de XMLHttpRequest ou la version Microsoft disponible dans IE8.

J'ai donc modifier mon code en utilisant l'exemple du site du zero pour arriver à ça :

function getXDomainRequest() {
        var xdr = null;
        
        if (window.XDomainRequest) {
                xdr = new XDomainRequest(); 
        } else if (window.XMLHttpRequest) {
                xdr = new XMLHttpRequest(); 
        } else {
                alert("Votre navigateur ne gère pas l'AJAX cross-domain !");
        }
        
        return xdr;        
}

        window.onload = function(){
        
            var xdr = getXDomainRequest();
            xdr.onload = function() {        
                ...
            }
       }
};

Vous remarquerez l'utilisation de l'évènement onLoad sur l'objet xdr et non plus onComplete ou onSuccess (cet évènement n'est pas disponible dans le level 1 de XMLHttpRequest)
Cependant cela ne suffit pas car LastFM n'as pas mis en place d'Access Control, je n'ai donc pas l'autorisation de récupérer les informations.

Je passe donc par un fichier php hébérgé sur un de mes serveurs qui fait le relais en utilisant CUrl, il reçoit l'url du flux rss en paramètre et le retourne.
La requête Ajax aura le droit d'interroger ce fichier car je lui ai paramètré un Access-Control pour tout domaine distant. Voici le code de ce fichier :

<?php
        header("Access-Control-Allow-Origin: *");
        header('Content-Type: text/html; charset=utf-8');
        header("content-type: application/xml");

        $curl_handle = curl_init();                
        curl_setopt($curl_handle,CURLOPT_URL, $_REQUEST['url']);
        curl_setopt($curl_handle,CURLOPT_CONNECTTIMEOUT,2);
        curl_setopt($curl_handle,CURLOPT_RETURNTRANSFER,1);
        curl_setopt($curl_handle,CURLOPT_GET,1);
                                                        
        $res = curl_exec($curl_handle);                        
        curl_close($curl_handle);

        print $res;
?>

Une fois le fichier mis en place j'ajoute ces 2 lignes à mon code Javascript afin d'envoyer la requête asynchrone :

xdr.open("GET", "http://static.ptirouz.net/tumblr/ajax_rss_call.php?url=http://ws.audioscrobbler.com/2.0/user/" + lastfmUser + "/lovedtracks.rss");
        xdr.send();

2 - Parsage du flux RSS Maintenant que ma fonction javascript reçoit bien le contenu du flux rss, je dois le parser afin de garder uniquement les infos nécessaires.

On utilise bien entendu la réponse XMLHttpRequest au format XML à savoir this.responseXML, un bout de code vaut tous les mots :

var innerHTML = "";
var track, lien;
                
var bloc = this.responseXML.getElementsByTagName("item");
        if (nbtracks > bloc.length) {
                nbtracks = bloc.length;
        }

        for (i=0; i<nbtracks ; i++) {
                var subxml = bloc[i].childNodes;

                for (j=0; j<subxml.length; j++) {
                        switch(subxml[j].tagName) {
                                case "title" :
                                        track = subxml[j].firstChild.nodeValue;
                                        break;
                                case "link" :
                                        lien = subxml[j].firstChild.nodeValue;
                                        break;                
                        }
                }        
              innerHTML += "\t<li class=\"lovedtracks\"> a href="\""">" + track + "</a \r\n";

3 - Affichage de la liste Il y a plusieurs façon de faire, j'a choisi celle qui consiste à remplir un objet DOM déjà existant dans le template HTML de ma page, comme ça mon code javascript peut rester tranquillement dans la balise Header et être non obstructif :

Dans mon javascript je met la touche finale :

document.getElementById('lastfm').innerHTML = innerHTML;

4 - Intégration dans votre Template Tumblr Maintenant que toute les pièces sont réuni reste plus qu'à l'intégrer à votre thème.

a - Ajouter les champs de configuration du widget :

<meta name="text:LastFm User" content=""/>
     <meta name="text:Loved Tracks Number" content="5"/>

b - Initialiser les variable Javascript :

<script type="text/javascript"></script>

c - Ajouter la référence au script créer précédemment qui à été ajouté statiquement à Tumblr :

<script src="http://static.tumblr.com/9bfczhx/0iZkv3ppu/lastfmlovedtracks.js"></script>

d - Ajouter un peu de style :

ul#lastfm {
                list-style-type:none;
                margin:0px;
                padding:0px;
        }

        li.lovedtracks
        {
                display:block;
                margin-bottom:3px;
        }

        li.lovedtracks a {                
                color:#666;
        }
        li.lovedtracks a:hover {
                color: #0099cc;
        }

e - Afficher la liste :

{block:IfLastFMUser}
    <h3 class="title"> a href="http://www.lastfm.fr/user/{text:LastFm User}/library/loved">Mes coups de coeurs</a </h3>!
    {/block:IfLastFMUser}

f - Paramétrage :
Il ne reste plus qu'as paramétrer votre utilisateur LastFM et le nombre de coup de coeur à afficher dans l'onglet Appearance 

Parametragelastfmtumblr

 


Pour fini un petit aperçu sur mon site

Apercuwifgtlastfmtumblr