• devfuuu@lemmy.world
      link
      fedilink
      arrow-up
      6
      ·
      7 days ago

      As long as they don’t go on a holy crusade or forcefully evangelize the entire world by genocide I wouldn’t call them fanatics.

  • Jayjader
    link
    fedilink
    arrow-up
    11
    ·
    7 days ago

    Why do we even need a server? Why can’t I pull this directly off the disk drive? That way if the computer is healthy enough, it can run our application at all, we don’t have dependencies that can fail and cause us to fail, and I looked around and there were no SQL database engines that would do that, and one of the guys I was working with says, “Richard, why don’t you just write one?” “Okay, I’ll give it a try.” I didn’t do that right away, but later on, it was a funding hiatus. This was back in 2000, and if I recall correctly, Newt Gingrich and Bill Clinton were having a fight of some sort, so all government contracts got shut down, so I was out of work for a few months, and I thought, “Well, I’ll just write that database engine now.”

    Gee, thanks Newt Gingrich and Bill Clinton?! Government shutdown leads to actual production of value for everyone instead of just making a better military vessel.

  • jbk@discuss.tchncs.de
    link
    fedilink
    arrow-up
    10
    ·
    7 days ago

    another one not mentioned there: sqlite is really tiny: (from https://sqlite.org/faq.html#q18 )

    The default configuration of SQLite only supports case-insensitive comparisons of ASCII characters. The reason for this is that doing full Unicode case-insensitive comparisons and case conversions requires tables and logic that would nearly double the size of the SQLite library.

  • I Cast Fist@programming.dev
    link
    fedilink
    arrow-up
    4
    ·
    7 days ago

    Their commitment to backwards compatibility, to the point of keeping a known bug that allows primary keys to be null, is both amazing and “wtf”.

    • FizzyOrange@programming.dev
      link
      fedilink
      arrow-up
      3
      ·
      7 days ago

      You can do backwards compatibility and make breaking changes to fix bugs. All you need is an opt-in “target version”. CMake and Android are good examples of this.

      • moonpiedumplings@programming.dev
        link
        fedilink
        arrow-up
        5
        ·
        edit-2
        7 days ago

        Well, I can’t read I guess.

        At least I linked to the code, since the article doesn’t seem to do that. The twitter thread it linked to probably does, but I can’t view the replies without logging in.

      • GissaMittJobb@lemmy.ml
        link
        fedilink
        arrow-up
        13
        ·
        7 days ago

        A limitation of testing is that you can only write tests for cases that you can think of, and cases you can think of ways to write tests for.

        It’s still valuable despite this limitation, of course.

        • FizzyOrange@programming.dev
          link
          fedilink
          arrow-up
          3
          ·
          7 days ago

          That’s not entirely true, e.g. you can do fuzz testing or constrained random testing. Maybe you aren’t including those in “testing”?

          • GissaMittJobb@lemmy.ml
            link
            fedilink
            arrow-up
            2
            ·
            7 days ago

            I was mostly thinking about hand-written tests and manual test procedures, but yeah, fuzzing can help you catch issues as well and you don’t necessarily consciously know about the test cases you put into the system in that case.

            Then again, you have to design the fuzzing input consciously so I guess that’s kind of a “what you can think about”-limitation.

            Good point regardless, thanks

      • MagicShel@lemmy.zip
        link
        fedilink
        English
        arrow-up
        9
        arrow-down
        4
        ·
        7 days ago

        You can write shit tests. Finding new bugs doesn’t surprise me. Putting that much effort in does, but 600:1? That’s some serious red flags there. There are only so many variables in a single line of code. How many unhappy paths can there be for a single line?

        • Kogasa@programming.dev
          link
          fedilink
          arrow-up
          8
          ·
          7 days ago

          SQLite is one of the best tested codebases in existence. Having only so many variables per line means nothing

  • roadrunner_ex@lemmy.ca
    link
    fedilink
    English
    arrow-up
    23
    ·
    7 days ago

    I get it…I’ve never been the maintainer of a codebase that’s deployed on trillions of devices, and backwards compatibility is something to be taken seriously and responsibly when you’re that prolific. I do not begrudge SQLite or any large projects when they make decisions in service to that.

    However

    It always makes me feel oddly icky when known bugs (particularly of the footgun variety) become the new standard that the project intentionally upholds.

    • chaos@beehaw.org
      link
      fedilink
      arrow-up
      3
      ·
      7 days ago

      I’m so confused that the same people can say “why does everyone get their undies in a bunch that we happily accept putting arbitrary data in columns regardless of type, that’s good, it’s flexible, but fine, we’ll put in a ‘strict’ keyword if you really want column types to mean something” and also “every other SQL says 1==‘1’ but this is madness, strings aren’t integers, what is everyone else thinking?!”

    • solrize@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      7 days ago

      It’s not on trillions of devices, just billions. But e.g. a typical android phone has 1000s of sqlite db’s for different purposes.