<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>blog ntic de revolunet &#187; developpement</title>
	<atom:link href="http://blog.revolunet.com/index.php/conseil.intranet/developpement/feed" rel="self" type="application/rss+xml" />
	<link>http://blog.revolunet.com</link>
	<description>Blog des Nouvelles Technologies de l'Information et de la Communication</description>
	<lastBuildDate>Thu, 05 Jan 2012 11:03:32 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Le point sur ExtJs 4</title>
		<link>http://blog.revolunet.com/index.php/general/le-point-sur-extjs-4</link>
		<comments>http://blog.revolunet.com/index.php/general/le-point-sur-extjs-4#comments</comments>
		<pubDate>Thu, 05 Jan 2012 11:03:32 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[actu informatique]]></category>
		<category><![CDATA[sencha]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=533</guid>
		<description><![CDATA[Ca fait deja quelques années qu’ExtJS fait le bonheur des développeurs d’applications web complexes. Depuis sa premiere version ce framework javascript a su tirer le meilleur de nos browsers web, permettant à ses utilisateurs le développement d’interfaces riches, robustes et évolutives. Pour ceux qui ne connaissent pas encore cette technologie, je vous invite à aller [...]]]></description>
			<content:encoded><![CDATA[<p>Ca fait deja quelques années qu’ExtJS fait le bonheur des <strong>développeurs d’applications web complexes</strong>. Depuis sa premiere version ce framework javascript a su tirer le meilleur de nos browsers web, permettant à ses utilisateurs le développement d’interfaces riches, robustes et évolutives. Pour ceux qui ne connaissent pas encore cette technologie, je vous invite à aller <a href="http://www.sencha.com/products/extjs/examples/" target="_blank">jeter un oeil au site de Sencha</a> qui présente parfaitement les différents produits réalisés par cette companie.</p>
<p>Aujourd’hui la version 4 d’ExtJS est disponible, stable et remplie de nouveautés faisant toute la différence avec la version 3 qui était deja tres appréciées des codeurs de webapps.</p>
<p>Chez REVOLUNET ça fait deja quelques mois que nous utilisons cette version et il est temps pour nous de vous faire un petit retour d’expérience.</p>
<h4><strong>SO WHAT’S NEW ?</strong></h4>
<p><strong> </strong>Les nouveautés implémentées dans ExtJS 4 sont nombreuses, nous n’allons pas les lister ici mais simplement parler de ce qui nous parait comme une avancée notable par rapport aux versions précédentes.</p>
<p><strong>1) The MVC model</strong><br />
Le but d’architecturer sont code selon le modèle MVC est une avancée importante. Auparavant le code métier (controlleurs) etait souvent mélangé avec la description de l’interface et des données (views and models), les actions concernant les éléments du design étant déclarées au meme niveau que les attributs influants sur l’affichage.</p>
<p>Exemple avec ExtJS 3 : un bouton et sa fonction s’exécutant lors du clic.</p>
<div class="codesnip-container" >var button = new Ext.Button({<br />
iconCls: ‘my-icon-class’,<br />
handler: function() {<br />
// on my button click a form is submitted&#8230;<br />
}<br />
});</div>
<p>Bien sûr cette facon de déclarer un bouton dans ExtJS 4 est encore valide mais lors du développement d’interfaces complexes cette méthode peut s’avérer assez inefficace. Imaginons que notre bouton soit perdu au milieu de l’imbrication de plusieurs widgets et que le clic sur ce dernier doit déclencher différentes actions un peu partout dans l’application. Et bien notre seule facon de faire les choses proprement était de déclencher des évenement personnalisés et de les relayer “à la main” (bubble, cascade, relayEvent&#8230;) pour qu’ils soient pris en compte dans les autres éléments de l’interface.</p>
<p>Désormais ExtJS 4 nous propose une alternative à cette architecture que nous avions l’habitude d’avoir avec ExtJS 3. Il suffit pour cela de séparer les deux codes, la déclaration de notre bouton dans une “vue” et les actions le concernant dans un &#8220;controlleur&#8221;.</p>
<p>Exemple avec ExtJS 4 :</p>
<p>myView.js</p>
<div class="codesnip-container" >var button = Ext.create(‘Ext.Button’, {<br />
iconCls: ‘my-icon-class’,<br />
action: ‘submit_a_form’<br />
});</div>
<p>myControlleur.js</p>
<div class="codesnip-container" >// …</p>
<p>init: function() {<br />
this.control({<br />
&#8216;viewport button[action=submit_a_form]&#8216;: {<br />
click: function() {<br />
// on my button click a form is submitted&#8230;<br />
}<br />
}<br />
});<br />
}</p></div>
<p>Dans cet exemple on peut voir l’utilisation du nouveau concept de “ComponentQuery” qui a la maniere des selecteurs CSS permet d’obtenir une référence à n’importe quel composant de notre interface. Ici &#8216;viewport button[action=submit_a_form]&#8216; signifie “le bouton du viewport qui comporte un attribut action égal à submit_a_form”.<br />
Il suffit ensuite d’associer les évènements a notre bouton sans ce soucier des son imbrication dans les widgets de notre application. Cerise sur le gateau grace à cette technique, les évènement peuvent etre déclarés avant que les widgets (ici notre bouton) n’aient été “render”.<br />
Si un nouveau bouton faisant parti de notre viewport et ayant un attribut action égal à submit_a_form est créé il repondra au meme fonctionnement, meme s’il n’est pas rendu au load initial de l’application.</p>
<p>Dans cet exemple on peut aussi apprécier l’utilisation de Ext.create qui évite d’avoir un code truffé de “new Ext.Button” qui étaient interprétés au run time. Cela a pour effet d’accélérer grandement le chargement de l’application.</p>
<p><strong>2) Ext.loader</strong></p>
<p>Ce n’est pas à proprement dit une nouveauté d’ExtJS 4 car cette fonctionnalité existait deja en partie dans la version 3 du framework. Disons simplement que le load dynamique des ressources de votre application est désormais induite pour peu qu’on en ai envie.</p>
<p>Si nous reprenons les projets que nous avons développer chez REVOLUNET avec ExtJS 3, on peut voir des fichiers “index.html” démesurément grands car ils comportent toutes les inclusions des differents scripts necessaires au bon fonctionnement de l’application, meme si ces resources ne sont pas utilisées au load de la page.</p>
<p>Aujourd’hui la donne a changée, ExtJS se chargeant d’aller chercher les ressources nécessaires au fur et a mesure de leur utilisation. Ceci comporte deux avantages a nos yeux, le premier etant de ne plus se soucier de savoir si les bons fichiers sont inclus dans l’index, le deuxième est que cette technique nous force a organiser notre projet d’un facon bien spécifique afin qu’ExtJS soit en mesure de trouver le code qu’il souhaite charger quand il le juge necessaire.</p>
<p>Afin de bien comprendre le fonctionnement du chargement dynamique de vos scripts nous vous invitons à lire cet article: http://www.sencha.com/blog/using-ext-loader-for-your-application</p>
<p><strong>SO WHAT’S THE POINT ?</strong></p>
<p>Il aurait beaucoup de choses a dire sur la nouvelle version d’ExtJS 4, la gestion des données, la configuration des objets complexes comme les grids ou les forms, les améliorations de performances&#8230; les avancées apportées par le nouvelles version de ce framework sont nombreuses.</p>
<p>En ce qui nous concerne il est évident qu’ExtJS a fait un réel bon en avant avec la sortie de la version 4. Concrètement notre point de vue de développeurs spécialisés dans les applications web est qu’ExtJS 4 va nous faire gagner un temps precieux lors du développement de nos nouveaux projets. Et ca, ca vaut de l’or <img src='http://blog.revolunet.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>De plus, de nombreuses améliorations ont également été portées dans Sencha Touch 2 (gestion des classes, loader&#8230;), ce qui nous permet de capitaliser en compétence sur les projets basés sur les frameworks Sencha, que ce soit pour les applis Desktop, ou mobiles.</p>
<p>N&#8217;hésitez pas à nous consulter pour vos besoins en<a href="http://revolunet.com"> développement d&#8217;applications web riches</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/general/le-point-sur-extjs-4/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Revolunet réalise l&#8217;application de E-coffrefort.fr</title>
		<link>http://blog.revolunet.com/index.php/developpement/revolunet-realise-lapplication-de-e-coffrefort-fr</link>
		<comments>http://blog.revolunet.com/index.php/developpement/revolunet-realise-lapplication-de-e-coffrefort-fr#comments</comments>
		<pubDate>Wed, 16 Nov 2011 15:41:09 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[developpement]]></category>
		<category><![CDATA[anroid]]></category>
		<category><![CDATA[apple]]></category>
		<category><![CDATA[application]]></category>
		<category><![CDATA[ipad]]></category>
		<category><![CDATA[mobile]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[sencha]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=517</guid>
		<description><![CDATA[E-coffrefort.fr est, comme son nom l&#8217;indique, un coffre-fort virtuel via lequel vous pouvez sécuriser, organiser et gérer tous vos documents papier et numériques !
C&#8217;est le coffre-fort N°01 depuis 2006 des particuliers et des entreprises.
Revolunet a permis à ce service de se développer sur mobile via une application compatible iPad, Android et BlackBerry !
Découvrez l&#8217;application E-Coffrefort.fr [...]]]></description>
			<content:encoded><![CDATA[<p>E-coffrefort.fr est, comme son nom l&#8217;indique, un coffre-fort virtuel via lequel vous pouvez sécuriser, organiser et gérer tous vos documents papier et numériques !<br />
C&#8217;est le coffre-fort N°01 depuis 2006 des particuliers et des entreprises.</p>
<p>Revolunet a permis à ce service de se développer sur mobile via une application compatible iPad, Android et BlackBerry !</p>
<p>Découvrez l&#8217;application E-Coffrefort.fr sur <a href="http://itunes.apple.com/fr/app/e-coffrefort/id466701059?mt=8">iTunes Store</a></p>
<p>Technologies : Php, Sencha Touch, MySQL, Linux Debian<br />

<a href='http://blog.revolunet.com/index.php/developpement/revolunet-realise-lapplication-de-e-coffrefort-fr/attachment/cf_01' title='CF_01'><img width="150" height="150" src="http://blog.revolunet.com/wp-content/uploads/2011/10/CF_01-150x150.jpg" class="attachment-thumbnail" alt="" title="CF_01" /></a>
<a href='http://blog.revolunet.com/index.php/developpement/revolunet-realise-lapplication-de-e-coffrefort-fr/attachment/cf_02' title='CF_02'><img width="150" height="150" src="http://blog.revolunet.com/wp-content/uploads/2011/10/CF_02-150x150.jpg" class="attachment-thumbnail" alt="" title="CF_02" /></a>
<a href='http://blog.revolunet.com/index.php/developpement/revolunet-realise-lapplication-de-e-coffrefort-fr/attachment/cf_03' title='CF_03'><img width="150" height="150" src="http://blog.revolunet.com/wp-content/uploads/2011/10/CF_03-150x150.jpg" class="attachment-thumbnail" alt="" title="CF_03" /></a>
</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/developpement/revolunet-realise-lapplication-de-e-coffrefort-fr/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Revolunet réalise le magazine digital BellesDemeures.com</title>
		<link>http://blog.revolunet.com/index.php/developpement/revolunet-a-remporte-lappel-doffre-lancee-par-le-magazine-digital-bellesdemeures-com</link>
		<comments>http://blog.revolunet.com/index.php/developpement/revolunet-a-remporte-lappel-doffre-lancee-par-le-magazine-digital-bellesdemeures-com#comments</comments>
		<pubDate>Sat, 15 Oct 2011 16:57:53 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[developpement]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=504</guid>
		<description><![CDATA[Toute l&#8217;équipe a travaillé pour mettre en place une application mobile compatible iPad, Android et BlackBerry qui permet de consulter le magazine BellesDemeures.com directement depuis sa tablette.
Vous pouvez y consulter les dernières parutions à la manière d&#8217;un magazine, découvrir l&#8217;actualité, rechercher par région ou département, visualiser des diaporamas de photos en haute résolution…
L&#8217;application est accessible [...]]]></description>
			<content:encoded><![CDATA[<p><img src="http://blog.revolunet.com/wp-content/uploads/2011/10/home1.jpg" alt="Accueil Application BellesDemeures" title="Accueil Application BellesDemeures" width="200" height="142" class="alignright size-full wp-image-503" />Toute l&#8217;équipe a travaillé pour mettre en place une application mobile compatible iPad, Android et BlackBerry qui permet de consulter le magazine BellesDemeures.com directement depuis sa tablette.</p>
<p>Vous pouvez y consulter les dernières parutions à la manière d&#8217;un magazine, découvrir l&#8217;actualité, rechercher par région ou département, visualiser des diaporamas de photos en haute résolution…</p>
<p>L&#8217;application est accessible directement via le site internet, l&#8217;AppleStore, l&#8217;Android Market ou BlackBerry AppWorld.</p>
<p>Découvrez le magazine digital sur <a href="http://itunes.apple.com/ke/app/digimag/id471310624?mt=8">iTunes Store</a>. </p>
<p>Technologies : Php, Sencha Touch, MySQL, Linux Debian</p>
<p>A la recherche d&#8217;un <a href="http://chewam.com">consultant ExtJs</a> ?</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/developpement/revolunet-a-remporte-lappel-doffre-lancee-par-le-magazine-digital-bellesdemeures-com/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Recrute développeur PHP</title>
		<link>http://blog.revolunet.com/index.php/actu-informatique/recrute-developpeur-php</link>
		<comments>http://blog.revolunet.com/index.php/actu-informatique/recrute-developpeur-php#comments</comments>
		<pubDate>Fri, 24 Sep 2010 15:30:36 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[actu informatique]]></category>
		<category><![CDATA[developpement]]></category>
		<category><![CDATA[emploi]]></category>
		<category><![CDATA[web]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=487</guid>
		<description><![CDATA[Nous recherchons pour l&#8217;un de nos clients, société spécialisée en développement d&#8217;applications web de nouvelle génération (interfaces riches), deux développeurs PHP expérimentés.
Vous intégrerez une équipe d&#8217;une quinzaine de développeurs dans le quartier de l&#8217;Opéra à Paris.
Salaire à négocier + Primes.
Nous envoyer votre CV et quelques mots sur vos compétences et motivations sur contact@revolunet.com
]]></description>
			<content:encoded><![CDATA[<p>Nous recherchons pour l&#8217;un de nos clients, société spécialisée en développement d&#8217;applications web de nouvelle génération (interfaces riches), deux développeurs PHP expérimentés.</p>
<p>Vous intégrerez une équipe d&#8217;une quinzaine de développeurs dans le quartier de l&#8217;<strong>Opéra à Paris</strong>.</p>
<p>Salaire à négocier + Primes.</p>
<p>Nous envoyer votre CV et quelques mots sur vos compétences et motivations sur <a href="mailto:contact@revolunet.com">contact@revolunet.com</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/actu-informatique/recrute-developpeur-php/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Django internationalisation made easy with i18n</title>
		<link>http://blog.revolunet.com/index.php/general/django-internationalisation-with-i18n</link>
		<comments>http://blog.revolunet.com/index.php/general/django-internationalisation-with-i18n#comments</comments>
		<pubDate>Wed, 08 Sep 2010 20:12:03 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[django]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=431</guid>
		<description><![CDATA[Ok so now you have your new django based killer app you&#8217;d like to translate it into several languages. Here&#8217;s a quick memo to get all this running quickly.
Django provides all the tools you need to do this effectively. You can use simple string translations or create more advanced rules with various plurals forms, variable [...]]]></description>
			<content:encoded><![CDATA[<p>Ok so now you have your new django based killer app you&#8217;d like to translate it into several languages. Here&#8217;s a quick memo to get all this running quickly.</p>
<p>Django provides all the tools you need to do this effectively. You can use simple string translations or create more advanced rules with various <a href="http://docs.djangoproject.com/en/dev/topics/i18n/internationalization/#pluralization" target="_blank">plurals forms, variable interpolations</a>&#8230;</p>
<p>First, be sure to use UTF-8 encode anywhere in your project :</p>
<ul>
<li>Save your file as UTF-8 (check your text editor)</li>
<li>Declare python files encoding with this at the top of each python file (see <a href="http://www.python.org/dev/peps/pep-0263/" target="_blank">PEP 263</a>) :<br />
# -*- encoding: UTF-8 -*-</li>
<li><a href="http://www.python.org/dev/peps/pep-0263/" target="_blank">Define your strings as unicode</a> if needed</li>
<li>Be warned : mixing encodings and charsets in a project can cause hasardous/mystical issues then massive headaches</li>
</ul>
<p>Django provides several builtin tools to help you internationalise :</p>
<ul>
<li><strong>makemessages</strong> command : scan your code to extract definition and create a .po file</li>
<li><strong>compilemessages </strong>command : compile your translations in the .po files to .mo</li>
<li><strong>django.middleware.locale.LocaleMiddleWare </strong>: Autodetect user language (from browser) or use session defined language (or fallback to project default)</li>
<li><strong>django.core.context_processors.i18n</strong>: add LANGUAGE_CODE and LANGUAGES variables to your templates</li>
<li><strong>django.conf.urls.i18n </strong>: a view that accepts a language POST parameter to change session language</li>
<li><strong>django.views.i18n.javascript_catalog </strong>: provides a javascript array with the translations and helpers functions gettext&#8230;</li>
</ul>
<p><b>So lets internationalise our project :</b><br />
<br />
Django make it easier to work with app level localisations and not project-global files.<br />
So you must create a ‘locale’ subfolder for each app you want to localize.<br />
Create a ‘fr’ and ‘en’ folder inside each ‘locale’ folder. (or more if needed)<br />
Try first to translate a first app in a second language before going on.<br />
</p>
<h2>Activate django.middleware.locale.LocaleMiddleWare and tweak your settings.py :</h2>
<pre class="brush: python">
# -*- encoding: UTF-8 -*-

TIME_ZONE = &#039;Europe/Paris&#039;
LANGUAGE_CODE = &#039;fr-FR&#039;
USE_I18N = True

# see http://code.djangoproject.com/browser/django/trunk/django/conf/global_settings.py
gettext = lambda s: s
LANGUAGES = (
(&#039;fr&#039;, gettext(u&#039;French&#039;)),
(&#039;en&#039;, gettext(&#039;English&#039;)),
)

MIDDLEWARE_CLASSES = (
&#039;django.contrib.sessions.middleware.SessionMiddleware&#039;,
&#039;django.middleware.locale.LocaleMiddleware&#039;,
&#039;django.middleware.common.CommonMiddleware&#039;,
&#039;django.contrib.auth.middleware.AuthenticationMiddleware&#039;,
)

TEMPLATE_CONTEXT_PROCESSORS = (
&quot;django.core.context_processors.auth&quot;,
&quot;django.core.context_processors.debug&quot;,
&quot;django.core.context_processors.i18n&quot;,
&quot;django.core.context_processors.media&quot;,
&quot;django.core.context_processors.debug&quot;,
)
</pre>
<h2>Add a lang toolbar to your template and connect to the django.conf.urls.i18n view :</h2>
<p>Add a simple lang bar to your base template :</p>
<pre class="brush: html">
   {% load i18n %}
    &lt;div id=&#039;langbar&#039; style=&#039;text-align:right;padding-top:5px;&#039;&gt;
        &lt;form name=&#039;langform&#039; style=&#039;margin:0px;display:inline;width:200px&#039; action=&#039;/i18n/setlang/&#039; method=&#039;POST&#039;&gt;
            {% for LANG in LANGUAGES  %}
                &lt;img src=&#039;{{ MEDIA_URL }}img/flags/{{ LANG.0 }}.png&#039; title=&quot;{% trans LANG.1 %}&quot; style=&#039;margin:5px;cursor:pointer&#039; onclick=&quot;document.langform.language.value=&#039;{{ LANG.0 }}&#039;;document.langform.submit();&quot;&gt;
            {% endfor %}
            &lt;input name=&#039;language&#039; type=hidden value=&quot;{{ LANGUAGE_CODE }}&quot;&gt;
            current LANG : {{ LANGUAGE_CODE }}
        &lt;/form&gt;
    &lt;/div&gt;
</pre>
<p>As you can see, when you enable i18n context processor, your templates can acces <a target="_blank" href="http://docs.djangoproject.com/en/dev/ref/templates/api/#django-core-context-processors-i18n">new variables</a> like LANGUAGE_CODE or LANGUAGES</p>
<p>Now add the /i18n/setlang/ view in your urls.py.<br />
This view accepts language POST parameter then redirect user to REFERER page (or one designed with ?next GET parameter). Selected language is then kept in session.</p>
<pre class="brush: python">
urlpatterns += patterns(&#039;&#039;,
    (r&#039;^i18n/&#039;, include(&#039;django.conf.urls.i18n&#039;)),
)
</pre>
<p>Now, check if when you submit the form, the selected language is kept in session. If not check your database (need the session table), restart your dev server or enable settings.DEBUG  <img src='http://blog.revolunet.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>If you can submit your lang and LANGUAGE_CODE is kept in session, <strong>bravo</strong>, your django is multilingual ready. </p>
<h2>Internationalise your code</h2>
<p>In your templates : just load i18n then replace every string with a <a target="_blank" href="http://docs.djangoproject.com/en/dev/topics/i18n/internationalization/#trans-template-tag">trans tag</a></p>
<pre class="brush: html">
{% load i18n %}
&lt;div class=&quot;main&quot;&gt;{% trans &quot;Welcome to our new website&quot; %}&gt;&lt;/div&gt;
{% block contents %}&lt;img src=&quot;/img/intro-{{ LANGUAGE_CODE }}&quot;/&gt;{% trans &quot;This is the intro&quot; %}{% block %}
</pre>
<p>In your views : just import django.utils.translation.gettext then replace every string with gettext(thestring)</p>
<pre class="brush: python">
from django.utils.translation import gettext as _ # just a shortcut
def view(request):
    hello = _(&#039;Hello, World&#039;)
    return HttpResponse(&#039;&lt;b&gt;%s&lt;/b&gt;&#039; % hello)
</pre>
<p>Now each time you run the makemessages command for this app, it will detect these string and update this app django.po files accordingly.</p>
<h2>Generate the .po, traduct then compile to .mo</h2>
<ol>
<li><strong>From this app folder</strong>, run
<pre class="brush: bash">python ../manage.py makemessages --all</pre>
<p>This will scan this app .py and .html files for gettext/trans calls and generate or update a django.po file for each lang.</li>
<li>Now you can edit (manually) this old-fashionned-style .po file with your favorite  text editor.<br />
If your site default is English, edit app/locale/fr/LC_MESSAGES/django.po (and djangojs.po if needed)</li>
<li>Once all your strings are translated, run
<pre class="brush: bash">python ../manage.py compilemessages</pre>
<p>from the <strong>app root</strong>. This will generate .mo files from the .po</li>
</ol>
<p>Now your templates and views should be automagically translated.</p>
<p>run makemessages/compilemessages commands to update the .po and .mo when you change some code. restart the web server.</p>
<h2>Javascript internationalisation</h2>
<p>Now your templates and views are correctly translated, you may also need  to internationalise jour javascript files.</p>
<p>Django provide a simple solution that you can use in your projects</p>
<ul>
<li>the <b>makemessages</b> command takes a -d djangojs parameter to parse .js files and create a djangojs.po</li>
<li>The <b>django.views.i18n.javascript_catalog</b> provides a way to acces the .po files from javascript</li>
<li>This view serves a javascript file containing a &#8216;catalog&#8217; array with translations and utilities functions such as <strong>gettext</strong></li>
</ul>
<p><b>Activate the view in your urls.py</b> :<br />
<br />I tweaked the <a target="_blank" href="http://docs.djangoproject.com/en/dev/topics/i18n/internationalization/#module-django.views.i18n">official rule</a> a bit.</p>
<pre class="brush: python">
# urls.py
def jsi18n(request, packages = None, domain = None):
    if not domain:
        domain = &#039;djangojs&#039;
    from django.views.i18n import javascript_catalog
    return javascript_catalog(request, domain, packages)

urlpatterns += patterns(&#039;&#039;,
    (r&#039;^jsi18n/?(?P&lt;packages&gt;[^/]+)?/?(?P&lt;domain&gt;[^/]+)?/?$&#039;, jsi18n ),                                          # serves the javascript data
)
</pre>
<p>Add a javascript include in your template ( be sure to include it before any other javascript localised file) :</p>
<pre class="brush: html">
	&lt;script type=&quot;text/javascript&quot; src=&quot;/jsi18n/main/djangojs&quot;&gt;&lt;/script&gt;
</pre>
<p>This url will serves you a javascript file from project/main/locale/fr/LC_MESSAGES/djangojs.po (if user lang is fr)<br />
<br />
By default, this language definition returns the user LANGUAGE_CODE but you can override using ?language GET parameter</p>
<p>Now you just need to replace each string in your javascript files with a call to gettext.</p>
<pre class="brush: javascript">
alert( gettext(&quot;Ready to start ?&quot;) );
</pre>
<h2>Maintain</h2>
<p>When you add new code, always use calls to gettext instead of strings.<br />
run makemessages to update the .po definitions<br />
translate new strings in the .po files<br />
run compilemessages to update</p>
<p></p>
<p><b>Voila</b> Now your app can speak any UTF-8 lang, which is more than 600 languages <img src='http://blog.revolunet.com/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>These are just the basics, check out for the full story <a target="_blank" href="http://docs.djangoproject.com/en/dev/topics/i18n/internationalization/">http://docs.djangoproject.com/en/dev/topics/i18n/internationalization/</a></p>
<p><strong>Notes/Gotchas</strong> :</p>
<ul>
<li>Using builtin dev server, you need to restart after a compilemessages</li>
<li>Use <a href="http://www.famfamfam.com/lab/icons/flags/" target="_blank">famfamfam flag icons</a></li>
<li>You must add your app to settings.INSTALLED_APPS if you want to use jsi18n view for this app</li>
<li>Double check middlewares order, and session tables</li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/general/django-internationalisation-with-i18n/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Astuces Django</title>
		<link>http://blog.revolunet.com/index.php/developpement/astuces-django</link>
		<comments>http://blog.revolunet.com/index.php/developpement/astuces-django#comments</comments>
		<pubDate>Fri, 11 Dec 2009 00:46:07 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[Python]]></category>
		<category><![CDATA[developpement]]></category>
		<category><![CDATA[django]]></category>
		<category><![CDATA[web]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=393</guid>
		<description><![CDATA[Suite à mon quickstart Django, me revoici avec quelques astuces pour continuer.
Pour tester/développer avec Django, je rappelle qu&#8217;il vaut mieux utiliser le serveur de dev intégré, puis passer à Apache, nginx ou autre pour la production par la suite.
Il est important de lire pour commencer les principes de la philosophie Django ainsi que le &#8216;django coding style&#8217;
Ne [...]]]></description>
			<content:encoded><![CDATA[<p><img class="alignleft size-full wp-image-396" title="tips" src="http://blog.revolunet.com/wp-content/uploads/2009/12/tips.jpg" alt="tips" width="150" height="152" />Suite à mon <a href="http://blog.revolunet.com/index.php/general/bien-demarrer-avec-django" target="_blank">quickstart Django</a>, me revoici avec quelques astuces pour continuer.</p>
<p>Pour tester/développer avec Django, je rappelle qu&#8217;il vaut mieux utiliser le serveur de dev intégré, puis passer à Apache, nginx ou autre pour la production par la suite.</p>
<p>Il est important de lire pour commencer les principes de la <strong><a href="http://docs.djangoproject.com/en/dev/misc/design-philosophies/" target="_blank">philosophie Django</a> </strong>ainsi que le <a href="http://docs.djangoproject.com/en/dev/internals/contributing/#coding-style" target="_blank">&#8216;django coding style&#8217;</a></p>
<p><strong>Ne hardcodez pas vos paths</strong></p>
<ul>
<li>dans votre settings.py :</li>
<li>
<div class="codesnip-container" >BASE_DIR = os.path.dirname(__file__)</div>
</li>
<li>utilisez ensuite os.path.join avec settings.BASE_DIR ailleurs si besoin</li>
<li>Pour importer les settings de votre projet, utilisez toujours
<div class="codesnip-container" >from django.conf import settings</div>
</li>
</ul>
<p><strong>Utilisez un fichier local_settings.py</strong></p>
<ul>
<li>Créez un fichier local_settings.py qui contiendra uniquement les settings relatifs au déploiment de votre application : settings de base de données, smtp, debug&#8230; Vous n&#8217;aurez plus que celui la à modifier pour un nouveau déploiement.</li>
</ul>
<p><strong>Mettre en production avec Apache</strong></p>
<ul>
<li>Pour une installation classique avec <strong>Apache</strong>, utilisez de préférence <strong><a href="http://code.google.com/p/modwsgi/wiki/IntegrationWithDjango" target="_blank">mod_wsgi</a>. <span style="color: #ff0000;">N&#8217;utilisez pas le serveur de dev intégré en production!</span></strong></li>
</ul>
<p><strong>Debug AJAX plus pratique</strong></p>
<ul>
<li>Si vous faites de l&#8217;Ajax, utilisez <strong><a href="https://addons.mozilla.org/fr/firefox/addon/1843" target="_blank">Firebug</a> et le middleware </strong><a href="http://www.djangosnippets.org/snippets/650/" target="_blank"><strong>AJAXSimpleExceptionResponse</strong></a></li>
</ul>
<p><strong>Queysets : filters et excludes dynamiques</strong></p>
<ul>
<li>Utilisez les dictionnaires pour filtrer dynamiquement vos querysets :</li>
</ul>
<div class="codesnip-container" >filtres = {}<br />
filtres['date__gte'] = datetime.datetime.today() &#8211; datetime.timedelta(dasy=7)<br />
filtres['titre__icontains'] = &#8216;python&#8217;<br />
excludes={}<br />
excludes['epuise'] = True<br />
qs = model.Livres.objects.exclude(**excludes).filter(**filtres)</div>
<p><strong>Créez des applications modulaires</strong></p>
<ul>
<li>Placez vos app dans un sous dossier &#8216;apps&#8217;</li>
<li>Utiliser des objets génériques : le <a href="http://docs.djangoproject.com/en/dev/ref/contrib/contenttypes/" target="_blank">ContentType framework</a></li>
</ul>
<p><strong>Utilisez un script pour mettre à jour vos modèles</strong></p>
<ul>
<li>Django ne gérant pas nativement les ALTER sur votre base de données, vous devez sauvegarder (manage.py dumpdata), reset votre base (manage.py reset) puis recréer votre base (manage.py syncdb) et recharger les données (manage.py loaddata).</li>
<li>Utilisez plutot un <a href="http://www.chrisdpratt.com/2008/02/27/a-django-snippet-to-refresh-your-database/" target="_blank">script qui automatisera cette tache</a></li>
</ul>
<p><strong>Utilisez des décorateurs dans vos vues</strong></p>
<ul>
<li><strong>@login_required </strong>pour restreindre la vue aux utilisateurs loggés</li>
<li><strong>@user_passes_test(lambda u: u.has_perm(&#8217;polls.can_vote&#8217;)) </strong>pour restreindre la vue selon un test particulier</li>
<li>créez vos propres décorateurs</li>
</ul>
<p><strong>Ne définissez qu&#8217;une fois vos urls</strong></p>
<ul>
<li>Utilisez les <a href="{% url arch-summary 1945 %}" target="_blank">named-urls</a> pour ne plus harcoder vos urls
<ul>
<li>Dans urls.py :  
<div class="codesnip-container" >(r&#8217;^articles/list/(\d)+&#8217;, apps.main.list, name=&#8221;list-view&#8221;)</div>
</li>
<li>Dans une vue :
<div class="codesnip-container" >return HttpResponseRedirect(reverse(&#8217;list-view&#8217;, args=[2007]))</div>
</li>
<li>Dans un template :
<div class="codesnip-container" >&lt;a href=&#8221;{% url list-view 2007 %}&#8221;&gt;ma vue&lt;/a&gt;</div>
</li>
</ul>
</li>
<li>Utilisez <a href="http://docs.djangoproject.com/en/dev/ref/models/instances/#django.db.models.Model.get_absolute_url" target="_blank">get_absolute_url()</a> sur vos modèles pour affecter une url à chacun de vos objets</li>
</ul>
<p><strong>Des questions que vous vous posez surement :</strong></p>
<ul>
<li><a href="http://www.b-list.org/weblog/2006/jun/28/django-tips-difference-between-blank-and-null/" target="_blank">La différence entre null et blank</a> dans vos modèles</li>
<li>Comment toujours passer des variables à mes templates : les <a href="http://docs.djangoproject.com/en/dev/ref/templates/api/#id1" target="_blank">template contexts</a></li>
</ul>
<p><strong>De bons examples de coding-styles : </strong></p>
<ul>
<li><a href="http://code.google.com/p/django-basic-apps/" target="_blank">http://code.google.com/p/django-basic-apps/</a></li>
<li><a href="http://groups.google.com/group/django-hotclub" target="_blank">http://groups.google.com/group/django-hotclub</a></li>
</ul>
<p><strong>Différents cas de figures sur les formulaires Django</strong> : <a href="http://uswaretech.com/blog/2010/01/doing-things-with-django-forms/">http://uswaretech.com/blog/2010/01/doing-things-with-django-forms/</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/developpement/astuces-django/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Bien démarrer avec django</title>
		<link>http://blog.revolunet.com/index.php/general/bien-demarrer-avec-django</link>
		<comments>http://blog.revolunet.com/index.php/general/bien-demarrer-avec-django#comments</comments>
		<pubDate>Wed, 02 Dec 2009 11:21:53 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[developpement]]></category>
		<category><![CDATA[django]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=381</guid>
		<description><![CDATA[Cela fait maintenant presque deux ans que j&#8217;utilise intensivement le framework Django pour toutes mes applications web, et j&#8217;ai enfin réuni assez d&#8217;éléments pour pouvoir vous livrer un petit &#8216;QuickStart&#8217; qui vous permettra de démarrer rapidement.
Contrairement à d&#8217;autres frameworks web, Django n&#8217;est pas orienté CMS ou HTML. Vous pouvez tout autant créer un site HTML/Ajax, une [...]]]></description>
			<content:encoded><![CDATA[<p>Cela fait maintenant presque deux ans que j&#8217;utilise intensivement le framework <a href="http://www.djangoproject.com/" target="_blank">Django</a> pour toutes mes applications web, et j&#8217;ai enfin réuni assez d&#8217;éléments pour pouvoir vous livrer un petit &#8216;QuickStart&#8217; qui vous permettra de démarrer rapidement.</p>
<p>Contrairement à d&#8217;<a href="http://drupal.org/" target="_blank">autres</a> <a href="http://www.zope.org/" target="_blank">frameworks</a> <a href="http://www.symfony-project.org/doc/1_4/" target="_blank">web</a>, Django n&#8217;est pas orienté CMS ou HTML. Vous pouvez tout autant créer un site HTML/Ajax, une API RESTFUL http ou une application en ligne de commande.</p>
<p>Django permet de coder toute la partie serveur de votre application, mais pour la partie &#8216;client&#8217;, c.a.d. le HTML par exemple, vous devrez vous débrouiller tout seul ou utiliser un autre framework, <a href="http://jquery.com/" target="_blank">jQuery</a> par exemple, ou <a href="http://extjs.com/" target="_blank">ExtJs</a>.</p>
<p><img class="alignleft size-full wp-image-389" title="django" src="http://blog.revolunet.com/wp-content/uploads/2009/12/django.jpg" alt="django" width="120" height="177" /></p>
<p style="padding-left: 120px;"><strong> Pourquoi Django ? </strong></p>
<p style="padding-left: 120px;">Open Source<br />
Portable<br />
Langage Python<br />
Prototypage rapide<br />
Evolutivité<br />
Abstration <a href="http://fr.wikipedia.org/wiki/Mapping_objet-relationnel" target="_blank">ORM<br />
</a> Supporté par <a href="http://fr.wikipedia.org/wiki/Google_App_Engine" target="_blank">Google AppEngine</a> (avec restrictions)<br />
Excellente <a href="http://docs.djangoproject.com/en/dev/" target="_blank">documentation</a></p>
<p><strong>Fonctionnalités principales :</strong></p>
<ul>
<li><strong>ORM :</strong> permet une abstraction de la base de données et du SQL, ce qui fait que vos applications peuvent tourner sur : SQLlite, MySQL, SQLserver, Oracle, PostGres&#8230;</li>
<li><strong>Admin automatique : </strong>une fois vos modèles définis, ils sont de suite accessible dans l&#8217;interface d&#8217;admin automatique, et vous pouvez toute de suite créer objets</li>
<li><strong>Templates : </strong>une gestion des templates très poussée, avec gestion des héritages, des filtres et &#8216;customs tags&#8217;.</li>
<li><strong>Shell intégré : </strong>Tout votre code est également accessible directement depuis un shell intégré</li>
<li><strong>Gestion des utilisateurs : </strong>Toute la partie utilisateurs, comptes, login, sécurité et permissions est déjà disponible sans efforts</li>
</ul>
<p><strong>Inconvénients :</strong></p>
<ul>
<li>Peu d&#8217;hébergeurs mais cela évolue : <a href="http://code.djangoproject.com/wiki/DjangoFriendlyWebHosts">http://code.djangoproject.com/wiki/DjangoFriendlyWebHosts</a></li>
<li>C&#8217;est surtout  un avantage, mais le projet évoluant très vite, vous devrez coder avec et pour une version spécifique de Django. Et vous ne mettrez à jour django pour tel projet seulement après avoir consulté cette page : <a href="http://code.djangoproject.com/wiki/BackwardsIncompatibleChanges">http://code.djangoproject.com/wiki/BackwardsIncompatibleChanges</a></li>
</ul>
<p>A noter que Django est une librairie python, vous pouvez n&#8217;utiliser que les fonctions dont vous avez besoin, même en &#8217;standalone&#8217;  (hors du web).  Et vous pouvez tout modifier, étendre et améliorer à souhait.</p>
<p>La première chose à faire avant de se lancer dans Django est déjà de connaitre un minimum le langage python et sa &#8216;magie&#8217;. Le livre &#8216;<a href="http://openbookproject.net//thinkCSpy/" target="_blank">Think like a computer scientist</a>&#8216; est à lire, <a href="http://hetland.org/writing/instant-python.html" target="_blank">Instant Python</a> pour les préssés, et &#8220;<a href="http://www.swaroopch.com/notes/Python_fr:Table_des_Mati%C3%A8res" target="_blank">A byte of python</a>&#8221; (en francais).</p>
<h2><strong>C&#8217;est parti</strong></h2>
<p>Installez <a href="http://python.org/download/" target="_blank">python </a>(2.5 ou 2.6) sur votre machine, et récupérez la <a href="http://www.djangoproject.com/download/" target="_blank">dernière version de Django</a>. Le repertoire &#8216;django&#8217; de cette archive doit se trouver dans le dossier &#8216;lib/site-packages&#8217; de votre installation de Python. Si vous souhaitez utiliser MySQL comme serveur, installez <a href="http://sourceforge.net/projects/mysql-python/" target="_blank">python-mysqldb</a>. Sinon, SQLlite fera très bien l&#8217;affaire pour démarrer !</p>
<p>Pour tester si votre installation de python/django est correcte :</p>
<div id="_mcePaste" style="position: absolute; left: -10000px; top: 272px; width: 1px; height: 1px; overflow-x: hidden; overflow-y: hidden;">juju@devserver:/var/www/django$ python</div>
<div id="_mcePaste" style="position: absolute; left: -10000px; top: 272px; width: 1px; height: 1px; overflow-x: hidden; overflow-y: hidden;">Python 2.5.2 (r252:60911, Jul 31 2008, 17:28:52)</div>
<div id="_mcePaste" style="position: absolute; left: -10000px; top: 272px; width: 1px; height: 1px; overflow-x: hidden; overflow-y: hidden;">[GCC 4.2.3 (Ubuntu 4.2.3-2ubuntu7)] on linux2</div>
<div id="_mcePaste" style="position: absolute; left: -10000px; top: 272px; width: 1px; height: 1px; overflow-x: hidden; overflow-y: hidden;">Type &#8220;help&#8221;, &#8220;copyright&#8221;, &#8220;credits&#8221; or &#8220;license&#8221; for more information.</div>
<div class="codesnip-container" >juju@xxxxxxx:/home/juju$ python<br />
Python 2.5.2 (r252:60911, Jul 31 2008, 17:28:52)<br />
[GCC 4.2.3 (Ubuntu 4.2.3-2ubuntu7)] on linux2<br />
Type &#8220;help&#8221;, &#8220;copyright&#8221;, &#8220;credits&#8221; or &#8220;license&#8221; for more information.<br />
&gt;&gt;&gt;import django<br />
&gt;&gt;&gt;print django.VERSION<br />
(1, 0, 2, &#8216;final&#8217;, 0)<br />
&gt;&gt;&gt;</div>
<p>Si vous avez une erreur lors de l&#8217;import, alors votre dossier &#8216;django&#8217; n&#8217;est pas dans votre dossier python\lib\site-packages, vérifiez.</p>
<p>Si l&#8217;install est correcte, alors vous pouvez créer votre premier projet django.</p>
<p><strong>Exemple sur windows :</strong></p>
<p>Ouvrez un shell, et placez vous dans votre dossier de travail, puis lancez la commande django-admin.py startproject</p>
<div class="codesnip-container" >cd c:\dev\django<br />
c:\dev\django&gt;c:\Python25\lib\site-packages\django\bin\django-admin.py startproject projet1</div>
<p>Un dossier &#8216;projet1&#8242; a été crée et contient les fichier de base :</p>
<ul>
<li><strong>settings.py :</strong> configuration du projt, base de données, emails&#8230;</li>
<li><strong>urls.py : </strong>la configuration des urls de votre projet</li>
<li><strong>manage.py : </strong>la commande qui permet de lancer le serveur, mettre a jour les bases et effectuer des opérations de maintenance.</li>
<li><strong>__init__.py :</strong> ce fichier permet simplement à Python d&#8217;interpréter le dossier en tant que &#8216;module&#8217;</li>
</ul>
<p>Pour développer un projet Django, utilisez le &#8217;serveur de dev&#8217; intégré (commande manage.py runserver), mais pour la production, vous devrez mettre en place <a href="http://code.djangoproject.com/wiki/django_apache_and_mod_wsgi" target="_blank">Apache+WSGI</a>, <a href="http://www.alrond.com/en/2007/mar/01/start-django-with-nginx/" target="_blank">Nginx</a> ou <a href="http://code.djangoproject.com/wiki/ServerArrangements" target="_blank">un autre serveur</a>.</p>
<p>Lancez le serveur pour vérifier que votre projet est bien crée :</p>
<div class="codesnip-container" >cd c:\dev\django<br />
c:\dev\django&gt;manage.py runserver<br />
Validating models&#8230;<br />
0 errors found<br />
Django version 1.0-alpha-SVN-8225, using settings &#8216;projet1.settings&#8217;<br />
Development server is running at http://127.0.0.1:8000/<br />
Quit the server with CTRL-BREAK.</div>
<p>Maintenant vous pouvez ouvrir votre browser à cette adresse : <a href="http://127.0.0.1:8000/" target="_blank">http://127.0.0.1:8000/</a></p>
<p>Modifiez le fichier settings.py, puis suivez le <a href="http://docs.django-fr.org/intro/tutorial01.html#creation-des-modeles" target="_blank">premier tutorial</a> pour commencer à faire joujou.</p>
<p>Je reviens prochainement  pour <a href="http://blog.revolunet.com/index.php/developpement/astuces-django">la suite</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/general/bien-demarrer-avec-django/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>rsync alternative for low cpus</title>
		<link>http://blog.revolunet.com/index.php/geek-style/rsync-alternative-for-low-cpus</link>
		<comments>http://blog.revolunet.com/index.php/geek-style/rsync-alternative-for-low-cpus#comments</comments>
		<pubDate>Thu, 02 Apr 2009 12:11:54 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[geek style]]></category>
		<category><![CDATA[shell]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=289</guid>
		<description><![CDATA[I had to transfer some +500Gb of data from an NTFS drive, using my QNAP TS409 PRO Nas external USB connector.
Using the integrated &#8220;hot copy button&#8221; or a simple rsync between the two drives, i only reached 2.5mb/s which is a pitty. In fact its the Qnap Cpu which is a pitty. (yes rsync is [...]]]></description>
			<content:encoded><![CDATA[<p>I had to transfer some +500Gb of data from an NTFS drive, using my QNAP TS409 PRO Nas external USB connector.</p>
<p>Using the integrated &#8220;hot copy button&#8221; or a simple rsync between the two drives, i only reached 2.5mb/s which is a pitty. In fact its the Qnap Cpu which is a pitty. (yes rsync is cpu consuming)</p>
<p>So inspired from <a href="http://discuss.joelonsoftware.com/default.asp?design.4.528600.11">http://discuss.joelonsoftware.com/default.asp?design.4.528600.11</a> i wrote a simple bash script to recursively copy a directory tree, but using cp instead of rsync. I can now reach 6.5mb/s which is 3 times faster.</p>
<p>So here it is : <a href="http://www.revolunet.com/static/download/labo/mysync.sh">http://www.revolunet.com/static/download/labo/mysync.sh</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/geek-style/rsync-alternative-for-low-cpus/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Fin de la passerelle MSN de jabber.fr</title>
		<link>http://blog.revolunet.com/index.php/general/fin-de-la-passerelle-msn-de-jabberfr</link>
		<comments>http://blog.revolunet.com/index.php/general/fin-de-la-passerelle-msn-de-jabberfr#comments</comments>
		<pubDate>Fri, 27 Feb 2009 16:22:59 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[Jabber]]></category>
		<category><![CDATA[actu informatique]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=282</guid>
		<description><![CDATA[A mon grand regret, les admins de jabber.fr ont décidé de mettre fin aux services des passerelles propriétaires sur le serveur jabber.fr.  Cela concerne bien sur MSN, mais aussi ICQ et AIM.
Cette décision, surtout politique, va obliger tous ceux qui ont migré sur jabber à changer de client (pour un client multi-protocoles) ou à s&#8217;inscrire [...]]]></description>
			<content:encoded><![CDATA[<p>A mon grand regret, les admins de jabber.fr ont <a href="http://jabber.apinc.org/news/?p=48" target="_blank">décidé de mettre fin aux services des passerelles propriétaires</a> sur le serveur jabber.fr.  Cela concerne bien sur MSN, mais aussi ICQ et AIM.</p>
<p>Cette décision, surtout politique, va obliger tous ceux qui ont migré sur jabber à changer de client (pour un client multi-protocoles) ou à s&#8217;inscrire sur une autre passerelle.</p>
<p>Si comme moi vous êtes un fan de <a href="http://psi-im.org/" target="_blank">PSI</a> , vous pouvez tout de même utiliser d&#8217;autres passerelles, comme par exemple celle de jabber.gnubox.net tout en gardant votre compte jabber actuel. </p>
<p>La passerelle MSN aura en tous cas rendu de bons et loyaux services pendant plusieurs années, meme s&#8217;il fallait la relancer 1 à 2 fois par semaine, ce qui est tout de meme toujours mieux que de faire tourner Live Messenger.</p>
<p>AMEN</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/general/fin-de-la-passerelle-msn-de-jabberfr/feed</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>WPF MediaElement + ASX workaround</title>
		<link>http://blog.revolunet.com/index.php/general/wpf-mediaelement-asx-workaround</link>
		<comments>http://blog.revolunet.com/index.php/general/wpf-mediaelement-asx-workaround#comments</comments>
		<pubDate>Fri, 13 Feb 2009 16:30:35 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[.NET]]></category>
		<category><![CDATA[General]]></category>
		<category><![CDATA[developpement]]></category>

		<guid isPermaLink="false">http://blog.revolunet.com/?p=272</guid>
		<description><![CDATA[This i my first English post so sorry for the poor english, and feel free to correct me  
I recently had to develop a multimedia XAML application  that plays Asx playlists with customs overlays and i faced to differents annoying, unresolved problems related to the MediaElement ASX handling. I discovered that the MediaElement behaves [...]]]></description>
			<content:encoded><![CDATA[<p>This i my first English post so sorry for the poor english, and feel free to correct me <img src='http://blog.revolunet.com/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>I recently had to develop a multimedia XAML application  that plays Asx playlists with customs overlays and i faced to differents annoying, unresolved problems related to the MediaElement ASX handling. I discovered that the MediaElement behaves very differently with medias played within an Asx and the same medias played direclty.</p>
<p>My four main problems were  :</p>
<ul>
<li>The MediaElement keeps the first Asx item aspect radio for the whole Asx. (cannot mix 4:3 and 16:9 medias)</li>
<li>If you add some still images in the Asx (jpeg), you cannot add animated overlays over it, because the animated items leave ugly black trails over the image&#8230; </li>
<li>The MediaElement doesnt play correctly WMV files inside an Asx. It stops before the end, and the Audio is a little bit desynchronised.</li>
<li>Maybe related to my last wmv playback problem, sometimes, even with &lt;REPEAT&gt; tags in the Asx, the MediaElement stops during a video.</li>
</ul>
<p>It took weeks to track and identify these problems&#8230;but if you test outside an Asx, all the problems go away, So its clearly related to MediaElement Asx handling. Problem is that MediaElement control is actually very limited.</p>
<p>So i finally decide to create a small AsxController class that simply parse an Asx file and control a specified MediaElement object. Its simple and it works like a charm. Supported Asx items are streams uri, files, but also still images with a specified duration. </p>
<p>Its written in VB.NET but you can easily translate it to C# or something else. It should be compatible with Silverlight.</p>
<p>Grab the source and example code here (rename to .vb) : <a title="AsxController.vb" href="http://blog.revolunet.com/wp-content/uploads/2009/02/asxcontroller.vb" target="_blank">AsxController.vb</a></p>
<p>Enjoy !</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.revolunet.com/index.php/general/wpf-mediaelement-asx-workaround/feed</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
	</channel>
</rss>

