Writing an interpreter... in OCaml?!?

  Рет қаралды 42,020

TJ DeVries

TJ DeVries

Күн бұрын

Пікірлер: 147
@tini_
@tini_ Жыл бұрын
Tom is a genius!
@tapu_
@tapu_ Жыл бұрын
JDSL is the best language ever.
@teej_dv
@teej_dv Жыл бұрын
oh no, the meme is spreading. it's broken containment from the degen army
@londospark7813
@londospark7813 Жыл бұрын
@@tapu_ Aren't you supposed to JDeez Nuts?
@leonvolq6179
@leonvolq6179 Жыл бұрын
Everyone in twitch programming knows the joke by now
@georgecop9538
@georgecop9538 Жыл бұрын
​@@tapu_ until you add code comments, but yeah, genius.
@ameenkhieredeen6663
@ameenkhieredeen6663 Жыл бұрын
I love OCaml, would be great if you made an OCaml course or tutorials would definitely watch them.
@teej_dv
@teej_dv Жыл бұрын
awesome! I'm considering how to do it. thanks for the feedback :)
@jsonkody
@jsonkody Жыл бұрын
Me too
@tjfreak12
@tjfreak12 Жыл бұрын
Here is a great playlist for learning ocaml. kzbin.info/aero/PLre5AT9JnKShBOPeuiD9b-I4XROIJhkIU&si=WbnPg2gbb8qZnCuo
@Ytuserqf
@Ytuserqf 4 ай бұрын
@@teej_dvhave you done it?
@JakobKenda
@JakobKenda Жыл бұрын
Yes, definitely do more of this. I don't think we need a full OCaml course, just learning alongside you explaining code is enough I think.
@teej_dv
@teej_dv Жыл бұрын
cool :) we'll at least start with just "learn ocaml through seeing this code" i think
@bayrockdev
@bayrockdev Жыл бұрын
Keep these coming, OCaml has been my language of choice recently and deserves attention.
@gokukakarot6323
@gokukakarot6323 2 ай бұрын
Thank god for your existence, I was looking for any project to do with ocaml, I was just getting bummed out. Hoping this is going to become neorust.
@pharmajoe990
@pharmajoe990 Жыл бұрын
This is great, I’ve only ever heard of ocaml previously. Will have to have a play around, cheers
@teej_dv
@teej_dv Жыл бұрын
sweet :) I hope you enjoy it! I'm having a lot of fun
@maleldil1
@maleldil1 Жыл бұрын
Please keep these coming! I've done the book in Go, so seeing a different way will be interesting. I can already see how much better pattern matching is compared to type switching on interfaces in the original. OCaml is a language that I used to be interested in (as a middle ground between Rust and Haskell), but I got put off by how inconsistent the community is. I can see it being useful for cases like this, where you likely don't need much outside of the core language.
@draakisback
@draakisback Жыл бұрын
I love Ocaml, glad you decided to make a video on it. I know you're pretty hot on the language also but obviously it's not as popular as say rust for example. I'm looking forward to the opam Windows release since I do most of my development on Windows. Fortunately in the meantime we have DKML which is pretty fantastic.
@rickdg
@rickdg Жыл бұрын
Nice to see your first ocaml my caml video. If you can find a way to have your green screen a little further back, you can probably prevent the green reflection that its casting on your head.
@TerryDellino
@TerryDellino Жыл бұрын
I’m enjoying these Ocaml videos! I have always loved functional programming languages, but never got into Ocaml. I need to give it another look. Pattern matching makes code really easy to reason about IMO
@lillyschwarz5295
@lillyschwarz5295 9 ай бұрын
you're literally saving me and my bachelor thesis xD
@industry_std
@industry_std Жыл бұрын
When I discovered pattern matching with Elixir my mind was blown... and yet this looks even 'cuter'
@tyrox9
@tyrox9 Жыл бұрын
Really liked the video, what i would like to see is how to use dune/run tests or an explanation on how to use modules. I tried to read the documentation and i could not figure this things out.
@AlleBalle54
@AlleBalle54 Жыл бұрын
great video, the mattern matching looks very intressting and think I would've loved it for a use case I had the other day
@imhassane
@imhassane Жыл бұрын
Learnt it in my second year of university, couldn’t understand this language at the time but this code looks beautiful
@orbital1337
@orbital1337 Жыл бұрын
OCaml is pretty nice - especially for this kind of stuff! I've used it a bit in the past for automated reasoning & formal verification type work.
@rahuldevstech
@rahuldevstech Жыл бұрын
OCaml, my Caml! But, seriously: even more OCaml curious now. Thanks for sharing!
@teej_dv
@teej_dv Жыл бұрын
well hopefully next few videos will convince you even more!
@arisweedler4703
@arisweedler4703 Жыл бұрын
this is awesome. Would love to see more of this
@WillEhrendreich
@WillEhrendreich Жыл бұрын
Great stuff, love it.
@xtsxo9872
@xtsxo9872 Жыл бұрын
great video! really interested to see more ocaml
@Honken
@Honken Жыл бұрын
Subscribing for OCaml content! One of the nicest programming languages in existence.
@Blure
@Blure Жыл бұрын
Thanks for the video TJ. Could you please share your ocaml setup for neovim? Mine is not showing type hints like yours. Thanks :)
@nemartin1
@nemartin1 Жыл бұрын
Subscribed just for the future OCaml videos.
@pauloffborba
@pauloffborba Жыл бұрын
This remember the Elixir code 👏🏻👏🏻 Great video!
@fredericchopin255
@fredericchopin255 Жыл бұрын
Wow! We do ocaml in france and i had a project for writing mini compiler of java using ocaml
@TayTayChan
@TayTayChan Жыл бұрын
Long overdue video, Teej! I knew you were doing some OCaml and got curious, but try as I might I'm not made for watching live streams. Interesting implementation, would love to see more. I did some ML back in the day, so it's not completely alien.
@The45DegreesProject
@The45DegreesProject Жыл бұрын
This is cool. First time I see OCaml and sort of get what is going on :D
@The45DegreesProject
@The45DegreesProject Жыл бұрын
I’d love to see more on OCamls type system and how modules/functors work
@AndreiDim
@AndreiDim Жыл бұрын
keep it up with ocaml videos 👍
@teej_dv
@teej_dv Жыл бұрын
will do!
@tofuman9526
@tofuman9526 Жыл бұрын
Yes yes, it’s fun to watch OCaml lang used to make something interesting like this. Would love to see an API development or something too
@charstringetje
@charstringetje Жыл бұрын
Any curried ML language is nice, and Rok too (even though it doesn't curry functions by default). With OCaml I just had to get used to the French ordering of product types: `int list` instead of `List Int`. French acronyms can be confusing in the same way.
@alphabitserial
@alphabitserial Жыл бұрын
Would love to see more OCaml videos!
@RoccoGhielmini
@RoccoGhielmini Жыл бұрын
Love it love it!! Keep going
@pedrosaraiva1930
@pedrosaraiva1930 Жыл бұрын
15 years ago at my university class we were assigned to build a interpreter in OCaml and Prolog
@mattinykanen4780
@mattinykanen4780 Жыл бұрын
My own Master's final programming project was to implement a compiler whose (i) source language was Prolog extended with certain features which come in handy when you are writing compilers in Prolog (ii) object language was standard Prolog (iii) implementation language was... Prolog, of course.
@sultanaldihani3296
@sultanaldihani3296 Жыл бұрын
You did an amazing video, the idea is interesting I’m doing the same but with rust to learn it 🌚 continue the great work plz
@rac116
@rac116 Жыл бұрын
Functional programming! 🎉
@mustafazakiassagaf1757
@mustafazakiassagaf1757 Жыл бұрын
i love this video. Maybe having a little bit live coding explaining how to solve something in ocaml would be nice
@teej_dv
@teej_dv Жыл бұрын
come watch on twitch :) twitch.tv/teej_dv
@mustafazakiassagaf1757
@mustafazakiassagaf1757 Жыл бұрын
​@@teej_dvahh I did not know that you also stream it. gonna watch the vod
@hyto
@hyto Жыл бұрын
Awesome video, keep them coming.
@teej_dv
@teej_dv Жыл бұрын
Will do :)
@AXYGaming
@AXYGaming Жыл бұрын
Ocaml has built in support for lexing and parsing with .mll and .mly extensions with ocamllex and ocamlyacc respectivly
@lpanebr
@lpanebr Жыл бұрын
10:13 oh I see it! I see the angstrom pattern matching there! Right? Interesting!
@diegolikescode
@diegolikescode Жыл бұрын
waiting for the playlist, babie!
@Danielo515
@Danielo515 Жыл бұрын
By the way, if you want to keep people hooked and understanding the syntax easier, you could consider using reason syntax. It is the same, but with a more C-style looking
@talhaakram
@talhaakram Жыл бұрын
love this.
@teej_dv
@teej_dv Жыл бұрын
love this comment :)
@nickskywalker2568
@nickskywalker2568 Жыл бұрын
thanks for the ocaml love
@teej_dv
@teej_dv Жыл бұрын
my pleasure, more coming soon!
@nickskywalker2568
@nickskywalker2568 Жыл бұрын
@@teej_dv nice! Let's get ocaml some momentum in the industry!
@tavin136
@tavin136 Жыл бұрын
I'll [[likely]] save this for later.
@sgwong513
@sgwong513 Жыл бұрын
never lean OCaml before, although you try to explain it but still couldn't get how it works(I also haven't read the book for how it implement the lexer). Might see the code offline again. but it seems fresh and interesting to look at functional program with OCaml. had been doing imperative programming for so long time.
@un9286
@un9286 Жыл бұрын
I would actually like some tutorial in how to make the Ocaml lsp work in nvim
@goosechaser
@goosechaser Жыл бұрын
Bought this book months ago and was unironically going to write it in OCaml too! Lmao. Learned OCaml for functional class in school
@ercpereda
@ercpereda Жыл бұрын
That was awesome! Can you share the resources do you use to learn OCaml?
@teej_dv
@teej_dv Жыл бұрын
Mostly: 1. Reading the official docs from ocaml.org 2. Starting to build things :) also, asking friends in discord / twitch / etc.
@kylestubblefield3404
@kylestubblefield3404 Жыл бұрын
We need all the OCamls!
@jakeshoemaker1483
@jakeshoemaker1483 Жыл бұрын
This was really cool.
@Tala2n
@Tala2n Жыл бұрын
Ocamllex is included with Ocaml package. So I use it for the lexer. I refuse to use ocamlyacc, that adds dependency and Ocaml is sufficiently cool to implement a parser.
@marcusrehn6915
@marcusrehn6915 Жыл бұрын
Seems really cool, would love to see other examples! A bit curious about the performance, but mostly really curious about the ecosystem. Is there a package manager that people actually use and are there implementations for graphl and grpc as well as the most common databases?
@shivisuper91
@shivisuper91 Жыл бұрын
More functional programming please! Also, did you create your own plugin to show type hints for each function or there's an existing plugin for it?
@RoryIsNotACabbage
@RoryIsNotACabbage Жыл бұрын
Hey teej is back 😀
@teej_dv
@teej_dv Жыл бұрын
haha finally :) hoping to get back into making some new videos more regularly
@RoryIsNotACabbage
@RoryIsNotACabbage Жыл бұрын
@TJ DeVries I look forward to it. ngl was sad there was no 0.9 launch party
@felgenh399
@felgenh399 Жыл бұрын
keep it comin'
@thomasfrans1185
@thomasfrans1185 Жыл бұрын
This was very interesting!
@teej_dv
@teej_dv Жыл бұрын
Thanks!! :)
@coptan99
@coptan99 Жыл бұрын
Which theme do you use?
@--------------------.
@--------------------. Жыл бұрын
OCaml seems really nice! I wish i started my fp journey with it instead of Haskell!
@mattinykanen4780
@mattinykanen4780 Жыл бұрын
I did it the other way around: First Standard ML and Caml - because it was and still is the only ML with a pulse - but then turning to Haskell because some features of Caml were not quite orthogonal, Whenever you add later a totally different programming or data model into an existing language, you are bound to see the stitches which keep that Frankenstein's monster together. As proof, compare (i) the Java generics, which added parametric polymorphism into what had been so far a purely object-oriented language with ad hoc and subtype polymorphism (ii) the "O" which added objects into Caml which had been so far purely parametrically polymorphic (iii) Haskell which developed instead the fresh idea of classifying types and not values. In OO terms, they did introduce ad hoc polymorphism, but for interfaces only. Values stayed intact, and hence parametric polymorphism continue working as before.
@rohithsuresh1877
@rohithsuresh1877 Жыл бұрын
Banger of a video teej!! How do you have an end of line marked in neovim(the return symbol at the end of each line), is it some plugin?
@Mankepanke
@Mankepanke Жыл бұрын
Native. See :help list and listchars
@CrazyLuke11
@CrazyLuke11 Жыл бұрын
I love neovim!! ❤
@dandogamer
@dandogamer Жыл бұрын
Functional languages seem great for writing parsers
@ersstuff
@ersstuff Жыл бұрын
The C A M L, with an O at the front It’s not imperative scaring ya, and we ain’t tryna stunt Just tryna process every single type to keep it in check And having higher-order fun with it is just a side effect (c) rangersbeats
@teej_dv
@teej_dv Жыл бұрын
very nice lyrics
@kaioneal6160
@kaioneal6160 Жыл бұрын
Ah I finally found your channel At last the algorithm is working as it should
@jackevansevo
@jackevansevo Жыл бұрын
This code looks so elegant compared to the Go implementation.
@teej_dv
@teej_dv Жыл бұрын
LETS GOOOOOO
@matthewrossee
@matthewrossee Жыл бұрын
Great video, ocaml seems pretty cool. I have kinda mixed feelings about immutability though. I love the idea behind pure functions, but how do the performance and memory consumption compare to mutable solutions? It seems like the lexer is allocated for every token. Does ocaml perform some kind of optimization behind the scenes?
@teej_dv
@teej_dv Жыл бұрын
ocaml's compiler and garbage collector are optimized for lots of small, immutable allocations! In some cases, making many small objects (that are all declared mutable) is actually faster than creating mutable ones (because the compiler can make more optimizations). It's not like trying to write immutable code in javascript.
@teej_dv
@teej_dv Жыл бұрын
but that's a great question and concern!
@anarchymatt
@anarchymatt Жыл бұрын
Persistent data structures can be used to minimize copying!
@anderdrache8504
@anderdrache8504 Жыл бұрын
In general, immutable functional languages are mostly slower than something like C or Rust but they are often faster than mutable and garbage-collected languages. Immutability provides a bunch more possibility for optimization!
@matthewrossee
@matthewrossee Жыл бұрын
@@anderdrache8504 Do you know some good articles or something like that about such optimizations? I'm really interested how it works under the hood.
@mazinabdallah5241
@mazinabdallah5241 Жыл бұрын
I’m curious to know why you chose OCaml specifically out of all the FP langs. Like why not Haskell, for example?
@mattinykanen4780
@mattinykanen4780 Жыл бұрын
Apart from being able to use monadic parsing expressions - which is admittedly a _huge_ win! - laziness does not really buy you much in compiler writing. In contrast, say, Prolog-style logical variables with unification make backpatching semi-generated code much simpler.
@kylegaijin
@kylegaijin Жыл бұрын
I'm beginning to love Ocaml. It's the language that would be born if Rust and Go had a baby. By the way you went through the code really fast, so it was difficult to grasp a lot of what you were saying. Do you have this code posted on github? I looked, but I didn't find it.
@viktorhabchak470
@viktorhabchak470 Жыл бұрын
More OCaml!
@mumk
@mumk Жыл бұрын
The syntax of OCaml and F# bears a striking resemblance
@mattinykanen4780
@mattinykanen4780 Жыл бұрын
...because F# began essentially as "Microsoft OCaml"...
@ben.faerber
@ben.faerber 8 ай бұрын
Java is to C# what OCaml is to F#. Same with Pascal and AL
@piotrjaga6929
@piotrjaga6929 Жыл бұрын
do you mean like PiterDeVries in diune?
@NathanHedglin
@NathanHedglin Жыл бұрын
Ocaml os amazing for interpreters
@dacam29
@dacam29 Жыл бұрын
I studied OCaml at university in 2007.... crazy
@mattinykanen4780
@mattinykanen4780 Жыл бұрын
And now the scary part: the name is originally an acronym for Objective (as in OO) Categorical (as in Category theory in math - yes, monads & c.) Abstract (as in device independent meaning for its programs) Machine (as in reduction rules which implement that meaning) Language (as in a notation for the C and A above). It's really a clever decoy which tempts you from the bountiful fruits of Real Programming into the arid wasteland of Computer Science - with the tacit goal to make you unemployable...
@slowjocrow6451
@slowjocrow6451 Жыл бұрын
Hey teej, can you explain c# yield to a noob? I'm really struggling to understand
@teej_dv
@teej_dv Жыл бұрын
c# yield is like "return" but it keeps the state of the function call, so you can resume it later ( I think)
@_idiot
@_idiot Жыл бұрын
could google and read 100 explanations instead of wait for him to answer a youtube comment
@slowjocrow6451
@slowjocrow6451 Жыл бұрын
@@teej_dv Thank you. I saw it in a video with you and Prime recently. You two look like you have so much fun streaming together. Thanks for being so inspiring ❤️
@MENTOKz
@MENTOKz Жыл бұрын
does ocaml have easy concurrency like in golang? but yeah i like the video
@noname78520
@noname78520 Жыл бұрын
they just added multicore support in the last version 5.0
@Danielo515
@Danielo515 Жыл бұрын
You’re officially hooked in Ocaml, nuahahaha
@ebukaezike9308
@ebukaezike9308 Жыл бұрын
What Font is this ?
@dezorted2834
@dezorted2834 Жыл бұрын
thevimteejen came back!
@JohnWasinger
@JohnWasinger Жыл бұрын
Is Ocaml easier than writing with flex and yacc?
@teej_dv
@teej_dv Жыл бұрын
Hmm... I think flex/yacc can often be "easier"... until they're not. Once you want to try and do something non-standard, you'll have a hard time. The point of the series isn't to pick the easiest way to write an interpreter, but instead to understand what is happening under the hood.
@havocindustries3078
@havocindustries3078 Жыл бұрын
Flex and yacc are code generators. They open a can of worms beyond imagination. Code generation is pure evil. Stay away from those and use a language that allows you to express ideas in a concise way. Haskell, OCaml, F#, Scala, Rust are good examples.
@anderdrache8504
@anderdrache8504 Жыл бұрын
Lexers and parsers are in my opinion not hard enough problems to justify parser generators. Of course use what you like but parsing is so simple that you can just do it yourself and be more flexible!
@desuburinga
@desuburinga Жыл бұрын
Ocaml my caml with FEM maybe???
@teej_dv
@teej_dv Жыл бұрын
Maybe if they get tweeted at a bunch about it :)
@Vanna1321
@Vanna1321 Жыл бұрын
chad
@teej_dv
@teej_dv Жыл бұрын
actually, the name's teej ;)
@aftalavera
@aftalavera 11 ай бұрын
Is Ocaml Rust daddy! If so, whats the big deal?
@vaishnavmhetre9061
@vaishnavmhetre9061 Жыл бұрын
Tom spelled Immuntable in comments ❤️
@maman14141414
@maman14141414 Жыл бұрын
i know nothing about ocamel but i have for sure seen you using your superior typing speed to make an appearance on AsmonGold stream
@teej_dv
@teej_dv Жыл бұрын
Whilst the older games certainly had a lot of multiplayer, they were absolutely viable single player games. Do you feel this element will be lost with the ever increasing push towards seasons and battle passes in diablo 4?
@maman14141414
@maman14141414 Жыл бұрын
@@teej_dv now a days everything has a battle passe,and most of the time it doesn't serve any purpose beside making money, you should take a look at the video about abusive monetisation strategies that asmongold reacted to very informative
@twenty-fifth420
@twenty-fifth420 Жыл бұрын
Looks like my comment got flagged somehow, I just think OCaml looks pretty is the primary takeaway I got from here 😂. I want to make it work with Godot somehow. ⭐️
@teej_dv
@teej_dv Жыл бұрын
haha, i'm sure it's possible.... given enough time haha
@marcobuess
@marcobuess Жыл бұрын
seeing ocaml makes me miss f#. 😢
@timjames4306
@timjames4306 Жыл бұрын
Require a NeoVim installation and setup guide Video for Windows User also.🙌✌
Writing our own parser in OCaml!
18:37
TJ DeVries
Рет қаралды 21 М.
How OCaml Makes Ints Speedy | Prime Reacts
20:21
ThePrimeTime
Рет қаралды 56 М.
I'VE MADE A CUTE FLYING LOLLIPOP FOR MY KID #SHORTS
0:48
A Plus School
Рет қаралды 20 МЛН
ССЫЛКА НА ИГРУ В КОММЕНТАХ #shorts
0:36
Паша Осадчий
Рет қаралды 8 МЛН
How to have fun with a child 🤣 Food wrap frame! #shorts
0:21
BadaBOOM!
Рет қаралды 17 МЛН
БОЙКАЛАР| bayGUYS | 27 шығарылым
28:49
bayGUYS
Рет қаралды 1,1 МЛН
Ocaml First Thoughts
11:49
ThePrimeTime
Рет қаралды 63 М.
going fast is about doing less
19:41
leddoo
Рет қаралды 176 М.
LIVE: ocaml framework to ocaml saas
TJ DeVries
Рет қаралды 18
I implemented Goto in OCaml
38:41
Tsoding Daily
Рет қаралды 43 М.
Creating Your Own Programming Language - Computerphile
21:15
Computerphile
Рет қаралды 225 М.
The purest coding style, where bugs are near impossible
10:25
Coderized
Рет қаралды 1 МЛН
So you want to write an interpreter?
40:39
Next Day Video
Рет қаралды 135 М.
Ocaml Becomes Rust w/ Garbage Collection?
47:31
ThePrimeTime
Рет қаралды 73 М.
How To Learn A New Programming Language
6:24
ThePrimeagen
Рет қаралды 289 М.
The Worst Thing You Can Do For Your Career
13:15
TJ DeVries
Рет қаралды 35 М.
I'VE MADE A CUTE FLYING LOLLIPOP FOR MY KID #SHORTS
0:48
A Plus School
Рет қаралды 20 МЛН