00:19.46 Matt Godbolt Hey Ben. It's been a while. 00:20.50 Ben Rady Hey, Matt. 00:22.16 Matt Godbolt How you doing? 00:23.14 Ben Rady Good. Yeah, good. 00:25.38 Matt Godbolt So I'd like to abuse this podcast to ask you something that I would like to have asked you if we'd have met up in person. 00:34.40 Ben Rady Mm-hmm. 00:35.20 Matt Godbolt And it strikes me that it might actually be a good podcast episode. So I can kill two stones with one bird or whatever. Stone two birds with one kill. 00:43.00 Ben Rady Mm-hmm. 00:43.12 Matt Godbolt I don't know. One of those things. 00:45.12 Ben Rady I feel like that's like the fundamental basis of this podcast is that we just talk and then, yeah. 00:49.99 Matt Godbolt So... 00:50.04 Matt Godbolt It's an enforced meeting between you and I. Enforced. Wow. It sounds awful. Yeah. 00:56.40 Ben Rady Encouraged. 00:56.76 Matt Godbolt no Like, I don't like this. No, but it's a, there's a point on our calendar where we will sit and talk to each other, even though, yeah, we don't work together anymore, which makes this less of a thing that we just do naturally. 01:10.68 Matt Godbolt But anyway, my question is, Last I spoke to you, we were talking and you had some clever ideas about how you were sort of starting to use carefully AI to do some of the things that, yeah, I guess some of the more humdrum work or I don't know. 01:30.92 Ben Rady Mm-hmm. 01:30.96 Matt Godbolt how do you How would you explain what you're doing? But I know that you have a clever way of using it. 01:35.52 Ben Rady Yeah. Well, I've gone through many, it seems like every few weeks or every month, you know everything with AI and coding agents is changing so incredibly quickly right now. 01:49.36 Ben Rady So it seems like every month or every few weeks, I have a new iteration 01:55.06 Matt Godbolt Oh, so I might be like my mental model of where you are, maybe like several iterations behind, given that we haven't really caught up in a while. 02:00.34 Ben Rady I mean, you know, it's I don't think it's that far behind. I think I think you're maybe one version behind. 02:05.54 Matt Godbolt Okay. 02:07.06 Ben Rady The last, and it's just, you know, it's this whole progression. I think we've talked about it on prior podcasts. I'm not going to recap from the beginning, but and the last iteration I was on was creating, I had created basically like a Docker image that I could run 02:28.18 Matt Godbolt Right. 02:28.18 Ben Rady either locally or on remote machines or in the cloud in various places. And the way that I would use it is I would, it had an embedded Git server, which you know for those that don't know this, a Git server is just SSH, right? There's really not a thing as a Git server. There's not a process that you run. It's like, oh, I killed, like yeah know I pgrep'd for my Git server. It's like, no, that's just SSH. 02:55.64 Ben Rady SSH is your Git server. So it's, 03:00.16 Matt Godbolt And like, what SCP kind of things like there's only a few things it can do is like there's a git remote command that it runs, I think right effectively on your behalf as... 03:08.12 Ben Rady Well, there's a they recommend that you use a special shell for the for the Git user, but you don't have to, actually. 03:15.34 Ben Rady You can just make a bare directory on another machine and use that as Git remote, and that makes, yes, huh the Chicago bear directories. 03:26.38 Matt Godbolt Not that kind of bear. The Chicago Bear Directory. 03:27.40 Ben Rady Yeah. the Chicago Barenaked Lady directories. Not to be confused with the to terrible... I never... 03:35.96 Ben Rady any No, I'm not going on the tangent. There's a bridge involved and a boat. 03:39.32 Matt Godbolt Yeah. yeah 03:39.40 Ben Rady We're not going to talk about that. 03:43.40 Matt Godbolt But so yeah anyway, Git is simpler than you might think. 03:46.14 Ben Rady But get... 03:46.14 Matt Godbolt It's relatively just running a process on a remote machine. 03:48.46 Ben Rady it's real It's real simple. 03:49.18 Matt Godbolt Yeah. 03:49.32 Ben Rady there's no There's no long-running process that needs to be managed with a Git server. right But anyway, there are directories and permissions and sometimes shell and SSH configuration, perhaps, that should be done if you want to you know have the have the thing be particularly secure. 04:10.54 Ben Rady So you I just created this Docker container. and And set up. 04:16.93 Matt Godbolt Right. 04:17.20 Matt Godbolt an SSH server you can get into inside the Docker container. And on the other end of that, it has all the things it needs to be a Git server. 04:24.54 Ben Rady Yeah, yeah. and And honestly, the only hard part about any of this is credential management, which I feel like is true 80% of the time anyway, right? 04:31.12 Ben Rady Like how do you get your public key registered? How do you get the credentials for the processes that you may wanna run? But long story short, and actually there's one smaller other tangent, is that there is actually an open source version of this that Aquatic released under the Aquanauts organization. 04:53.78 Ben Rady And yeah, and it's very like 60% complete at this point, right? like I wouldn't I wouldn't necessarily, I mean, it's I would I would say it's great inspiration for your own implementation, which you can probably create with Claude in about an hour. 05:06.93 Matt Godbolt Oh, I was going to ask you about that because, well, then. 05:08.75 Matt Godbolt Right. 05:08.90 Ben Rady So there's not a real reason to necessarily use it out of the box, but it is there and it does kind of do this thing, which is finally punchline. 05:18.36 Matt Godbolt Yes. 05:19.10 Ben Rady The idea is that you set up Git remotes that point to the running instances of the Docker container and the post receive hook for these Git remotes basically just runs the headless form of Claude, you know, claude -p with a very simple prompt 05:38.00 Ben Rady And that prompt is something like, make this code better. Right? And the idea is that you have enough, you know, CLAUDE.md and skills and other things perhaps checked into whatever repository it is that you're pushing such that you can have like a local working copy and you're like, yeah, this code is like close, but it kind of sucks. 05:58.64 Ben Rady You know, there's some know commented out tests that fail and there's some stubbed out methods and classes. And it's like, have a general skeleton of sort of what I'm trying to do, but it's not really there yet. 06:08.61 Matt Godbolt Right. 06:09.94 Ben Rady And I'm just going to commit that and I'm going to push it to this remote that I've set up to run this or maybe a few of them. 06:17.18 Matt Godbolt right 06:17.24 Ben Rady And then it's going to just make it better. And then when it's done, after a few minutes perhaps, and like each, you know, the instructions that I put in there tell it to do it in very incremental steps. 06:28.92 Ben Rady So it's like, you know, for each to do comment, for example, fix it and commit it with a description in the commit message of what it is that you did. 06:36.18 Matt Godbolt And this is committing into its own local copy of the repository. So it's got no way of getting out from there. 06:43.52 Ben Rady Yes, it's in the Docker container, right? 06:44.91 Matt Godbolt Right. And, and, and 06:45.18 Ben Rady So this is like the post receive hook for the sort of main repo directory in the Docker container creates a working copy and then Claude is operating on that working copy. 06:58.62 Matt Godbolt yeah. 06:58.62 Ben Rady And there can be multiple Claudes working on multiple working copies if you want to configure it that way. 07:03.28 Matt Godbolt Right. This is what like you might use work trees and your local machine, but you're effectively just doing clones, clones all over the place for each Claude. 07:08.83 Ben Rady Yeah. 07:09.06 Matt Godbolt And so one thing is like, usually they need a lot of guidance guidance and or they will say, hey, I'd like to edit this file now. And like, there's nobody on the other end of that. So how do you. 07:17.82 Ben Rady Well, so part of running it in Docker is that I run it with the dangerous permissions, right? And and you know a more evolved form of this might have some like IP tables rules or other things to try to limit its internet access. 07:28.39 Matt Godbolt Got it. 07:28.52 Ben Rady But the general idea here is to create a safe container so that it can run without, like you're trying the whole design of this is to not interact with it. 07:36.33 Matt Godbolt I know. 07:36.46 Ben Rady That's the whole reason I created this. in the first place is because I was sick and tired of babysitting a bunch of Claudes. 07:42.28 Matt Godbolt Got it. 07:42.88 Ben Rady And so I'm like, no, I'm going to try to structure things and change my the way that I work such that the intention is I send you crappy code and then you send me commits. And then I can review those commits and decide whether it was that I liked what you did, but at no point should I ever have to interact with you in between those two points. 08:01.28 Matt Godbolt Got it. And so how, yeah, how that's, so let me sort of read back to you. Yeah, this is a sort of self-contained world. And the only way that it starts up is you inject from the outside world, something new into it by get pushing. 08:17.50 Ben Rady okay 08:17.88 Matt Godbolt And then it turns away and turns away and turns away. And you don't even, you'rere you're off walking the dog, you're off making tea. 08:24.20 Ben Rady Right. 08:25.34 Matt Godbolt , and then when it's finished, how do you know? and how does that process? How's the handoff back you? 08:31.28 Ben Rady So usually when I'm running these things, I'm running them in a tmux so I can see the output of each one just for debugging purposes. 08:38.97 Matt Godbolt Yeah. 08:39.18 Ben Rady I'm not interacting with them, but I'm like looking at what they're doing. If one of them misbehaves or something goes wrong, I can poke it or restart it or look at what it did or whatever. 08:48.56 Matt Godbolt And with claude -p, that's a like one-shot mode, right? You can't talk back to it or anything like that. It just keeps running and running. and 08:55.08 Ben Rady Uh-huh. Yeah, that's right. 08:56.50 Matt Godbolt I see, right. I've I've never really used that. I mean, I've used it like to say claude -p, tell me a joke, you know that kind of thing, just to see that it works. But I always felt like something would need to be more babysat. 09:06.41 Ben Rady Mm-hmm. 09:06.42 Matt Godbolt But you're saying... No, you give it the permissions, let it run, and then just mark it at the end, right? 09:14.29 Ben Rady Mm-hmm. 09:14.30 Matt Godbolt You don't have to look at all the intermediate steps that it went through necessarily. You don't have to micromanage it, which is, of course, the exhausting and part that's frustrating, which you're trying to avoid, is this whole babysitting part. 09:26.50 Ben Rady Yeah. Yeah. And I've tried this with different variations, like, you know, with like the agent teams and you have like an agent, the lead of the agent team that is responsible for watching the commits go in and out and, you know, having different agents working on different things and all of it, it's all just like different variations on the same thing. 09:45.40 Ben Rady And it's nothing, nothing that's like really any more amazing than anything else. Yeah, you know, there are advantages and disadvantages maybe, but again, this is one of those things where it's like, I'm not even doing this anymore because it's, it's been, it's been obsolete. 09:58.80 Matt Godbolt Oh, right, right, right. So that's what you were doing. 10:05.32 Ben Rady yeah. 10:05.75 Matt Godbolt That's what I remember you explaining to patiently in the pub, that's what you were doing. 10:06.40 Ben Rady Yeah. yeah 10:06.48 Matt Godbolt And I was like, cool, that sounds great. Because yeah, when I do use Claude, it feels like a powerful refactoring tool, but I have to be with it all of the time. 10:17.60 Matt Godbolt And you know then if I try and do anything more complicated with it, I have done some pretty complicated things with it. But like you just say, hey, simplify the code or whatever. Then you have to sort of watch it. 10:26.15 Ben Rady Right. 10:26.20 Matt Godbolt And it feels like, as I say, it's exhausting. And you feel like you should be doing something else at the same time. But context switching is burning you out. And it would be nice to just throw it over a fence and say, I'll have a look in half an hour without without the worry that inevitably when you say, here's a big piece of work to do, one second after tabbing away from it, it's stopped on a question saying, hey, would you like me to do this? 10:46.20 Ben Rady Right. 10:46.32 Matt Godbolt and then you come back to it and like you've been doing nothing. 10:47.22 Ben Rady Right, right, right. 10:47.30 Matt Godbolt Yeah. 10:49.02 Ben Rady Yeah, but the general model has not changed. 10:51.31 Matt Godbolt So. 10:51.46 Ben Rady The general model for me that I'm trying to work towards, which you know happens in fits and spurts and I run into problems with it, and you know but the thing I'm trying to move toward is a world where I create... 11:03.20 Matt Godbolt Okay. 11:03.20 Ben Rady It's a little bit like getting the right answer on the internet by posting the wrong answer. 11:07.64 Ben Rady I create... 11:08.16 Ben Rady a vague, partially specified, broken in pieces skeleton of what it is that I want to exist. 11:16.82 Matt Godbolt that 11:17.13 Matt Godbolt Right. 11:17.44 Ben Rady And then rather than creating like complicated prompts, I just put comments in the code because that sort of creates like the most context for Claude, right? 11:25.97 Matt Godbolt , right. 11:26.08 Ben Rady Like instead of describing like, oh, in this function, in this file, maybe you should consider doing this. It's like, no. 11:30.76 Matt Godbolt Right. 11:30.90 Ben Rady to do, do this, to do, do that. And then it can tell from the like surrounding function structure and maybe what's calling it and like the tests that are calling it. like It gathers more context and it like focuses, because it's all about managing the context window. 11:44.98 Ben Rady right like You just have to get the right information in the context window, no more, no less. 11:49.84 Matt Godbolt Yeah. 11:50.28 Ben Rady And so I feel like the best way to do that is to say, okay, I'm going to take a bunch of crappy things. I'm going to have one agent break up the work that it sees in those crappy things. 12:03.66 Ben Rady And then each piece of crap is gonna be worked down by one agent, which will create one commit. And then all of those commits together then come back to me as we clean up all your mess, right? 12:15.32 Matt Godbolt Got it. 12:15.56 Ben Rady And that is the workflow that I'm trying to move towards. And eventually I kinda wanna get to a point where after that process is complete, 12:26.38 Ben Rady I don't even need a PR. I don't even need anyone to review it because the PR is baked into the continuous deployment process. And that's just something that because here's here's the thing is we've we've created all these amazing tools for writing more code and making more changes. 12:43.11 Matt Godbolt Right. 12:43.58 Ben Rady but But as you know, if you have a pipeline with multiple stages and you increase the throughput of one stage without increasing the throughput of the next stage, all you do is create a queue at the next stage, right? 12:54.72 Ben Rady You don't actually increase the throughput of the overall system at all, right? 12:57.02 Matt Godbolt Yeah, this has been my life of like, it used to be that I would open up like say Compiler Explorer and look at the 40 open pull requests and go, oh gosh, I really have to get through these. 13:06.23 Ben Rady Right. 13:06.34 Matt Godbolt And this is when humans were generating these pull requests, right? And I want to make sure that I give them the time and the thought to interact with them and say, yeah, this is great. 13:15.12 Ben Rady Right. 13:15.20 Matt Godbolt Or can you change this? All that stuff. But it's a lot of work and ultimately it's great. I don't want to sound like I don't like that thing, right? But now, when I ask an agent to do like, Hey, can you fix bug 27? 13:30.20 Matt Godbolt It goes off, finds bug 27. 13:31.43 Ben Rady Mm-hmm. 13:31.66 Matt Godbolt Often it can, if they're a certain form. And then now, instead of me working on bug 27 and effectively pre reviewing it because it's my own code. Right. 13:41.72 Matt Godbolt And, you know, CE is not a professional product. 13:44.75 Ben Rady Mm-hmm. 13:45.44 Matt Godbolt So like, you know, I can merge straight to main if I want, I choose generally don't, but I still, you know, the review is kind of like, advisory more than anything else, I can I can I can fix bug 17 and we're done. 13:57.46 Ben Rady Mm-hmm. 13:57.62 Matt Godbolt But now it's like, no, I've asked the robot to do the bit that I enjoy doing. And then and then I get just stuck with the bit that I don't like so much, which is the review part. 14:06.36 Ben Rady Yeah, yeah, yeah, right. 14:07.01 Matt Godbolt And I'm like, yeah, so. And then you're like, oh, now I have 80 open PRs because I've got some, oh, oh dear. So 14:13.10 Ben Rady Yeah, yeah, yeah, I mean, so yeah. 14:16.50 Matt Godbolt Kind of removed the... But, but that you know, without without human interaction at some point, how do you prevent... wildly spinning out of control things I'm sure you've seen this you know like I've you know you know I mean but models are getting better at this but you know I actually was working with one just a few minutes ago and I saw it several times go no let me take a big step back no let me take a huge step back as it was kind of floundering and realizing it was floundering and whatever magical craft crafting in the prompts and whatever they're doing notices that and then tries to like do what a human would do which I think is clever but like you know But, you know, you do need someone to say, wait a minute, you know, the otherwise you're going to be in like there's some kind of like millions of paper cuts all over your code base. 15:01.89 Ben Rady Oh, yeah, yeah, yeah. 15:02.10 Matt Godbolt How do you how do you deal with that without a human going, wait, wait, wait a second. Something needs to look. I have the context and I can broadly. 15:08.40 Ben Rady Yeah. I mean, so I think I don't think that the way to do this is to give it a large chunk of work to do and then go and make tea and then come back in 30 minutes. 15:18.97 Matt Godbolt OK. Mm-hmm. 15:19.46 Ben Rady that's That's not the model that I'm trying to move toward. 15:22.96 Ben Rady The model that I'm trying to move toward is one where I'm doing enough work to get, you know, to sort of like seed the work of some number of agents. 15:37.26 Ben Rady And while those agents are churning away, I'm kind of like thinking about what the next step is and maybe creating those pieces, some of those pieces. And one advantage of this model is that, you know, you can do a git pull at any time. And so if like the easy ones start coming in first, right? So like if you have a to-do comment, that's like, you know, 15:57.64 Ben Rady you know, simplify this method, right? There's some unnecessary complexity in here. 16:01.81 Matt Godbolt Right, right. 16:02.18 Ben Rady Like, you know, you'll see that one finish and then it's like, all right, that took all of 10 seconds. git pull, okay, cool, I'll get that and I'm gonna look at that. And so you it's not like, you know, create a big bunch of work, push off a big bunch of work, get back a big bunch of work, review a big bunch of work. It's more like create a bunch of individual things or maybe just a handful, push them out and then start pulling them in and reviewing them and reading through them and maybe even iterating on them. 16:29.14 Ben Rady Or I'd be like, you know, I'm gonna revert this commit, we're gonna try again, or I'm gonna, you know, add another comment in that says like, this still needs more work. 16:38.18 Matt Godbolt so So just to look at my, maybe I missed this part. 16:40.76 Matt Godbolt you You can pull from this repo and then it's just a different remote for you. So you would, you're still, as in you, Ben, are still the main repo is on GitHub or GitHub Enterprise wherever it is. 16:51.75 Ben Rady Yeah. 16:51.86 Matt Godbolt And then you are just pulling from yet another source or pushing and pulling to another source, much as if it was like a vendor branch. 17:00.00 Ben Rady Right. 17:00.18 Matt Godbolt It's just like, this is the agent repo. 17:00.80 Ben Rady Right. Right. 17:01.74 Matt Godbolt I see. Okay. 17:02.74 Ben Rady Yeah, it's a different Git remote. 17:04.35 Matt Godbolt So then the 17:05.15 Ben Rady And usually I'll just name the remote for whatever the host name is that the Docker image is running on. right 17:10.79 Matt Godbolt Makes sense. 17:11.33 Matt Godbolt Makes sense. Yeah, no, I get it. So, and then ultimately those changes make it through into the main line through you having pulled them and looked at them. 17:19.11 Ben Rady Right. 17:19.38 Matt Godbolt And so you've looked at them locally rather than through GitHub. So that's kind of, that's interesting. 17:23.94 Ben Rady Exactly. 17:32.26 Matt Godbolt That's interesting. So, so that's different from what the model that I've been sort of trying to work towards myself in my own experience. way because for me, the goal the goal, and this is very Compiler Explorer centric, is many, many, many of the open issues in Compiler Explorer are please install Compiler X. And Compiler X is, yeah and we have readme's for this, people can send pull requests for it, but usually it's a multi-step process. and you know It can be up to four steps, which is a pain, but you know it's in it and it's almost automatable. 17:58.82 Matt Godbolt you know, someone says, hey, I have this Clang build over here. 18:02.27 Ben Rady Yeah. 18:02.32 Matt Godbolt I'm like, great. what's What GitHub repo is it? Oh yeah, which branch is it in? Oh yeah, right, whatever. And you go and you go and pull it down. It's like, yeah, didn't build. I said, oh yeah, you need these extra flags because we need these things on our building. 18:12.36 Matt Godbolt Okay, that can be done, right? You know, there's no, but I had to try the build out and which is, you know, like a 45 minute build on a beefy machine and then discover that I actually, no, I need to change it. 18:22.82 Matt Godbolt And I have to iterate a few times to get the exact flags Then having built it, it gets some it needs to be installed, and then the install usually picks up a few things, and then it has to be configured, then it has to be tested, whatever. 18:33.48 Matt Godbolt Each of these is a different repo for unfortunate legacy. well I don't know if they're unfortunate, but for reasons, right? you know most Most people who pull the get the Compiler Explorer repository aren't actually installing three terabytes of compilers. 18:45.78 Matt Godbolt They're about to use it on their local machine, and they don't want to have anything to do with all of the things that to do, the orchestration and infrastructure of Compiler Explorer, the website. 18:54.23 Ben Rady Mm-hmm. Mm-hmm. 18:54.48 Matt Godbolt So that's a separate thing. They just have the code, right? And the code is just versioned. and We pull in version 12 of the code into, you know, that kind of stuff. So, but it does mean that now there's two repos you have to manage. And then similarly, even in the infrastructural thing, it doesn't make sense to have like every Docker container we've ever had to build every possible compiler ever gets rebuilt every single time, every push happens. 19:15.57 Matt Godbolt So they're in their own repositories and so on. And so it all makes sense, but it's also painful and it requires orchestration and multiple steps. Anyway, popping the stack, it is nearly automatable, but you need something with half a brain to watch it and got to go, oh yeah, maybe we need to change this flag. Oh, it has completed now. Now I can test install it locally. Oh, it does work locally. Okay, cool. Now I can make the pull request, all these things. And so that workflow is what I would like to manage so that I can sick the... 19:45.62 Matt Godbolt something on that and say, can you just do this thing and send me the pull request when it's done. And I can review on my phone while I'm walking the dog and go, yes, that's fine. And merge it because most of the time I can see if it's okay. 19:57.64 Matt Godbolt and And if in particular, I can see that it's been through the test steps and the CI build is giving it the clean bill of health. 20:02.73 Ben Rady Yeah, yeah. 20:03.06 Matt Godbolt So that's what I'm working towards to try and design away, that kind of thing.,, Yeah, it's kind of a different model, I think. from Yours is more of a, I want to use this as a pair programmer or mob programmer with me, and I'm kind of pulling and pushing with it. Is that a fair observation, or would you say it's different than that? 20:24.82 Ben Rady I, you know, I don't know that it really... I wouldn't really compare it to like pair programming or I wouldn't compare it to any practices that we have used in the last 30 years, honestly. 20:36.60 Ben Rady It's just a new and different thing. 20:38.10 Matt Godbolt Interesting. 20:38.48 Ben Rady It's just a different, it's just a different way to build software. 20:40.89 Matt Godbolt Right. 20:41.80 Ben Rady If the closest analog is I've had situations in my career where I have intentionally created an incorrect PR and sent it to someone 20:55.86 Matt Godbolt for the same, you know, someone's wrong on the internet kind of approach. 20:58.22 Ben Rady Yeah, like you get you get into a discussion with someone, like I think you should this, and I say, you know what the easiest way for me to describe what I'm trying to do here is to do a third of it. 21:06.94 Matt Godbolt Yeah. 21:07.56 Ben Rady And then you'll see the other two thirds. So I'm just going to do that. 21:10.31 Matt Godbolt Yeah. 21:10.34 Ben Rady Now, you know, it's very limited in the situations where I've done that, right? 21:15.94 Matt Godbolt Yeah. 21:16.24 Ben Rady But now it's basically that all the time. Or at least that's what that model was, which again, is not what I'm actually doing right now. 21:24.57 Matt Godbolt Maybe. 21:24.68 Ben Rady But that's... 21:24.68 Matt Godbolt I was going to say, yeah, you just made me think of something else that I found is a useful thing for me to do now is that the cost of prototyping with now we're I'm just talking generally about this is going to be a meandering conversation. Sorry, listener. 21:38.42 Matt Godbolt The cost of exploratory work is so low now. that I will happily, so I now have a restricted user on my machine and I run it in a sandbox and I put a T-Mux into it like you're suggesting and it allows me to run in YOLO mode as well. So then I can kind of say, oh, knock yourself out, go and, you know, I don't care. 21:57.08 Matt Godbolt The worst you can do is delete your entire directory and everything you have in here, which in case is, well, inconvenience me not one bit, you know, you'll stop working and then I'll come find you. 22:05.34 Ben Rady Yeah, yeah. 22:05.74 Matt Godbolt And it has, you know, it's a separate Unix user. It has no credentials, all the things, all those good things. I don't necessarily internet sandbox it as well. I mean, if I told it to hack my network, I'm sure it could. 22:16.02 Matt Godbolt But anyway, the point is I can point it at saying, so like, I don't know how to do this. 22:20.10 Ben Rady Mm-hmm. 22:20.18 Matt Godbolt Can you just have a spirited attempt at it? And then and I can see... where where you get stuck and where the problems lie. right The cost of prototyping and spiking out an idea and going, would it be possible to do X? 22:31.74 Matt Godbolt Like, hey, what if we were to completely replace this? So in the window behind you, my JavaScript BBC microemulator, the it's like a 400k download in the web thing because it has two separate g unzip libraries for like very ancient reasons right there's just like two you know silly reasons and nowadays browsers have decompression stream but they don't support the one thing that I kind of need in it and I'm like is it possible to hack the heck out of it and make it work reliably on both node and chrome and firefox go 23:02.68 Ben Rady yeah, yeah. Yeah, 23:03.82 Matt Godbolt And it came back and I can see behind you now it's like, yeah. And now I haven't looked at the code. It may be atroc an atrocity, in which case I'll throw it away and we'll pretend it never happened. But if it's okay, that was great. 23:15.06 Ben Rady yeah. yeah 23:15.14 Matt Godbolt Right. And that's, that's not utility to me. 23:16.94 Matt Godbolt And it's also not the kind of thing that I particularly want to do. And again, this is something interesting. Maybe, maybe this is a pivot now, right away from the kind of things that would be automating. It's like, And maybe you're feeling this too, because you said about like the way software engineering is changing, the way that you're developing. 23:31.44 Matt Godbolt This is something new that is not pair programming or mob program, whatever it is, whatever this is nowadays. It's LLM assistant, agent assistant coded coding. 23:40.97 Ben Rady Yeah. yeah 23:41.54 Matt Godbolt And, you know, there's a lot of people who quite reasonably have a lot of issues with it. There are people who have, you know, issues on in terms of the power that it's using and things like that. And that is a very valid concern, but not one I want to talk about here for all the complicated reasons that I'm I'm not well thought about. 23:55.10 Matt Godbolt it And honestly, a little bit put my fingers my eyes and hoping that someone clever person solves this. You know, I suppose I'm pinning my hopes on the fact that there is at least one one. 24:04.91 Ben Rady Haha. 24:05.38 Matt Godbolt one prior piece of art that says that you can think and not take an entire data center's worth of power because it's between my ears at the moment, right? And it's not, apparently not taking more than a few tens of watts. I don't know what a brain takes, but it's certainly not hundreds of kilowatts, right? Anyway, that to one side. The, the, 24:26.28 Matt Godbolt Folks of our age, I think, are having a bit of an interesting experience here because you know we can see the utility of being able to do stuff very quickly in prototype, like I just described. 24:39.54 Ben Rady right. 24:40.34 Matt Godbolt We're seeing the utility of getting stuff done really quickly, which... And maybe we're sort of still discovering what really quickly is whether or not there is it is a silver bullet or it's you know just a sort of copper bullet that's not quite as good as we think it is, whatever. 24:54.78 Matt Godbolt Something like this, right? It's like it's a good it's a good thing. 24:57.11 Ben Rady right 24:57.18 Matt Godbolt Maybe it's it's not as we're not as effective as we think we are. Maybe that will play out in the medium term and we'll discover that. But what it means is that we're not programming... as much anymore, like literally hand on keyboard, open bracket, type some things, close bracket. I don't feel like I'm doing that. There have been days recently where I've spent the entire day going. And then at the end of the day, I was like, oh, let me just look at the code. 25:20.98 Matt Godbolt Oh, I haven't opened even Visual Studio Code. I've just been talking to a you know various things. 25:26.35 Ben Rady right 25:26.38 Matt Godbolt It's like I'm chatting in Slack and I'm chatting in Windows and things are happening and I'm reviewing them on like pull request level things, but I'm not necessarily programming in the same sense. 25:36.80 Matt Godbolt And like, there's a definitely a part of me that's like, Oh, I like that. 25:39.90 Ben Rady Yeah, right. Uh-huh. 25:43.34 Matt Godbolt And so I'm, you know, maybe I'm just using this as our, you know therapy session. 25:47.75 Ben Rady Yeah. 25:48.02 Matt Godbolt I'm I'm still trying to work out how I feel about it. Like I can't deny that I'm excited to get things done that are exciting to me. 25:56.19 Ben Rady Mm-hmm. 25:56.80 Matt Godbolt And I enjoy the outcome. but I feel like maybe I'm missing something on the journey, you know, and maybe that will bite me in the future as well. 26:05.28 Ben Rady Yeah, no, I've thought about that a lot you know in the last three to six months. 26:11.82 Matt Godbolt Oh boy. 26:12.22 Ben Rady And you know the conclusion that I kind of came to is that the career that I enjoyed for 25 years is now over. And my number one priority in exploring all of these things, and the reason why I change it every month, or less than a month, is because the number one priority is that the new thing is fun. 26:32.86 Ben Rady The productivity gains, I don't care. I'm sure they'll come. 26:35.55 Matt Godbolt Right, right, right. 26:35.62 Ben Rady like It's kind of inevitable that they'll come in some form. I'm not worried about that at all. The sort of efficiency, the like you know resume fodder of like, did you use this? I don't care about any of that. The only thing I care about is that I create a new way of working that is fun. 26:53.72 Ben Rady Because if it's fun, I'll do it. And if it's not fun, then I won't do it. And if I do it, then I'll get better at it. And if I don't do it, then I won't. 26:59.69 Matt Godbolt That's... 27:00.14 Ben Rady So the only thing that matters is create something that's fun. And the inch the great thing about this is that it's like a brand new world. like 27:07.96 Matt Godbolt Yeah. 27:08.26 Ben Rady it's You get to reinvent the rules all over again. you know 27:11.26 Matt Godbolt Yeah. 27:11.56 Ben Rady I've been having a lot of discussions with people lately about maybe rewrites aren't a bad idea anymore. 27:16.86 Matt Godbolt Yeah, maybe not. I mean... 27:17.86 Ben Rady Maybe language choice doesn't matter anymore because you can just have it, rewrite it in whatever language you want, right? 27:23.72 Matt Godbolt and 27:24.00 Ben Rady Like there's all of the rules might be out the window. 27:27.08 Ben Rady Some of them are not going to be, but we don't know, right 27:29.96 Matt Godbolt Well, and I was going to say, some some of the rules that are closest to your heart are probably still very valid. 27:33.36 Matt Godbolt You know, like the fact that having a strong framework around the outside about sort of intersubjective and test for, is this what we want it to be? 27:47.58 Ben Rady Yeah. 27:48.56 Matt Godbolt bit yeah I said test, I was trying to avoid the word test, but like, is test, right? 27:52.78 Ben Rady No, I'm, you know, it's verifying correctness, right? 27:54.20 Matt Godbolt Functional test? Yeah, yes, thank you, that's better word. 27:54.62 Ben Rady the The requirement that you verify that the software that you produce works correctly for the definition of correctly that you probably are in charge of maintaining, right? 28:04.06 Matt Godbolt Yeah. 28:04.12 Ben Rady Like that's your job is to, what does it mean to be correct? Right? Like that's why you're there is to figure that out. 28:09.13 Matt Godbolt Yeah. 28:09.56 Ben Rady None of that has changed. The tools that we use to do it, I'm sure are going to change dramatically. 28:14.90 Matt Godbolt Right. Right. 28:16.66 Ben Rady Yeah. 28:16.74 Matt Godbolt It's interesting. So I was having a discussion about how the kind of, if you cast your mind back to one of our first guests, Claire McRae and the, I always want to call them golden tests, acceptance tests. 28:34.63 Ben Rady Not acceptance tests. 28:34.94 Ben Rady Yeah. 28:35.08 Matt Godbolt Is that the right one? 28:35.67 Ben Rady Approval tests, perhaps. 28:35.88 Matt Godbolt Oh, I'm so sorry. 28:37.10 Matt Godbolt Approval test. Thank you. 28:38.07 Ben Rady Yeah. 28:38.44 Matt Godbolt Oh gosh. Yeah. But you know, though, the, those tests seem to be not, let me try and think, the disc, I'm trying to remember what the discussion was. 28:51.08 Matt Godbolt I you know, effectively I, prefer a well-designed unit test because then I, you know, like you, right? If something breaks, one test breaks in one place and you don't have like this collateral damage of like, well, I changed the log line and now everything is different apparently. 29:06.90 Ben Rady Yeah. 29:06.92 Matt Godbolt Not everyone thinks that way. And someone made a reasonably compelling argument to me that I'm forgetting exactly, but of like in an LLM driven world, the value of having a targeted unit test that tells you what the problem is, is not as great as the fragility of like, oh, I'm changing my API and now everything has to be updated. 29:26.32 Ben Rady Yeah. 29:26.32 Matt Godbolt Whereas like the bloody output of your program should be the same. Kind of makes sense to me then. But like, it's, yeah, you know, it doesn't sit comfortably with me yet. but I could see it and I was like, this is the first time I'm nodding a little bit towards this. This. 29:42.10 Ben Rady No, it's funny because, again, all the rules are up for debate. Let's debate. I could make the argument that the sort of isolation of those tests in the sense of like one bug produces one test, what I would have been called an informative test. 29:59.03 Matt Godbolt hmm. 29:59.34 Ben Rady is less important, but only to the extent that the tokens don't cost you too much. right like If you've got Claude or many Claudes in a very tight loop running tests over and over and over again, and they're trying to make changes, and every time they make any change, you get hundreds of failing tests, that's going to fill up the context window pretty fast. 30:15.87 Matt Godbolt it gets pretty expensive pretty quick. yeah 30:17.62 Ben Rady But the thing that might matter more is speed. Right? Like the faster your tests run, the more iterations you can go through. 30:24.07 Matt Godbolt Yeah. Yeah. 30:24.16 Ben Rady And if you can automate that, then you can get things done very quickly. Right? These are things that we're going to have to find out. 30:31.30 Matt Godbolt That's an excellent point. Yeah. Yeah, no, I think that's very, very valid. It's in fact, one of the more interesting things I have seen people do again recently is change the model that they're using to us to a smaller one that's dumber because it can go faster. 30:44.04 Ben Rady Yeah. 30:44.19 Ben Rady Yeah. 30:44.20 Matt Godbolt It's like, I don't care that it's dumb because you know it's protected from itself. 30:47.32 Matt Godbolt and like And then I can use a slower model at the end to kind of like clean it up or whatever. 30:51.10 Ben Rady Mm-hmm. Yep. 30:51.54 Matt Godbolt And that was like, oh, that is interesting. 30:53.65 Ben Rady yep 30:54.62 Matt Godbolt So let me ask you another question. This is really far reaching now. Sorry, we've we've reached half an hour into this conversation. We had literally zero plan. How do you feel about the fact that you're working and then you get a 500 error from the Claude endpoint and now suddenly everything comes to a slamming halt and you're like, oh oh, I can't work. And as a proxy for, oh, what does it mean for my hobby that I could previously do with an air-gapped computer 31:30.54 Matt Godbolt and then And obviously there's a hundred reasons why that's not true, but like let's just go with it for now. And I got, you know, I'm on the plane. 31:35.67 Ben Rady Right. 31:35.88 Matt Godbolt I have no internet access, although also that's not true anymore. I'm just tinkering around and I can do my thing and I'm enjoying it. Suddenly it's not only the fact that there is no internet there, it's the fact that there is a vendor that is the thing that is preventing you. 31:50.26 Ben Rady Yeah. 31:50.26 Matt Godbolt That, that you know, as much as I'm an anthropic fan boy, that does scare me. and I'm like, oh, shucks. 31:59.54 Ben Rady Yeah. 32:00.02 Matt Godbolt What do you, yeah, discuss. 32:00.80 Ben Rady Yeah, that's a real serious problem. That's a real serious problem. And, you know, I, yeah, I get, yep. 32:04.98 Matt Godbolt You can see why folks are looking at like, you know, self hosting solutions, even if they're again, dumber models, it's like, well, look, I have a rack of GPUs behind me or whatever, and it's running there. 32:15.00 Matt Godbolt And then I know where I am, stand with it. You know, it's a, it's my own electricity, better my own power. 32:18.94 Ben Rady Well, so that this leads me and the local models thing leads me to the next iteration of things that I am doing. 32:26.13 Matt Godbolt Oh, unintentional segue. 32:26.82 Ben Rady and And one of the reasons why I am doing it, the next iteration is I am just fully leaning into remote development environments. 32:37.57 Matt Godbolt Right. Right. 32:38.18 Ben Rady And I am trying, I have right now a project where I'm trying to just set up an Amazon AWS account. It's really just the EC2 instance and a few other attendant things right now. 32:51.78 Ben Rady But basically, like the way I want to think about this is that like I do all of my programming in and a cloud account, and I'm doing that for multiple reasons. 33:02.04 Matt Godbolt which mirrors the kind of way that you and I've had to work in finance for a while. 33:04.98 Ben Rady the first The first... Yeah, it's not that foreign. 33:07.24 Matt Godbolt Anyway, for all those reasons of, like yeah, it's not, yeah, we've we've got kind of gotten used to it. 33:08.51 Ben Rady and Exactly. Right. 33:08.54 Matt Godbolt And also, you know, IDEs are good at this these days. 33:11.40 Ben Rady Yeah, remote development yeah over SSH works pretty well. 33:13.82 Matt Godbolt You can kind of, yeah. And for me, it works a treat as well. 33:15.78 Ben Rady Yeah. 33:15.86 Matt Godbolt You know, I'm forever just using Mosh to talk to the machine that's that's under my desk here, where where the real development happens for the same reason. 33:21.61 Ben Rady yeah 33:21.82 Matt Godbolt And it doesn't matter which laptop I'm on or where I am. I'm the same, dropped into the same environment, carrying on with the same sessions that were there from before. So it's, yeah. But yeah, so you're setting this up. 33:30.64 Ben Rady Yeah. Yeah. now And the metaphor here, I think a useful way to think about this is like a long time ago in a galaxy far, far away, when we built systems, they ran on a computer. 33:39.12 Ben Rady Like you'd go into a you know server closet in your office building and they'd be like, all right, this is the Dell computer that we got to run our you know whatever. 33:49.03 Matt Godbolt Yep. 33:49.22 Ben Rady And it was on that computer. And then we built, you know, much bigger systems that run on lots of computers in the cloud and all of that. 33:57.90 Matt Godbolt yep 33:58.20 Ben Rady This is what we're doing with the development environment. I think development environments are going to move from it's running on your computer that's like on your desk or your laptop to like, no, it's a whole system of interconnected services and computers and things for you. 34:13.94 Ben Rady for you individually so that you can do all of these things with agents. 34:18.64 Matt Godbolt Yep. Yeah. 34:19.08 Ben Rady Right. And a key part of this is security. Right. Because, you know, a lot of times in a lot of environments that I've worked in, they've had this sort of like, you know, hard exterior, soft interior security model. 34:31.66 Matt Godbolt yep 34:31.78 Ben Rady where you're protecting yourself from from outside attacks, but then inside the network is fairly loosey-goosey, right? And I think when you have a structure of like, you know, very competent engineers internally, and you are reasonable about taking precautions and various things, that model works really well. 34:52.22 Ben Rady I don't want to set a whole bunch of Claude YOLO agents loose in an environment like that, right? 34:58.18 Ben Rady So my... 34:58.24 Matt Godbolt Right. 34:58.24 Matt Godbolt We've all seen the tweets from people saying, oh, I, you know, Claude just deleted the database, whatever, you know. 35:03.92 Ben Rady Yeah, 35:03.94 Matt Godbolt And like the thing is, you and I as humans have made idiotic mistakes in our time, maybe not to that extent. 35:10.38 Ben Rady Yeah. 35:10.64 Matt Godbolt And that's only to be expected. And the only thing that you can do to protect that is to make sure those humans know the consequences and are scared of them and don't do them. But you can't scare the agents. 35:20.66 Ben Rady Right. 35:20.70 Matt Godbolt So you have to just bubble wrap them. and say you're not allowed to do the things that you think you're allowed to do, even when it would be extremely useful for them to be able to alter the live production data, to do a rollout for you or whatever. 35:32.20 Ben Rady Right. 35:32.30 Matt Godbolt You're like, no, that's not how we're doing things here. 35:36.28 Ben Rady Yep. Yep. And, and, you know, it's so, so, so, 35:37.64 Matt Godbolt Yeah, so to have fine-grained controls and say, like, you've got read-only to these things, you can do what you like with those, that cut so yeah I'm with you. 35:42.75 Ben Rady Exactly. 35:42.82 Matt Godbolt Sorry, I cut you off. 35:43.54 Ben Rady Yeah. and And cloud providers are really good at fine-grained access controls. It's something that they've been doing for decades, right? 35:49.92 Matt Godbolt Yeah, yeah, that's fine. 35:50.70 Ben Rady And so I'm like, all right, my whole development environment now is going to live in AWS, Google Cloud, doesn't really matter. And it's going to be managed in Terraform and it's going to have this like very particular setup to it. 36:02.62 Ben Rady And that's going to do a number of things for me. when it's going to solve a security problem for me so I don't have to worry about like, I don't have to retrofit my company's internal network to have passwords everywhere. Right. 36:14.08 Ben Rady You know, and then the second thing it's going to do for me is it's going to at least potentially allow me to start running my own models. Right. 36:23.18 Ben Rady So I can at least explore the idea of being less dependent on third parties in order to basically do my job. Because right now, when I when that happens, I have to drop into the slow mode and be like, all right, well, going to fire up PyCharm or IntelliJ or Vim or whatever it is. 36:40.40 Ben Rady And I'm just going to run the test myself and I'm going back to the way that I worked for 25, 30 years. 36:44.87 Matt Godbolt Yep. Emacs. 36:45.38 Ben Rady And that is slower. It's definitely a lot slower. And so I think this is just like, again, and I expect this to last like a month. 36:57.38 Matt Godbolt because things move so quickly. It's funny. I did a panel AI agents and the use of it in C++ at CppCon and they just released a video and it's like, you shouldn't have bothered. 37:09.02 Ben Rady Yeah. 37:09.34 Matt Godbolt You know, that was six months ago. 37:11.05 Ben Rady Yeah. 37:12.04 Matt Godbolt The landscape's completely different now. 37:13.10 Ben Rady Yeah, yeah, yeah. 37:14.06 Matt Godbolt You know, it's, it's, it is, I want, yeah, want so this is really interesting. and I know I asked you about this and that was where your opinion and whatever. and things but Obviously, you're now almost doubling down on the vendor lock-in with the fact that you're now like, well, I'm running on AWS. 37:27.70 Matt Godbolt Now, obviously, other providers are available, that kind of stuff. But like, there's... 37:30.16 Ben Rady I can point that Terraform somewhere else and it'll do just fine. You know what I mean? 37:33.54 Ben Rady I'm not really doing anything special there. 37:33.94 Matt Godbolt Sure, sure. 37:35.78 Matt Godbolt Yeah, I mean, I don't think... 37:36.10 Ben Rady The IAM permissions are a little bespoke, but other than that, it's not that big at all. 37:38.08 Matt Godbolt I think... 37:38.12 Matt Godbolt Yeah, and you know, yeah, there's a lot of things that, but yeah, having, you know, holding a thing in your hand and saying, this is my thing and I can do whatever I like with it. You know, in fact, until earlier I had my BBC micro behind me, which is like though the epitome of like literally everything is inside this box. 37:54.82 Matt Godbolt that is that maybe we have to accept that's going or, you know, like everything's a cycle. It used to be, you know, everyone would go and get timeshare on their timeshare machine. That's the only thing we had, you know, it's kind of a comeback round to that, but, but there's something about the models being so, you know, in principle, I can buy computers, I can rack them in my basement, I can connect them up with a network switch and I can go on and I can be like, yeah, I can, I can continue to do this, you know, that, that what I, what I like to do, but I I can't necessarily get access to, 38:22.40 Matt Godbolt the technology that lets me run an agent in the same way, right? And that's not just, you know, the GPU stuff. It's like the whole IP of it and whatever. 38:33.72 Matt Godbolt that just sort of, I suppose, having been so open source for so long, where, you know, in principle, I can compile every piece of code that I use from source. Not that I ever do, but I could, on a machine that is mostly open to me and is well understood. 38:47.04 Ben Rady Yeah. 38:47.22 Matt Godbolt That's one thing to have it sort of like taken away, we'd be like, oh yeah, you know my company uses SQL Server from Microsoft. You're like, wait, I oh, but it doesn't work. 38:57.53 Ben Rady Right, right. 38:58.02 Matt Godbolt like, tough. 38:59.18 Ben Rady Right, right. 38:59.54 Matt Godbolt Sorry about that. It doesn't sit well, but I can't deny the and this is what I wanted to go back to you know as we kind of probably should finish up soon. But like the the joy, the fun aspect and making fun. I am having fun. That's probably why I'm so invested in trying to find a way to make it work well for me so that I can enjoy the things that I'm doing. And you know and that's why I think about this whole difference between outcomes when you just, I want the cool thing, make the cool thing. 39:32.10 Ben Rady Uh-huh. 39:32.16 Matt Godbolt And I don't actually care how the cool thing was made. And having the cool thing is more interesting to me than than the making process. But then, you know, accepting that some of me enjoys the making process, but I knowing that I can choose, certainly my personal life, I can choose to make the cool things. 39:45.44 Matt Godbolt And the hope is that the The thing maker, the automatic thing maker can do the things that the only, sorry, that the that I can't do or I don't want to do rather. 39:56.20 Matt Godbolt And then I'm just left with the things that I can do and I am good at and are my USP. And that's what I hope. We're not there. necessarily yet and now I can't remember where I was going with this big long meander but yeah the joy oh yeah it's burnout I want to just talk about that because I get so you know it's I'm reminded of the times when I first got into programming and I was burning the midnight oil doing all sorts of things and I would go to sleep and I wake up early in the morning and my mind was still buzzing with like oh I could do this thing oh I wonder if we could do that whatever and I'm finding that about programming again 40:30.16 Ben Rady Mm-hmm. 40:30.90 Matt Godbolt But it's perhaps got a slightly darker tone to it because all the time I'm not able to feed the agents that are doing useful work for me, I feel like it's wasted time. 40:42.09 Ben Rady Yeah. 40:42.96 Matt Godbolt And so I, you know, and somebody was saying to me, someone I worked with was saying like, oh, I woke up in the night the other night and I got up and I was like, well, I might as well just check on what it's doing and kind of logged in to just hit enter a few times on some Claude sessions. 40:55.80 Ben Rady Yeah, 40:55.80 Matt Godbolt And there's a certain, like, there's a dark pattern around that. You know, there's a meme went around about the fruit machine where, I'm sorry, fruit machine being a slot machine and to translate for you, where, you know, you pull the crank, which is like hitting the yes, do this, and maybe you get the right answer this time. 41:10.25 Ben Rady yeah. yeah 41:10.34 Matt Godbolt And there is a bit of that and that doesn't, you know I'm I'm I don't know how I feel about that either. it feels you know So I feel like overwhelmed, overworked, burnt because I'm context switching all the time, but also excited. And I'm trying to pick through that. 41:23.00 Matt Godbolt And I wondered if, yeah, having me just talked at you like for 10 minutes, what do you if you could somehow. 41:28.06 Ben Rady I mean, that's, I that yes. 41:32.00 Matt Godbolt All right. 41:34.10 Ben Rady I think you're not the you're not the only person that is feeling that right now. 41:38.14 Matt Godbolt And. 41:38.27 Ben Rady we're One of the things that we're going to have to figure out, you know, I have used the phrase, I think, on this podcast before, a sustainable pace. What does sustainable pace look like when basically you're building software at the speed of thought? 41:50.18 Ben Rady Right? Like there's literally no barrier. I mean, you know, maybe this is a few years ahead of us, but it's like, there's literally no barrier between you coming up with an idea and implementing it. 42:00.46 Matt Godbolt Right 42:01.70 Matt Godbolt yeah 42:02.30 Ben Rady One of the, you know, we had a mutual friend that pointed out that he thought that this sort of agentic programming would separate out programmers that love to code and programmers that love to make things, right? 42:14.96 Ben Rady I think that's a little bit more of a two dimensions in a plane for me. And one thing that I have, because I think I like I enjoy both aspects of it, right? 42:26.40 Matt Godbolt There. Mm-hmm. 42:26.48 Ben Rady Like there's a puzzle solving aspect to writing code that I enjoy. That's why I play games like Factorio. But I also love building things for the sake of building things. And if I could build them at the speed that I can think of them, that would be great. One of the things that I've noticed is that I think actually this has diminished the number of personal projects that I take on because In the past, I would choose projects because I would be getting something from both of those dimensions. 42:54.90 Ben Rady Like, oh, this would be a useful thing and it would be a fun puzzle to solve. 42:58.20 Matt Godbolt Uh-huh, right. 42:58.82 Ben Rady And now the puzzle aspect is completely gone. 43:00.68 Matt Godbolt And or I would learn something and all this, yeah. 43:00.92 Ben Rady right There's no puzzle enjoyment from it at all. 43:04.57 Matt Godbolt Right. 43:04.92 Ben Rady And so there's a certain category of them that just don't meet the bar anymore. right like 43:09.08 Matt Godbolt Interesting to put, yeah. 43:10.02 Ben Rady But I'm also taking on personal projects that I never would have dreamed of doing before because it would have been too time consuming. Right. I think the net number of them is actually lower, but the quality is like, 43:26.30 Ben Rady not better, but more use because it's a personal project. What does better even mean? 43:30.08 Matt Godbolt Yeah, right. Yeah, you definitely. 43:30.74 Ben Rady It's more like more useful, right? 43:32.02 Matt Godbolt Right. 43:32.34 Ben Rady Like there's more of a chance that I'm going to actually use it and it will not just be a thing that I built three years ago and then shoved in a folder somewhere and then forgot about. 43:42.56 Matt Godbolt Right. 43:42.67 Ben Rady it 43:42.78 Ben Rady Right. 43:42.88 Matt Godbolt It is. 43:43.10 Matt Godbolt Yeah, it's definitely changing. You reminded me of a tweet I saw by Ellie Huxtable, who is the person writes Atuin, the shell history thing. 43:50.56 Ben Rady Oh yeah. 43:50.64 Matt Godbolt I don't know if you know it. 43:51.35 Ben Rady Yeah. 43:51.48 Matt Godbolt Yeah. I can't live without it now. 43:52.96 Ben Rady Yeah. 43:53.02 Matt Godbolt That's another sort of crutch I have to live on as I, my memory did disappears and I have to use my infinite shell searchable shell history as my, like the most important intellectual property I create. 44:03.92 Ben Rady so 44:04.92 Matt Godbolt , Yeah, she was retweeting somebody who was like some high school student who was like trying to build a web browser using agents to help them do it. 44:13.96 Matt Godbolt And it's like, and I think her point was something along the lines of like, if you aren't doing this kind of thing, are you even exploring the space anymore? Now now that the barriers have come down so much, well, you know, like this is an amazing kind of thing you can do. 44:25.50 Matt Godbolt Now, whether you're successful or not, this is the new thing that you can, yeah this is a new achievable goal, right? Or at least, you know, you can learn a whole bunch of stuff about why it's not trivial to do this kind of thing. 44:37.05 Ben Rady Right. Right. 44:37.14 Matt Godbolt You know, I was fascinated by that. 44:39.08 Ben Rady right 44:39.08 Matt Godbolt And I thought, wow, you know, what what it would be like to be a teen in this and this environment. But I would like to put a massive thumbprint thing which I now I've made a horrible noise that microphone is, I'm not going to like this in the edit. 44:54.18 Matt Godbolt I come from this as somebody who can afford to pay for the access to these systems at the level, which means effectively, I don't have to think about it so much. 45:07.30 Matt Godbolt I don't hit the limits very much. Right. And that is different from somebody who is, 45:13.08 Ben Rady Yeah. 45:15.00 Matt Godbolt you know, you know, and unable to afford even, I say, the most minimal access to cloud. And that is not a good feel, actually, compared to like, you know, if you could get a computer in the old days, even some time on your friend's computer, you could learn to program. 45:27.92 Matt Godbolt And now it's like, no, you need a $20 a month subscription at the absolute minimum to even start the whole process. 45:32.96 Ben Rady yeah 45:33.08 Matt Godbolt You know, that doesn't sit that well. 45:34.14 Ben Rady And honestly, yeah, those $20 a month subscriptions are clearly being subsidized and are not sustainable and are, yeah. I mean, if you look at, especially what's been happening with some of the rate limiting lately, like it's getting, yeah. 45:45.52 Matt Godbolt So I understand, yeah. it 45:47.60 Ben Rady Like, and so like, yes, it's introducing this whole other like barrier to entry for programming, which is not great. 45:54.40 Matt Godbolt Yeah, it's, yeah. Not great, but, you know, also... if you know if you're, I guess, a craftsman, you can buy a set of tools and you know whittle away at a piece of wood and make something beautiful, and that's wonderful, and it's a new thing. 46:08.56 Matt Godbolt But like you know I can't operate a mill because I can't afford it. 46:12.79 Ben Rady Yeah. 46:12.82 Matt Godbolt It's like, well, fine. you know Maybe that's okay anymore, but it's just that it's always been something that is so emotionally important to us and our backstory. The reason that we you and are even talking to each other now on this podcast is because we were whittling away, right? 46:27.28 Ben Rady It's true. and you know, yeah, yeah, yeah. 46:27.91 Matt Godbolt And now, don't know if 46:28.78 Ben Rady It's possible that history will tell of a brief period of time where unlike pretty much every other professional engineering industry, civil engineering, mechanical engineering, maybe not mechanical, engineering You could essentially for the cost of a laptop, have everything that you needed to apply your profession. 46:48.38 Matt Godbolt Yeah. 46:48.64 Ben Rady And that was incredible. What an amazing thing to have occurred. 46:52.47 Matt Godbolt Yeah. 46:52.78 Ben Rady That's not how normally things occur, right? 46:55.29 Matt Godbolt No, that's true. 46:56.99 Ben Rady You know, you can't be a chemical engineer at home unless you're just brewing beer. And even then it's sort of like, you know, how are you going to scale that? 47:05.00 Matt Godbolt You know, I mean, that's true. 47:06.07 Ben Rady and You're not going to, you're not going to get a job at, you know, Oh God, what is the name of that chemical company? It's like, we don't make the thing. We make the thing that goes, whatever. 47:16.68 Ben Rady Some big chemical company whose name I can't remember right now because you know how to brew your own beer. 47:21.44 Matt Godbolt isn't Isn't your wife a chemical engineer? 47:22.88 Ben Rady Well, that's why I brought that one up. 47:23.66 Matt Godbolt Should we know this stuff? 47:24.30 Ben Rady I mean, you know, she worked in the petroleum industry for a little while and you definitely can't do that at home, nor should you, nor should anyone ever for any reason. 47:32.05 Matt Godbolt Oh. No, that's true. Nor should you. No. 47:33.99 Matt Godbolt True. Oh, boy. Well, somehow we're a like very long time into this podcast, and we should probably stop talking about it, but this is... 47:40.04 Ben Rady Yeah, well, this yeah this is a topic that could go on forever. Yeah. 47:43.44 Matt Godbolt I know, but it's really interesting to check in. and I mean, I think unlike most of our podcasts, this one will probably go out somewhat contemporarily. So maybe this will be up to date when by the time people hear it still. you know like we We won't be so ridiculously out of date, rather. 47:57.24 Matt Godbolt So I mean I'd be interested. 47:59.96 Ben Rady yeah 48:01.02 Matt Godbolt you know it is it's It's a tough and interesting and very deep topic and has a lot of dimensions that we're not used to dealing with as programmers. you know like which Which sort algorithm is better? is like where my you know What should be pulled out how the branch predict as well these are things that I'm kind of more comfortable with but when it's like you know hey this may change the whole nature of what we do as a profession and it may exclude people it may cause environmental damage but it's also very exciting I don't know how to navigate it other than like I'm so kind of riding the wave yeah 48:30.28 Ben Rady Yep. Yep. It's, it's a it is a crazy world. We're in a crazy world. 48:31.69 Ben Rady and Everything's new. 48:32.16 Matt Godbolt Well, friend, let's let's leave it there for this time and we'll let our listeners let us know if they want us to continue ranting and rambling about this or whether we should go back to something a little bit more traditionally twos complementy. 48:44.92 Matt Godbolt But well, either way, this has been fab. Thank you for bringing me up to date with what you're doing. 48:48.86 Ben Rady Right, right. 48:50.56 Matt Godbolt And we'll have to try and find a time to grab a coffee in person sometime and talk more. 48:53.00 Ben Rady Yeah, next time at the bar, that'll be the plan. 48:54.80 Matt Godbolt That works. That works for me. 48:56.78 Ben Rady Yeah, yeah. 48:56.94 Matt Godbolt All right, friend, until next time. 48:58.46 Ben Rady Until next time.