Thank you for having me on! It was an absolute pleasure.
@DeveloperVoices9 ай бұрын
For me too. ❤️
@MaxAbramson38 ай бұрын
Thanks for tge heads up. Great interview.
@ska4dragons7 ай бұрын
I first heard of you on Primeagen's channel. I could listen to you talk about Odin all day long. Good stuff.
@Reichstaubenminister5 ай бұрын
I just watched an interview with you today, this feels weird.
@torgnyandersson4032 ай бұрын
+1 for the Rush reference!
@tommcboatface19089 ай бұрын
You are such an amazing interviewer. Like for real. You know exactly how to shine the spotlight on the guest, you bring the conversation in really interesting directions, you know what you're talking about and you're insightful. Really impressed with your host skills, they really make the show. The topics and guests are also very well chosen as well. Please keep going!
@DeveloperVoices9 ай бұрын
Thanks! 😊
@natescode9 ай бұрын
Odin sounds like GO without a GC. Having your employer use your language for their major products is a MAJOR accomplishment!
@golangismyjam9 ай бұрын
My thoughts exactly, plus decent windows support which go struggles with a bit, very interesting language.
@BboyKeny9 ай бұрын
Will there be an "Are we X yet?" moment for Odin as was for Rust?
@JohnLeidegren9 ай бұрын
It's an interesting starting point because in one sense there's a product driving development and the features needed to make that product are in the language.
@losinggeneration9 ай бұрын
I've used Odin for a week or two, and Go for many years. So far, it does feel like a mix of Go and maybe something like Zig (with regards to allocators being passed into functions.) A lot of Odin's standard library also seems similar in package structure to Go, which has made it easier for me to find things.
@FullGardenStudent9 ай бұрын
@@BboyKeny no. Odin lang community is not a cult. So most likely not.
@mjolnirdev9 ай бұрын
I have been using Odin as my daily driver for about a year and a half now. At first, I too complained about not having methods, namespaces and a few other "minor" oopy concepts i was used to. And now having spent time with it, i am **so** happy they do not exist. Bill designed a language around psychology of the users, with the tag line of Joy in Programming, and its true. I **love** working in Odin.
@Renni-kg6vf9 ай бұрын
Yeah, I feel like the pitfall of a lot of languages is that they try to include everything, and stray away from their initial concept. For example, Rusts big (maybe biggest) sell is safety, but people often complain about the borrow checker, but if Rust made workarounds easier, it would destroy the point of the language. You should invent a language with a philosophy, python has issues with type checking, and speed, but it has really simple syntax that works well as an interface for libraries. If Python made itself a low level language with strict syntax, they would lose their purpose. There’s a billion general use languages that are all practically the same, when designing a language, it’s good to have a mindset like him and think what the language needs to achieve its purpose. It’s trying to be C v2, so making the same mistakes C++ made would be stupid and silly
@awesomedavid20128 ай бұрын
I think as long as you have packages, that's all the namespacing you really need
@jamesrivettcarnac2 ай бұрын
I try to write no method. But I do like go interfaces. I'm torn.
@matejzajacik84969 ай бұрын
I find Odin very ergonomic, well principled, powerful, and fun to use. And actually quite beautiful, too. Also, Ginger Bill's responsiveness is refreshing -- he responds to questions regularly, usually within minutes. If possible, I'd switch to Odin in my day job in a heartbeat.
@karl_zylinski9 ай бұрын
Odin is amazing and does so many things right! Odin addresses almost all my grievances with C that have popped up over years of making game engines in C. Also, over the years I've come to love ideas like custom allocators and zero-is-initialized, which Odin has taken to heart both in the design of the language and the standard library. I've been using it for roughly two years and within a few weeks I will release my own commercial game written in Odin!
@beloaded37369 ай бұрын
Good luck with that. What's the game name?
@karl_zylinski9 ай бұрын
@@beloaded3736 Thank you. Game name is CAT & ONION. I'll post on this youtube account and on twitter when it's out. Steam page coming soonish. It'll be released on itch before Steam!
@edelgyn26999 ай бұрын
@@karl_zylinski Best of luck!!
@ciCCapROSTi7 ай бұрын
Why would anyone develop a game engine in C, the only reasons to use C is if you don't have a C++ compiler available for the platform or you work with legacy code.
@karl_zylinski7 ай бұрын
@@beloaded3736 thank you! The game is called CAT & ONION. It's out on Steam now ✨
@michaellee27869 ай бұрын
Thank you for giving us Odin, Bill!
@GingerGames9 ай бұрын
Thank you so much for using it!
@androth15029 ай бұрын
@@GingerGames waiting for the next ~ update.
@Ilumar5899 ай бұрын
@@GingerGames No, really, thank you! First language and way of thinking that clicked with me in a long time. Zig is in the same ball park but something about Odin just makes it more fun. May be the syntax or just the fact we have actual strings in the core lib instead of []u8 :p, or maybe just the fact that it's so focused on game dev...can't choose :D . Btw #soa, best thing ever
@hasen_judi9 ай бұрын
@@GingerGames Incredibly grateful for this language!
@GingerGames9 ай бұрын
@@androth1502 what kind of "update"?
@dolorsitametblue9 ай бұрын
Wow, this channel is a treasure trove for any programming language enthusiast! Do you have any plans to interview Nim creator, Andreas Rumpf? Right now is the perfect time as he recently published second edition of his book "Mastering Nim"; Nim hit 2.0 last year and there are number of really cool features coming/returning to Nim in near future: new sum types, Nim's very own IR, IC support, etc. More Nim Topics I would love to see discussed: move semantics 'borrowed' from Rust, new ARC/ORC memory management, Safety without much restrictions
@pookiepats7 ай бұрын
Andreas Rumpf is the creator of Nim, sir - not Araq.
@dolorsitametblue7 ай бұрын
@@pookiepatsAraq is his username But you are right, I should've used a full name here.
@saniancreations9 ай бұрын
Now I'd love to see an interview with Jonathan Blow about the language he is developing (jai, working title), I think he'd be open to it. Whilst syntactically similar to Odin, it has very different opinions about aspects like metaprogramming and macros. Jonathan himself doesn't shy away from voicing his opinion, to the point where he's become a somewhat controversial figure in the programming sphere. He has some good takes, some honestly quite bad, but he sticks by them and it seems to be working out for him. Given all that, the interview is bound to be interesting at the very least, and I'd love to see how it compares to this one.
@meanmole32129 ай бұрын
We need this.
@lucasjames82815 ай бұрын
I’d love to see this
@charlesw312011 күн бұрын
Aye!
@nexovec9 ай бұрын
Odin is hands down my favorite language. It's the only language that feels like a genuine attempt at making a tool for people who deeply care about crafting software.
@ITSecNEOАй бұрын
And so is Zig, Rust etc too. No point for Odin and Zig adoption is already far better
@nexovecАй бұрын
@@ITSecNEO Rust is a language that is built about implementing constraints for programmers in order to get extra guarrantees about a program. Zig is a tool for making C++ less bad, it's their entire user story... No they're not.
@KikkerFish9 ай бұрын
I’ve followed gingerBill for years, watched many of his interviews and I believe he’s one of the most sensible language designers out there!
@e.alvarez28439 ай бұрын
Between using Odin, and watching GingerBill's streams, or listening to his interviews; has been the greatest leap in CS knowledge I've had in the past three years. Thank you @GingerGames
@xba20079 ай бұрын
What a wonderful interview, so refreshing to hear someone that clearly understands language design and current hardware. Thank you so much Kris and Bill. Looking forward to pause my coding Go for a bit and give Odin a go.
@TankorSmash9 ай бұрын
These are very good questions from the host, thank you both for making this! Looking forward to the Verse lang topic too
@liquidmobius9 ай бұрын
I absolutely love your channel! Thanks for all the great content! Reading through the docs and Odin seems to share a lot of syntax with Go, which I personally really like.
@Muskar29 ай бұрын
You're a great interviewer. It would be very cool to get Jonathan Blow on to talk about his Jai-lang, which is also C-like but has a lot of powerful features. Besides exposing low-level stuff when needed, I really like its metaprogramming, its extremely powerful "context" passed onto every function, its focus on development iteration speed and being minimalist. But it's still closed beta, and I think Jon likes to not talk too much about it before he feels its more mature (which he sometimes said is when he's done with his new game written in it). He can be very grumpy on a tangent, but with preparation and a good day, I think you could get some very interesting insights out of him. I'd love to see _you_ try. Thanks for sharing these.
@Laurent_GameDevАй бұрын
I'm currently learning Odin, and it seems like every time I delve into a topic, I'm always amazed at how cleverly things are done in Odin. The more I use Odin, the more I agree with his maxim "Odin is the alternative to C for the joy of programming". I invit any coder to test it for a few weeks. It's an amazing language for coding.
@ElementResources-rp8ox9 ай бұрын
Excellent episode...great questions Chris, you are a great interviewer and ask interesting questions, let your guest answer, and then a thoughtful follow up or two. The language is very interesting and looks tailor made for game and graphics applications based on some of the neat features and libraries discussed.
@mfalk62639 ай бұрын
I enjoy programming in Odin a lot!
@UliTroyo9 ай бұрын
Oh, you're talking to all my favorite hipster langs! It would be cool if you get Sophia to come talk about Nushell-it's like Roc, but also like Bash.
@DeveloperVoices9 ай бұрын
Oooh, nice. I'll drop a line to Sophia and see if she's interested. Thanks!
@olivierdulac9 ай бұрын
This interview was extremely pleasing to watch. I will try to give Odin a go, and also will see what other videos you did on this KZbin channel.
@iatheman9 ай бұрын
Second video I watch and the interviews are so interesting and the conversations go on so pleasantly. That's an amazing skill to have.
@edgeeffect9 ай бұрын
At the moment, I'm seeing Odin and Zig as aiming at simillar places... It'd be fascinating to hear you do a three-way with Andrew Kelley and Ginger Bill.
@sirrobinofloxley71568 ай бұрын
If they formulate the two, Zigdin, Odig, Zod... Oz? 👊
@ITSecNEOАй бұрын
Zig > Odin
@_slier9 ай бұрын
The best c like language out there.. The only downside, there is not a lot of marketting around it.. This language should become more famous/hype compared to other c like languages out there.. It is so much fun to work with.. Memory management is far cleaner from c like languages out there.. Try using it, its totally fun to use
@Tekay379 ай бұрын
Thank you KZbin Algortithm for suggesting this video to me only 2 hours after the Upload.
@BboyKeny9 ай бұрын
Tsoding does this neat technique with a function that does it in C that contains a goto defer and then you put a defer label underneath in the scope. Go defer is still way more preferred but it's nice to have a convention and some ergonomics in C.
@mattanimation9 ай бұрын
it was nice to hear a bit more about the history of Odin and how it came to be in the gaming sphere. thanks!
@Bobbias9 ай бұрын
I had never really thought deeply about how data structures implicitly encode a particular algorithm. One part of me wants to point out that a generic tree could encode either DFS or BFS and there's no way to know based on the tree structure alone whoch one it encodes. But that dpesnt change the fact that there is at least one algorithm implicitly encoded in the tree.
@fburton89 ай бұрын
Yes, I _did_ enjoy this episode very much, thank you!
@DeveloperVoices9 ай бұрын
Our pleasure!
@steveknight8789 ай бұрын
Many years ago I worked for a Canadian company called Geac. It had its own languages (and operating system) with several interesting features. The lowest-level language was ZOPL, which was derived from BCPL. It had no data types at all. When you declared variables, there were two areas of memory available - you could use DCL which started at the top of memory (location 0) and BDCL which started at another specific location (can't remember why, now). You would declare something like: DCL Fred(20) This would give you a named area of memory, 20 bytes long, and if this was your first declaration then it would start at location 0. If you followed this with DCL Alice(10) then Alice would start at location 20, and occupy 10 bytes. And so on. You could then use offsets - so ^$Fred+10 = 4 (^ means contents of, and $ means address) would make the byte at location at address 10 become 4. And if you said ^$Fred+25 = 2, then the byte at memory location 25 would become 2 - which is actually the same location as Alice + 5 It had other features. All parameters in subroutines/functions were effectively passed as addresses, not as variables. So if you had a routine with a single variable DoSomething(Var), and called it with DoSomething(Fred), then actually what you were passing was the address of Fred (which is 0 in memory). Inside the procedure's definition, you would use the ^$ construct to use or make changes to the variable passed in. This, of course, has many problems. One is that all variables are global. And another is that it was very easy to pass a variable to a procedure and then tromp all over any other variable you wanted to. You needed a lot of discipline. But it also had many advantages. It was nice to hear a shout-out fr Wirth. The second (or third or fourth, can't remember) language I used was Modula. That was (a the time - 1980) a lovely language to use.
@filipanicic7719 ай бұрын
Thank you for the amazing talk. I really like the aproach Odin is going for and I started following a small tutorial series on making a game with it. The teaser for a video on Verse is exciting to hear. Can't wait for it.
@DeveloperVoices9 ай бұрын
You didn't have to wait long - it's up now. :-D
@RyanWhitlie9 ай бұрын
Another excellent conversation, thanks! Odin quickly became one of the most joyous languages to write for me. Odin and Elixir *chefs kiss*. Perhaps a conversation with José Valim could be on the cards🤞
@poggybitz5139 ай бұрын
ginger bill is doing amazing work with odin and its a delightful langauage for the games and graphics domain imo. But, I would like to point out that C is not dead and is being actively developed. For example, we use defer in c 21 that are implemented with the macros. It would be awesome if chris broguth someone Dawid and Jens who are pioneering the modern c.
@Pariatech9 ай бұрын
This got me reading the Odin's Doc. Fascinating language with some great features, like how it handle structs of array or the using keyword. A lil bummed about the lack of automagic C interop like Zig has. I will have to try it out that's for sure.
@GingerGames9 ай бұрын
Thank you for watching the video. With regards to the "automagic C interop", this sounds cool until you realize this is actually pretty much NEVER what you want. In all of the cases you look at what Zig does, the libraries just wrap the automagically imported C calls, which is effectively the same amount of work as just writing the bindings manually, defeating the entire purpose of the automagical stuff. There is also the other issue that people use the C-preprocess as if it was the same language as C. They define constants and many wrapper functions and more, with the preprocessor, which will be missed by the "automagical" stuff. We are currently working on making an official automatic bindings generator, and because of Odin's amazing `foreign` system stuff, things can have little to no wrappers whatsoever, and still be extremely useful. Odin has tried its best to make binding with foreign code very pleasurable, whilst not requiring wrappers. See things like the attributes `link_prefix` or even `b32` types (for booleans which are not 1-byte) or `u32le` types (endian specific types) or multi-pointers `[^]T`. With a bindings generator, you'll have a lot more control about how you can interface with foreign (e.g. C) code.
@Pariatech9 ай бұрын
@@GingerGames thank you for the wonderful reply!
@filker09 ай бұрын
I am interested in exploring Odin and am impressed with how far it's come. I have created a few domain-specific programming languages, but I've never attempted to design and implement a compiler for a general purpose programming language. Unfortunately, from looking at the website, I won't be able to experiment with Odin in the sort of programming I do. It's not available for any of the architectures that I commonly program on. I do a lot of low-level embedded engineering and programming, so I need languages that work with compiler suites that are able to produce code for common embedded microcontrollers and other microprocessors used in this domain such as PowerPC (32 and 64 bit), Cortex-M (32 and 64 bit), Cortex-R (32 bit), MicroBlaze (32 bit). I also do a lot of bare-metal (unhosted) programming, either single-threaded or using a small multithreading executive (not a full RTOS). A few nits: C is not from the 1950's, it's really late 1960s through the 1970s. It really didn't hit its stride until the K&R compiler for Unix 7th edition. Fortran and Cobol have their origins in the 1950s. C passes arrays by reference because a raw array identifier is treated as a pointer to the first element of the array.
@GingerGames8 ай бұрын
We'd be interested in seeing if we can support a freestanding PowerPC platforms for Odin most definitely! Maybe some forms of Cortex-M (but it's too varied to be actually useful as a single generic target). As for MicroBlaze, you're probably the first person I've met in a long time to even use it still. Supporting these new platforms does take a bit work (LLVM isn't just magic, unfortunately) to get working, but we are not against supporting those platforms. We have just been focusing on the main application-oriented platforms (AMD64, ARM64, and now wasm), but that doesn't mean we cannot support other platforms.
@dark_nation_79 ай бұрын
The SOA stuff seems really neat, was a good interview.
@mlliarm9 ай бұрын
Already interested in the language at 20:48. After reviewing the overview of the language, having some golang experience already, I really feel being at home. The syntax is very similar, but the language is highly performant? I'll surely dive deeper ! Thanks Bill ! And thank **you** Kris for this amazing discussion !!!
@ForeverZer09 ай бұрын
It will generally beat out Go in performance, but not quite at the level of C, C++, Zig, etc in regards to its potential "raw power". It is probably most relatable to Rust in regards to potential performance. Obviously all of these languages being listed are "fast", so its in the ballpark, and the differences are moot unless you are developing for some AAA game title that is aiming to eek out the absolute most possible out of the hardware.
@tedbendixson9 ай бұрын
CPU up. Wonderful talk Bill!
@Tordvergar9 ай бұрын
Working on a language in an environment where it's in heavy production use seems to me a wonderful thing. Assuming, of course, the language is adequately stable at the start. A feedback loop for the actual logic of the language: marvelous.
@mwcz51909 ай бұрын
Great guest, great interviewer, great topic. Easy sub!
@_supervolcano9 ай бұрын
I really enjoy these videos. Thanks for the interview, Odin is super interesting!
@emilvaleev9 ай бұрын
Thank u for having Bill and for doing this awesome content and being such a great interviewer!
@oglothenerd7 ай бұрын
I am making a compiled programming language myself! It is meant to be a serious replacement for Rust. Rust is amazing, but it has a bunch of huge flaws... the biggest being it relies on the internet to compile most things...
@ITSecNEOАй бұрын
Good Luck 🤡
@gadajacaglowa7 ай бұрын
Odin for me is like refreshing love for coding in the perfect spot between high and low in modern terms of complexity. An amazingly balanced language.
@dragonalong68609 ай бұрын
Love Odin, using it to develop games
@mrmaniac99059 ай бұрын
You’ve inspired me to write a game in odin
@karl_zylinski9 ай бұрын
Do it! I'm making games in Odin and I've never been both so productive and creative at the same time.
@ITSecNEOАй бұрын
Let me guess, your project died after one week 😂😂😂😂
@gearboxworks9 ай бұрын
Nice interview. One thing though, as a visual learner I wish he had shown code while he was explaining various aspects of the language.
@DeveloperVoices9 ай бұрын
Yeah, that's a thorny one. We also go out as an audio-only podcast on Spotify, Apple, etc., so we have to treat it like radio...
@dieyproductions44039 ай бұрын
Operator overloading is f'ing stupid, good choice.
@ITSecNEOАй бұрын
It's not xD It's far easier to express complex mathematical formulas. It's just missused by some peoples
@Satook9 ай бұрын
Always a pleasure to listen to Bill talk about Odin and computing in general. Great interview! Verse is a new language that Simon Peyton Jones (and others) are working on at Epic. Very interesting to see where it goes. He has a great talk up called “Beyond Functional Programming. A taste of verse” if you’re interested. m.kzbin.info/www/bejne/hXvZaaV8ltVjhNk
@codegeek989 ай бұрын
0:14:47 that "type" always horrified me... can't use it to store hash outputs since 0 is a legal octet; can't use it to store user-input UTF-8 or ASCII strings since U+0000 is technically a character...
@Kuwaaito9 ай бұрын
I've been called out, I saw the syntax and said no thanks. I'm gonna give it a shot and report back. The no methods stance sold me.
@taylankammer9 ай бұрын
Another great language to try out!
@AlexanderYaremchuk2 ай бұрын
Thank you, enjoyed the talk a lot. Does using LLVM mean that essentially it's not Odin's compiler support all the mentioned platforms but just LLVM supports them? What's Odin's compiler's part in it?
@timlong72899 ай бұрын
The biggest thing wrong with C (and C++) IMO is that it is a multi-pass compiler + linker that requires header files to tie everything together. The reasons it's that way are unimportant in today's computing landscape, so simply removing the need for header files IMO would be the single largest improvement to the C family. Odin looks interesting, and appears to abolish the need for herader files which is great. However, I think it would gain much more traction if it stopped there and preserved most of the C syntax, which is very deeply embedded (pardon the pun).
@ForeverZer09 ай бұрын
While it gets compared to C quite a bit, it is far closer to Go than C, especially regarding syntax. I almost think of it as more complex version of Go, but using LLVM under the hood. I really like Odin, it is downright fun to code with, but IMHO it is not even close to being a "C/C++ replacement", I honestly don't even understand why they are so often compared to one another. It has some great strengths that make it stand out, even among other emerging lower-level languages like Zig, Rust, etc. and I feel it would be better off to not try and brand itself as a "C replacement" and lean harder into its strengths and the fields it excels in.
@michaelmay20219 ай бұрын
GG balances self confidence and open mindedness well
@MrBranh09134 ай бұрын
Just picked up Zig. I’ve been coding in Go for about 8 years professionally. Odin has a ton of similarities to Go honestly. There is a lot I like about Zig though. My only concern is funding for these sort of languages. I feel languages never take off without backing from a major player like Google or Microsoft
@tomthumb67129 ай бұрын
Any chance of getting jon blow on jai?
@casvanmarcelАй бұрын
Odin is amazing! I feel extremely productive in it. Joy of programming? Definetely!!
@jorgegimenezperez93989 ай бұрын
Maaan when the interviewee and the interviewer are damn goo🥹
@duke6057 ай бұрын
The fact that defer is SCOPE exit and not function exit... Amazing. Go needs a scope defer. So many times I find myself in a look wishing the defer would run at the end of the loop/scope, not the end of the function
@yldrmcs9 ай бұрын
looks like we'll have a language for every subset of features to beat C and C++
@inthegaps4 ай бұрын
I came to this video not expecting such a beautiful host!
@kamertonaudiophileplayer847Ай бұрын
Did you look in PL/1? I like how it manages types.
@doBobro9 ай бұрын
You easily can say Odin is a great language because Bill wields a luxury beard.
@jamesrivettcarnac2 ай бұрын
31:52 this is also why go is my scripting language. I'm going to learn Odin now.
@pmcgee0039 ай бұрын
Simon Peyton-Jones for Verse ...
@hacking4arabs9 ай бұрын
So what am I supposed to choose, Zig or Odin?
@GingerGames9 ай бұрын
As I say in the interview, try both of the languages out for at least a week each, and see which you prefer!
@hacking4arabs9 ай бұрын
@@GingerGames Thank you, Bill, you're such a great inspiration 🫡
@rbettsx5 ай бұрын
I'm getting a healthy whiff of (Yorkshire?) pragmatism over purity, an engineer knowing perfectly well the theory, before carefully discarding the right bits to get the job done. Unlikely to be taught in the halls of academe... But hey, they didn't build the railways.
@claudiusraphael94239 ай бұрын
Wonderful chat.
@pmcgee0039 ай бұрын
A case study for "taking things literally" 🙂
@_iao_9 ай бұрын
excellent talk 👍 just finished it
@albinekb5 ай бұрын
You are a great host! Thank you!
@BytebroUK8 ай бұрын
Sorry to butt in here but as an old guy, as soon as you said "Programming Done Right", I'm shouting for Perl. Never yet played with yer Odin, but have done about two dozen others over the years. For me, for non machine-language use-cases, it would easily be Perl, all day long :)
@itsjustboarsley9 ай бұрын
GB is such a king. 👑
@_TheDudeAbides_9 ай бұрын
The way he describes how the types will be chosen on use sounds like type inference. If it is, I suspect some people will dislike it because they like specifying type. Maybe it is not the way I think it sounds.
@jimmarshall37245 ай бұрын
From what I've seen odin only has for loops which function as both for and while loops depending on how you write them - cool - but can it do do- while loops?
@Barnardrab9 ай бұрын
Could I use Odin with an Arduino kit? Does it depend on a mainstream operating system like Windows?
@channel111219 ай бұрын
Are there any plans to open up the in-house IMGUI?
@GingerGames9 ай бұрын
Nope. That's private. But Odin does have `vendor:microui` which you can use and modify to your heart's content.
@channel111219 ай бұрын
@@GingerGames Hey thanks for the reply and I completely understand [keeping it private]!
@MireneyeАй бұрын
Looking forward to the language programmer battle royale! ^- ^
@DeveloperVoicesАй бұрын
Whoever wins, we win. 😁
@MireneyeАй бұрын
@@DeveloperVoices True words! Also phenomenal work on this channel, I hope it keeps growing
@henrikholst74909 ай бұрын
I'd Love to see V lang, Crystal, and Nim on the show.
@ITSecNEOАй бұрын
V lang is vaporware
@henrikholst7490Ай бұрын
@@ITSecNEO Why do you think that? Do you think the founder and core team lacks the required momentum or what is the issue you're seeing?
@ITSecNEOАй бұрын
@@henrikholst7490 It's their false claims in the past. There are some articles about that
@workflowinmind9 ай бұрын
Great episode!
@spacewad87459 ай бұрын
beautiful hair Kris 😍
@djazz09 ай бұрын
Thanks for the podcast! Seems to have many similarities to Nim but with focus on modern cpus and running under an OS. No embedded support it seems though, maybe I look in wrong places? Have a look at Nim too!
@GingerGames9 ай бұрын
Odin does have freestanding targets, but it we are not focusing on embedded systems for loads of reasons. Personally I believe embedded systems (whatever that even means, since it is such a broad category), needs a language tailored for its domain. More domain specific languages is what we need, not "generalized" languages which is not great for any specific domain.
@mvargasmoran9 ай бұрын
THIS MAN!
@jazzochannel9 ай бұрын
I'm more of a Loki kind of guy. When is the release date for that language?
@codegeek989 ай бұрын
0:27:25 i.e. you're better off doing a library call or otherwise sending your array off to a whatever quantum operation provider at this time, if you actually had a need for it?
@scottcastle91199 ай бұрын
My programmer and I are creating a 2D game engine in odin.
@laughingvampire755516 күн бұрын
instincts are not built over time, they come from evolution, your fast mind is trained over time and that is not an instinct.
@lunakid123 ай бұрын
BTW, choosing custom operators is _not_ optimizing for typing. It's an expression of a much deeper, more universal desire -- it's like finding a rhyme, instead of just using normal everyday prose. Now, the world is full of bad poems, no question, but blaming the rhymes themselves for that...
@PrivateUsername9 ай бұрын
C, but older and wiser? That would be Fortran :)
@АндрейДенькевич9 ай бұрын
That would be Pascal :(
@coolguy69verycool3 ай бұрын
Is Bill talking about "Algorithms + Data Structures = Programs" by Niklaus Wirth at 55:55?
@DeveloperVoices3 ай бұрын
Yes, I believe he was. There's a link in the shownotes. :-)
@toby9999Ай бұрын
@DeveloperVoices I have that book. The Pascal version. Bought a hard cover copy 30 years ago. The book just appealed to me for some reason. It was also the textbook for an introduction to a computer programming course at my university.
@harishreddy33109 ай бұрын
thoughts on odin vs zig? I think only 1 language can survive, unlike rust vs zig where both are offering some different features.
@zn4niye9 ай бұрын
kzbin.info/www/bejne/qpjbpZ5ohMp_ra8
@Kuraitou9 ай бұрын
It's not clear either of these languages will survive. People have been trying (unsuccessfully) to kill C and C++ for decades, and there has been a large number of new systems programming languages lately. Hare, Jai, Vale, Hylo, Austral to name a few. How many do we need and why would you pick one over the others?
@JaconSamsta9 ай бұрын
@@Kuraitou So? Doesn't mean we should stop trying. C is a relic and while C++ has its nice parts, it's a pretty poor language from an objective perspective. It barley has any cohesive design and copied over all of C's pain points verbatim. I think Jonathan Blow put it quite well (and I don't usually find myself agreeing much with the guy). Roughly paraphrased "We aren't going to be programming in C or C++ for ever. The question isn't *if* another language is going to replace it, but *when*." And even leaving that besides the point, why do can't we have multiple low level systems programming languages? Rust, Zig, Odin, Jai, V, Hare... They can comfortably coexist. If Odin proves itself suitable for graphics, simulations and game programming, then why not adopt it for those tasks? Take a look at other domains. Backend development is a mix of C#, Java, Go, unfortunately a lot of JavaScript. High frequency trading sees a lot of languages in play, so does data science and virtually any other software domain. You'd be laughed out of the room, if you suggested any of those domains needs to settle for "one true language" or that we should stop trying to innovate within them, or that you don't need anything besides good old Java. Truth is, Systems programming has simply been under-served for a long time. I'd wager that's mostly down to how hard it was to write a good compiler and there not being major incentives for the M$, Googles and Oracles of the world to do so (hard to sell a platform for a language that doesn't need a platform), but LLVM, for all its shortcomings, has really changed the game here. Too some end, I think we are seeing a cambrian explosion in terms of low-level systems programming languages. Surely not all will find mass adoption and maybe not all of them will survive long term, but many will find their niches. Maybe that's why C/C++ folks get so defensive over the whole issue. They aren't used to having competition.
@natescode9 ай бұрын
Odin is domain focused language while Zig is more general purposes. I don't see the competition. Zig tries to interop and actually replace C. Odin is just another specialized systems language.
@pierreollivier19 ай бұрын
@@Kuraitou have they tho ? I hear this all the time that people have been trying to replace C for decades but failed like it was impossible ? All those languages who ""tried"" to replace C where failing from the start. For example Jave could never be a C replacement yet in the early days it was advertised as such, On the other hand nowadays we have in my opinion real contenders, Zig for examples actually feels like a C replacement, as a C developer, Zig makes me feel at home, it's imperative, there is no inheritance, it's lower level than C. Everything feels better in Zig than in C, the type system feels better, the std is light years more useful, the semantic feels more cohesive, the error handling is better, testing code as never been easier, building it too, allocators as first class citizen is awesome, I could go on but all those things considered makes me feel like Zig could be an actual replacement to C, same with Rust, It feels a lot like Cpp, I hate Cpp, but Rust makes it more fun, it's still way too convoluted for my taste but It's a fantastic C++ replacement. So I think the argument of many have tried and they all failed isn't relevant anymore, because now that programming as a whole as evolved people have grown tired of C, myself included, it's a great language but the developer experience is really terrible and outdated, I see that everyday around me the programmers I work with all hate C in one way or another, and none of them use C in their spare time to build toy project, they all use Rust, Zig, Odin, Nim, OCaml and whatnot. I think the question is not about whether any of these languages will replace C, it's more of a when ? because it's pretty obvious that nobody in the industry wants a decade more of C, let alone another 50 years of it.
@pookiepats8 ай бұрын
Great job mr host
@Tordvergar9 ай бұрын
Bill: if you build in math functions that operate on 128-bit floating point types, you could take over the scientific programming domain, like FORTRAN did 50+ years ago.
@GingerGames8 ай бұрын
Firstly, name a single platform that supports 128-bit floating point numbers in hardware?---that isn't an FPGA. Secondly, if you need more precision than 64-bits, you probably want "big floats" instead, because 128-bits is probably not enough.
@DanielJoyce9 ай бұрын
Gonna be tough to fight zig, and memory safety is becoming more and more critical. Valgrind doesnt cut it anymore.
@GingerGames9 ай бұрын
Odin does have bounds checking any many other memory safety features, just like Zig.
@DanielJoyce9 ай бұрын
@@GingerGames insufficient in the modern world. Zig programs still can segfault. There are open PRs/bugs about memory corruption issues for tools written in zig ( I forget which one I was looking at ). The issue tracker mentioned the difficulty of tracking down the cause. I've yet to have a rust one crash. Affine/Linear types remove a whole class of memory errors.
@DanielJoyce9 ай бұрын
@@GingerGames pascal has bounds checking for array access back in the 80s. It's old hat and barely suffices.
@GingerGames9 ай бұрын
@@DanielJoyce so what are you referring to with regards to Zig in your original comment? Odin and Zig both use LLVM as their backend.
@Muskar29 ай бұрын
@@DanielJoyce Why is segfaults your primary concern? If you're rewriting a known or extremely critical program, I think it's understandable. But in my experience, writing software is a lot like exploration, and iteration speed matters a great deal. That's not Rust's strength at all. Compiler errors, just as well as runtime errors (e.g. crashes, boundary checks etc.) can be very useful with iteration speed. Crashes in production-ready code should be extremely rare even in "unsafe" C-like languages, when you zero-initialize and make default paths for zero values. And if you need to squeeze out performance, a borrow-checker (and most definitely a GC) will be in your way.
@megetmorsomt8 ай бұрын
I like the pragmatic approach - thoroughly absent from Western thought these days...
@jamesrivettcarnac2 ай бұрын
38:53 i honestly never really understood how the C preprocessor survived the 90s
@toby9999Ай бұрын
I still use it. I've been coding in C and C++ for 30 years Never had a problem with it. The real problem is with how it's used.
@johnsalverda33589 ай бұрын
OK, write an OS with it. Unix is written in C. Can this new language do low level stuff? If not, it is not a replacement for C.
@DeveloperVoices9 ай бұрын
You might be interested in Hare. Drew DeVault's writing that as a C replacement, and he's writing an OS too, to answer exactly your point. kzbin.info/www/bejne/amPcY4RvntRmjtU
@GingerGames8 ай бұрын
People have already written Kernels in Odin. So yes you can write an OS with Odin.
@MagpieMcGraw9 ай бұрын
I've been dabbling in Odin for a while, never heard of this "Bill Hall"
@DeveloperVoices9 ай бұрын
Well, it's easy to verify who created Odin, if you want to double-check. 🙂
@GingerGames9 ай бұрын
That's my actual (legal) name. I am "Ginger Bill". My actual name is just so generic, which would make it nigh impossible to search for on the internet.
@MagpieMcGraw9 ай бұрын
@@GingerGames Bill Hall is a great programming language designer name. It's right up there with Rob Pike.