Skip Navigation

I've been recently thinking about the future of lemmy-meter and where should we go next from where we stand today.

It quickly became obvious to me that I've got no clue where do we stand today. I've been too caught up with my life (and possibly too lazy and distracted) that I never ran a survey to gather any sort of feedback.

Since many of you have been using lemmy-meter for more than a month already, I'd like to redirect the following important questions to you:

Strengths

What do you think lemmy-meter does right? What are its strength? In other words, what makes you enjoy using lemmy-meter (if at all)?

Weaknesses

Where do you think lemmy-meter falls short? What are the things that make unsatisfied or even disappointed?

Potentials

Do you see any areas to explore that we haven't touched yet? Do you think lemmy-meter can expand to cover new realms? What could be the ideas that would take lemmy-meter to next level?

Thank you, Your friendly neighbourhood observability enthusiast

0

cross-posted from: https://lemmy.ml/post/18315517

> I wanted to share a personal experience that might resonate with some of you. I've been diagnosed with ADD and major depressive syndrome, and for a long time, I struggled to enjoy over-the-board chess. > > The fast pace and constant need for focus left me feeling drained and frustrated – blaming myself for not being able to concentrate. > > Then, I discovered correspondence chess! This format allows for a much slower pace, giving me the time I need to analyze positions and make thoughtful moves. It's been a game-changer. No more pressure, just the joy of strategic thinking without the stress. > > Do you ever feel like traditional chess isn't quite the right fit? > > If you struggle with focus or find the fast pace overwhelming, correspondence chess could be for you! Here are a couple of options to get you started: > > - ICCF.com (International Correspondence Chess Federation): This is the official platform for serious correspondence chess with tournaments and rankings. > > - Daily Chess on chess.com: This is a more casual option where you can play correspondence games at your own pace. > > Let me know in the comments if you've tried correspondence chess, or if you're interested in giving it a go!

0

I stumbled upon Opening Master the other day and am quite tempted to buy the Golem subscription and use it with Scid.

Have you ever used their databases? If yes, can you share your thoughts please?

In particular:

  • How is the quality of the compilation?
  • Are there any annotated games in the database (like ChessBase)?
  • Is it as large as they claim it to be?
  • Does it receive proper regular updates?
0

My fellow software engineer, It's the year 2024...

mastodon.social Bahman M. (@bahmanm@mastodon.social)

Attached: 1 image My fellow software engineer, It's the year 2024. Please store your #Linux #desktop application configurations ONLY in `$XDG_CONFIG_HOME`. NOT in `$HOME` or other non-standard or obsolete places. May #FreeDesktop be your guide. https://www.freedesktop.org/wiki/Specifications/...

cross-posted from: https://lemmy.ml/post/17978313

> Shameless plug: I am the author.

1
mastodon.social Bahman M. (@bahmanm@mastodon.social)

Attached: 1 image My fellow software engineer, It's the year 2024. Please store your #Linux #desktop application configurations ONLY in `$XDG_CONFIG_HOME`. NOT in `$HOME` or other non-standard or obsolete places. May #FreeDesktop be your guide. https://www.freedesktop.org/wiki/Specifications/...

Shameless plug: I am the author.

122

euler-cl now tracks coverage with Codecov

cross-posted from: https://lemmy.ml/post/15607790

> Just wanted to share some (exciting) news about my Common Lisp project, euler-cl. I finally got the time to sit down and integrate it with Codecov! This means a couple of cool things: > > * 📈 Test Coverage Tracking: I can now see how well my code is tested over time, giving valuable insights into code quality. > * 🏅 Codecov Badge: euler-cl now sports a snazzy Codecov badge to show off! > * 📦 Reusable Setup: The code and setup process should be simple enough to be used as a reference to integrate Codecov (and potentially other services) into your own Common Lisp projects! > > If you're interested this commit is almost all you need: https://github.com/bahmanm/euler-cl/commit/855b014 > > Let me know in the comments if you have any questions or want to chat about integrating Codecov into your own projects!

0

Docker Image Fusions for Simpler Workflows!

github.com GitHub - bahmanm/bdockerimg: A collection of Docker images which are otherwise not easy to find.

A collection of Docker images which are otherwise not easy to find. - bahmanm/bdockerimg

If you've found yourself manually crafting complex Docker images or repeatedly installing tools, I've got something for you 😁

Check out "fusions" in bdockerimg project (https://github.com/bahmanm/bdockerimg).

---

With fusions, you merge base images into powerful composite images.

Currently there are:

  • sdkman.bmakelib
  • quicklisp.bmakelib

---

Let me know what other fusions would make your Docker life easier 🙏

0
Jump
Could bdockerimg make your dev life easier?
  • Thanks for the pointer! Very interesting. I actually may end up doing a prototype and see how far I can get.

    2
  • Could bdockerimg make your dev life easier?

    I've been working on a small project called bdockerimg.

    It's a collection of pre-built Docker images for some less common development tools (currently bmakelib, QuickLisp, and SDKMAN).

    The idea is to streamline setup, especially for CI/CD pipelines, where I found myself repeating the same Dockerfile steps a lot. Basic functionality tests are included for a bit of extra peace of mind.

    ---

    👀 Here's the repo if you're interested: https://github.com/bahmanm/bdockerimg 🗣 And here's the the Matrix room: https://matrix.to/#/#bdockerimg:matrix.org

    ---

    I'm curious:

    • Does this seem like something you might find useful?
    • Are there any specific tools you'd love to see as easy-to-use Docker images?

    ---

    This project is still in its early stages, so any feedback or contributions are much appreciated 🙏

    2

    Do you know any chess clubs/programmes for a 5-7 year old in Vancouver/Richmond area?

    I would preferably want to be able to look up the coach(es) online or attend one of their lessons before enrolling my kid.

    PS: I know I may sound very picky, but I have witnessed first hand how a not great tutor in the early ages can ruin the enthusiasm for chess and change the future.

    0

    [HELP] A noob's request for code review

    github.com prolog-etudes/basic-list-techniques/mapping_nested.prolog at main · bahmanm/prolog-etudes

    A collection of etudes for folks new to Prolog (and sometimes experienced ones) to learn the language in a practical fashion. - bahmanm/prolog-etudes

    I just started learning Prolog (based on "Programming in Prolog") and in doing so I've been trying to write code as much as I can.

    So far, my little collection of tiny predicates have seemed OK, to my mind.

    However, I'm not sure if I'm confident about the most recent piece of Prolog code I've written: https://github.com/bahmanm/prolog-etudes/blob/main/basic-list-techniques/mapping_nested.prolog

    Which is why I'm asking if I could please get a code review from the experts. Any hint/feedback is highly appreciated 🙏

    0
    github.com Release v0.7.0 · bahmanm/bmakelib

    The highlight is the introduction of fail-fast alternative to $(shell) which relieves you from checking .SHELLSTATUS every time $(shell) is used. Makefile: VAR1 := $(call bmakelib.shell.error-if-no...

    bmakelib v0.7.0 has just been released.

    The highlight is the fail-fast alternative to $(shell) which relieves you from checking .SHELLSTATUS every time $(shell) is used.

    ---

    Makefile:

    ```makefile include bmakelib/bmakelib.mk

    VAR1 := $(call bmakelib.shell.error-if-nonzero,\ echo Fails hard❗ && false)

    unreachable-target : ```

    Shell:

    text $ make unreachable-target Makefile:3: *** shell.error-if-nonzero: Command exited with non-zero value 1. Stop.

    0
    Jump
    Winter Update
  • Thank you 💗

    2
  • Jump
    Winter Update
  • Thank you 💗

    2
  • Jump
    Winter Update
  • Thank you 💗

    2
  • You may have noticed that things have been quite quiet these past few weeks and there hasn't been any new developments.

    The reason is that I have recently become a father (again) and my life, as I had expected, have become quite busy leaving literally no free time for me and my FOSS endeavours.

    I anticipate that starting from Spring, things will slowly fall back to normal and I will find myself comfortable w/ life's new routines and schedules and will resume the work on lemmy-meter.

    In the meantime, in case of urgencies, the best way to reach out to me is via my e-mail (Bahman@BahmanM.com)

    Stay warm and keep safe,

    6

    Latency, aka Roundtrip Time (RTT) or Time To Load (TTL), is the time it takes for the instance to respond to an HTTP request.

    ---

    Latency indicators have been added to the instance health breakdown dashboard, allowing you to view the latency of your favourite instance compared to itself:

    • Past 3 hours compared to the past 7 days
    • Past 24 hours compared to the past 30 days
    • Past 24 hours compared to the past 90 days

    ---

    Screenshot 1

    !

    Screenshot 2

    !

    0

    [ANN] bmakelib v0.6.0 with enums

    github.com Release v0.6.0 · bahmanm/bmakelib

    The highlight of this release is the introduction of enum (aka variants or options) which can be used to limit and validate a variable's value. For example: Makefile: define-enum : bmakelib.enum.de...

    cross-posted from: https://lemmy.ml/post/8492082

    > bmakelib is a collection of useful targets, recipes and variables you can use to augment your Makefiles. > > --- > > I just released bmakelib v0.6.0 w/ the main highlight being the ability to define enums and validate variable values against them. > > --- > > ➤ Makefile: > > Makefile > define-enum : bmakelib.enum.define( DEPLOY-ENV/dev,staging,prod ) > include define-enum > > deploy : bmakelib.enum.error-unless-member( DEPLOY-ENV,ENV ) > deploy : > @echo 🚀 Deploying to $(ENV)... > > > ➤ Shell: > > text > $ make ENV=local-laptop deploy > *** 'local-laptop' is not a member of enum 'DEPLOY-ENV'. Stop. > > $ make ENV=prod deploy > 🚀 Deploying to prod... >

    0
    github.com Release v0.6.0 · bahmanm/bmakelib

    The highlight of this release is the introduction of enums (aka variants or options) which can be used to limit and validate a variable's value. For example: Makefile: define-enum : bmakelib.enum.d...

    bmakelib is a collection of useful targets, recipes and variables you can use to augment your Makefiles.

    ---

    I just released bmakelib v0.6.0 w/ the main highlight being the ability to define enums and validate variable values against them.

    ---

    ➤ Makefile:

    ```Makefile define-enum : bmakelib.enum.define( DEPLOY-ENV/dev,staging,prod ) include define-enum

    deploy : bmakelib.enum.error-unless-member( DEPLOY-ENV,ENV ) deploy : @echo 🚀 Deploying to $(ENV)... ```

    ➤ Shell:

    ```text $ make ENV=local-laptop deploy *** 'local-laptop' is not a member of enum 'DEPLOY-ENV'. Stop.

    $ make ENV=prod deploy 🚀 Deploying to prod... ```

    0

    As of a couple of days ago, uptime indicators have been added to the health breakdown page allowing you to glance at the availability of the instance during the past 7, 30 and 90 days.

    Screenshot 1

    !

    Screenshot 2

    !

    2
    Jump
    Would you be interested in opting-in to lemmy-meter?
  • UPDATE: lemmy.ml is now on lemmy-meter 🥳

    1
  • Jump
    No money but want to contribute
  • Good question!

    IMO a good way to help a FOSS maintainer is to actually use the software (esp pre-release) and report bugs instead of working around them. Besides helping the project quality, I'd find it very heart-warming to receive feedback from users; it means people out there are actually not only using the software but care enough for it to take their time, report bugs and test patches.

    18
  • Jump
    [ANN] lemmy-synapse v1.0.0
  • "Announcment"

    It used to be quite common on mailing lists to categorise/tag threads by using subject prefixes such as "ANN", "HELP", "BUG" and "RESOLVED".

    It's just an old habit but I feel my messages/posts lack some clarity if I don't do it 😅

    10
  • github.com Release v1.0.0 · bahmanm/lemmy-synapse

    The very first stable version of lemmy-synapse 🎉 What is lemmy-synapse A humble bundle of observability and monitoring for your Lemmy cluster. Read more ... What's included Docker stats dashboard ...

    lemmy-synapse is a light-weight observability and monitoring stack for Lemmy servers.

    ---

    Using Prometheus and Grafana, it allows the admins to visualise and query the stats of their instance. v1.0.0 comes out of the box with 3 detailed dashboards:

    • Host stats (CPU, RAM, disk, network, ...)
    • PostgreSQL stats (connections, locks, transations, queries, ...)
    • Docker stats (container CPU, RAM, disk, network, OOM signals, ...)

    ---

    It runs as Docker compose cluster alongside the Lemmy cluster and does not require any changes to it in most cases. Uninstalling lemmy-synapse is as easy as tearing down its cluster and deleting its installation directory.

    ---

    Got questions/feedback? Pray drop a line:

    2

    As an instance admin, would you be interested in receiving alerts in case lemmy-meter detects your instance's health has deteriorated?

    The alerts could be sent to any combination of

    • a Matrix chat (private or channel)
    • a Discord server
    • an e-mail address

    For example, you could receive an alert if the landing page hasn't been loading for the past 5 minutes.

    ---

    The details of alerting levels and the conditions that'd trigger them will be ironed out later. At this stage I'd mostly would like to know if there's interest in this feature in the first place before getting to the implementation.

    ---

    Follow up on https://github.com/bahmanm/lemmy-meter/issues/71

    0
    Jump
    How do you comment your makefiles?
  • I usually capture all my development-time "automation" in Make and Ansible files. I also use makefiles to provide a consisent set of commands for the CI/CD pipelines to work w/ in case different projects use different build tools. That way CI/CD only needs to know about make build, make test, make package, ... instead of Gradle/Maven/... specific commands.

    Most of the times, the makefiles are quite simple and don't need much comments. However, there are times that's not the case and hence the need to write a line of comment on particular targets and variables.

    1
  • Jump
    GNU Make - Unconditionally run a target before any other targets
  • Can you provide what you mean by check the environment, and why you’d need to do that before anything else?

    One recent example is a makefile (in a subproject), w/ a dozen of targets to provision machines and run Ansible playbooks. Almost all the targets need at least a few variables to be set. Additionally, I needed any fresh invocation to clean the "build" directory before starting the work.

    At first, I tried capturing those variables w/ a bunch of ifeqs, shells and defines. However, I wasn't satisfied w/ the results for a couple of reasons:

    1. Subjectively speaking, it didn't turn out as nice and easy-to-read as I wanted it to.
    2. I had to replicate my (admittedly simple) clean target as a shell command at the top of the file.

    Then I tried capturing that in a target using bmakelib.error-if-blank and bmakelib.default-if-blank as below.

    ##############
    
    .PHONY : ensure-variables
    
    ensure-variables : bmakelib.error-if-blank( VAR1 VAR2 )
    ensure-variables : bmakelib.default-if-blank( VAR3,foo )
    
    ##############
    
    .PHONY : ansible.run-playbook1
    
    ansible.run-playbook1 : ensure-variables cleanup-residue | $(ansible.venv)
    ansible.run-playbook1 : 
    	...
    
    ##############
    
    .PHONY : ansible.run-playbook2
    
    ansible.run-playbook2 : ensure-variables cleanup-residue | $(ansible.venv)
    ansible.run-playbook2 : 
    	...
    
    ##############
    

    But this was not DRY as I had to repeat myself.

    That's why I thought there may be a better way of doing this which led me to the manual and then the method I describe in the post.


    running specific targets or rules unconditionally can lead to trouble later as your Makefile grows up

    That is true! My concern is that when the number of targets which don't need that initialisation grows I may have to rethink my approach.

    I'll keep this thread posted of how this pans out as the makefile scales.


    Even though I’ve been writing GNU Makefiles for decades, I still am learning new stuff constantly, so if someone has better, different ways, I’m certainly up for studying them.

    Love the attitude! I'm on the same boat. I could have just kept doing what I already knew but I thought a bit of manual reading is going to be well worth it.

    1
  • Jump
    How do you comment your makefiles?
  • That's a great starting point - and a good read anyways!

    Thanks 🙏

    1
  • How do you comment your makefiles?

    cross-posted from: https://lemmy.ml/post/6863402

    > Fed up w/ my ad-hoc scripts to display the targets and variables in a > makefile(s), I've decided to write a reusable piece of code to do > that: https://github.com/bahmanm/bmakelib/issues/81 > > --- > > The first step toward that would be to understand the common commenting styles. So far I have identified 4 patterns in the wild which you can find below. > > Are there any style guides/conventions around this topic? Any references > to well-written makefiles I can get inspiration from? > > --- > > ### A > > > VAR1 = foo ## short one-liner comment > my-target: ## short one-liner comment > … > > > ### B > > > # longer comment which > # may span > # several lines > VAR1 = foo > > ## comments can be prefixed w/ more than # > ## lorem ipsum dolor > my-target: > … > > > ### C > > > ##### > # a comment block which is marked w/ several #s on > # an otherwise blank line > ##### > VAR1 = foo > > > ### D > > > ##### > #> # heading 1 > # This is a variation to have markdown comments > # inside makefile comments. > # > # ## It's a made-up style! > # I came up w/ this style and used it to document `bmakelib`. > # For example: https://is.gd/QtiqyA (opens github) > #< > ##### > VAR1 = foo >

    4

    Fed up w/ my ad-hoc scripts to display the targets and variables in a makefile(s), I've decided to write a reusable piece of code to do that: https://github.com/bahmanm/bmakelib/issues/81

    ---

    The first step toward that would be to understand the common commenting styles. So far I have identified 4 patterns in the wild which you can find below.

    Are there any style guides/conventions around this topic? Any references to well-written makefiles I can get inspiration from?

    ---

    A

    VAR1 = foo ## short one-liner comment my-target: ## short one-liner comment …

    B

    ```

    longer comment which

    may span

    several lines

    VAR1 = foo

    comments can be prefixed w/ more than

    lorem ipsum dolor

    my-target: … ```

    C

    ```

    a comment block which is marked w/ several #s on

    an otherwise blank line

    VAR1 = foo ```

    D

    ```

    #> # heading 1

    This is a variation to have markdown comments

    inside makefile comments.

    ## It's a made-up style!

    I came up w/ this style and used it to document bmakelib.

    For example: https://is.gd/QtiqyA (opens github)

    #<

    VAR1 = foo ```

    0
    Jump
    How to audit a shell-completion script?
  • Agree w/ you re trust.

    1
  • Jump
    How to audit a shell-completion script?
  • Thanks. At least I've got a few clues to look for when auditing such code.

    1
  • Jump
    Sicilian Defense: Hyperaccelerated Dragon, Fianchetto, Pterodactyl Defense
  • I'm not an 1.e4 or Sicilian player but this smells like wild tactical variations early in the game.

    3
  • Jump
    What is lemmy-meter?
  • Thanks 🙏

    1
  • Jump
    [DONE] Would you be interested in opting-in to lemmy-meter?
  • Update

    sh.itjust.works in now added to lemmy-meter 🥳 Thanks all.

    3
  • Jump
    [Help] go and perl5 folders in ~/
  • I didn't like the capitalised names so configured xdg to use all lowercase letters. That's why ~/opt fits in pretty nicely.

    You've got a point re ~/.local/opt but I personally like the idea of having the important bits right in my home dir. Here's my layout (which I'm quite used to now after all these years):

    $ ls ~
    bin  
    desktop  
    doc  
    downloads  
    mnt  
    music  
    opt 
    pictures  
    public  
    src  
    templates  
    tmp  
    videos  
    workspace
    

    where

    • bin is just a bunch of symlinks to frequently used apps from opt
    • src is where i keep clones of repos (but I don't do work in src)
    • workspace is a where I do my work on git worktrees (based off src)
    1
  • Jump
    Linux Mint Debian Edition officially released
  • Thanks! So much for my reading skills/attention span 😂

    12
  • Jump
    Linux Mint Debian Edition officially released
  • Which Debian version is it based on?

    0
  • Jump
    Mozilla.ai is a new startup and community funded with 30M from Mozilla that aims to build trustworthy and open-source AI ecosystem
  • Something that I'll definitely keep an eye on. Thanks for sharing!

    8
  • Jump
    [Help] go and perl5 folders in ~/
  • RE Go: Others have already mentioned the right way, thought I'd personally prefer ~/opt/go over what was suggested.


    RE Perl: To instruct Perl to install to another directory, for example to ~/opt/perl5, put the following lines somewhere in your bash init files.

    export PERL5LIB="$HOME/opt/perl5/lib/perl5${PERL5LIB:+:${PERL5LIB}}"
    export PERL_LOCAL_LIB_ROOT="$HOME/opt/perl5${PERL_LOCAL_LIB_ROOT:+:${PERL_LOCAL_LIB_ROOT}}"
    export PERL_MB_OPT="--install_base \"$HOME/opt/perl5\""
    export PERL_MM_OPT="INSTALL_BASE=$HOME/opt/perl5"
    export PATH="$HOME/opt/perl5/bin${PATH:+:${PATH}}"
    

    Though you need to re-install the Perl packages you had previously installed.

    4