• Pleonasm@programming.dev
    link
    fedilink
    English
    arrow-up
    28
    arrow-down
    3
    ·
    1 year ago

    Who is this for? People who write lots of regular expressions won’t need it because they know what they’re doing and people who don’t write lots of regular expressions probably won’t find it anyway.

    It just seems like a weird type of user who actually wants this.

    • realitista@lemm.ee
      link
      fedilink
      English
      arrow-up
      27
      arrow-down
      1
      ·
      edit-2
      1 year ago

      I almost never use regex, but when I do, I’d love something like this. Exactly because I don’t use regex enough to be bothered learning it’s impenetrable syntax.

      • NightAuthor@beehaw.org
        link
        fedilink
        English
        arrow-up
        7
        ·
        1 year ago

        I learned enough to see how powerful it was, then started using it within Sublime Text to edit data from time to time. (Extract URLs or something from a websites code, reformat X or Y data for a script I’m hacking together) and I’ve slowly retained more and more of the elements I repeatedly use. I think I’ve actually got a pretty good grasp on it. Maybe you should be using it more.

        • realitista@lemm.ee
          link
          fedilink
          English
          arrow-up
          5
          ·
          1 year ago

          I’m not a programmer by trade so I only program when I need something and regex is a small subset of that. Usually I find something someone else wrote and adapt it to my needs. But it would be nice to be able to write things from scratch, this would be a helpful tool for that for sure.

      • custom_situation@lemm.ee
        link
        fedilink
        English
        arrow-up
        6
        arrow-down
        1
        ·
        edit-2
        1 year ago

        i mean, you can learn the basics of matching in 30 minutes or less. that core knowledge will be broadly applicable across any tool that uses regex. things get much easier once to have a handle on the basics.

        …or you can learn this regex dsl and still have to learn regex. the difference is you’re learning a non-portable regex syntax.

        • IronDonkey@lemmy.world
          link
          fedilink
          English
          arrow-up
          5
          arrow-down
          1
          ·
          1 year ago

          You’re right, I can learn the basics of regex in 30 minutes. Then I can write my one regex. Then I can forget the basics of regex in 3 minutes, because regex’s syntax is random garbage that makes no intuitive sense, and I hate and suck at memorizing nonsense. Repeat every 4-16 months.

          It’s true though that regex is entrenched enough that even if something is easier to read, it’s unlikely that it’ll replace regex any time soon. You’d need a couple big names to adopt it, then many years.

          But if there’s a readable replacement that can convert to and from regex - well, screw it, I’m in. Even if I’m required to use regex in some program, if I can write something that makes sense without the requisite half hour of googling crap, I’ll just use it as a separate tool to make and read regex strings.

        • realitista@lemm.ee
          link
          fedilink
          English
          arrow-up
          2
          ·
          1 year ago

          Probably I’ve spent the 30 minutes 5-10 times over my life. But then it’s a few years till I need it again and I need to spend the 30 minutes again.

      • SloppyPuppy@lemmy.world
        link
        fedilink
        English
        arrow-up
        3
        arrow-down
        2
        ·
        1 year ago

        I just learned to type what I want from a regex in chatgpt and call it a day. It works pretty well.

        Also fuck regex.

    • minorninth@lemmy.world
      link
      fedilink
      English
      arrow-up
      5
      ·
      1 year ago

      OK, let’s say you’ve got a bunch of regexes in a source repository that need to get modified frequently. It can be difficult to code-review complex regexes, and even harder to code-review changes to an existing regex.

      Something like this might actually help. A change to a complex regex might actually produce a more clear diff of a subset of lines.

      Also, I think being able to comment in the middle of a regex would be super handy for that type of code.

      • Pleonasm@programming.dev
        link
        fedilink
        English
        arrow-up
        1
        ·
        1 year ago

        But you can do that already in many languages using extended Regex syntax.This doesn’t add anything except more verbosity and another syntax to learn.

    • Spzi@lemm.ee
      link
      fedilink
      English
      arrow-up
      2
      ·
      1 year ago

      It might be used in education. Some who learned it this way might stick to it, or advance to your first group.

    • yoavlavi@programming.devOP
      link
      fedilink
      English
      arrow-up
      11
      arrow-down
      3
      ·
      edit-2
      1 year ago

      I wouldn’t consider Melody a new flavour of regex as it compiles to ECMAScript regular expressions.

      I’d consider being more verbose than regular expressions as a great thing for what this project aims to do, regular expressions are very write optimized which is the wrong (IMO) tradeoff to make in a shared codebase (or even your personal code that’s more than a few days old) where code is read much more often.

      • custom_situation@lemm.ee
        link
        fedilink
        English
        arrow-up
        5
        arrow-down
        1
        ·
        1 year ago

        respectfully disagree—this is very much a regex dsl. folks still need to conceptually understand regex to use this, which begs the question about who this is for.

        the best use case i can think of is large and complicated expressions, but i’d need to see more of that to have a definitive opinion.

      • NightAuthor@beehaw.org
        link
        fedilink
        English
        arrow-up
        3
        ·
        1 year ago

        I don’t know all the forms of regex but might it be useful to have this capable of compiling to different types of regex?

      • vrighter@discuss.tchncs.de
        link
        fedilink
        English
        arrow-up
        3
        arrow-down
        1
        ·
        1 year ago

        if it can only be used to create regexes, and all programs compile to regexes, then it is a regex flavor in itself.

        And let’s not kid ourselves, regexes are not that hard. They can look cryptic, but in most cases they’re not really that hard to understand.

        all this does is make it much more verbose and introduce the HUGE inconvenience of a separate compiler for regexes, since regexes are typically embedded within other files written in other languages that this compiler can’t understand. So somehow regexes would end up needing their own file.

  • fubo@lemmy.world
    link
    fedilink
    English
    arrow-up
    15
    ·
    1 year ago

    Sure, but can it go the other way — turn a regexp string into a parse tree and then into Melody syntax?

    Or, at least, the equivalent of CL-PPCRE’s parse-string?

        • yoavlavi@programming.devOP
          link
          fedilink
          English
          arrow-up
          8
          arrow-down
          1
          ·
          1 year ago

          Awesome idea, will definitely take it into consideration when that feature is available. Melody actually has a VSCode extension with highlighting and snippets, could be added to that

        • Grandwolf319@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          2
          ·
          1 year ago

          Yeah, I think it makes little sense to have another programming language to create a regex but it sounds like a great regex inspect tool.

          Keep everything in regex, want to change something complicated? You can translate it into this language, tweak it, then translate it back!

          • Die4Ever@programming.dev
            link
            fedilink
            English
            arrow-up
            1
            ·
            edit-2
            1 year ago

            maybe it makes sense if you’re working on a project that uses a ton of different regexes and really depends on them, idk what kind of project that would be though

            maybe an html parser or web browser? /s

            seriously though this would be cool in a compiled language if it’s built in, but adding another build step to transpile your regexes might be a bit annoying especially if you’re using an interpreted language

  • Pika@lemmy.world
    link
    fedilink
    English
    arrow-up
    13
    arrow-down
    2
    ·
    1 year ago

    Nothing makes sense about this, how can anyone understand this. I think I will stick with standard RegExp. It’s short, it’s simple yet complex at the same time. And it gets the job done

  • maegul (he/they)@lemmy.ml
    link
    fedilink
    English
    arrow-up
    5
    ·
    1 year ago

    Quickly looking at the readme, it seems nice and readable. I’d be curious though to see examples of monster expressions, as I’d be worried that Melody’s syntax wouldn’t be so helpful there (not sure though).

    I don’t mind the verbosity, but it does feel like it leans a tad too much plain language with the some of stuff.

    It’d be cool if it could also produce train track diagrams.

  • RandomBit@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    5
    ·
    1 year ago

    I can’t say this is for me. What I really need is something that will convert one flavor of regex to another. It’s really annoying to always have to look up the shortcuts and capture group syntax.

    • ajjlyman@lemmy.sdf.org
      link
      fedilink
      English
      arrow-up
      2
      ·
      1 year ago

      Yes! I actually had this exact desire years ago, and went searching for it. RegexBuddy does this, best $US 40 I’ve spent. It’ll even do its best to make something that’ll match the same things, even if you’re using features that aren’t technically supported in the target. Don’t worry, it’ll describe exactly what doesn’t work, and why, when it does that.

      For example, if I ask it to convert from C# /(?>atomic) case-(?i)insensitive(?-i) string/ to JavaScript (chrome) it’ll throw out: /(?:atomic) case-[iI][nN][sS][eE][nN][sS][iI][tT][iI][vV][eE] string/, along with the warning:

      Conversion is incorrect because the target application's regular expression flavor doesn't have certain features: JavaScript (Chrome) does not support atomic grouping

    • custom_situation@lemm.ee
      link
      fedilink
      English
      arrow-up
      2
      ·
      1 year ago

      this is really the problem here. it’s very much lipstick-on-a-pig and doesn’t actually reduce complexity.

  • custom_situation@lemm.ee
    link
    fedilink
    English
    arrow-up
    4
    arrow-down
    1
    ·
    1 year ago

    so, where’s the email address regex? that’s where this lives or dies. there is no reason to use this for extremely simple happy-path regexes.

    i’m having a tough time understanding who this is for. a beginner might think this is great, but they’re shooting themselves in the foot by adding an additional layer of abstraction rather than reading something to learn the basics.

  • Reptorian@programming.dev
    link
    fedilink
    English
    arrow-up
    3
    ·
    1 year ago

    Hmm, I think I will give it a star in case I need something like this. I did use regex enough to know how it works though I do have a offline regex101 software to aid into that.