Transcript #221: Pattern matching and accepting change in Python with Brett Cannon
Return to episode page view on github00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.
00:05 This is episode 221, I think, recorded, when is it? February 17th, 2021.
00:11 I'm Brian Okken.
00:12 I'm Michael Kennedy.
00:13 And we also have Brett Cannon, yeah.
00:15 I always talk over the third person. I'm not sure why.
00:19 Well, you're always going like, is there going to be an introduction or should I just join the Brady Bunch theme?
00:23 Let's just go in a circle and just introduce ourselves.
00:26 Well, if we're going to do Brady Bunch, we've got to have more people so we can fill out, what is that, rows of three or whatever in the picture?
00:33 I'm sure Anthony Shaw and Paul Everett are available based on how often they show up here, so I'm sure they're waiting in the ways.
00:38 That's right. We'll just swoop them in here for the right picture.
00:41 Welcome, Brett. It's great to have you here.
00:42 Lovely to be back.
00:44 You know what, Brian, I'm impressed with Brett's microphone.
00:47 He has mastered the work from home.
00:49 Yeah, I love this. We're going to have to put a link in the show notes to this thing.
00:53 Tell people about this.
00:55 So, Brian and I both have good microphones.
00:57 We have many different microphones we've tried, but yours has a visual aspect, which is unusual for audio.
01:03 Yeah.
01:03 So, it's a HyperX Quadcast S specifically, and it comes with RGB lighting because it's really a gamer mic.
01:11 But, obviously, in pandemic times, I work from home.
01:15 And my wife is also at home because of the pandemic.
01:17 And we always had an issue of her wanting to come in and not knowing whether I was actually occupied actually in a meeting, because I'm in them a lot for work, or whether or not I was just sitting there with my headphones on listening to music or whatever, and she could totally just walk in.
01:31 And so, the great thing about this microphone is if it has a touch sensitive top, and if you tap it, the LEDs turn off.
01:38 And so, it acts as like an on-air light for the room.
01:41 I mean, it's not that bright specifically, but if she opens the door, she can totally just look in and go, is the mic lit?
01:46 And if the mic's not lit, she knows she's not going to be heard or be directly interrupting me, and I can just turn and answer any questions she has.
01:53 And it's awesome.
01:54 It works out great that way.
01:55 That is so fantastic.
01:56 The whole mic glows when it's on and active.
01:59 Different colors.
02:00 It's beautiful.
02:00 I love it.
02:01 Yeah, and you can even change which colors it uses.
02:03 I can't remember if it's waterfall or not, but you can actually change how the color spectrum changes from side to side in terms of colors and whether it's top to bottom or not.
02:11 It's very pretty.
02:12 I think I once did Harry Potter color theme for a co-worker of mine who's a big Harry Potter fan for all the houses.
02:17 And I've purposely not played with it and kept with the defaults because it's definitely one of those things I could totally nerd out on and play with the colors all day long.
02:25 I tried Python colors once.
02:26 The transitions didn't look quite as nice, but, you know.
02:29 Yeah, no, it's good.
02:29 I have the microphone that matches.
02:31 I'm sorry, the mouse that matches it.
02:33 Oh, nice.
02:33 And it pulses.
02:34 So, I didn't get it for the color, but it's the only one I could get that had color.
02:38 I'm like, why is it of color?
02:39 How do I turn this off?
02:40 But no, it just has color.
02:41 It's fine.
02:41 But anyway, great mic.
02:42 I think people should check that out if they have like weird work from home situations and people are interrupting.
02:48 It's super cool.
02:49 I love it.
02:49 Definitely get a mic stand, though.
02:51 The default stand is a little low.
02:53 And I have found that getting a cheap, like $10, $15 stand.
02:57 I got this from Amazon that pushes it off about seven inches, I think.
03:02 I'm trying to do the American units.
03:03 It pushes up about 15 centimeters.
03:06 Perfect.
03:06 It's a nice sweet spot in terms of distance while it's still not completely taking up your vision in the screen.
03:11 Yeah, excellent.
03:12 Excellent.
03:13 Well, Brian, you want to kick us off here with our first topic?
03:15 Yeah.
03:16 Well, we've got – it's hard to keep up with Will McCoogan.
03:21 Sorry, Will.
03:22 Will wrote Rich, which is a – I forget what he calls it.
03:28 Basically, it's a CLI tool.
03:29 But there's been a whole bunch of really cool things he's done recently, like really recently.
03:35 So in December, he added Live View, which allows you to just – it continually updates whenever an event happens or something in that part of the screen, which is cool.
03:47 He didn't write a blog post on that.
03:50 But then in January, Tree View came out.
03:53 And the Tree Views are lovely.
03:56 You can do all sorts of stuff with the Tree View.
03:59 And yeah, it's a nice thing to have in a CLI tool.
04:04 And then what's really impressive to me, I think, was layouts.
04:09 So this month, he released layouts.
04:12 And it allows you to split the screen up.
04:16 And his demo even shows it happening within a VS Code.
04:22 Oh, yeah.
04:25 Within the bottom.
04:26 Yeah.
04:27 Terminal part of VS Code.
04:28 Yeah.
04:29 Brett, you've heard of this, right?
04:30 You've heard of this tool?
04:31 How can I not?
04:32 I'm a fan of the podcast.
04:33 And Brian loves this tool.
04:35 So I've heard about it multiple times.
04:36 So I guess we've covered it before.
04:40 But one of the reasons why I'm covering it again, there's a couple of reasons, is the layout's neat.
04:45 And really, now I want to click on stuff and I want to do entry.
04:49 And he sort of hinted at that, that he's kind of going towards a full TUI, which I had never heard of before.
04:56 Text user interface.
04:57 Yeah, TUIs.
04:58 All right.
04:58 Right on.
04:59 That'd be cool.
05:00 So I think that would be neat.
05:01 And I'd like to encourage that.
05:03 So the other thing that's going on with Rich is he's accepting sponsorships now.
05:08 And it's kind of hidden in the demo window.
05:11 But we're highlighting it on the show so more people can know about it.
05:17 So on GitHub, he's doing sponsorships on GitHub.
05:20 And I like how GitHub sponsorships work.
05:22 It's kind of neat.
05:24 So check it out.
05:25 The other thing that I guess when I was playing with these layout things that I didn't really realize before is you can just say Python-mrich.
05:33 And it shows a little demo of a whole bunch of stuff.
05:36 And then some of the particular parts of it, you can demo them individually.
05:41 Like for the layout, you can say Python-mrich.layout.
05:45 And it'll show a demo.
05:48 That's cool.
05:48 The tree is also as a demo.
05:50 And the live one, actually, I couldn't escape it.
05:54 I had to kill my window.
05:55 So the live one just continually updates some, like, I think it does.
06:00 I don't know if it's actually going out to the internet.
06:03 But it's doing some, like, conversions of monetary conversions.
06:08 And it just kept updating.
06:10 And it doesn't hit Control-C.
06:12 So it's got a bear except somewhere they shouldn't have.
06:16 I think it's very reliable.
06:17 I mean, the only way to exit it is forced quit.
06:19 So we're all...
06:21 Kill Dash 9.
06:21 Where's your friend?
06:23 So, yeah.
06:25 I'd love to have Rich continue with this and make it a full 2E.
06:30 That would be fun.
06:31 That would be very cool.
06:32 Because the presentation is really nice here.
06:34 I will also fully support Will making this a full-on thing.
06:37 Because actually, a couple months ago, I did a slight dive on a weekend trying to find some 2E libraries.
06:44 Because I have a personal project for work purposes that I've been trying to do a GUI for.
06:49 And two years in a row, I've tried to do it during hackathon week at Microsoft.
06:54 And I keep failing because I don't have enough time to dive into all the GUI libraries that go from, like, here's how to do Hello World.
07:00 Here's the reference.
07:01 And it's like, no, no.
07:02 I need more steps there.
07:04 Where's that middle ground?
07:06 Come on.
07:07 Yeah, exactly.
07:07 And then I decided, oh, well, I totally could just do this in Curses.
07:11 It's like, it's literally just to keep track of what I do every day.
07:13 And it's just like, it's snippets from Google is where I picked up the habit of just literally just, oh, I did this today.
07:19 That was out of ordinary.
07:20 I did this today.
07:21 That was out of ordinary.
07:22 Just to kind of track the high level, not just meanings, but I actually did something different today.
07:26 And it's like, oh, I could totally do this in the terminals.
07:29 Like, suddenly pull up in Curses library.
07:32 It's in the Snare library.
07:33 And it's like, oh, yes, you need to know the size of your terminal window and all this other stuff.
07:36 And, oh, how to move the cursor to this specific position.
07:38 It's like, yeah, no, I still don't have time for this.
07:40 So if we're trying to move this along and make input work, I mean, I would be totally down for giving it a shot.
07:47 Yeah.
07:48 Yeah, quite cool.
07:49 And if people don't know, you kind of live an alter ego.
07:52 You've got Brett Cannon Open Source Steering Council and also work closely with VS Code at Microsoft, right?
08:00 So having the screenshot on the screen is right at home.
08:04 Yeah, yeah.
08:05 Just for people who don't know, I'm the dev manager for the Python extension for VS Code.
08:10 That's how I pay for my open source habit, which includes being on the Python Steering Council and the core dev.
08:17 Yeah, yeah, quite cool.
08:18 So Gandalfor says, I've been using Prompt Toolkit for the Tui library for a while, but this rich seems a lot nicer if it actually accepted input, which I agree.
08:29 It seems very cool.
08:30 And I've heard some people using them together.
08:31 I just don't know how to do that.
08:33 So if somebody wants to write a tutorial on how to use both rich and Prompt Toolkit together, that'd be cool.
08:39 Yeah, that would be cool, actually.
08:40 All right.
08:41 What I want to talk about is this article I ran across and some tools that I went to play with afterwards after reading it called 12 requests per second.
08:50 Sounds amazing, right?
08:53 So it's a realistic look at web frameworks and Python web frameworks.
08:58 So if you look out there, you'll hear things like, oh, we're getting 100,000 requests per second on UV loop with a single thread.
09:05 Or, you know, we've got Sanic doing 100,000 requests or even Jopronto up to 1.2 million requests per second, right?
09:14 Which is amazing.
09:14 And then a lot of these examples are doing like really not real type of work, right?
09:21 They're just doing some little tiny thing like, oh, here, let's add two numbers and tell you how fast we can do that.
09:26 So this article is more like, well, let's go through a real application and see what kind of performance you might expect.
09:34 So I thought it'd be fun to talk about this because it gives some people some things to think about.
09:39 You know, how can you compare your app to these types of quotes that people are getting and so on?
09:44 And would it be better to choose something like Jopronto or AIoHTP or FastAPI or something like that over, say, Flask or Django,
09:54 which don't have so much support for things like Async.
09:57 So I thought this was fun to go through and just kind of look at it.
09:59 They start out by profiling just sort of a Hello World app and they get, all right, well, Hello World's pretty good.
10:06 If you run Flask on CPython, you get some amount here.
10:11 Maybe it was 500 to 1,000.
10:14 You run it on PyPy.
10:16 They were able to get 3,000.
10:17 You run it.
10:18 And so that's just, you know, Flask run, right?
10:20 Which is not really the way you should probably be doing things.
10:23 You should be running on G Unicorn or MicroWisgi or something like that.
10:27 So if they ran the same thing on G Unicorn, right, it's up to like 12,000.
10:32 And you run it on, compare that against Sanic, you get, you know, Sanic was doing like 24,000 or something.
10:37 So these comparisons I thought would be fun for people.
10:39 You can go through, they've got a bunch of graphs that you can check out.
10:43 But then they write one that actually talks to a database doing database-y things.
10:46 And then let me get down to the numbers here, the bottom for that.
10:49 And they're like, okay, well, with this one, now we're running at, you know, quite a bit lower request per second.
10:55 And I think in the end they said for our real app, what we ended up with is a whopping like 12 requests per second.
11:02 Yeah, here we go.
11:02 Here's the graph I was looking for.
11:04 Where like, this is Flask running the synchronous Postgres driver there.
11:11 And that's all pretty interesting.
11:13 I think, you know, even be able to answer the question, you know, well, what about me?
11:17 What about my app?
11:18 How would it do if I were to run these things against it?
11:21 And we've talked about Locus before.
11:23 Locus is a really fantastic way to write load testing and user interaction testing against websites,
11:33 web APIs and so on.
11:34 And it's all about Python.
11:35 So what you do with this is you go through and you write some kind of class and you say, okay, here's a test,
11:40 like a representation of what people might do to my website.
11:45 They might log in.
11:46 They might go view the episode page.
11:48 If we were testing the Python Bytes site, they go check out the episode page.
11:51 They might drill into an episode.
11:52 They might do a search.
11:53 And what you can do is you write simple little bits of Python to say, here's a function that does this action.
12:00 Here's a function that does that action.
12:01 Like, here's one that goes to the episode listing.
12:03 And then you can actually, it's not shown in the example here, but you can say things like, well, you know, 10 out of 15 times, I want them to view an episode page.
12:12 One out of the 10 times, I want them to do a search.
12:14 And three out of the 10 times, I want them to actually go to the listing, right?
12:18 So you can sort of break it up to what the normal look would be.
12:21 Then you just run Locus and you get like this web UI where you enter some information.
12:27 And then it just runs, if you want, even in a distributed way against your site and then, you know, pounds it until it gives up, basically.
12:33 Brett, have you heard this tool?
12:35 No, I actually haven't.
12:37 I mean, you hear about different tools for different things, but this is pretty, looking at this example, it's pretty simple, which is pretty great.
12:44 Yeah, the simplicity is really great.
12:46 And then when you run it, you actually get a web view into it.
12:49 Then the web UI lets you basically control and monitor the tests in real time.
12:53 So anyway, coming back to some numbers off of that, I decided, well, if they're getting, you know, 12 to 80 requests per second, what does my stuff look like?
13:02 Like, for example, I talk to Python training stuff.
13:04 It's not using any of this async stuff.
13:07 How is it doing?
13:07 So it's Python 3, MicroWisgee, Pyramid, MongoDB on a $20 server.
13:12 Would it get 12 requests per second?
13:14 I don't know.
13:15 So I turned this thing loose and it'll do about 125 requests per second.
13:22 I felt better than, that's better than 12.
13:24 I felt pretty good.
13:25 But one of the things that's cool about Locus is you can tell it, not just, I want you to use this partitioning, but also I would like you to have a distribution of how often the user actually does something.
13:37 So you can say, well, this user is going to make between every 10 to 60 seconds, it's going to do one of these things among this mix.
13:45 So instead of just pounding it, it's like, well, an average user doesn't just hit F5 or control command R as hard as they can.
13:51 They move around and they pause, right?
13:53 So you can pause that.
13:54 So I don't know, maybe it's 10 to 20,000 realistic users I was able to sort of map out with this.
13:59 Anyway, it was just a fun deep dive into like, well, what does performance look like?
14:03 How important is async?
14:05 Some of the tools to do it.
14:07 I don't know.
14:07 If people are, if that's interesting, people definitely check out this 12 requests per second article here.
14:12 I think you'll enjoy it.
14:14 Then also check out Locus if you want to try to answer that question for yourself.
14:17 So I was curious how, when you're testing your site, did anybody else like experience downtime or something while you're being on it?
14:26 Well, so that's the question, right?
14:28 Like with the Locus thing, you can start to see what the like real time, what the response times are and everything.
14:34 It never crashed.
14:36 It just got a little bit slow.
14:37 So I was, you know, I ran it locally and I'm like, well, what's it look like in production, right?
14:41 So I'm like, I really want to know what with all the way that everything's put together, what number will I get?
14:47 So I'm like, I'm just going to turn it loose on it.
14:49 And if it starts to overwhelm it, I'll just hit the stop button, you know, and it never died.
14:52 It just got to where it took like three or 400 milliseconds to get back to me.
14:56 So it was okay.
14:56 Okay, good.
14:57 Yeah.
14:58 So pretty fun.
14:58 Pretty fun example there.
15:00 I think one other thing I appreciate about that blog post actually was they pointed out towards the end that at some point scaling is no longer a Python problem and it's an infrastructure problem.
15:08 Like, oh, it's probably better to update your database and stuff.
15:11 And I've heard this from a lot of people too.
15:14 There's kind of a misnomer if you're not in the Python community that, oh, Python's so slow, it's going to be your bottleneck.
15:20 And instead, I've heard it from a lot of people in the community that, oh, actually it's not.
15:23 I can get it done, get my work done a third of a time.
15:26 And then the two thirds of time it would have taken me to do it in, I don't know, Java, just choosing a language.
15:30 I can optimize my infrastructure.
15:32 And guess what?
15:33 I end up with the same performance with more time to bug fix and test than I would have in the other platform.
15:38 And the other thing is, is obviously there's, there is always throwing more hardware at the problem if you need to horizontally scale.
15:44 But, and honestly, I think when I say this post also, I think from our correctly pointed out, not everyone needs a thousand requests a second.
15:52 Most people don't.
15:54 Even popular websites are not doing a thousand.
15:57 I mean, that's a lot of requests.
15:59 A thousand requests a second.
16:00 That is a lot.
16:00 Like most people measure in queries per minute, not per second.
16:04 Right?
16:04 Yeah.
16:05 So like even 12 per second, like we're still talking 720, if my math is not finding me on the spot, requests per minute.
16:12 Right?
16:12 That's still a decent cliff.
16:14 Like if you're running a business that's getting that much traffic every single minute, you're probably still doing pretty good for yourself.
16:20 Yeah.
16:21 That's 32 million page views per month.
16:23 Right?
16:24 That's like you're at a limit where you've got some real stuff going on, some real infrastructure.
16:28 Well, okay.
16:29 So, but there's also, if I've got services running, I've got a bunch of services that include this.
16:34 So, I mean, one user interaction isn't one hit.
16:38 It might be dozens.
16:39 Yeah.
16:40 So, my rule of thumb is honestly, don't worry unless you're going over a hundred a second.
16:45 Like you should be able to hit a hundred a second without too much effort.
16:48 And after that, you might have to start doing some planning.
16:50 But I would suspect as a general rule of thumb, you can handle hundreds without a whole lot of effort in Python.
16:55 Yeah.
16:56 If you're getting to a thousand, you might have to do a bit more planning for it, but it's solely serviceable for that kind of thing.
17:01 Yeah.
17:01 Totally agree.
17:03 Magnus Carlson has a quick comment.
17:06 Nice.
17:06 So, I can now see if my work turning my FastAPI app into async was worth it.
17:12 Yes, you can.
17:13 That's a very good use of that.
17:15 I'm going to be biased and just say it was totally worth it, Magnus.
17:18 You just don't know yet.
17:19 Because it's got the cool new design patterns.
17:23 Absolutely.
17:23 Exactly.
17:24 All right, Brett, you're up next.
17:25 You've got something special for us.
17:27 Yeah.
17:28 Yeah.
17:28 So, the world exclusive news breaking thing is the Python launcher for Unix is probably at RC stage.
17:39 For those of you who don't know about this, it's a project I've been working on since May of 2018.
17:45 And if you're a Windows user, you probably know what I'm talking about.
17:49 But on Windows, there's a little app called the Python launcher for Windows.
17:54 And it ships with Python.
17:55 And it gives you the Py command.
17:56 So, sometimes you might see this on websites where they say, well, if you're on Windows, you run Python using PY.
18:01 And then the command and other platforms just run with Python 3.
18:05 And I decided that I kind of wanted this on Unix.
18:10 I had enough people complain to me about how it's difficult to get started.
18:14 We're having the Windows instructions on how to run something was always different from the Unix version and all this.
18:19 Yes.
18:20 That is really annoying.
18:21 The very first thing you got to do, like right at the start, like, oh, it's so easy.
18:24 But there's these two ways.
18:25 There's like this diversion, right?
18:27 Exactly.
18:28 And I saw some benefits of the Python launcher because what it does on Windows is it serves kind of two key purposes.
18:36 One is it kind of makes up for the lack of shebang support on Windows because the launcher will actually look for a shebang line,
18:44 figure out what version of Python is required, and then finds the right version of Python to run it.
18:48 The other thing is it does away with the need of caring about what order you installed your Pythons in.
18:54 Because, like, for instance, on Unix, like Python 3, what does that point at?
18:57 Well, what it points at is the last version of Python 3 that you installed, not the newest version of Python.
19:03 Yeah.
19:04 So if you installed 3.9 today, but then installed the 3.8 security release that I think happened yesterday, you will get 3.8 as your version for Python 3.
19:13 So if you don't specify Python 3.9, you won't be running it.
19:17 Like, you have to either create your virtual environment and be using it that way or remember that.
19:20 Python launcher takes care of all that.
19:22 It will automatically just figure out what versions you have installed and just automatically run the newest version.
19:27 And so I really like that.
19:29 So I decided to implement it in Rust, partially as a Rust project of decent size, and it's about a thousand lines of Rust code.
19:36 And also because I wanted it, because if this works out, hopefully some projects can stop listing two different ways to run things.
19:43 So in the Unix version, it's a little different from the Windows version, and I'll ask for feedback from the two of you and anyone in the live stream if they want to provide it.
19:52 First, it looks to see if a virtual environment is activated.
19:55 So it looks for the virtual under env environment variable, and if it's there, it just uses that.
19:59 So automatically, this is a little shorter and easier if you have an activated virtual environment.
20:04 It's just PY now instead of having to type Python.
20:06 The next one is if you have...
20:08 You're here to save us from RSI already.
20:10 I'm kidding, but this is really interesting.
20:12 Keep going.
20:13 Yeah.
20:13 One third the typing.
20:14 The other thing is if you create a virtual environment in a .venv directory, it will also automatically use that without activation.
20:24 So once again, if you use the, I personally think, standard nomenclature, naming your virtual environments .venv, you don't even have to activate them anymore.
20:34 Because activation is just a shorthand for the shell that, honestly, I typically just use to make Python do the right thing.
20:42 Because I use dashed m for everything, even when I'm in an activated environment.
20:46 This takes care of that entire step for me, so I don't have to activate my environments anymore.
20:49 That's super cool.
20:51 After that, it does the shebang, just like on Windows, trying to figure out what the right Python might be for that.
20:56 And then after that, it checks some environment variables.
20:58 Like if you want to, if you have 3.10 installed, for instance, for Python, you have an alpha installed.
21:02 But you want to make sure that if you ever say, hey, if I say Python, if I run Py with no arguments or say, hey, I want to run a Python 3 version of Python, you can actually set the environment variables to restrict it and basically specify the exact version you want.
21:16 And then after that, it just, if none of that triggers, it just finds the newest version and runs that.
21:20 I've been running this personally for a while.
21:22 And when I added the .venv support, I've completely switched.
21:28 I don't even bother typing Python anymore because this completely fits my workflow of just doing exactly what I think it should do whenever I need.
21:36 Now, the question I have for the two of you and anyone in the audience who cares to answer is, do you think prioritizing virtual environments over shebangs makes sense?
21:44 Now, my argument is yes, obviously, or else I would have done it this way.
21:48 But this is partially, I don't know how much of this is a Unixism versus just in general, because I do hope to actually add Windows support to this as well and make this a universal Python launcher.
21:58 So the reason I did it this way was on Unix, you can just chmod a file and add the executable bit.
22:04 And that's how you can execute it.
22:05 And honestly, most of my files at this point are going to be in a virtual environment anyway, whether it's sold via PipX or I create an entry point and I install that.
22:13 So once again, I don't need the shebang directly.
22:16 It's just going to be baked into the executable and Windows will do the exact same thing, right?
22:21 Like set of tools will give you that little shim.
22:22 So to me, if I am running in a project directory with a virtual environment, whether activated or not, I'm assuming that's what I want.
22:30 Don't try to figure it out for me or else I'd be running this somewhere else and I would not have a virtual environment installed.
22:36 Does that logic make sense?
22:37 Do people do you think I made the right decision here and choosing virtual environments over shebang lines or am I crazy?
22:43 I forgot shebangs were even supported.
22:45 I'm all about virtual environments.
22:47 Yes.
22:48 Okay, cool.
22:49 I think this is fantastic.
22:50 I've long wanted an easy way to just say I'm down inside.
22:56 Maybe you can tell me if it works this way.
22:58 Does it traverse up looking for a virtual environment?
23:01 Like if I'm in a subdirectory and I try to pie a file, but one directory up, there's a virtual environment.
23:08 Will it go up and find that and then use it?
23:10 No, I did not implement it that way.
23:11 It would not be too difficult to do it that way.
23:14 But for simplicity reasons, when I first plugged this in, for my purposes, I'm not an SRC guy like Brian is, for instance.
23:21 So I don't need to worry about that as much.
23:24 But that would be totally reasonable feature request to ask for to be able to traverse up a directory who's looking for the .vnv directory.
23:31 Yeah, very cool.
23:32 I'm down a level in my SRC.
23:34 Go up a level to find the actual.
23:36 Right, like I have a lot of things that will do like maintenance for my website.
23:40 So I'll have like a bin folder as one of the subfolders of my website.
23:44 Then I'll go in there and I want to run something.
23:46 If I'm like, oh, I should have run and gone up and then bin slash.
23:49 I think it'd just be really cool.
23:50 Like I'm sort of in the realm of this virtual environment, even if it's not at the same working directory.
23:56 Yeah, and one thing I do want to clarify here is this is very much about simplifying running Python manually.
24:01 It is not meant to completely replace running Python, right?
24:05 Like a misnomer I hear from people when I tell them about this is like, oh, hey, are you going to add a config file to be able to alias to PyPy versus specifically or this thing or a framework builder that thing is.
24:16 And for me is if you have that kind of specific requirement of a specific version of Python you have installed, just use the absolute paths of that version of Python.
24:25 Yeah, I don't think this is this is purely for I just want the newest version.
24:28 I don't care what it is.
24:30 Just give it to me or I have a virtual environment.
24:32 Just give me the virtual environment.
24:34 I don't want to have to think about it.
24:35 If you have to put thought into what kind of Python you want to run, I think you should be specifying that manually, not be using this.
24:41 Well, so on the side of the being able to go up a couple directories looking for virtual environments, I'm often not in the source directory.
24:50 I'm often sitting in the tests directory running pytest on stuff, in which case, I guess I already am in a virtual environment.
24:58 So it doesn't matter.
24:59 But I might just open up another terminal and try to just run Python.
25:06 So I like this.
25:07 I'm excited to hear that this is eventually going to be a Windows thing also, hopefully.
25:12 I don't actually normally use the Python launcher on Windows.
25:16 Does it?
25:17 It doesn't do looking for virtual environments, does it?
25:20 No, that's exclusive.
25:21 That is exclusive to the Unix version of this launcher.
25:25 So basically, the environment variable it will use, it doesn't actually look on path.
25:31 It completely uses the Windows registry.
25:32 It does the shebang.
25:34 And that's it.
25:35 So looking in the .venv folder, that is entirely my addition.
25:40 And the order of execution here is kind of tweaked to what I think.
25:46 And it doesn't search on path, actually.
25:48 So that's a Unix thing specifically.
25:50 But I suspect this will actually help with the Windows Store, although I think Steve Dower fixed that issue with the Windows Store install.
25:56 But yeah, so there's slight tweaks.
25:59 But I figure if I have all the logic done already, there's no reason not to just make it universal to support multiple platforms.
26:05 So why not?
26:06 Yeah.
26:07 So your announcement here has kind of lit up the live stream.
26:11 So ZDocs is just a Brett Cannon fan, which is awesome.
26:15 So Gendal Forth asks, is the Rust version cross-platform in any way?
26:21 Is there a chance of this on Windows?
26:22 No, I don't.
26:25 I've not tried it on Windows.
26:26 It definitely works on Mac and Linux, right?
26:29 So it truly is Unix-based.
26:31 So it will handle that no problem.
26:33 I've not tried to wire it up into the registry at all.
26:37 So that's not there.
26:37 I have an open enhancement issue to do that.
26:40 I honestly don't know what would happen if you tried running this on Windows.
26:43 I haven't tried.
26:45 Everything's very hard-coded to Unix at the moment, just to get this done.
26:48 If you look at the readme, you'll notice everything is slash bin.
26:52 Slash user slash bin, yeah.
26:54 There's no scripts support here.
26:57 If slash one, I do Windows support.
27:00 Obviously, I'll look at fix.
27:01 But I have tried putting zero effort.
27:03 Because the Python launcher for Windows just comes with the install from Python.org, right?
27:07 So there was no real time pressure to try to get that done.
27:09 So I haven't tried it.
27:11 I'm a big fan.
27:11 I could try this on my macOS and I'd be happy now.
27:14 Yeah.
27:14 This is how I do it.
27:16 I have it on my Mac.
27:16 I just installed.
27:17 You do have to install Rust to install it right now.
27:19 Because I haven't figured out how to do distributable binaries that you can just download.
27:24 But yeah, if you have Rust installed, which you can get through Rust up or Homebrew or whatever,
27:28 it's just a cargo install away.
27:30 So if you want to get a shot, please do so.
27:32 Fantastic.
27:32 And then I kind of forgot that my Mac was Unix-y.
27:36 That's right.
27:38 And Magnus agrees on the VNV over shebang.
27:41 Awesome.
27:42 And Gandalfor says same as well.
27:44 I don't think I've ever seen a shebang that was more specific than user bin Python 3 anyway.
27:48 Yeah.
27:49 And I actually suspect the shebang support was partially because the Python launcher has been
27:52 around back in Python 2 days, right?
27:55 Where that was much more of a concern.
27:56 So like, as I said, I started this in 2018.
27:58 So it was pre-Python 2 deprecation.
28:01 So it's still supported there.
28:03 But a lot of this, I think, was also partially to support the 2 to 3 transition.
28:07 So those little extras here, I don't think are quite as important unless Python 4 happens
28:12 someday, which there are zero plans for.
28:14 So I don't think so.
28:15 Yeah.
28:15 Don't hold your breath.
28:16 By the way, one extra nicety I want to tell people is if you're a Starship user, the Starship
28:23 cross shell prompt, there's a setting in Starship that lets you specify how it figures out what
28:31 version of Python you have.
28:32 Now, it does look for virtualenv, but otherwise it has a list of binaries that it will execute
28:36 to try to figure out what version of Python you have.
28:39 If you set it to Py using this, it will always tell you either what the virtual environment's
28:44 Python version is in the prompt or whatever the newest version of Python is installed.
28:48 So it has a really nice side effect.
28:50 Because if you read the docs in Starship, there's a big tip saying, hey, if you have
28:54 a Python installed that's default, i.e.
28:56 macOS, and it'll always say 2.7 unless you happen to have an activated virtual environment,
29:01 which always threw me because it's like, yeah, I'm not using 2.7 in this project.
29:04 As soon as I added this support for .venv files and tweaked my Starship config for this,
29:09 it always tells me the exact version that I happen to have set up for my virtual environment.
29:14 It's really handy.
29:15 For those of us not in the know, what's Starship?
29:17 So Starship is a cross-platform shell prompt tool.
29:22 So it's written in Rust.
29:24 But basically what you do is it has instructions for Bash and Zeesh and Phish and PowerShell and
29:29 everything else.
29:30 And basically it just gives you a line.
29:31 Brian's got it pulled up on the screen for those on the live stream.
29:36 And it's basically just an easy way to just say like, hey, this is how I want my prompt
29:40 to look.
29:40 Don't worry about whether it being Bash or Zeesh or Phish, whatever.
29:43 Like I'm a Phish user.
29:44 I'm sure Michael's probably a Zeesh user being a macOS user like he is.
29:48 Yep.
29:48 But it shouldn't matter.
29:50 My prompt is a prompt.
29:51 And pretty much they have pretty consistent user support.
29:55 So I decided, yeah, you know what?
29:57 I like some of the niceties it has automatically baked in.
30:00 It does like notification, it changes prompt for the usual, oh, I edited my Git checkout.
30:06 It'll tell you what branch you're on.
30:07 All these little nice things.
30:08 And setting fear code as my font gives me all the nice little glyphs that I want.
30:13 And so I said, nice.
30:14 All right, cool.
30:14 It'll tell me what version of Python is currently activated.
30:17 Except for that annoyance of being on Mac.
30:20 It kept saying, oh, you've got 2.7 until I activated.
30:22 And I was like, no, I don't like this.
30:24 So I prioritized getting the .vnv done.
30:26 And then lo and behold, it magically now tells me exactly what I want for Python.
30:30 Nice.
30:31 Wow, that's super cool.
30:32 Yeah, now we know.
30:33 Starship, fantastic.
30:34 Yeah, so before we move on, I'd like to thank our sponsor.
30:39 So this episode of Python Bytes is brought to you by Datadog.
30:43 Are you having trouble visualizing latency, CPU, and memory bottlenecks in your apps?
30:47 And not sure where the issue is coming from or how to solve it?
30:51 Datadog seamlessly correlates logs and traces at the level of individual requests
30:56 allowing you to quickly troubleshoot your Python application.
30:59 Plus, their continuous profiler allows you to find most resource-consuming parts
31:05 in your production code all the time at any scale with minimal overhead.
31:09 Be the hero that got your app back on track at your company.
31:13 Get started today with a free trial at pythonbytes.fm/Datadog or just click the link in your podcast player show notes.
31:22 Ooh, that's neat.
31:22 Yeah, very cool.
31:23 Thanks, Datadog.
31:24 So, Brett, I want to take you down a little bit lower.
31:28 If it's turtles all the way down, a few turtles down to this whole TUI world
31:32 and talk about this thing called build a text editor with Python and curses.
31:36 Is curses, is that what you do when you get upset because it's too low level?
31:40 Or, oh, no, it's about the curses.
31:42 Sorry.
31:43 Okay.
31:43 Got to remember, I'm on the Python Bytes podcast.
31:45 There are going to be jokes like that.
31:46 They're going to be bad, too, by the way.
31:48 So, no, here's a really cool article by Wasim Lorgat about basically walking you through building
31:56 a text editor like Vim or Emacs in the terminal using curses, which is a library that lets you
32:02 control what happens on the screen much better than, like, print and log and warn and whatnot.
32:07 So, there's a couple of just interesting things.
32:09 I thought going through this might just give people a sense of, like, what it's like to
32:12 work with curses.
32:13 And then there's this context of this text editor you can play with.
32:16 So, for example, a minimal curses app, all you got to do is define a function.
32:20 That's your main function.
32:21 And then while true, go to the screen and get the key.
32:25 And that's it.
32:25 You just say get key.
32:26 And it just gives you whatever gets pressed.
32:28 Without any help here, there's probably not a way to get out of it.
32:31 No.
32:32 Maybe control C.
32:34 But, yeah, there's not, like, a quit or anything.
32:36 So, you can really easily add, like, some tests and say, well, if they gave me the key,
32:41 you know, escape, then show the little colon.
32:43 You can WQ, exclamation mark, whatever, to get out of it.
32:46 However you want to exit your text editor that you're building.
32:50 And then they talk about how to show stuff on the screen.
32:53 So, if you want to just add a line, you can say, at this X, Y screen, you know,
32:58 cursor location, just write this line of text on the screen.
33:02 And it'll add that.
33:04 So, really easy.
33:04 And, you know, one of the things they do is they pass over the file name.
33:08 And it's kind of meta.
33:09 Like, they edit the file that is the demo for the editor with the editor as they're building it,
33:14 which is always fun to do.
33:15 So, you can do that.
33:17 But then, through this article, they go through and they build out, like, a window class
33:22 that talks about how big is the screen.
33:24 This is what Brett was talking about.
33:26 Like, ah, I got to figure out what my screen looks like and all that stuff.
33:28 And also, a cursor where you are on the screen.
33:31 How to have, like, a view into the file.
33:34 Because you might have, like, moved to the right a little bit.
33:37 And the file might be a thousand lines.
33:38 But you've only got a 40 on your screen or whatever.
33:41 So, anyway, if this is interesting to you, I think you should go through this article and check it out.
33:45 In the end, you end up with a pretty simple but non-trivial little text editor
33:49 that lets you do stuff.
33:50 So, I think it's pretty neat.
33:51 What do you guys think?
33:52 This shows me why I really hope Will grants Brian's wish of making Rich a full TY library.
33:58 Yeah.
33:59 I do agree.
34:00 I think if Rich, if something like that that has a really beautiful display technology,
34:04 but also has input.
34:06 Like, this is cool because it has a really great way to accept user input
34:09 and, like, update the screen.
34:10 But it's very low level.
34:12 It's like, I don't know, it's OpenGL versus Pi game or arcade.
34:16 You're, like, at the level of, here's what I put at this cursor, this XY coordinate.
34:20 Let's put that there.
34:21 Yeah.
34:22 I think it's a great showing of actually how much work it actually needs to go into making
34:26 those full text-based UIs that you see, like you used to see at the grocery store and those
34:31 screen, you probably still do at some of your grocery stores on that screen and just like,
34:34 or when they book your airline ticket and you're like, oh my God, what the hell are you using?
34:38 You do this all day?
34:39 Yeah, exactly.
34:40 It takes a lot of work to make those things happen.
34:43 It's surprising how much work it is and hence why getting higher level libraries like,
34:48 I think, that was the prompt toolkit we were told about earlier and Rich and all that would
34:52 be very welcome in existing.
34:55 Yeah, absolutely.
34:56 Do you got, either of you guys know if there's any curses libraries for Windows?
34:59 Magnus is asking.
35:01 That's why he's used prompt toolkit before, but I'm not sure actually.
35:05 Neither am I.
35:05 Yeah.
35:06 Yeah.
35:06 Cool, cool.
35:07 All right.
35:08 What's the next one?
35:09 Brian, you got the next one, right?
35:11 Actually, I skipped.
35:12 So, Brett's next.
35:14 All right, Brett's next and I'll pull up Brett's thing.
35:16 All right, Brett.
35:16 Okay.
35:17 So, there's been a major language feature announced that is coming in 3.10, right?
35:23 Yes, which actually was in your quick links at the end of episode 220, which Brian called
35:30 the five-barrel foot gun, which is pattern matching.
35:34 So, one of the things that always happens whenever there's a new Python feature that gets announced,
35:41 and especially one of this size that gets out into the general community, is some interesting
35:46 feelings from people.
35:47 And so, this is kind of slash, I don't want to say rant, but a little just me as a steering
35:54 council member just trying to explain how this all came about, where we're coming from as
35:59 a steering council in general.
36:01 I mean, obviously, I'm speaking for me directly, but generally, I think how the steering council
36:06 kind of thought.
36:06 But also, just kind of helping put all this in perspective, because I think for a lot of
36:10 people, this might be the first big feature that they've seen, because we used to do this
36:13 all the time in Python 2.
36:15 But things kind of slowed down for Python 3.
36:17 So, as I said, I've seen around the internet a lot of people ranging from, oh, this looks really cool.
36:22 I can't wait till I can use it, to people screaming bloody murder that we're killing Python.
36:26 And oh my God, it's the death knell of the language.
36:29 I've been doing this for 17 years.
36:30 Is it stressful for you?
36:31 Because it used to be?
36:33 It used to be stressful.
36:35 Now, it's just frustrating.
36:36 So, for instance, I gave a talk at PyCon US 2018.
36:40 It was one of the keynotes about participating in open source.
36:43 And one of the key things I said in it was people just need to try to be kind to each other.
36:47 It's kind of a very generic thing, I know.
36:50 But it really makes a difference.
36:52 As a project maintainer myself, having people tell me what they think I need to be doing or what
36:58 I should be doing is really frustrating, right?
37:01 Like, I put my personal time and effort into helping make this happen.
37:04 And the way you respond to that is telling me what I should be doing.
37:09 Yeah.
37:10 Like, I can only imagine people who are parents having other people tell them how they should
37:15 be raising their children.
37:16 It's worse than helicopter parents.
37:18 It's like helicopter backseat parenting.
37:20 Exactly.
37:21 And it's kind of the equivalent for open source maintainers.
37:25 People doing the backseat.
37:27 Oh, here's what you really should be doing with your free time, with what little time
37:31 you have left on this planet, right?
37:33 Yeah.
37:33 So it used to get really upsetting.
37:37 And now I'm just frustrated and just disappointed that this still happens.
37:41 It's also a little weird, too, because in Python, right?
37:44 I mean, we have tens of millions of people using language at this point, right?
37:47 It's immeasurable.
37:48 It's just cute.
37:50 Which means even if you assume one out of a thousand people are jerks, right?
37:54 0.1%.
37:55 Let's do 0.01%, right?
37:57 Like, we're still talking tens of thousands of people out there who basically know my face,
38:01 name, and address and feel totally fine sending me mail on occasion or just posting out in the
38:07 comments outside where we all congregate about what they think I should be doing with my life.
38:13 So it's one of these things where it's just frustrating.
38:17 I don't know how a lot of people feel about it.
38:20 Sorry.
38:20 But I think when you hear those negative things said to you, even if a thousand people are
38:24 appreciative, the one negative thing you get feels so much.
38:28 It makes such a bigger disproportionate impact.
38:31 Yeah, at least.
38:32 At least.
38:32 At least.
38:33 And the problem is it's not relative numbers.
38:35 It's absolute numbers.
38:36 And at the scale that we're at with Python, the absolute number of people who just don't
38:40 haven't quite either just, I mean, honestly, some people are just totally ignorant that they
38:44 are speaking this way and that they don't really realize the way they're phrasing things matters
38:48 or even that the way they're phrasing it comes off that way.
38:51 Like not everyone who says should really means for it to come off that way.
38:53 Thank you, Dean.
38:54 I appreciate the awesomeness call out.
38:57 But it's one of these things where I have to bring this up every couple of years.
39:03 And then I usually end up doing a blog post, which honestly, this is kind of a rough draft
39:06 of the blog post.
39:07 I'm just talking out loud with all of you.
39:08 Yeah.
39:09 And bouncing ideas off all of you for the feedback.
39:12 But it's just it gets a little exhausting that this is something I have to bring up every
39:17 couple of years.
39:17 You'd hope that we'd all learn this by now.
39:20 It's not like open source is a new newfangled thing we've all just discovered.
39:23 But there's still this disconnect between the consumer slash user slash takers of open
39:28 source versus the maintainer slash producer slash givers of the community.
39:33 And the disconnect of how to kind of just communicate with each other is still there.
39:37 And so specifically when it comes to this stuff with Python, right, is people go like, oh, my
39:42 God, this is crazy.
39:43 And it's like, no, it's not.
39:45 I've been doing this for 17 years.
39:47 Everything is controversial when it comes to syntax.
39:49 True and false were controversial, right?
39:51 Like true and false.
39:53 There were arguments on Python dev and whether or not we should add those keywords because
39:56 they would break code that chose to define those constants as one and zero.
40:01 Is that why it's capital T?
40:03 Well, it's also because they're singletons, right?
40:05 And that's just kind of the practice we follow with none.
40:07 So that was really kind of where it tied in.
40:09 I mean, it definitely helped that capital T lower the chance.
40:13 It's less likely.
40:14 Yeah, exactly.
40:15 It's less likely.
40:15 But that was an actual discussion we had was do we want to add booleans to the language?
40:20 Now, today, everyone scoffs at that and laughs.
40:23 Like, what?
40:23 Are you kidding me?
40:24 Booleans?
40:25 Really?
40:25 Everything in the language gets debated, right?
40:28 And in this too, right?
40:29 Like everyone's going like, oh, my God, what are you doing?
40:31 Like, do you understand the timeline of this?
40:33 Guido brought this up, I think, in July, maybe?
40:37 And had as one pep, got a massive amount of feedback on Python dev on this, went back with
40:43 his co-authors, broke it up into three peps, 634, 635, and 636, so that there was a pep
40:49 about the design, a PEP about the rationale behind the design, and a PEP that acts as
40:52 a tutorial to try to make it more easy to consume.
40:55 Brought that out in October.
40:57 We discussed it on Steering Council 2020.
41:00 We made a recommendation that probably the next one should accept it, but we still didn't
41:04 feel we had enough time to accept such a large thing.
41:06 Fast forward now to today, where Steering Council 2021 had a chance to sit down and look
41:10 at the recommendation and the peps and have a discussion, including calling Guido in personally
41:14 at least two times to talk directly to the Steering Council to help us understand where
41:19 he was coming from.
41:19 Like, this was not a snap decision, but everyone acts like it was.
41:23 Right.
41:23 This is literally taking over half.
41:24 It finally appears on their radar, and they're like, oh, where'd this come from?
41:27 Exactly.
41:27 Oh, it's like on Hacker News today.
41:29 Suddenly it happened.
41:30 Like, no, no, no.
41:30 This has been happening.
41:31 This has been in discussion actively in public for six months.
41:35 I first heard Guido talking with someone at a language summit in 2018 about the idea of
41:40 pattern matching.
41:40 Like, this has been on people's radar as something people have wanted for that long.
41:44 And I'll fully admit I wanted it.
41:46 Like, pattern matching is something I've wanted for a long time.
41:48 But it's just one of these things, once again, people just don't stop and think about the
41:52 time and effort that go into all this behind the scenes.
41:55 It's just, in my worldview, this just happened versus, oh, there's probably stuff that happened
42:00 that I'm just not aware of.
42:02 And specifically about this, one thing I always notice about this is people need to understand
42:06 the way the language is designed, right?
42:08 Like, we aim to increase your productivity.
42:10 Now, that means different things to different people.
42:12 But in general, it means keeping a language that's easy to understand and small enough to
42:16 have in your head, but also leads to you being more productive, which also means readability,
42:21 right?
42:21 There's a lot of side effects that we all appreciate that come with productivity, but that's
42:26 really the ultimate goal to me.
42:27 It's not that the language is readable.
42:29 Readable makes you productive.
42:31 And for pattern matching, there are certain algorithms that are just really difficult
42:34 to do without pattern matching, right?
42:36 Like the classic examples are parsers and compilers.
42:38 And they're not easy to do without having pattern matching.
42:42 There's a reason why functional programming languages that have had pattern matching for
42:45 a very long time are the best places right now to typically write a parser or compiler because
42:51 it just, the algorithm just works so much better that way.
42:54 So there were reasons why we brought this in.
42:56 There will be increases in productivity for some people.
42:58 We do realize that it is a big lift, but we also realize not everyone's going to see this
43:02 day one, right?
43:03 This is not, it is way more than a switch statement, which I know a lot of people typically look at
43:08 it as, right?
43:09 But the key point is it matches on structure.
43:11 It's not a mat.
43:12 It's not matching necessarily just on value, right?
43:14 This is the big difference between an if statement versus not.
43:17 And so there was a lot of work behind this.
43:19 So there are reasons.
43:21 Like this was not major.
43:22 The other thing I keep seeing about this is people going, oh, this is not Pythonic.
43:26 Well, I hate to break it to people.
43:27 Well, it is now.
43:29 Yeah, I hate to break it to people, but Guido Van Rossum, the creator of Python, and that's
43:33 probably the harbinger of what is Pythonic, is a co-author and a big pusher of this pep,
43:37 right?
43:38 Like Guido helped make this happen.
43:39 So unless you want to go up to him at PyCon and tell Guido that he doesn't know what's Pythonic
43:44 or what's not, I think we kind of just have to go with it that this is now what is considered
43:47 Pythonic.
43:47 And I will say, I have seen people say, oh my God, this is what happens when we lose the
43:52 BDFL.
43:52 Like the person who was the BDFL made this happen, right?
43:56 Yeah, it's not that.
43:57 It's not a really funny disconnect with people.
43:59 Like Guido drove this.
44:02 Like Guido talked to the steering council about this.
44:04 Like he was the point person for this.
44:06 Like he really helped make this happen.
44:07 So it's as Pythonic as it can be if you consider Guido the creator and head person in terms of
44:13 the design of the language, which I will fully admit I still do.
44:15 I kind of view Guido no longer as being BDFL.
44:18 It's kind of, he relinquished bureaucratic overhead costs in his life of the language.
44:23 And the steering council has more or less taken that on.
44:24 But I still trust Guido's gut more or less.
44:27 Like if he really went off the rails, we'd stop him.
44:29 But I don't think this is him going off the rails.
44:30 I think this is us going like, he's that one step ahead of us.
44:34 Yeah.
44:35 And Echelion says, I just wrote a horrible if LF statement and he's looking forward to pattern
44:40 matching.
44:41 Yeah.
44:41 I mean, there are some real places where I think there's going to be benefits to ways to structure
44:46 things that will just make things look better.
44:49 Yeah.
44:49 And Magnus says, agrees with me, that Python's full spectrum language and it just extends
44:54 that spectrum.
44:54 Yeah.
44:55 Right.
44:56 Yeah.
44:56 Yeah.
44:56 Thanks for that, Magnus.
44:57 It's one of these things I think some people lose track of that being beginner friendly does
45:02 not mean only for beginners.
45:04 And that's where this productivity thing comes in.
45:07 I think that's actually a huge part of Python's success, right?
45:10 Visual Basic 6 was awesome for beginners, for example.
45:13 But it just stopped.
45:14 Like, well, you can't do that here.
45:16 You're at the limit.
45:17 I'm sorry.
45:18 No, I don't want to be at the limit.
45:19 I want to learn C++.
45:20 Don't make me.
45:21 Hey, if you want to be beginner friendly, go code and scratch.
45:23 Right?
45:24 Yeah.
45:24 No one wants the right production code and scratch.
45:26 It's great to get going, but there's a limit.
45:28 Yeah.
45:29 One of the, one of the great quotes that I've heard that I think applies to Python is that
45:34 you can, you can do easy things simply, but you can do difficult, difficult things are
45:39 possible.
45:39 And I know I got that quote wrong, but it's definitely close enough that I'll just go with
45:43 it.
45:43 Like that is very true.
45:46 Like that is the goal here is to make the common things easy and simple.
45:51 And make, and definitely approachable and make the hard things at least possible.
45:55 And this is part of it.
45:56 This opens up the possibility for things that were really difficult to do in Python before
45:59 it.
46:00 Yeah.
46:00 Fantastic.
46:00 So, yeah.
46:01 So I'm thinking of doing a blog post about this whole rant called the social contract of
46:05 open source to try to harp on this whole shoot versus need.
46:07 And just, it's okay.
46:09 It's, it's, it, I start to criticism is totally acceptable.
46:12 It's just be understanding about how you're delivering it because we're all on the internet.
46:16 We do here and they indirectly you will suffer because guess what?
46:20 That project you're using is going to then suffer based on what you say.
46:23 So it does matter.
46:24 Yeah.
46:24 And just one aside, I think last podcast, Michael said this was influenced from Haskell is actually
46:31 the design comes a lot from Scala specifically for this.
46:35 But we got this comprehensions from Scala.
46:38 So we have actually gotten some nice things out of Scala.
46:41 Interesting.
46:41 Yeah.
46:41 Okay.
46:42 Very interesting.
46:43 Yeah.
46:43 Yeah.
46:44 I mean, my feeling is it's, it's a big step.
46:46 I think it's going to take some, take a while to really see the value of it.
46:51 If you're not working directly in a place where it's one of these algorithms that applies
46:56 a lot, but I think it'll be good.
46:58 Yeah.
46:58 It's definitely one of those things that when you see it for the first time, if you, if you're
47:01 not used to using like a language, like most functional languages that have pattern matching,
47:05 it just goes like, what?
47:07 Why?
47:07 Yeah.
47:07 And then when, when you get exposed to it, when you start to use it more, it starts much
47:11 like learning another programming language.
47:12 It starts to tweak your approach to certain algorithms and stuff.
47:15 And it's just, it's another tool in your toolbox.
47:17 Really?
47:17 Nice.
47:18 Well, Brian, you've got the follow-up, huh?
47:20 Yeah.
47:21 So I'm actually, that's why I thought this would be good as a, as a follow-up.
47:26 So Guido announced that he wrote the introduction to pattern matching and, and that it's, it's
47:34 now part of, it's part of an appendix A of PEP 636.
47:38 So I went off and looked at it and it actually really helped me a lot.
47:42 So this, this introduction kind of, I actually, I've been trying to follow this PEP and honestly
47:49 been confused for a while as to like exactly how it's working.
47:53 A lot of people have been focusing on the weird parts, but the easy parts actually are
47:57 really nice.
47:58 So I really, the, the, there's an example that it starts off with that kind of looks like
48:04 a switch statement, right?
48:06 So it's a, I want to match a status and like an HTTP status.
48:10 And then I do something different based on 400 or 404 or 418.
48:15 And then, and then of course we're like, well, what, what about default?
48:18 Right?
48:18 So there's going to be some sort of fall through that I handle all the other cases.
48:22 And there's an example of that.
48:23 And I was actually curious, the example here shows using the, just the single underscore
48:28 variable, magic variable as a, as, as a catch all.
48:33 And so Brett, I was just curious, can I use any variable here or does it need to be the
48:38 single underscore?
48:39 Do you know?
48:40 So I was actually going to come on at this when you were done.
48:43 so the underscore actually has some special semantics here because, in most, most
48:50 languages that have pattern matching, the underscore represents the wild card.
48:52 this has actually been one of the most controversial parts of peps 634 was the selection of this to
48:57 stay consistent with other languages.
48:59 while I will not suggest to people that there's an opportunity to remove pattern matching
49:05 or to necessarily have massive changes to it.
49:07 One of the things that if people try this out in real world code and can get feedback to
49:13 us well before beta one locks in and gets released.
49:16 Cause that's our cutoff, for feature changes, for Python 3.10, which will be in
49:21 May.
49:21 this is one of those areas where we could, we could actually consider changing, right?
49:26 Like fixing up code to change this case, wild card syntax of an underscore to something
49:32 else is totally possible.
49:34 If we got feedback from the community that, yeah, this really was a nasty sticking point and
49:38 really didn't work out well.
49:39 So I do want to say that there is still a chance to potentially influence the final outcome
49:44 of how the exact exact thing is.
49:47 Although I don't want to suggest that because it's not shipped in 3.10 yet, right?
49:50 It's exactly.
49:51 It's not shipped in 3.10 yet.
49:52 so we can tweak if necessary, but don't come out.
49:56 I wouldn't suggest people come out and try to completely rewrite the entire syntax.
50:00 But in this specific case, yes, it is special.
50:03 yes, some people don't like it.
50:05 And if enough people really came forward and really said, this is the one thing I'd want to
50:10 tweak.
50:10 We, I think we'd be open to considering.
50:12 Well, the underscore gets used so much for so many interesting things.
50:16 Like why not one more?
50:17 Make it.
50:17 I'm okay.
50:18 I personally, I don't care.
50:20 I just want to know what it is.
50:22 I mean, I didn't like, I didn't like spaces instead of braces when I first hit it.
50:28 So, anyway, but what happens if I put it like X there instead of a underscore?
50:34 If you put X, so the rules here basically are, if you put a single name that has no dot in
50:40 it, it's a binding.
50:41 If you put a name there with a dot, it will be a binding.
50:43 Now, this is one of the things that I learned from Guido in one of our meetings that really
50:47 helped clarify this for me.
50:48 And one of the reasons I ended up, voting to accept this was let's look at the, like,
50:53 consider these cases, right?
50:54 Return codes.
50:55 You're probably not going to hard code 400 and 404 and 14.
50:58 You're going to import the HTTP dot status module and you're going to specify the constants
51:02 from there, right?
51:03 Yeah.
51:03 Do you really want to rebind those constants by accident in your code?
51:06 Oh no.
51:08 No, but because it's been imported from a module or off a class, for instance, you're not going
51:13 to be wanting to do assignment.
51:14 You're just going to want to reference it.
51:15 So if there's a dot in the name, it automatically is just a reference.
51:18 Now, some people get really hung up on that when they think about the single binding of
51:23 a name, understandably.
51:24 But here's the thing is, well, this is a case right now where if you had just a bare
51:29 name, that's a bind where if there's a dot in it, it's actually going to be a reference
51:33 and a load to do a value check.
51:36 There is a potential in the future.
51:39 If people come back after trying out the PEP and having experience with pattern matching
51:43 to add to the language, a leading dot, which is actually used in Swift, by the way, in the
51:50 Swift community for something else.
51:51 But the key point is we can make it like a dot X to act as a load for comparison for
51:57 a local name.
51:58 That's an interesting syntactical use.
52:00 Like it's not actually coming from anywhere, but treat it as if it were.
52:03 Exactly.
52:04 Now, this was originally in the PEP and there was massive pushback from people thinking
52:09 that they would totally miss the dot.
52:11 But Corey Benfield, who used to run requests and all that and has multiple talks from PyCon,
52:18 a person who helped me start pushing sans IO development of libraries in the community.
52:23 He works at Apple now on Swift stuff and he posted something on Twitter and I asked him
52:27 like, hey, does that leading dot have any problems with Swift?
52:30 And they said, actually, the whole community is totally fine with it.
52:32 There's no readability problems.
52:33 It just totally works.
52:34 So we could potentially in the next version of Python actually make it so that that that
52:39 have it a dot in the name, whether it's just leading or not.
52:42 We could actually generalize that.
52:44 But because it's a forward compatible thing and backwards compatible, we decided not to
52:48 do that in this path and just try to just keep it simple, simple, keep it simpler than
52:53 it had to be necessary to go out and then add an opportunity.
52:56 So if I just put a bare X, it's going, will it hit it and will it bind to it and assign
53:02 the value to X?
53:04 Yes.
53:05 Okay.
53:05 Actually, that's what I expected because as I go down this little tutorial, it talks about
53:10 like, un pattern, like unpacking, which is totally cool.
53:15 So let's say you have a, like a, the example is a point object, which is like just an XY tuple.
53:21 now I want to be able to, if I, in the case statements are, you know, specific points
53:27 that you're going to match to, or like, let's say you don't care what X is, but you, you want
53:33 to fix Y at zero in, in the case, in the case block, you want to know what the value of X
53:39 was.
53:40 So you do want that binding.
53:41 And that's, that's really just cool.
53:43 I just, I can't wait to play with this.
53:45 So my, my follow-up question, I'm glad you showed up here is when can I play with this?
53:50 Is this in one of the alphas now or betas?
53:52 Or do you know?
53:53 I don't, there is, I don't know if it's, I don't think it's landed yet.
53:58 Bram Butcher, who's one of the coauthors of the PEP has a working implementation already,
54:03 which was, which is actually available in a Jupyter was available in a Jupyter notebook
54:07 somewhere.
54:08 so there's definitely a fork somewhere where you can try this out.
54:12 Okay.
54:12 but I don't, this is not landed in mainline, so it's not out in an alpha quite yet.
54:17 Okay.
54:17 one thing I did want to point out about this, that's really kind of cool.
54:20 with the example that Brian's showing here, right, is the match against a point argument,
54:26 as you said, that takes a two item tuple, right?
54:29 You could actually change this to also accept a single item tuple that represented X and Y
54:33 with the same value.
54:34 And that would totally match separately as well.
54:35 Right?
54:36 So once again, this is matching against structure.
54:38 So you could actually pass in tuples of different sizes and have it automatically just kind of
54:43 maybe do something different with 2d or 3d.
54:45 Yeah, exactly.
54:46 Yeah, exactly.
54:48 So because it's a structural thing and not a value thing, it opens those very interesting
54:53 doors.
54:53 Cool.
54:53 Interesting.
54:54 Yeah.
54:54 Cool.
54:54 It's really great to have you here to talk about all this stuff.
54:56 final comment, close this one out.
54:58 I guess, Zdoc says, I think, once good syntax highlighting lands, this will be as
55:04 natural as less comprehension.
55:05 Yeah.
55:06 And that's actually a good point.
55:07 One of the things, we had discussed was like the, the leading dot would, how hard would
55:13 that be to see with or without syntax highlighting?
55:15 And we realized that honestly, syntax highlighting will probably do it.
55:17 One thing some people were a little worried about was the reason this is even possible was
55:22 because of the new parser that landed in Python 3.9, the, new PGM parser.
55:26 it can do more contextualized parsing.
55:29 So that match, for instance, isn't going to suddenly make all your match keywords or the match
55:33 method on from the re module on match objects suddenly not work.
55:38 it contextually can tell that that match keyword is for a match statement.
55:42 So there might be a little funky coloring for some people based on how your syntax highlighting
55:46 works.
55:46 Like you might suddenly have all your match methods highlighted like it was the match keyword,
55:49 but honestly it'll be from, from, from what you're looking at in terms of the code,
55:54 it's going to be fairly obvious.
55:55 That is not a match statement.
55:56 So we weren't too worried about that kind of, haziness as it were, when it comes to
56:00 syntax.
56:00 Yeah.
56:01 No, this is cool.
56:02 I know a guy on the VS Code team.
56:04 So yeah, so do I.
56:06 You see him every morning in the mirror.
56:09 A quick plug and thank you to magic Python, which comes from, the magic Python team,
56:16 magic stack, the people who do edge DB.
56:19 They actually maintain, the syntax highlighting, that we use in VS Code, as well as
56:25 I think is using sublime text and Adam, like they have a generic grammar that they use that
56:29 they just auto gen out to, various editors for their syntax, mostly text mate, format,
56:35 but, kudos to them for always maintaining that, syntax highlighting.
56:38 Cause that's actually what VS Code itself ships in the box.
56:41 That's awesome.
56:41 Yeah.
56:42 Nice.
56:42 Brian, I don't have any extras.
56:43 Do you?
56:44 I don't know.
56:46 Right.
56:46 Anything else you want to throw out there before we, make a bad joke?
56:50 No, just thanks for having me on.
56:51 Thank you for everyone listening to me rant on about, how to please try to, talk
56:56 to maintainers that help them keep their sanity.
56:58 And, that's it.
57:00 I hope, I hope people give the Python launcher a shot and it works for them.
57:03 Yeah.
57:03 That's very exciting.
57:04 Let me know.
57:05 I can't make any promises about it shipping specifically with Python, but at least it's a
57:09 tool there that I find useful.
57:10 I hope others do as well.
57:11 Cool.
57:11 I'll definitely check that one out.
57:13 All right.
57:14 You guys ready for the joke?
57:15 you know, we're.
57:16 We're all stuck at home.
57:17 And especially if you're single, it's, it's really tricky to, to get out and meet people
57:22 and you know, whatnot.
57:24 See, see what's going to make you happy.
57:25 So I got a joke along those lines to kind of help people out there.
57:29 Ready?
57:29 All right.
57:30 So there's this tweet by Christian, zoo says, if you're not happy, single, you won't
57:35 be happy in a relationship.
57:36 I mean, we've all heard this, how important it is to be just like content with yourself.
57:39 She says, no, true happiness comes from closing 100 Chrome tabs after solving an obscure
57:44 programming bug, not from other people.
57:46 Come on.
57:47 Yeah.
57:49 Anyway, I thought that was good.
57:51 And Kiki.
57:51 Are you, are you two the type of folk who have like a bazillion tabs open at any one time?
57:56 Or are you more like only keep open exactly what I'm working on.
57:59 And as soon as I'm done, I close them.
58:00 I am not a hundred tab person, but what I do sometimes I'll like leave the tabs open.
58:07 Like, oh, I'm not done with this.
58:08 And so I'll close it.
58:09 If I got to reboot the computer, the first thing I do is reopen the browser and say history
58:13 restore previous session.
58:14 Cause I'm like, there were things in there.
58:15 I don't know what I was doing, but I know they're important.
58:17 So I may abuse that a little bit.
58:19 I, my daughter came to me once and said, I need dad like finals.
58:24 And then my laptop is too slow.
58:26 I need a new laptop.
58:27 Like, okay, well, let's talk about what you're doing.
58:28 Well, she was doing like three research projects and had like a hundred tabs open.
58:33 I'm like, well, let's just try this first.
58:35 Can I, can I tell you about this cool thing called bookmarks?
58:39 And anyway, totally fixed it.
58:43 So yeah, that's awesome.
58:45 Hipster dad showing bookmarks to the youngsters.
58:47 Yeah.
58:49 Magnus says the number of tabs is a measure of how hard the problem is.
58:53 And Niels says a great rant.
58:56 Love your work, Brett.
58:57 Great to have you on the show, Brett.
59:00 Always happy to be on.
59:01 Thanks for being here.
59:02 Thanks to everyone.
59:02 Brian.
59:03 Thank you.
59:03 Thanks as always.