Repository with sources and generator of https://larlet.fr/david/ https://larlet.fr/david/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.html 35KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585
  1. <!doctype html><!-- This is a valid HTML5 document. -->
  2. <!-- Screen readers, SEO, extensions and so on. -->
  3. <html lang="fr">
  4. <!-- Has to be within the first 1024 bytes, hence before the `title` element
  5. See: https://www.w3.org/TR/2012/CR-html5-20121217/document-metadata.html#charset -->
  6. <meta charset="utf-8">
  7. <!-- Why no `X-UA-Compatible` meta: https://stackoverflow.com/a/6771584 -->
  8. <!-- The viewport meta is quite crowded and we are responsible for that.
  9. See: https://codepen.io/tigt/post/meta-viewport-for-2015 -->
  10. <meta name="viewport" content="width=device-width,initial-scale=1">
  11. <!-- Required to make a valid HTML5 document. -->
  12. <title>Tag #gratitude — David Larlet</title>
  13. <meta name="description" content="Publications relatives au tag #gratitude">
  14. <!-- That good ol' feed, subscribe :). -->
  15. <link rel="alternate" type="application/atom+xml" title="Feed" href="/david/log/">
  16. <!-- Generated from https://realfavicongenerator.net/ such a mess. -->
  17. <link rel="apple-touch-icon" sizes="180x180" href="/static/david/icons2/apple-touch-icon.png">
  18. <link rel="icon" type="image/png" sizes="32x32" href="/static/david/icons2/favicon-32x32.png">
  19. <link rel="icon" type="image/png" sizes="16x16" href="/static/david/icons2/favicon-16x16.png">
  20. <link rel="manifest" href="/static/david/icons2/site.webmanifest">
  21. <link rel="mask-icon" href="/static/david/icons2/safari-pinned-tab.svg" color="#07486c">
  22. <link rel="shortcut icon" href="/static/david/icons2/favicon.ico">
  23. <meta name="msapplication-TileColor" content="#f7f7f7">
  24. <meta name="msapplication-config" content="/static/david/icons2/browserconfig.xml">
  25. <meta name="theme-color" content="#f7f7f7" media="(prefers-color-scheme: light)">
  26. <meta name="theme-color" content="#272727" media="(prefers-color-scheme: dark)">
  27. <!-- Documented, feel free to shoot an email. -->
  28. <link rel="stylesheet" href="/static/david/css/style_2021-01-20.css">
  29. <!-- See https://www.zachleat.com/web/comprehensive-webfonts/ for the trade-off. -->
  30. <link rel="preload" href="/static/david/css/fonts/triplicate_t4_poly_regular.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" crossorigin>
  31. <link rel="preload" href="/static/david/css/fonts/triplicate_t4_poly_bold.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" crossorigin>
  32. <link rel="preload" href="/static/david/css/fonts/triplicate_t4_poly_italic.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" crossorigin>
  33. <link rel="preload" href="/static/david/css/fonts/triplicate_t3_regular.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: dark)" crossorigin>
  34. <link rel="preload" href="/static/david/css/fonts/triplicate_t3_bold.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: dark)" crossorigin>
  35. <link rel="preload" href="/static/david/css/fonts/triplicate_t3_italic.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: dark)" crossorigin>
  36. <script>
  37. function toggleTheme(themeName) {
  38. document.documentElement.classList.toggle(
  39. 'forced-dark',
  40. themeName === 'dark'
  41. )
  42. document.documentElement.classList.toggle(
  43. 'forced-light',
  44. themeName === 'light'
  45. )
  46. }
  47. const selectedTheme = localStorage.getItem('theme')
  48. if (selectedTheme !== 'undefined') {
  49. toggleTheme(selectedTheme)
  50. }
  51. </script>
  52. <style type="text/css">
  53. details[open] summary {
  54. display: none;
  55. }
  56. </style>
  57. <body class="remarkdown h1-underline h2-underline h3-underline em-underscore hr-center ul-star pre-tick" data-instant-intensity="viewport-all">
  58. <header>
  59. <h1>Publications relatives au tag #gratitude</h1>
  60. </header>
  61. <nav>
  62. <p class="center">
  63. <a href="/david/" title="Aller à l’accueil"><svg class="icon icon-home">
  64. <use xlink:href="/static/david/icons2/symbol-defs-2021-12.svg#icon-home"></use>
  65. </svg> Accueil</a>
  66. • <a rel="tags" href="/david/#tags-2023" title="Liste de toutes les étiquettes"><svg class="icon icon-tags">
  67. <use xlink:href="/static/david/icons2/symbol-defs-2021-12.svg#icon-tags"></use>
  68. </svg> Étiquettes</a>
  69. </p>
  70. </nav>
  71. <hr>
  72. <main>
  73. <p>Les plus récentes en premier, les 3 premières sont dépliées et ensuite c’est à la demande, bonne exploration !</p>
  74. <h2><a href="/david/2023/02/07/" title="Lien permanent vers cet article">Madeleine</a> (2023-02-07)</h2>
  75. <p>Ma madeleine du jour m’a été offerte par <a href="https://latitude77.org">Aurélien</a> qui pointait vers <a href="https://lightdock.org/">LightDock</a>, ce qui m’a rappelé mon stage de master et mes <a href="/david/biologeek/archives/20051017-parser-un-fichier-pdb-en-python-facilement-et-efficacement/">premiers pas en Python</a>. Où l’on remarque qu’il y a 18&nbsp;ans, les <em>list-comprehensions</em> et les <code>__methodes_magiques__</code> devaient être&nbsp;récentes…</p>
  76. <p>Mais au fait, que s’est-il passé ces 20&nbsp;dernières années en bio-informatique&#8239;? Est-ce encore une matière (hybride) à part entière ou le <em>in silico</em> a-t-il fini par bouffer la&nbsp;madeleine&#8239;?</p>
  77. <hr />
  78. <p>🚲 Où j’apprends que la piste cyclable en bas de chez moi est considéré comme «&nbsp;bonne&nbsp;» <a href="https://numerique.banq.qc.ca/patrimoine/details/52327/3393377">depuis pas mal de temps</a>.</p>
  79. <hr />
  80. <blockquote>
  81. <p>🌱 J’ai fait des études d’agriculture biologique et ce milieu m’a dégoûté. On est dans la production. Et dans la production, soit tu t’auto-exploites, soit tu exploites de la main-d’oeuvre. <mark>Dans le bio, l’essentiel de la main-d’oeuvre, ce sont des sans-papiers.</mark> Cette réalité embarrasse énormément ceux qui croient que le bio est le summum de l’alternative. À une époque, avec des copains, on avait organisé des dépôts de paniers de légumes à Bruxelles. On est allé travailler dans le lieu de production situé à une vingtaine de kilomètres de Bruxelles. On s’est retrouvé avec des sans-papiers. Les dessous de la production échappent aux radars. Pourtant, en y réfléchissant, si les gens étaient payés décemment, c’est le quadruple du prix qu’on devrait payer. Eux, aux Fraternités ouvrières, ils ne font pas de la production. Ils n’essaient pas de te vendre une production éthique ou biologique. Ils te disent&nbsp;: «&nbsp;Vas-y, expérimente&nbsp;». C’est une incitation à expérimenter&nbsp;l’autonomie.</p>
  82. <p><cite><em><a href="https://www.rayonvertcinema.org/benjamin-hennot-interview/">Benjamin Hennot&nbsp;: Interview</a></em>&nbsp;(<a href="/david/cache/2023/ee7eb9c245d1b2c4b91b8dda4cd7d318/">cache</a>)</cite></p>
  83. </blockquote>
  84. <blockquote lang="en">
  85. <p>🎯 No, we need to move our attention back to the folks that have been right all along. The people who never gave up on semantic markup, CSS, and progressive enhancement for most sites. The people who, when slinging JS, have treated it as special occasion food. <mark>The tools and communities whose culture puts the user ahead of the developer</mark> and hold evidence of doing better for users in the highest&nbsp;regard.</p>
  86. <p><cite><em><a href="https://infrequently.org/2023/02/the-market-for-lemons/">The Market for Lemons</a></em>&nbsp;(<a href="/david/cache/2023/5b35e3f3639ceb7d9f684aa81979f304/">cache</a>)</cite></p>
  87. </blockquote>
  88. <blockquote lang="en">
  89. <p>✍️ To feed my blogging, I am constantly reading books, magazine articles, academic papers, and a sprawling network of blogs (I follow about 400&nbsp;via my RSS feed on Feedly). Much as writing catalyzes thinking, <mark>reading catalyzes writing;</mark> the vast majority of ideas I get for blog posts come from reading something and having it trigger a “wait, what about …”&nbsp;moment.</p>
  90. <p><cite><em><a href="https://clivethompson.medium.com/how-blogging-changes-the-way-you-think-526734dc86d1">How Blogging Changes The Way You Think</a></em>&nbsp;(<a href="/david/cache/2023/9caf3cf36d339cfffad8582583493204/">cache</a>)</cite></p>
  91. </blockquote>
  92. <hr />
  93. <blockquote lang="en">
  94. <p>🙈 Wikis, unless you have someone whose job it is to maintain the wiki, is where knowledge goes to&nbsp;die</p>
  95. <p><cite><em><a href="https://cloudisland.nz/@aurynn/109808680824741796">@aurynn@cloudisland.nz sur&nbsp;mastodon</a></em></cite></p>
  96. </blockquote>
  97. <blockquote>
  98. <p>🤯 une voiture, c’est jamais qu’un gros fauteuil roulant, hein.</p>
  99. <p><cite><em><a href="https://mamot.fr/@ffoodd/109796035120760099">@ffoodd@mamot.fr sur&nbsp;mastodon</a></em></cite></p>
  100. </blockquote>
  101. <blockquote lang="en">
  102. <p>👀 I have been in tech so long, I only have one question when I hear of a new invention.<br />
  103. Will it be used for war, porn or&nbsp;surveillance?</p>
  104. <p><cite><em><a href="https://eupolicy.social/@why0hy/109749311459562949">@why0hy@eupolicy.social sur&nbsp;mastodon</a></em></cite></p>
  105. </blockquote>
  106. <h2><a href="/david/2023/01/18/" title="Lien permanent vers cet article">Femmes</a> (2023-01-18)</h2>
  107. <p>Ces dernières années, je communique avec davantage de femmes que d’hommes au cours de mes journées de travail. Ce qui a commencé comme une opportunité est maintenant un choix délibéré, je ne souhaite plus participer à des équipes uniquement constituées d’hommes. Ça peut —&nbsp;malheureusement&nbsp;— paraitre flippant exprimé ainsi et ce n’est qu’un premier pas sur ce chemin de traverse au sein d’un écosystème majoritairement masculin. Il ne suffit pas d’être différemment entouré, il faut aussi apprendre à se taire et&nbsp;écouter.</p>
  108. <p>Accepter que les solutions ne soient pas forcément techniques, que ce ne soient même pas des «&nbsp;solutions&nbsp;» en fait mais une suite de prises de soin. Partager des points de vues sur les oppressions et des situations vécues qui font prendre conscience de ses propres privilèges. Découvrir qu’il n’y a pas vraiment d’environnements <em>safe</em> en fait, jamais. Apprendre à se méfier de ses propres biais et interprétations, à déceler ce qui est ressenti comme des agressions, à confier ses doutes sur de potentielles&nbsp;indélicatesses.</p>
  109. <p>Cette évolution remet aussi en question les dynamiques de groupes que l’on peut observer et ce qui est acceptable ou non. Il y a des postures qui deviennent beaucoup plus rapidement intolérables. Des incohérences entre les aspirations/publications et les situations qui font grincer des dents, fort. Je me sens parfois encore bien faible et démuni face à cela. Et je sais pourtant que ça n’est rien comparé à l’épuisement d’un quotidien dans une société patriarcale. Alors je prends le temps et je donne ce que je peux d’attention, de confiance et&nbsp;d’énergie.</p>
  110. <p>Ces environnements et échanges m’apportent tellement. <strong>Merci.</strong></p>
  111. <hr />
  112. <p>Bande son du jour&nbsp;: <a href="https://www.youtube-nocookie.com/embed/OZHSCZRs1LI">Elisapie</a>.</p>
  113. <p>Citation du&nbsp;jour&nbsp;:</p>
  114. <blockquote>
  115. <p>Un grand pouvoir implique une grande&nbsp;corruption.</p>
  116. </blockquote>
  117. <h2><a href="/david/2023/01/17/" title="Lien permanent vers cet article">Populaire</a> (2023-01-17)</h2>
  118. <p>Plus j’en fais et plus je considère que le ski de fond est un sport populaire (dans le sens «&nbsp;pour le peuple&nbsp;»). Très peu d’équipement est nécessaire et même de la récupération permet de s’amuser, le façonnage des pistes requiert relativement peu d’énergies (fossiles), il est possible d’en faire même en étant très débutant·e et pas à l’aise avec les pentes. Ça devrait être une politique de santé&nbsp;publique&#8239;!</p>
  119. <p>Alors bien sûr, un bon équipement change des choses mais la technique et l’expérience compensent tellement que ça en devient presque négligeable (en loisir). Tout le monde peut se mettre dans les rails et pousser un pied devant l’autre. Bon OK, juste à côté. C’est un excellent moyen de se mettre en confiance avant d’oser glisser. Et puis, le pas s’allonge, les bras se décrispent et se mettent en mouvement aussi, les cuisses prennent le relai, les pieds se&nbsp;soulèvent.</p>
  120. <p>Lorsqu’on commence à glisser et à trouver l’équilibre, le point d’accroche, le mouvement juste, ça procure une sensation de vol incroyable et ça permet de suer en continu (autant que la course mais avec moins d’impacts). Le matériel est léger et plutôt silencieux, les pratiquant·es courtois·es (et âgé·es, <a href="/david/2021/02/10/">en tout cas l’après-midi</a>).</p>
  121. <p>Je n’en dis pas plus… il risquerait d’y avoir trop de monde dans les&nbsp;traces&nbsp;😅.</p>
  122. <p>PS&nbsp;: j’ai une petite (8&#8239;km, hamster-style) piste à 250&nbsp;mètres de chez moi et je suis tellement reconnaissant à la ville de Montréal d’aménager les parcs et pistes cyclables en hiver pour glisser dans la nature&nbsp;urbaine&nbsp;💚.</p>
  123. <figure>
  124. <a href="#2023-01-13-ski-visitation1"
  125. title="Cliquer pour une version haute résolution">
  126. <picture>
  127. <source
  128. srcset="/static/david/2023/2023-01-13-ski-visitation1.webp 2048w"
  129. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  130. type="image/webp">
  131. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  132. <img
  133. src="/static/david/2023/2023-01-13-ski-visitation1.jpg"
  134. width="2048" height="2731"
  135. srcset="/static/david/2023/2023-01-13-ski-visitation1.jpg 2048w"
  136. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  137. fetchpriority="high"
  138. decoding="sync"
  139. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  140. </picture>
  141. </a>
  142. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation1">
  143. <picture style="margin:0 auto;">
  144. <source
  145. srcset="/static/david/2023/2023-01-13-ski-visitation1.webp 2048w"
  146. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  147. type="image/webp">
  148. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  149. <img
  150. src="/static/david/2023/2023-01-13-ski-visitation1.jpg"
  151. width="2048" height="2731"
  152. srcset="/static/david/2023/2023-01-13-ski-visitation1.jpg 2048w"
  153. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  154. fetchpriority="high"
  155. decoding="sync"
  156. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  157. </picture>
  158. </a>
  159. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  160. </figure>
  161. <figure>
  162. <a href="#2023-01-13-ski-visitation2"
  163. title="Cliquer pour une version haute résolution">
  164. <picture>
  165. <source
  166. srcset="/static/david/2023/2023-01-13-ski-visitation2.webp 2048w"
  167. sizes="min(100vw, calc(100vh * 2048 / 1536))"
  168. type="image/webp">
  169. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  170. <img
  171. src="/static/david/2023/2023-01-13-ski-visitation2.jpg"
  172. width="2048" height="1536"
  173. srcset="/static/david/2023/2023-01-13-ski-visitation2.jpg 2048w"
  174. sizes="min(100vw, calc(100vh * 2048 / 1536))"
  175. fetchpriority="high"
  176. decoding="sync"
  177. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  178. </picture>
  179. </a>
  180. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation2">
  181. <picture style="margin:0 auto;">
  182. <source
  183. srcset="/static/david/2023/2023-01-13-ski-visitation2.webp 2048w"
  184. sizes="min(100vw, calc(100vh * 2048 / 1536))"
  185. type="image/webp">
  186. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  187. <img
  188. src="/static/david/2023/2023-01-13-ski-visitation2.jpg"
  189. width="2048" height="1536"
  190. srcset="/static/david/2023/2023-01-13-ski-visitation2.jpg 2048w"
  191. sizes="min(100vw, calc(100vh * 2048 / 1536))"
  192. fetchpriority="high"
  193. decoding="sync"
  194. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  195. </picture>
  196. </a>
  197. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  198. </figure>
  199. <figure>
  200. <a href="#2023-01-13-ski-visitation3"
  201. title="Cliquer pour une version haute résolution">
  202. <picture>
  203. <source
  204. srcset="/static/david/2023/2023-01-13-ski-visitation3.webp 2048w"
  205. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  206. type="image/webp">
  207. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  208. <img
  209. src="/static/david/2023/2023-01-13-ski-visitation3.jpg"
  210. width="2048" height="2731"
  211. srcset="/static/david/2023/2023-01-13-ski-visitation3.jpg 2048w"
  212. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  213. fetchpriority="high"
  214. decoding="sync"
  215. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  216. </picture>
  217. </a>
  218. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation3">
  219. <picture style="margin:0 auto;">
  220. <source
  221. srcset="/static/david/2023/2023-01-13-ski-visitation3.webp 2048w"
  222. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  223. type="image/webp">
  224. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  225. <img
  226. src="/static/david/2023/2023-01-13-ski-visitation3.jpg"
  227. width="2048" height="2731"
  228. srcset="/static/david/2023/2023-01-13-ski-visitation3.jpg 2048w"
  229. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  230. fetchpriority="high"
  231. decoding="sync"
  232. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  233. </picture>
  234. </a>
  235. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  236. </figure>
  237. <figure>
  238. <a href="#2023-01-13-ski-visitation4"
  239. title="Cliquer pour une version haute résolution">
  240. <picture>
  241. <source
  242. srcset="/static/david/2023/2023-01-13-ski-visitation4.webp 2048w"
  243. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  244. type="image/webp">
  245. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  246. <img
  247. src="/static/david/2023/2023-01-13-ski-visitation4.jpg"
  248. width="2048" height="2731"
  249. srcset="/static/david/2023/2023-01-13-ski-visitation4.jpg 2048w"
  250. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  251. fetchpriority="high"
  252. decoding="sync"
  253. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  254. </picture>
  255. </a>
  256. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation4">
  257. <picture style="margin:0 auto;">
  258. <source
  259. srcset="/static/david/2023/2023-01-13-ski-visitation4.webp 2048w"
  260. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  261. type="image/webp">
  262. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  263. <img
  264. src="/static/david/2023/2023-01-13-ski-visitation4.jpg"
  265. width="2048" height="2731"
  266. srcset="/static/david/2023/2023-01-13-ski-visitation4.jpg 2048w"
  267. sizes="min(100vw, calc(100vh * 2048 / 2731))"
  268. fetchpriority="high"
  269. decoding="sync"
  270. alt="Des traces de piste de ski de fond dans la tempête de neige.">
  271. </picture>
  272. </a>
  273. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  274. </figure>
  275. <hr />
  276. <blockquote>
  277. <p>Et si l’attachement à la retraite des Français ne tenait plus à l’attente d’un repos ultime au terme d’une vie laborieuse et pénible, mais à la possibilité de <mark>faire retraite dès maintenant</mark> pour se réinventer dans un travail&nbsp;«&nbsp;amélioré&nbsp;»&#8239;?</p>
  278. <p><cite><em><a href="https://www.philomag.com/articles/retraite-la-fin-du-bonheur-differe-par-denis-maillard">Retraite&nbsp;: la fin du “bonheur différé”, par Denis Maillard</a></em>&nbsp;(<a href="/david/cache/2023/614fe609b04719e7835fc0717b99c1c6/">cache</a>)</cite></p>
  279. </blockquote>
  280. <h2><a href="/david/2023/01/14/" title="Lien permanent vers cet article">Dépendances</a> (2023-01-14)</h2>
  281. <details>
  282. <summary>Déplier pour lire le contenu de la publication</summary>
  283. <blockquote lang="en">
  284. <p>I suspect one of the reasons for this is that Pinafore is written in Svelte v2 and Sapper – both of which are deprecated in favor of Svelte v3 and SvelteKit. Not only is there no migration path from Svelte v2 to v3, but there isn’t one from Sapper to SvelteKit either. (And on top of that, I had to fork Sapper pretty heavily.) Anyone making a bet on learning Pinafore’s tech stack is investing in a dead framework, so <mark>it’s not very attractive for new&nbsp;maintainers.</mark></p>
  285. <p><cite><em><a href="https://nolanlawson.com/2023/01/09/retiring-pinafore/">Retiring Pinafore</a></em>&nbsp;(<a href="/david/cache/2023/b5acd8bbf209345ff300ea8c10c44181/">cache</a>)</cite></p>
  286. </blockquote>
  287. <p>«&nbsp;<span lang=en>Move fast and outdate things.</span>&nbsp;» n’est pas un <em>motto</em> mais une constatation. Je suis assez assidu des écrits de Baldur Bjarnason à ce sujet, que ce soit à travers son <a href="https://www.baldurbjarnason.com/">site</a>, son <a href="https://softwarecrisis.baldurbjarnason.com/">livre</a> ou sa <a href="https://softwarecrisis.dev/">newsletter</a>.</p>
  288. <p>Je crois que je commence à dépasser la sidération et le rejet pour tenter de comprendre un peu mieux les raisons profondes de toute cette complexité et cette vitesse que l’on s’impose, avec une composante historique&nbsp;notamment.</p>
  289. <p>2023, l’année de la maturité&nbsp;😂.</p>
  290. <blockquote lang="en">
  291. <p>The symptoms of pop&nbsp;culture:</p>
  292. <ul>
  293. <li>A “disdain for history”. Pop cultures believe history doesn’t have anything to teach&nbsp;them.</li>
  294. <li>Newer is automatically better. Pop cultures are built on the assumption that anything new or different is superior to established. Or, in other words, older is inherently&nbsp;inferior.</li>
  295. <li><mark>What’s next is going to be superior to what’s now.</mark> Pop cultures exist in perpetual anticipation of the next trend. Their disbelief of history appears to outsiders as a belief in&nbsp;progress.</li>
  296. <li>The “Pop” in “Pop Culture” stands for “popularity”. If it’s popular then it must be&nbsp;right.</li>
  297. </ul>
  298. <p>These traits are deeply irrational but they are the tech industry’s default mode of&nbsp;operation.</p>
  299. <p><cite><em><a href="https://softwarecrisis.dev/letters/tech-is-a-pop-culture/">Tech Companies Are Irrational Pop Cultures</a></em>&nbsp;(<a href="/david/cache/2023/45c1becce6fcd8254f2c99fbc1397018/">cache</a>)</cite></p>
  300. </blockquote>
  301. <hr />
  302. <blockquote lang="en">
  303. <p>We’re starting to see the initial decay hit the parts of the web dev ecosystem that are the furthest away from the cheap money fountains Google and Facebook are providing. Core projects run out of money. Git commits stop. <mark>A dependency you use breaks when one of its dependencies stops working,</mark> leading somebody to fork it with a quick fix or replacement dependency. Bandaid fixes to decaying OSS projects start to crop up in more and more places. We start to see blog posts saying that all we need to do is get enough people to donate money or pay for support. Everything will be fine. Just look at how OpenSSL got turned&nbsp;around.</p>
  304. <p>All of which is bad enough but also misses the&nbsp;point.</p>
  305. <p><cite><em><a href="https://www.baldurbjarnason.com/2021/the-oss-bubble-and-the-blogging-bubble/">The Open-Source Software bubble that is and the blogging bubble that was</a></em>&nbsp;(<a href="/david/cache/2023/d6b891fd250a6ae967ae55564770b67a/">cache</a>)</cite></p>
  306. </blockquote>
  307. <blockquote>
  308. <p>This JavaScript community (if judged by the demographics of this survey) seems to be comprised mostly of folks that are largely building with React, webpack, and Jest. With React on 3.2% of web sites and jQuery at 77.7% (as of January 2023), <mark>that’s a pretty small slice of a much larger&nbsp;community.</mark></p>
  309. <p>We seem to live in different&nbsp;worlds.</p>
  310. <p><cite><em><a href="https://www.zachleat.com/web/javascript-community/">JavaScript, Community</a></em>&nbsp;(<a href="/david/cache/2023/7ff62009f21336b8eb54ea18261bcfb7/">cache</a>)</cite></p>
  311. </blockquote>
  312. </details>
  313. <h2><a href="/david/2023/01/06/" title="Lien permanent vers cet article">Toile</a> (2023-01-06)</h2>
  314. <details>
  315. <summary>Déplier pour lire le contenu de la publication</summary>
  316. <blockquote lang="en">
  317. <p>I realised when I think of something it doesn’t exist as a single entity. A thought is linked to a million other thoughts, to the past and to the future. I remember too much, relate too much, <mark>connect too much,</mark> and I project too much. I thought this was “normal” until I met my partner. She doesn’t think much about the future or the past – she’s a much happier person compared to&nbsp;me.</p>
  318. <p><cite><em><a href="https://winnielim.org/journal/my-mind-is-full-of-webs/">my mind is full of webs</a></em>&nbsp;(<a href="/david/cache/2023/e1a26da20c603d214d0f844d5836569e/">cache</a>)</cite></p>
  319. </blockquote>
  320. <p>Il y a tellement de choses qui me font réagir (ré-penser plutôt&#8239;?) dans les écrits de Winnie Lim. Elle joue toujours avec la corde sensible qui crée un lien à la fois fragile et pourtant si résistant, je me l’imagine comme un fil de toile d’araignée entre nous. Difficile à décrire et pas forcément réciproque. De temps en temps, je m’aventure dessus et je vais me désaltérer de quelques gouttes de rosée. Je suis reconnaissant de ces partages qui viennent alimenter mes propres&nbsp;réflexions.</p>
  321. <blockquote lang="en">
  322. <p>But I do not want my webs to be truncated or forgotten. <mark>I do not wish to forget,</mark> or I wouldn’t have become obsessed with archival. I like noticing and preserving the connections. They become opportunities for learning and becoming, if I manage to detach enough from&nbsp;them.</p>
  323. <p><cite><em>Ibid.</em></cite></p>
  324. </blockquote>
  325. <figure>
  326. <a href="#2023-01-06-toile-gouttes"
  327. title="Cliquer pour une version haute résolution">
  328. <picture>
  329. <source
  330. srcset="/static/david/2023/2023-01-06-toile-gouttes.webp 3024w"
  331. sizes="min(100vw, calc(100vh * 3024 / 4032))"
  332. type="image/webp">
  333. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  334. <img
  335. src="/static/david/2023/2023-01-06-toile-gouttes.jpg"
  336. width="3024" height="4032"
  337. srcset="/static/david/2023/2023-01-06-toile-gouttes.jpg 3024w"
  338. sizes="min(100vw, calc(100vh * 3024 / 4032))"
  339. fetchpriority="high"
  340. decoding="sync"
  341. alt="Une toile d’araignée avec des gouttes de rosée et en arrière plan, flou, des immeubles de l’autre côté de la Rivière des Prairies">
  342. </picture>
  343. </a>
  344. <a href="#_" class="lightbox" id="2023-01-06-toile-gouttes">
  345. <picture style="margin:0 auto;">
  346. <source
  347. srcset="/static/david/2023/2023-01-06-toile-gouttes.webp 3024w"
  348. sizes="min(100vw, calc(100vh * 3024 / 4032))"
  349. type="image/webp">
  350. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  351. <img
  352. src="/static/david/2023/2023-01-06-toile-gouttes.jpg"
  353. width="3024" height="4032"
  354. srcset="/static/david/2023/2023-01-06-toile-gouttes.jpg 3024w"
  355. sizes="min(100vw, calc(100vh * 3024 / 4032))"
  356. fetchpriority="high"
  357. decoding="sync"
  358. alt="Une toile d’araignée avec des gouttes de rosée et en arrière plan, flou, des immeubles de l’autre côté de la Rivière des Prairies">
  359. </picture>
  360. </a>
  361. <figcaption>Parc Louis-Hébert, Montréal, 2 novembre&nbsp;2022.</figcaption>
  362. </figure>
  363. <details>
  364. <summary>Et pendant ce temps là de l’autre côté de la rue&nbsp;:</summary>
  365. <figure>
  366. <a href="#2023-01-06-toile-soleil"
  367. title="Cliquer pour une version haute résolution">
  368. <picture>
  369. <source
  370. srcset="/static/david/2023/2023-01-06-toile-soleil.webp 4032w"
  371. sizes="min(100vw, calc(100vh * 4032 / 3024))"
  372. type="image/webp">
  373. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  374. <img
  375. src="/static/david/2023/2023-01-06-toile-soleil.jpg"
  376. width="4032" height="3024"
  377. srcset="/static/david/2023/2023-01-06-toile-soleil.jpg 4032w"
  378. sizes="min(100vw, calc(100vh * 4032 / 3024))"
  379. fetchpriority="high"
  380. decoding="sync"
  381. alt="Un parc pour enfant à contre-jour avec le soleil qui se lève dans le brouillard et qui forme une jolie étoile">
  382. </picture>
  383. </a>
  384. <a href="#_" class="lightbox" id="2023-01-06-toile-soleil">
  385. <picture style="margin:0 auto;">
  386. <source
  387. srcset="/static/david/2023/2023-01-06-toile-soleil.webp 4032w"
  388. sizes="min(100vw, calc(100vh * 4032 / 3024))"
  389. type="image/webp">
  390. <!-- The <img> tag is a fallback image (required in the <picture> tag) -->
  391. <img
  392. src="/static/david/2023/2023-01-06-toile-soleil.jpg"
  393. width="4032" height="3024"
  394. srcset="/static/david/2023/2023-01-06-toile-soleil.jpg 4032w"
  395. sizes="min(100vw, calc(100vh * 4032 / 3024))"
  396. fetchpriority="high"
  397. decoding="sync"
  398. alt="Un parc pour enfant à contre-jour avec le soleil qui se lève dans le brouillard et qui forme une jolie étoile">
  399. </picture>
  400. </a>
  401. <figcaption>Une toile de soleil&nbsp;!</figcaption>
  402. </figure>
  403. </details>
  404. </details>
  405. </main>
  406. <hr>
  407. <footer>
  408. <p>
  409. <nobr>
  410. <a href="/david/" title="Aller à l’accueil"
  411. ><svg class="icon icon-home">
  412. <use
  413. xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-home"
  414. ></use>
  415. </svg>
  416. Accueil</a
  417. >
  418. </nobr>
  419. <nobr>
  420. <a href="/david/log/" title="Accès au flux RSS"
  421. ><svg class="icon icon-rss2">
  422. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-rss2"></use>
  423. </svg>
  424. Suivre</a
  425. >
  426. </nobr>
  427. <nobr>
  428. <a href="http://larlet.com" title="Go to my English profile" data-instant
  429. ><svg class="icon icon-user-tie">
  430. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-user-tie"></use>
  431. </svg>
  432. Pro</a
  433. >
  434. </nobr>
  435. <nobr>
  436. <a href="mailto:david%40larlet.fr" title="Envoyer un courriel"
  437. ><svg class="icon icon-mail">
  438. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-mail"></use>
  439. </svg>
  440. Email</a
  441. >
  442. </nobr>
  443. <nobr>
  444. <abbr
  445. class="nowrap"
  446. title="Hébergeur : Alwaysdata, 62 rue Tiquetonne 75002 Paris, +33184162340"
  447. ><svg class="icon icon-hammer2">
  448. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-hammer2"></use>
  449. </svg>
  450. Légal</abbr
  451. >
  452. </nobr>
  453. </p>
  454. <template id="theme-selector">
  455. <form>
  456. <fieldset>
  457. <legend><svg class="icon icon-brightness-contrast">
  458. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-brightness-contrast"></use>
  459. </svg> Thème</legend>
  460. <label>
  461. <input type="radio" value="auto" name="chosen-color-scheme" checked> Auto
  462. </label>
  463. <label>
  464. <input type="radio" value="dark" name="chosen-color-scheme"> Foncé
  465. </label>
  466. <label>
  467. <input type="radio" value="light" name="chosen-color-scheme"> Clair
  468. </label>
  469. </fieldset>
  470. </form>
  471. </template>
  472. </footer>
  473. <script src="/static/david/js/instantpage-5.1.0.min.js" type="module"></script>
  474. <script>
  475. function loadThemeForm(templateName) {
  476. const themeSelectorTemplate = document.querySelector(templateName)
  477. const form = themeSelectorTemplate.content.firstElementChild
  478. themeSelectorTemplate.replaceWith(form)
  479. form.addEventListener('change', (e) => {
  480. const chosenColorScheme = e.target.value
  481. localStorage.setItem('theme', chosenColorScheme)
  482. toggleTheme(chosenColorScheme)
  483. })
  484. const selectedTheme = localStorage.getItem('theme')
  485. if (selectedTheme && selectedTheme !== 'undefined') {
  486. form.querySelector(`[value="${selectedTheme}"]`).checked = true
  487. }
  488. }
  489. const prefersColorSchemeDark = '(prefers-color-scheme: dark)'
  490. window.addEventListener('load', () => {
  491. let hasDarkRules = false
  492. for (const styleSheet of Array.from(document.styleSheets)) {
  493. let mediaRules = []
  494. for (const cssRule of styleSheet.cssRules) {
  495. if (cssRule.type !== CSSRule.MEDIA_RULE) {
  496. continue
  497. }
  498. // WARNING: Safari does not have/supports `conditionText`.
  499. if (cssRule.conditionText) {
  500. if (cssRule.conditionText !== prefersColorSchemeDark) {
  501. continue
  502. }
  503. } else {
  504. if (cssRule.cssText.startsWith(prefersColorSchemeDark)) {
  505. continue
  506. }
  507. }
  508. mediaRules = mediaRules.concat(Array.from(cssRule.cssRules))
  509. }
  510. // WARNING: do not try to insert a Rule to a styleSheet you are
  511. // currently iterating on, otherwise the browser will be stuck
  512. // in a infinite loop…
  513. for (const mediaRule of mediaRules) {
  514. styleSheet.insertRule(mediaRule.cssText)
  515. hasDarkRules = true
  516. }
  517. }
  518. if (hasDarkRules) {
  519. loadThemeForm('#theme-selector')
  520. }
  521. })
  522. </script>
  523. </body>
  524. </html>