this post was submitted on 18 Feb 2024
516 points (96.9% liked)

Programmer Humor

19564 readers
1441 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 1 year ago
MODERATORS
 

Insert <it's not much but it's honest work> meme. It only supports ints and bools, some logic and simple arithmetics and it compiles to Java but damn was it hard to get that far.

Can you guess what everything does?

you are viewing a single comment's thread
view the rest of the comments
[–] bleistift2@feddit.de 103 points 9 months ago (5 children)

It only supports ints and bools, some logic and simple arithmetics and it compiles to Java but damn was it hard to get that far.

I have a bachelor’s in computer science and I don’t think I would be able to do that…

[–] Sibbo@sopuli.xyz 58 points 9 months ago (5 children)

Compiler courses are typically master level.

[–] pivot_root@lemmy.world 34 points 9 months ago (1 children)

My college must have been full of sadists. They had undergrad compiler courses and required students to take them.

[–] Adramis@lemmy.world 4 points 9 months ago* (last edited 9 months ago) (1 children)

Same, it usually whacked about half the attempted majors into another major. In the first half of senior year. They kept wondering why their program wasn't growing much even though similar colleges' programs were growing like mold on a dorm shower curtain. I enjoyed the course and never used the primary skills taught in it again.

[–] pivot_root@lemmy.world 2 points 8 months ago

It really depends on what you do, but somehow, I actually did end up using some of the things those courses were teaching. It turns out the visitor pattern is extremely useful for writing JavaScript code transformers.

[–] dan@upvote.au 4 points 9 months ago* (last edited 9 months ago)

I had an entry-level compiler course during undergrad. We used JavaCC to generate a lexer and parser based on eBNF grammar.

[–] seliaste@lemmy.blahaj.zone 3 points 9 months ago* (last edited 9 months ago) (1 children)

Im having a mandatory compiler course on my 3rd year of (french) bachelor

[–] WanakaTree@lemm.ee 6 points 9 months ago (2 children)

I definitely read this as you were a third year French major being forced to taking a compiler course for a moment and went wtf. Then my brain slapped itself and realized you mean you're a student in France.

[–] seliaste@lemmy.blahaj.zone 2 points 9 months ago* (last edited 9 months ago)

Haha yeah I meant that I was studying computer science im France and not studying french. Here in France, bachelor are called licence and are only 3 years compared to 4 in north america afaik, but there are way fewer electives

[–] bleistift2@feddit.de 1 points 9 months ago

Nah, I think they’ve won the French version of The Bachelor 2 years in a row and are about to win the third.

[–] BorgDrone@lemmy.one 2 points 9 months ago

It was part of my BSc, but that was over 20 years ago.

[–] MonkderZweite@feddit.ch 0 points 8 months ago* (last edited 8 months ago)

in your area on the world map (wherever that is).

[–] swordsmanluke@programming.dev 37 points 9 months ago (2 children)

Compilers are a specialized topic - and syntax design is fiddly - but it really is no harder than any other sort of program. A lot of the hard theoretical work was done back in the sixties and seventies. You don't have to start from scratch. These days it's "only" a matter of implementing the features you want and making sure your syntax doesn't leave itself open to multiple interpretations. (just as arithmetic, e.g. '5 × 4 - 1' requires some rules to make sure there's only one correct interpretation, so do language syntaxes need to be unambiguous to parse. )

Don't get me wrong - writing a language is a lot of work and it's super cool that OP has done this! I just want to stress that language development is 100% doable with an undergrad degree. If you understand recursion and how to parse a string you already have all the theory you need to get started.

[–] prof@infosec.pub 8 points 9 months ago

Valuable input! I actually am an undergrad student. There are a lot of frameworks out there that support writing languages, with MPS being one of them.

If I'd start from scratch again and had a little more time, I'd frankly try writing an interpreter myself, instead of trying to conform to weird framework syntax, which I won't be able to reuse in any other context.

Saying syntax design is fiddly is an understatement. I focused very hard on getting an abstract syntax somehow finished before working on generation in my first iteration. Then I had so much technical debt, that I couldn't get anything to work and had to rewrite a lot. So I scrapped it all and started again, starting with top level concepts including generation and only implementing some lower level ones, once everything around it worked properly.

[–] sik0fewl@kbin.social 4 points 9 months ago

If you'd like to learn how, I recommend the book (which is also available online) Crafting Interpreters.

[–] tsonfeir@lemm.ee 4 points 9 months ago

Make a meme with no GitHub repo? Don’t sell yourself short.

[–] catastrophicblues@lemmy.ca 1 points 9 months ago (1 children)

It’s likely transpiring and not compiling, so it’s a lot easier than it seems. Source: made a language that adds features to Python and transpiles to valid Python.

[–] prof@infosec.pub 1 points 9 months ago

It doesn't compile or transpile in actuality. It generates Java based on an abstract syntax tree. The concrete syntax is not considered in Java generation by MPS.