diff options
Diffstat (limited to '')
-rw-r--r-- | 2022/captions/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.vtt | 853 | ||||
-rw-r--r-- | 2022/info/python-before.md | 10 |
2 files changed, 860 insertions, 3 deletions
diff --git a/2022/captions/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.vtt b/2022/captions/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.vtt new file mode 100644 index 00000000..904762a5 --- /dev/null +++ b/2022/captions/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.vtt @@ -0,0 +1,853 @@ +WEBVTT +Kind: captions: +Language: en-GB + +00:00:00.000 --> 00:00:04.000 +Hi! My name is Eduardo Ochs. I'm the author + +00:00:04.000 --> 00:00:06.000 +of an Emacs package called eev... + +00:00:06.000 --> 00:00:10.000 +and eev is about taking executable notes + +00:00:10.000 --> 00:00:13.000 +of everything that you do, and this + +00:00:13.000 --> 00:00:16.000 +presentation is about how I use this... + +00:00:16.000 --> 00:00:18.000 +how I finally found a way to take + +00:00:18.000 --> 00:00:22.000 +executable notes of what the python docs + +00:00:22.000 --> 00:00:23.000 +say. + +00:00:23.000 --> 00:00:28.000 +Let me explain that in another way. I've + +00:00:28.000 --> 00:00:31.000 +try to Learn Python many times, but + +00:00:31.000 --> 00:00:34.000 +hm, my brain is wired in a weird way, so + +00:00:34.000 --> 00:00:37.000 +it didn't work... and finally a few + +00:00:37.000 --> 00:00:40.000 +months ago I found a way of studying + +00:00:40.000 --> 00:00:44.000 +Python that finally clicked for me. + +00:00:44.000 --> 00:00:47.000 +The idea is that... well, it's here in + +00:00:47.000 --> 00:00:50.000 +the title - is a way to create short + +00:00:50.000 --> 00:00:52.000 +hyperlinks to the + +00:00:52.000 --> 00:00:54.000 +documentation of python. + +00:00:54.000 --> 00:00:56.000 +Here's an example. + +00:00:56.000 --> 00:01:00.000 +This file contains some some chunks + +00:01:00.000 --> 00:01:03.000 +of code from the Python tutorial and + +00:01:03.000 --> 00:01:05.000 +some links to the places in which + +00:01:05.000 --> 00:01:07.000 +I found these chunks of code. + +00:01:07.000 --> 00:01:12.000 +for example, if I run this link here + +00:01:12.000 --> 00:01:14.000 +it opens a certain page of the Python + +00:01:14.000 --> 00:01:18.000 +tutorial in my browser - note that it + +00:01:18.000 --> 00:01:19.000 +opens the local copy of the + +00:01:19.000 --> 00:01:22.000 +documentation - + +00:01:22.000 --> 00:01:25.000 +and if I + +00:01:25.000 --> 00:01:29.000 +run this link here it opens the source + +00:01:29.000 --> 00:01:30.000 +in .rst + +00:01:30.000 --> 00:01:34.000 +of the same page. So the first link opens + +00:01:34.000 --> 00:01:37.000 +the HTML and this one opens the + +00:01:37.000 --> 00:01:39.000 +RST. This is useful because in the + +00:01:39.000 --> 00:01:40.000 +beginning + +00:01:40.000 --> 00:01:44.000 +I was copying these chunks of code in + +00:01:44.000 --> 00:01:46.000 +the obvious way - I would simply + +00:01:46.000 --> 00:01:50.000 +visit the the documentation in HTML and + +00:01:50.000 --> 00:01:51.000 +I would mark + +00:01:51.000 --> 00:01:54.000 +a chunk... a snippet of code here and I + +00:01:54.000 --> 00:01:58.000 +would copy it to my notes. + +00:01:58.000 --> 00:02:01.000 +And then after a while I + +00:02:01.000 --> 00:02:03.000 +realized that it was much easier to + +00:02:03.000 --> 00:02:07.000 +simply go to the RST sources and to copy + +00:02:07.000 --> 00:02:10.000 +the chunks of code from there... and + +00:02:10.000 --> 00:02:14.000 +note that these links look quite similar. + +00:02:14.000 --> 00:02:17.000 +There's one difference here, that is + +00:02:17.000 --> 00:02:20.000 +this `r' that is prepended to the name + +00:02:20.000 --> 00:02:23.000 +of the function... the `r' means + +00:02:23.000 --> 00:02:26.000 +"open the RST"... + +00:02:26.000 --> 00:02:30.000 +and if I use the suffix `w' it means + +00:02:30.000 --> 00:02:32.000 +use the documentation on the web instead + +00:02:32.000 --> 00:02:34.000 +of using the local copy. + +00:02:34.000 --> 00:02:36.000 +So this one + +00:02:36.000 --> 00:02:38.000 +opens a local copy + +00:02:38.000 --> 00:02:42.000 +and this one + +00:02:42.000 --> 00:02:46.000 +takes a while + +00:02:46.000 --> 00:02:49.000 +and opens the + +00:02:49.000 --> 00:02:52.000 +the page of the documentation in the + +00:02:52.000 --> 00:02:56.000 +site of Python blah blah... + +00:02:56.000 --> 00:02:58.000 +and this thing here is + +00:02:58.000 --> 00:03:02.000 +executable in the usual eev sense, that + +00:03:02.000 --> 00:03:05.000 +we ca... if we type f8 several times here + +00:03:05.000 --> 00:03:08.000 +the f8s on the lines that start + +00:03:08.000 --> 00:03:12.000 +with red stars create a target buffer + +00:03:12.000 --> 00:03:14.000 +here... and in this case it creates a + +00:03:14.000 --> 00:03:17.000 +target buffer running Python, and if I + +00:03:17.000 --> 00:03:20.000 +type f8 on these other lines these are + +00:03:20.000 --> 00:03:23.000 +the lines are sent + +00:03:23.000 --> 00:03:25.000 +to that REPL. + +00:03:25.000 --> 00:03:30.000 +But anyway, let me go back. + +00:03:30.000 --> 00:03:32.000 +Most of the things that I'm going to + +00:03:32.000 --> 00:03:35.000 +present here are in the tutorial of this... + +00:03:35.000 --> 00:03:37.000 +package... + +00:03:37.000 --> 00:03:41.000 +we can go to the source code + +00:03:41.000 --> 00:03:44.000 +here in the eev directory - it's a file + +00:03:44.000 --> 00:03:50.000 +called eev-rstdoc.el but the best + +00:03:50.000 --> 00:03:53.000 +docs are in the tutorial, here... + +00:03:53.000 --> 00:03:56.000 +and the tutorial also has some + +00:03:56.000 --> 00:03:58.000 +executable + +00:03:58.000 --> 00:04:02.000 +chunks... some snippets of python + +00:04:02.000 --> 00:04:05.000 +code that are executable, but they + +00:04:05.000 --> 00:04:07.000 +don't have those nice colors... so + +00:04:07.000 --> 00:04:11.000 +apologies for that. + +00:04:11.000 --> 00:04:13.000 +We need to run this thing here to make + +00:04:13.000 --> 00:04:15.000 +everything work. + +00:04:15.000 --> 00:04:17.000 +This thing will define some functions + +00:04:17.000 --> 00:04:19.000 +with funny names that I will + +00:04:19.000 --> 00:04:26.000 +explain later. + +00:04:26.000 --> 00:04:30.000 +Let me explain something new. + +00:04:30.000 --> 00:04:35.000 +let's compare all these + +00:04:35.000 --> 00:04:38.000 +links here. They take this argument + +00:04:38.000 --> 00:04:41.000 +here and they expand the the argument in + +00:04:41.000 --> 00:04:44.000 +a certain way. For example this string is + +00:04:44.000 --> 00:04:49.000 +expanded to this long URL here... note that + +00:04:49.000 --> 00:04:52.000 +it got a prefix here, + +00:04:52.000 --> 00:04:56.000 +that's quite long... it got the .html here, + +00:04:56.000 --> 00:04:59.000 +and then the hash and the anchor here... + +00:04:59.000 --> 00:05:03.000 +and each one of the functions in the + +00:05:03.000 --> 00:05:06.000 +pydoc family expands this + +00:05:06.000 --> 00:05:09.000 +argument in a different way. + +00:05:09.000 --> 00:05:12.000 +The one that that opens the doc in the + +00:05:12.000 --> 00:05:16.000 +web uses another prefix - + +00:05:16.000 --> 00:05:20.000 +this one - and the one that opens the rst + +00:05:20.000 --> 00:05:24.000 +file ignores the part after the hash + +00:05:24.000 --> 00:05:28.000 +for technical reasons... I was never + +00:05:28.000 --> 00:05:30.000 +able to to find a good way to convert + +00:05:30.000 --> 00:05:33.000 +this hash into a string to search for, + +00:05:33.000 --> 00:05:35.000 +so to make something that goes to + +00:05:35.000 --> 00:05:38.000 +the right section in the link to the rst + +00:05:38.000 --> 00:05:42.000 +doc I have to convert by hand, and by + +00:05:42.000 --> 00:05:46.000 +trial and error, this thing here into a + +00:05:46.000 --> 00:05:48.000 +pointer to that section, like + +00:05:48.000 --> 00:05:50.000 +this one... + +00:05:50.000 --> 00:05:55.000 +in which the "_numeric-types:" + +00:05:55.000 --> 00:05:58.000 +is here. + +00:05:58.000 --> 00:06:02.000 +So all these links here are based on + +00:06:02.000 --> 00:06:04.000 +expansion, and this is easy to + +00:06:04.000 --> 00:06:05.000 +understand... + +00:06:05.000 --> 00:06:08.000 +but suppose that I want to + +00:06:08.000 --> 00:06:11.000 +create a link like this, or suppose that + +00:06:11.000 --> 00:06:16.000 +I'm browsing the docs here + +00:06:16.000 --> 00:06:21.000 +and I just I follow some some links... + +00:06:21.000 --> 00:06:31.000 +let me do something random here... + +00:06:31.000 --> 00:06:34.000 +suppose that I decide that this + +00:06:34.000 --> 00:06:35.000 +section is very interesting. How can I + +00:06:35.000 --> 00:06:39.000 +create a link to that? I can + +00:06:39.000 --> 00:06:44.000 +use this pilcrow symbol and the + +00:06:44.000 --> 00:06:45.000 +"Copy link address", + +00:06:45.000 --> 00:06:49.000 +and copy the link to + +00:06:49.000 --> 00:06:51.000 +my notes... + +00:06:51.000 --> 00:06:55.000 +and then the Python family... + +00:06:55.000 --> 00:06:58.000 +well, we saw the the functions in the + +00:06:58.000 --> 00:07:00.000 +Python family have a certain way - have + +00:07:00.000 --> 00:07:03.000 +several ways of expanding these + +00:07:03.000 --> 00:07:06.000 +short arguments... and they also have a + +00:07:06.000 --> 00:07:07.000 +certain way of + +00:07:07.000 --> 00:07:11.000 +shortening URLs like this one. If I type + +00:07:11.000 --> 00:07:12.000 +`M-x pdk' the message is this one. + +00:07:12.000 --> 00:07:17.000 +`pdk' is a mnemonic for + +00:07:17.000 --> 00:07:20.000 +"Python doc kill", and this + +00:07:20.000 --> 00:07:23.000 +"kill" means "copy to the kill ring" + +00:07:23.000 --> 00:07:27.000 +so if I type `M-x pdk' here it + +00:07:27.000 --> 00:07:31.000 +considers that this thing is a link + +00:07:31.000 --> 00:07:34.000 +to the python Docs, and it + +00:07:34.000 --> 00:07:36.000 +shortens this link in a certain way, and + +00:07:36.000 --> 00:07:42.000 +it kills a short link. + +00:07:42.000 --> 00:07:45.000 +I can insert the short link with C-y + +00:07:45.000 --> 00:07:46.000 +(yank) + +00:07:46.000 --> 00:07:49.000 +and then I can test this link to be sure + +00:07:49.000 --> 00:07:52.000 +that it points to where I want, and + +00:07:52.000 --> 00:07:55.000 +then I can delete this thing, and ta-da, + +00:07:55.000 --> 00:07:57.000 +now I have a short link, and of course I + +00:07:57.000 --> 00:08:00.000 +can modify this link by adding a suffix + +00:08:00.000 --> 00:08:02.000 +here... + +00:08:02.000 --> 00:08:06.000 +and in this case here + +00:08:06.000 --> 00:08:09.000 +I will have to change the identifier + +00:08:09.000 --> 00:08:12.000 +to something else... + +00:08:12.000 --> 00:08:18.000 +but I'm not going to do that now. + +00:08:18.000 --> 00:08:20.000 +This module of eev comes with three + +00:08:20.000 --> 00:08:24.000 +families predefined. One is a family that + +00:08:24.000 --> 00:08:26.000 +points to the the documentation of + +00:08:26.000 --> 00:08:28.000 +Python itself, another one points the + +00:08:28.000 --> 00:08:30.000 +documentation of SymPy, that is a program + +00:08:30.000 --> 00:08:34.000 +for symbolic computation, like for doing + +00:08:34.000 --> 00:08:37.000 +mathematics equations... + +00:08:37.000 --> 00:08:40.000 +and the other one points to the + +00:08:40.000 --> 00:08:43.000 +documentation of MatPlotLib. + +00:08:43.000 --> 00:08:47.000 +How do these families work? + +00:08:47.000 --> 00:08:51.000 +Each family has to be defined in two + +00:08:51.000 --> 00:08:53.000 +parts. + +00:08:53.000 --> 00:08:55.000 +Remember that + +00:08:55.000 --> 00:08:58.000 +eev has lots of functions + +00:08:58.000 --> 00:09:03.000 +like this one... this one + +00:09:03.000 --> 00:09:06.000 +is the most basic, and it is explained + +00:09:06.000 --> 00:09:08.000 +here, in this section of the main + +00:09:08.000 --> 00:09:13.000 +tutorial. This section explains that + +00:09:13.000 --> 00:09:16.000 +a sexp like this one produces lots of + +00:09:16.000 --> 00:09:19.000 +functions - produces a family of + +00:09:19.000 --> 00:09:23.000 +functions - and it does that by producing + +00:09:23.000 --> 00:09:25.000 +a certain chunk of code and then + +00:09:25.000 --> 00:09:28.000 +executing this chunk of code... and if we + +00:09:28.000 --> 00:09:31.000 +add a certain prefix here... `find-' and we + +00:09:31.000 --> 00:09:35.000 +execute this we can... instead of executing + +00:09:35.000 --> 00:09:37.000 +that chunk of code we can see what is + +00:09:37.000 --> 00:09:39.000 +that chunk of code. In the case of `code-c-d' + +00:09:39.000 --> 00:09:43.000 +it is this. It is a `setq`, several + +00:09:43.000 --> 00:09:47.000 +`defun's, and some comments here, with + +00:09:47.000 --> 00:09:49.000 +links to the documentation. + +00:09:49.000 --> 00:09:52.000 +In the case of rstdoc it's the same. + +00:09:52.000 --> 00:09:54.000 +We have this function here that defines + +00:09:54.000 --> 00:09:56.000 +the function in the python family... + +00:09:56.000 --> 00:09:59.000 +and we can run this to understand what + +00:09:59.000 --> 00:10:03.000 +this `code-rstdoc' does. + +00:10:03.000 --> 00:10:05.000 +It creates this temporary buffer here... + +00:10:05.000 --> 00:10:09.000 +with lots of `defun's, a `code-c-d' here, + +00:10:09.000 --> 00:10:10.000 +and lots of comments here... and the + +00:10:10.000 --> 00:10:13.000 +comments include some tests. For example + +00:10:13.000 --> 00:10:16.000 +we can use these functions here to test + +00:10:16.000 --> 00:10:21.000 +how the expansion works. + +00:10:21.000 --> 00:10:23.000 +And + +00:10:23.000 --> 00:10:26.000 +note that in this buffer here we don't + +00:10:26.000 --> 00:10:28.000 +have the paths that that this family + +00:10:28.000 --> 00:10:31.000 +uses. We don't have for example + +00:10:31.000 --> 00:10:33.000 +the URL that points to the site of + +00:10:33.000 --> 00:10:36.000 +Python, to the directory that contains + +00:10:36.000 --> 00:10:40.000 +the reference manual, or whatever... all + +00:10:40.000 --> 00:10:42.000 +these things are in another part of the + +00:10:42.000 --> 00:10:44.000 +definition of that family - that is a + +00:10:44.000 --> 00:10:45.000 +variable. + +00:10:45.000 --> 00:10:48.000 +If we execute this we go to the + +00:10:48.000 --> 00:10:50.000 +source code of eev-rstdoc, + +00:10:50.000 --> 00:10:54.000 +to the parts in which + +00:10:54.000 --> 00:10:57.000 +this variable is defined... + +00:10:57.000 --> 00:10:59.000 +and + +00:10:59.000 --> 00:11:01.000 +for each family we have a variable like + +00:11:01.000 --> 00:11:02.000 +this, + +00:11:02.000 --> 00:11:05.000 +whose value is a property + +00:11:05.000 --> 00:11:07.000 +list with several fields... + +00:11:07.000 --> 00:11:09.000 +these first fields are very easy to + +00:11:09.000 --> 00:11:10.000 +understand - they are used in the + +00:11:10.000 --> 00:11:16.000 +expansion... this one too. And these + +00:11:16.000 --> 00:11:19.000 +two fields are used in the shrinking - + +00:11:19.000 --> 00:11:21.000 +in the shortening - and + +00:11:21.000 --> 00:11:25.000 +this field here + +00:11:25.000 --> 00:11:28.000 +tells what is the name of the + +00:11:28.000 --> 00:11:30.000 +killing function + +00:11:30.000 --> 00:11:33.000 +so the fields of this thing here are + +00:11:33.000 --> 00:11:34.000 +used + +00:11:34.000 --> 00:11:36.000 +to generate... + +00:11:36.000 --> 00:11:39.000 +some fields are used to generate the + +00:11:39.000 --> 00:11:41.000 +code that appears here, and some fields + +00:11:41.000 --> 00:11:44.000 +are simply + +00:11:44.000 --> 00:11:47.000 +read by functions like this one, that + +00:11:47.000 --> 00:11:51.000 +consults the variable. + +00:11:51.000 --> 00:11:53.000 +Now the natural question is: how can we + +00:11:53.000 --> 00:11:57.000 +define new families? Or: how can we change + +00:11:57.000 --> 00:11:59.000 +a family like this one to point to + +00:11:59.000 --> 00:12:03.000 +another version of Python? + +00:12:03.000 --> 00:12:06.000 +There are some template-based functions + +00:12:06.000 --> 00:12:09.000 +for doing that. They are explained in + +00:12:09.000 --> 00:12:10.000 +this section of the tutorial... + +00:12:10.000 --> 00:12:14.000 +where is that?... + +00:12:14.000 --> 00:12:17.000 +oh God, it's far away... + +00:12:17.000 --> 00:12:20.000 +here. + +00:12:20.000 --> 00:12:23.000 +Suppose that we have a package foo, that + +00:12:23.000 --> 00:12:25.000 +we want to create a family that points + +00:12:25.000 --> 00:12:27.000 +to the docs + +00:12:27.000 --> 00:12:31.000 +of that package foo... so, we + +00:12:31.000 --> 00:12:32.000 +can execute this thing here, and it + +00:12:32.000 --> 00:12:34.000 +generates this + +00:12:34.000 --> 00:12:37.000 +this thing from a template. + +00:12:37.000 --> 00:12:40.000 +If we just want to modify a current + +00:12:40.000 --> 00:12:42.000 +definition we can run something like + +00:12:42.000 --> 00:12:44.000 +this - note that the family `:py' + +00:12:44.000 --> 00:12:47.000 +already exists, and instead of using + +00:12:47.000 --> 00:12:51.000 +placeholders in some of these + +00:12:51.000 --> 00:12:53.000 +URLs it will use the current values of + +00:12:53.000 --> 00:12:55.000 +the fields... + +00:12:55.000 --> 00:12:59.000 +so we can also use this modify + +00:12:59.000 --> 00:13:01.000 +existing families. + +00:13:01.000 --> 00:13:05.000 +Well these are the technical details. + +00:13:05.000 --> 00:13:08.000 +Now the natural question is: why do I + +00:13:08.000 --> 00:13:12.000 +want this? This doesn't + +00:13:12.000 --> 00:13:14.000 +any sense to me! Why should I + +00:13:14.000 --> 00:13:15.000 +try this? + +00:13:15.000 --> 00:13:18.000 +And the best answer: is for most people + +00:13:18.000 --> 00:13:21.000 +this way of using + +00:13:21.000 --> 00:13:24.000 +executable notes do not make any sense + +00:13:24.000 --> 00:13:27.000 +at all at first sight... + +00:13:27.000 --> 00:13:30.000 +so what I'm trying to do is: I'm trying + +00:13:30.000 --> 00:13:33.000 +to write to these tutorials with + +00:13:33.000 --> 00:13:35.000 +many examples that are very easy to run, + +00:13:35.000 --> 00:13:38.000 +and that examine data structures, + +00:13:38.000 --> 00:13:40.000 +and functions, and test things, + +00:13:40.000 --> 00:13:46.000 +and so on... so my main argument + +00:13:46.000 --> 00:13:48.000 +for convincing people to + +00:13:48.000 --> 00:13:52.000 +test this is: this is trivial to test - + +00:13:52.000 --> 00:13:54.000 +simply install eev and run this thing + +00:13:54.000 --> 00:13:56.000 +here, and run the examples, and probably + +00:13:56.000 --> 00:13:58.000 +you're going to find that this + +00:13:58.000 --> 00:14:01.000 +tutorial is fun to follow. + +00:14:01.000 --> 00:14:03.000 +So that's it! =) + diff --git a/2022/info/python-before.md b/2022/info/python-before.md index 433857af..ab650d64 100644 --- a/2022/info/python-before.md +++ b/2022/info/python-before.md @@ -1,16 +1,20 @@ <!-- Automatically generated by emacsconf-publish-before-page --> The following image shows where the talk is in the schedule for Sun 2022-12-04. Solid lines show talks with Q&A via BigBlueButton. Dashed lines show talks with Q&A via IRC or Etherpad.<div class="schedule-in-context schedule-svg-container" data-slug="python"> -<svg width="800" height="150" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <title> Schedule for Sunday</title> <rect width="800" height="150" x="0" y="0" fill="white"></rect> <text font-size="10" fill="black" y="12" x="3"> Sunday</text> <a href="/2022/talks/sun-open" title="Sunday opening remarks" data-slug="sun-open"> <title> 9:00- 9:05 Sunday opening remarks</title> <rect x="0" y="15" opacity="0.5" width="7" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(5,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> sun-open</text></g></a> <a href="/2022/talks/survey" title="Results of the 2022 Emacs Survey" data-slug="survey"> <title> 9:05- 9:25 Results of the 2022 Emacs Survey</title> <rect x="7" y="15" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(36,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> survey</text></g></a> <a href="/2022/talks/orgyear" title="This Year in Org" data-slug="orgyear"> <title> 9:35- 9:45 This Year in Org</title> <rect x="54" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(67,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> orgyear</text></g></a> <a href="/2022/talks/rolodex" title="Build a Zettelkasten with the Hyperbole Rolodex" data-slug="rolodex"> <title> 9:55-10:20 Build a Zettelkasten with the Hyperbole Rolodex</title> <rect x="86" y="15" opacity="0.5" width="39" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(123,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> rolodex</text></g></a> <a href="/2022/talks/orgsuperlinks" title="Linking headings with org-super-links (poor-man's Zettelkasten)" data-slug="orgsuperlinks"> <title> 10:40-10:50 Linking headings with org-super-links (poor-man's Zettelkasten)</title> <rect x="156" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(169,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> orgsuperlinks</text></g></a> <a href="/2022/talks/orgvm" title="orgvm: a simple HTTP server for org" data-slug="orgvm"> <title> 11:10-11:20 orgvm: a simple HTTP server for org</title> <rect x="203" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(216,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> orgvm</text></g></a> <a href="/2022/talks/hyperorg" title="Powerful productivity with Hyperbole and Org Mode" data-slug="hyperorg"> <title> 1:00- 1:30 Powerful productivity with Hyperbole and Org Mode</title> <rect x="376" y="15" opacity="0.5" width="47" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(421,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> hyperorg</text></g></a> <a href="/2022/talks/workflows" title="Org workflows for developers" data-slug="workflows"> <title> 1:50- 2:15 Org workflows for developers</title> <rect x="454" y="15" opacity="0.5" width="39" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(491,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> workflows</text></g></a> <a href="/2022/talks/grail" title="GRAIL---A Generalized Representation and Aggregation of Information Layers" data-slug="grail"> <title> 2:35- 2:55 GRAIL---A Generalized Representation and Aggregation of Information Layers</title> <rect x="525" y="15" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(554,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> grail</text></g></a> <a href="/2022/talks/indieweb" title="Putting Org Mode on the Indieweb" data-slug="indieweb"> <title> 3:25- 3:45 Putting Org Mode on the Indieweb</title> <rect x="603" y="15" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(632,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> indieweb</text></g></a> <a href="/2022/talks/devel" title="Emacs development updates" data-slug="devel"> <title> 4:05- 4:15 Emacs development updates</title> <rect x="666" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(679,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> devel</text></g></a> <a href="/2022/talks/fanfare" title="Fanfare for the Common Emacs User" data-slug="fanfare"> <title> 4:25- 4:35 Fanfare for the Common Emacs User</title> <rect x="698" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(711,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> fanfare</text></g></a> <a href="/2022/talks/sun-close" title="Sunday closing remarks" data-slug="sun-close"> <title> 4:50- 5:00 Sunday closing remarks</title> <rect x="737" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(750,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> sun-close</text></g></a> <a href="/2022/talks/rde" title="rde Emacs introduction" data-slug="rde"> <title> 10:00-10:25 rde Emacs introduction</title> <rect x="94" y="75" opacity="0.5" width="39" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(131,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> rde</text></g></a> <a href="/2022/talks/justl" title="justl: Driving recipes within Emacs" data-slug="justl"> <title> 10:50-11:05 justl: Driving recipes within Emacs</title> <rect x="172" y="75" opacity="0.5" width="23" height="59" stroke="black" stroke-dasharray="5,5,5" fill="skyblue"></rect> <g transform="translate(193,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> justl</text></g></a> <a href="/2022/talks/rms" title="What I'd like to see in Emacs" data-slug="rms"> <title> 11:15-11:35 What I'd like to see in Emacs</title> <rect x="211" y="75" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="5,5,5" fill="skyblue"></rect> <g transform="translate(240,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> rms</text></g></a> <a href="/2022/talks/detached" title="Getting detached from Emacs" data-slug="detached"> <title> 1:00- 1:15 Getting detached from Emacs</title> <rect x="376" y="75" opacity="0.5" width="23" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(397,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> detached</text></g></a> <a href="/2022/talks/eshell" title="Top 10 reasons why you should be using Eshell" data-slug="eshell"> <title> 1:40- 1:55 Top 10 reasons why you should be using Eshell</title> <rect x="439" y="75" opacity="0.5" width="23" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(460,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> eshell</text></g></a> <a href="/2022/talks/async" title="Emacs was async before async was cool" data-slug="async"> <title> 2:20- 2:40 Emacs was async before async was cool</title> <rect x="501" y="75" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(530,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> async</text></g></a> <a href="/2022/talks/dbus" title="The Wheels on D-Bus" data-slug="dbus"> <title> 3:15- 3:35 The Wheels on D-Bus</title> <rect x="588" y="75" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(617,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> dbus</text></g></a> <a href="/2022/talks/localizing" title="Pre-localizing Emacs" data-slug="localizing"> <title> 4:00- 4:10 Pre-localizing Emacs</title> <rect x="658" y="75" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(671,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> localizing</text></g></a> <a href="/2022/talks/python" title="Short hyperlinks to Python docs" data-slug="python"> <title> 4:30- 4:35 Short hyperlinks to Python docs</title> <rect stroke-width="3" x="705" y="75" opacity="0.8" width="7" height="59" stroke="black" stroke-dasharray="5,5,5" fill="skyblue"></rect> <g transform="translate(710,133)"> <text font-weight="bold" fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> python</text></g></a> <g transform="translate(0,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 9 AM</text></g> <g transform="translate(94,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 10 AM</text></g> <g transform="translate(188,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 11 AM</text></g> <g transform="translate(282,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 12 PM</text></g> <g transform="translate(376,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 1 PM</text></g> <g transform="translate(470,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 2 PM</text></g> <g transform="translate(564,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 3 PM</text></g> <g transform="translate(658,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 4 PM</text></g> <g transform="translate(752,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 5 PM</text></g></svg> +<svg width="800" height="150" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <title> Schedule for Sunday</title> <rect width="800" height="150" x="0" y="0" fill="white"></rect> <text font-size="10" fill="black" y="12" x="3"> Sunday</text> <a href="/2022/talks/sun-open" title="Sunday opening remarks" data-slug="sun-open"> <title> 9:00- 9:05 Sunday opening remarks</title> <rect x="0" y="15" opacity="0.5" width="7" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(5,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> sun-open</text></g></a> <a href="/2022/talks/survey" title="Results of the 2022 Emacs Survey" data-slug="survey"> <title> 9:06- 9:26 Results of the 2022 Emacs Survey</title> <rect x="9" y="15" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(38,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> survey</text></g></a> <a href="/2022/talks/orgyear" title="This Year in Org" data-slug="orgyear"> <title> 9:35- 9:45 This Year in Org</title> <rect x="54" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(67,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> orgyear</text></g></a> <a href="/2022/talks/rolodex" title="Build a Zettelkasten with the Hyperbole Rolodex" data-slug="rolodex"> <title> 9:57-10:22 Build a Zettelkasten with the Hyperbole Rolodex</title> <rect x="89" y="15" opacity="0.5" width="39" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(126,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> rolodex</text></g></a> <a href="/2022/talks/orgsuperlinks" title="Linking headings with org-super-links (poor-man's Zettelkasten)" data-slug="orgsuperlinks"> <title> 10:40-10:50 Linking headings with org-super-links (poor-man's Zettelkasten)</title> <rect x="156" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(169,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> orgsuperlinks</text></g></a> <a href="/2022/talks/orgvm" title="orgvm: a simple HTTP server for org" data-slug="orgvm"> <title> 11:10-11:20 orgvm: a simple HTTP server for org</title> <rect x="203" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(216,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> orgvm</text></g></a> <a href="/2022/talks/hyperorg" title="Powerful productivity with Hyperbole and Org Mode" data-slug="hyperorg"> <title> 1:00- 1:30 Powerful productivity with Hyperbole and Org Mode</title> <rect x="376" y="15" opacity="0.5" width="47" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(421,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> hyperorg</text></g></a> <a href="/2022/talks/workflows" title="Org workflows for developers" data-slug="workflows"> <title> 1:50- 2:15 Org workflows for developers</title> <rect x="454" y="15" opacity="0.5" width="39" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(491,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> workflows</text></g></a> <a href="/2022/talks/grail" title="GRAIL---A Generalized Representation and Aggregation of Information Layers" data-slug="grail"> <title> 2:35- 2:55 GRAIL---A Generalized Representation and Aggregation of Information Layers</title> <rect x="525" y="15" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(554,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> grail</text></g></a> <a href="/2022/talks/indieweb" title="Putting Org Mode on the Indieweb" data-slug="indieweb"> <title> 3:25- 3:45 Putting Org Mode on the Indieweb</title> <rect x="603" y="15" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(632,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> indieweb</text></g></a> <a href="/2022/talks/devel" title="Emacs development updates" data-slug="devel"> <title> 4:05- 4:15 Emacs development updates</title> <rect x="666" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="5,5,5" fill="peachpuff"></rect> <g transform="translate(679,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> devel</text></g></a> <a href="/2022/talks/fanfare" title="Fanfare for the Common Emacs User" data-slug="fanfare"> <title> 4:25- 4:35 Fanfare for the Common Emacs User</title> <rect x="698" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(711,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> fanfare</text></g></a> <a href="/2022/talks/sun-close" title="Sunday closing remarks" data-slug="sun-close"> <title> 4:50- 5:00 Sunday closing remarks</title> <rect x="737" y="15" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="peachpuff"></rect> <g transform="translate(750,73)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> sun-close</text></g></a> <a href="/2022/talks/rde" title="rde Emacs introduction" data-slug="rde"> <title> 10:00-10:25 rde Emacs introduction</title> <rect x="94" y="75" opacity="0.5" width="39" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(131,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> rde</text></g></a> <a href="/2022/talks/justl" title="justl: Driving recipes within Emacs" data-slug="justl"> <title> 10:50-11:05 justl: Driving recipes within Emacs</title> <rect x="172" y="75" opacity="0.5" width="23" height="59" stroke="black" stroke-dasharray="5,5,5" fill="skyblue"></rect> <g transform="translate(193,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> justl</text></g></a> <a href="/2022/talks/rms" title="What I'd like to see in Emacs" data-slug="rms"> <title> 11:15-11:35 What I'd like to see in Emacs</title> <rect x="211" y="75" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="5,5,5" fill="skyblue"></rect> <g transform="translate(240,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> rms</text></g></a> <a href="/2022/talks/detached" title="Getting detached from Emacs" data-slug="detached"> <title> 1:01- 1:16 Getting detached from Emacs</title> <rect x="378" y="75" opacity="0.5" width="23" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(399,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> detached</text></g></a> <a href="/2022/talks/eshell" title="Top 10 reasons why you should be using Eshell" data-slug="eshell"> <title> 1:40- 1:55 Top 10 reasons why you should be using Eshell</title> <rect x="439" y="75" opacity="0.5" width="23" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(460,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> eshell</text></g></a> <a href="/2022/talks/async" title="Emacs was async before async was cool" data-slug="async"> <title> 2:20- 2:40 Emacs was async before async was cool</title> <rect x="501" y="75" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(530,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> async</text></g></a> <a href="/2022/talks/dbus" title="The Wheels on D-Bus" data-slug="dbus"> <title> 3:15- 3:35 The Wheels on D-Bus</title> <rect x="588" y="75" opacity="0.5" width="31" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(617,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> dbus</text></g></a> <a href="/2022/talks/localizing" title="Pre-localizing Emacs" data-slug="localizing"> <title> 4:00- 4:10 Pre-localizing Emacs</title> <rect x="658" y="75" opacity="0.5" width="15" height="59" stroke="black" stroke-dasharray="" fill="skyblue"></rect> <g transform="translate(671,133)"> <text fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> localizing</text></g></a> <a href="/2022/talks/python" title="Short hyperlinks to Python docs" data-slug="python"> <title> 4:30- 4:35 Short hyperlinks to Python docs</title> <rect stroke-width="3" x="705" y="75" opacity="0.8" width="7" height="59" stroke="black" stroke-dasharray="5,5,5" fill="skyblue"></rect> <g transform="translate(710,133)"> <text font-weight="bold" fill="black" x="0" y="0" font-size="10" transform="rotate(-90)"> python</text></g></a> <g transform="translate(0,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 9 AM</text></g> <g transform="translate(94,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 10 AM</text></g> <g transform="translate(188,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 11 AM</text></g> <g transform="translate(282,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 12 PM</text></g> <g transform="translate(376,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 1 PM</text></g> <g transform="translate(470,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 2 PM</text></g> <g transform="translate(564,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 3 PM</text></g> <g transform="translate(658,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 4 PM</text></g> <g transform="translate(752,15)"> <line stroke="darkgray" x1="0" y1="0" x2="0" y2="120"></line> <text fill="black" x="0" y="133" font-size="10" text-anchor="left"> 5 PM</text></g></svg> </div> [[!toc ]] -Format: 5-min talk followed by IRC Q&A (<a href="https://chat.emacsconf.org/?join=emacsconf,emacsconf-org,emacsconf-accessible,emacsconf-gen,emacsconf-dev">#emacsconf-dev</a>) +Format: 15-min talk followed by IRC Q&A (<a href="https://chat.emacsconf.org/?join=emacsconf,emacsconf-org,emacsconf-accessible,emacsconf-gen,emacsconf-dev">#emacsconf-dev</a>) Etherpad: <https://pad.emacsconf.org/2022-python> Discuss on IRC: [#emacsconf-dev](https://chat.emacsconf.org/?join=emacsconf,emacsconf-dev) -Status: Waiting for video from speaker +Status: Now playing on the conference livestream <div>Times in different timezones:</div><div class="times" start="2022-12-04T21:30:00Z" end="2022-12-04T21:35:00Z"><div class="conf-time">Sunday, Dec 4 2022, ~4:30 PM - 4:35 PM EST (US/Eastern)</div><div class="others"><div>which is the same as:</div>Sunday, Dec 4 2022, ~3:30 PM - 3:35 PM CST (US/Central)<br />Sunday, Dec 4 2022, ~2:30 PM - 2:35 PM MST (US/Mountain)<br />Sunday, Dec 4 2022, ~1:30 PM - 1:35 PM PST (US/Pacific)<br />Sunday, Dec 4 2022, ~9:30 PM - 9:35 PM UTC <br />Sunday, Dec 4 2022, ~10:30 PM - 10:35 PM CET (Europe/Paris)<br />Sunday, Dec 4 2022, ~11:30 PM - 11:35 PM EET (Europe/Athens)<br />Monday, Dec 5 2022, ~3:00 AM - 3:05 AM IST (Asia/Kolkata)<br />Monday, Dec 5 2022, ~5:30 AM - 5:35 AM +08 (Asia/Singapore)<br />Monday, Dec 5 2022, ~6:30 AM - 6:35 AM JST (Asia/Tokyo)</div></div><div><a href="/2022/watch/dev/">Find out how to watch and participate</a></div> +[[!template id="vid" vidid="python-mainVideo" src="https://media.emacsconf.org/2022/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.webm" poster="https://media.emacsconf.org/2022/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.png" ${captions} +size="48M" duration="14:03" other_resources="""[Download --main.webm (48MB)](https://media.emacsconf.org/2022/emacsconf-2022-python--short-hyperlinks-to-python-docs--eduardo-ochs--main.webm) +"""]] + # Description |