• @Fades
    link
    183
    edit-2
    2 months ago

    WHY IS THE HEALTH INPUT PARAMETER A GODDAMN STRING???

    Why are you passing ‘%’ inside said goddamn string?!?! Not to mention the static reference instead of the actual instance.

    Shame on you

    • katy ✨
      link
      fedilink
      362 months ago

      OldMan.setHealth(“Robert’); DROP TABLE Students;–”)

      • @Fades
        link
        42 months ago

        Finally someone with some wisdom

    • @[email protected]
      link
      fedilink
      29
      edit-2
      2 months ago

      I guess its just a reminder that getting a PhD is often more about dedication than it is about practical knowledge.

    • @Buddahriffic
      link
      232 months ago

      Because the meme wasn’t made by someone with a doctorate in CS or even a bachelor’s.

    • @devfuuu
      link
      19
      edit-2
      2 months ago

      Smells like JavaScript.

    • @[email protected]
      link
      fedilink
      182 months ago

      It’s not his fault the world is made this way.

      He just has to follow it or else that man dies.

    • @FilthyShrooms
      link
      142 months ago

      They use a look-up table with every value from 0% to 100%

    • Fat Tony
      link
      9
      edit-2
      2 months ago

      Honestly, if someone were to try to safe my life. And I find out he uses a string as a parameter to do so. Just let me die right there.

    • VeganPizza69 Ⓥ
      link
      62 months ago

      The high level setter function should be made to handle both string and numeric values.

      If it contains “%” it’s a percentage value.

      If it’s a string without a “%” it’s an absolute value and needs to be normalized.

      If it’s a numeric value, it’s an absolute value.

      If it’s a numeric 100, it’s 100%.

      If it’s a subunitary numeric value, it’s a percentage.

      • @sandbox
        link
        282 months ago

        yeah I’m gonna go ahead and reject your PR, please change this function to accept a decimal value between 0 and 1

        • @ChickenLadyLovesLife
          link
          English
          122 months ago

          Ironically, the worst thing I ever saw a coworker do was to change a function that accepted an Integer value between 0 and 32767 to one that accepted a Float between 0.0 and 1.0. Perfectly sensible change except that it resulted in a 120 mph knuckleball fired a foot above a 10 year old kid’s head, followed by a fist fight between the client and my boss.

          • @jaybone
            link
            112 months ago

            That sounds like something that should have been caught by QA, integration tests or unit tests long before it was launching balls at ten year olds.

            • @ChickenLadyLovesLife
              link
              English
              62 months ago

              Yes, testing the new Little League control module on a field full of Little Leaguers was not the best plan.

              • @jaybone
                link
                32 months ago

                What is a little league control module?

                • @ChickenLadyLovesLife
                  link
                  English
                  72 months ago

                  You push a button and it makes Little Leaguers do whatever you tell them to do. Very potent, should never be misused.

          • @[email protected]
            link
            fedilink
            42 months ago

            yeah every engineer knows you gotta set KidHeadKnuckleballClearance waaay higher than that, it’s compsci 101

      • NTripleOne
        link
        132 months ago

        If it’s a numeric 100, it’s 100%.

        absolute lunacy

        • VeganPizza69 Ⓥ
          link
          3
          edit-2
          2 months ago

          Absolute (cm)

          adding one 0:

          100%, automatically changes unit to %

          (Word table properties)

      • @[email protected]
        link
        fedilink
        42 months ago

        Oldman.setHealth(“dicktits”); //normalize pls

        Oldman.setHealth(“-100±1%”); //make percentage pls

        Oldman.setHealth(0.0); //it is subunitary, but undefined behavior - will it access the ‘numeric value’ overload, or the ‘subunitary numeric value’ overload?

        Don’t write your own code just yet.

        • VeganPizza69 Ⓥ
          link
          32 months ago

          Oldman.setHealth(“dicktits”); //normalize pls

          0

          Oldman.setHealth(“-100±1%”); //make percentage pls

          Reject operations.

          Use absolute number to remove the minus. Math.abs()

          Oldman.setHealth(0.0); //it is subunitary, but undefined behavior - will it access the ‘numeric value’ overload, or the ‘subunitary numeric value’ overload?

          Same result either way, so whatever if branch is first.

          Understand the purpose. If you want to kill the old man with 0, then there’s no point to leaving it as 0.9%, understand the non-linear characteristics of life and death.

          When you’re dealing with the low level functions, sure, you can keep it simple. When you’re reaching the surface of user input, you’re either going to waste time with validation and error reporting, or you’re going to waste time with interfaces that can handle more shit without complaining. There’s no fool proof either way, but good luck pissing users off with endless docs.

          Don’t write your own code just yet.

          If your goal in programming is just to be a traffic cop between the user input and the database, all you’re doing is building a virtual bureaucracy, the kind that people really hate and is easily generated with coding tools. Or you’re just deferring the “smoothing out” burden to the UI developers.

        • VeganPizza69 Ⓥ
          link
          1
          edit-2
          2 months ago

          …ends with. And there are more ways to parse.

      • @Fades
        link
        32 months ago

        Yes absolutely, the parameter even if not in a strongly typed language should be a specific number and the unit should be implied. Overload the method to support different units if necessary or provide a unit as an additional parameter instead of forcing the method to parse the string for any unit type hints that may or may not be there