17 points

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?

permalink
report
reply
20 points

That’s not supported yet but is planned (see the “reverse compiler” feature in the README)

permalink
report
parent
reply
16 points

sounds like it would make an amazing VSCode extension

permalink
report
parent
reply
8 points

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

permalink
report
parent
reply
2 points

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!

permalink
report
parent
reply
7 points

This look greats! Hopefully I can start skipping chatGPT for regex

permalink
report
reply
20 points

Oh great. A new flavour of regex, but it’s less portable and more verbose. https://xkcd.com/927/

permalink
report
reply
9 points
*

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.

permalink
report
parent
reply
3 points

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?

permalink
report
parent
reply
4 points

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.

permalink
report
parent
reply
2 points

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.

permalink
report
parent
reply
5 points

but it’s less portable and more verbose

you misspelled “less obtuse and more expressive”

Also it doesn’t compete with regex. It’s an abstraction layer. You know, the thing programmers have been building since the dawn of programming to make everyone’s lives easier. There’s a reason why everyone who has the option to has stopped working directly with assembly and C.

permalink
report
parent
reply
28 points

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.

permalink
report
reply
27 points
*

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.

permalink
report
parent
reply
6 points

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.

permalink
report
parent
reply
5 points

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.

permalink
report
parent
reply
0 points

When you want to get better using a hammer, just treat everything as a nail.

permalink
report
parent
reply
1 point

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.

permalink
report
parent
reply
0 points

hey hey! Regex are awesome! Fuck regex syntax!

permalink
report
parent
reply
6 points
*

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.

permalink
report
parent
reply
5 points

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.

permalink
report
parent
reply
6 points

Sure. I just very rarely need just basic regexes.

And once you go beyond these the syntax gets very obtuse. Which means I’m spending an hour+ googling something close to what I need and then using a sandbox to try and tweak it until it does what I need. Then I paste something into my code that I won’t understand anymore 5 minutes into the future - which isn’t exactly great for maintainability.

permalink
report
parent
reply
2 points

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.

permalink
report
parent
reply
2 points

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

permalink
report
parent
reply
11 points

I think it’s for me. I occasionally need regular expressions, like any career programmer. I also hate regular expressions. I have to complely relearn the every time I use them.

permalink
report
parent
reply
2 points

I’m not a programmer, but I do have to write scripts, and I’m the same way with regex.

permalink
report
parent
reply
5 points

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.

permalink
report
parent
reply
1 point

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.

permalink
report
parent
reply
5 points

me for example. I don’t write regex often enough to be really familar with the cryptic syntax. But I do use them every once in a while and dread the occasion every time. Having a more expressive way to write pattern matching instructions would be really useful to me.

permalink
report
parent
reply
4 points

But then you’ll have to learn the syntax of this instead.

I suspect that if you actually start using Melody you won’t find it as helpful as you think you might. Maybe I’m wrong. Let’s see in a year’s time.

permalink
report
parent
reply
1 point

I mean it’s JS. I’m not touching that if I can help it. But what you describe is less of a problem with the concept and more one with an immature technology.

permalink
report
parent
reply
3 points

Oh nice. An entire language that is write-only.

permalink
report
reply
2 points

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

permalink
report
parent
reply

Programming

!programming@programming.dev

Create post

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person’s post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you’re posting long videos try to add in some form of tldr for those who don’t want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



Community stats

  • 3.1K

    Monthly active users

  • 1.8K

    Posts

  • 30K

    Comments