• cgtjsiwy@programming.dev
    ·
    1 year ago

    Regular expressions are great and can always be matched in linear time with respect to the input string length.

    The problem is that JS standard library RegExps aren't actually regular expressions, but rather a much broader language, which is impossible to implement efficiently. If RegExp switched to proper regular expressions, they would match much faster but supporting backreferences like /(.*)x\1/ would be impossible.

  • sebsch@discuss.tchncs.de
    ·
    1 year ago

    Is there one thing not screwed up in this language? I mean it's regex, there are so many good implementations for it.

    • philnash@programming.dev
      hexagon
      ·
      1 year ago

      JavaScript's regex engine isn't the only one to have these problems. There certainly are other implementations, like Re2 and Rust's implementation, that don't have this issue. But they also lack some of the features of the JS implementation too.

      • sebsch@discuss.tchncs.de
        ·
        1 year ago

        Ok thanks for the clarification.

        I would argue, the gold standard of regex would be perlre or even re from python. I never heard one discouraging using them. Do you know sth I don't?

        • burntsushi@programming.dev
          ·
          1 year ago

          Both Perl and Python use backtracking regex engines and are thus susceptible to similar problems as discussed in the OP.