Way back in July of 2023, this channel inspired me to start a gaming project bigger than I've ever attempted. I grabbed 7 other buddies, programmers, artists, and a musician with the intention of landing a job in game development. I followed the advice of this channel as best I could. The game is not even released yet(it will be finished within the month), but it was enough to land my first job at a gaming studio as a software engineer/game designer. I didn't even finish my computer science degree! So thank you, Tim, and I hope this can inspire others to pursue a career in game development as well! It's truly as simple as making a game and continuing to make games. This will be me my 4th released project.
@vk34777 ай бұрын
“My code was a flawless gem but then things change” Thank you Tim. Such a privilege to learn from your experience.
@alexnewman96277 ай бұрын
absolutely
@masmullin7 ай бұрын
"if you are having a problem. Try rewriting it differently" (paraphrased) +1 on this. This is one of the first techniques I ever learned. Not only can it solve an annoying bug, but simply rewriting bug-free code can make it significantly cleaner and easier to understand.
@ZlothZloth7 ай бұрын
And when you rewrite it, don't erase the old one until you finish. Rewiting makes you think of every little part, so sometimes you'll realize what you did wrong last time and can fix it with one tiny change. If you've already torn out the old code in frustration, you're going to be even more frustrated.
@KookoCraft6 ай бұрын
@@ZlothZloth been there lol
@Teethmafia7 ай бұрын
I’m a game design student with 2 programming finals I should be doing right now. This was the perfect procrastination video for me.
@Medik_00017 ай бұрын
Watch his previous video 😂
@zhulikkulik7 ай бұрын
@@Medik_0001oh, the irony of this comment branch 😂😂😂
@Teethmafia7 ай бұрын
@@Medik_0001unwise to assume that I missed that one somehow.
@MrOmega-cz9yo7 ай бұрын
LOL I literally had the semi-colon problem happen to me. Many moons ago, I was sitting there looking at my code for 20+ minuets, and our new hire walks by, looks at the code for about 10 seconds, pointed and said "You need a semi-colon there". D'Oh! 🤣🤣
@trielt17 ай бұрын
13:00 ish One of my programming teachers would tell us the "the subconscious works faster than the conscious." If you just keep banging your head against the problem, you won't get it done any time soon, but if you just walk away and let you brain breathe for a bit, you will figure it out in no time.
@redsixx6696 ай бұрын
Ive only just started learning coding and already the amount of times just stepping away from a problem for a couple minutes just to have the answer pop into my head is baffling
@wtetzner3 ай бұрын
Yep, though my experience is that you have to bang you head against the problem hard enough that your subconscious thinks it's important enough to work on when you walk away from the problem.
@Andonios887 ай бұрын
I’m an accountant, I’m forcing myself to be here after you said we didn’t like to watch your game development content in your Fallout TV video. 😂😂
@akranov7 ай бұрын
Fellow guilty accountant watching this for similar reasons lol
@bratttn7 ай бұрын
thank you, Tim. I don't know how relevant it's in gaming, however in enterprise there sometimes a bug that's long fixed for the next big release and the solution required a overhaul of half the infrastructure modules in different ways. However there is always a customer requires the fix ASAP for the current build and your schedule goes haywire and in the end what the customer gets is not a proper solution but a hideous amalgamation of hotfixes that due to some voodoo cybermancy hold together somehow. Your programmer's soul bleeds to bring this cadaver to life in production but it's the best you could come up with within the given timeframe. The hardest part is such makeshift pieces of bad code could persist for years until someone dares to do a proper cleanup and the saddest part is even after you refactor everything to meet some measure of standard no one will see it or appreciate it.
@bruceschlickbernd84757 ай бұрын
Second pair of eyes: at one point, I told Brian that no matter how good I was at bug-hunting and testing games, breaking the breakable, rewriting the unreadable, redesigning the badly designed, I was one person, and someone else would inherently see what I didn’t. With us moving to being our own publisher, at some point I was going to be the bottleneck and we needed someone else to help out on that end. That’s how Tom Decker got hired (you’re welcome, Tom). And it worked - we found stuff because we simply had different approaches to the games, and the simple fact that there were only so many hours in the day. Just staring over Jay’s shoulder I would spot bugs in his code (and I could not write a line of code to save my life - I just got so used to seeing him fix stuff, I could spot it when it was wrong). Great advice on just going away, doing something (hopefully productive) else, and coming back to it with fresh eyes. Poor Q (J and Q, sounds like Programmers in Black) had one bug that took him a long, long time to find - it was in the Atari system itself. Good luck planning for that. So, yes, non-programmers can learn from this. But…spaghetti code. Or Miles code. Or Pavlish code. Or - all the other programmers in unison - Becky [well, it’s pre-Burger 2.0 name] Code!!! Programmers seem to delight in their amazement at the wacky things that other programmers do. And all of you did it. Every single one. ;-)
@gilgamecha7 ай бұрын
I have encountered this "missing method" issue quite a few times. Usually months of debugging before the library vendor confessed that yeah, it was just a stub at the back end.
@mikehenkelman21117 ай бұрын
I love Tim...so much wisdom...and such a good dude/gentle soul. This channel could literally live off the notes he's kept over the years. Keep them coming buddy!
@Orangubara7 ай бұрын
When you hear that „Hi everyone it’s Tim” and you know that you will be blessed with knowledge 10/10
@specialagentgeralt97637 ай бұрын
Hey Tim, I just wanna say thank you! I only found your channel recently but as a 27 year old without a real "path" in life I've always wanted to make games and feel like I missed my calling. These videos make me wanna rethink what I'm doing with my life (in a good way).
@gregorio877 ай бұрын
You certainly haven't missed your calling. If it's your age that's holding you back, I'm sorry, but that's laughable. I felt the same way when I was 27, but trust me, you have plenty of time to do whatever it is you want to do.
@specialagentgeralt97637 ай бұрын
@@gregorio87 I appreciate it stranger... I'm currently a mailman so unless there's a platinum chip coming my way I hope I can somehow course correct someday. Just seems like so many people in the industry started so young. I don't really have any skills. Just a passion for games and how they're made. Always dreamed of working on them.
@ProrokLebioda7 ай бұрын
I feel that part about UI...
@aleccrisman7 ай бұрын
Don't underestimate how interesting these videos are for non-programmers. I'm a political theorist who games as my main hobby and I basically find every part of the game design process fascinating. Programming seems like the part of the development process where the rubber really hits the road and this seems to give programmers a unique perspective on where and how things can go wrong in gamedev.
@toobyoolaar7 ай бұрын
w.r.t. "pair debugging", here's another technique that can work surprisingly well: *pretend* (in your mind) that you are explaining the situation to another person -- it may work even better if the pretend person is not a programmer, like your wife or SO, so you have to explain it in more detail; go through the motions in this pretend conversation (as if you were talking to a real person) and go through the whole issue from top to bottom... in many cases, the issue will become clear to you before you even finish. This has worked well for me many times! You don't even need to be at the computer; you could be on a walk or something.
@Nariek3147 ай бұрын
Often referred to as "rubber duck debugging" :)
@toobyoolaar7 ай бұрын
@@Nariek314 I've never heard that term but I like it!
@Fokkusu7 ай бұрын
This is such a good video, I used to be a programmer but now I am a technical artist so is still relevant to me, and your suggestions to deal with these problems and frustrations are what I do already, but this video format on it is super useful because now I can point at it and educate others in why sometimes I can take weeks on something that was supposed to be simple without loosing the little remaining sanity I have left.
@vikinggameprogrammer72337 ай бұрын
My right eye started twitching when you mentioned Watcom around 04:08. We have a private Slack channel for our team where we tackle problems together after spending our due time on it as an individual developer and also for rubberducking and it's immensely helpful. Also for sh*t talking about code stuff cos it helps to vent too and humour is helpful during the development process. I'm a little leery about compile-time optimisation but it's safe enough these days to where I'm not ultra curious/paranoid about how it will optimise. Thanks for the vid- subbed too! :D
@chigbungus30267 ай бұрын
I love your passion and zest for your crafts. The world can be such a bleak and depressing place but creators like yourself offer stories and worlds not like our own that give some much needed fun and escapism. I don't know if you've touched upon it already but id like to see a video on how you keep the fire for creativity going inspite of life and all its tribulations trying to extinguish it.
I recall John Romero and John Carmack both citing the problems of using outside and old code as the main reason they always tried to make all-new code for their projects when feasible. The old code invariably had unnecessary limits bound to the time the old code was written which had been mostly cancelled out by improvements in hardware and so on. The outside code invariably had limits or faults that they found too tedious to fix or work-around. For sure, this was much easier back in the 1990s, but to a degree, it is still applicable today. Advice I have seen thrown around to new developers is to at least TRY to code an engine for your game before you rent one from someone else. Best case scenario, your engine will do exactly what your want it to do. At worst, you spent time learning the limits of your programming skills. Either way, you learn from experience, good and bad.
@philbertius7 ай бұрын
This is exactly the rationalization I needed to continue working on my engine of 8 years 😂
@tedbendixson7 ай бұрын
I've definitely landed on simply allocating a big block of memory up front and then using memory arenas inside of that block. Memory arenas and static allocation are definitely underrated.
@draloalo7 ай бұрын
Sometimes I consider to start smoking again. Whenever I got frustrated I would go outside for a smoke break. When I got back, I had often solved the issue while not looking at it.
@samotdengode7 ай бұрын
It's not worth it to start smoking again but you still can go outside, do a little repetetive task and find the same results!
@jimmianimates9187 ай бұрын
could go feed some birds or something. i find walking my dog clears my head and lets my mind wander and its when i do my best problem solving
@hardgay75377 ай бұрын
A lot of nicotine addiction is both pavlovian and dopaminergic. Pavlovian in the sense that you associate things like stepping outside for 5-10 minutes with smoking. Dopaminergic in the sense that it often also follows things that feel good chemically, like coffee, a meal, or sex. If you can enjoy all of those things without cigarettes you're already making progress quitting.
@za73047 ай бұрын
Don’t go back you don’t need smoking to get things done
@freddytackos7 ай бұрын
always interesting to me that people need the excuse of smoking to go outside, as if you can't just go outside for fresh air and sunlight
@lunch96box7 ай бұрын
Much love from Florida brother 🙏 Your games were my childhood man, don't think anyone can hold a candle to you and your guy's work ✌️
@StavrosNikolaou7 ай бұрын
Thank you for this very sound advice! All of the suggestions i have used and all have been successful in one context or another (though number 3 hurts when you have to do it). Have a great day Tim!
@TheAlison14567 ай бұрын
Incredible video I loved how you addressed different roles in gamedev throughout the same subject. Also, pair debugging is awesome.
@WilliamAhlert7 ай бұрын
Currently in the thick of it working on some UE Audio Programming for a university assignment and my goodness do I resonate with a lot of these. Thanks for sharing
@RolyPolyGames7 ай бұрын
I'm not sure if I am blessed that I haven't had a lot of these issues yet or cursed. I'm no expert programmer I wouldn't even put myself on a 5 on a scale out of 10. Most of what I do is self taught with some basic understandings from classes. My biggest hookups so far have been stupid typos, and self doubt where I have an idea on how to do something, but I don't dive in and do it quickly enough. I'm getting better at that at least, typos continue to be a random curse. Probably got this video because I was looking up information on debugging better, but glad I found the channel. 13:00 I can confirm getting away from it helps. I was stuck trying to fix an error with my UI not replicating changes on clients for multiplayer for several days.. I went through it line by line confused as all the broadcasts looked great, I was debugging and getting the calls going through up to the exact point changes SHOULD occur, but it wouldn't fire. I stepped away and not more than 4 hours later it popped in my head, "hey you know the rest of the UI is firing fine. Why don't you redo it step by step and see what went wrong." My dumb self had called reliable server instead of reliable client on the initial function. I had a laugh and its back in business now. Just wish it hadn't taken several days going through everything...
@ZacharyBuechlein7 ай бұрын
My son just recently got into coding. Will be sure to pass the video on to him as well :)
@ciscornBIG7 ай бұрын
I could listen to you talk about programming forever, Tim. You're making me want to try again...
@KeiNovak7 ай бұрын
Funny that you mentioned UI/UX issues. I'm going through one right now and it's taking way more stuff to get it to function then I expected. I used to do UI/UX but on other things, and this is the first time with the current platform I'm using. And yeah, UI stuff is still a pain in the butt after all these years.
@ki36576 ай бұрын
I am so glad you mentioned the UI thing. I'm prototyping with minimal UI right now (99% of it is a single text block) purely due to how much time I lost on my last project to UI hell. It's the single most frustrating experience I've had in 10+ years of coding and I have this niggling suspicion that, if this prototype makes it to project & one day ships, I'll spend more time trying to avoid designing an UI than on anything else.
@colinfrederick26037 ай бұрын
This mostly went over my head. I love that. Now I know what I need to research further. Thanks Tim!
@FerreusDeus7 ай бұрын
lmao Oh god, your very first one and I'm like, "GOOOOOD WHYYY?!" It's so real! War flashbacks, man. Even in programming war never changes.
@revanbrittain34807 ай бұрын
I just wanted to say how much I love watching your videos since I found your channel! I've been a Fallout fan since I was in middle school, and even though my first game was New Vegas, I fell in love and I played the original Fallout and fell in love again. I love the original game and Fallout and finding your channel where we get to learn about not only Fallout itself but just your life as well it brings me joy especially now as times are hard for me and my husband at the moment. Watching your videos has given me an outlet to find some peace in this crazy world, Thank you!
@TernaryHound7 ай бұрын
Love these tips. Never really thought about the UI thing until now but rings true! My own programming tip is to wait as long as feasible before writing code for a hard problem. A bad solution often takes some reflection to catch and writing code can make you hesitate to change course.
@RazielIgor7 ай бұрын
I was literally thinking about asking this today. Thanks for the video ❤
@Owl907 ай бұрын
What a fantastic video. Thank you, Tim!
@tedbendixson7 ай бұрын
lol immediately the first thing he mentions is working with other libraries. This is why I do as much from scratch as possible. It's comforting listening to this. It makes me realize all the problems I'm running into are totally normal. Just embrace the struggle right.
@darkmattergamesofficial7 ай бұрын
Thank you for your helpful insights, Tim!
@aNerdNamedJames7 ай бұрын
What I appreciate about this video is that, even to someone who is neither production nor programming focused, the realities of small teams can often mean that everyone is involved in production to some capacity, so more go-to reference material for easing communication between programmers and non-programmers is always a godsend.
@GlassesAndCoffeeMugs7 ай бұрын
One of my funniest programming memories is when I was a freshman CS student, asked to write a program to simulate a forest of trees burning (text-based console "simulation"). Got so hung up on a problem and went to bed incredibly frustrated. A solution came to me *while I was sleeping*, and I got up, immediately tried it, and it worked. Which to me forever cemented the idea that often the best solutions will not come from being frustrated sitting in front of a screen, but doing literally anything else or even while you're sleeping.
@vast6347 ай бұрын
For the redesign thing: I think projects should have enough time for the prototyping and pre production stage, where key mechanics of the game can be quickly implemented and tested in a rough version. (like the example of having a clickable round button. A prototype specifically just for testing this part). In this preproduction stage rewriting and iterating on code should be expected and normal. Finding a fun game-loop is important. Once the critical mechanics and designs are prototyped and tested - starting with the production phase - code should be cleanly reimplemented and the producer can be more rigid about what changes are allowed.
@inuous7 ай бұрын
UI code is certainly my least favorite to write (and always the buggiest). Writing UI code as we speak.
@RaccoonKCD7 ай бұрын
I don't even have an interest in game development but listening to Tim talk about things he is interested in and has experience in is just super entertaining for some reason
@ZlothZloth7 ай бұрын
A good pillow is a surprisingly effective debugging tool. :)
@jwithersooon7 ай бұрын
This channel along with pirate software inspired me to start learning how to make metroidvania type games. fallout: PNRPG is my favorite game of the series which says alot since i started with f3
@TheClodax7 ай бұрын
I am programmer, but I have never worked on game development. I write code for servers for a large multinational company. I always wondered what coding for games would be like. Your channel has showed it me that it's about the same. It is interesting to find out game programmers run into to same issues that I do.
@Ambanoid7 ай бұрын
My most frustrating thing comes at the end of development of a complex system - the "finishing block". It's aggravated by not having strict deadlines and strict design specifications, since I work on everything gameplay related and always cross into game design and have to think for both designers and players. So making the finishing touches to a complex system, that gotten tad bit too complex through the course of its development, wrapping things up and shipping it into the workspace often puts a sort of a block on me. Procrastination, overthinking, burnout - all the good stuff.
@fredrickvonstien8617 ай бұрын
Being a recent programmer I've already experienced all the examples given, the most frustrating thing to me is being given a task to write a program a specific way and check and double check with your lead to ensure everything is being done correctly and then management or the lead themselves decide they want it to do something else entirely different and it feels like I had to throw away almost everything I made, with weeks instead of months to left complete the task and I had to do nothing but to chug coffee and program, no time for breaks no time for lunch.
@unitedpainter98757 ай бұрын
Completely Unrelated question: Would you remaster or remake Arcanum? What would you add? What would Take away? More events? New User interface 😂? Etc. Thank you so much for your time. I just started watching your videos, not but a week ago, and I’ve just been binge-watching it; great stuff!
@CainOnGames7 ай бұрын
You might like this video: kzbin.info/www/bejne/ppjRY6aHadt0obc
@NoMastersNoMistress7 ай бұрын
This was fascinating... I'm interested though in your experiences with modifying an existing engine, i.e. adding and removing classes to it, but especially your thoughts on adding and modifying scripting engines and modding API's to existing game engines, since that's actually a hot topic in some indie quarters.
@BigOlBear7 ай бұрын
Another great video, I really love this channel so firstly thanks very much for sharing all these videos. I am a programmer as well, in web development so a bit away from game development, but your points all resonate for sure! The UI and design changes especially, what can look like a simple shape or size change can have a massive impact. One other area that maybe isn't as common in game development is also tool or library upgrades. In web development I don't know how many times I've upgraded a library to a new version that says it is not a breaking change only to have... breaking changes. I wonder if this is something common in game development, or is it more set that you know early on the versions of things like engine version, library versions etc.?
@LDiCesare7 ай бұрын
I think people just avoid changing game engine or library versions as much as possible once they have something running. It's always a lengthy process and introduces different bugs. In web, you tend to have to go with the latest versions for security reasons, which rarely matter for games. It may also be different in MMOs or games with very long development lifespans.
@BigOlBear7 ай бұрын
@@LDiCesare Yeah that was my thinking, games are maybe a bit more static in terms of the choice of tools or libraries and how what you choose at the start is what you stick with. I can imagine a game engine upgrade mid development (or even post!) is a big undertaking, it is impressive when you hear of those long running games that do upgrade something massive like the engine yet still continue to run very well.
@YT-Lucas7 ай бұрын
8:37 - producer here: I need that short reaction as a gif that I can use forever on everything.
@razaquu7 ай бұрын
9:45 YES! Goddamn YES! This is the reason i mainly HATE iterative development, im not saying its wrong or you shouldnt do it, but it very often leads to "unforeseen" issues.
@LDiCesare7 ай бұрын
Also when the bosses give you shorter timeline than the actual timelines to put pressure on you and you have to try something low-quality fast and then they tell you you still have more time and think you could have done things clean from the start if you had known.
@JohnTyree7 ай бұрын
I don't want to break your heart, but there's really no alternative to iterating on a design. People are just not capable of designing things that work up front, just like you're not capable of writing code without bugs in it. There are design bugs too and there's no substitute for trying the thing out, seeing that it sucks and changing the design. The problem is when people don't understand how long it takes, but that's also why it's important to just get SOMETHING out as quickly as you can. The sooner you do that, the sooner you can figure out what needs to change.
@razaquu7 ай бұрын
@@JohnTyree My heart remains NotBroken :) I realize i worded my message poorly, what i meant there always should be a scope for iterative design. Its much easier to create tools when designers are vocal about their mindset instead of saying "I need this 1 rigid thing" I hope you kinda understand my rambling :)
@michalkleszcz7 ай бұрын
It might just be me but i love these kinds of issues, they promote problem solving skills which are important and inspire team work and new solutions
@HRZN_YT7 ай бұрын
Hi Tim, I have a question regarding older games, and continued development. Why don't developers go back and make expansions to their older games? The increasing size of game budgets had me thinking of ways to generate revenue with lower overhead, and this seemed like an lower cost way to leverage existing audiences and generate new income. A game like Civ V still has 17k peak players every day, despite being almost 15 years old. Why not make a low cost expansion for it? Something fun like aliens. It seems like developers and publishers let their back catalog languish, before pouring a mountain of cash into a full scale remake. Is there something I'm missing? Thanks!
@CainOnGames7 ай бұрын
Developers cannot do that without their publishers permission. My guess is most publishers want to spend their money on new big IPs, hoping for a big hit rather than a small return on their investment. Ultimately, your question is for publishers to answer, not developers.
@HRZN_YT7 ай бұрын
@@CainOnGames Thank you for the insight, I appreciate it!
@LDiCesare7 ай бұрын
So true. All of this, from the compiler issues to UI code.
@georgeabitbol41807 ай бұрын
Now i take my breakfast watching one of your videos everyday, honestly it's a great way to start the day xD, not sure that this information will be useful for you tho
@keagancollins32437 ай бұрын
Paired debugging is shockingly effective. Frequently the other person doesn’t even have to say anything, but as soon as I try walking through the code with someone else i often figure out the issue before the bug even presents.
@Nightwulf12697 ай бұрын
Thank you Tim! Same stuff everywhere....I'm working in a very different area but can sign the whole video. Just with other topics like APIs not beeing documented, describing not the reality, not following standards or even invent their own "protocols". Especially REST services often don't get HTTP response codes right. Same applies to libraries. As another guy mentioned already in the comments, I'm a big fan of doing stuff myself meanwhile. And you just described, why 😉 Only exception I make is, if something around crypto is involved or other things you really, *really* need to be an expert in, to get it right.
@UlissesSampaio7 ай бұрын
Hey Tim, what are your thoughts on the "consolization" of games? Since late 2000s, seems like every game is now made with gamepad in mind. This imo forced games (including RPGs) to simplify its mechanics due to not being able to use a mouse.
@WhoIsJohnGaltt7 ай бұрын
Of coarse. Less input potentials IE; buttons. Naturally lead to more simplicity. Imagine a game like arma 2 on a controller. How would that change the experience?
@MrHerrGotlieb7 ай бұрын
Hi Tim! This technically-minded video has reminded me of something I wanted to ask you: How come the pathfinding range on movement in Fallout is quite low? Replaying the game recently, I noticed that just scrolling one screen away is enough for the hex cursor to show the red X, as if you can't go across the open field. Now, this never bugged me when I was a kid, playing on my Win 98 with a 4:3 CRT, so maybe this is only noticeable on modern resolutions? I refuse to believe that you couldn't figure out an efficient pathfinding algorithm, so in my head, I explain this as being too low-priority to "fix". I asked a question once before (which prompted your video about Disneyland), so I politely waited before posing another one. Thanks for the great videos and great games!
@gilgamecha7 ай бұрын
Pathfinding is a fundamentally difficult computation problem.
@raylder63397 ай бұрын
Hi Tim, it’s us, everyone. Love hearing the dog asleep in the background 😊
@kylepulman7 ай бұрын
7:18 As a web developer, PREACH brother
@danutz_plusplus7 ай бұрын
Tim, what's your opinion of Fallout Tactics? I never heard you ever mentioning it. I'm not even sure I know the history. Was it contracted out to a separate studio? But that's technically the very first Fallout game I ever played, before I got the chance to get into the wonderful Fallout 1.
@shnargru7 ай бұрын
I own a cup that says, "Please forgive me for what I said today. I was debugging." 😂
@lilykp7 ай бұрын
its weirdly reassuring to know UI programming has always been like that™️
@uncooked_ham7 ай бұрын
I remember when I was younger, one of my most common sources of programming in Basic frustrations was "10 play Arcanum, 20 Love Arcanum and ToEE more than anything, 30 print "THANK YOU TIM!" :)
@olwiz7 ай бұрын
I think there was a saying somewhere along the lines of 'a project will take as long as the time allocated for it'- im paraphrasing, maybe it was 'more' then time allocated... it aludes first to how 'more time' have a positive correlation for parts of development bloating(its not lazyness, extra work applied- polish, features etc) but also stands for you cant account for time realistically. No one can. Surprises will always show up, not only bug or technical but even personal and logistics and no one cant ever predict what, when, and most of all how long it will take to fix each one.
@deadclicks7 ай бұрын
Felt satisfied to hear that implementing UI stuff is awful for everyone else as well
@dwroberts7 ай бұрын
I recently used a rarely-called method in a library and got a linker error. I needed a newer version of the library to use this specific method. The recommended way to get the library was with my OS. The OS on my machine was too old to receive the newer version of the library that had the added call. So I was faced with either update my OS to get the newer version, or starting to build this (complex) library from scratch on my machine. I eventually surrendered to an OS update - that of course then broke everything else that was already working
@Medik_00017 ай бұрын
What OS?
@dogecoin16927 ай бұрын
Tim, in your career, did you ever second guess it? Did you ever think, “maybe I should be doing x rather than this?”
@BrentMalice7 ай бұрын
UI is the devil. the weirdest intersection of geometry, state machines, and art.
@thebaffman48987 ай бұрын
My personal programming philosophy is "never compromise". Unless I'm rushing to complete some prototype, I always write code to account for every possible scenario I can think of in that situation. If you write code that's too specific, sooner or later something will need to be changed or added and that will lead to spaghetti code that will be a nightmare to debug. Of course being human you can miss things, but if your code is flexible enough you will thank your past self for the few more hours you spent making robust code instead of rushing because "I only need this one thing now, who cares". This strategy saved me a lot of time and headaches more times than I can remember.
@philbertius7 ай бұрын
How do you feel this interacts with KISS, “Keep It Simple Stupid”?
@thebaffman48987 ай бұрын
@@philbertius That's a valid rule and, in a way, what I do helps me keep things simpler in the long run. I very rarely have to rewrite code, and when I have to add things it's usually very easy because when I was writing the code I thought "I might need this functionality in the future" and accounted for it. I don't take shortcuts to speed up things because I know that's gonna bite me in the ass sooner or later. Also this way my code is reusable and easely extendable so as a plus I save time by recycling it in other projects.
@VoiceActingInGames7 ай бұрын
I would really love to watch a tutorial of you creating a small basic demo start to finish
@TheNezharMC7 ай бұрын
As a junior programmer, this video interests me a great deal.
@AntonioDoesMetal7 ай бұрын
As a senior engineer, this video interests me greatly. There's almost no end to wisdom you can get from people when they're telling you stories of code they wrote in the 80's and 90's. It might not click immediately, but eventually you'll have an "ooooooh" moment and realize how potent a piece of knowledge is
@iswordlogici77607 ай бұрын
I am currently learning the basics of Python and this video interests me. All of Tims do tbh, thats the reason im learning programming
@lordofthe6string5 ай бұрын
My biggest frustration is tools that say they make things easier often make it harder. I recently tried Raylib as it comes as a vendor library in Odin which I was checking out. It was going great until there were mouse issues that are just part of Raylib. I thought "eh, I'll just write my own mouse code" but I found out they have function name collisions with User32 so it would be a bigger job to sort that out. I found people asking them for years to fix it but they refuse because of backwards compat. I switched to SDL which doens't have mouse problems, but it's a bit more complex. Also I think Odin is pretty good
@robert-de-calvary7 ай бұрын
On your point that sometimes it is extremely hard to make a minor UI change like making buttons round I found that there is often even further level of frustration. When your projects manager asks you something like "It's ONLY making the button you already have round. Why is it taking you two days to complete this minor change??"
@occupationalhazard7 ай бұрын
It is mind blowing how many features are entirely unimplemented in a large number of games. I'm amazed what some developers get away with. I'm never releasing any of my games in that state.
@nathanielguggenheim55227 ай бұрын
Can totally relate to the UI-problem. Everybody thinks, bc you have UI in every game, it is sth simple. But it never is. This was true 20y ago and it is true today, even in Unity or UE. It's just the most underrated problem in all of Game Programming imo (25+y of professional XP).
@ZwiekszoneRyzyko7 ай бұрын
I'm very happy that your channel has really grown in a relatively short time! I find your content amusing and informative, really entertaining. DId you get your Yt plaque? WIll you have it on the wall behind you?
@nathanlonghair7 ай бұрын
What I’m hearing is “never write a precious perfect gem”, always write spaghetti, and either refactor later after revisions or just suck it up 😂 (especially regarding UI, which has absolutely always been a pain for me too, almost no matter how simple)
@RealPheidian7 ай бұрын
"Hi everyone, it's me Tim" is the moment I press the like button. Just so you know.
@rabbitcreative7 ай бұрын
12:34 LOL. Fast and broken is just broken. :)
@TimvanderLeeuw7 ай бұрын
It's not just _game_ development, it's _development_. I remember these bugs that got you stumped for weeks in my own development projects that I've worked on. Sometimes it's you, sometimes it's the compiler, sometimes it's a library, sometimes it's one of the external systems you depend on. Sometimes you switch suppliers and they should implement the same API but there's subtle differences that mean you suddenly have a bug. I could go on.
@Noxfrolic7 ай бұрын
I'm not sure I agree with the estimation and buffer bit. The way I see it is more in terms of who does the estimation and planning. I've worked in software engineering for two decades, not in game development at all but in "boring" sectors like energy and finance, and we tend to meet our estimates fairly well. A big part of this is that we don't ask programmers to do estimations. I wouldn't even trust myself to make a good estimation on a lot of things. Instead our production people use the data we've collected over the years and find similar issues being solved. Which I guess is easier outside of game development, but is still very useful since it's basically always more correct than any project estimate given by a current project team. Because if you take the data of implementations of solar inverter data and the consumption of these on 10 different plants, then you're like to get an average estiamte that's going to be pretty close to what will happen on the 11th project. Even when the tech is widly different because, well, why wouldn't they build those damn things without any sort of standards? I don't believe in crunch, but then I'm Scandinavian. I'm not sure I know a single programmer who wouldn't just clock out at 3pm regardless of what you told them. I know I would... I'm sure there is some sort of godly amount of money you could pay me to get me to stay and work for a weekend, but it would probably be ridicilously high because I'd rather be with my family, and what are you going to do? You're already spending too much money on HR headhunting because programmers are hard to come by. Which I guess is less of an issue in game development (and probably not in north american working culture at all), but it's still just a concept that's so weird to me. Other than that I think this is a very excellent video.
@Pajkes7 ай бұрын
Thanks to Father of Fallout for programming tips & tricks. Your love for programming and solving problems while using power of programming in hands with design and art to create interesting, new, breathing and living digital worlds, is inspiring. I'm still learning, hoping to be as good as you one day
@nafanail2nd7 ай бұрын
Hi Tim, a software manager here. I haven't done game dev itself, but worked with gaming companies and had some exposure to their processes. Crunch and delays are common, however regular software application development produced varieties of techniques for early detection of development delays. Iterative approach, regular milestones (or some call them "gates"), agile practices. I understand it all probably does not work well in game production, but can do you think you could talk on this topic in detail?
@Rodhern7 ай бұрын
Totally understand the point, so I am not saying the message is wrong - I am just plain old fashioned curious. At 4:15 Tim mentions a 64kB memory block limitation on Windows. I think I always saw that limitation as a choice of processor memory addressing instructions (addressing using classic segment registers and 16 bit addresses 'automatically' limits you to a maximum of 64kB). Is there a particular reason that the instruction set variation and operating system would be paired up as hinted? Again, I understand why Tim phrased it as he did, and I am not picking on that; it is probably the best way to explain it - purely a nostalgic curiosity.
@chillDude_chills7 ай бұрын
because fallout 1 can run in dos, it can run in dosbox. meaning, fallout 1 has wide compatibility in the modern age. thanks Chris for saving fallout 1 in DOS
@dmath14907 ай бұрын
I remember having to use wx widgets without any GUI helper and it was the worst experience i have ever encountered.
@ShmilS7 ай бұрын
Design changes also might affect a basic principle the code is leaning on and then you either rewrite everything or add some spaghetti.
@MrKipling4207 ай бұрын
Hi Tim, it's us, everyone!
@cookiesliyr2Ай бұрын
I Wrote a list before watching the video, The UI and misleading docs were among them. The UI or GUI programming can be confusing cause people who uses tools to draw would think drawing = coding the interface, and that's not on the same plane specially i am the one who program the GUI system for my Monogame\C# engine and not all the control are that smooth to use unfortuntally.
@HairyPixels6 ай бұрын
Handles stopped being used what feels like a long time ago. I wonder why. They seem have some good benefits when compared to raw pointers.
@puffpuffpass32147 ай бұрын
I constantly think of the dude I found on reddit like years and years ago who went to school to learn everything to make SAO possible. He wanted to recreate it 1-1 and I MEAN 1-1. The idea was so batshit insane yet at the same time the guy seemed so adamant about being able to pull it off. Now I wonder if there's going to be a freeware death game floating around someday
@puffpuffpass32147 ай бұрын
-Someone made a lethal headset not long ago. There's a partner ship if I've ever seen one
@alfonsoesteves50902 ай бұрын
Hi guys, Is memory fragmentation an issue for RAM memory. Or it can also be an issue for CPU cache??? If it is an issue only for RAM memory, I might not worry too much... (I mean, if a game consumes just 3GB out of a 8GB ram, it shoudln't be a big deal, right?) On the other hand, if fragmentation is an issue for CPU cache, then I might worry about it. I am working on something that is very CPU expensive but not too much RAM memory consuming
@Raspredval13377 ай бұрын
12:50 judging from my experience with clang and gcc(+mingw) modern compilers are actually quite good. I had some situations when some pretty obvious optimizations were skipped for some reason, but I've never had a situation, when it was 100% a compiler's fault. It almost always comes down to Undefined Behavior. Compilers are so good at what they do because they make assumptions about the code. If the code is doing something fishy or too clever, compilers might get it wrong and optimize the good stuff away. The advice is to learn to write more structured and simple code, that cannot be misinterpreted by the compilers and you'll be fine.
@therosincrans62217 ай бұрын
I’m curious if you have any stories or advice about collaborating with programmers with different styles, or different comfort levels of best practices. Like having to work with someone else’s code that does the job it’s supposed to, but to your eye it’s sloppy, could cause issues as it’s built upon, or just hard to debug.
@thesardiner20347 ай бұрын
I wonder what Tim thinks about microtransactions in single players games. I thought the trend was over but then with Dragons Dogma 2 its come back into the general gaming talking points. I see a lot of apologists for it saying "its all earnable in game so its not a problem". I generally dont agree with slippery slope arguments but there is one to make with microtransactions in single players games because it crosses the metaphorical rubicon of the value of play time. With them in, it tells the player this isnt worth playing because you can pay to skip it. Thoughts anyone?