summaryrefslogtreecommitdiffstats
path: root/2024/captions/emacsconf-2024-emacs30--emacs-30-highlights--philip-kaludercic--main.vtt
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--2024/captions/emacsconf-2024-emacs30--emacs-30-highlights--philip-kaludercic--main.vtt899
1 files changed, 445 insertions, 454 deletions
diff --git a/2024/captions/emacsconf-2024-emacs30--emacs-30-highlights--philip-kaludercic--main.vtt b/2024/captions/emacsconf-2024-emacs30--emacs-30-highlights--philip-kaludercic--main.vtt
index f0d08f0b..fba04b0a 100644
--- a/2024/captions/emacsconf-2024-emacs30--emacs-30-highlights--philip-kaludercic--main.vtt
+++ b/2024/captions/emacsconf-2024-emacs30--emacs-30-highlights--philip-kaludercic--main.vtt
@@ -1,1361 +1,1352 @@
-WEBVTT captioned by anush and sachac, checked by anush and bhavin
+WEBVTT
NOTE Introduction
-00:00.000 --> 00:06.066
+00:00:00.000 --> 00:00:06.119
Hello, and welcome to Emacs 30 Highlights at EmacsConf 2024.
-00:06.100 --> 00:08.833
+00:00:06.120 --> 00:00:08.839
Before I begin, I'd like to thank the organizers
-00:08.866 --> 00:11.800
+00:00:08.840 --> 00:00:11.799
and everyone involved for putting this all together.
-00:11.800 --> 00:13.733
+00:00:11.800 --> 00:00:13.759
While this talk is being pre-recorded,
-00:13.766 --> 00:15.233
+00:00:13.760 --> 00:00:15.239
my experience from the last few years
-00:15.266 --> 00:19.100
+00:00:15.240 --> 00:00:19.159
assures me that it will be a great experience for everyone.
-00:19.133 --> 00:21.300
+00:00:19.160 --> 00:00:21.359
My name is Philip Kaludercic.
-00:21.333 --> 00:24.466
+00:00:21.360 --> 00:00:24.479
I am a core contributor and ELPA co-maintainer.
-00:24.500 --> 00:26.066
+00:00:24.480 --> 00:00:26.079
I was honored when Sacha asked me
-00:26.100 --> 00:28.333
+00:00:26.080 --> 00:00:28.359
to take over the slot for this year.
-00:28.366 --> 00:29.866
+00:00:28.360 --> 00:00:29.879
In the past few iterations,
-00:29.900 --> 00:32.133
+00:00:29.880 --> 00:00:32.199
John Wiegley has filled a similar presentation
-00:32.166 --> 00:35.666
+00:00:32.200 --> 00:00:35.679
focusing on more general Emacs development updates.
-00:35.700 --> 00:00:38.501
+00:00:35.680 --> 00:00:38.519
This year, I will specifically focus on
-00:00:38.502 --> 00:00:41.900
+00:00:38.520 --> 00:00:41.919
highlight features from the upcoming Emacs 30 release,
-00:41.933 --> 00:44.200
+00:00:41.920 --> 00:00:45.879
which might or might not have been released
-00:44.200 --> 00:00:48.059
+00:00:45.880 --> 00:00:48.079
by the time you are seeing this.
-00:00:48.060 --> 00:51.266
+00:00:48.080 --> 00:00:51.079
As you can imagine, everything new about Emacs
-00:51.300 --> 00:55.133
+00:00:51.080 --> 00:00:55.519
can always be found in the Emacs NEWS file.
-00:55.166 --> 00:57.100
+00:00:55.520 --> 00:00:57.079
Or, alternatively,
-00:57.133 --> 01:01.800
+00:00:57.080 --> 00:01:01.919
if one doesn't want to read through the 3,000 lines here,
-01:01.800 --> 01:05.233
+00:01:01.920 --> 00:01:05.279
one can also take a look at the Emacs FAQ
-01:05.266 --> 01:08.000
+00:01:05.280 --> 00:01:07.999
and then go to the what's new about
-01:08.000 --> 01:12.300
+00:01:08.000 --> 00:01:10.079
or what's different about Emacs 30 node.
-01:12.333 --> 01:14.700
+00:01:10.080 --> 00:01:14.759
Next to these two official options,
-01:14.733 --> 01:18.200
+00:01:14.760 --> 00:01:18.599
I also have a page on Emacs Wiki
-01:18.200 --> 01:21.300
+00:01:18.600 --> 00:01:20.439
called EmacsThirtyHighlights,
-01:21.333 --> 01:24.266
+00:01:20.440 --> 00:01:24.279
highlighting some of the interesting features
-01:24.300 --> 01:28.433
+00:01:24.280 --> 00:01:28.439
with some context and suggestions on how to try them out.
-01:28.466 --> 01:30.033
+00:01:28.440 --> 00:01:30.039
This is more of a collaborative effort.
-01:30.066 --> 01:32.733
+00:01:30.040 --> 00:01:32.719
So if you see this and think something is missing,
-01:32.766 --> 01:34.500
+00:01:32.720 --> 00:01:34.519
feel free to add it.
-01:34.533 --> 01:36.833
+00:01:34.520 --> 00:01:36.839
So without further ado,
-01:36.866 --> 01:41.800
+00:01:36.840 --> 00:01:41.759
let's begin taking a look at new features in Emacs 30.
NOTE Android
-01:41.800 --> 01:44.700
+00:01:41.760 --> 00:01:44.679
The biggest one, and the one I want to mention first,
-01:44.733 --> 01:49.033
+00:01:44.680 --> 00:01:49.039
is Android support, native Android support.
-01:49.066 --> 01:51.833
+00:01:49.040 --> 00:01:51.879
As you can see here, Emacs has been ported
-01:51.866 --> 01:53.666
+00:01:51.880 --> 00:01:53.639
to the Android operating system.
-01:53.700 --> 01:56.500
+00:01:53.640 --> 00:01:56.479
What this means is that from Emacs 30 onwards,
-01:56.533 --> 02:01.066
+00:01:56.480 --> 00:02:01.279
you can build Android to target Android devices natively
-02:01.100 --> 02:06.733
+00:02:01.280 --> 00:02:06.759
and using a graphical interface.
-02:06.766 --> 02:08.433
+00:02:06.760 --> 00:02:08.399
While it has been possible to run Emacs
-02:08.466 --> 02:11.133
+00:02:08.400 --> 00:02:11.159
inside of terminal emulators on Android for a while,
-02:11.166 --> 02:13.900
+00:02:11.160 --> 00:02:13.919
this actually means that you can use Emacs
-02:13.933 --> 02:17.533
+00:02:13.920 --> 00:02:17.519
on an Android device, a phone or a tablet,
-02:17.566 --> 02:20.933
+00:02:17.520 --> 00:02:20.959
and have all the usual advantages from GUI Emacs,
-02:20.966 --> 02:23.466
+00:02:20.960 --> 00:02:23.479
such as the ability to bind all commands
-02:23.500 --> 02:25.466
+00:02:23.480 --> 00:02:25.479
without having to worry about--
-02:25.500 --> 02:27.266
+00:02:25.480 --> 00:02:27.279
all keys without having to worry
-02:27.300 --> 02:29.033
+00:02:27.280 --> 00:02:29.359
about terminal compatibility issues,
-02:29.066 --> 02:32.733
+00:02:29.360 --> 00:02:32.759
displaying images and multiple fonts
-02:32.766 --> 02:35.333
+00:02:32.760 --> 00:02:35.359
on the same display of different sizes.
-02:35.366 --> 02:37.300
+00:02:35.360 --> 00:02:37.279
I should have a recording
-02:37.333 --> 02:42.200
+00:02:37.280 --> 00:02:42.199
of that somewhere here--here we are--
-02:42.200 --> 02:44.100
+00:02:42.200 --> 00:02:44.439
which I made earlier on my phone,
-02:44.133 --> 02:47.266
+00:02:44.440 --> 00:02:47.319
because I'm recording this on a laptop--
-02:47.300 --> 02:50.466
+00:02:47.320 --> 00:02:50.479
where we can see how touch interaction works
-02:50.500 --> 02:53.333
+00:02:50.480 --> 00:02:53.199
on an Android phone. I can switch between buffers.
-02:53.366 --> 02:56.100
+00:02:53.200 --> 00:02:56.119
Here I've connected an external keyboard,
-02:56.133 --> 02:57.800
+00:02:56.120 --> 00:02:58.559
opening the Emacs website.
-02:57.800 --> 00:03:02.559
+00:02:58.560 --> 00:03:02.679
We have images that we can interact with.
-00:03:02.560 --> 00:03:04.319
+00:03:02.680 --> 00:03:05.319
We could resize them if we wanted to
-00:03:04.320 --> 03:07.400
+00:03:05.320 --> 00:03:07.559
with the image resizing commands.
-03:07.400 --> 03:10.300
+00:03:07.560 --> 00:03:10.359
Pinch-to-zoom works, so it
-03:10.333 --> 03:12.733
+00:03:10.360 --> 00:03:12.759
does realize what touchscreen interactions are.
-03:12.766 --> 03:15.233
+00:03:12.760 --> 00:03:15.239
With an external mouse, and for example,
-03:15.266 --> 03:17.800
+00:03:15.240 --> 00:03:17.799
enabling context menu mode,
-03:17.800 --> 03:23.066
+00:03:17.800 --> 00:03:23.079
I can even pop up little interaction windows,
-03:23.100 --> 00:03:28.139
+00:03:23.080 --> 00:03:27.239
which one you would usually also know from GUI Emacs.
-00:03:28.140 --> 03:33.200
+00:03:27.240 --> 00:03:32.959
TUI Emacs actually also supports them since a while now.
-03:33.200 --> 03:34.600
+00:03:32.960 --> 00:03:34.639
And in this case, I'm demonstrating
-03:34.600 --> 03:36.000
+00:03:34.640 --> 00:03:35.999
how even the touchscreen events
-03:36.000 --> 03:39.133
+00:03:36.000 --> 00:03:39.119
can be inspected using the usual help system,
-03:39.166 --> 03:43.333
+00:03:39.120 --> 00:03:43.359
and how context-mode notices
-03:43.366 --> 03:45.200
+00:03:43.360 --> 00:03:45.239
where we are and allows me to, for example,
-03:45.200 --> 03:47.800
+00:03:45.240 --> 00:03:47.799
evaluate this specific region,
-03:47.800 --> 03:49.300
+00:03:47.800 --> 00:03:49.079
which I've highlighted down there,
-03:49.333 --> 03:58.300
+00:03:49.080 --> 00:03:58.319
binding a command to touch-screen-scroll. Yeah.
-03:58.333 --> 04:00.533
+00:03:58.320 --> 00:04:00.479
One should note that these additions,
-04:00.566 --> 04:02.400
+00:04:00.480 --> 00:04:02.359
for example touchscreen interaction,
-04:02.400 --> 04:03.833
+00:04:02.360 --> 00:04:04.159
are not specific to Android,
-04:03.866 --> 04:07.066
+00:04:04.160 --> 00:04:06.839
but they also are supported in other operating systems,
-04:07.100 --> 04:12.200
+00:04:06.840 --> 00:04:12.279
such as Wayland and Xorg, which are not operating systems,
-04:12.200 --> 04:15.300
+00:04:12.280 --> 00:04:15.279
and Windows, insofar as they have touchscreen,
-04:15.333 --> 00:04:18.419
+00:04:15.280 --> 00:04:17.319
and devices have touchscreen support.
-00:04:18.420 --> 04:21.300
+00:04:17.320 --> 00:04:21.239
One should mention, or I want to mention,
-04:21.333 --> 04:24.666
+00:04:21.240 --> 00:04:24.039
that the main developer behind this feature, Po Lu,
-04:24.700 --> 04:27.500
+00:04:24.040 --> 00:04:27.319
should be complimented for the additional effort he put
-04:27.533 --> 00:04:31.019
+00:04:27.320 --> 00:04:29.759
into making sure that Emacs for Android
-00:04:31.020 --> 04:34.133
+00:04:29.760 --> 00:04:33.719
can be built using only a free software toolchain,
-04:34.166 --> 00:04:36.359
+00:04:33.720 --> 00:04:36.999
which is certainly not something one has come to expect
-00:04:36.360 --> 04:40.700
+00:04:37.000 --> 00:04:40.759
from working on Android applications,
-04:40.733 --> 04:43.833
+00:04:40.760 --> 00:04:43.839
as usually you have to agree to some terms and conditions
-04:43.866 --> 00:04:46.519
+00:04:43.840 --> 00:04:46.479
for Google-specific software.
-00:04:46.520 --> 04:49.633
+00:04:46.480 --> 00:04:49.639
Final note is that if you try and look for this online,
-04:49.666 --> 04:52.133
+00:04:49.640 --> 00:04:52.119
there are APKs you can find,
-04:52.166 --> 04:54.666
+00:04:52.120 --> 00:04:54.679
but some of them might be outdated.
-04:54.700 --> 04:59.333
+00:04:54.680 --> 00:04:59.359
To the best of my knowledge, Po Lu has...
-04:59.366 --> 05:03.400
+00:04:59.360 --> 00:05:02.399
Emacs 30 Android Sourceforge...
-05:03.400 --> 05:06.500
+00:05:02.400 --> 00:05:06.759
He has set up some system where here in Sourceforge,
-05:06.533 --> 05:12.433
+00:05:06.760 --> 00:05:10.159
there are regular and updated
-05:12.466 --> 05:14.500
+00:05:10.160 --> 00:05:14.519
APK files which you can download
-05:14.533 --> 05:16.933
+00:05:14.520 --> 00:05:17.039
to avoid having to build it yourself,
-05:16.966 --> 05:18.866
+00:05:17.040 --> 00:05:18.559
testing out the newest version
-05:18.900 --> 05:24.133
+00:05:18.560 --> 00:05:30.639
in case there are some bugs which you'd like to report.
-05:24.166 --> 05:33.100
+00:05:30.640 --> 00:05:33.119
Which-key is a package which has now been moved
-05:33.133 --> 05:35.266
+00:05:33.120 --> 00:05:34.719
from ELPA to the core.
-05:35.300 --> 00:05:39.179
+00:05:34.720 --> 00:05:38.879
If you haven't heard of which-key before, the idea is,
-00:05:39.180 --> 05:41.633
+00:05:38.880 --> 00:05:41.399
or the general pitch is that which-key
-05:41.666 --> 05:45.233
+00:05:41.400 --> 00:05:45.279
is a additional documentation interface for Emacs
-05:45.266 --> 05:49.700
+00:05:45.280 --> 00:05:49.639
for displaying various keys which you could input,
-05:49.733 --> 00:05:53.439
+00:05:49.640 --> 00:05:52.679
or various keys and key maps
-00:05:53.440 --> 05:54.833
+00:05:52.680 --> 00:05:55.479
that have been partially inputted.
-05:54.866 --> 05:57.633
+00:05:55.480 --> 00:05:57.639
A better way to demonstrate this
-05:57.666 --> 05:59.300
+00:05:57.640 --> 00:05:59.319
or to explain this is just to show it.
-05:59.333 --> 06:03.466
+00:05:59.320 --> 00:06:03.519
If we enable the which-key mode--it's a global minor mode--
-06:03.500 --> 06:06.333
+00:06:03.520 --> 00:06:06.399
then I can press, for example, C-x,
-06:06.366 --> 06:08.700
+00:06:06.400 --> 00:06:08.719
which is a prefix for the C-x keymap.
-06:08.733 --> 06:12.433
+00:06:08.720 --> 00:06:11.719
Then down here in the buffer, in this window down here,
-06:12.466 --> 06:15.333
+00:06:11.720 --> 00:06:15.599
we see various commands which we could invoke
-06:15.366 --> 06:17.900
+00:06:15.600 --> 00:06:17.919
and the keys to invoke them with.
-06:17.933 --> 06:23.000
+00:06:17.920 --> 00:06:23.039
For example, if I wanted to say C-x i for insert-file,
-06:23.000 --> 06:27.233
+00:06:23.040 --> 00:06:27.319
then I just have to press i to highlight it once again.
-06:27.266 --> 06:32.600
+00:06:27.320 --> 00:06:32.559
It should be down here. Pressing i without having to repeat
-06:32.600 --> 06:34.733
+00:06:32.560 --> 00:06:34.759
the entire key code again,
-06:34.766 --> 06:37.200
+00:06:34.760 --> 00:06:37.719
the partial key code again, just works.
-06:37.200 --> 06:41.533
+00:06:37.720 --> 00:06:41.679
This is different from the feature which Emacs has already,
-06:41.566 --> 06:45.400
+00:06:41.680 --> 00:06:45.519
which is if you have input the partial keychord,
-06:45.400 --> 06:47.033
+00:06:45.520 --> 00:06:47.039
you can press C-h
-06:47.066 --> 06:51.000
+00:06:47.040 --> 00:06:50.959
and then a help buffer pops up with a listing
-06:51.000 --> 06:54.066
+00:06:50.960 --> 00:06:54.159
of all keybindings that start with C-x.
-06:54.100 --> 06:56.633
+00:06:54.160 --> 00:06:56.639
The information is the same, the presentation is different,
-06:56.666 --> 06:59.066
+00:06:56.640 --> 00:06:59.159
because now if I wanted to do C-x i,
-06:59.100 --> 00:07:03.339
+00:06:59.160 --> 00:07:02.159
I have to repeat the entire keychord again.
-00:07:03.340 --> 07:09.466
+00:07:02.160 --> 00:07:09.479
So it's a matter of personal preference, which you prefer.
-07:09.500 --> 00:07:10.959
+00:07:09.480 --> 00:07:12.519
This is more of a traditional static approach
-00:07:10.960 --> 07:19.633
+00:07:12.520 --> 00:07:19.639
because I get a help buffer which I can search
-07:19.666 --> 07:20.900
+00:07:19.640 --> 00:07:21.119
using usual key commands,
-07:20.933 --> 07:28.133
+00:07:21.120 --> 00:07:28.159
while which-key is more of a transient and modern.
-07:28.166 --> 07:31.400
+00:07:28.160 --> 00:07:30.119
Some might prefer that approach
-07:31.400 --> 00:07:35.719
+00:07:30.120 --> 00:07:33.079
to solving the same problem.
-00:07:35.720 --> 07:39.100
+00:07:33.080 --> 00:07:39.119
Also, don't forget to check out the customization group
-07:39.133 --> 07:41.933
+00:07:39.120 --> 00:07:41.959
for which-key which has a number of options
-07:41.966 --> 00:07:45.719
+00:07:41.960 --> 00:07:43.679
which you might or might not be interested in.
NOTE EditorConfig
-00:07:45.720 --> 07:50.866
+00:07:43.680 --> 00:07:50.879
Next up, Emacs 30 has built-in EditorConfig support.
-07:50.900 --> 07:53.633
+00:07:50.880 --> 00:07:53.679
If you have not heard of EditorConfig before,
-07:53.666 --> 00:07:56.639
+00:07:53.680 --> 00:07:57.319
I believe I've linked to it down here somewhere.
-00:07:56.640 --> 00:08:00.119
+00:07:57.320 --> 00:08:02.239
Ah, there it is, EditorConfig.
-00:08:00.120 --> 00:08:09.419
+00:08:02.240 --> 00:08:06.519
This is a file format used to specify
-00:08:09.420 --> 08:12.133
+00:08:06.520 --> 00:08:11.959
common formatting rules in an editor-agnostic way.
-08:12.166 --> 08:16.266
+00:08:11.960 --> 00:08:16.319
You might compare it to .dir-locals.el files,
-08:16.300 --> 08:19.333
+00:08:16.320 --> 00:08:19.159
which is a sort of an s-expression
-08:19.366 --> 08:22.233
+00:08:19.160 --> 00:08:22.159
for setting file-local variables in Emacs.
-08:22.266 --> 08:27.266
+00:08:22.160 --> 00:08:25.639
Of course, this is restricted to the common subset
-08:27.300 --> 08:29.400
+00:08:25.640 --> 00:08:28.559
of what all editors should understand.
-08:29.400 --> 08:31.833
+00:08:28.560 --> 00:08:31.839
For example, indentation styles,
-08:31.866 --> 00:08:35.119
+00:08:31.840 --> 00:08:34.239
whether you prefer tabs or spaces,
-00:08:35.120 --> 08:38.733
+00:08:34.240 --> 00:08:38.759
tab width, file encoding, and so on.
-08:38.766 --> 00:08:43.919
+00:08:38.760 --> 00:08:42.559
So it's nothing too advanced, but it's something...
-00:08:43.920 --> 08:48.500
+00:08:42.560 --> 00:08:48.559
It is a file format which one sees popping up more
-08:48.533 --> 08:50.433
+00:08:48.560 --> 00:08:50.439
and more often in lots of projects
-08:50.466 --> 08:53.600
+00:08:50.440 --> 00:08:53.479
which want to enforce a consistent indentation style
-08:53.600 --> 08:56.633
+00:08:53.480 --> 00:08:56.639
or formatting rules for all editors in a project.
-08:56.666 --> 09:00.200
+00:08:56.640 --> 00:09:00.159
Having this built in is certainly useful in Emacs.
-09:00.200 --> 09:03.466
+00:09:00.160 --> 00:09:04.439
Though one should note that it's not enabled by default.
-09:03.500 --> 00:09:10.939
+00:09:04.440 --> 00:09:09.079
You still have to enable the global minor mode,
-00:09:10.940 --> 09:14.200
+00:09:09.080 --> 00:09:14.239
which is simply turning on this one option.
-09:14.200 --> 09:15.500
+00:09:14.240 --> 00:09:15.599
Shouldn't be more than that,
-09:15.533 --> 09:18.633
+00:09:15.600 --> 00:09:18.759
and then Emacs will respect the rules.
-09:18.666 --> 00:09:23.640
+00:09:18.760 --> 00:09:31.399
If it finds a .editorconfig file in the project directory,
-00:09:23.641 --> 00:09:25.320
+00:09:31.400 --> 00:09:35.839
then it will respect those rules
-00:09:25.321 --> 00:09:27.320
+00:09:35.840 --> 00:09:38.439
without having to do anything else.
NOTE use-package integration with package-vc
-00:09:27.310 --> 00:09:33.567
+00:09:38.440 --> 00:09:45.039
Next up, use-package integration with package-vc.
-00:09:33.568 --> 00:09:36.533
+00:09:45.040 --> 00:09:48.039
For those not familiar with either of the two,
-00:09:36.534 --> 00:09:37.533
+00:09:48.040 --> 00:09:49.519
or at least one of the two,
-00:09:37.534 --> 00:09:40.699
+00:09:49.520 --> 00:09:52.159
use-package is a popular configuration macro.
-00:09:40.700 --> 00:09:42.833
+00:09:52.160 --> 00:09:54.399
What it does is it allows
-00:09:42.866 --> 00:09:46.233
+00:09:54.400 --> 00:09:56.959
users to declaratively specify packages
-00:09:46.266 --> 00:09:48.900
+00:09:56.960 --> 00:10:00.399
they would like to have installed and configured
-00:09:48.900 --> 00:09:51.659
+00:10:00.400 --> 00:10:01.759
in their configuration file,
-00:09:51.660 --> 00:09:54.400
+00:10:01.760 --> 00:10:05.879
so that, for example, if you copy your init.el
-00:09:54.433 --> 00:09:55.900
+00:10:05.880 --> 00:10:07.399
from one system to another,
-00:09:55.900 --> 00:09:58.500
+00:10:07.400 --> 00:10:09.959
it could bootstrap the entire configuration,
-00:09:58.500 --> 00:10:00.733
+00:10:09.960 --> 00:10:12.199
downloading all the packages you want
-00:10:00.766 --> 00:10:02.366
+00:10:12.200 --> 00:10:13.759
without having to manually do this
-00:10:02.400 --> 00:10:05.139
+00:10:13.760 --> 00:10:15.599
on every system you'd like to use.
-00:10:05.140 --> 00:10:07.600
+00:10:15.600 --> 00:10:19.119
This allows configurations
-00:10:07.633 --> 00:10:10.859
+00:10:19.120 --> 00:10:21.319
to be self-encapsulated and portable.
-00:10:10.860 --> 00:10:15.059
+00:10:21.320 --> 00:10:27.039
package-vc is an extension of package.el,
-00:10:15.060 --> 00:10:19.400
+00:10:27.040 --> 00:10:30.919
which allows installing packages from an alternative.
-00:10:19.433 --> 00:10:22.366
+00:10:30.920 --> 00:10:33.759
Instead of using the standard way to install packages,
-00:10:22.400 --> 00:10:26.499
+00:10:33.760 --> 00:10:37.039
which is just download tarball and unpack it,
-00:10:26.500 --> 00:10:27.933
+00:10:37.040 --> 00:10:39.479
byte compile, and so on,
-00:10:27.966 --> 00:10:32.399
+00:10:39.480 --> 00:10:44.119
it will fetch the files for a package
-00:10:32.400 --> 00:10:34.966
+00:10:44.120 --> 00:10:46.519
directly from the source code repository
-00:10:35.000 --> 00:10:37.233
+00:10:46.520 --> 00:10:48.679
and initialize it in such a way
-00:10:37.266 --> 00:10:38.800
+00:10:48.680 --> 00:10:50.319
that package.el can work with it.
-00:10:38.833 --> 00:10:44.239
+00:10:50.320 --> 00:10:54.239
So it's just a front-end for installing packages.
-00:10:44.240 --> 00:10:46.500
+00:10:54.240 --> 00:10:57.999
Even though these two were added to Emacs 29,
-00:10:46.500 --> 00:10:48.366
+00:10:58.000 --> 00:10:59.919
we didn't have the time to work on the
-00:10:48.400 --> 00:10:52.500
+00:10:59.920 --> 00:11:04.159
use-package integration of package-vc into use-package,
-00:10:52.500 --> 00:10:54.600
+00:11:04.160 --> 00:11:06.079
which has been changed now.
-00:10:54.633 --> 00:11:00.139
+00:11:06.080 --> 00:11:10.039
What we have with Emacs 30 is that
-00:11:00.140 --> 00:11:02.833
+00:11:10.040 --> 00:11:14.599
there is a :vc keyword for use-package
-00:11:02.866 --> 00:11:05.200
+00:11:14.600 --> 00:11:16.919
with which we can instruct use-package
-00:11:05.233 --> 00:11:10.239
+00:11:16.920 --> 00:11:20.599
to not download a package using tarball,
-00:11:10.240 --> 00:11:12.433
+00:11:20.600 --> 00:11:23.959
but instead to fetch the source code
-00:11:12.466 --> 00:11:13.766
+00:11:23.960 --> 00:11:25.279
from a source code repository.
-00:11:13.800 --> 00:11:15.566
+00:11:25.280 --> 00:11:27.079
This is useful if you, for example,
-00:11:15.600 --> 00:11:18.200
+00:11:27.080 --> 00:11:29.759
have packages which you yourself work on
-00:11:18.233 --> 00:11:19.933
+00:11:29.760 --> 00:11:31.439
and know that you always want to have
-00:11:19.966 --> 00:11:21.900
+00:11:31.440 --> 00:11:33.399
the development version of the package
-00:11:21.900 --> 00:11:26.819
+00:11:33.400 --> 00:11:37.359
where you can directly commit changes you've made
-00:11:26.820 --> 00:11:29.733
+00:11:37.360 --> 00:11:40.399
to the repository and push them upstream.
-00:11:29.766 --> 00:11:32.100
+00:11:40.400 --> 00:11:43.919
Or, if you know that you want to contribute to a package,
-00:11:32.100 --> 00:11:34.966
+00:11:43.920 --> 00:11:46.479
you can use package-vc to download the source code,
-00:11:35.000 --> 00:11:37.366
+00:11:46.480 --> 00:11:48.879
have all the version control information,
-00:11:37.400 --> 00:11:41.739
+00:11:48.880 --> 00:11:50.559
prepare a patch and send it upstream.
-00:11:41.740 --> 00:11:43.800
+00:11:50.560 --> 00:11:54.799
In these examples here,
-00:11:43.833 --> 00:11:49.166
+00:11:54.800 --> 00:12:00.679
the first example Lisp instructs package-vc
-00:11:49.200 --> 00:11:52.366
+00:12:00.680 --> 00:12:03.879
to download the source code from a URL.
-00:11:52.400 --> 00:11:55.400
+00:12:03.880 --> 00:12:06.919
So this is a git URL where it will download
-00:11:55.433 --> 00:11:57.400
+00:12:06.920 --> 00:12:08.919
the source code from, and in this case,
-00:11:57.433 --> 00:12:00.000
+00:12:08.920 --> 00:12:11.839
choose the newest checkout of the source code,
-00:12:00.033 --> 00:12:04.939
+00:12:11.840 --> 00:12:15.799
not the latest release. Down here, we have another example.
-00:12:04.940 --> 00:12:08.766
+00:12:15.800 --> 00:12:20.319
I prefer to consider the following example here.
-00:12:08.800 --> 00:12:10.733
+00:12:20.320 --> 00:12:22.399
If we just had written this,
-00:12:10.766 --> 00:12:13.200
+00:12:22.400 --> 00:12:24.719
then package-vc would use the metadata
-00:12:13.233 --> 00:12:15.000
+00:12:24.720 --> 00:12:26.959
which an ELPA server provides
-00:12:15.033 --> 00:12:20.166
+00:12:26.960 --> 00:12:31.719
to fetch the URL from the official repository of,
-00:12:20.200 --> 00:12:22.833
+00:12:31.720 --> 00:12:34.319
in this case, BBDB, without having to...
-00:12:22.866 --> 00:12:27.733
+00:12:34.320 --> 00:12:39.239
It would be more or less the same like this up here,
-00:12:27.766 --> 00:12:32.700
+00:12:39.240 --> 00:12:44.199
with the simple difference that package-vc integration
-00:12:32.700 --> 00:12:36.300
+00:12:44.200 --> 00:12:47.839
into use-package doesn't check out the latest commit,
-00:12:36.300 --> 00:12:37.766
+00:12:47.840 --> 00:12:49.319
but the latest release,
-00:12:37.800 --> 00:12:44.979
+00:12:49.320 --> 00:12:54.519
just to keep configurations more deterministic by default.
-00:12:44.980 --> 00:12:47.566
+00:12:54.520 --> 00:12:59.399
Of course, if you prefer to use latest commit,
-00:12:47.600 --> 00:12:52.179
+00:12:59.400 --> 00:13:01.799
you can use a package-vc install command
-00:12:52.180 --> 00:12:54.933
+00:13:01.800 --> 00:13:06.279
or just update the package manually yourself,
-00:12:54.966 --> 00:13:01.779
+00:13:06.280 --> 00:13:13.059
which you can use using package-vc-upgrade.
-00:13:01.780 --> 00:13:04.366
+00:13:13.060 --> 00:13:15.879
Next, I'd like to focus on a few features
-00:13:04.400 --> 00:13:07.000
+00:13:15.880 --> 00:13:18.919
which one might not necessarily realize directly,
-00:13:07.033 --> 00:13:11.559
+00:13:18.920 --> 00:13:22.859
but will hopefully improve your experience with Emacs.
NOTE JSON
-00:13:11.560 --> 00:13:15.133
+00:13:22.860 --> 00:13:26.639
First up in this list is a new JSON parser.
-00:13:15.166 --> 00:13:21.959
+00:13:26.640 --> 00:13:29.759
Let's maybe show the source code for that one:
-00:13:21.960 --> 00:13:39.533
+00:13:29.760 --> 00:13:51.039
not json.el, json.c. The history of JSON parsing in Emacs
-00:13:39.566 --> 00:13:43.366
+00:13:51.040 --> 00:13:54.879
started with Emacs 23 with the addition of json.el.
-00:13:43.400 --> 00:13:46.766
+00:13:54.880 --> 00:13:58.239
This was the file which we had just opened a moment ago.
-00:13:46.800 --> 00:13:50.366
+00:13:58.240 --> 00:14:02.319
This is a JSON parser in Emacs Lisp.
-00:13:50.400 --> 00:13:53.233
+00:14:02.320 --> 00:14:04.759
It's fine, it does the job, but it can get slow
-00:13:53.266 --> 00:13:55.000
+00:14:04.760 --> 00:14:06.519
if we have a situation like where
-00:13:55.033 --> 00:14:00.319
+00:14:06.520 --> 00:14:11.239
Eglot uses a LSP server to communicate with
-00:14:00.320 --> 00:14:02.999
+00:14:11.240 --> 00:14:14.039
and the LSP server can get a bit chatty,
-00:14:03.000 --> 00:14:05.133
+00:14:14.040 --> 00:14:17.039
sending a lot of JSON data,
-00:14:05.166 --> 00:14:07.966
+00:14:17.040 --> 00:14:19.599
which all has to be parsed and garbage collected,
-00:14:08.000 --> 00:14:09.933
+00:14:19.600 --> 00:14:21.439
which can slow down Emacs a bit.
-00:14:09.966 --> 00:14:13.733
+00:14:21.440 --> 00:14:25.279
The situation was improved upon in Emacs 29
-00:14:13.766 --> 00:14:18.000
+00:14:25.280 --> 00:14:29.479
when JSON parsing was added to the core.
-00:14:18.033 --> 00:14:21.000
+00:14:29.480 --> 00:14:32.679
This was the json.c file, which we see on this side,
-00:14:21.033 --> 00:14:22.733
+00:14:32.680 --> 00:14:34.279
the old version of the json.c file,
-00:14:22.766 --> 00:14:26.700
+00:14:34.280 --> 00:14:38.279
which employed the Jansson library (it's the C library)
-00:14:26.700 --> 00:14:31.899
+00:14:38.280 --> 00:14:42.479
for parsing and accelerating JSON parsing in Emacs.
-00:14:31.900 --> 00:14:33.966
+00:14:42.480 --> 00:14:45.479
This was good enough,
-00:14:34.000 --> 00:14:36.200
+00:14:45.480 --> 00:14:47.719
or it certainly improved the situation
-00:14:36.233 --> 00:14:38.300
+00:14:47.720 --> 00:14:50.039
for a lot of LSP clients.
-00:14:38.300 --> 00:14:44.766
+00:14:50.040 --> 00:14:53.239
But in Emacs 30, the situation has been improved once more
-00:14:44.800 --> 00:14:49.800
+00:14:53.240 --> 00:15:01.174
with the addition of a JSON parser directly in Emacs.
-00:14:49.833 --> 00:14:53.566
+00:15:01.175 --> 00:15:03.874
So instead of using an external library,
-00:14:53.600 --> 00:14:57.400
+00:15:03.875 --> 00:15:08.879
there's a custom JSON parser written in C in the Emacs core,
-00:14:57.433 --> 00:15:01.539
+00:15:08.880 --> 00:15:12.240
which directly generates Elisp objects.
-00:15:01.540 --> 00:15:05.033
+00:15:12.241 --> 00:15:16.574
The advantage to this approach
-00:15:05.066 --> 00:15:06.433
+00:15:16.575 --> 00:15:18.007
compared to the Jansson approach
-00:15:06.466 --> 00:15:07.933
+00:15:18.008 --> 00:15:19.439
is that there's no intermediate format
-00:15:07.966 --> 00:15:09.200
+00:15:19.440 --> 00:15:20.879
which has to be allocated
-00:15:09.233 --> 00:15:11.500
+00:15:20.880 --> 00:15:23.159
and memory managed and freed again,
-00:15:11.500 --> 00:15:19.539
+00:15:23.160 --> 00:15:30.240
which of course incurs an additional performance overhead.
-00:15:19.540 --> 00:15:22.433
-Next to this, there's also a custom serializer
+00:15:30.241 --> 00:15:35.639
+There is absolutely no dependency on Jansson anymore.
-00:15:22.466 --> 00:15:29.239
-for JSON contents translating a JSON object into a string.
-
-00:15:29.240 --> 00:15:30.640
-... The consequence of this is that
-
-00:15:30.641 --> 00:15:35.519
-there is absolutely no dependency on Jansson anymore.
-
-00:15:35.520 --> 00:15:38.533
+00:15:35.640 --> 00:15:38.599
This in turn means that now all Emacs users
-00:15:38.566 --> 00:15:39.800
+00:15:38.600 --> 00:15:39.720
from Emacs 30 onwards
-00:15:39.833 --> 00:15:42.733
+00:15:39.760 --> 00:15:42.639
can take advantage of this new JSON parser
-00:15:42.766 --> 00:15:44.933
+00:15:42.640 --> 00:15:44.839
and don't have to worry about whether
-00:15:44.966 --> 00:15:47.633
+00:15:44.840 --> 00:15:47.759
or not they have Jansson, this JSON parsing library,
-00:15:47.666 --> 00:15:50.433
+00:15:47.760 --> 00:15:50.999
installed on their system or not when they want
-00:15:50.466 --> 00:15:56.679
+00:15:51.000 --> 00:15:56.799
to take advantage of this accelerated JSON parsing.
NOTE Native compilation
-00:15:56.680 --> 00:16:00.366
+00:15:56.800 --> 00:16:00.279
Next up, another behind-the-scenes feature
-00:16:00.400 --> 00:16:06.406
+00:16:00.280 --> 00:16:03.959
is that if you build Emacs on your own from source,
-00:16:06.407 --> 00:16:07.766
+00:16:03.960 --> 00:16:07.759
you might know that if you wanted
-00:16:07.800 --> 00:16:09.533
+00:16:07.760 --> 00:16:09.479
to use native compilation,
-00:16:09.566 --> 00:16:12.379
+00:16:09.480 --> 00:16:13.119
so the translation of Elisp bytecodes
-00:16:12.380 --> 00:16:15.533
+00:16:13.120 --> 00:16:15.479
to whatever the native assembly
-00:16:15.566 --> 00:16:19.133
+00:16:15.480 --> 00:16:18.999
or native instruction set is on your system,
-00:16:19.166 --> 00:16:24.339
+00:16:19.000 --> 00:16:24.199
you have to specify with native compilation.
-00:16:24.340 --> 00:16:25.933
+00:16:24.200 --> 00:16:25.839
when invoking the configure script,
-00:16:25.966 --> 00:16:28.366
+00:16:25.840 --> 00:16:28.239
otherwise it would not have been enabled at all.
-00:16:28.400 --> 00:16:32.479
+00:16:28.240 --> 00:16:31.439
With Emacs 30, this step is not necessary anymore.
-00:16:32.480 --> 00:16:36.233
+00:16:31.440 --> 00:16:36.119
The configure script will automatically check
-00:16:36.266 --> 00:16:41.700
+00:16:36.120 --> 00:16:41.639
if you have the libgccjit library installed on your system,
-00:16:41.700 --> 00:16:42.766
+00:16:41.640 --> 00:16:42.759
and if that is so,
-00:16:42.800 --> 00:16:45.566
+00:16:42.760 --> 00:16:45.519
then native compilation will be enabled by default.
-00:16:45.600 --> 00:16:49.400
+00:16:45.520 --> 00:16:49.279
In other words, if you have an issue with native compilation
-00:16:49.433 --> 00:16:52.500
+00:16:49.280 --> 00:16:52.359
or prefer not to use it for whatever reason,
-00:16:52.500 --> 00:16:55.533
+00:16:52.360 --> 00:16:55.559
you now have to type --without-native-compilation
-00:16:55.566 --> 00:16:58.433
+00:16:55.560 --> 00:16:58.199
when compiling Emacs to prevent this from happening.
-00:16:58.466 --> 00:17:02.433
+00:16:58.200 --> 00:17:02.239
But native compilation was added in Emacs 28
-00:17:02.466 --> 00:17:04.333
+00:17:02.240 --> 00:17:04.319
and has proven to be a very stable
-00:17:04.366 --> 00:17:06.233
+00:17:04.320 --> 00:17:06.159
and useful feature for most people,
-00:17:06.266 --> 00:17:09.400
+00:17:06.160 --> 00:17:09.359
so there's probably no reason to do this
-00:17:09.433 --> 00:17:11.133
+00:17:09.360 --> 00:17:11.199
and you can just invoke the configure script
-00:17:11.166 --> 00:17:16.300
+00:17:11.200 --> 00:17:16.239
with one argument less. Right, and I'd like to finish up
-00:17:16.300 --> 00:17:19.500
+00:17:16.240 --> 00:17:19.399
with a few smaller features, a few smaller highlights.
-00:17:19.500 --> 00:17:29.639
+00:17:19.400 --> 00:17:29.579
Maybe we can go back to the listing here. Here we have it.
NOTE Tree-sitter
-00:17:29.640 --> 00:17:32.833
+00:17:29.580 --> 00:17:32.799
There are a few new major modes
-00:17:32.866 --> 00:17:34.333
+00:17:32.800 --> 00:17:34.239
based on the tree-sitter library.
-00:17:34.366 --> 00:17:37.939
+00:17:34.240 --> 00:17:37.519
tree-sitter is this parser library
-00:17:37.940 --> 00:17:39.933
+00:17:37.520 --> 00:17:42.699
which has been integrated into Emacs 29.
-00:17:39.966 --> 00:17:44.100
+00:17:42.700 --> 00:17:43.999
It allows the integration
-00:17:44.100 --> 00:17:48.400
+00:17:44.000 --> 00:17:48.359
of external, specialized, and quick parsers into Emacs,
-00:17:48.433 --> 00:17:52.133
+00:17:48.360 --> 00:17:52.039
which improve stuff like syntax highlighting, indentation,
-00:17:52.166 --> 00:17:55.233
+00:17:52.040 --> 00:17:55.159
structural navigation, imenu support,
-00:17:55.266 --> 00:18:01.033
+00:17:55.160 --> 00:18:00.839
by simply having a better understanding of, for example,
-00:18:01.066 --> 00:18:03.900
+00:18:00.840 --> 00:18:03.839
a HTML file, or a Lua file, a PHP file,
-00:18:03.900 --> 00:18:06.233
+00:18:03.840 --> 00:18:06.239
than what people usually implement
-00:18:06.266 --> 00:18:10.366
+00:18:06.240 --> 00:18:10.319
using regular expressions in traditional major modes.
-00:18:10.400 --> 00:18:16.779
+00:18:10.320 --> 00:18:16.679
So, a few new major modes which you can try out here.
NOTE Completion preview mode
-00:18:16.780 --> 00:18:20.033
+00:18:16.680 --> 00:18:19.959
Another interesting feature is the completion-preview-mode.
-00:18:20.066 --> 00:18:22.966
+00:18:19.960 --> 00:18:23.079
We can maybe try it out here in the scratch buffer.
-00:18:23.000 --> 00:18:28.300
+00:18:23.080 --> 00:18:28.199
If I enable completion-preview-mode...
-00:18:28.300 --> 00:18:32.033
+00:18:28.200 --> 00:18:31.999
This is a non-global minor mode,
-00:18:32.066 --> 00:18:38.600
+00:18:32.000 --> 00:18:38.479
which will display completion options inline using overlays.
-00:18:38.633 --> 00:18:43.133
+00:18:38.480 --> 00:18:43.079
For example, if I start typing a longer symbol like define,
-00:18:43.166 --> 00:18:48.200
+00:18:43.080 --> 00:18:48.119
now we have a derived mode. It suggests me to...
-00:18:48.233 --> 00:18:51.133
+00:18:48.120 --> 00:18:51.039
I can just press TAB and then it completes the option here,
-00:18:51.166 --> 00:18:51.933
+00:18:51.040 --> 00:18:51.799
but it didn't actually...
-00:18:51.966 --> 00:18:55.333
+00:18:51.800 --> 00:18:55.279
It's not actually modifying the buffer, it's not pressing,
-00:18:55.366 --> 00:18:57.100
+00:18:55.280 --> 00:18:56.999
these are just overlays,
-00:18:57.100 --> 00:18:59.533
+00:18:57.000 --> 00:18:59.479
so if I move around, it gets deleted.
-00:18:59.566 --> 00:19:02.619
+00:18:59.480 --> 00:19:01.519
It wouldn't get saved if I were to save the buffer.
-00:19:02.620 --> 00:19:04.966
+00:19:01.520 --> 00:19:04.879
The same also should work in a shell buffer.
-00:19:05.000 --> 00:19:08.366
+00:19:04.880 --> 00:19:08.439
If I enable completion preview mode here and start...
-00:19:08.400 --> 00:19:12.800
+00:19:08.440 --> 00:19:12.719
In this case, I'm using the bash completion package,
-00:19:12.833 --> 00:19:15.000
+00:19:12.720 --> 00:19:15.159
which provides additional completion information.
-00:19:15.033 --> 00:19:17.933
+00:19:15.160 --> 00:19:17.839
This is not only limited to programming systems,
-00:19:17.966 --> 00:19:22.900
+00:19:17.840 --> 00:19:22.879
but anywhere where you have completion at point in Emacs.
-00:19:22.900 --> 00:19:26.159
+00:19:22.880 --> 00:19:26.599
I can start typing here, ignore, and put ignore-backups,
-00:19:26.160 --> 00:19:30.000
+00:19:26.600 --> 00:19:29.879
and it hints to the options which I have
-00:19:30.033 --> 00:19:34.200
+00:19:29.880 --> 00:19:33.239
and allows me to complete them quickly.
NOTE package-isolate
-00:19:34.233 --> 00:19:37.966
+00:19:33.240 --> 00:19:37.879
Another small feature is the package-isolate command.
-00:19:38.000 --> 00:19:40.000
+00:19:37.880 --> 00:19:39.959
What this does is it will start
-00:19:40.033 --> 00:19:42.800
+00:19:39.960 --> 00:19:42.719
or it will prompt me for packages
-00:19:42.833 --> 00:19:44.333
+00:19:42.720 --> 00:19:44.119
I have installed in my system
-00:19:44.366 --> 00:19:46.500
+00:19:44.120 --> 00:19:46.439
and will start an isolated
-00:19:46.500 --> 00:19:51.133
+00:19:46.440 --> 00:19:51.079
or like "emacs -Q"-ish instance of emacs
-00:19:51.166 --> 00:19:53.333
+00:19:51.080 --> 00:19:53.239
with only these packages installed.
-00:19:53.366 --> 00:20:00.439
+00:19:53.240 --> 00:20:00.359
So for example, if I said I want slime and I want diff-hl,
-00:20:00.440 --> 00:20:02.700
+00:20:00.360 --> 00:20:02.279
then this is a new Emacs window.
-00:20:02.700 --> 00:20:04.533
+00:20:02.280 --> 00:20:04.439
It's unrelated to the one around.
-00:20:04.566 --> 00:20:06.500
+00:20:04.440 --> 00:20:06.759
It uses the same executable, of course,
-00:20:06.500 --> 00:20:09.939
+00:20:06.760 --> 00:20:08.999
but will not load your configuration file
-00:20:09.940 --> 00:20:13.679
+00:20:09.000 --> 00:20:13.079
or any other further customizations on your system.
-00:20:13.680 --> 00:20:15.533
+00:20:13.080 --> 00:20:15.159
All it does, it will ensure
-00:20:15.566 --> 00:20:17.933
+00:20:15.160 --> 00:20:17.879
that these packages, which are listed here,
-00:20:17.966 --> 00:20:24.599
+00:20:17.880 --> 00:20:24.359
so in our case SLIME and dependencies of SLIME and diff-hl,
-00:20:24.600 --> 00:20:25.300
+00:20:24.360 --> 00:20:25.119
in the system
-00:20:25.300 --> 00:20:29.100
+00:20:25.120 --> 00:20:28.999
so that I could, for example, as you can see here,
-00:20:29.100 --> 00:20:32.139
+00:20:29.000 --> 00:20:32.019
diff-hl-mode works.
-00:20:32.140 --> 00:20:34.766
+00:20:32.020 --> 00:20:35.319
Okay, this is not a version-controlled file.
-00:20:34.800 --> 00:20:41.200
+00:20:35.320 --> 00:20:41.119
Maybe if we take a look at, have I enabled diff-hl-mode?
-00:20:41.233 --> 00:20:44.600
+00:20:41.120 --> 00:20:44.559
It's enabled in this case. What diff-hl-mode does
-00:20:44.633 --> 00:20:48.300
+00:20:44.560 --> 00:20:48.239
is it displays these version control changes
-00:20:48.300 --> 00:20:49.566
+00:20:48.240 --> 00:20:49.999
in the fringe of a buffer.
-00:20:49.600 --> 00:20:54.133
+00:20:50.000 --> 00:20:54.039
And even though this is a uncustomized version of Emacs,
-00:20:54.166 --> 00:20:56.333
+00:20:54.040 --> 00:20:56.279
or an uncustomized instance of Emacs,
-00:20:56.366 --> 00:20:59.000
+00:20:56.280 --> 00:20:58.919
it was easy for me to load this one package,
-00:20:59.033 --> 00:21:02.033
+00:20:58.920 --> 00:21:01.959
or these two packages and all the dependencies necessary.
-00:21:02.066 --> 00:21:05.300
+00:21:01.960 --> 00:21:04.759
As you can imagine, the main purpose for this
-00:21:05.300 --> 00:21:07.733
+00:21:04.760 --> 00:21:07.719
is to make debugging issues easier.
-00:21:07.766 --> 00:21:10.566
+00:21:07.720 --> 00:21:10.519
If you want to report about an issue
-00:21:10.600 --> 00:21:14.900
+00:21:10.520 --> 00:21:14.519
you have with a package. And if I close this, it's closed
-00:21:14.900 --> 00:21:16.919
+00:21:14.520 --> 00:21:15.959
and everything's thrown away.
NOTE Reindenting
-00:21:16.920 --> 00:21:19.000
+00:21:15.960 --> 00:21:18.959
Last up, a nice feature I think
-00:21:19.033 --> 00:21:20.933
+00:21:18.960 --> 00:21:21.199
a lot of people will appreciate is,
-00:21:20.966 --> 00:21:24.300
+00:21:21.200 --> 00:21:24.239
if you are familiar with... Let's open a text buffer.
-00:21:24.300 --> 00:21:30.279
+00:21:24.240 --> 00:21:29.119
The M-q key is traditionally bound to fill-paragraph.
-00:21:30.280 --> 00:21:32.200
+00:21:29.120 --> 00:21:32.119
What this means is that...
-00:21:32.233 --> 00:21:35.000
+00:21:32.120 --> 00:21:34.919
Let's, for example, copy this text from here
-00:21:35.033 --> 00:21:40.366
+00:21:34.920 --> 00:21:40.279
and squash it all into one line. If I press M-q here,
-00:21:40.400 --> 00:21:42.719
+00:21:40.280 --> 00:21:43.679
then the lines will be broken
-00:21:42.720 --> 00:21:49.879
+00:21:43.680 --> 00:21:49.599
according to the fill column indicator up here.
-00:21:49.880 --> 00:21:52.600
+00:21:49.600 --> 00:21:52.199
This is the traditional usage of M-q,
-00:21:52.633 --> 00:21:54.200
+00:21:52.200 --> 00:21:54.159
and it still works in text-mode buffers,
-00:21:54.233 --> 00:21:55.859
+00:21:54.160 --> 00:21:56.639
but in prog-mode buffers--
-00:21:55.860 --> 00:22:00.100
+00:21:56.640 --> 00:22:00.079
so any major mode inheriting prog-mode--
-00:22:00.100 --> 00:22:02.233
+00:22:00.080 --> 00:22:02.199
M-q will now by default be bound
-00:22:02.266 --> 00:22:09.779
+00:22:02.200 --> 00:22:09.639
to prog-fill-reindent-defun. To summarize the point,
-00:22:09.780 --> 00:22:13.433
+00:22:09.640 --> 00:22:13.359
if you are editing a string or a comment,
-00:22:13.466 --> 00:22:16.039
+00:22:13.360 --> 00:22:15.939
then the comment will be filled.
-00:22:16.040 --> 00:22:19.100
+00:22:15.940 --> 00:22:19.039
But if you are outside of a comment or outside of a string,
-00:22:19.100 --> 00:22:23.166
+00:22:19.040 --> 00:22:22.919
then the defun or the top-level construct
-00:22:23.200 --> 00:22:26.159
+00:22:22.920 --> 00:22:25.559
in the programming language will be re-indented.
-00:22:26.160 --> 00:22:34.099
+00:22:25.560 --> 00:22:33.879
Let's try that out with maybe some file I have open here.
-00:22:34.100 --> 00:22:38.800
+00:22:33.880 --> 00:22:37.719
If I'm in this... Let's choose some function,
-00:22:38.833 --> 00:22:40.733
+00:22:37.720 --> 00:22:41.279
let's take this for example.
-00:22:40.766 --> 00:22:43.959
+00:22:41.280 --> 00:22:42.879
If we followed all of this again,
-00:22:43.960 --> 00:22:47.400
+00:22:42.880 --> 00:22:46.479
and I press M-q in on this paragraph,
-00:22:47.433 --> 00:22:49.433
+00:22:46.480 --> 00:22:49.399
then the paragraph gets re-indented.
-00:22:49.466 --> 00:22:55.800
+00:22:49.400 --> 00:22:55.759
But if I'm down here and I choose to break the indentation
-00:22:55.833 --> 00:22:58.166
+00:22:55.760 --> 00:22:58.239
and then press M-q,
-00:22:58.200 --> 00:23:02.333
+00:22:58.240 --> 00:23:02.279
then as you see, it practically selected the defun
-00:23:02.366 --> 00:23:03.566
+00:23:02.280 --> 00:23:03.559
and re-indented everything
-00:23:03.600 --> 00:23:06.959
+00:23:03.560 --> 00:23:06.699
without having me to move the point around in the buffer.
-00:23:06.960 --> 00:23:08.633
+00:23:06.700 --> 00:23:08.559
So I think that's a really nice feature,
-00:23:08.666 --> 00:23:11.100
+00:23:08.560 --> 00:23:12.919
which a lot of people can appreciate.
-00:23:11.100 --> 00:23:17.939
+00:23:12.920 --> 00:23:18.279
It's one of those niceties which comes from time to time.
NOTE Wrapping up
-00:23:17.940 --> 00:23:20.633
+00:23:18.280 --> 00:23:20.599
Right, so that was my overview
-00:23:20.666 --> 00:23:22.600
+00:23:20.600 --> 00:23:22.559
of what's going to be new in Emacs 30.
-00:23:22.633 --> 00:23:24.400
+00:23:22.560 --> 00:23:24.359
I hope that most people could take away
-00:23:24.433 --> 00:23:25.579
+00:23:24.360 --> 00:23:26.159
something from this presentation
-00:23:25.580 --> 00:23:28.900
+00:23:26.160 --> 00:23:28.959
and have something to look forward
-00:23:28.900 --> 00:23:31.133
+00:23:28.960 --> 00:23:31.039
to try out after upgrading.
-00:23:31.166 --> 00:23:33.833
+00:23:31.040 --> 00:23:33.759
As mentioned initially, as of recording,
-00:23:33.866 --> 00:23:36.566
+00:23:33.760 --> 00:23:36.519
this release has not been completed yet.
-00:23:36.600 --> 00:23:38.833
+00:23:36.520 --> 00:23:38.799
If this is still not the case
-00:23:38.866 --> 00:23:40.233
+00:23:38.800 --> 00:23:40.199
when you're seeing this video,
-00:23:40.266 --> 00:23:43.833
+00:23:40.200 --> 00:23:43.799
please consider downloading and building Emacs 30 yourself.
-00:23:43.866 --> 00:23:48.200
+00:23:43.800 --> 00:23:48.159
If you have any issues, which is always the case,
-00:23:48.233 --> 00:23:56.439
+00:23:48.160 --> 00:23:51.959
please report them to using report-emacs-bug.
-00:23:56.440 --> 00:23:57.907
+00:23:51.960 --> 00:23:55.079
That will pop up a mail buffer,
-00:23:57.908 --> 00:23:59.600
+00:23:55.080 --> 00:23:59.519
and then you can describe your issue and send them out.
-00:23:59.633 --> 00:24:01.800
+00:23:59.520 --> 00:24:01.759
All bug reports are valuable,
-00:24:01.833 --> 00:24:04.433
+00:24:01.760 --> 00:24:04.359
even if they are false positives or duplicates--
-00:24:04.466 --> 00:24:05.233
+00:24:04.360 --> 00:24:05.159
it doesn't matter--
-00:24:05.266 --> 00:24:08.533
+00:24:05.160 --> 00:24:08.439
because when you take the time to submit a bug report,
-00:24:08.566 --> 00:24:12.233
+00:24:08.440 --> 00:24:12.159
which describes something that's specific to your setup,
-00:24:12.266 --> 00:24:16.700
+00:24:12.160 --> 00:24:16.639
which the developers might not have noticed or known about,
-00:24:16.700 --> 00:24:19.133
+00:24:16.640 --> 00:24:19.079
then you are certainly helping out a lot of other people
-00:24:19.166 --> 00:24:21.766
+00:24:19.080 --> 00:24:21.679
which might run into the same issue in the future.
-00:24:21.800 --> 00:24:23.200
+00:24:21.680 --> 00:24:23.119
Especially with upgrades,
-00:24:23.233 --> 00:24:26.566
+00:24:23.120 --> 00:24:26.559
it would be nice to figure out small problems
-00:24:26.600 --> 00:24:30.800
+00:24:26.560 --> 00:24:30.759
which make upgrading difficult for some people.
-00:24:30.833 --> 00:24:34.700
+00:24:30.760 --> 00:24:34.559
The ideal is, of course, to have no issues
-00:24:34.700 --> 00:24:37.199
+00:24:34.560 --> 00:24:36.159
when upgrading from one version to another.
-00:24:37.200 --> 00:24:39.566
+00:24:36.160 --> 00:24:39.519
Having said that, I thank you for your attention,
-00:24:39.600 --> 00:24:43.766
+00:24:39.520 --> 00:24:43.680
and I'm saying goodbye.