{"id":93,"date":"2010-03-16T01:56:13","date_gmt":"2010-03-16T00:56:13","guid":{"rendered":"http:\/\/ban.free-h.net\/?p=93"},"modified":"2017-04-16T19:21:35","modified_gmt":"2017-04-16T17:21:35","slug":"ctpl-0-1-1-et-lavenir","status":"publish","type":"post","link":"https:\/\/ban.netlib.re\/blog\/ctpl-0-1-1-et-lavenir\/","title":{"rendered":"CTPL 0.1.1 et l&rsquo;avenir"},"content":{"rendered":"<p>Oui vous avez bien lu, <a href=\"http:\/\/ctpl.tuxfamily.org\/\">CTPL<\/a> 0.1.1 vient de sortir. Comme le num\u00e9ro de version le laisse supposer, c&rsquo;est une version mineure faisant suite \u00e0 la 0.1. Au menu : corrections de bugs, dont deux majeurs : <em>stack overflow<\/em> lors de la destruction d&rsquo;un tr\u00e8s grand arbre de <em>tokens<\/em> ; et acc\u00e9l\u00e9ration fulgurante de la cr\u00e9ation de grands arbres.<\/p>\n<h3>Quel futur pour CTPL ?<\/h3>\n<p>J&rsquo;ai en ce moment plusieurs id\u00e9es de ce qui pourrait peupler l&rsquo;avenir de CTPL, c&rsquo;est-\u00e0-dire de quoi y ajouter ou qu&rsquo;y changer. Voici quelques unes de ces id\u00e9es ; je vous invite bien entendu \u00e0 faire part de vos avis sur le sujet.<\/p>\n<h4>Utilisation GIO comme <em>I\/O layer<\/em><\/h4>\n<p>Je penses s\u00e9rieusement laisser tomber <a href=\"\/libmb\/\">LibMB<\/a> au profit de <a href=\"http:\/\/library.gnome.org\/devel\/gio\/unstable\/\">GIO<\/a>, qui dispose d&rsquo;un module d&rsquo;I\/O en m\u00e9moire, <a href=\"http:\/\/library.gnome.org\/devel\/gio\/unstable\/GMemoryInputStream.html\">GMemoryInputStream<\/a> et <a href=\"http:\/\/library.gnome.org\/devel\/gio\/unstable\/GMemoryOutputStream.html\">GMemoryOutputStream<\/a>. Pourquoi ? H\u00e9 bien principalement car ceci permettrai de g\u00e9rer implicitement toutes les sources de donn\u00e9es que GIO g\u00e8re \u00e0 travers les <a href=\"http:\/\/library.gnome.org\/devel\/gio\/unstable\/GInputStream.html\">flux d&rsquo;ent\u00e9e<\/a> et <a href=\"http:\/\/library.gnome.org\/devel\/gio\/unstable\/GOutputStream.html\">de sortie<\/a>, et ce directement, c&rsquo;est-\u00e0-dire sans forcement charger les donn\u00e9es en m\u00e9moire (donc utilisation m\u00e9moire plus faible pour l&rsquo;analyse \u2212 mais ne r\u00eavons pas : les <em>tokens<\/em> sont de toutes fa\u00e7ons charg\u00e9s en m\u00e9moire).<\/p>\n<h5><em>Pros<\/em><\/h5>\n<ul>\n<li>Analyse possible en <em>streaming<\/em> depuis un fichier (local, distant, tout ce que GIO supporte) ;<\/li>\n<li>Plus de d\u00e9pendance sur LibMB, mais sur GIO qui est quand-m\u00eame plus courant.<\/li>\n<\/ul>\n<h5><em>Cons<\/em><\/h5>\n<ul>\n<li>N\u00e9cessite de r\u00e9\u00e9crire une partie de la biblioth\u00e8que, en fait tout ce qui interagit directement avec les donn\u00e9es d&rsquo;entr\u00e9e et de sortie (la sortie devrait \u00eatre triviale \u00e0 changer, l&rsquo;entr\u00e9e beaucoup moins) plus ce dont j&rsquo;ai besoin mais qui n&rsquo;est pas dans l&rsquo;API GIO (manipulation plus ais\u00e9e qu&rsquo;\u00e0 uniques coups de <code>read()<\/code>) ;<\/li>\n<li>Peut-\u00eatre plus lent (rapport \u00e0 toute l&rsquo;abstraction et \u00e0 GObject) ?<\/li>\n<\/ul>\n<h4>Ajout du support de l&rsquo;assignation<\/h4>\n<p>Haha. Bon, \u00e7a j&rsquo;y penses \u00e0 moiti\u00e9, et \u00e0 moiti\u00e9 pas, particuli\u00e8rement \u00e0 cause de ses rares <em>pros<\/em> et nombreux <em>cons<\/em>.<\/p>\n<h5><em>Pros<\/em><\/h5>\n<ul>\n<li>\u00c7a serait cool.<\/li>\n<\/ul>\n<h5><em>Cons<\/em><\/h5>\n<ul>\n<li>\u00c7a ne sert sans doutes \u00e0 rien en fait ;<\/li>\n<li>Il serait sans doutes bien d&rsquo;avoir un vrai support des <em>scopes<\/em> avec ;<\/li>\n<li>\u00c7a n\u00e9cessite l&rsquo;un des points suivants :\n<ol>\n<li>Que toute assignation soit aussi ajout\u00e9e \u00e0 la sortie (<code>{a = b}<\/code> ajoute <code>b<\/code> \u00e0 la sortie, cool) ;<\/li>\n<li>Faire en sorte qu&rsquo;un op\u00e9rateur puisse ne rien retourner (ce qui n&rsquo;est ni pr\u00e9vu actuellement, ni n&rsquo;a de sens pour un autre op\u00e9rateur) ;<\/li>\n<li>Ajouter un moyen pour qu&rsquo;une partie des substitutions ne se retrouvent pas dans la sortie.<\/li>\n<\/ol>\n<p>La premi\u00e8re solution est facile \u00e0 impl\u00e9menter, mais forcement j&rsquo;ai un penchant pour la troisi\u00e8me puisque non seulement \u00e7a permet de ne pas \u00e9crire le r\u00e9sultat d&rsquo;une assignation dans la sortie, mais aussi de le faire, au choix. Oui, mais comment faire ? Ajouter un nouveau type de bloc ? Ajouter une sorte d&rsquo;op\u00e9rateur unaire \u00ab ne pas afficher \u00bb ? Bof bof\u2026<\/li>\n<\/ul>\n<h4>Ajout des cha\u00eenes litt\u00e9rales<\/h4>\n<p>Ceci permettrai l&rsquo;une ou l&rsquo;autre petite fantaisie comme la comparaison avec des variables de l&rsquo;environnement (<code>{if foo == \"some text\"}...<\/code>) ou de s&rsquo;amuser \u00e0 remplir la sortie de \u00ab lol \u00bb tr\u00e8s facilement (<code>{\"lol\" * 10000}<\/code>). Pas besoin de longue dissertation sur cette id\u00e9e-l\u00e0 : \u00e7a ne serait sans-doutes pas tr\u00e8s utile, et sans doutes pas tr\u00e8s complexe \u00e0 impl\u00e9menter (BTW, il y a d\u00e9j\u00e0 une branche pour \u00e7a, m\u00eame si je ne me souviens plus de son statut exact).<\/p>\n<h4>Conclusion<\/h4>\n<p>C&rsquo;est gentil les fonctionnalit\u00e9s, mais il faut peut-\u00eatre aussi se demander si \u00e7a vaut le coup\u00a0: utiliser GIO me semble assez int\u00e9ressant, mais les autres id\u00e9es plus discutables. Qu&rsquo;en pensez-vous, qu&rsquo;est-ce qu&rsquo;il vous serait agr\u00e9able ou utile de voir venir\u00a0?<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Oui vous avez bien lu, CTPL 0.1.1 vient de sortir. Comme le num\u00e9ro de version le laisse supposer, c&rsquo;est une version mineure faisant suite \u00e0 la 0.1. Au menu : corrections de bugs, dont deux majeurs : stack overflow lors de la destruction d&rsquo;un tr\u00e8s grand arbre de tokens ; et acc\u00e9l\u00e9ration fulgurante de la &hellip; <a href=\"https:\/\/ban.netlib.re\/blog\/ctpl-0-1-1-et-lavenir\/\" class=\"more-link\">Continuer la lecture de <span class=\"screen-reader-text\">CTPL 0.1.1 et l&rsquo;avenir<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[5,6],"tags":[9,11,19],"class_list":["post-93","post","type-post","status-publish","format-standard","hentry","category-informatique","category-logiciels-libres","tag-ctpl","tag-glib","tag-programmation"],"_links":{"self":[{"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/posts\/93","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/comments?post=93"}],"version-history":[{"count":1,"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/posts\/93\/revisions"}],"predecessor-version":[{"id":269,"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/posts\/93\/revisions\/269"}],"wp:attachment":[{"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/media?parent=93"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/categories?post=93"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ban.netlib.re\/blog\/wp-json\/wp\/v2\/tags?post=93"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}