Disclaimer : I am a hobbyist programmer, I have not gone to Uni for that , so I might not know everything I am talking about.

My question is why don’t open source programs include something like diagrams of the algorithms they employ ?? I Was looking for algorithms for a chat program with client-server architecture, I was hoping to find diagrams and descriptions of how algorithms work, so a to study them an adapt them to my needs. All I found were FOSS projects with no such documentation.

Considering that reading source code can take a long time, and sometimes interesting projects are written in a language the user isn’t familiar with, I was wondering why such documentation style doesn’t exist ? It could help even newer contributors get started quicker.

  • NullPointer@programming.dev
    link
    fedilink
    arrow-up
    1
    ·
    9 months ago

    “algorithm” is a little too fine grained for what you describe. “software design patterns” is probably what you are looking for.

    unfortunately, not all projects call out the patterns they employ.

  • amio@kbin.social
    link
    fedilink
    arrow-up
    0
    ·
    9 months ago

    There’s no point spending twice the time making something that corresponds 1:1 to code - unless the code is truly horrific, and then you’ve got bigger issues. One generally assumes people involved with a project will know or learn relevant languages.

    It’s more commonly used for things that are less obvious from the source itself - like “what’s sent between the client and server in this handshake” or “what is the overall architecture of this part of the code”

    Flowcharts may be a bit more common when studying algorithms in general

    Edit; from your other comments, you seem to be talking about protocols, not algorithms. An algorithm is a set of steps to do something. A protocol is a description of how different systems interact such as in a chat application.

  • ninjan@lemmy.mildgrim.com
    link
    fedilink
    English
    arrow-up
    0
    ·
    9 months ago

    The answer to this question is the same as for all documentation:

    1. Because it’s boring to write documentation
    2. What is obvious and what needs to be explained is often not apparent for the person creating it
    3. When time is limited then documentation is the first thing to be reduced
    4. Not enough value is put on good documentation and the associated skill

    But in the spirit of FOSS documentation is something that is actually an excellent thing for a person new the project to start contributing to. You need to understand the code anyway to be able to help with bugfixes / feature creation so might as well build reputation by improving on existing documentation by adding clarification and comments and wiki entries that would’ve aided in making it quicker for you to grasp something.

    • MagicShel@programming.dev
      link
      fedilink
      arrow-up
      0
      ·
      9 months ago

      Also, it’s not just that it’s boring, difficult, and undervalued, but also during development the code is constantly changing and to constantly spend 20 minutes updating documentation for a 3 minute change that might or might not solve an issue is horribly wasteful of time. So by the time a project releases, probably 80% of the documentation is outdated already.

      The only exception to this I’m familiar with (though I’m sure there are others) is using OpenAPI to generate both source code and documentation from a configuration file. That way your documentation and code are always in sync. But that’s a relatively narrow use case that isn’t going to cover low-level stuff like algorithms.

  • justJanne@startrek.website
    cake
    link
    fedilink
    arrow-up
    0
    arrow-down
    1
    ·
    edit-2
    9 months ago

    Considering that reading source code can take a long time

    You’ll get faster over time, until reading code is faster than reading documentation, as code will always represent what’s truly happening, while docs are frequently outdated.

    In a language the user isn’t familiar with

    If you’re not that familiar with the language, it’s likely you won’t be contributing to the project. Open source projects usually to have quite limited resources, so they tend to optimize docs and dev UX for people who are likely to contribute.

    • erranto@lemmy.worldOP
      link
      fedilink
      arrow-up
      0
      ·
      9 months ago

      If you’re not that familiar with the language, it’s likely you won’t be contributing to the project.

      You can still borrow and implement features developed by project x into project y , but I do understand the time limitation.

      because I am more of a visual learner I wondered whether developers don’t use diagrams and flow charts, or just don’t include them in the docs.

  • Diplomjodler@feddit.de
    link
    fedilink
    arrow-up
    0
    arrow-down
    1
    ·
    9 months ago

    Most software is poorly documented. That applies to FOSS as much as to commercial projects.