pulkomandy a écrit 1730 commentaires

  • [^] # Re: Quels outils ?

    Posté par  (site web personnel, Mastodon) . En réponse au journal On ne contribue pas que du code. Évalué à 3.

    Pour la génération des fichiers de traduction, ce sont également des outils développés par Haiku. Il s'aggit de collectcatkeys qui va parser des sources C++ à la recherche d'appels à une famille de macros (B_TRANSLATE) et extraire les chaînes de caractères passées en paramètre.

    Pour chaque appel à la macro on peut avoir:
    - La chaîne à traduire
    - Un "contexte" (qui permet d'avoir la même chaîne avec des traductions différentes, par exemple quand un nom et un verbe sont homonymes en anglais mais pas dans les traductions)
    - Un commentaire (qui est là pour informer les traducteurs)

    Ces trois informations sont affichées par l'outil de traduction.

    Le résultat est un fichier "catkeys" qui contient simplement ces entrées, une par ligne, avec les 3 infos séparées par des tabulations (les chaînes elle-mêmes sont stockées avec les caractères spéciaux échappés comme en C, donc s'il y a une tabulation ou un retour à la ligne dans la chaîne à traduire, il est remplacé par un \t ou un \n).

    Ensuite on convertit les fichiers traduits dans un format binaire qui permet un accès plus rapide aux traductions.

    Pour les outils de traduction, il y a d'abord eu un premier outil maison (c'était vers 2009 ou 2010), avant le passage à Pootle. Pootle fonctionne bien pour le système, mais nous n'avons pas réussi à y intégrer des applications tierces sous forme de projets indépendants. Pour la version ancienne, c'est en cours de migration!

    Un problème de Pootle est qu'il est écrit en Python (si je me souviens bien) et donc en héberger une instance nécessite un serveur qui permet de faire des pages en Python. Ce n'est pas un problème pour le projet Haiku, mais ça l'est pour plusieurs projets de petites applications qui sont hébergées juste sous forme d'un projet github. Et là on a un développeur qui a eu envie de se faire la main sur le développement d'application web, je crois :)

    Pour le format d'ICU, je ne sais pas si je peux répondre car je connaît assez mal celui utilisé par gettext. Il y a quelques exemples ici:
    http://userguide.icu-project.org/formatparse/messages

    En gros, le format est presque un langage de script qui permet au traducteur d'exprimer tout un tas de conditions sur les données à formater. On l'utilise principalement pour gérer correctement le nombre (singulier/pluriel en français, mais c'est plus compliqué dans d'autres langues, comme on peut le voir dans la base de données CLDR.

    Comment ça se passe avec gettext pour gérer ce genre de problèmes?

  • [^] # Re: Oui mais non

    Posté par  (site web personnel, Mastodon) . En réponse au journal Twitch et copyleft. Évalué à 4.

    La version française de la licence: "Faites ce que vous voulez, j'en ai rien à branler." contient bien une clause d'exclusion de garanties (indice: c'est la partie après la virgule). Par contre ça ne semble pas être le cas de la version anglaise.

  • [^] # Re: Merci pour ce partage - mais la doc fouque

    Posté par  (site web personnel, Mastodon) . En réponse au journal Publication de bibliothèques c++ sous licence libre. Évalué à 3.

    Si ta fonction et tes arguments et leurs types sont nommés correctement, alors tu n'as pas besoin de répéter ces informations évidentes dans un cartouche de documentation.

    En exagérant un peu, du code qui a besoin de documentation, c'est du code pas clair et mal écrit. Il vaut mieux passer du temps à nettoyer ton code qu'à le documenter. En suivant ce principe, on devrait pouvoir se faire une idée de l'architecture globale en regardant l'organisation des fichiers, ou les scripts de build.

    Maintenant, c'est vrai que ce n'est pas facile d'en arriver là, et donc avoir une documentation peut être pertinent. La rédiger sous forme d'une TODO list (avec la liste de tous les trucs pas clairs) peut être un bon moyen de se souvenir que c'est comme ça qu'elle fonctionne, et que le but du développeur est de faire que la documentation ne soit plus nécessaire, parce que le code parle de lui-même.

  • [^] # Re: Quels outils ?

    Posté par  (site web personnel, Mastodon) . En réponse au journal On ne contribue pas que du code. Évalué à 6.

    Pour Haiku, on utilise:

    • Pootle, pour la traduction des applications fournies avec le système,
    • Polyglot, un outil maison, pour la traduction des applications tierces,
    • Un autre outil maison pour la traduction de la documentation du système.

    Je précise que nous avons aussi choisi de ne pas utiliser gettext, nos traductions sont basées sur le support fourni par ICU qui donne pas mal de contrôle au traducteur pour le format des messages, et permet notamment une gestion correcte du pluriel dans toutes les langues (certaines ont des règles complexes ou inhabituelles).

    Une conséquence est l'utilisation de notre propre format de fichier pour les traductions. Ce format a été intégré dans Pootle mais à ma connaissance pas dans les autres outils. Nous avons aussi une application native pour traduire ces fichiers, mais l'utilisation d'un outil en ligne et collaboratif est finalement plus conviviale.

    Nous avons aussi un ensemble de documents destinés aux traducteurs afin d'aider la coordination, le choix d'un vocabulaire commun, etc: https://dev.haiku-os.org/wiki/i18n

  • [^] # Re: goodies

    Posté par  (site web personnel, Mastodon) . En réponse à la dépêche Aider les associations du Libre en achetant leurs goodies. Évalué à 5.

    On en a conscience, mais on fait ce qu'on peut avec les contributeurs qu'on a. Plutôt que de pleurer de honte dans ton coin, viens te moquer de nos goodies tous moche, et faire des propositions de nouveaux designs!

    Pour un projet libre, c'est déjà difficile de recruter des développeurs, c'est encore plus compliqué de recruter des gens pour faire de la communication, du graphisme, de la comptabilité, de l'administration système, et plein d'autres trucs.

    On a essayé de confier quelques tâches "design" aux participants du Google Code-In cette année. La conclusion est que comme on a pas de personne compétente/formée dans le domaine dans notre équipe, on a beaucoup de mal à obtenir des résultats corrects car on ne sait pas dire ce qui ne va pas dans les travaux qui nous sont remis dans ce cadre.

  • [^] # Re: Éditeur de code sans le code

    Posté par  (site web personnel, Mastodon) . En réponse au journal un éditeur de code portable par Microsoft?. Évalué à 5.

    Il n'y a pas vraiment de controverse. Simplement, on passe beaucoup de temps dans un éditeur, c'est notre principal outil de travail, après tout. Et c'est bien d'avoir le choix entre différents outils, qui fonctionnent différemment et du coup conviennent aux besoins de chacun. Je suppose que c'est le cas aussi dans la plupart des autres métiers.

  • [^] # Re: Un peu de documentation sur le sujet

    Posté par  (site web personnel, Mastodon) . En réponse au journal Misogynie et discrimination à l'embauche. Évalué à 5.

    C'est vrai, il y a des sexistes parmi les hackers, et c'est vrai aussi, c'est un (gros) problème. Mais ça m'embête déjà qu'on en fasse une généralité, et encore plus un "ciment" (c'est fort, quand même!). Si on va aussi loin, ça donne l'impression qu'il n'y a plus rien à faire à part détruire les dits groupes (tous les groupes de hackers sont visés sans distinction, du coup).

    On peut être un hacker, même en groupe, sans être sexiste.

  • [^] # Re: Hem...

    Posté par  (site web personnel, Mastodon) . En réponse au journal Misogynie et discrimination à l'embauche. Évalué à 2.

    Il n'y a pas de problème dans ton équipe, et c'est très bien. Mais ça ne répond pas à une question, qu'est-ce qu'on fait dans les cas où il y a manifestement un problème et qu'on arrive pas à s'en sortir?

    Mettre en place un quota c'est une solution extrême et risquée, mais je ne sais pas s'il y a autre chose qui pourrait fonctionner (à part dissoudre l'équipe et recommencer, et encore).

    En tout cas je travaille actuellement dans une équipe qui manque de diversité (pas juste homme/femme, on a aussi presque tous à peu près le même âge, des formations similaires, etc). Qu'est-ce qu'on peut faire pour se mettre un coup de pied aux fesses et essayer d'améliorer ça?

  • [^] # Re: Impolitesse ?

    Posté par  (site web personnel, Mastodon) . En réponse au journal Petit guide à l'usage des développeurs de LL qui souhaitent se tirer dans le pied. Évalué à 8.

    On va parler de comment ça se passe chez Haiku, tiens.

    Nos paquets sont construits automatiquement à partir de recettes qui sont sur un dépôt github. On a un certain nombre de contributeurs actifs sur ce dépôt, mais surtout un tas de gens qui font des pull requests: soit des utilisateurs qui avaient besoin d'utiliser un logiciel et qui ont écrit une recette eux-même, soit de plus en plus, des développeurs upstream qui viennent eux-même mettre à jour nos recettes ou au moins nous ouvrir un ticket quand ils publient une nouvelle version (surtout si elle corrige une faille de sécurité).

    En échange, on essaie de penser à faire des patchs propres et à les envoyer à l'upstream, même si on est pas toujours très efficaces ou réactifs (c'est qu'on gère beaucoup de paquets à la fois, quand même).

    Pour l'instant ça se passe plutôt bien dans l'ensemble.

  • [^] # Re: C'est pas trop mal

    Posté par  (site web personnel, Mastodon) . En réponse au journal Directive sur le droit d'auteur. Évalué à 5.

    Sauf que cet article ne vise pas spécifiquement le code source. En fait ils ont plutôt en tête les sites de streaming vidéo, musique, etc. L'incidence sur le logiciel (libre ou pas) est accidentelle, les rédacteurs de l'article n'y ont probablement pas vraiment pensé et oublié que le code des logiciels est soumis lui aussi au droit d'auteur.

    C'est pour ça qu'il y a besoin d'un peu de lobbying pour rappeler notre existence et expliquer que ce cas particulier est problématique, afin que la rédaction de l'article soit analysée et si nécessaire modifiée pour pallier le problème.

  • [^] # Re: C'est pas trop mal

    Posté par  (site web personnel, Mastodon) . En réponse au journal Directive sur le droit d'auteur. Évalué à 3.

    ça va être compliqué de contacter toutes les entreprises de l'univers connu pour leur demander si elles ont un bout de code (ou tout autre oeuvre soumise au droit d'auteur) qu'elles souhaitent voir protégé.

    Donc je ne vois pas de solution raisonnable, sauf celle ou c'est le propriétaire des droits qui est à l'initiative de la chose. Par contre, avec cette loi, l'hébergeur sera obligé de mettre en place les moyens nécessaires. En contrepartie, il aura la collaboration du propriétaire des droits de l'oeuvre.

    Soyons clairs: cette loi est écrite avec en tête des œuvres dont la gestion des droits est organisée très différemment. L'idée c'est que la SACEM va pouvoir venir mettre son nez chez Deezer, Spotify, Dogmazic ou leurs concurrents et leur demander de vérifier les droits de ce qu'ils diffusent - et va donc devoir leur donner accès à son catalogue pour leur permettre de faire les vérifications. Mais je doute que l'Agence pour la Protection des Programmes en fasse de même avec Github, Gitlab ou Framagit.

  • [^] # Re: Hem...

    Posté par  (site web personnel, Mastodon) . En réponse au journal Misogynie et discrimination à l'embauche. Évalué à 6.

    Avec un quota, tu vas volontairement écarter des gens qui conviennent parfaitement pour en mettre d'autres qui conviennent moins. Pour de l'idéologie.

    Tu as raté un virage dans le raisonement.

    Si tu fais une équipe avec les gens "qui conviennent parfaitement" uniquement, tu vas construire une monoculture. J'ai vécu ça dans une boîte: tous les employés venaient de la même fac avec le même diplôme avant que j'arrive. Donc oui, ils s'entendaient bien et ils réfléchissaient tous de la même façon. Et ils faisaient des trucs pas du tout efficace sans s'en rendre compte.

    Si au contraire tu fais l'effort de sortir de la zone de confort, tu vas enrichir la culture de ton entreprise avec des gens d'horizons différents. Et ils vont t'apporter des trucs que personne n'aurait pu prévoir.

    Ce qui est important, c'est d'apporter de la diversité et des points de vue différents.

    ça peut marcher tout seul si ton équipe de départ a compris que la diversité était importante et apportait de l'ouverture. Mais si ce n'est pas le cas, il va falloir forcer un peu les choses, et le recours à des "quotas" peut être une solution.

  • # C'est pas trop mal

    Posté par  (site web personnel, Mastodon) . En réponse au journal Directive sur le droit d'auteur. Évalué à 9.

    J'étais un peu inquiet avec cette affaire, mais en lisant l'article dans le détail:

    prennent, en coopération avec les titulaires de droits, des mesures destinées à assurer le bon fonctionnement des accords

    Du coup, si quelqu'un veut que son code soit protégé, il doit venir demander et doit coopérer pour mettre en place les contrôles.

    Ces mesures doivent être appropriées et proportionnées.

    Je dirais qu'une mesure du genre "demander la licence à la personne qui soumet du code" serait déjà tout à fait appropriée (ce n'est pas le cas sur GitHub par exemple et il y a plein de code sans licence ou avec une licence pas claire) et serait plutôt une bonne chose pour le logiciel libre.

    On peut la compléter d'un "si vous voyez du code qui vous appartient, contactez-nous, on vérifie et on le supprime s'il y a lieu" qui me semble assez adapté.

    Est-ce que ceci semble approprié et proportionné? Je pense que oui. Si une forge décide d'aller plus loin et de mettre en place un truc chiant, ça va juste faire que ses utilisateurs iront voir ailleurs, non?

  • # Rapport de bug

    Posté par  (site web personnel, Mastodon) . En réponse au journal un éditeur de code portable par Microsoft?. Évalué à 10.

    Note pour moi-même, vérifier que les dépendances listées par le .deb sont bien les seules réellement nécessaires, c'est une piste de râlage potentiel… ou un moyen d'apprendre une technique pour faire du code plus indépendant du système: d'un côté ou de l'autre, je gagnerai à étudier ça.

    Fais attention, bientôt tu vas te retrouver à envoyer des rapports de bugs à Microsoft, voire même à contribuer à régler le problème (gasp!).

  • [^] # Re: Quelles sont les fonctionnalités malheureuses, selon vous ?

    Posté par  (site web personnel, Mastodon) . En réponse à la dépêche Sortie de LibreOffice 6.0. Évalué à 10.

    J'utilise le menu formulaire pour fabriquer… ben des formulaires.

    Par exemple, les fiches d'inscription dans une école de musique, que je peux ainsi exporter en formulaires PDF que les adhérents peuvent compléter et renvoyer par mail ou imprimer. Ce qui me permet d'avoir des adresses mails écrites par ordinateur et pas des gribouillages illisibles. Le gain de temps est appréciable et c'est très facile à faire.

    C'est la première fois que j'entends dire qu'il y a des fonctionnalités en trop dans LibreOffice.

  • [^] # Re: Crowdfunding pour Driver VPU

    Posté par  (site web personnel, Mastodon) . En réponse au journal Free-electrons se fait attaquer en justice par Free, et change de nom. Évalué à 10.

    Et ben non, pas sur les puces ARM.

    Le VPU c'est une unité utiliser pour décoder de la vidéo. Ce sera utilisé par exemple par ffmpeg ou gstreamer. Rien ne t'oblige à afficher la dite vidéo sur un écran (en passant par le GPU). Tu peux très bien décider de la ré-encoder dans un autre format, de l'envoyer sur le réseau, etc.

    Donc le VPU (décodage vidéo) et le GPU (accélération 3D) ne sont pas liés. En plus, sur ce genre de puces le GPU lui-même n'est même pas branché directement à la partie affichage qui gère le framebuffer. Le GPU fait uniquement l'accélération 3D, et fait son rendu dans la RAM (rendu que tu pourrais très bien… envoyer au VPU pour l'encoder, sans jamais l'afficher à l'écran).

    Ce sont donc des blocs complètement indépendants.

    Sur les architectures x86, le GPU et le VPU sont effectivement souvent regroupés dans la partie "carte graphique", avec une séparation un peu moins claire.

  • [^] # Re: Ha la mauvaise foi...

    Posté par  (site web personnel, Mastodon) . En réponse à la dépêche La fin des IPv4 est très proche ! Les ennuis aussi…. Évalué à 6.

    En IPv4 on utilise le NAT. On s'est habitués mais c'est une astuce moche pour économiser les IPs.

    En IPv6, on pourrait aussi faire du NAT mais ce n'est pas nécessaire puisque chaque machine a une IP publique et qu'il y a largement assez d'IPs pour tout le monde.

    Donc oui, il vaut mieux nommer ses machines (camera.chezmoi.com, ordinateur.chezmoi.com, …) plutêt que de retenir que la caméra IP c'est le port 6928, l'aquarium c'est 4519, etc. Une fois que tu as ton nom de domaine, créer des sous-domaines ne coûte pas cher. Et si tu tiens vraiemnt à utiliser des numéros, tu peux toujours faire p6928.chezmoi.com, etc.

  • [^] # Re: Nom moche

    Posté par  (site web personnel, Mastodon) . En réponse au journal Areva → New Areva → Orano ? Vérifions ça…. Évalué à 2.

    Je trouve pénible que http://vim.org ne fonctionne pas alors que http://www.vim.org, oui. L'adresse est quand même 57% plus longue!

    Je n'ai pas de problème avec les sites qui autorisent les deux formes, par contre.

  • [^] # Re: Corrections

    Posté par  (site web personnel, Mastodon) . En réponse au journal En évoquant Facebook. Évalué à 7.

    Et non, le HDMI conserve plein de machins débiles venus de là, y compris les framerates. Peut-être que le prochain standard dans 60 ans permettra enfin de s'en débarasser.

  • [^] # Re: Ne règle pas le "problème" du journa précédent

    Posté par  (site web personnel, Mastodon) . En réponse au journal Le retour de la vengeance de la virgule flottante. Évalué à 2.

    Même problème ici (Vivaldi, Windows) dès qu'il y a des formules mathématiques dans un post.

  • [^] # Re: Liens

    Posté par  (site web personnel, Mastodon) . En réponse au journal Le retour de la vengeance de la virgule flottante. Évalué à 4.

    Je te dis pas les problèmes quand tu lis un fichier depuis un disque ou le réseau pour savoir si la longueur est sur 8, 16 ou 32 ou 36 bits, et dans quel endianness, aussi.

  • [^] # Re: Patch à la volée

    Posté par  (site web personnel, Mastodon) . En réponse au journal Il y a de grand malade sur Terre.... Évalué à 2.

    On veut des preuves!

  • [^] # Re: Pourquoi ?

    Posté par  (site web personnel, Mastodon) . En réponse au journal Il y a de grand malade sur Terre.... Évalué à 5.

    Moi ça m'étonnerait pas qu'ils aient perdu le code. Plus précisément, le code est quelque part dans leurs péta-octets d'archives, mais personne n'a su trouver où exactement. Et vu le peu de changements à faire, ça va plus vite de corriger directement le binaire que de passer 6 mois à retrouver les sources.

  • [^] # Re: Et sur le fond?

    Posté par  (site web personnel, Mastodon) . En réponse au journal Microsoft voudrait de la biométrie. Évalué à 2.

    Il y a du NFC dans la plupart des téléphones aussi, non? On peut pas utiliser ça?

    Le mien est également équipé d'un lecteur d'empreintes digitales, que je peux utiliser pour déverrouiller mon compte Google associé au dit téléphone (y compris pour y accéder depuis d'autres machines).

  • [^] # Re: Et sur le fond?

    Posté par  (site web personnel, Mastodon) . En réponse au journal Microsoft voudrait de la biométrie. Évalué à 6.

    Protégé par un mot de passe ET une clé privée (qu'on ne stockera bien sur pas au même endroit!)

    Moi j'aimerais bien m'authentifier auprès de sites internets en utilisant des certificats SSL. HTTPS le permet, de la même façon qu'il permet d'authentifier le site auquel on se connecte. Mais l'interface utilisateur dans tous les navigateurs est inutilisable voire inexistante.

    Je crois que les impôts en France ont utilisé ce système quelques temps, mais ont vite laissé tomber face à la complexité et au nombre de personnes qui revenaient pleurer tous les ans qu'ils avaient perdu leur certificat.