• @[email protected]
    link
    fedilink
    2010 days ago

    Unfortunately, it makes sense if you know what + means, which is concatenate. - is strictly a math function though.

    Not saying that makes this better. It just makes sense.

    • @[email protected]
      link
      fedilink
      26
      edit-2
      10 days ago

      It is ‘comprehensible’ in the sense that it’s possible to figure out how it happened, but it absolutely does not “make sense” in terms of being a reasonable language design decision. It’s 100% incompetence on the part of the person who created Javascript.

      • @[email protected]
        link
        fedilink
        710 days ago

        I mean, I’d never try to do this anyway because if the types aren’t the same unexpected things can happen. That’s like programming 101.

      • Fushuan [he/him]
        link
        fedilink
        210 days ago

        It makes perfect sense if the Lang objective is to fail as little as possible. It picks the left side object, checks if the operand is a valid operand of the type. If it is, it casts the right variable into that type and perform the operand. If it isn’t, it reverses operand positions and tries again.

        The issue here is more the fact that + is used both as addition and as concatenation with different data types. Well, not an issue, just some people will complain.

        • @[email protected]
          link
          fedilink
          29 days ago

          Computing a nonsensical result is itself a failure. Continuing to run while avoiding giving an error in that case accomplishes nothing but to make the program harder to debug.

    • Tb0n3
      link
      fedilink
      English
      11
      edit-2
      10 days ago

      It’s an issue with most if not all languages that aren’t strongly typed.

      • palordrolap
        link
        fedilink
        410 days ago

        Perl is an old but notable exception. + is purely for addition in the base language.

        If you try to add two strings with it, they’ll be converted to numbers based on any number-like characters they have at their left hand ends, and, if warnings are enabled (and you should definitely do that), you’ll get runtime warnings about it if there’s even anything vaguely non-numeric about them.

        e.g. “1”+“11” will get you 12 with no complaint, warnings or otherwise. Not even the string “12” either, although it’s hard to determine one from the other in Perl. It’s a need-to-know kind of thing. And you generally don’t.

        “a”+“bb” gives 0 as the result because they’re not numbers and “1a”+“11bb” will give 12, but these latter two will give warnings. Two each, in fact, one for each dodgy parameter.

        String concatenation is done with the dot operator instead. “1”.“11” gives “111”. This comes with it’s own minor problems, but at least + is safe.

        • @[email protected]
          link
          fedilink
          English
          39 days ago

          That’s because Perl doesn’t do operator overloading in general. Even the equality operator is different for strings (eq instead of ==). As a language, it may look pretty weird and lack some modern features, but the underlying design is surprisingly intelligent and consistent in many ways.

          • palordrolap
            link
            fedilink
            19 days ago

            Not strictly true.

            Perl’s default bitwise operators do differentiate between numbers and strings that look like numbers in a way that addition doesn’t*, and the readline/glob operator <> does different things depending on what (if anything) is between the signs.

            There’s also the whole overload pragma for objects, which doesn’t affect default data types, but if you’re sufficiently perverse, you can define a String class that uses ‘+’ like JavaScript.

            * in 2015, they added new operators so that those and the original operators don’t overload and have only one specific purpose if the bitwise pragma Edit: feature is turned on. You might know all this already though.