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 21KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  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/01/17/" title="Lien permanent vers cet article">Populaire</a> (2023-01-17)</h2>
  75. <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>
  76. <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>
  77. <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>
  78. <p>Je n’en dis pas plus… il risquerait d’y avoir trop de monde dans les&nbsp;traces&nbsp;😅.</p>
  79. <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>
  80. <figure>
  81. <a href="#2023-01-13-ski-visitation1"
  82. title="Cliquer pour une version haute résolution">
  83. <img src="/static/david/2023/2023-01-13-ski-visitation1.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  84. loading="lazy" width="2048" height="2731" />
  85. </a>
  86. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation1">
  87. <img src="/static/david/2023/2023-01-13-ski-visitation1.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  88. loading="lazy" width="2048" height="2731" />
  89. </a>
  90. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  91. </figure>
  92. <figure>
  93. <a href="#2023-01-13-ski-visitation2"
  94. title="Cliquer pour une version haute résolution">
  95. <img src="/static/david/2023/2023-01-13-ski-visitation2.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  96. loading="lazy" width="2048" height="1536" />
  97. </a>
  98. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation2">
  99. <img src="/static/david/2023/2023-01-13-ski-visitation2.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  100. loading="lazy" width="2048" height="1536" />
  101. </a>
  102. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  103. </figure>
  104. <figure>
  105. <a href="#2023-01-13-ski-visitation3"
  106. title="Cliquer pour une version haute résolution">
  107. <img src="/static/david/2023/2023-01-13-ski-visitation3.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  108. loading="lazy" width="2048" height="2731" />
  109. </a>
  110. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation3">
  111. <img src="/static/david/2023/2023-01-13-ski-visitation3.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  112. loading="lazy" width="2048" height="2731" />
  113. </a>
  114. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  115. </figure>
  116. <figure>
  117. <a href="#2023-01-13-ski-visitation4"
  118. title="Cliquer pour une version haute résolution">
  119. <img src="/static/david/2023/2023-01-13-ski-visitation4.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  120. loading="lazy" width="2048" height="2731" />
  121. </a>
  122. <a href="#_" class="lightbox" id="2023-01-13-ski-visitation4">
  123. <img src="/static/david/2023/2023-01-13-ski-visitation4.jpg" alt="Des traces de piste de ski de fond dans la tempête de neige."
  124. loading="lazy" width="2048" height="2731" />
  125. </a>
  126. <figcaption>Parc de l’Île de la Visitation, Montréal, 13 janvier&nbsp;2023.</figcaption>
  127. </figure>
  128. <hr />
  129. <blockquote>
  130. <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>
  131. <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>
  132. </blockquote>
  133. <h2><a href="/david/2023/01/14/" title="Lien permanent vers cet article">Dépendances</a> (2023-01-14)</h2>
  134. <blockquote lang="en">
  135. <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>
  136. <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>
  137. </blockquote>
  138. <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>
  139. <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>
  140. <p>2023, l’année de la maturité&nbsp;😂.</p>
  141. <blockquote lang="en">
  142. <p>The symptoms of pop&nbsp;culture:</p>
  143. <ul>
  144. <li>A “disdain for history”. Pop cultures believe history doesn’t have anything to teach&nbsp;them.</li>
  145. <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>
  146. <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>
  147. <li>The “Pop” in “Pop Culture” stands for “popularity”. If it’s popular then it must be&nbsp;right.</li>
  148. </ul>
  149. <p>These traits are deeply irrational but they are the tech industry’s default mode of&nbsp;operation.</p>
  150. <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>
  151. </blockquote>
  152. <hr />
  153. <blockquote lang="en">
  154. <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>
  155. <p>All of which is bad enough but also misses the&nbsp;point.</p>
  156. <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>
  157. </blockquote>
  158. <blockquote>
  159. <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>
  160. <p>We seem to live in different&nbsp;worlds.</p>
  161. <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>
  162. </blockquote>
  163. <h2><a href="/david/2023/01/06/" title="Lien permanent vers cet article">Toile</a> (2023-01-06)</h2>
  164. <blockquote lang="en">
  165. <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>
  166. <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>
  167. </blockquote>
  168. <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>
  169. <blockquote lang="en">
  170. <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>
  171. <p><cite><em>Ibid.</em></cite></p>
  172. </blockquote>
  173. <figure>
  174. <a href="#2023-01-06-toile-gouttes"
  175. title="Cliquer pour une version haute résolution">
  176. <img src="/static/david/2023/2023-01-06-toile-gouttes.jpg" 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"
  177. loading="lazy" width="3024" height="4032" />
  178. </a>
  179. <a href="#_" class="lightbox" id="2023-01-06-toile-gouttes">
  180. <img src="/static/david/2023/2023-01-06-toile-gouttes.jpg" 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"
  181. loading="lazy" width="3024" height="4032" />
  182. </a>
  183. <figcaption>Parc Louis-Hébert, Montréal, 2 novembre&nbsp;2022.</figcaption>
  184. </figure>
  185. <details>
  186. <summary>Et pendant ce temps là de l’autre côté de la rue&nbsp;:</summary>
  187. <figure>
  188. <a href="#2023-01-06-toile-soleil"
  189. title="Cliquer pour une version haute résolution">
  190. <img src="/static/david/2023/2023-01-06-toile-soleil.jpg" alt="Un parc pour enfant à contre-jour avec le soleil qui se lève dans le brouillard et qui forme une jolie étoile"
  191. loading="lazy" width="4032" height="3024" />
  192. </a>
  193. <a href="#_" class="lightbox" id="2023-01-06-toile-soleil">
  194. <img src="/static/david/2023/2023-01-06-toile-soleil.jpg" alt="Un parc pour enfant à contre-jour avec le soleil qui se lève dans le brouillard et qui forme une jolie étoile"
  195. loading="lazy" width="4032" height="3024" />
  196. </a>
  197. <figcaption>Une toile de soleil&nbsp;!</figcaption>
  198. </figure>
  199. </details>
  200. </main>
  201. <hr>
  202. <footer>
  203. <p>
  204. <nobr>
  205. <a href="/david/" title="Aller à l’accueil"
  206. ><svg class="icon icon-home">
  207. <use
  208. xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-home"
  209. ></use>
  210. </svg>
  211. Accueil</a
  212. >
  213. </nobr>
  214. <nobr>
  215. <a href="/david/log/" title="Accès au flux RSS"
  216. ><svg class="icon icon-rss2">
  217. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-rss2"></use>
  218. </svg>
  219. Suivre</a
  220. >
  221. </nobr>
  222. <nobr>
  223. <a href="http://larlet.com" title="Go to my English profile" data-instant
  224. ><svg class="icon icon-user-tie">
  225. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-user-tie"></use>
  226. </svg>
  227. Pro</a
  228. >
  229. </nobr>
  230. <nobr>
  231. <a href="mailto:david%40larlet.fr" title="Envoyer un courriel"
  232. ><svg class="icon icon-mail">
  233. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-mail"></use>
  234. </svg>
  235. Email</a
  236. >
  237. </nobr>
  238. <nobr>
  239. <abbr
  240. class="nowrap"
  241. title="Hébergeur : Alwaysdata, 62 rue Tiquetonne 75002 Paris, +33184162340"
  242. ><svg class="icon icon-hammer2">
  243. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-hammer2"></use>
  244. </svg>
  245. Légal</abbr
  246. >
  247. </nobr>
  248. </p>
  249. <template id="theme-selector">
  250. <form>
  251. <fieldset>
  252. <legend><svg class="icon icon-brightness-contrast">
  253. <use xlink:href="/static/david/icons2/symbol-defs-2022-03.svg#icon-brightness-contrast"></use>
  254. </svg> Thème</legend>
  255. <label>
  256. <input type="radio" value="auto" name="chosen-color-scheme" checked> Auto
  257. </label>
  258. <label>
  259. <input type="radio" value="dark" name="chosen-color-scheme"> Foncé
  260. </label>
  261. <label>
  262. <input type="radio" value="light" name="chosen-color-scheme"> Clair
  263. </label>
  264. </fieldset>
  265. </form>
  266. </template>
  267. </footer>
  268. <script src="/static/david/js/instantpage-5.1.0.min.js" type="module"></script>
  269. <script>
  270. function loadThemeForm(templateName) {
  271. const themeSelectorTemplate = document.querySelector(templateName)
  272. const form = themeSelectorTemplate.content.firstElementChild
  273. themeSelectorTemplate.replaceWith(form)
  274. form.addEventListener('change', (e) => {
  275. const chosenColorScheme = e.target.value
  276. localStorage.setItem('theme', chosenColorScheme)
  277. toggleTheme(chosenColorScheme)
  278. })
  279. const selectedTheme = localStorage.getItem('theme')
  280. if (selectedTheme && selectedTheme !== 'undefined') {
  281. form.querySelector(`[value="${selectedTheme}"]`).checked = true
  282. }
  283. }
  284. const prefersColorSchemeDark = '(prefers-color-scheme: dark)'
  285. window.addEventListener('load', () => {
  286. let hasDarkRules = false
  287. for (const styleSheet of Array.from(document.styleSheets)) {
  288. let mediaRules = []
  289. for (const cssRule of styleSheet.cssRules) {
  290. if (cssRule.type !== CSSRule.MEDIA_RULE) {
  291. continue
  292. }
  293. // WARNING: Safari does not have/supports `conditionText`.
  294. if (cssRule.conditionText) {
  295. if (cssRule.conditionText !== prefersColorSchemeDark) {
  296. continue
  297. }
  298. } else {
  299. if (cssRule.cssText.startsWith(prefersColorSchemeDark)) {
  300. continue
  301. }
  302. }
  303. mediaRules = mediaRules.concat(Array.from(cssRule.cssRules))
  304. }
  305. // WARNING: do not try to insert a Rule to a styleSheet you are
  306. // currently iterating on, otherwise the browser will be stuck
  307. // in a infinite loop…
  308. for (const mediaRule of mediaRules) {
  309. styleSheet.insertRule(mediaRule.cssText)
  310. hasDarkRules = true
  311. }
  312. }
  313. if (hasDarkRules) {
  314. loadThemeForm('#theme-selector')
  315. }
  316. })
  317. </script>
  318. </body>
  319. </html>