summaryrefslogtreecommitdiffstats
path: root/2020/subtitles
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith-autogen.vtt1081
-rw-r--r--2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith.vtt968
-rw-r--r--2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard-autogen.vtt1426
-rw-r--r--2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard.vtt1297
-rw-r--r--2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita-autogen.vtt1183
-rw-r--r--2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita.vtt1057
6 files changed, 3322 insertions, 3690 deletions
diff --git a/2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith-autogen.vtt b/2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith-autogen.vtt
deleted file mode 100644
index eb176536..00000000
--- a/2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith-autogen.vtt
+++ /dev/null
@@ -1,1081 +0,0 @@
-WEBVTT
-
-00:00:00.320 --> 00:00:03.280
-um so hi I'm joe corneli
-
-00:00:03.280 --> 00:00:05.920
-uh this is work I did with ray puzio and
-
-00:00:05.920 --> 00:00:06.879
-cameron smith
-
-00:00:06.879 --> 00:00:10.559
-um and they're the main protagonists in
-
-00:00:10.559 --> 00:00:11.599
-this story they
-
-00:00:11.599 --> 00:00:14.960
-are uh researchers who've been working
-
-00:00:14.960 --> 00:00:17.840
-on theoretical biology um so in a
-
-00:00:17.840 --> 00:00:20.160
-typical project they may use manxima
-
-00:00:20.160 --> 00:00:23.760
-and julia their work for biology physics
-
-00:00:23.760 --> 00:00:24.800
-and computer science
-
-00:00:24.800 --> 00:00:27.199
-computer science and the latest work in
-
-00:00:27.199 --> 00:00:29.439
-progress is on branching processes for
-
-00:00:29.439 --> 00:00:30.800
-cancer modeling so
-
-00:00:30.800 --> 00:00:34.719
-how can um Emacs possibly help
-
-00:00:34.719 --> 00:00:37.360
-let's let's have a look uh moving code
-
-00:00:37.360 --> 00:00:38.399
-and data between these different
-
-00:00:38.399 --> 00:00:39.680
-programs by hand is
-
-00:00:39.680 --> 00:00:42.000
-annoying on separate workflows for
-
-00:00:42.000 --> 00:00:43.200
-writing up notes and preparing
-
-00:00:43.200 --> 00:00:44.399
-publications
-
-00:00:44.399 --> 00:00:46.000
-is perhaps even more annoying all of
-
-00:00:46.000 --> 00:00:48.640
-it's time consuming and error-prone
-
-00:00:48.640 --> 00:00:52.000
-um so what about maybe using jupiter
-
-00:00:52.000 --> 00:00:53.760
-uh we found something called script of
-
-00:00:53.760 --> 00:00:55.199
-scripts and it solves some of those
-
-00:00:55.199 --> 00:00:58.399
-problems because you can use
-
-00:00:58.399 --> 00:01:01.120
-maximum and julia together but we were
-
-00:01:01.120 --> 00:01:02.640
-quite happy to explore emacs based
-
-00:01:02.640 --> 00:01:05.199
-solutions being emax enthusiasts and we
-
-00:01:05.199 --> 00:01:05.840
-even
-
-00:01:05.840 --> 00:01:07.760
-got cameron to be enthusiastic about
-
-00:01:07.760 --> 00:01:09.200
-doing emacs so that
-
-00:01:09.200 --> 00:01:11.600
-went nice so just here's a little
-
-00:01:11.600 --> 00:01:12.400
-feature grid
-
-00:01:12.400 --> 00:01:15.360
-of emacs org versus just sort of your
-
-00:01:15.360 --> 00:01:16.400
-generic
-
-00:01:16.400 --> 00:01:19.040
-um tools that are in a different more
-
-00:01:19.040 --> 00:01:20.960
-general ecosystem so as you can see it's
-
-00:01:20.960 --> 00:01:21.520
-quite
-
-00:01:21.520 --> 00:01:23.360
-feature complete you've got your maximo
-
-00:01:23.360 --> 00:01:25.520
-mode julia mode you can use both of them
-
-00:01:25.520 --> 00:01:27.119
-inside of org mode
-
-00:01:27.119 --> 00:01:28.720
-you can present things with word tree
-
-00:01:28.720 --> 00:01:30.240
-slide you can set up a
-
-00:01:30.240 --> 00:01:33.280
-wiki inside of orgrome this is one I
-
-00:01:33.280 --> 00:01:33.680
-found
-
-00:01:33.680 --> 00:01:35.759
-rather recently you can even use
-
-00:01:35.759 --> 00:01:37.759
-compatibly with orgrome something called
-
-00:01:37.759 --> 00:01:38.799
-log seek
-
-00:01:38.799 --> 00:01:41.520
-which is in the browser um so that's
-
-00:01:41.520 --> 00:01:42.159
-nice
-
-00:01:42.159 --> 00:01:44.320
-um you can do real-time collaborative
-
-00:01:44.320 --> 00:01:45.840
-editing um
-
-00:01:45.840 --> 00:01:47.840
-either in a kind of pairing style or in
-
-00:01:47.840 --> 00:01:49.280
-a more etherpad style
-
-00:01:49.280 --> 00:01:51.520
-obviously you can manage your references
-
-00:01:51.520 --> 00:01:54.159
-you can typeset whatever you want um you
-
-00:01:54.159 --> 00:01:55.759
-can publish work in progress on a blog
-
-00:01:55.759 --> 00:01:57.439
-and the fern is another one of these
-
-00:01:57.439 --> 00:01:58.159
-external
-
-00:01:58.159 --> 00:02:00.560
-org mode tools it's not actually any mac
-
-00:02:00.560 --> 00:02:01.360
-but works with
-
-00:02:01.360 --> 00:02:03.680
-org mode stuff and you know so we're
-
-00:02:03.680 --> 00:02:04.399
-good to go
-
-00:02:04.399 --> 00:02:06.640
-uh with all of that so what does that
-
-00:02:06.640 --> 00:02:08.000
-look like well here's
-
-00:02:08.000 --> 00:02:09.679
-a little example from before they were
-
-00:02:09.679 --> 00:02:11.599
-doing um
-
-00:02:11.599 --> 00:02:12.800
-before we started really thinking
-
-00:02:12.800 --> 00:02:14.560
-seriously about this stuff so this is
-
-00:02:14.560 --> 00:02:15.599
-just maxima
-
-00:02:15.599 --> 00:02:17.440
-well maximo doesn't have a long running
-
-00:02:17.440 --> 00:02:19.280
-process by default if you've ever used
-
-00:02:19.280 --> 00:02:20.160
-python
-
-00:02:20.160 --> 00:02:22.480
-uh you have something called sessions uh
-
-00:02:22.480 --> 00:02:23.920
-they don't have that for maxim at least
-
-00:02:23.920 --> 00:02:24.959
-not by default
-
-00:02:24.959 --> 00:02:27.599
-um so how what was the workaround
-
-00:02:27.599 --> 00:02:29.360
-there's this thing called uh
-
-00:02:29.360 --> 00:02:32.480
-solve for you here and um
-
-00:02:32.480 --> 00:02:34.879
-that shows up down below again in these
-
-00:02:34.879 --> 00:02:36.319
-angle brackets which you've seen maybe
-
-00:02:36.319 --> 00:02:37.360
-in someone else's talk
-
-00:02:37.360 --> 00:02:40.480
-uh which means go to the previous uh
-
-00:02:40.480 --> 00:02:41.920
-thing that was named soul for you
-
-00:02:41.920 --> 00:02:43.920
-and do that all over again so they do
-
-00:02:43.920 --> 00:02:45.280
-that over again
-
-00:02:45.280 --> 00:02:47.440
-and here's the little maxima code for
-
-00:02:47.440 --> 00:02:49.519
-defining you saw so you've now defined
-
-00:02:49.519 --> 00:02:50.560
-you saw
-
-00:02:50.560 --> 00:02:51.920
-and then you can use it in the next
-
-00:02:51.920 --> 00:02:54.000
-expression you get out a nice juicy
-
-00:02:54.000 --> 00:02:56.560
-zero at the end but it's a little bit a
-
-00:02:56.560 --> 00:02:57.200
-little bit
-
-00:02:57.200 --> 00:02:58.959
-like cartridge in a pear tree to have to
-
-00:02:58.959 --> 00:03:00.640
-redefine everything every time
-
-00:03:00.640 --> 00:03:02.560
-so this is clearly at the level of work
-
-00:03:02.560 --> 00:03:04.159
-around um maybe just
-
-00:03:04.159 --> 00:03:06.879
-one more time going looking through that
-
-00:03:06.879 --> 00:03:07.920
-um
-
-00:03:07.920 --> 00:03:11.599
-that stuff um
-
-00:03:11.599 --> 00:03:13.760
-sorry so uh looking through that stuff
-
-00:03:13.760 --> 00:03:15.280
-this is we're going to need something
-
-00:03:15.280 --> 00:03:17.200
-like that probably for stitching
-
-00:03:17.200 --> 00:03:19.599
-maxima and julie julia together so it's
-
-00:03:19.599 --> 00:03:20.319
-good to
-
-00:03:20.319 --> 00:03:21.680
-look a little bit about how that might
-
-00:03:21.680 --> 00:03:23.920
-work so first of all you can cache
-
-00:03:23.920 --> 00:03:25.680
-results so if you wanted to save the
-
-00:03:25.680 --> 00:03:26.480
-date
-
-00:03:26.480 --> 00:03:28.480
-out of block one at a certain time and
-
-00:03:28.480 --> 00:03:29.920
-then use
-
-00:03:29.920 --> 00:03:32.239
-use it again later so at the time when I
-
-00:03:32.239 --> 00:03:33.280
-ran this code
-
-00:03:33.280 --> 00:03:34.640
-you can see I've got two slightly
-
-00:03:34.640 --> 00:03:36.720
-different time stamps down below one's
-
-00:03:36.720 --> 00:03:38.560
-the cached result and the other was the
-
-00:03:38.560 --> 00:03:40.319
-result of reevaluating
-
-00:03:40.319 --> 00:03:42.640
-the block so you can move things around
-
-00:03:42.640 --> 00:03:43.760
-um and that's
-
-00:03:43.760 --> 00:03:46.000
-that's going to be useful but you know
-
-00:03:46.000 --> 00:03:47.280
-that's not really the main problem the
-
-00:03:47.280 --> 00:03:48.080
-main problem is
-
-00:03:48.080 --> 00:03:50.799
-making maxima long running so kind of
-
-00:03:50.799 --> 00:03:51.440
-the
-
-00:03:51.440 --> 00:03:53.920
-core of this talk is a new observant
-
-00:03:53.920 --> 00:03:56.400
-facility which is a general purpose
-
-00:03:56.400 --> 00:03:59.280
-way to do that kind of thing which
-
-00:03:59.280 --> 00:04:00.560
-involves a very simple
-
-00:04:00.560 --> 00:04:04.239
-change to obcor uh so we'll give a quick
-
-00:04:04.239 --> 00:04:05.360
-overview of that and show
-
-00:04:05.360 --> 00:04:08.480
-an example um so here's the example
-
-00:04:08.480 --> 00:04:11.760
-um a very simple sort of silly example
-
-00:04:11.760 --> 00:04:13.040
-uh what does it mean to have a long
-
-00:04:13.040 --> 00:04:14.640
-running process here I've set this
-
-00:04:14.640 --> 00:04:15.920
-display2d
-
-00:04:15.920 --> 00:04:18.560
-to be false um which just means that
-
-00:04:18.560 --> 00:04:19.440
-things are going to come
-
-00:04:19.440 --> 00:04:22.320
-come across in 1d and then I ask it to
-
-00:04:22.320 --> 00:04:23.040
-expand
-
-00:04:23.040 --> 00:04:25.199
-uh something and I get latex by default
-
-00:04:25.199 --> 00:04:27.280
-so so that's what it means is I've sent
-
-00:04:27.280 --> 00:04:28.639
-something in and it's going to come
-
-00:04:28.639 --> 00:04:30.240
-across in one view which is great
-
-00:04:30.240 --> 00:04:32.080
-um maybe you'll also notice that there's
-
-00:04:32.080 --> 00:04:34.560
-no semicolon if you're a maxima fan
-
-00:04:34.560 --> 00:04:36.720
-um and things are coming across as tech
-
-00:04:36.720 --> 00:04:38.400
-so those were some little bonus features
-
-00:04:38.400 --> 00:04:40.320
-and I'll show you how that works later
-
-00:04:40.320 --> 00:04:41.040
-so
-
-00:04:41.040 --> 00:04:45.440
-um the change to obcor is as follows uh
-
-00:04:45.440 --> 00:04:48.880
-um we uh actually this should say uh
-
-00:04:48.880 --> 00:04:51.520
-instead of stream here it should say um
-
-00:04:51.520 --> 00:04:52.479
-servant
-
-00:04:52.479 --> 00:04:54.800
-sorry uh we tried an experimental
-
-00:04:54.800 --> 00:04:56.160
-version what's called stream so now it's
-
-00:04:56.160 --> 00:04:58.160
-called servant but all it does is it
-
-00:04:58.160 --> 00:05:01.520
-overrides uh or babel execute laying for
-
-00:05:01.520 --> 00:05:02.639
-arbitrary laying
-
-00:05:02.639 --> 00:05:05.919
-if you have um a servant
-
-00:05:05.919 --> 00:05:07.840
-in your in your params so that's the
-
-00:05:07.840 --> 00:05:09.759
-change that hasn't been
-
-00:05:09.759 --> 00:05:11.919
-pushed out or sent as a patch to anybody
-
-00:05:11.919 --> 00:05:13.759
-but it's a pretty minor change
-
-00:05:13.759 --> 00:05:16.960
-um here's an overview without the code
-
-00:05:16.960 --> 00:05:19.080
-of just a high level overview of
-
-00:05:19.080 --> 00:05:20.720
-observant.el so
-
-00:05:20.720 --> 00:05:22.160
-it stores information about these
-
-00:05:22.160 --> 00:05:24.479
-processes in a hash table
-
-00:05:24.479 --> 00:05:26.080
-it can do pre-processing and
-
-00:05:26.080 --> 00:05:27.600
-post-processing
-
-00:05:27.600 --> 00:05:29.759
-um it does all these things it stores
-
-00:05:29.759 --> 00:05:30.720
-the output
-
-00:05:30.720 --> 00:05:32.479
-I mentioned here that in principle we
-
-00:05:32.479 --> 00:05:34.080
-could store lots of output and have a
-
-00:05:34.080 --> 00:05:35.280
-kind of browsable
-
-00:05:35.280 --> 00:05:36.560
-history although we don't do that
-
-00:05:36.560 --> 00:05:38.880
-presently um but that's what observant
-
-00:05:38.880 --> 00:05:40.639
-does is it does what you might expect
-
-00:05:40.639 --> 00:05:41.440
-and here's the
-
-00:05:41.440 --> 00:05:45.440
-here's the maxima kind of um
-
-00:05:45.440 --> 00:05:48.160
-on-ramp uh to get maxima brought in so
-
-00:05:48.160 --> 00:05:49.600
-you have to obviously have a maximum
-
-00:05:49.600 --> 00:05:51.360
-process you can call
-
-00:05:51.360 --> 00:05:54.960
-um put hash uh this is the preprocessing
-
-00:05:54.960 --> 00:05:57.840
-thing I mentioned adding in some tech um
-
-00:05:57.840 --> 00:05:58.960
-and adding in
-
-00:05:58.960 --> 00:06:01.520
-uh or deleting rather a substring and
-
-00:06:01.520 --> 00:06:03.120
-here here is why you delete the
-
-00:06:03.120 --> 00:06:03.759
-substring
-
-00:06:03.759 --> 00:06:06.960
-is because um maxima thinks it's a good
-
-00:06:06.960 --> 00:06:08.240
-idea to tell you false
-
-00:06:08.240 --> 00:06:10.080
-once you once you run check on things
-
-00:06:10.080 --> 00:06:11.759
-you've got to delete that back out to
-
-00:06:11.759 --> 00:06:13.680
-get something kind of coherent out of it
-
-00:06:13.680 --> 00:06:16.960
-but so this is how to set up maximal um
-
-00:06:16.960 --> 00:06:19.280
-that's enough really of the demo is not
-
-00:06:19.280 --> 00:06:20.000
-really a demos for
-
-00:06:20.000 --> 00:06:21.919
-show and tell but uh this is an
-
-00:06:21.919 --> 00:06:23.600
-experience report I wanted to talk about
-
-00:06:23.600 --> 00:06:25.440
-the experience of doing this
-
-00:06:25.440 --> 00:06:28.080
-so some some negatives like we tried to
-
-00:06:28.080 --> 00:06:30.160
-get emacs jupiter working
-
-00:06:30.160 --> 00:06:33.199
-prior to prior to working on the um
-
-00:06:33.199 --> 00:06:36.000
-observant and we couldn't get it doing
-
-00:06:36.000 --> 00:06:37.919
-everything we wanted despite a bit of
-
-00:06:37.919 --> 00:06:40.160
-heavy lifting and debugging and stuff so
-
-00:06:40.160 --> 00:06:41.840
-that's not not finished that was a bit
-
-00:06:41.840 --> 00:06:42.880
-difficult
-
-00:06:42.880 --> 00:06:45.360
-um on the other hand working on
-
-00:06:45.360 --> 00:06:47.759
-observing was fun and pretty lightweight
-
-00:06:47.759 --> 00:06:48.479
-and easy
-
-00:06:48.479 --> 00:06:50.400
-um we got some experience co-editing
-
-00:06:50.400 --> 00:06:52.400
-things with these real-time tools
-
-00:06:52.400 --> 00:06:54.479
-obviously the stack is somewhat work in
-
-00:06:54.479 --> 00:06:55.919
-progress um
-
-00:06:55.919 --> 00:06:58.000
-so I just wanted to give a shout out to
-
-00:06:58.000 --> 00:07:00.800
-crdt which was really fun
-
-00:07:00.800 --> 00:07:03.919
-and champion was making bug fiction
-
-00:07:03.919 --> 00:07:07.039
-bug fixes for that as we go similarly
-
-00:07:07.039 --> 00:07:08.960
-for fern and log seek the maintainers
-
-00:07:08.960 --> 00:07:10.160
-were really responsive
-
-00:07:10.160 --> 00:07:12.960
-um and so that was nice we did try to
-
-00:07:12.960 --> 00:07:14.560
-get emacs running in the browser
-
-00:07:14.560 --> 00:07:15.840
-thinking it would be really nice for
-
-00:07:15.840 --> 00:07:16.880
-people who
-
-00:07:16.880 --> 00:07:19.520
-um didn't want to install it to get a
-
-00:07:19.520 --> 00:07:21.120
-chance to just try it
-
-00:07:21.120 --> 00:07:23.120
-uh but actually browsers capture things
-
-00:07:23.120 --> 00:07:24.479
-like uh control n
-
-00:07:24.479 --> 00:07:27.120
-and so that's that was a bit annoying
-
-00:07:27.120 --> 00:07:28.479
-but we did get lots of great feedback
-
-00:07:28.479 --> 00:07:29.759
-and interaction with people including
-
-00:07:29.759 --> 00:07:31.599
-around this conference so thank you
-
-00:07:31.599 --> 00:07:33.759
-to those who we've had discussions with
-
-00:07:33.759 --> 00:07:35.599
-um
-
-00:07:35.599 --> 00:07:37.680
-so future work okay so maybe you
-
-00:07:37.680 --> 00:07:38.639
-remember I didn't
-
-00:07:38.639 --> 00:07:41.039
-give a talk a few years back on arcana
-
-00:07:41.039 --> 00:07:42.400
-so what what
-
-00:07:42.400 --> 00:07:44.479
-might this have to do with org mode and
-
-00:07:44.479 --> 00:07:45.919
-that's always the question one asks
-
-00:07:45.919 --> 00:07:47.039
-about arcata
-
-00:07:47.039 --> 00:07:48.720
-well so arcana one of the things it does
-
-00:07:48.720 --> 00:07:50.319
-is transclusions and so that could be
-
-00:07:50.319 --> 00:07:51.680
-actually very helpful
-
-00:07:51.680 --> 00:07:54.000
-in connection with this combined notes
-
-00:07:54.000 --> 00:07:55.520
-and write-up workflow so you might have
-
-00:07:55.520 --> 00:07:56.479
-a
-
-00:07:56.479 --> 00:07:58.400
-forward mode uh and some of these
-
-00:07:58.400 --> 00:08:00.800
-results we got back as raw results
-
-00:08:00.800 --> 00:08:03.199
-could go right into your write up in a
-
-00:08:03.199 --> 00:08:03.919
-kind of
-
-00:08:03.919 --> 00:08:07.520
-convenient way at a level above um
-
-00:08:07.520 --> 00:08:09.039
-transparently a level above the notebook
-
-00:08:09.039 --> 00:08:11.280
-so you'd have the notebook alongside the
-
-00:08:11.280 --> 00:08:13.440
-write-up in that case
-
-00:08:13.440 --> 00:08:15.599
-which is a sort of variation on the
-
-00:08:15.599 --> 00:08:16.800
-literate programming
-
-00:08:16.800 --> 00:08:19.120
-workflow this is speculative who knows
-
-00:08:19.120 --> 00:08:20.000
-the other thought is
-
-00:08:20.000 --> 00:08:22.080
-it just relates to the idea of network
-
-00:08:22.080 --> 00:08:23.520
-programming so we can imagine these
-
-00:08:23.520 --> 00:08:24.800
-networks of
-
-00:08:24.800 --> 00:08:26.639
-computational nodes maybe sitting inside
-
-00:08:26.639 --> 00:08:28.800
-of orgrome calling each other
-
-00:08:28.800 --> 00:08:31.199
-um and you would want to maintain some
-
-00:08:31.199 --> 00:08:32.560
-kind of model of that
-
-00:08:32.560 --> 00:08:34.959
-process and a sort of general question
-
-00:08:34.959 --> 00:08:36.640
-is how do we have a remote control for
-
-00:08:36.640 --> 00:08:38.320
-long-running processes you could do that
-
-00:08:38.320 --> 00:08:40.240
-in lisp or closure but
-
-00:08:40.240 --> 00:08:42.479
-maybe we could have something a little
-
-00:08:42.479 --> 00:08:44.080
-bit like that here
-
-00:08:44.080 --> 00:08:45.839
-um so conclusions what have we actually
-
-00:08:45.839 --> 00:08:48.080
-addressed well uh we addressed uh
-
-00:08:48.080 --> 00:08:50.080
-accessing any long-running process with
-
-00:08:50.080 --> 00:08:51.600
-a simple or mode interface
-
-00:08:51.600 --> 00:08:52.959
-obviously we're not the only people to
-
-00:08:52.959 --> 00:08:54.880
-think about notebooks but we think that
-
-00:08:54.880 --> 00:08:56.880
-emacs has some advantages
-
-00:08:56.880 --> 00:08:58.880
-related to reproducible research and
-
-00:08:58.880 --> 00:09:01.120
-interdisciplinary collaboration so let's
-
-00:09:01.120 --> 00:09:01.680
-just
-
-00:09:01.680 --> 00:09:03.120
-say that we think something is
-
-00:09:03.120 --> 00:09:04.880
-reproducible if it's actually teachable
-
-00:09:04.880 --> 00:09:07.200
-to someone new and they can do it
-
-00:09:07.200 --> 00:09:09.279
-org mode seems very useful for that many
-
-00:09:09.279 --> 00:09:11.680
-of the other talks have touched on this
-
-00:09:11.680 --> 00:09:14.399
-interdisciplinary collaboration is great
-
-00:09:14.399 --> 00:09:16.000
-this was an interdisciplinary
-
-00:09:16.000 --> 00:09:17.839
-collaboration on some level but
-
-00:09:17.839 --> 00:09:19.680
-what about you know future work for
-
-00:09:19.680 --> 00:09:21.600
-bringing in scenario planners simulation
-
-00:09:21.600 --> 00:09:22.320
-scientists
-
-00:09:22.320 --> 00:09:24.480
-and local farmers and building something
-
-00:09:24.480 --> 00:09:25.519
-that they can all
-
-00:09:25.519 --> 00:09:27.200
-use that's more than the sum of the
-
-00:09:27.200 --> 00:09:29.200
-parts so a little
-
-00:09:29.200 --> 00:09:30.720
-future work for everybody else here so
-
-00:09:30.720 --> 00:09:32.160
-we think science should be widely
-
-00:09:32.160 --> 00:09:33.120
-teachable
-
-00:09:33.120 --> 00:09:34.560
-shareable semi-automated
-
-00:09:34.560 --> 00:09:36.720
-transdisciplinary and real time
-
-00:09:36.720 --> 00:09:40.399
-like EmacsConf so you can get in touch
-
-00:09:40.399 --> 00:09:43.279
-uh via these methods and the code which
-
-00:09:43.279 --> 00:09:44.560
-is very much early stage work in
-
-00:09:44.560 --> 00:09:45.200
-progress
-
-00:09:45.200 --> 00:09:46.640
-as this was meant to be an experience
-
-00:09:46.640 --> 00:09:48.800
-report not a it's all done here it is
-
-00:09:48.800 --> 00:09:49.920
-polished report
-
-00:09:49.920 --> 00:09:51.680
-um it's also online if you'd like to
-
-00:09:51.680 --> 00:09:53.360
-have a look so that's the end of the
-
-00:09:53.360 --> 00:09:54.560
-talk and I don't know if there's time
-
-00:09:54.560 --> 00:09:55.279
-for questions
-
-00:09:55.279 --> 00:09:57.440
-or not but um I'm at your disposal now
-
-00:09:57.440 --> 00:10:00.240
-thank you you are now unmuted
-
-00:10:00.240 --> 00:10:04.079
-um many thanks for the tough job
-
-00:10:04.079 --> 00:10:07.120
-uh let's see we have about I think four
-
-00:10:07.120 --> 00:10:08.880
-minutes four questions
-
-00:10:08.880 --> 00:10:10.880
-um and we have a couple of questions on
-
-00:10:10.880 --> 00:10:12.320
-the pad would you like to read them
-
-00:10:12.320 --> 00:10:14.240
-yourself or should I read them to you
-
-00:10:14.240 --> 00:10:16.560
-uh just for sake of easy management why
-
-00:10:16.560 --> 00:10:18.079
-don't you read them out if that's okay
-
-00:10:18.079 --> 00:10:21.279
-yeah sure uh so they ask have you looked
-
-00:10:21.279 --> 00:10:22.240
-into trying
-
-00:10:22.240 --> 00:10:25.440
-sage math I've long uh long wanted
-
-00:10:25.440 --> 00:10:33.760
-nothing org files
-
-00:10:33.760 --> 00:10:36.959
-right and I and I wrote the answer that
-
-00:10:36.959 --> 00:10:39.279
-we should be possible because one can
-
-00:10:39.279 --> 00:10:44.839
-call it from a command
-
-00:10:44.839 --> 00:10:46.399
-okay
-
-00:10:46.399 --> 00:10:48.640
-and I see there's another sagemath
-
-00:10:48.640 --> 00:10:50.079
-question that you seem to have answered
-
-00:10:50.079 --> 00:10:52.100
-as well so I guess I won't repeat that
-
-00:10:52.100 --> 00:10:54.880
-[Music]
-
-00:10:54.880 --> 00:10:56.959
-there's let's not forget about embedded
-
-00:10:56.959 --> 00:11:00.640
-calc in emacs
-
-00:11:00.640 --> 00:11:03.680
-so so the first demos actually were with
-
-00:11:03.680 --> 00:11:05.040
-calc so that's that's
-
-00:11:05.040 --> 00:11:06.640
-useful uh although I think it was a
-
-00:11:06.640 --> 00:11:07.839
-different kind of a different command
-
-00:11:07.839 --> 00:11:08.240
-line
-
-00:11:08.240 --> 00:11:11.839
-well that was the next calc yeah
-
-00:11:11.839 --> 00:11:13.839
-so sure there is there is calc so that
-
-00:11:13.839 --> 00:11:15.680
-would be calculus and
-
-00:11:15.680 --> 00:11:19.120
-calc is already in org mode yeah
-
-00:11:19.120 --> 00:11:25.680
-yeah yeah
-
-00:11:25.680 --> 00:11:39.760
-um still looking for questions
-
-00:11:39.760 --> 00:11:41.760
-okay I think that's about it I don't see
-
-00:11:41.760 --> 00:11:44.320
-any questions on the ether pad
-
-00:11:44.320 --> 00:11:47.440
-and let's see
-
-00:11:47.440 --> 00:11:53.040
-anything on irc
-
-00:11:53.040 --> 00:11:55.760
-um nothing but phrases and everyone
-
-00:11:55.760 --> 00:11:56.720
-thanking you
-
-00:11:56.720 --> 00:11:59.120
-thank you all right you're welcome
-
-00:11:59.120 --> 00:12:00.240
-thanks a lot uh
-
-00:12:00.240 --> 00:12:02.880
-we'll see you guys around then cheers
-
-00:12:02.880 --> 00:12:06.800
-and see you around
diff --git a/2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith.vtt b/2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith.vtt
new file mode 100644
index 00000000..15513080
--- /dev/null
+++ b/2020/subtitles/emacsconf-2020--13-experience-report-steps-to-emacs-hyper-notebooks--joseph-corneli-raymond-puzio-cameron-ray-smith.vtt
@@ -0,0 +1,968 @@
+WEBVTT
+
+00:00:00.320 --> 00:00:03.280
+Joe: Hi, I'm Joe Corneli.
+
+00:00:03.280 --> 00:00:06.879
+This is work I did with Ray Puzio and
+Cameron Smith.
+
+00:00:06.879 --> 00:00:11.123
+They're the main protagonists in
+this story.
+
+00:00:11.123 --> 00:00:14.960
+They are researchers who've been working
+
+00:00:14.960 --> 00:00:17.490
+on theoretical biology.
+
+00:00:17.490 --> 00:00:21.357
+In a typical project, they may use
+Maxima and Julia.
+
+00:00:21.357 --> 00:00:24.800
+Their work combines biology, physics and
+computer science.
+
+00:00:24.800 --> 00:00:29.439
+The latest work-in-progress is on
+branching processes for
+
+00:00:29.439 --> 00:00:30.800
+cancer modeling.
+
+00:00:30.800 --> 00:00:34.719
+How can Emacs possibly help?
+
+00:00:34.719 --> 00:00:37.360
+Let's have a look. Moving code
+
+00:00:37.360 --> 00:00:38.399
+and data between these different
+
+00:00:38.399 --> 00:00:39.680
+programs by hand is
+
+00:00:39.680 --> 00:00:42.000
+annoying. Separate workflows for
+
+00:00:42.000 --> 00:00:44.399
+writing up notes and preparing
+publications
+
+00:00:44.399 --> 00:00:46.000
+is perhaps even more annoying. All of
+
+00:00:46.000 --> 00:00:48.640
+it is time consuming and error-prone.
+
+00:00:48.640 --> 00:00:52.000
+So what about maybe using Jupyter?
+
+00:00:52.000 --> 00:00:53.760
+We found something called Script of
+
+00:00:53.760 --> 00:00:55.199
+Scripts. It solves some of those
+
+00:00:55.199 --> 00:00:58.399
+problems because you can use
+
+00:00:58.399 --> 00:01:01.120
+Maxima and Julia together, but we were
+
+00:01:01.120 --> 00:01:02.640
+quite happy to explore Emacs-based
+
+00:01:02.640 --> 00:01:04.890
+solutions, being Emcas enthusiasts
+
+00:01:04.890 --> 00:01:07.760
+We even got Cameron to be
+enthusiastic about
+
+00:01:07.760 --> 00:01:10.057
+doing Emacs, so that went nice.
+
+00:01:10.057 --> 00:01:12.400
+Here's a little feature grid
+
+00:01:12.400 --> 00:01:15.360
+of Emacs + Org versus your
+
+00:01:15.360 --> 00:01:18.390
+generic tools that are in a
+
+00:01:18.390 --> 00:01:20.123
+different, more general ecosystem.
+
+00:01:20.123 --> 00:01:21.520
+As you can see, it's quite
+
+00:01:21.520 --> 00:01:22.957
+feature-complete. You've got your
+
+00:01:22.957 --> 00:01:25.520
+maxima-mode, julia-mode. You can use both of them
+
+00:01:25.520 --> 00:01:27.119
+inside of org-mode.
+
+00:01:27.119 --> 00:01:28.720
+You can present things with org-tree-slide.
+
+00:01:28.720 --> 00:01:31.490
+You can set up a wiki inside of org-roam.
+
+00:01:31.490 --> 00:01:33.680
+This is one I found
+
+00:01:33.680 --> 00:01:35.759
+rather recently. You can even use
+
+00:01:35.759 --> 00:01:37.759
+compatibly with org-roam, something called
+
+00:01:37.759 --> 00:01:42.159
+logseq, which is in the browser, so that's
+nice.
+
+00:01:42.159 --> 00:01:44.957
+You can do real-time collaborative
+editing,
+
+00:01:44.957 --> 00:01:47.657
+either in a kind of pairing style
+
+00:01:47.657 --> 00:01:49.280
+or in a more Etherpad style.
+
+00:01:49.280 --> 00:01:51.520
+Obviously, you can manage your references.
+
+00:01:51.520 --> 00:01:53.457
+You can typeset whatever you want.
+
+00:01:53.457 --> 00:01:55.759
+You can publish work in progress on
+a blog.
+
+00:01:55.759 --> 00:01:57.439
+Firn is another one of these
+
+00:01:57.439 --> 00:01:59.790
+external Org Mode tools.
+
+00:01:59.790 --> 00:02:00.560
+It's not actually in Emacs,
+
+00:02:00.560 --> 00:02:03.557
+but works with Org Mode stuff. And, you know...
+
+00:02:03.557 --> 00:02:05.657
+So we're good to go with all of that.
+
+00:02:05.657 --> 00:02:07.423
+So what does that look like? Well,
+
+00:02:07.423 --> 00:02:09.423
+here's a little example from before
+
+00:02:09.423 --> 00:02:12.800
+they were doing... before we started
+really thinking
+
+00:02:12.800 --> 00:02:13.890
+seriously about this stuff.
+
+00:02:13.890 --> 00:02:15.599
+So this is just Maxima.
+
+00:02:15.599 --> 00:02:17.440
+Well, Maxima doesn't have a long running
+
+00:02:17.440 --> 00:02:19.280
+process by default. If you've ever used
+
+00:02:19.280 --> 00:02:22.480
+Python, you have something called
+sessions.
+
+00:02:22.480 --> 00:02:23.920
+They don't have that for Maxima, at least
+
+00:02:23.920 --> 00:02:24.959
+not by default.
+
+00:02:24.959 --> 00:02:27.599
+So how... What was the workaround?
+
+00:02:27.599 --> 00:02:29.360
+There's this thing called
+
+00:02:29.360 --> 00:02:32.480
+solve-for-u here
+
+00:02:32.480 --> 00:02:34.879
+that shows up down below again in these
+
+00:02:34.879 --> 00:02:36.319
+angle brackets, which you've seen maybe
+
+00:02:36.319 --> 00:02:37.360
+in someone else's talk,
+
+00:02:37.360 --> 00:02:40.480
+which means go to the previous
+
+00:02:40.480 --> 00:02:41.920
+thing that was named solve-for-u
+
+00:02:41.920 --> 00:02:43.920
+and do that all over again, so they do
+
+00:02:43.920 --> 00:02:45.280
+that over again.
+
+00:02:45.280 --> 00:02:47.440
+Here's the little Maxima code for
+
+00:02:47.440 --> 00:02:48.990
+defining usol, so you've now
+
+00:02:48.990 --> 00:02:51.723
+defined usol, and then you can use it
+
+00:02:51.723 --> 00:02:54.000
+in the next expression. You get out a
+nice juicy
+
+00:02:54.000 --> 00:02:56.560
+zero at the end. It's a little bit
+
+00:02:57.200 --> 00:02:58.959
+like a partridge in a pear tree to have to
+
+00:02:58.959 --> 00:03:00.640
+redefine everything every time.
+
+00:03:00.640 --> 00:03:02.490
+So this is clearly at the level of
+
+00:03:02.490 --> 00:03:04.159
+work-around. Maybe just
+
+00:03:04.159 --> 00:03:06.223
+one more time looking through
+
+00:03:06.223 --> 00:03:11.599
+that stuff.
+
+00:03:11.599 --> 00:03:13.760
+Sorry. So, looking through that stuff,
+
+00:03:13.760 --> 00:03:15.280
+this is... We're going to need something
+
+00:03:15.280 --> 00:03:17.200
+like that, probably, for stitching
+
+00:03:17.200 --> 00:03:19.599
+Maxima and Julia together. so it's
+
+00:03:19.599 --> 00:03:20.890
+good to look a little bit
+
+00:03:20.890 --> 00:03:22.590
+about how that might work.
+
+00:03:22.590 --> 00:03:23.920
+First of all, you can cache
+
+00:03:23.920 --> 00:03:25.680
+results, so if you wanted to save the
+
+00:03:25.680 --> 00:03:28.480
+date out of block one at a certain
+time and
+
+00:03:28.480 --> 00:03:30.990
+then use it again later...
+
+00:03:30.990 --> 00:03:33.280
+At the time when I ran this code,
+
+00:03:33.280 --> 00:03:34.640
+you can see I've got two slightly
+
+00:03:34.640 --> 00:03:36.623
+different time stamps down below.
+
+00:03:36.623 --> 00:03:38.323
+One's the cached result, and the other
+
+00:03:38.323 --> 00:03:40.319
+was the result of reevaluating
+
+00:03:40.319 --> 00:03:42.640
+the block. So you can move things around.
+
+00:03:43.760 --> 00:03:46.000
+That's going to be useful. But you know,
+
+00:03:46.000 --> 00:03:46.923
+that's not really the main problem.
+
+00:03:46.923 --> 00:03:48.080
+The main problem is
+
+00:03:48.080 --> 00:03:50.799
+making Maxima long-running.
+
+00:03:50.799 --> 00:03:53.920
+The core of this talk is a new observant
+
+00:03:53.920 --> 00:03:56.400
+facility, which is a general purpose
+
+00:03:56.400 --> 00:03:59.280
+way to do that kind of thing, which
+
+00:03:59.280 --> 00:04:01.823
+involves a very simple change to ob-core.
+
+00:04:01.823 --> 00:04:04.239
+We'll give a quick
+
+00:04:04.239 --> 00:04:05.360
+overview of that and show
+
+00:04:05.360 --> 00:04:08.480
+an example. So here's the example,
+
+00:04:08.480 --> 00:04:11.760
+a very simple sort of silly example.
+
+00:04:11.760 --> 00:04:12.957
+What does it mean to have
+
+00:04:12.957 --> 00:04:13.990
+a long-running process?
+
+00:04:13.990 --> 00:04:14.640
+Here, I've set this
+
+00:04:14.640 --> 00:04:18.560
+display2d to be false, which just
+means that
+
+00:04:18.560 --> 00:04:19.440
+things are going to come
+
+00:04:19.440 --> 00:04:22.320
+come across in 1d. Then I ask it to
+
+00:04:22.320 --> 00:04:25.199
+expand something. I get LaTeX
+by default.
+
+00:04:25.199 --> 00:04:27.280
+So that's what it means. It's that I've sent
+
+00:04:27.280 --> 00:04:28.639
+something in and it's going to come
+
+00:04:28.639 --> 00:04:30.240
+across in one view, which is great.
+
+00:04:30.240 --> 00:04:32.080
+Maybe you'll also notice that there's
+
+00:04:32.080 --> 00:04:34.560
+no semicolon, if you're a Maxima fan,
+
+00:04:34.560 --> 00:04:36.720
+and things are coming across as TeX.
+
+00:04:36.720 --> 00:04:38.400
+So those were some little bonus features.
+
+00:04:38.400 --> 00:04:40.320
+I'll show you how that works later.
+
+00:04:41.040 --> 00:04:45.440
+The change to ob-core is as follows.
+
+00:04:45.440 --> 00:04:48.880
+Actually, this should say...
+
+00:04:48.880 --> 00:04:51.520
+Instead of stream here, it should say
+
+00:04:51.520 --> 00:04:54.800
+servant. Sorry. We tried an experimental
+
+00:04:54.800 --> 00:04:56.160
+version which was called stream, so now it's
+
+00:04:56.160 --> 00:04:58.160
+called servant. But all it does is it
+
+00:04:58.160 --> 00:05:01.520
+overrides org-babel-execute lang for
+
+00:05:01.520 --> 00:05:02.639
+arbitrary lang
+
+00:05:02.639 --> 00:05:05.919
+if you have a servant
+
+00:05:05.919 --> 00:05:07.840
+in your params. So that's the
+
+00:05:07.840 --> 00:05:09.759
+change that hasn't been
+
+00:05:09.759 --> 00:05:11.919
+pushed out or sent as a patch to anybody,
+
+00:05:11.919 --> 00:05:13.759
+but it's a pretty minor change.
+
+00:05:13.759 --> 00:05:16.960
+Here's an overview without the code.
+
+00:05:16.960 --> 00:05:19.080
+Just a high level overview of
+
+00:05:19.080 --> 00:05:20.720
+observant.el.
+
+00:05:20.720 --> 00:05:22.160
+It stores information about these
+
+00:05:22.160 --> 00:05:24.479
+processes in a hash table.
+
+00:05:24.479 --> 00:05:26.080
+It can do pre-processing and
+
+00:05:26.080 --> 00:05:27.600
+post-processing.
+
+00:05:27.600 --> 00:05:29.759
+It does all these things. It stores
+
+00:05:29.759 --> 00:05:30.720
+the output.
+
+00:05:30.720 --> 00:05:32.479
+I mentioned here that, in principle, we
+
+00:05:32.479 --> 00:05:34.080
+could store lots of output and have a
+
+00:05:34.080 --> 00:05:35.657
+kind of browsable history,
+
+00:05:35.657 --> 00:05:37.790
+although we don't do that
+presently.
+
+00:05:37.790 --> 00:05:38.790
+But that's what observant does.
+
+00:05:38.790 --> 00:05:40.639
+It does what you might expect.
+
+00:05:41.440 --> 00:05:46.190
+Here's the Maxima on-ramp
+
+00:05:46.190 --> 00:05:48.160
+to get Maxima brought in.
+
+00:05:48.160 --> 00:05:49.257
+You have to obviously have
+
+00:05:49.257 --> 00:05:51.360
+a Maxima process you can call.
+
+00:05:51.360 --> 00:05:54.960
+puthash... this is the preprocessing
+
+00:05:54.960 --> 00:05:57.840
+thing I mentioned, adding in some Tex
+
+00:05:57.840 --> 00:05:58.960
+and adding in--
+
+00:05:58.960 --> 00:06:01.520
+or deleting, rather--a substring.
+
+00:06:01.520 --> 00:06:03.759
+Here is why you delete the
+substring.
+
+00:06:03.759 --> 00:06:06.960
+It's because Maxima thinks it's a good
+
+00:06:06.960 --> 00:06:08.240
+idea to tell you false
+
+00:06:08.240 --> 00:06:10.080
+once you run check on things.
+
+00:06:10.080 --> 00:06:11.759
+You've got to delete that back out to
+
+00:06:11.759 --> 00:06:13.680
+get something coherent out of it.
+
+00:06:13.680 --> 00:06:16.960
+So this is how to set up Maxima.
+
+00:06:16.960 --> 00:06:19.157
+That's enough, really, of the demo.
+
+00:06:19.157 --> 00:06:20.000
+It's not really a demo for
+
+00:06:20.000 --> 00:06:21.919
+show and tell, but as this is an
+
+00:06:21.919 --> 00:06:23.600
+experience report, I wanted to talk about
+
+00:06:23.600 --> 00:06:25.440
+the experience of doing this.
+
+00:06:25.440 --> 00:06:28.080
+Some negatives, like we tried to
+
+00:06:28.080 --> 00:06:30.160
+get Emacs Jupyter working
+
+00:06:30.160 --> 00:06:34.190
+prior to working on observant.
+
+00:06:34.190 --> 00:06:36.000
+We couldn't get it doing
+
+00:06:36.000 --> 00:06:37.919
+everything we wanted, despite a bit of
+
+00:06:37.919 --> 00:06:40.160
+heavy lifting and debugging and stuff.
+
+00:06:40.160 --> 00:06:42.880
+So that's not finished. That was a bit
+difficult.
+
+00:06:42.880 --> 00:06:45.360
+On the other hand, working on
+
+00:06:45.360 --> 00:06:47.759
+observant was fun, pretty lightweight,
+
+00:06:47.759 --> 00:06:48.479
+and easy.
+
+00:06:48.479 --> 00:06:50.400
+We got some experience co-editing
+
+00:06:50.400 --> 00:06:52.400
+things with these real-time tools.
+
+00:06:52.400 --> 00:06:55.919
+Obviously, the stack is somewhat work in
+progress.
+
+00:06:55.919 --> 00:06:58.000
+I just wanted to give a shout out to
+
+00:06:58.000 --> 00:07:00.800
+crdt which was really fun,
+
+00:07:00.800 --> 00:07:03.919
+and Qiantan was making
+
+00:07:03.919 --> 00:07:06.057
+bug fixes for that as we go.
+
+00:07:06.057 --> 00:07:08.960
+Similarly, for firn and logseq,
+the maintainers
+
+00:07:08.960 --> 00:07:10.160
+were really responsive,
+
+00:07:10.160 --> 00:07:12.960
+so that was nice. We did try to
+
+00:07:12.960 --> 00:07:14.560
+get Emacs running in the browser,
+
+00:07:14.560 --> 00:07:15.840
+thinking it would be really nice for
+
+00:07:15.840 --> 00:07:19.290
+people who didn't want to install it
+
+00:07:19.290 --> 00:07:21.120
+to get a chance to just try it,
+
+00:07:21.120 --> 00:07:23.120
+but actually, browsers capture things
+
+00:07:23.120 --> 00:07:27.120
+like C-n, so that was a bit annoying.
+
+00:07:27.120 --> 00:07:28.479
+But we did get lots of great feedback
+
+00:07:28.479 --> 00:07:29.759
+and interaction with people, including
+
+00:07:29.759 --> 00:07:31.599
+around this conference. Thank you
+
+00:07:31.599 --> 00:07:33.759
+to those who we've had discussions with.
+
+00:07:35.599 --> 00:07:37.680
+So, future work. Okay, so... Maybe you
+
+00:07:37.680 --> 00:07:41.039
+remember, I gave a talk a few years back
+on Arxana.
+
+00:07:41.039 --> 00:07:44.479
+What might this have to do with Org
+Mode?
+
+00:07:44.479 --> 00:07:45.919
+That's always the question one asks
+
+00:07:45.919 --> 00:07:47.039
+about Arxana.
+
+00:07:47.039 --> 00:07:48.720
+Arxana... One of the things it does
+
+00:07:48.720 --> 00:07:50.319
+is transclusions, and so that could be
+
+00:07:50.319 --> 00:07:51.680
+actually very helpful
+
+00:07:51.680 --> 00:07:54.000
+in connection with this "combined notes
+
+00:07:54.000 --> 00:07:55.520
+and write-up" workflow. So you might have
+
+00:07:55.520 --> 00:07:58.400
+an Org Mode. Some of these
+
+00:07:58.400 --> 00:08:00.800
+results we got back as raw results
+
+00:08:00.800 --> 00:08:03.199
+could go right into your write-up in a
+
+00:08:03.919 --> 00:08:07.520
+convenient way, at a level above--
+
+00:08:07.520 --> 00:08:09.039
+transparently, a level above the notebook.
+
+00:08:09.039 --> 00:08:11.280
+So you'd have the notebook alongside the
+
+00:08:11.280 --> 00:08:13.440
+write-up in that case,
+
+00:08:13.440 --> 00:08:15.599
+which is a variation on the
+
+00:08:15.599 --> 00:08:17.423
+literate programming workflow.
+
+00:08:17.423 --> 00:08:19.120
+This is speculative. Who knows?
+
+00:08:19.120 --> 00:08:20.000
+The other thought is,
+
+00:08:20.000 --> 00:08:22.080
+it just relates to the idea of network
+
+00:08:22.080 --> 00:08:23.520
+programming. So we can imagine these
+
+00:08:23.520 --> 00:08:25.990
+networks of computational nodes
+
+00:08:25.990 --> 00:08:27.623
+sitting inside of org-roam,
+
+00:08:27.623 --> 00:08:28.800
+calling each other.
+
+00:08:28.800 --> 00:08:31.199
+You would want to maintain some
+
+00:08:31.199 --> 00:08:33.357
+kind of model of that process.
+
+00:08:33.357 --> 00:08:36.640
+A general question is: how do we have a
+remote control for
+
+00:08:36.640 --> 00:08:37.957
+long-running processes?
+
+00:08:37.957 --> 00:08:38.320
+You could do that
+
+00:08:38.320 --> 00:08:39.857
+in Lisp or Clojure,
+
+00:08:39.857 --> 00:08:41.657
+but maybe we could have something
+
+00:08:41.657 --> 00:08:44.080
+a little bit like that here.
+
+00:08:44.080 --> 00:08:45.839
+Conclusions: what have we actually
+
+00:08:45.839 --> 00:08:48.080
+addressed? Well, we addressed
+
+00:08:48.080 --> 00:08:50.080
+accessing any long-running process with
+
+00:08:50.080 --> 00:08:51.600
+a simple Org Mode interface.
+
+00:08:51.600 --> 00:08:52.959
+Obviously, we're not the only people to
+
+00:08:52.959 --> 00:08:54.880
+think about notebooks, but we think that
+
+00:08:54.880 --> 00:08:56.880
+Emacs has some advantages
+
+00:08:56.880 --> 00:08:58.880
+related to reproducible research and
+
+00:08:58.880 --> 00:09:00.757
+interdisciplinary collaboration.
+
+00:09:00.757 --> 00:09:02.590
+Let's just say that we think
+
+00:09:02.590 --> 00:09:04.880
+something is reproducible if it's
+actually teachable
+
+00:09:04.880 --> 00:09:07.200
+to someone new and they can do it.
+
+00:09:07.200 --> 00:09:09.190
+Org Mode seems very useful for that.
+
+00:09:09.190 --> 00:09:11.680
+Many of the other talks have touched
+on this.
+
+00:09:11.680 --> 00:09:14.399
+Interdisciplinary collaboration is great.
+
+00:09:14.399 --> 00:09:16.000
+This was an interdisciplinary
+
+00:09:16.000 --> 00:09:17.839
+collaboration on some level, but
+
+00:09:17.839 --> 00:09:19.680
+what about future work for
+
+00:09:19.680 --> 00:09:21.190
+bringing in scenario planners,
+
+00:09:21.190 --> 00:09:22.320
+simulation scientists,
+
+00:09:22.320 --> 00:09:24.480
+and local farmers, and building something
+
+00:09:24.480 --> 00:09:26.023
+that they can all use
+
+00:09:26.023 --> 00:09:27.857
+that's more than the sum of the
+parts?
+
+00:09:27.857 --> 00:09:30.720
+So a little future work for everybody
+else here.
+
+00:09:30.720 --> 00:09:32.160
+We think science should be widely
+
+00:09:32.160 --> 00:09:34.560
+teachable, shareable, semi-automated,
+
+00:09:34.560 --> 00:09:36.720
+transdisciplinary, and real-time
+
+00:09:36.720 --> 00:09:40.399
+like EmacsConf. So you can get in touch
+
+00:09:40.399 --> 00:09:43.279
+via these methods. The code--which
+
+00:09:43.279 --> 00:09:45.200
+is very much early stage work in
+progress,
+
+00:09:45.200 --> 00:09:46.640
+as this was meant to be an experience
+
+00:09:46.640 --> 00:09:48.800
+report, not a "it's all done, here, it is
+
+00:09:48.800 --> 00:09:49.920
+polished" report--
+
+00:09:49.920 --> 00:09:51.680
+it's also online if you'd like to
+
+00:09:51.680 --> 00:09:53.360
+have a look. That's the end of the
+
+00:09:53.360 --> 00:09:54.560
+talk. I don't know if there's time
+
+00:09:54.560 --> 00:09:57.440
+for questions or not, but um I'm at your
+disposal now.
+
+00:09:57.440 --> 00:10:00.240
+Thank you.
+
+00:10:00.240 --> 00:10:04.079
+(Amin: Many thanks for the tough job.
+
+00:10:04.079 --> 00:10:07.120
+Let's see. We have about I think four
+
+00:10:07.120 --> 00:10:08.880
+minutes for questions,
+
+00:10:08.880 --> 00:10:10.880
+and we have a couple of questions on
+
+00:10:10.880 --> 00:10:12.320
+the pad. Would you like to read them
+
+00:10:12.320 --> 00:10:14.240
+yourself or should I read them to you?)
+
+00:10:14.240 --> 00:10:16.423
+Just for the sake of easy management
+
+00:10:16.423 --> 00:10:18.079
+why don't you read them out, if
+that's okay?
+
+00:10:18.079 --> 00:10:21.279
+(Amin: yeah, sure. They ask, "Have you looked
+
+00:10:21.279 --> 00:10:25.440
+into trying Sage Math? I've long wanted
+
+00:10:25.440 --> 00:10:33.760
+to use Sage Math in Org files.")
+
+00:10:33.760 --> 00:10:36.959
+Ray: Right. I wrote the answer that
+
+00:10:36.959 --> 00:10:39.279
+it should be possible because one can
+
+00:10:39.279 --> 00:10:44.839
+call it from a command.
+
+00:10:44.839 --> 00:10:48.190
+(Amin: okay, and I see there's
+
+00:10:48.190 --> 00:10:50.079
+another Sage Math question that you seem
+to have answered
+
+00:10:50.079 --> 00:10:52.100
+as well, so I guess I won't repeat that.
+
+00:10:54.880 --> 00:10:56.959
+There's... "Let's not forget about embedded
+
+00:10:56.959 --> 00:11:00.640
+Calc in Emacs.")
+
+00:11:00.640 --> 00:11:05.040
+Joe: So the first demos actually were with
+Calc.
+
+00:11:05.040 --> 00:11:06.640
+That's useful. Although I think it was a
+
+00:11:06.640 --> 00:11:08.240
+different--kind of a different command
+line.
+
+00:11:08.240 --> 00:11:11.839
+Ray: Well, that was UNIX Calc.
+
+00:11:11.839 --> 00:11:13.839
+Joe: So, sure, there is calc, so that...
+
+00:11:15.680 --> 00:11:19.120
+Ray: Calc is already in Org Mode.
+
+00:11:25.680 --> 00:11:39.760
+(Amin: Still looking for questions.
+
+00:11:39.760 --> 00:11:41.760
+Okay, I think that's about it. I don't see
+
+00:11:41.760 --> 00:11:44.320
+any questions on the Etherpad.
+
+00:11:44.320 --> 00:11:47.440
+And let's see...
+
+00:11:47.440 --> 00:11:53.040
+Anything on irc?
+
+00:11:53.040 --> 00:11:55.760
+Nothing but praises and everyone
+
+00:11:55.760 --> 00:11:57.290
+thanking you. Thank you.)
+
+00:11:57.290 --> 00:11:59.120
+Ray: all right, you're welcome.
+
+00:11:59.120 --> 00:12:00.240
+Joe: Thanks a lot!
+
+00:12:00.240 --> 00:12:01.923
+We'll see you guys around then.
+
+00:12:01.923 --> 00:12:06.800
+Amin: Cheers, and see you around!
diff --git a/2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard-autogen.vtt b/2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard-autogen.vtt
deleted file mode 100644
index 3179635f..00000000
--- a/2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard-autogen.vtt
+++ /dev/null
@@ -1,1426 +0,0 @@
-WEBVTT
-
-00:00:03.600 --> 00:00:04.400
-hello
-
-00:00:04.400 --> 00:00:06.560
-welcome to readme driven design in Emacs
-
-00:00:06.560 --> 00:00:08.400
-by adam aard
-
-00:00:08.400 --> 00:00:10.800
-if you're a programmer you're accustomed
-
-00:00:10.800 --> 00:00:12.559
-to putting a readme file at the root of
-
-00:00:12.559 --> 00:00:13.759
-your project
-
-00:00:13.759 --> 00:00:16.400
-and it's usually a markdown file but if
-
-00:00:16.400 --> 00:00:17.600
-you use an org
-
-00:00:17.600 --> 00:00:20.720
-more an org mode file instead you can
-
-00:00:20.720 --> 00:00:22.560
-take advantage of the great features
-
-00:00:22.560 --> 00:00:24.400
-that org mode provides including
-
-00:00:24.400 --> 00:00:25.920
-literate programming
-
-00:00:25.920 --> 00:00:28.000
-which lets you generate your source code
-
-00:00:28.000 --> 00:00:31.840
-and markdown documentation dynamically
-
-00:00:31.840 --> 00:00:34.719
-I want to walk you through a little bit
-
-00:00:34.719 --> 00:00:37.120
-of what this looks like
-
-00:00:37.120 --> 00:00:39.440
-when you start a project especially if
-
-00:00:39.440 --> 00:00:41.280
-if you use something like github you
-
-00:00:41.280 --> 00:00:43.320
-begin with an automatically generated
-
-00:00:43.320 --> 00:00:47.039
-readme.md file so just delete that
-
-00:00:47.039 --> 00:00:50.239
-and instead create a readme.org file
-
-00:00:50.239 --> 00:00:51.920
-starting with an empty org file like you
-
-00:00:51.920 --> 00:00:54.800
-see here you can begin
-
-00:00:54.800 --> 00:00:56.559
-by recording important information about
-
-00:00:56.559 --> 00:00:59.440
-your project goals you can add diagrams
-
-00:00:59.440 --> 00:01:01.920
-code snippets to-do lists time tracking
-
-00:01:01.920 --> 00:01:03.520
-and much more
-
-00:01:03.520 --> 00:01:05.360
-I'm going to drop in some documentation
-
-00:01:05.360 --> 00:01:07.760
-that I r that I've written about
-
-00:01:07.760 --> 00:01:10.840
-about my project here so you can kind of
-
-00:01:10.840 --> 00:01:12.240
-see
-
-00:01:12.240 --> 00:01:15.280
-what this would look like
-
-00:01:15.280 --> 00:01:17.119
-so as you can see I have a title and a
-
-00:01:17.119 --> 00:01:20.320
-description and then a sub section
-
-00:01:20.320 --> 00:01:23.840
-as well as some code snippets
-
-00:01:23.840 --> 00:01:25.520
-and you can see that orgmo does a great
-
-00:01:25.520 --> 00:01:28.240
-job of formatting lists and
-
-00:01:28.240 --> 00:01:31.280
-code sections diagrams and so forth
-
-00:01:31.280 --> 00:01:33.920
-it's good or it's as good or better than
-
-00:01:33.920 --> 00:01:35.040
-markdown
-
-00:01:35.040 --> 00:01:37.520
-but when you use it in the Emacs you can
-
-00:01:37.520 --> 00:01:38.880
-do a lot more
-
-00:01:38.880 --> 00:01:40.479
-for example you can dynamically create
-
-00:01:40.479 --> 00:01:43.360
-diagrams using graphviz
-
-00:01:43.360 --> 00:01:45.200
-from a text description so if you go to
-
-00:01:45.200 --> 00:01:46.560
-this source block here
-
-00:01:46.560 --> 00:01:49.439
-and hit control c control c you'll see
-
-00:01:49.439 --> 00:01:51.439
-that we generate a
-
-00:01:51.439 --> 00:01:55.439
-diagram dynamically you can run
-
-00:01:55.439 --> 00:01:59.200
-so you can run these code snippets in
-
-00:01:59.200 --> 00:02:00.799
-place and get the results
-
-00:02:00.799 --> 00:02:03.040
-to show up inside of your your file
-
-00:02:03.040 --> 00:02:08.000
-which is a really powerful paradigm
-
-00:02:08.000 --> 00:02:10.640
-but most important most importantly for
-
-00:02:10.640 --> 00:02:11.520
-the
-
-00:02:11.520 --> 00:02:14.800
-purposes my purpose is here
-
-00:02:14.800 --> 00:02:17.200
-orgmo provides you the ability to do
-
-00:02:17.200 --> 00:02:19.520
-literate programming
-
-00:02:19.520 --> 00:02:21.440
-so take a quick look at this diagram
-
-00:02:21.440 --> 00:02:23.200
-that I generated here
-
-00:02:23.200 --> 00:02:25.360
-and gives you a quick overview of what I
-
-00:02:25.360 --> 00:02:27.520
-mean by literate programming
-
-00:02:27.520 --> 00:02:31.200
-and how I'm using it you can see
-
-00:02:31.200 --> 00:02:33.920
-that we start with a readme.org file on
-
-00:02:33.920 --> 00:02:34.720
-top
-
-00:02:34.720 --> 00:02:36.879
-at this point we can do one of two
-
-00:02:36.879 --> 00:02:37.920
-things
-
-00:02:37.920 --> 00:02:41.280
-tangle or weave tangle is used to
-
-00:02:41.280 --> 00:02:42.720
-describe the process of
-
-00:02:42.720 --> 00:02:46.319
-generating source code while weave
-
-00:02:46.319 --> 00:02:47.599
-is the process of generating
-
-00:02:47.599 --> 00:02:49.840
-documentation these are terms that
-
-00:02:49.840 --> 00:02:51.920
-donald knuth used
-
-00:02:51.920 --> 00:02:53.840
-and he's the one that came up with the
-
-00:02:53.840 --> 00:02:55.519
-idea of literate programming
-
-00:02:55.519 --> 00:02:59.920
-in the early 1980s
-
-00:02:59.920 --> 00:03:01.519
-but this is really all that there is to
-
-00:03:01.519 --> 00:03:04.480
-it you just
-
-00:03:04.480 --> 00:03:06.400
-who are simply using literate illiterate
-
-00:03:06.400 --> 00:03:07.840
-source file
-
-00:03:07.840 --> 00:03:10.319
-in this case the readme.org to generate
-
-00:03:10.319 --> 00:03:11.680
-the rest of the project
-
-00:03:11.680 --> 00:03:17.120
-the rest of the project files basically
-
-00:03:17.120 --> 00:03:20.959
-so let's dig in to the details of how
-
-00:03:20.959 --> 00:03:22.640
-this works
-
-00:03:22.640 --> 00:03:24.560
-and I hope you hopefully you'll see how
-
-00:03:24.560 --> 00:03:26.159
-cool this is
-
-00:03:26.159 --> 00:03:28.959
-so returning to the file here let's
-
-00:03:28.959 --> 00:03:31.120
-assume we have enough documentation now
-
-00:03:31.120 --> 00:03:32.080
-that we want to get started
-
-00:03:32.080 --> 00:03:34.159
-coding so maybe we'll just start with
-
-00:03:34.159 --> 00:03:35.519
-like a hello world
-
-00:03:35.519 --> 00:03:38.159
-app just so we can make sure that our
-
-00:03:38.159 --> 00:03:41.519
-environment is set up correctly
-
-00:03:41.519 --> 00:03:47.120
-so let's get started with a code block
-
-00:03:47.120 --> 00:03:49.519
-so I created a little snippet to help me
-
-00:03:49.519 --> 00:03:50.319
-add
-
-00:03:50.319 --> 00:03:52.239
-a source block for literate programming
-
-00:03:52.239 --> 00:03:53.599
-quickly
-
-00:03:53.599 --> 00:03:56.959
-and there's not much to it
-
-00:03:56.959 --> 00:03:58.799
-but there is some important annotations
-
-00:03:58.799 --> 00:04:01.599
-here so there's
-
-00:04:01.599 --> 00:04:04.080
-excuse me there's a there's a property
-
-00:04:04.080 --> 00:04:05.200
-called tangle
-
-00:04:05.200 --> 00:04:09.360
-and that takes a value of a file name
-
-00:04:09.360 --> 00:04:13.280
-and then there's also a no web property
-
-00:04:13.280 --> 00:04:18.880
-called no export
-
-00:04:18.880 --> 00:04:23.759
-and basically
-
-00:04:23.759 --> 00:04:26.800
-basically the no export will explain
-
-00:04:26.800 --> 00:04:28.639
-that a little bit
-
-00:04:28.639 --> 00:04:32.080
-more later um it has has to do with how
-
-00:04:32.080 --> 00:04:33.919
-the tangling
-
-00:04:33.919 --> 00:04:37.600
-is uh done in the tangle step versus the
-
-00:04:37.600 --> 00:04:39.280
-weave step and I'll explain that a
-
-00:04:39.280 --> 00:04:41.199
-little bit more but the tangle
-
-00:04:41.199 --> 00:04:45.199
-field just simply tells tells uh
-
-00:04:45.199 --> 00:04:48.320
-Emacs where it needs to generate the
-
-00:04:48.320 --> 00:04:50.320
-main.go file and where it needs to put
-
-00:04:50.320 --> 00:04:55.360
-it on the file system
-
-00:04:55.360 --> 00:04:57.680
-uh you'll you'll notice that we we're
-
-00:04:57.680 --> 00:04:59.040
-going to use go
-
-00:04:59.040 --> 00:05:01.440
-that's just the language that I've been
-
-00:05:01.440 --> 00:05:02.160
-using
-
-00:05:02.160 --> 00:05:05.360
-the most lately uh but
-
-00:05:05.360 --> 00:05:07.360
-this programming strategy is language
-
-00:05:07.360 --> 00:05:08.400
-agnostic
-
-00:05:08.400 --> 00:05:12.080
-you could use any language or any mix
-
-00:05:12.080 --> 00:05:14.720
-of languages you could create some files
-
-00:05:14.720 --> 00:05:16.560
-in python some files and go
-
-00:05:16.560 --> 00:05:19.520
-some files in in lisp or whatever you
-
-00:05:19.520 --> 00:05:21.520
-want
-
-00:05:21.520 --> 00:05:24.720
-and so but let's
-
-00:05:24.720 --> 00:05:28.000
-uh let's create just a little hello
-
-00:05:28.000 --> 00:05:29.440
-world
-
-00:05:29.440 --> 00:05:32.320
-let's use another snippet here to
-
-00:05:32.320 --> 00:05:33.520
-generate
-
-00:05:33.520 --> 00:05:36.560
-the basics of a go program
-
-00:05:36.560 --> 00:05:40.240
-so I'm just going to print
-
-00:05:40.240 --> 00:05:44.960
-hello world
-
-00:05:44.960 --> 00:05:48.560
-so that's and then
-
-00:05:48.560 --> 00:05:52.320
-let's make it a section in our
-
-00:05:52.320 --> 00:05:55.280
-file so now you can see we've got this
-
-00:05:55.280 --> 00:05:56.400
-snippet
-
-00:05:56.400 --> 00:05:59.600
-um when you have a source block in
-
-00:05:59.600 --> 00:06:01.600
-inside of org mode you can easily pop
-
-00:06:01.600 --> 00:06:02.880
-into a
-
-00:06:02.880 --> 00:06:04.960
-language specific buffer by typing
-
-00:06:04.960 --> 00:06:07.680
-control c single quote
-
-00:06:07.680 --> 00:06:10.240
-so you can see now I have a a go a
-
-00:06:10.240 --> 00:06:12.160
-buffer that's in go mode
-
-00:06:12.160 --> 00:06:14.240
-and gives you all the ability to edit
-
-00:06:14.240 --> 00:06:15.520
-like you would
-
-00:06:15.520 --> 00:06:18.800
-normally if you hit ctrl c
-
-00:06:18.800 --> 00:06:20.800
-single quote again then it goes back and
-
-00:06:20.800 --> 00:06:22.639
-any changes you
-
-00:06:22.639 --> 00:06:25.280
-make would will be updated there but you
-
-00:06:25.280 --> 00:06:26.160
-can do quite a bit
-
-00:06:26.160 --> 00:06:28.000
-just inside of here too there's quite a
-
-00:06:28.000 --> 00:06:29.199
-bit of
-
-00:06:29.199 --> 00:06:33.360
-language specific
-
-00:06:33.360 --> 00:06:35.440
-functionality just in place and so you
-
-00:06:35.440 --> 00:06:36.880
-don't always have to go over to a
-
-00:06:36.880 --> 00:06:38.080
-separate buffer
-
-00:06:38.080 --> 00:06:42.319
-but it's a it's a nice option sometimes
-
-00:06:42.319 --> 00:06:44.319
-but now that you have the code in here
-
-00:06:44.319 --> 00:06:46.720
-you're going to want to run it
-
-00:06:46.720 --> 00:06:48.560
-but right now it just lives here in this
-
-00:06:48.560 --> 00:06:50.240
-documentation
-
-00:06:50.240 --> 00:06:52.160
-so you need to get a copy of it into a
-
-00:06:52.160 --> 00:06:53.840
-separate file
-
-00:06:53.840 --> 00:06:57.440
-and that's the tangle process that you
-
-00:06:57.440 --> 00:07:01.360
-you need to follow there so I'm gonna
-
-00:07:01.360 --> 00:07:03.360
-drop in a little bit more doc a little
-
-00:07:03.360 --> 00:07:05.280
-bit more
-
-00:07:05.280 --> 00:07:12.240
-documentation really quick here
-
-00:07:12.240 --> 00:07:17.360
-okay all right so just kind of as a
-
-00:07:17.360 --> 00:07:21.520
-kind of as a side note I like to follow
-
-00:07:21.520 --> 00:07:24.800
-this process uh whenever having whenever
-
-00:07:24.800 --> 00:07:26.639
-I have an operation to perform I
-
-00:07:26.639 --> 00:07:28.880
-I'd like to document it here with a
-
-00:07:28.880 --> 00:07:31.680
-snippet that can be executed in line
-
-00:07:31.680 --> 00:07:33.280
-then I don't have to leave org mode and
-
-00:07:33.280 --> 00:07:34.639
-I don't have to try to remember what I
-
-00:07:34.639 --> 00:07:36.800
-did later so instead of just
-
-00:07:36.800 --> 00:07:38.960
-trying to do an operation the first time
-
-00:07:38.960 --> 00:07:40.319
-I do something I take the
-
-00:07:40.319 --> 00:07:41.680
-take the time to figure out what it is
-
-00:07:41.680 --> 00:07:43.440
-and document it and so then it's
-
-00:07:43.440 --> 00:07:44.879
-recorded
-
-00:07:44.879 --> 00:07:48.400
-and so here we find that to do a tangle
-
-00:07:48.400 --> 00:07:49.120
-operation
-
-00:07:49.120 --> 00:07:51.680
-you run the command or babel tangled
-
-00:07:51.680 --> 00:07:52.560
-which is a
-
-00:07:52.560 --> 00:07:55.840
-e-list command so if you hit ctrl c
-
-00:07:55.840 --> 00:07:59.199
-ctrl c to run it in place you get the
-
-00:07:59.199 --> 00:08:00.080
-result
-
-00:08:00.080 --> 00:08:02.720
-of main dot go which basically is
-
-00:08:02.720 --> 00:08:03.759
-telling us that
-
-00:08:03.759 --> 00:08:07.680
-we've tangled one file called main.go
-
-00:08:07.680 --> 00:08:11.039
-and you can see that that's true
-
-00:08:11.039 --> 00:08:14.000
-if you go to the file system and you
-
-00:08:14.000 --> 00:08:14.400
-look
-
-00:08:14.400 --> 00:08:17.840
-so now in uh in our demo directory
-
-00:08:17.840 --> 00:08:20.960
-we have a readme.org we have that png
-
-00:08:20.960 --> 00:08:22.479
-that we generated but we also have a
-
-00:08:22.479 --> 00:08:23.440
-main.go
-
-00:08:23.440 --> 00:08:26.080
-and if you if you visit that file you'll
-
-00:08:26.080 --> 00:08:27.759
-see that it's just the source code that
-
-00:08:27.759 --> 00:08:29.280
-was in our documentation which is
-
-00:08:29.280 --> 00:08:31.039
-exactly what we expected and what we
-
-00:08:31.039 --> 00:08:32.880
-wanted so that's good
-
-00:08:32.880 --> 00:08:36.560
-so if we return to
-
-00:08:36.560 --> 00:08:41.120
-to where we are at
-
-00:08:41.120 --> 00:08:42.959
-now we're we're at the point where we
-
-00:08:42.959 --> 00:08:44.640
-have a file on the file system so now we
-
-00:08:44.640 --> 00:08:45.760
-need
-
-00:08:45.760 --> 00:08:48.959
-um now we need to build it and to
-
-00:08:48.959 --> 00:08:53.600
-run it so let's follow the same
-
-00:08:53.600 --> 00:08:57.040
-philosophy where let's document
-
-00:08:57.040 --> 00:08:58.720
-these operations that we're going to
-
-00:08:58.720 --> 00:09:00.160
-perform
-
-00:09:00.160 --> 00:09:04.560
-so I'm dropping in a
-
-00:09:04.560 --> 00:09:07.839
-a build instruction section and a run
-
-00:09:07.839 --> 00:09:13.360
-instruction section
-
-00:09:13.360 --> 00:09:15.279
-so as you can see here we have a little
-
-00:09:15.279 --> 00:09:17.839
-a bash source block
-
-00:09:17.839 --> 00:09:20.000
-and another batch source block this one
-
-00:09:20.000 --> 00:09:22.000
-compiles the go build command is what
-
-00:09:22.000 --> 00:09:25.440
-compiles a file and then
-
-00:09:25.440 --> 00:09:26.880
-the file that gets generated should be
-
-00:09:26.880 --> 00:09:30.080
-called demo
-
-00:09:30.080 --> 00:09:32.959
-and uh so we just run it here so if if I
-
-00:09:32.959 --> 00:09:34.000
-type control c
-
-00:09:34.000 --> 00:09:37.839
-control c we get an empty results block
-
-00:09:37.839 --> 00:09:40.640
-when you compile things no news is good
-
-00:09:40.640 --> 00:09:41.360
-news
-
-00:09:41.360 --> 00:09:44.399
-so it means there's no errors so
-
-00:09:44.399 --> 00:09:46.560
-presumably we've created an executable
-
-00:09:46.560 --> 00:09:48.000
-that's called demo
-
-00:09:48.000 --> 00:09:51.440
-so let's uh
-
-00:09:51.440 --> 00:09:54.560
-let's look again at the file system and
-
-00:09:54.560 --> 00:10:02.480
-regenerate
-
-00:10:02.480 --> 00:10:05.760
-yep and what we have here is a demo
-
-00:10:05.760 --> 00:10:07.200
-executable which is exactly what we
-
-00:10:07.200 --> 00:10:07.760
-wanted
-
-00:10:07.760 --> 00:10:12.079
-so let's go back
-
-00:10:12.079 --> 00:10:14.160
-so now we should be able to run it so
-
-00:10:14.160 --> 00:10:16.079
-ctrl c ctrl c
-
-00:10:16.079 --> 00:10:20.399
-and we get hello world as a result
-
-00:10:20.399 --> 00:10:23.440
-which was exactly what we were expecting
-
-00:10:23.440 --> 00:10:26.560
-so that's already pretty cool
-
-00:10:26.560 --> 00:10:30.839
-you can you can do that much
-
-00:10:30.839 --> 00:10:33.040
-um but
-
-00:10:33.040 --> 00:10:34.560
-that's really just kind of the tip of
-
-00:10:34.560 --> 00:10:37.839
-the iceberg to uh to really
-
-00:10:37.839 --> 00:10:41.040
-kind of um
-
-00:10:41.040 --> 00:10:43.440
-use the more impressive features of
-
-00:10:43.440 --> 00:10:46.160
-literate programming we need to uh
-
-00:10:46.160 --> 00:10:49.920
-we need to do a little bit more
-
-00:10:49.920 --> 00:10:53.200
-so or at least
-
-00:10:53.200 --> 00:10:55.519
-at least really to get the full benefit
-
-00:10:55.519 --> 00:10:56.480
-of it then
-
-00:10:56.480 --> 00:10:59.600
-we need to do
-
-00:10:59.600 --> 00:11:02.959
-add some sections that will cause uh
-
-00:11:02.959 --> 00:11:06.320
-Emacs to have to to tangle or assemble
-
-00:11:06.320 --> 00:11:06.720
-this
-
-00:11:06.720 --> 00:11:09.760
-this file from different pieces so
-
-00:11:09.760 --> 00:11:13.120
-imagine that we wanted to take this file
-
-00:11:13.120 --> 00:11:16.720
-and maybe kind of templatize it
-
-00:11:16.720 --> 00:11:19.120
-so using literature programming syntax
-
-00:11:19.120 --> 00:11:21.279
-this angle bracket syntax
-
-00:11:21.279 --> 00:11:24.399
-let's say that we want to create an in
-
-00:11:24.399 --> 00:11:29.360
-imports section
-
-00:11:29.360 --> 00:11:32.399
-in a functions section
-
-00:11:32.399 --> 00:11:35.040
-and then maybe just a main section and
-
-00:11:35.040 --> 00:11:36.240
-we'll get rid of this
-
-00:11:36.240 --> 00:11:37.920
-so now you see we've created something
-
-00:11:37.920 --> 00:11:39.760
-that looks a little bit like a
-
-00:11:39.760 --> 00:11:42.000
-like a template or a scaffolding or
-
-00:11:42.000 --> 00:11:42.880
-outline
-
-00:11:42.880 --> 00:11:46.000
-for what what our file is going to be it
-
-00:11:46.000 --> 00:11:48.399
-looks a little bit like pseudocode
-
-00:11:48.399 --> 00:11:50.800
-and what we're going to have literate
-
-00:11:50.800 --> 00:11:52.399
-programming do
-
-00:11:52.399 --> 00:11:54.800
-is dynamically insert those things into
-
-00:11:54.800 --> 00:11:56.639
-those slots
-
-00:11:56.639 --> 00:12:00.079
-so the first thing we need to do
-
-00:12:00.079 --> 00:12:03.200
-is so let's create a section
-
-00:12:03.200 --> 00:12:08.079
-maybe called say hello so we want
-
-00:12:08.079 --> 00:12:09.519
-we want to add some functionality that
-
-00:12:09.519 --> 00:12:12.720
-makes our program say hello
-
-00:12:12.720 --> 00:12:15.680
-so using a different snippet that I have
-
-00:12:15.680 --> 00:12:17.600
-for creating something
-
-00:12:17.600 --> 00:12:20.800
-that I call like a literate section
-
-00:12:20.800 --> 00:12:24.079
-um basically we create a
-
-00:12:24.079 --> 00:12:26.000
-another source block that's almost the
-
-00:12:26.000 --> 00:12:27.839
-same as the one for the file but it's
-
-00:12:27.839 --> 00:12:31.040
-it just has a few differences so say we
-
-00:12:31.040 --> 00:12:31.680
-want to
-
-00:12:31.680 --> 00:12:34.160
-drop code into the import section and we
-
-00:12:34.160 --> 00:12:36.639
-want it to be in go
-
-00:12:36.639 --> 00:12:39.120
-here we use the same noed no web no
-
-00:12:39.120 --> 00:12:40.720
-export syntax
-
-00:12:40.720 --> 00:12:43.200
-but then we've added this no web refs
-
-00:12:43.200 --> 00:12:44.560
-imports
-
-00:12:44.560 --> 00:12:48.240
-and this ties that slot
-
-00:12:48.240 --> 00:12:51.120
-basically to this reference it tells
-
-00:12:51.120 --> 00:12:53.760
-Emacs that when you tangle
-
-00:12:53.760 --> 00:12:56.880
-we want to stick whatever's in here in
-
-00:12:56.880 --> 00:12:58.240
-that spot
-
-00:12:58.240 --> 00:13:02.079
-so you skip the tangle file name section
-
-00:13:02.079 --> 00:13:03.279
-because you're not actually creating a
-
-00:13:03.279 --> 00:13:04.240
-file name you're
-
-00:13:04.240 --> 00:13:06.160
-you're putting information into an
-
-00:13:06.160 --> 00:13:07.680
-existing file
-
-00:13:07.680 --> 00:13:10.720
-so here we would just add the fmt
-
-00:13:10.720 --> 00:13:14.399
-for the imports
-
-00:13:14.399 --> 00:13:18.839
-so let's add another section for uh
-
-00:13:18.839 --> 00:13:22.240
-functions and let's create a
-
-00:13:22.240 --> 00:13:25.519
-let's just create a function called
-
-00:13:25.519 --> 00:13:30.240
-say hello that
-
-00:13:30.240 --> 00:13:32.839
-doesn't have any arguments no return
-
-00:13:32.839 --> 00:13:34.000
-types
-
-00:13:34.000 --> 00:13:35.760
-all it does is kind of pretty much the
-
-00:13:35.760 --> 00:13:37.440
-same thing as we did before
-
-00:13:37.440 --> 00:13:39.199
-just print something but let's just say
-
-00:13:39.199 --> 00:13:41.360
-hello
-
-00:13:41.360 --> 00:13:45.760
-Emacs comp this time
-
-00:13:45.760 --> 00:13:49.519
-okay so now we have a function and now
-
-00:13:49.519 --> 00:13:51.040
-the function won't do anything unless we
-
-00:13:51.040 --> 00:13:52.720
-invoke it so let's do
-
-00:13:52.720 --> 00:13:56.000
-one last literate section
-
-00:13:56.000 --> 00:13:59.920
-called main make that go
-
-00:13:59.920 --> 00:14:03.519
-source block and then let's
-
-00:14:03.519 --> 00:14:06.560
-just invoke
-
-00:14:06.560 --> 00:14:10.320
-that that function
-
-00:14:10.320 --> 00:14:13.360
-so now you can see that we've got
-
-00:14:13.360 --> 00:14:15.600
-our scaffolding scaffolding kind of
-
-00:14:15.600 --> 00:14:17.199
-outline and then we have
-
-00:14:17.199 --> 00:14:20.079
-the sections that we want to get tangled
-
-00:14:20.079 --> 00:14:21.360
-or inserted
-
-00:14:21.360 --> 00:14:25.440
-so I I've kind of used this syntax
-
-00:14:25.440 --> 00:14:27.199
-it's it's kind of borrowed from
-
-00:14:27.199 --> 00:14:28.560
-literature programming a little bit with
-
-00:14:28.560 --> 00:14:30.320
-a plus equals so really it's just saying
-
-00:14:30.320 --> 00:14:32.480
-that I want to append
-
-00:14:32.480 --> 00:14:35.760
-this item into the import section so
-
-00:14:35.760 --> 00:14:37.600
-it's really just to make a little bit
-
-00:14:37.600 --> 00:14:39.839
-more clear what's going on
-
-00:14:39.839 --> 00:14:41.519
-when you generate documentation you
-
-00:14:41.519 --> 00:14:43.519
-won't see these
-
-00:14:43.519 --> 00:14:46.160
-these these particular property
-
-00:14:46.160 --> 00:14:49.360
-annotations and so you won't know
-
-00:14:49.360 --> 00:14:51.440
-immediately that this section goes in
-
-00:14:51.440 --> 00:14:53.839
-the imports area and so I usually put
-
-00:14:53.839 --> 00:14:55.440
-a little bit of documentation on top
-
-00:14:55.440 --> 00:14:57.760
-there so that it's easy to see
-
-00:14:57.760 --> 00:15:01.120
-and you would probably if this was very
-
-00:15:01.120 --> 00:15:03.040
-complicated you'd put some
-
-00:15:03.040 --> 00:15:06.399
-documentation above to explain what you
-
-00:15:06.399 --> 00:15:07.360
-were doing
-
-00:15:07.360 --> 00:15:11.519
-maybe right here
-
-00:15:11.519 --> 00:15:13.279
-you could you could picture yourself
-
-00:15:13.279 --> 00:15:15.040
-maybe explaining
-
-00:15:15.040 --> 00:15:17.440
-a complicated algorithm or something up
-
-00:15:17.440 --> 00:15:18.079
-here
-
-00:15:18.079 --> 00:15:21.120
-and having a nice way to document it
-
-00:15:21.120 --> 00:15:22.959
-so now that we've got that here in the
-
-00:15:22.959 --> 00:15:25.600
-documentation we need to figure out
-
-00:15:25.600 --> 00:15:27.040
-we need to make sure that it's going to
-
-00:15:27.040 --> 00:15:29.920
-tangle properly so your best friend
-
-00:15:29.920 --> 00:15:33.519
-at this point is is uh
-
-00:15:33.519 --> 00:15:35.680
-is a keyboard shortcut that lets you
-
-00:15:35.680 --> 00:15:38.240
-preview the tangled operation so if you
-
-00:15:38.240 --> 00:15:38.959
-say control
-
-00:15:38.959 --> 00:15:42.560
-c control v control v
-
-00:15:42.560 --> 00:15:45.120
-it will create a new buffer with the
-
-00:15:45.120 --> 00:15:46.480
-tangled
-
-00:15:46.480 --> 00:15:49.360
-contents and so you can see here that
-
-00:15:49.360 --> 00:15:50.639
-the fmt
-
-00:15:50.639 --> 00:15:53.199
-import went to the right place that
-
-00:15:53.199 --> 00:15:54.720
-function went to the right place the
-
-00:15:54.720 --> 00:15:56.160
-function invocation went to the right
-
-00:15:56.160 --> 00:15:58.480
-place and so we're feeling good
-
-00:15:58.480 --> 00:16:01.279
-you can nest these things many layers
-
-00:16:01.279 --> 00:16:02.800
-deep
-
-00:16:02.800 --> 00:16:04.800
-actually so like if you came into the
-
-00:16:04.800 --> 00:16:07.199
-say hello function you could add
-
-00:16:07.199 --> 00:16:10.560
-more sections
-
-00:16:10.560 --> 00:16:12.160
-you know and it gets and it'll go
-
-00:16:12.160 --> 00:16:13.759
-through and it'll
-
-00:16:13.759 --> 00:16:15.680
-keep track of all that and tangle it for
-
-00:16:15.680 --> 00:16:16.959
-you so you really get a lot of freedom
-
-00:16:16.959 --> 00:16:18.320
-and flexibility for how you want to
-
-00:16:18.320 --> 00:16:19.600
-document things
-
-00:16:19.600 --> 00:16:22.320
-by doing this so now that we've
-
-00:16:22.320 --> 00:16:25.839
-previewed it and we feel good about it
-
-00:16:25.839 --> 00:16:28.639
-we need to uh we need to tangle so we
-
-00:16:28.639 --> 00:16:31.440
-get the file on the file system
-
-00:16:31.440 --> 00:16:34.480
-so ctrl c ctrl c and
-
-00:16:34.480 --> 00:16:37.199
-get just main.go comes back again
-
-00:16:37.199 --> 00:16:37.920
-control c
-
-00:16:37.920 --> 00:16:40.959
-control c and no errors come back
-
-00:16:40.959 --> 00:16:43.839
-and then if we did this right when we
-
-00:16:43.839 --> 00:16:45.600
-when we run this we should get hello
-
-00:16:45.600 --> 00:16:47.199
-Emacs comp so ctrl c
-
-00:16:47.199 --> 00:16:51.199
-ctrl c hello Emacs comp
-
-00:16:51.199 --> 00:16:54.800
-so I uh
-
-00:16:54.800 --> 00:16:57.120
-I think that's pretty pretty cool
-
-00:16:57.120 --> 00:16:58.240
-actually so we've got
-
-00:16:58.240 --> 00:17:00.160
-kind of the breadcrumbs of the process
-
-00:17:00.160 --> 00:17:02.399
-we've gone through to get to this point
-
-00:17:02.399 --> 00:17:05.520
-this initial this initial
-
-00:17:05.520 --> 00:17:08.000
-document that has some tangling in it we
-
-00:17:08.000 --> 00:17:09.919
-have documentation for how to tangle
-
-00:17:09.919 --> 00:17:12.799
-how to build how to run it's we've
-
-00:17:12.799 --> 00:17:14.079
-really built a nice
-
-00:17:14.079 --> 00:17:17.760
-foundation for
-
-00:17:17.760 --> 00:17:20.160
-moving forward on our project and a nice
-
-00:17:20.160 --> 00:17:21.439
-way of breaking things out and
-
-00:17:21.439 --> 00:17:23.280
-documenting further
-
-00:17:23.280 --> 00:17:27.120
-the last piece that we need to
-
-00:17:27.120 --> 00:17:30.559
-take care of is the weave that I
-
-00:17:30.559 --> 00:17:34.799
-that's I showed you in the diagram above
-
-00:17:34.799 --> 00:17:38.640
-so one more time we'll drop in
-
-00:17:38.640 --> 00:17:41.760
-some documentation so this time on how
-
-00:17:41.760 --> 00:17:42.400
-to weave
-
-00:17:42.400 --> 00:17:44.400
-so it's really just an export function
-
-00:17:44.400 --> 00:17:47.520
-it's not there's not a separate weave
-
-00:17:47.520 --> 00:17:49.280
-command going on here we're just going
-
-00:17:49.280 --> 00:17:50.640
-to export
-
-00:17:50.640 --> 00:17:52.799
-what we've got here into a markdown
-
-00:17:52.799 --> 00:17:55.200
-format so we're using org
-
-00:17:55.200 --> 00:17:57.440
-gfm export to markdown which is the
-
-00:17:57.440 --> 00:17:58.880
-github style
-
-00:17:58.880 --> 00:18:02.160
-markdown you can use the other just
-
-00:18:02.160 --> 00:18:05.440
-more standard type as well so hit ctrl c
-
-00:18:05.440 --> 00:18:10.320
-ctrl c now you see we've got a readme
-
-00:18:10.320 --> 00:18:15.280
-file and if you look
-
-00:18:15.280 --> 00:18:17.440
-in the file system we've got that right
-
-00:18:17.440 --> 00:18:19.120
-there and so
-
-00:18:19.120 --> 00:18:23.120
-if you go to something like ghostwriter
-
-00:18:23.120 --> 00:18:31.679
-and open that file
-
-00:18:31.679 --> 00:18:34.559
-now you can see that it's generated some
-
-00:18:34.559 --> 00:18:35.520
-documentation
-
-00:18:35.520 --> 00:18:38.320
-it puts a index at top at the top I
-
-00:18:38.320 --> 00:18:39.679
-usually just
-
-00:18:39.679 --> 00:18:42.000
-I usually turn that off it's easy to do
-
-00:18:42.000 --> 00:18:43.679
-that by putting a property at the top of
-
-00:18:43.679 --> 00:18:44.559
-your
-
-00:18:44.559 --> 00:18:46.880
-your org file but some people like to
-
-00:18:46.880 --> 00:18:48.559
-have an index
-
-00:18:48.559 --> 00:18:50.799
-but here you can see that it's generated
-
-00:18:50.799 --> 00:18:52.160
-pretty nicely and
-
-00:18:52.160 --> 00:18:55.200
-formatted snippets well
-
-00:18:55.200 --> 00:18:56.880
-put the diagram in there and then it's
-
-00:18:56.880 --> 00:18:58.240
-preserved
-
-00:18:58.240 --> 00:19:01.039
-it's preserved this literate programming
-
-00:19:01.039 --> 00:19:02.799
-syntax
-
-00:19:02.799 --> 00:19:04.960
-which is important because that's how we
-
-00:19:04.960 --> 00:19:06.480
-want to view the documentation that's
-
-00:19:06.480 --> 00:19:07.200
-what the no
-
-00:19:07.200 --> 00:19:10.559
-exports um
-
-00:19:10.559 --> 00:19:13.360
-property was was trying to maintain so
-
-00:19:13.360 --> 00:19:14.000
-that
-
-00:19:14.000 --> 00:19:16.080
-no exports means when you export do not
-
-00:19:16.080 --> 00:19:18.400
-try to tangle so that's
-
-00:19:18.400 --> 00:19:20.559
-hopefully that makes more sense now but
-
-00:19:20.559 --> 00:19:22.240
-now you can see all the documentation
-
-00:19:22.240 --> 00:19:26.080
-and I think it demonstrates a
-
-00:19:26.080 --> 00:19:29.919
-pretty useful feature that's inside of
-
-00:19:29.919 --> 00:19:33.520
-Emacs and and hopefully
-
-00:19:33.520 --> 00:19:35.039
-hopefully you'll have as much fun using
-
-00:19:35.039 --> 00:19:39.919
-that as I have
-
-00:19:39.919 --> 00:19:43.600
-so thanks
diff --git a/2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard.vtt b/2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard.vtt
new file mode 100644
index 00000000..608729bd
--- /dev/null
+++ b/2020/subtitles/emacsconf-2020--14-readme-driven-design--adam-ard.vtt
@@ -0,0 +1,1297 @@
+WEBVTT
+
+00:00:03.600 --> 00:00:04.400
+Adam: Hello!
+
+00:00:04.400 --> 00:00:06.560
+Welcome to Readme Driven Design in Emacs
+
+00:00:06.560 --> 00:00:08.400
+by Adam Aard.
+
+00:00:08.400 --> 00:00:10.800
+If you're a programmer, you're accustomed
+
+00:00:10.800 --> 00:00:12.559
+to putting a README file at the root of
+
+00:00:12.559 --> 00:00:13.759
+your project.
+
+00:00:13.759 --> 00:00:15.845
+It's usually a Markdown file
+
+00:00:15.845 --> 00:00:20.579
+But if you use an Org Mode file instead,
+
+00:00:20.579 --> 00:00:22.560
+you can take advantage of the
+great features
+
+00:00:22.560 --> 00:00:24.400
+that Org Mode provides, including
+
+00:00:24.400 --> 00:00:25.920
+literate programming,
+
+00:00:25.920 --> 00:00:28.000
+which lets you generate your source code
+
+00:00:28.000 --> 00:00:31.840
+and Markdown documentation dynamically.
+
+00:00:31.840 --> 00:00:34.719
+I want to walk you through a little bit
+
+00:00:34.719 --> 00:00:37.120
+of what this looks like.
+
+00:00:37.120 --> 00:00:39.440
+When you start a project, especially if
+
+00:00:39.440 --> 00:00:41.280
+if you use something like Github you
+
+00:00:41.280 --> 00:00:43.320
+begin with an automatically generated
+
+00:00:43.320 --> 00:00:47.039
+README.md file. So just delete that
+
+00:00:47.039 --> 00:00:50.239
+and instead create a README.org file.
+
+00:00:50.239 --> 00:00:51.712
+Starting with an empty Org file,
+
+00:00:51.712 --> 00:00:54.800
+like you see here, you can begin
+
+00:00:54.800 --> 00:00:56.559
+by recording important information about
+
+00:00:56.559 --> 00:00:59.440
+your project goals. You can add diagrams,
+
+00:00:59.440 --> 00:01:01.920
+code snippets, to-do lists, time tracking
+
+00:01:01.920 --> 00:01:03.520
+and much more.
+
+00:01:03.520 --> 00:01:05.360
+I'm going to drop in some documentation
+
+00:01:05.360 --> 00:01:07.760
+that that I've written about
+
+00:01:07.760 --> 00:01:12.240
+about my project here, so you can see
+
+00:01:12.240 --> 00:01:15.280
+what this would look like.
+
+00:01:15.280 --> 00:01:17.119
+As you can see, I have a title, and a
+
+00:01:17.119 --> 00:01:20.320
+description, and then a subsection
+
+00:01:20.320 --> 00:01:23.840
+as well as some code snippets.
+
+00:01:23.840 --> 00:01:25.520
+You can see that Org Mode does a great
+
+00:01:25.520 --> 00:01:28.240
+job of formatting lists,
+
+00:01:28.240 --> 00:01:31.280
+code sections, diagrams, and so forth.
+
+00:01:31.280 --> 00:01:35.040
+It's as good or better than Markdown,
+
+00:01:35.040 --> 00:01:37.179
+but when you use it in Emacs
+
+00:01:37.179 --> 00:01:38.880
+you can do a lot more.
+
+00:01:38.880 --> 00:01:40.479
+For example, you can dynamically create
+
+00:01:40.479 --> 00:01:43.360
+diagrams using Graphviz
+
+00:01:43.360 --> 00:01:45.200
+from a text description. If you go to
+
+00:01:45.200 --> 00:01:46.560
+this source block here
+
+00:01:46.560 --> 00:01:49.439
+and hit C-c C-c, you'll see
+
+00:01:49.439 --> 00:01:52.979
+that we generate a diagram dynamically
+
+00:01:55.439 --> 00:01:59.200
+You can run these code snippets in
+
+00:01:59.200 --> 00:02:00.799
+place and get the results
+
+00:02:00.799 --> 00:02:03.040
+to show up inside of your file,
+
+00:02:03.040 --> 00:02:08.000
+which is a really powerful paradigm.
+
+00:02:08.000 --> 00:02:10.640
+But most importantly, for
+
+00:02:10.640 --> 00:02:14.800
+my purposes here,
+
+00:02:14.800 --> 00:02:17.200
+Org Mode provides you the ability to do
+
+00:02:17.200 --> 00:02:19.520
+literate programming.
+
+00:02:19.520 --> 00:02:21.440
+So take a quick look at this diagram
+
+00:02:21.440 --> 00:02:23.200
+that I generated here.
+
+00:02:23.200 --> 00:02:25.312
+It gives you a quick overview of what
+
+00:02:25.312 --> 00:02:27.520
+I mean by literate programming
+
+00:02:27.520 --> 00:02:31.200
+and how I'm using it. You can see
+
+00:02:31.200 --> 00:02:34.720
+that we start with a README.org file
+on top.
+
+00:02:34.720 --> 00:02:37.920
+At this point, we can do one of two
+things:
+
+00:02:37.920 --> 00:02:41.280
+tangle or weave. Tangle is used to
+
+00:02:41.280 --> 00:02:42.720
+describe the process of
+
+00:02:42.720 --> 00:02:46.319
+generating source code, while weave
+
+00:02:46.319 --> 00:02:47.599
+is the process of generating
+
+00:02:47.599 --> 00:02:49.840
+documentation. These are terms that
+
+00:02:49.840 --> 00:02:51.920
+Donald Knuth used.
+
+00:02:51.920 --> 00:02:53.840
+He's the one that came up with the
+
+00:02:53.840 --> 00:02:55.519
+idea of literate programming
+
+00:02:55.519 --> 00:02:59.920
+in the early 1980s.
+
+00:02:59.920 --> 00:03:01.945
+But this is really all that there is to
+it.
+
+00:03:01.945 --> 00:03:05.412
+You just... You are simply
+
+00:03:05.412 --> 00:03:07.840
+using a literate source file,
+
+00:03:07.840 --> 00:03:10.319
+in this case the README.org, to generate
+
+00:03:11.680 --> 00:03:17.120
+the rest of the project files, basically.
+
+00:03:17.120 --> 00:03:22.640
+So let's dig in to the details of how
+this works.
+
+00:03:22.640 --> 00:03:24.560
+I hope you... Hopefully you'll see how
+
+00:03:24.560 --> 00:03:26.159
+cool this is.
+
+00:03:26.159 --> 00:03:27.545
+So returning to the file here.
+
+00:03:27.545 --> 00:03:31.120
+Let's assume we have enough
+documentation now,
+
+00:03:31.120 --> 00:03:32.679
+that we want to get started
+coding.
+
+00:03:32.679 --> 00:03:34.159
+So maybe we'll just start with
+
+00:03:34.159 --> 00:03:35.845
+like a Hello World app,
+
+00:03:35.845 --> 00:03:38.159
+just so we can make sure that our
+
+00:03:38.159 --> 00:03:41.519
+environment is set up correctly.
+
+00:03:41.519 --> 00:03:47.120
+Let's get started with a code block.
+
+00:03:47.120 --> 00:03:49.519
+So I created a little snippet to help me
+
+00:03:49.519 --> 00:03:51.612
+add a source block for
+
+00:03:51.612 --> 00:03:53.599
+literate programming quickly.
+
+00:03:53.599 --> 00:03:56.959
+There's not much to it,
+
+00:03:56.959 --> 00:03:59.479
+but there are some important annotations
+here.
+
+00:04:01.599 --> 00:04:04.080
+Excuse me. There's a property
+
+00:04:04.080 --> 00:04:05.200
+called :tangle
+
+00:04:05.200 --> 00:04:09.360
+and that takes a value of a file name.
+
+00:04:09.360 --> 00:04:13.280
+Then there's also a :noweb property
+
+00:04:13.280 --> 00:04:18.880
+called no-export.
+
+00:04:23.759 --> 00:04:26.800
+Basically, the noexport--we'll explain
+
+00:04:26.800 --> 00:04:29.645
+that a little bit more later
+
+00:04:29.645 --> 00:04:32.080
+It has has to do with how
+
+00:04:32.080 --> 00:04:36.845
+the tangling is done in the tangle
+step
+
+00:04:36.845 --> 00:04:38.479
+versus the weave step.
+
+00:04:38.479 --> 00:04:40.212
+I'll explain that a little bit more.
+
+00:04:40.212 --> 00:04:45.199
+But the tangle field just simply tells
+
+00:04:45.199 --> 00:04:48.320
+Emacs where it needs to generate the
+
+00:04:48.320 --> 00:04:50.320
+main.go file and where it needs to put
+
+00:04:50.320 --> 00:04:55.360
+it on the file system.
+
+00:04:55.360 --> 00:04:57.680
+You'll notice that we we're
+
+00:04:57.680 --> 00:04:59.040
+going to use Go.
+
+00:04:59.040 --> 00:05:01.440
+That's just the language that I've been
+
+00:05:01.440 --> 00:05:03.379
+using the most lately,
+
+00:05:03.379 --> 00:05:06.845
+but this programming strategy
+
+00:05:06.845 --> 00:05:08.400
+is language-agnostic.
+
+00:05:08.400 --> 00:05:11.279
+You could use any language
+
+00:05:11.279 --> 00:05:13.145
+or any mix of languages.
+
+00:05:13.145 --> 00:05:14.720
+You could create some files
+
+00:05:14.720 --> 00:05:16.560
+in Python, some files in Go,
+
+00:05:16.560 --> 00:05:19.179
+some files in Lisp,
+
+00:05:19.179 --> 00:05:21.520
+or whatever you want.
+
+00:05:24.720 --> 00:05:29.440
+Let's create just a little
+Hello World.
+
+00:05:29.440 --> 00:05:31.379
+Let's use another snippet here
+
+00:05:31.379 --> 00:05:36.560
+to generate the basics of a Go program.
+
+00:05:36.560 --> 00:05:40.240
+I'm just going to print
+
+00:05:40.240 --> 00:05:44.960
+Hello World.
+
+00:05:44.960 --> 00:05:48.560
+So that's... And then
+
+00:05:48.560 --> 00:05:52.779
+let's make it a section in our file.
+
+00:05:52.779 --> 00:05:55.045
+So now you can see, we've got
+
+00:05:55.045 --> 00:05:56.400
+this snippet.
+
+00:05:56.400 --> 00:05:59.600
+When you have a source block in
+
+00:05:59.600 --> 00:06:01.600
+inside of Org Mode, you can easily pop
+
+00:06:01.600 --> 00:06:04.960
+into a language-specific buffer
+by typing
+
+00:06:04.960 --> 00:06:07.680
+C-c ' (single quote).
+
+00:06:07.680 --> 00:06:10.240
+So you can see, now I have a
+
+00:06:10.240 --> 00:06:12.160
+buffer that's in go-mode
+
+00:06:12.160 --> 00:06:14.240
+and gives you all the ability to edit
+
+00:06:14.240 --> 00:06:15.520
+like you would
+
+00:06:15.520 --> 00:06:19.945
+normally. If you hit C-c '
+(single quote)
+
+00:06:19.945 --> 00:06:20.800
+again, it goes back and
+
+00:06:20.800 --> 00:06:25.045
+any changes you make will be
+updated there.
+
+00:06:25.045 --> 00:06:26.160
+But you can do quite a bit
+
+00:06:26.160 --> 00:06:27.879
+just inside of here too.
+
+00:06:27.879 --> 00:06:29.199
+There's quite a bit of
+
+00:06:29.199 --> 00:06:34.479
+language-specific functionality
+
+00:06:34.479 --> 00:06:35.312
+just in place,
+
+00:06:35.312 --> 00:06:36.880
+so you don't always have to go over to a
+
+00:06:36.880 --> 00:06:38.080
+separate buffer.
+
+00:06:38.080 --> 00:06:42.319
+It's a nice option sometimes.
+
+00:06:42.319 --> 00:06:44.319
+Now that you have the code in here,
+
+00:06:44.319 --> 00:06:46.720
+you're going to want to run it.
+
+00:06:46.720 --> 00:06:48.179
+Right now, it just lives here
+
+00:06:48.179 --> 00:06:50.240
+in this documentation.
+
+00:06:50.240 --> 00:06:52.160
+You need to get a copy of it into a
+
+00:06:52.160 --> 00:06:53.840
+separate file,
+
+00:06:53.840 --> 00:06:57.440
+and that's the tangle process that you
+
+00:06:57.440 --> 00:07:01.360
+you need to follow there. So I'm gonna
+
+00:07:01.360 --> 00:07:03.360
+drop in a little bit more doc, a little
+
+00:07:03.360 --> 00:07:12.240
+bit more documentation really quick here.
+
+00:07:12.240 --> 00:07:19.112
+Okay, all right. So just as a side note,
+
+00:07:19.112 --> 00:07:22.845
+I like to follow this process.
+
+00:07:22.845 --> 00:07:26.639
+Whenever I have an operation to perform,
+
+00:07:26.639 --> 00:07:28.880
+I'd like to document it here with a
+
+00:07:28.880 --> 00:07:31.680
+snippet that can be executed inline.
+
+00:07:31.680 --> 00:07:33.280
+Then I don't have to leave Org Mode, and
+
+00:07:33.280 --> 00:07:34.639
+I don't have to try to remember what I
+
+00:07:34.639 --> 00:07:36.800
+did later. So instead of just
+
+00:07:36.800 --> 00:07:38.960
+trying to do an operation, the first time
+
+00:07:38.960 --> 00:07:40.319
+I do something,
+
+00:07:40.319 --> 00:07:41.680
+I take the time to figure out what it is
+
+00:07:41.680 --> 00:07:44.879
+and document it, so then it's
+recorded.
+
+00:07:44.879 --> 00:07:49.120
+So here we find that to do a tangle
+operation,
+
+00:07:49.120 --> 00:07:51.680
+you run the command org-babel-tangle,
+
+00:07:51.680 --> 00:07:53.779
+which is an Elisp command.
+
+00:07:53.779 --> 00:07:58.712
+If you hit C-c C-c to run it in place,
+
+00:07:58.712 --> 00:08:00.080
+you get the result
+
+00:08:00.080 --> 00:08:02.720
+of main.go, which basically is
+
+00:08:02.720 --> 00:08:03.759
+telling us that
+
+00:08:03.759 --> 00:08:07.680
+we've tangled one file called main.go.
+
+00:08:07.680 --> 00:08:11.039
+You can see that that's true
+
+00:08:11.039 --> 00:08:12.879
+if you go to the file system
+
+00:08:12.879 --> 00:08:14.400
+and you look.
+
+00:08:14.400 --> 00:08:17.840
+Now in our demo directory,
+
+00:08:17.840 --> 00:08:19.712
+we have a README.org,
+
+00:08:19.712 --> 00:08:22.045
+we have that PNG that we generated,
+
+00:08:22.045 --> 00:08:23.440
+but we also have a main.go.
+
+00:08:23.440 --> 00:08:25.945
+If you visit that file,
+
+00:08:25.945 --> 00:08:27.045
+you'll see that it's just
+
+00:08:27.045 --> 00:08:28.212
+the source code that was
+
+00:08:28.212 --> 00:08:29.280
+in our documentation, which is
+
+00:08:29.280 --> 00:08:30.679
+exactly what we expected
+
+00:08:30.679 --> 00:08:32.880
+and what we wanted. So that's good.
+
+00:08:32.880 --> 00:08:41.120
+So if we return to where we were at...
+
+00:08:41.120 --> 00:08:42.959
+Now we're at the point where we
+
+00:08:42.959 --> 00:08:44.479
+have a file on the file system.
+
+00:08:45.760 --> 00:08:48.379
+Now we need to build it
+
+00:08:48.379 --> 00:08:49.612
+and to run it.
+
+00:08:49.612 --> 00:08:57.040
+So let's follow the same philosophy,
+where let's document
+
+00:08:57.040 --> 00:09:00.160
+these operations that we're going to
+perform.
+
+00:09:00.160 --> 00:09:04.560
+I'm dropping in a
+
+00:09:04.560 --> 00:09:07.112
+a build instruction section
+
+00:09:07.112 --> 00:09:13.360
+and a run instruction section.
+
+00:09:13.360 --> 00:09:15.279
+As you can see here, we have a little
+
+00:09:15.279 --> 00:09:17.839
+a bash source block,
+
+00:09:17.839 --> 00:09:19.245
+and another bash source block.
+
+00:09:19.245 --> 00:09:21.812
+This one compiles. The go build command
+
+00:09:21.812 --> 00:09:25.440
+is what compiles a file. Then
+
+00:09:25.440 --> 00:09:26.579
+the file that gets generated
+
+00:09:26.579 --> 00:09:30.080
+should be called demo.
+
+00:09:30.080 --> 00:09:32.412
+So we just run it here.
+
+00:09:32.412 --> 00:09:37.839
+If I type C-c C-c, we get an
+empty results block.
+
+00:09:37.839 --> 00:09:38.979
+When you compile things,
+
+00:09:38.979 --> 00:09:41.360
+no news is good news.
+
+00:09:41.360 --> 00:09:43.012
+It means there's no errors
+
+00:09:43.012 --> 00:09:45.912
+So presumably, we've created
+
+00:09:45.912 --> 00:09:48.000
+an executable that's called demo.
+
+00:09:51.440 --> 00:09:53.312
+Let's look again at the file system
+
+00:09:53.312 --> 00:10:02.480
+and regenerate...
+
+00:10:02.480 --> 00:10:06.479
+Yep. What we have here is a demo
+executable,
+
+00:10:06.479 --> 00:10:07.760
+which is exactly what we
+wanted.
+
+00:10:07.760 --> 00:10:12.079
+Let's go back.
+
+00:10:12.079 --> 00:10:14.160
+Now we should be able to run it.
+
+00:10:14.160 --> 00:10:16.079
+C-c C-c,
+
+00:10:16.079 --> 00:10:20.399
+and we get Hello World as a result,
+
+00:10:20.399 --> 00:10:23.440
+which was exactly what we were expecting.
+
+00:10:23.440 --> 00:10:26.560
+So that's already pretty cool.
+
+00:10:26.560 --> 00:10:30.839
+You can do that much.
+
+00:10:33.040 --> 00:10:34.560
+That's really just the tip of
+
+00:10:34.560 --> 00:10:37.839
+the iceberg. To really
+
+00:10:41.040 --> 00:10:43.440
+use the more impressive features of
+
+00:10:43.440 --> 00:10:46.160
+literate programming,
+
+00:10:46.160 --> 00:10:49.920
+we need to do a little bit more
+
+00:10:53.200 --> 00:10:54.512
+at least. Really,
+
+00:10:54.512 --> 00:10:56.480
+to get the full benefit of it,
+
+00:10:56.480 --> 00:11:01.079
+we need to add some sections
+
+00:11:01.079 --> 00:11:04.412
+that will cause Emacs to have to
+
+00:11:04.412 --> 00:11:06.720
+tangle or assemble
+
+00:11:06.720 --> 00:11:09.760
+this file from different pieces.
+
+00:11:09.760 --> 00:11:13.120
+Imagine that we wanted to take this file
+
+00:11:13.120 --> 00:11:16.720
+and maybe kind of templatize it.
+
+00:11:16.720 --> 00:11:19.120
+So, using literature programming syntax,
+
+00:11:19.120 --> 00:11:21.279
+this angle bracket syntax,
+
+00:11:21.279 --> 00:11:24.399
+let's say that we want to create an
+
+00:11:24.399 --> 00:11:29.360
+imports section,
+
+00:11:29.360 --> 00:11:32.399
+a functions section,
+
+00:11:32.399 --> 00:11:35.040
+and then maybe just a main section.
+
+00:11:35.040 --> 00:11:36.240
+We'll get rid of this.
+
+00:11:36.240 --> 00:11:37.920
+So now you see, we've created something
+
+00:11:37.920 --> 00:11:39.760
+that looks a little bit like a
+
+00:11:39.760 --> 00:11:42.880
+template or a scaffolding or outline
+
+00:11:42.880 --> 00:11:45.812
+for what our file is going to be.
+
+00:11:45.812 --> 00:11:48.399
+It looks a little bit like pseudocode.
+
+00:11:48.399 --> 00:11:50.612
+What we're going to have
+
+00:11:50.612 --> 00:11:52.399
+literate programming do
+
+00:11:52.399 --> 00:11:54.800
+is dynamically insert those things into
+
+00:11:54.800 --> 00:11:56.639
+those slots.
+
+00:11:56.639 --> 00:12:00.079
+So the first thing we need to do
+
+00:12:00.079 --> 00:12:03.200
+is... So let's create a section
+
+00:12:03.200 --> 00:12:08.079
+called "Say Hello."
+
+00:12:08.079 --> 00:12:09.519
+We want to add some functionality that
+
+00:12:09.519 --> 00:12:12.720
+makes our program say hello.
+
+00:12:12.720 --> 00:12:15.680
+So using a different snippet that I have
+
+00:12:15.680 --> 00:12:17.600
+for creating something
+
+00:12:17.600 --> 00:12:20.800
+that I call like a literate section,
+
+00:12:20.800 --> 00:12:24.079
+basically, we create a
+
+00:12:24.079 --> 00:12:26.000
+another source block that's almost the
+
+00:12:26.000 --> 00:12:27.839
+same as the one for the file.
+
+00:12:27.839 --> 00:12:29.412
+It just has a few differences
+
+00:12:29.412 --> 00:12:34.079
+Say we want to drop code into the import
+section
+
+00:12:34.079 --> 00:12:36.639
+and we want it to be in Go.
+
+00:12:36.639 --> 00:12:40.720
+Here we use the same :noweb no-export syntax,
+
+00:12:40.720 --> 00:12:44.560
+but then we've added this :noweb-ref imports,
+
+00:12:44.560 --> 00:12:48.240
+and this ties that slot
+
+00:12:48.240 --> 00:12:51.120
+to this reference. It tells
+
+00:12:51.120 --> 00:12:53.760
+Emacs that when you tangle,
+
+00:12:53.760 --> 00:12:55.479
+we want to stick whatever's in here
+
+00:12:55.479 --> 00:12:58.240
+in that spot.
+
+00:12:58.240 --> 00:13:02.079
+You skip the tangle file name section
+
+00:13:02.079 --> 00:13:03.279
+because you're not actually creating a
+
+00:13:03.279 --> 00:13:04.240
+file name.
+
+00:13:04.240 --> 00:13:06.160
+You're putting information into an
+
+00:13:06.160 --> 00:13:07.680
+existing file.
+
+00:13:07.680 --> 00:13:10.720
+So here, we would just add the "fmt"
+
+00:13:10.720 --> 00:13:14.399
+for the imports.
+
+00:13:14.399 --> 00:13:16.145
+Let's add another section
+
+00:13:16.145 --> 00:13:22.240
+for functions.
+
+00:13:22.240 --> 00:13:23.812
+Let's just create a function
+
+00:13:23.812 --> 00:13:28.079
+called sayHello
+
+00:13:28.079 --> 00:13:31.745
+that doesn't have any arguments.
+
+00:13:31.745 --> 00:13:34.000
+No return types.
+
+00:13:34.000 --> 00:13:35.760
+All it does is pretty much the
+
+00:13:35.760 --> 00:13:37.440
+same thing as we did before:
+
+00:13:37.440 --> 00:13:38.479
+just print something.
+
+00:13:38.479 --> 00:13:45.760
+Let's just say "Hello EmacsConf"
+this time.
+
+00:13:45.760 --> 00:13:47.279
+Now we have a function,
+
+00:13:47.279 --> 00:13:50.779
+and now the function won't do anything
+
+00:13:50.779 --> 00:13:52.720
+unless we invoke it. Let's do
+
+00:13:52.720 --> 00:13:56.000
+one last literate section
+
+00:13:56.000 --> 00:13:59.920
+called main. Make that Go
+
+00:13:59.920 --> 00:14:03.519
+source block. Then let's
+
+00:14:03.519 --> 00:14:10.320
+invoke that function.
+
+00:14:10.320 --> 00:14:13.360
+Now you can see that we've got
+
+00:14:13.360 --> 00:14:15.600
+our scaffolding
+
+00:14:15.600 --> 00:14:17.199
+outline, and then we have
+
+00:14:17.199 --> 00:14:20.079
+the sections that we want to get tangled
+
+00:14:20.079 --> 00:14:21.360
+or inserted.
+
+00:14:21.360 --> 00:14:25.440
+I've used this syntax.
+
+00:14:25.440 --> 00:14:27.199
+It's kinda borrowed from
+
+00:14:27.199 --> 00:14:28.479
+literate programming a little bit
+
+00:14:28.479 --> 00:14:30.320
+with a +=, so really it's just saying
+
+00:14:30.320 --> 00:14:32.480
+that I want to append
+
+00:14:32.480 --> 00:14:35.760
+this item into the import section
+
+00:14:35.760 --> 00:14:37.600
+It's really just to make a little bit
+
+00:14:37.600 --> 00:14:39.839
+more clear what's going on.
+
+00:14:39.839 --> 00:14:41.445
+When you generate documentation,
+
+00:14:41.445 --> 00:14:43.519
+you won't see these
+
+00:14:43.519 --> 00:14:46.979
+particular property annotations,
+
+00:14:46.979 --> 00:14:50.145
+and so you won't know immediately
+
+00:14:50.145 --> 00:14:51.779
+that this section goes in the
+
+00:14:51.779 --> 00:14:53.839
+imports area. So I usually put
+
+00:14:53.839 --> 00:14:55.440
+a little bit of documentation on top
+
+00:14:55.440 --> 00:14:57.760
+there, so that it's easy to see.
+
+00:14:57.760 --> 00:15:01.120
+You would, probably, if this was very
+
+00:15:01.120 --> 00:15:03.040
+complicated, you'd put some
+
+00:15:03.040 --> 00:15:06.245
+documentation above to explain
+
+00:15:06.245 --> 00:15:07.360
+what you were doing,
+
+00:15:07.360 --> 00:15:11.519
+maybe right here.
+
+00:15:11.519 --> 00:15:13.279
+You could picture yourself
+
+00:15:13.279 --> 00:15:15.040
+maybe explaining
+
+00:15:15.040 --> 00:15:16.745
+a complicated algorithm
+
+00:15:16.745 --> 00:15:18.079
+or something up here
+
+00:15:18.079 --> 00:15:21.120
+and having a nice way to document it.
+
+00:15:21.120 --> 00:15:22.959
+So now that we've got that here in the
+
+00:15:22.959 --> 00:15:25.600
+documentation, we need to figure out...
+
+00:15:25.600 --> 00:15:27.040
+We need to make sure that it's going to
+
+00:15:27.040 --> 00:15:28.045
+tangle properly.
+
+00:15:28.045 --> 00:15:33.519
+Your best friend at this point
+
+00:15:33.519 --> 00:15:35.680
+is a keyboard shortcut that lets you
+
+00:15:35.680 --> 00:15:37.945
+preview the tangled operation.
+
+00:15:37.945 --> 00:15:42.560
+If you say C-c C-v C-v,
+
+00:15:42.560 --> 00:15:44.079
+it will create a new buffer
+
+00:15:44.079 --> 00:15:47.212
+with the tangled contents
+
+00:15:47.212 --> 00:15:49.179
+and so you can see here
+
+00:15:49.179 --> 00:15:52.345
+that the fmt import went to the right
+place,
+
+00:15:52.345 --> 00:15:54.679
+that function went to the right place,
+
+00:15:54.679 --> 00:15:56.079
+the function invocation went to
+
+00:15:56.079 --> 00:15:58.480
+the right place. We're feeling good.
+
+00:15:58.480 --> 00:16:00.912
+You can nest these things
+
+00:16:00.912 --> 00:16:02.800
+many layers deep.
+
+00:16:02.800 --> 00:16:06.045
+If you came into the sayHello function,
+
+00:16:06.045 --> 00:16:10.560
+you could add more sections.
+
+00:16:10.560 --> 00:16:13.759
+It'll go through and it'll
+
+00:16:13.759 --> 00:16:15.345
+keep track of all that
+
+00:16:15.345 --> 00:16:16.212
+and tangle it for you
+
+00:16:16.212 --> 00:16:16.959
+so you really get a lot of freedom
+
+00:16:16.959 --> 00:16:18.320
+and flexibility for how you want to
+
+00:16:18.320 --> 00:16:20.479
+document things by doing this.
+
+00:16:20.479 --> 00:16:23.079
+So now that we've previewed it
+
+00:16:23.079 --> 00:16:25.839
+and we feel good about it,
+
+00:16:25.839 --> 00:16:28.639
+we need to tangle so
+
+00:16:28.639 --> 00:16:31.440
+we get the file on the file system.
+
+00:16:31.440 --> 00:16:34.979
+so C-c C-c and get...
+
+00:16:34.979 --> 00:16:37.199
+just main.go comes back again.
+
+00:16:37.199 --> 00:16:40.959
+C-c C-cc and no errors come back.
+
+00:16:40.959 --> 00:16:43.279
+Then if we did this right,
+
+00:16:43.279 --> 00:16:45.079
+when we run this, we should get
+
+00:16:45.079 --> 00:16:45.600
+"Hello, EmacsConf."
+
+00:16:45.600 --> 00:16:51.199
+So C-c C-c, Hello EmacsConf.
+
+00:16:54.800 --> 00:16:57.645
+I think that's pretty, pretty cool,
+actually.
+
+00:16:57.645 --> 00:16:59.579
+So we've got the breadcrumbs
+
+00:16:59.579 --> 00:17:01.212
+of the process we've gone through
+
+00:17:01.212 --> 00:17:02.399
+to get to this point,
+
+00:17:02.399 --> 00:17:07.545
+this initial document that has some
+tangling in it.
+
+00:17:07.545 --> 00:17:09.919
+We have documentation for how to tangle,
+
+00:17:09.919 --> 00:17:11.345
+how to build, how to run.
+
+00:17:11.345 --> 00:17:15.045
+We've really built a nice foundation
+
+00:17:15.045 --> 00:17:19.379
+for moving forward on our project
+
+00:17:19.379 --> 00:17:21.439
+and a nice way of breaking things
+out
+
+00:17:21.439 --> 00:17:23.280
+and documenting further.
+
+00:17:23.280 --> 00:17:27.120
+The last piece that we need to
+
+00:17:27.120 --> 00:17:30.559
+take care of is the weave that
+
+00:17:30.559 --> 00:17:34.799
+I showed you in the diagram above.
+
+00:17:34.799 --> 00:17:38.640
+So one more time, we'll drop in
+
+00:17:38.640 --> 00:17:41.760
+some documentatio, this time on how
+
+00:17:41.760 --> 00:17:42.400
+to weave.
+
+00:17:42.400 --> 00:17:44.400
+It's really just an export function.
+
+00:17:44.400 --> 00:17:46.245
+it's not... There's not a separate
+
+00:17:46.245 --> 00:17:49.012
+weave command going on here.
+
+00:17:49.012 --> 00:17:50.640
+we're just going to export
+
+00:17:50.640 --> 00:17:53.512
+what we've got here into a Markdown
+format.
+
+00:17:53.512 --> 00:17:57.045
+We're using org-gfm-export-to-markdown,
+
+00:17:57.045 --> 00:17:59.745
+which is the Github style markdown.
+
+00:17:59.745 --> 00:18:02.160
+You can use the other,
+
+00:18:02.160 --> 00:18:03.812
+more standard type as well.
+
+00:18:03.812 --> 00:18:08.479
+Hit C-c C-c. Now you see
+
+00:18:08.479 --> 00:18:11.312
+we've got a README file,
+
+00:18:11.312 --> 00:18:16.512
+and if you look in the file system,
+
+00:18:16.512 --> 00:18:19.120
+we've got that right there.
+
+00:18:19.120 --> 00:18:23.120
+If you go to something like ghostwriter
+
+00:18:23.120 --> 00:18:31.679
+and open that file,
+
+00:18:31.679 --> 00:18:32.879
+now you can see that
+
+00:18:32.879 --> 00:18:35.520
+it's generated some documentation.
+
+00:18:35.520 --> 00:18:37.645
+It puts a index at top at the top.
+
+00:18:39.679 --> 00:18:41.145
+I usually turn that off.
+
+00:18:41.145 --> 00:18:42.379
+It's easy to do that by
+
+00:18:42.379 --> 00:18:43.179
+putting a property at the
+
+00:18:43.179 --> 00:18:46.145
+top of your Org file,
+
+00:18:46.145 --> 00:18:46.880
+but some people like to
+
+00:18:46.880 --> 00:18:48.559
+have an index.
+
+00:18:48.559 --> 00:18:50.799
+Here you can see that it has generated
+
+00:18:50.799 --> 00:18:55.200
+pretty nicely and formatted
+snippets well,
+
+00:18:55.200 --> 00:18:56.880
+put the diagram in there, and then
+
+00:18:58.240 --> 00:19:02.799
+it's preserved this
+literate programming syntax,
+
+00:19:02.799 --> 00:19:04.960
+which is important because that's how we
+
+00:19:04.960 --> 00:19:06.112
+want to view the documentation.
+
+00:19:06.112 --> 00:19:11.312
+That's what the no-exports property
+
+00:19:11.312 --> 00:19:13.360
+was trying to maintain.
+
+00:19:13.360 --> 00:19:15.979
+no-exports means when you export,
+
+00:19:15.979 --> 00:19:18.400
+do not try to tangle.
+
+00:19:18.400 --> 00:19:20.559
+Hopefully that makes more sense now.
+
+00:19:20.559 --> 00:19:22.240
+Now you can see all the documentation.
+
+00:19:22.240 --> 00:19:26.080
+I think it demonstrates a
+
+00:19:26.080 --> 00:19:33.520
+pretty useful feature that's inside of
+Emacs.
+
+00:19:33.520 --> 00:19:34.979
+Hopefully you'll have as much fun
+
+00:19:34.979 --> 00:19:39.919
+using that as I have.
+
+00:19:39.919 --> 00:19:43.600
+So thanks!
diff --git a/2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita-autogen.vtt b/2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita-autogen.vtt
deleted file mode 100644
index 21202a4a..00000000
--- a/2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita-autogen.vtt
+++ /dev/null
@@ -1,1183 +0,0 @@
-WEBVTT
-
-00:00:00.080 --> 00:00:03.120
-okay okay excellent sorry okay so
-
-00:00:03.120 --> 00:00:06.960
-uh hello everyone um and um
-
-00:00:06.960 --> 00:00:10.080
-uh nice meeting you and let me
-
-00:00:10.080 --> 00:00:12.400
-thank the the organizer for all the
-
-00:00:12.400 --> 00:00:13.920
-organization and all the work they are
-
-00:00:13.920 --> 00:00:15.200
-doing to support us
-
-00:00:15.200 --> 00:00:18.400
-my name is adolfo villaferita
-
-00:00:18.400 --> 00:00:19.920
-I'm teaching at the university of
-
-00:00:19.920 --> 00:00:21.920
-trenton I'm also
-
-00:00:21.920 --> 00:00:24.480
-work will shortly be working at
-
-00:00:24.480 --> 00:00:26.240
-shared.tech which is a comp
-
-00:00:26.240 --> 00:00:29.359
-a non-profit organization developing an
-
-00:00:29.359 --> 00:00:30.530
-applications to
-
-00:00:30.530 --> 00:00:32.399
-[Music]
-
-00:00:32.399 --> 00:00:35.680
-recover surplus food but the the
-
-00:00:35.680 --> 00:00:38.960
-reason of the talk today and the reason
-
-00:00:38.960 --> 00:00:40.079
-I'm here today
-
-00:00:40.079 --> 00:00:42.719
-is to talk about my experience in moving
-
-00:00:42.719 --> 00:00:44.000
-from jekyll uh
-
-00:00:44.000 --> 00:00:47.200
-static website generator to org mode and
-
-00:00:47.200 --> 00:00:49.200
-the reason
-
-00:00:49.200 --> 00:00:52.079
-I move to work mode is to have better
-
-00:00:52.079 --> 00:00:53.039
-support for
-
-00:00:53.039 --> 00:00:56.800
-literary programming on the websites
-
-00:00:56.800 --> 00:00:58.399
-at the university of trento where we
-
-00:00:58.399 --> 00:01:00.480
-make available the content for the
-
-00:01:00.480 --> 00:01:04.720
-the students okay so
-
-00:01:04.720 --> 00:01:08.000
-first of all what is a static website
-
-00:01:08.000 --> 00:01:10.080
-generator it is basically a tool which
-
-00:01:10.080 --> 00:01:11.360
-allows you to
-
-00:01:11.360 --> 00:01:15.360
-generate html files out of text files
-
-00:01:15.360 --> 00:01:17.439
-containing basically two types of
-
-00:01:17.439 --> 00:01:19.280
-information metadata
-
-00:01:19.280 --> 00:01:23.119
-and content metadata is let's say a
-
-00:01:23.119 --> 00:01:26.159
-set of key pairs describing the the
-
-00:01:26.159 --> 00:01:28.560
-content of the file such as the title
-
-00:01:28.560 --> 00:01:30.000
-author
-
-00:01:30.000 --> 00:01:31.759
-tags and so on and so forth and the
-
-00:01:31.759 --> 00:01:34.560
-content is what you actually want to to
-
-00:01:34.560 --> 00:01:37.040
-get published on the on the internet in
-
-00:01:37.040 --> 00:01:38.880
-the html file
-
-00:01:38.880 --> 00:01:41.439
-and usually the content is written in
-
-00:01:41.439 --> 00:01:44.560
-some kind of
-
-00:01:44.560 --> 00:01:47.520
-markup language such as markdown or
-
-00:01:47.520 --> 00:01:49.759
-possibly
-
-00:01:49.759 --> 00:01:53.200
-org mode and well jackie is a very
-
-00:01:53.200 --> 00:01:55.759
-popular website uh
-
-00:01:55.759 --> 00:01:58.719
-a static website generator it is written
-
-00:01:58.719 --> 00:01:59.840
-in a ruby
-
-00:01:59.840 --> 00:02:03.280
-and what it does it it it systematically
-
-00:02:03.280 --> 00:02:06.840
-let's say transforms all the input files
-
-00:02:06.840 --> 00:02:09.440
-by making the content into
-
-00:02:09.440 --> 00:02:11.599
-html and systematically applying a
-
-00:02:11.599 --> 00:02:14.000
-template in order to generate the
-
-00:02:14.000 --> 00:02:17.120
-html files which you can then deploy
-
-00:02:17.120 --> 00:02:19.840
-on your server of choice to make them
-
-00:02:19.840 --> 00:02:22.160
-available on the on the internet
-
-00:02:22.160 --> 00:02:26.160
-and one of the features uh most
-
-00:02:26.160 --> 00:02:28.480
-well I would say all static website
-
-00:02:28.480 --> 00:02:30.239
-generators have
-
-00:02:30.239 --> 00:02:32.560
-is a debt of being able to let's say
-
-00:02:32.560 --> 00:02:34.879
-collect the metadata information
-
-00:02:34.879 --> 00:02:38.400
-uh of the files being part of your of
-
-00:02:38.400 --> 00:02:39.440
-your project
-
-00:02:39.440 --> 00:02:45.280
-and the reason they do that is because
-
-00:02:45.280 --> 00:02:47.840
-you sometimes want to generate pages
-
-00:02:47.840 --> 00:02:49.280
-based on the content
-
-00:02:49.280 --> 00:02:53.200
-of your um of your projects
-
-00:02:53.200 --> 00:02:56.239
-such as for instance the the list of
-
-00:02:56.239 --> 00:02:59.040
-posts you have recently published or
-
-00:02:59.040 --> 00:03:00.400
-maybe the list of tags
-
-00:03:00.400 --> 00:03:03.840
-uh you uh have defined for your post and
-
-00:03:03.840 --> 00:03:07.280
-so on and so forth so so
-
-00:03:07.280 --> 00:03:09.760
-dracula gives the possibility of
-
-00:03:09.760 --> 00:03:12.400
-generating this kind of dynamic
-
-00:03:12.400 --> 00:03:15.760
-content by using liquid which is a
-
-00:03:15.760 --> 00:03:18.800
-templating language which
-
-00:03:18.800 --> 00:03:21.840
-looks like these
-
-00:03:21.840 --> 00:03:24.879
-so basically you you have all the
-
-00:03:24.879 --> 00:03:26.879
-constructs you can
-
-00:03:26.879 --> 00:03:29.120
-expect in a programming language this
-
-00:03:29.120 --> 00:03:29.920
-for instance
-
-00:03:29.920 --> 00:03:33.360
-is a fourth cycle which
-
-00:03:33.360 --> 00:03:37.440
-iterates over all the post or the
-
-00:03:37.440 --> 00:03:39.599
-files in a specific directory of the
-
-00:03:39.599 --> 00:03:41.040
-jacket project
-
-00:03:41.040 --> 00:03:45.040
-and for each post it takes the the title
-
-00:03:45.040 --> 00:03:48.400
-and the url and generates a link
-
-00:03:48.400 --> 00:03:51.840
-okay so dracule is
-
-00:03:51.840 --> 00:03:55.200
-nice and sweet but over the years
-
-00:03:55.200 --> 00:03:57.760
-I started using more and more
-
-00:03:57.760 --> 00:03:59.519
-systematically
-
-00:03:59.519 --> 00:04:02.959
-or mode to write all my files and I
-
-00:04:02.959 --> 00:04:05.439
-moved from markdown to word mode I am a
-
-00:04:05.439 --> 00:04:07.439
-long time Emacs user so I've been using
-
-00:04:07.439 --> 00:04:09.680
-imax for 30 years now so
-
-00:04:09.680 --> 00:04:12.799
-or mode is a more recent discovery
-
-00:04:12.799 --> 00:04:15.280
-but it is a very nice uh let's say
-
-00:04:15.280 --> 00:04:16.239
-discovery I
-
-00:04:16.239 --> 00:04:19.680
-I made and the reason I like org mode
-
-00:04:19.680 --> 00:04:22.320
-is because for instance you can write
-
-00:04:22.320 --> 00:04:23.600
-formulas using
-
-00:04:23.600 --> 00:04:26.639
-mac jacks and you can generate diagrams
-
-00:04:26.639 --> 00:04:30.320
-or plots with new plots and
-
-00:04:30.320 --> 00:04:32.240
-also important is the fact that you have
-
-00:04:32.240 --> 00:04:34.080
-the possibility of let's say publishing
-
-00:04:34.080 --> 00:04:35.919
-your documents
-
-00:04:35.919 --> 00:04:39.520
-to multiple ends backhands such as pdf
-
-00:04:39.520 --> 00:04:40.400
-or
-
-00:04:40.400 --> 00:04:43.600
-maybe a review presentations or
-
-00:04:43.600 --> 00:04:47.199
-or html and this is all made possible
-
-00:04:47.199 --> 00:04:50.479
-by bubble which is
-
-00:04:50.479 --> 00:04:52.560
-exactly what we just saw in the the
-
-00:04:52.560 --> 00:04:54.639
-previous talk
-
-00:04:54.639 --> 00:04:57.440
-namely the possibility of executing a
-
-00:04:57.440 --> 00:04:59.520
-snippet of code
-
-00:04:59.520 --> 00:05:02.560
-embedded in in your pages
-
-00:05:02.560 --> 00:05:06.400
-um and our model can also be used
-
-00:05:06.400 --> 00:05:09.600
-within let's say jackie and in fact
-
-00:05:09.600 --> 00:05:10.720
-there is a
-
-00:05:10.720 --> 00:05:15.199
-a nice gem a nice library called jackie
-
-00:05:15.199 --> 00:05:18.880
-org which allows you to use org modifies
-
-00:05:18.880 --> 00:05:19.680
-directly
-
-00:05:19.680 --> 00:05:22.880
-into jekyll but when you start using
-
-00:05:22.880 --> 00:05:26.560
-org mode when I started using
-
-00:05:26.560 --> 00:05:30.560
-mode I realized I could move
-
-00:05:30.560 --> 00:05:34.240
-all my workflow to or my publishing
-
-00:05:34.240 --> 00:05:36.840
-workflow to image
-
-00:05:36.840 --> 00:05:39.520
-and and and in fact
-
-00:05:39.520 --> 00:05:41.600
-org mode is also static website
-
-00:05:41.600 --> 00:05:42.880
-generator because
-
-00:05:42.880 --> 00:05:46.240
-it has got the possibility of publishing
-
-00:05:46.240 --> 00:05:50.880
-um projects made of org mode files
-
-00:05:50.880 --> 00:05:53.840
-and one of the nice things about let's
-
-00:05:53.840 --> 00:05:55.759
-say that the publishing features of work
-
-00:05:55.759 --> 00:05:56.479
-mode
-
-00:05:56.479 --> 00:05:58.880
-is that it allows you to define in the
-
-00:05:58.880 --> 00:05:59.840
-org publish
-
-00:05:59.840 --> 00:06:03.199
-project a list of the components
-
-00:06:03.199 --> 00:06:06.479
-which are part of your project and in a
-
-00:06:06.479 --> 00:06:07.520
-sense it is
-
-00:06:07.520 --> 00:06:10.479
-also more flexible than jackie lee's
-
-00:06:10.479 --> 00:06:12.400
-because it also allows you for instance
-
-00:06:12.400 --> 00:06:12.880
-to
-
-00:06:12.880 --> 00:06:15.120
-let's say publish a single file rather
-
-00:06:15.120 --> 00:06:17.440
-than having to recompile everything
-
-00:06:17.440 --> 00:06:20.080
-every time you want to publish your
-
-00:06:20.080 --> 00:06:23.919
-your project to your website however
-
-00:06:23.919 --> 00:06:25.840
-there are some short comments I would
-
-00:06:25.840 --> 00:06:27.120
-say or some some
-
-00:06:27.120 --> 00:06:29.520
-areas of improvement improvement let me
-
-00:06:29.520 --> 00:06:30.400
-say
-
-00:06:30.400 --> 00:06:32.720
-the first is that let's say support for
-
-00:06:32.720 --> 00:06:33.600
-templating
-
-00:06:33.600 --> 00:06:36.639
-is not so obvious as it is let's say
-
-00:06:36.639 --> 00:06:39.280
-in jackie or even though there are some
-
-00:06:39.280 --> 00:06:40.560
-let's say
-
-00:06:40.560 --> 00:06:44.560
-nice extensions such as argo t html
-
-00:06:44.560 --> 00:06:46.160
-for instance which allows you to use
-
-00:06:46.160 --> 00:06:48.400
-templates and
-
-00:06:48.400 --> 00:06:51.840
-more important to me was the fact that
-
-00:06:51.840 --> 00:06:54.080
-apparently there is little support for
-
-00:06:54.080 --> 00:06:55.520
-the creation of dynamic
-
-00:06:55.520 --> 00:06:58.240
-content so I was very curious and very
-
-00:06:58.240 --> 00:06:59.360
-keen to use
-
-00:06:59.360 --> 00:07:02.800
-or mode for let's say publishing my blog
-
-00:07:02.800 --> 00:07:05.440
-and my the the courses at the university
-
-00:07:05.440 --> 00:07:08.720
-but then uh I had to find a way
-
-00:07:08.720 --> 00:07:11.440
-to let's say being able to publish these
-
-00:07:11.440 --> 00:07:13.599
-dynamic pages finding some kind of
-
-00:07:13.599 --> 00:07:16.000
-replacement so to speak for uh the
-
-00:07:16.000 --> 00:07:16.720
-liquid
-
-00:07:16.720 --> 00:07:19.759
-the liquid engine and and the solution
-
-00:07:19.759 --> 00:07:20.160
-was
-
-00:07:20.160 --> 00:07:24.160
-that at hand actually because
-
-00:07:24.160 --> 00:07:27.280
-basically I realized I could use bubble
-
-00:07:27.280 --> 00:07:30.800
-for exactly this purpose so rather than
-
-00:07:30.800 --> 00:07:32.720
-using bubble for generating
-
-00:07:32.720 --> 00:07:35.759
-plots or let's say my other computation
-
-00:07:35.759 --> 00:07:37.919
-or whatever I was using them for
-
-00:07:37.919 --> 00:07:41.039
-I realized they could use bubble to
-
-00:07:41.039 --> 00:07:42.080
-generate
-
-00:07:42.080 --> 00:07:45.120
-html which could be let's say
-
-00:07:45.120 --> 00:07:48.960
-uh then published uh uh
-
-00:07:48.960 --> 00:07:52.720
-in the project so uh so all I needed to
-
-00:07:52.720 --> 00:07:53.680
-do then
-
-00:07:53.680 --> 00:07:56.240
-was defining some kind of functions some
-
-00:07:56.240 --> 00:07:58.319
-kind of code in order to read
-
-00:07:58.319 --> 00:08:01.840
-all the org mode uh the metadata of all
-
-00:08:01.840 --> 00:08:02.400
-the
-
-00:08:02.400 --> 00:08:05.759
-opmod files of my web project so that
-
-00:08:05.759 --> 00:08:09.680
-I could let's say then publish uh
-
-00:08:09.680 --> 00:08:13.280
-generate the dynamic content and
-
-00:08:13.280 --> 00:08:18.080
-this is a snippet taken from
-
-00:08:18.080 --> 00:08:21.759
-one of my html projects
-
-00:08:21.759 --> 00:08:24.800
-which basically shows the way in which
-
-00:08:24.800 --> 00:08:27.599
-I generate the um the list of posts on
-
-00:08:27.599 --> 00:08:29.360
-my on my page it is uh
-
-00:08:29.360 --> 00:08:32.560
-exactly how the the liquid that we saw
-
-00:08:32.560 --> 00:08:34.320
-in a couple of a couple of slides
-
-00:08:34.320 --> 00:08:35.680
-earlier that looks like
-
-00:08:35.680 --> 00:08:39.200
-uh in inner mode
-
-00:08:39.200 --> 00:08:42.320
-and basically what I'm doing I'm using I
-
-00:08:42.320 --> 00:08:46.720
-wrote a ruby script which
-
-00:08:46.720 --> 00:08:49.680
-reads all the metadata so this uh
-
-00:08:49.680 --> 00:08:51.040
-highlighted code
-
-00:08:51.040 --> 00:08:53.440
-basically loads the script which is
-
-00:08:53.440 --> 00:08:54.240
-stored
-
-00:08:54.240 --> 00:08:56.800
-externally and then it collects all the
-
-00:08:56.800 --> 00:08:58.320
-metadata from the
-
-00:08:58.320 --> 00:09:00.880
-org mode files in the current uh in the
-
-00:09:00.880 --> 00:09:02.240
-current directory
-
-00:09:02.240 --> 00:09:04.800
-and then the the following the the code
-
-00:09:04.800 --> 00:09:06.480
-you can see here
-
-00:09:06.480 --> 00:09:09.839
-basically iterate over all the
-
-00:09:09.839 --> 00:09:12.959
-past red the at the previous step
-
-00:09:12.959 --> 00:09:16.399
-and it generates um
-
-00:09:16.399 --> 00:09:19.519
-a list with the title and uh
-
-00:09:19.519 --> 00:09:22.959
-and the urls and so basically
-
-00:09:22.959 --> 00:09:27.440
-replicating what jackie does so
-
-00:09:27.440 --> 00:09:30.240
-okay so there are some some other things
-
-00:09:30.240 --> 00:09:32.399
-I have to to deal with in order to let's
-
-00:09:32.399 --> 00:09:33.200
-say
-
-00:09:33.200 --> 00:09:36.480
-accommodate my workflow and but that was
-
-00:09:36.480 --> 00:09:39.200
-relatively easy in the sense that one of
-
-00:09:39.200 --> 00:09:40.240
-the
-
-00:09:40.240 --> 00:09:43.279
-uh problem one of the issue I had to
-
-00:09:43.279 --> 00:09:45.360
-solve was that of let's say having
-
-00:09:45.360 --> 00:09:48.480
-a common navigation on all my
-
-00:09:48.480 --> 00:09:51.040
-pages uh but that was easily solved
-
-00:09:51.040 --> 00:09:51.920
-using
-
-00:09:51.920 --> 00:09:54.959
-uh the include feature so I basically
-
-00:09:54.959 --> 00:09:56.000
-made available
-
-00:09:56.000 --> 00:09:57.839
-and include with all the navigation
-
-00:09:57.839 --> 00:10:00.560
-which is uh embedded in all the pages of
-
-00:10:00.560 --> 00:10:01.839
-my websites
-
-00:10:01.839 --> 00:10:04.959
-uh through the could include and another
-
-00:10:04.959 --> 00:10:06.160
-nice feature which
-
-00:10:06.160 --> 00:10:08.560
-jackie las is the possibility of
-
-00:10:08.560 --> 00:10:09.760
-previewing
-
-00:10:09.760 --> 00:10:12.800
-a website before deploying it and but
-
-00:10:12.800 --> 00:10:13.200
-then
-
-00:10:13.200 --> 00:10:16.079
-Emacs also has got a node which allows
-
-00:10:16.079 --> 00:10:17.839
-you to
-
-00:10:17.839 --> 00:10:21.200
-launch a web server and in fact
-
-00:10:21.200 --> 00:10:24.320
-I wrote a quick ack
-
-00:10:24.320 --> 00:10:26.959
-which allows you to which allows to
-
-00:10:26.959 --> 00:10:28.000
-basically
-
-00:10:28.000 --> 00:10:31.519
-invoke a node on a on our
-
-00:10:31.519 --> 00:10:34.720
-mode project and start a local preview
-
-00:10:34.720 --> 00:10:37.920
-and then use rsync
-
-00:10:37.920 --> 00:10:44.839
-in order to deploy the the website
-
-00:10:44.839 --> 00:10:46.240
-um
-
-00:10:46.240 --> 00:10:48.720
-five minutes left okay okay more than
-
-00:10:48.720 --> 00:10:51.200
-enough okay
-
-00:10:51.200 --> 00:10:53.200
-thanks thank you thank you very much I'm
-
-00:10:53.200 --> 00:10:55.440
-nearly done so then I can take some some
-
-00:10:55.440 --> 00:10:56.480
-questions
-
-00:10:56.480 --> 00:11:00.560
-so okay just to give you maybe
-
-00:11:00.560 --> 00:11:03.680
-a slightly more in-depth uh
-
-00:11:03.680 --> 00:11:06.480
-view of what the pages look like so
-
-00:11:06.480 --> 00:11:07.200
-these are
-
-00:11:07.200 --> 00:11:11.120
-one of the pages or the source files
-
-00:11:11.120 --> 00:11:14.720
-of one of the websites it is
-
-00:11:14.720 --> 00:11:18.480
-in literate programming so basically uh
-
-00:11:18.480 --> 00:11:20.399
-you see there is some metadata here I
-
-00:11:20.399 --> 00:11:22.640
-mean this is a regular old mod file
-
-00:11:22.640 --> 00:11:26.640
-and this part here
-
-00:11:26.640 --> 00:11:29.920
-basically defines some common options
-
-00:11:29.920 --> 00:11:31.519
-for publication
-
-00:11:31.519 --> 00:11:35.920
-and these two includes here
-
-00:11:35.920 --> 00:11:41.120
-put some extra html in the head part and
-
-00:11:41.120 --> 00:11:44.480
-the navigation and here as you can see
-
-00:11:44.480 --> 00:11:48.079
-is the code generating the
-
-00:11:48.079 --> 00:11:50.160
-the list in chronological order it is
-
-00:11:50.160 --> 00:11:52.240
-slightly more complex than the example I
-
-00:11:52.240 --> 00:11:53.839
-made in the slide
-
-00:11:53.839 --> 00:11:56.240
-because uh there is some more
-
-00:11:56.240 --> 00:11:57.839
-elaboration to
-
-00:11:57.839 --> 00:11:59.760
-uh to do including putting some
-
-00:11:59.760 --> 00:12:01.839
-javascript to identify
-
-00:12:01.839 --> 00:12:05.120
-according to let's say the the tags
-
-00:12:05.120 --> 00:12:08.160
-so to go back to the to the presentation
-
-00:12:08.160 --> 00:12:11.200
-um so the okay so
-
-00:12:11.200 --> 00:12:13.600
-I I managed this migration uh a few
-
-00:12:13.600 --> 00:12:14.560
-months ago
-
-00:12:14.560 --> 00:12:17.680
-and then uh all my workflow is within
-
-00:12:17.680 --> 00:12:20.399
-with old mode and within imax and um
-
-00:12:20.399 --> 00:12:23.079
-I'm very happy with it because it's
-
-00:12:23.079 --> 00:12:24.240
-simplified
-
-00:12:24.240 --> 00:12:26.800
-uh quite a bit let's say my public
-
-00:12:26.800 --> 00:12:28.480
-publication process
-
-00:12:28.480 --> 00:12:31.839
-and uh one of the advantages so another
-
-00:12:31.839 --> 00:12:34.240
-advantage so the first advantage is that
-
-00:12:34.240 --> 00:12:36.959
-everything is in ork mode and dmax
-
-00:12:36.959 --> 00:12:38.160
-second advantage
-
-00:12:38.160 --> 00:12:41.680
-is that everything is based on the
-
-00:12:41.680 --> 00:12:44.880
-standard machinery provided by orb mode
-
-00:12:44.880 --> 00:12:47.760
-so in a sense it is kind of let's say
-
-00:12:47.760 --> 00:12:50.079
-more robust with respect to
-
-00:12:50.079 --> 00:12:53.040
-dependencies and possible errors and so
-
-00:12:53.040 --> 00:12:54.320
-on and so forth
-
-00:12:54.320 --> 00:12:56.639
-and um and the fact that the old mode
-
-00:12:56.639 --> 00:12:58.240
-allows you to publish
-
-00:12:58.240 --> 00:13:00.880
-a single file in a project is is also
-
-00:13:00.880 --> 00:13:03.839
-very interesting because
-
-00:13:03.839 --> 00:13:07.839
-it allows to let's say be more robust to
-
-00:13:07.839 --> 00:13:11.040
-problems you might introduce when
-
-00:13:11.040 --> 00:13:14.079
-you're changing when I'm changing the
-
-00:13:14.079 --> 00:13:14.959
-setup
-
-00:13:14.959 --> 00:13:16.880
-and another interesting thing which I
-
-00:13:16.880 --> 00:13:18.320
-realized that I
-
-00:13:18.320 --> 00:13:21.519
-uh I could have is that
-
-00:13:21.519 --> 00:13:23.600
-in a sense the specification of the
-
-00:13:23.600 --> 00:13:24.880
-website
-
-00:13:24.880 --> 00:13:27.360
-is uh can be embedded in the website
-
-00:13:27.360 --> 00:13:28.480
-itself
-
-00:13:28.480 --> 00:13:30.800
-so in a sense this is some kind of let's
-
-00:13:30.800 --> 00:13:31.839
-say self
-
-00:13:31.839 --> 00:13:35.120
-the command it's a real set documenting
-
-00:13:35.120 --> 00:13:37.200
-uh what I'm actually doing so for
-
-00:13:37.200 --> 00:13:38.560
-instance
-
-00:13:38.560 --> 00:13:43.199
-uh here on my
-
-00:13:43.199 --> 00:13:46.399
-website you can see let's say the
-
-00:13:46.399 --> 00:13:48.240
-specification of the
-
-00:13:48.240 --> 00:13:51.519
-of the of the project which is uh loaded
-
-00:13:51.519 --> 00:13:52.320
-from my
-
-00:13:52.320 --> 00:13:55.519
-initialization file but then it is also
-
-00:13:55.519 --> 00:13:56.320
-published
-
-00:13:56.320 --> 00:13:59.440
-together with my home page and it leaves
-
-00:13:59.440 --> 00:14:01.360
-with the repository where
-
-00:14:01.360 --> 00:14:05.360
-I keep all the sources of my website
-
-00:14:05.360 --> 00:14:08.079
-which is kind of nice because it
-
-00:14:08.079 --> 00:14:09.839
-basically isolates
-
-00:14:09.839 --> 00:14:14.079
-everything in a single in a single place
-
-00:14:14.079 --> 00:14:16.880
-okay so there are some examples I'm
-
-00:14:16.880 --> 00:14:18.000
-showing them
-
-00:14:18.000 --> 00:14:20.320
-more because of the let's say source
-
-00:14:20.320 --> 00:14:21.760
-code which
-
-00:14:21.760 --> 00:14:25.519
-you can grab from the git repositories
-
-00:14:25.519 --> 00:14:26.160
-if you are
-
-00:14:26.160 --> 00:14:28.399
-interested of course I'm also available
-
-00:14:28.399 --> 00:14:30.079
-to provide some
-
-00:14:30.079 --> 00:14:32.959
-support and help if you are interested
-
-00:14:32.959 --> 00:14:34.480
-in this kind of stuff
-
-00:14:34.480 --> 00:14:37.760
-the the next step for me will be that of
-
-00:14:37.760 --> 00:14:38.560
-let's say trying
-
-00:14:38.560 --> 00:14:41.600
-making this kind of machinery available
-
-00:14:41.600 --> 00:14:45.199
-for more general use at the moment
-
-00:14:45.199 --> 00:14:47.120
-if you are interested in trying out my
-
-00:14:47.120 --> 00:14:48.800
-suggestion is let's say grabbing the
-
-00:14:48.800 --> 00:14:49.839
-sources
-
-00:14:49.839 --> 00:14:52.959
-or one of the let's say websites to see
-
-00:14:52.959 --> 00:14:56.000
-what how they look like and maybe try
-
-00:14:56.000 --> 00:14:56.720
-and
-
-00:14:56.720 --> 00:15:00.160
-customize it for your purposes
-
-00:15:00.160 --> 00:15:02.720
-and this is basically the content of my
-
-00:15:02.720 --> 00:15:03.839
-talk so
-
-00:15:03.839 --> 00:15:06.959
-I'm open to two questions and thank you
-
-00:15:06.959 --> 00:15:07.279
-for
-
-00:15:07.279 --> 00:15:10.880
-your attention you are now unmuted uh
-
-00:15:10.880 --> 00:15:12.880
-thank you very much adolfo for your
-
-00:15:12.880 --> 00:15:14.480
-awesome presentation
-
-00:15:14.480 --> 00:15:17.360
-um I think we have time for maybe like
-
-00:15:17.360 --> 00:15:19.360
-one or two questions
-
-00:15:19.360 --> 00:15:21.279
-um and then the rest maybe you could
-
-00:15:21.279 --> 00:15:22.880
-take up um
-
-00:15:22.880 --> 00:15:26.639
-after the stream after sure
-
-00:15:26.639 --> 00:15:30.000
-uh I we should do um would you like me
-
-00:15:30.000 --> 00:15:31.839
-to read you the questions
-
-00:15:31.839 --> 00:15:35.199
-uh yeah probably better because
-
-00:15:35.199 --> 00:15:40.399
-I kind of lost there okay no problem um
-
-00:15:40.399 --> 00:15:42.480
-okay so someone asks do you have any
-
-00:15:42.480 --> 00:15:45.440
-opinion on fern
-
-00:15:45.440 --> 00:15:48.639
-fan I I don't know fans
-
-00:15:48.639 --> 00:15:51.839
-so I'll give it a try and uh and uh
-
-00:15:51.839 --> 00:15:55.040
-and check it out okay
-
-00:15:55.040 --> 00:15:57.839
-thanks and um people are also asking do
-
-00:15:57.839 --> 00:15:59.680
-you discuss this for example in a blog
-
-00:15:59.680 --> 00:16:01.279
-or anywhere else they could find more
-
-00:16:01.279 --> 00:16:02.800
-about it
-
-00:16:02.800 --> 00:16:05.600
-oh yes I'm going to publish the let's
-
-00:16:05.600 --> 00:16:08.560
-say the talk and the content on the
-
-00:16:08.560 --> 00:16:11.120
-on my website and then I'll link it from
-
-00:16:11.120 --> 00:16:12.320
-the max conf
-
-00:16:12.320 --> 00:16:14.720
-conference so that it will be easier for
-
-00:16:14.720 --> 00:16:15.680
-people to
-
-00:16:15.680 --> 00:16:19.040
-to reach it so I will shortly make it
-
-00:16:19.040 --> 00:16:22.880
-available right after the conference
-
-00:16:22.880 --> 00:16:25.440
-wonderful and I think that's all for the
-
-00:16:25.440 --> 00:16:26.160
-questions
-
-00:16:26.160 --> 00:16:28.560
-thank you very much okay thank you very
-
-00:16:28.560 --> 00:16:29.600
-much thank you
-
-00:16:29.600 --> 00:16:34.800
-and cheers bye cheers bye
diff --git a/2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita.vtt b/2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita.vtt
new file mode 100644
index 00000000..5d0b0b57
--- /dev/null
+++ b/2020/subtitles/emacsconf-2020--15-moving-from-jekyll-to-orgmode-an-experience-report--adolfo-villafiorita.vtt
@@ -0,0 +1,1057 @@
+WEBVTT
+
+00:00:00.080 --> 00:00:03.120
+Adolfo: Okay, excellent.
+
+00:00:03.120 --> 00:00:06.960
+Hello, everyone and
+
+00:00:06.960 --> 00:00:10.080
+nice meeting you. Let me
+
+00:00:10.080 --> 00:00:12.400
+thank the the organizer for all the
+
+00:00:12.400 --> 00:00:13.920
+organization and all the work they are
+
+00:00:13.920 --> 00:00:15.200
+doing to support us.
+
+00:00:15.200 --> 00:00:18.400
+My name is Adolfo Villafiorita.
+
+00:00:18.400 --> 00:00:20.733
+I'm teaching at the University of
+Trento.
+
+00:00:20.733 --> 00:00:24.480
+I will shortly be working at
+
+00:00:24.480 --> 00:00:26.240
+shared.tech, which is
+
+00:00:26.240 --> 00:00:29.359
+a non-profit organization developing
+
+00:00:29.359 --> 00:00:30.530
+applications to
+
+00:00:32.399 --> 00:00:35.680
+recover surplus food.
+
+00:00:35.680 --> 00:00:38.600
+The reason of the talk today
+
+00:00:38.600 --> 00:00:40.079
+and the reason I'm here today
+
+00:00:40.079 --> 00:00:42.719
+is to talk about my experience in moving
+
+00:00:42.719 --> 00:00:47.200
+from Jekyll static website generator to
+Org Mode.
+
+00:00:47.200 --> 00:00:50.700
+The reason I moved to Org Mode
+
+00:00:50.700 --> 00:00:53.100
+is to have better support for
+
+00:00:53.100 --> 00:00:56.800
+literate programming on the websites
+
+00:00:56.800 --> 00:00:58.399
+at the University of Trento, where we
+
+00:00:58.399 --> 00:01:00.480
+make available the content for the
+
+00:01:00.480 --> 00:01:04.720
+the students.
+
+00:01:04.720 --> 00:01:08.900
+First of all, what is a static
+website generator?
+
+00:01:08.900 --> 00:01:10.080
+It is basically a tool which
+
+00:01:10.080 --> 00:01:11.360
+allows you to
+
+00:01:11.360 --> 00:01:15.360
+generate HTML files out of text files
+
+00:01:15.360 --> 00:01:17.439
+containing basically two types of
+
+00:01:17.439 --> 00:01:20.700
+information: metadata and content.
+
+00:01:20.700 --> 00:01:23.119
+Metadata is a
+
+00:01:23.119 --> 00:01:26.159
+set of key pairs describing the
+
+00:01:26.159 --> 00:01:28.560
+content of the file, such as the title,
+
+00:01:28.560 --> 00:01:31.733
+author, tags, and so on and so forth.
+
+00:01:31.733 --> 00:01:34.560
+The content is what you actually
+want to
+
+00:01:34.560 --> 00:01:37.040
+get published on the Internet in
+
+00:01:37.040 --> 00:01:38.880
+the HTML file.
+
+00:01:38.880 --> 00:01:41.439
+Usually the content is written in
+
+00:01:41.439 --> 00:01:45.800
+some kind of markup language,
+
+00:01:45.800 --> 00:01:49.759
+such as Markdown or possibly
+
+00:01:49.759 --> 00:01:53.200
+Org Mode. Jekyll is a very
+
+00:01:53.200 --> 00:01:57.900
+popular static website generator.
+
+00:01:57.900 --> 00:01:59.840
+It is written in Ruby.
+
+00:01:59.840 --> 00:02:03.280
+What it does: it systematically
+
+00:02:03.280 --> 00:02:06.840
+transforms all the input files
+
+00:02:06.840 --> 00:02:09.440
+by making the content into
+
+00:02:09.440 --> 00:02:11.599
+HTML and systematically applying a
+
+00:02:11.599 --> 00:02:14.000
+template in order to generate the
+
+00:02:14.000 --> 00:02:17.120
+HTML files, which you can then deploy
+
+00:02:17.120 --> 00:02:19.840
+on your server of choice to make them
+
+00:02:19.840 --> 00:02:22.160
+available on the Internet.
+
+00:02:22.160 --> 00:02:26.160
+One of the features most--
+
+00:02:26.160 --> 00:02:27.500
+well, I would say all
+
+00:02:27.500 --> 00:02:30.239
+static website generators have
+
+00:02:30.239 --> 00:02:32.560
+is that of being able to
+
+00:02:32.560 --> 00:02:34.879
+collect the metadata information
+
+00:02:34.879 --> 00:02:38.400
+of the files being part of
+
+00:02:38.400 --> 00:02:39.440
+your project.
+
+00:02:39.440 --> 00:02:45.280
+The reason they do that is because
+
+00:02:45.280 --> 00:02:47.840
+you sometimes want to generate pages
+
+00:02:47.840 --> 00:02:49.280
+based on the content
+
+00:02:49.280 --> 00:02:53.200
+of your projects,
+
+00:02:53.200 --> 00:02:56.239
+such as, for instance, the list of
+
+00:02:56.239 --> 00:02:59.040
+posts you have recently published, or
+
+00:02:59.040 --> 00:03:00.400
+maybe the list of tags
+
+00:03:00.400 --> 00:03:03.840
+you have defined for your post,
+
+00:03:03.840 --> 00:03:07.280
+and so on and so forth.
+
+00:03:07.280 --> 00:03:09.760
+Jekyll gives the possibility of
+
+00:03:09.760 --> 00:03:12.400
+generating this kind of dynamic
+
+00:03:12.400 --> 00:03:14.400
+content by using Liquid,
+
+00:03:14.400 --> 00:03:18.800
+which is a templating language which
+
+00:03:18.800 --> 00:03:21.840
+looks like this.
+
+00:03:21.840 --> 00:03:24.879
+So basically, you have all the
+
+00:03:24.879 --> 00:03:26.879
+constructs you can
+
+00:03:26.879 --> 00:03:28.800
+expect in a programming language.
+
+00:03:28.800 --> 00:03:29.920
+This, for instance,
+
+00:03:29.920 --> 00:03:33.360
+is a for cycle which
+
+00:03:33.360 --> 00:03:37.440
+iterates over all the posts or the
+
+00:03:37.440 --> 00:03:39.599
+files in a specific directory of the
+
+00:03:39.599 --> 00:03:41.040
+Jekyll project.
+
+00:03:41.040 --> 00:03:45.040
+For each post, it takes the title
+
+00:03:45.040 --> 00:03:48.400
+and the URL and generates a link.
+
+00:03:48.400 --> 00:03:52.867
+So Jekyll is nice and sweet,
+
+00:03:52.867 --> 00:03:55.200
+but over the years
+
+00:03:55.200 --> 00:03:57.760
+I started using more and more
+
+00:03:57.760 --> 00:03:59.519
+systematically
+
+00:03:59.519 --> 00:04:02.000
+Org Mode to write all my files.
+
+00:04:02.000 --> 00:04:04.833
+I moved from Markdown to Org Mode
+
+00:04:04.833 --> 00:04:07.200
+I am a long time Emacs user.
+
+00:04:07.200 --> 00:04:09.167
+I've been using Emacs for 30 years now,
+
+00:04:09.167 --> 00:04:12.799
+so Org Mode is a more recent discovery,
+
+00:04:12.799 --> 00:04:17.033
+but it is a very nice discovery I made.
+
+00:04:17.033 --> 00:04:19.680
+The reason I like Org Mode
+
+00:04:19.680 --> 00:04:22.320
+is because, for instance, you can write
+
+00:04:22.320 --> 00:04:24.933
+formulas using MathJax
+
+00:04:24.933 --> 00:04:26.639
+and you can generate diagrams
+
+00:04:26.639 --> 00:04:30.320
+or plots with Gnuplot.
+
+00:04:30.320 --> 00:04:32.240
+Also important is the fact that you have
+
+00:04:32.240 --> 00:04:34.080
+the possibility of publishing
+
+00:04:34.080 --> 00:04:39.520
+your documents to multiple backends
+such as PDF,
+
+00:04:39.520 --> 00:04:43.600
+or maybe a Reveal presentation,
+
+00:04:43.600 --> 00:04:47.199
+or HTML. This is all made possible
+
+00:04:47.199 --> 00:04:50.479
+by Babel, which is
+
+00:04:50.479 --> 00:04:52.560
+exactly what we just saw in the
+
+00:04:52.560 --> 00:04:54.639
+previous talk:
+
+00:04:54.639 --> 00:04:57.440
+Namely, the possibility of executing a
+
+00:04:57.440 --> 00:04:59.520
+snippet of code
+
+00:04:59.520 --> 00:05:02.560
+embedded in in your pages.
+
+00:05:02.560 --> 00:05:06.400
+Our model can also be used
+
+00:05:06.400 --> 00:05:09.600
+within Jekyll. In fact,
+
+00:05:09.600 --> 00:05:13.667
+there is a a nice gem, a nice library,
+
+00:05:13.667 --> 00:05:17.233
+called jekyll-org which allows you
+
+00:05:17.233 --> 00:05:19.680
+to use Org Mode files directly
+
+00:05:19.680 --> 00:05:22.880
+into jekyll. But when you start using
+
+00:05:22.880 --> 00:05:26.560
+Org Mode... When I started using
+
+00:05:26.560 --> 00:05:30.560
+Org Mode, I realized I could move
+
+00:05:30.560 --> 00:05:34.240
+all my workflow, all my publishing
+
+00:05:34.240 --> 00:05:36.840
+workflow to Emacs.
+
+00:05:36.840 --> 00:05:41.100
+In fact, Org Mode is also a
+
+00:05:41.100 --> 00:05:42.880
+static website generator because
+
+00:05:42.880 --> 00:05:46.240
+it has got the possibility of publishing
+
+00:05:46.240 --> 00:05:50.880
+projects made of Org Mode files.
+
+00:05:50.880 --> 00:05:53.840
+One of the nice things about
+
+00:05:53.840 --> 00:05:56.479
+the publishing features of Org Mode
+
+00:05:56.479 --> 00:05:58.880
+is that it allows you to define in the
+
+00:05:58.880 --> 00:06:01.300
+org-publish-project-alist,
+
+00:06:01.300 --> 00:06:03.199
+all the the components
+
+00:06:03.199 --> 00:06:05.367
+which are part of your project.
+
+00:06:05.367 --> 00:06:07.520
+In a sense, it is
+
+00:06:07.520 --> 00:06:10.479
+also more flexible than Jekyll,
+
+00:06:10.479 --> 00:06:12.880
+because it also allows you, for instance,
+
+00:06:12.880 --> 00:06:15.120
+to publish a single file rather
+
+00:06:15.120 --> 00:06:17.440
+than having to recompile everything
+
+00:06:17.440 --> 00:06:20.080
+every time you want to publish your
+
+00:06:20.080 --> 00:06:22.333
+your project to your website.
+
+00:06:22.333 --> 00:06:25.333
+However, there are some short comments
+
+00:06:25.333 --> 00:06:29.520
+I would say, or some areas
+of improvement.
+
+00:06:30.400 --> 00:06:33.600
+The first is that support for
+templating
+
+00:06:33.600 --> 00:06:36.639
+is not so obvious as it is
+
+00:06:36.639 --> 00:06:39.280
+in Jekyll, even though there are some
+
+00:06:40.560 --> 00:06:44.560
+nice extensions such as org-thtml,
+
+00:06:44.560 --> 00:06:48.400
+for instance, which allows you to use
+templates.
+
+00:06:48.400 --> 00:06:51.840
+More important to me was the fact that
+
+00:06:51.840 --> 00:06:54.080
+apparently, there is little support for
+
+00:06:54.080 --> 00:06:56.133
+the creation of dynamic content
+
+00:06:56.133 --> 00:06:57.900
+So I was very curious
+
+00:06:57.900 --> 00:06:59.360
+and very keen to use
+
+00:06:59.360 --> 00:07:02.800
+Org Mode for publishing my blog
+
+00:07:02.800 --> 00:07:05.440
+and the courses at the university,
+
+00:07:05.440 --> 00:07:08.720
+but then I had to find a way
+
+00:07:08.720 --> 00:07:11.440
+to being able to publish these
+
+00:07:11.440 --> 00:07:13.599
+dynamic pages, finding some kind of
+
+00:07:13.599 --> 00:07:16.000
+replacement, so to speak,
+
+00:07:16.720 --> 00:07:17.900
+for the liquid engine.
+
+00:07:17.900 --> 00:07:24.160
+The solution was there at hand,
+actually, because
+
+00:07:24.160 --> 00:07:27.280
+basically, I realized I could use Babel
+
+00:07:27.280 --> 00:07:30.800
+for exactly this purpose. Rather than
+
+00:07:30.800 --> 00:07:32.720
+using Babel for generating
+
+00:07:32.720 --> 00:07:35.759
+plots or my other computations
+
+00:07:35.759 --> 00:07:37.919
+or whatever I was using them for,
+
+00:07:37.919 --> 00:07:41.039
+I realized I could use Babel to
+
+00:07:41.039 --> 00:07:45.120
+generate HTML which could be
+
+00:07:45.120 --> 00:07:49.967
+then published in the project
+
+00:07:49.967 --> 00:07:53.680
+All I needed to do then
+
+00:07:53.680 --> 00:07:56.100
+was defining some kind of functions,
+
+00:07:56.100 --> 00:07:58.319
+some kind of code in order to read
+
+00:07:58.319 --> 00:08:01.840
+the metadata of all
+
+00:08:01.840 --> 00:08:04.767
+the Org Mode files of my web project,
+
+00:08:04.767 --> 00:08:09.680
+so that I could then publish--
+
+00:08:09.680 --> 00:08:13.280
+generate the dynamic content.
+
+00:08:13.280 --> 00:08:18.080
+This is a snippet taken from
+
+00:08:18.080 --> 00:08:21.759
+one of my HTML projects,
+
+00:08:21.759 --> 00:08:24.800
+which basically shows the way in which
+
+00:08:24.800 --> 00:08:27.599
+I generate the list of posts on
+
+00:08:27.599 --> 00:08:32.560
+my page. It is exactly how the
+Liquid that we saw
+
+00:08:32.560 --> 00:08:35.680
+a couple of slides earlier that
+looks like
+
+00:08:35.680 --> 00:08:39.200
+in Org Mode.
+
+00:08:39.200 --> 00:08:42.320
+Basically, what I'm doing...
+I'm using...
+
+00:08:42.320 --> 00:08:46.720
+I wrote a Ruby script which
+
+00:08:46.720 --> 00:08:49.680
+reads all the metadata. So this
+
+00:08:49.680 --> 00:08:51.040
+highlighted code
+
+00:08:51.040 --> 00:08:53.100
+basically loads the script
+
+00:08:53.100 --> 00:08:55.300
+which is stored externally.
+
+00:08:55.300 --> 00:08:56.800
+Then it collects all the
+
+00:08:56.800 --> 00:08:58.320
+metadata from the
+
+00:08:58.320 --> 00:09:00.880
+Org Mode files in the
+
+00:09:00.880 --> 00:09:02.240
+current directory.
+
+00:09:02.240 --> 00:09:04.800
+And then the following... The code
+
+00:09:04.800 --> 00:09:06.480
+you can see here
+
+00:09:06.480 --> 00:09:09.839
+basically iterates over all the
+
+00:09:09.839 --> 00:09:12.959
+posts read at the previous step.
+
+00:09:12.959 --> 00:09:16.399
+It generates
+
+00:09:16.399 --> 00:09:19.519
+a list with the title
+
+00:09:19.519 --> 00:09:22.959
+and the URLS, basically
+
+00:09:22.959 --> 00:09:27.440
+replicating what Jekyll does.
+
+00:09:27.440 --> 00:09:30.240
+There are some other things
+
+00:09:30.240 --> 00:09:32.399
+I have to deal with in order to
+
+00:09:33.200 --> 00:09:36.480
+accommodate my workflow. But that was
+
+00:09:36.480 --> 00:09:39.200
+relatively easy in the sense that one of
+
+00:09:39.200 --> 00:09:43.279
+the problems, one of the issues I had to
+
+00:09:43.279 --> 00:09:45.360
+solve was that of having
+
+00:09:45.360 --> 00:09:48.480
+a common navigation on all my
+
+00:09:48.480 --> 00:09:51.040
+pages. That was easily solved
+
+00:09:51.040 --> 00:09:53.867
+using the #+INCLUDE feature.
+
+00:09:53.867 --> 00:09:54.959
+So I basically
+
+00:09:54.959 --> 00:09:56.000
+made available
+
+00:09:56.000 --> 00:09:57.839
+an #+INCLUDE with all the navigation
+
+00:09:57.839 --> 00:10:00.560
+which is embedded in all the pages of
+
+00:10:00.560 --> 00:10:01.839
+my websites
+
+00:10:01.839 --> 00:10:03.733
+through the #+INCLUDE.
+
+00:10:03.733 --> 00:10:06.160
+Another nice feature which
+
+00:10:06.160 --> 00:10:08.560
+Jekyll has is the possibility of
+
+00:10:08.560 --> 00:10:12.800
+previewing a website before deploying it.
+
+00:10:13.200 --> 00:10:16.079
+Emacs also has got a node which allows
+
+00:10:16.079 --> 00:10:21.200
+you to launch a web server. In fact,
+
+00:10:21.200 --> 00:10:24.320
+I wrote a quick hack
+
+00:10:24.320 --> 00:10:26.959
+which allows you to
+
+00:10:26.959 --> 00:10:31.519
+invoke a node on an Org Mode
+
+00:10:31.519 --> 00:10:34.720
+project, start a local preview,
+
+00:10:34.720 --> 00:10:37.920
+and then use rsync
+
+00:10:37.920 --> 00:10:44.839
+in order to deploy the the website.
+
+00:10:46.240 --> 00:10:48.720
+Five minutes left. More than
+
+00:10:48.720 --> 00:10:51.200
+enough. Okay.
+
+00:10:51.200 --> 00:10:52.967
+Thanks. Thank you, thank you very much.
+
+00:10:52.967 --> 00:10:56.480
+I'm nearly done. So then I can take
+some questions.
+
+00:10:56.480 --> 00:11:00.560
+Just to give you maybe
+
+00:11:00.560 --> 00:11:03.680
+a slightly more in-depth
+
+00:11:03.680 --> 00:11:06.480
+view of what the pages look like,
+
+00:11:06.480 --> 00:11:07.200
+so these are
+
+00:11:07.200 --> 00:11:11.120
+one of the pages, or the source files
+
+00:11:11.120 --> 00:11:14.720
+of one of the websites. It is
+
+00:11:14.720 --> 00:11:18.480
+in literate programming. Basically,
+
+00:11:18.480 --> 00:11:20.399
+you see there is some metadata here.
+
+00:11:20.399 --> 00:11:22.640
+I mean this is a regular Org Mode file.
+
+00:11:22.640 --> 00:11:26.640
+This part here
+
+00:11:26.640 --> 00:11:29.920
+basically defines some common options
+
+00:11:29.920 --> 00:11:31.519
+for publication.
+
+00:11:31.519 --> 00:11:35.920
+These two includes here
+
+00:11:35.920 --> 00:11:41.120
+put some extra HTML in the head part and
+
+00:11:41.120 --> 00:11:44.480
+the navigation. Here, as you can see,
+
+00:11:44.480 --> 00:11:48.079
+is the code generating the
+
+00:11:48.079 --> 00:11:50.160
+the list in chronological order. It is
+
+00:11:50.160 --> 00:11:52.240
+slightly more complex than the example I
+
+00:11:52.240 --> 00:11:53.839
+made in the slide
+
+00:11:53.839 --> 00:11:56.240
+because there is some more
+
+00:11:56.240 --> 00:11:59.760
+elaboration to do, including
+putting some
+
+00:11:59.760 --> 00:12:01.839
+Javascript to identify
+
+00:12:01.839 --> 00:12:05.120
+according to the tags.
+
+00:12:05.120 --> 00:12:08.160
+To go back to the presentation...
+
+00:12:11.200 --> 00:12:13.067
+I managed this migration
+
+00:12:13.067 --> 00:12:14.560
+a few months ago,
+
+00:12:14.560 --> 00:12:17.680
+and then all my workflow is within
+
+00:12:17.680 --> 00:12:20.399
+Org Mode and within Emacs.
+
+00:12:20.399 --> 00:12:23.079
+I'm very happy with it because it's
+
+00:12:23.079 --> 00:12:26.800
+simplified quite a bit
+
+00:12:26.800 --> 00:12:28.480
+my publication process.
+
+00:12:28.480 --> 00:12:31.839
+One of the advantages... Another
+
+00:12:31.839 --> 00:12:34.240
+advantage... So the first advantage is that
+
+00:12:34.240 --> 00:12:36.959
+everything is in Org Mode and Emacs.
+
+00:12:36.959 --> 00:12:38.160
+Second advantage
+
+00:12:38.160 --> 00:12:41.680
+is that everything is based on the
+
+00:12:41.680 --> 00:12:44.880
+standard machinery provided by Org Mode.
+
+00:12:44.880 --> 00:12:47.760
+So in a sense, it is
+
+00:12:47.760 --> 00:12:50.079
+more robust with respect to
+
+00:12:50.079 --> 00:12:53.040
+dependencies, possible errors, and so
+
+00:12:53.040 --> 00:12:54.320
+on and so forth.
+
+00:12:54.320 --> 00:12:56.639
+The fact that Org Mode
+
+00:12:56.639 --> 00:12:58.240
+allows you to publish
+
+00:12:58.240 --> 00:13:00.880
+a single file in a project is also
+
+00:13:00.880 --> 00:13:03.839
+very interesting because
+
+00:13:03.839 --> 00:13:07.839
+it allows to be more robust to
+
+00:13:07.839 --> 00:13:11.040
+problems you might introduce when
+
+00:13:11.040 --> 00:13:14.959
+you're changing--when I'm changing the
+setup.
+
+00:13:14.959 --> 00:13:16.880
+Another interesting thing which I
+
+00:13:16.880 --> 00:13:21.519
+realized that I could have is that
+
+00:13:21.519 --> 00:13:23.600
+in a sense, the specification of the
+
+00:13:23.600 --> 00:13:28.480
+website can be embedded in the website
+itself.
+
+00:13:28.480 --> 00:13:30.800
+In a sense this is some kind of
+
+00:13:30.800 --> 00:13:31.839
+self-documenting...
+
+00:13:31.839 --> 00:13:35.120
+It's a way of self-documenting
+
+00:13:35.120 --> 00:13:36.600
+what I'm actually doing.
+
+00:13:36.600 --> 00:13:44.133
+For instance, here on my website,
+
+00:13:44.133 --> 00:13:46.399
+you can see the
+
+00:13:46.399 --> 00:13:48.240
+specification of the
+
+00:13:48.240 --> 00:13:51.519
+project which is loaded
+
+00:13:51.519 --> 00:13:53.933
+from my initialization file,
+
+00:13:53.933 --> 00:13:56.320
+but then it is also published
+
+00:13:56.320 --> 00:13:59.440
+together with my home page. It lives
+
+00:13:59.440 --> 00:14:01.360
+with the repository where
+
+00:14:01.360 --> 00:14:05.360
+I keep all the sources of my website,
+
+00:14:05.360 --> 00:14:08.079
+which is kind of nice because it
+
+00:14:08.079 --> 00:14:09.839
+basically isolates
+
+00:14:09.839 --> 00:14:14.079
+everything in a single place.
+
+00:14:14.079 --> 00:14:16.880
+So there are some examples. I'm
+
+00:14:16.880 --> 00:14:19.433
+showing them more because of the
+
+00:14:19.433 --> 00:14:21.760
+source code which
+
+00:14:21.760 --> 00:14:25.519
+you can grab from the git repositories
+
+00:14:25.519 --> 00:14:26.933
+if you are interested.
+
+00:14:26.933 --> 00:14:28.399
+Of course I'm also available
+
+00:14:28.399 --> 00:14:31.600
+to provide some support and help
+
+00:14:31.600 --> 00:14:32.959
+if you are interested
+
+00:14:32.959 --> 00:14:34.480
+in this kind of stuff.
+
+00:14:34.480 --> 00:14:37.760
+The the next step for me will be that of
+
+00:14:37.760 --> 00:14:41.600
+trying, making this kind of
+machinery available
+
+00:14:41.600 --> 00:14:45.199
+for more general use at the moment.
+
+00:14:45.199 --> 00:14:47.120
+If you are interested in trying out my
+
+00:14:47.120 --> 00:14:48.800
+suggestion, grabbing the
+
+00:14:48.800 --> 00:14:51.933
+sources for one of the websites
+
+00:14:51.933 --> 00:14:54.700
+to seehow they look like,
+
+00:14:54.700 --> 00:14:56.720
+and maybe try and
+
+00:14:56.720 --> 00:15:00.160
+customize it for your purposes...
+
+00:15:00.160 --> 00:15:03.839
+This is basically the content of my talk.
+
+00:15:03.839 --> 00:15:06.959
+I'm open to questions and thank you
+
+00:15:06.959 --> 00:15:10.880
+for your attention.
+
+00:15:10.880 --> 00:15:12.880
+(Amin: Thank you very much, Adolfo, for your
+
+00:15:12.880 --> 00:15:14.480
+awesome presentation.
+
+00:15:14.480 --> 00:15:17.360
+I think we have time for maybe like
+
+00:15:17.360 --> 00:15:19.360
+one or two questions,
+
+00:15:19.360 --> 00:15:21.279
+and then the rest maybe you could
+
+00:15:21.279 --> 00:15:26.639
+take up after the stream.)
+
+00:15:26.639 --> 00:15:28.033
+Adolfo: What should we do?
+
+00:15:28.033 --> 00:15:30.000
+(Amin: Would you like me
+
+00:15:30.000 --> 00:15:31.839
+to read you the questions?)
+
+00:15:31.839 --> 00:15:35.199
+Adolfo: Yeah, probably better because
+
+00:15:35.199 --> 00:15:36.700
+I'm kind of lost there.
+
+00:15:36.700 --> 00:15:40.399
+(Amin: Okay, no problem.
+
+00:15:40.399 --> 00:15:42.480
+So someone asks, "Do you have any
+
+00:15:42.480 --> 00:15:45.440
+opinion on Firn?")
+
+00:15:45.440 --> 00:15:48.639
+Adolfo: Firn. I don't know Firn,
+
+00:15:48.639 --> 00:15:51.839
+so I'll give it a try
+
+00:15:51.839 --> 00:15:55.040
+and check it out.
+
+00:15:55.040 --> 00:15:57.839
+(Amin: Thanks. People are also asking,
+
+00:15:57.839 --> 00:15:59.680
+do you discuss this, for example, in a blog
+
+00:15:59.680 --> 00:16:01.279
+or anywhere else they could find more
+
+00:16:01.279 --> 00:16:02.800
+about it?)
+
+00:16:02.800 --> 00:16:05.600
+Adolfo: Oh yes. I'm going to publish the
+
+00:16:05.600 --> 00:16:08.560
+the talk and the content
+
+00:16:08.560 --> 00:16:11.120
+on my website, and then I'll link it from
+
+00:16:11.120 --> 00:16:13.067
+the EmacsConf conference
+
+00:16:13.067 --> 00:16:14.720
+so that it will be easier for
+
+00:16:14.720 --> 00:16:16.533
+people to to reach it
+
+00:16:16.533 --> 00:16:19.040
+I will shortly make it
+
+00:16:19.040 --> 00:16:22.880
+available right after the conference.
+
+00:16:22.880 --> 00:16:26.160
+(Amin: Wonderful. I think that's all
+for the questions.
+
+00:16:26.160 --> 00:16:27.667
+Thank you very much.)
+
+00:16:27.667 --> 00:16:29.600
+Adolfo: Thank you very much. Thank you.
+
+00:16:29.600 --> 00:16:34.800
+(Amin: Cheers.) Adolfo: Bye, cheers. (Amin: Bye.)