#+title: ffs 0.2.2 released #+date: 2026-05-21 Thu 17:33:33 -0400 #+options: num:nil toc:nil #+rights: marked [[../../COPYING.CC0][CC0 1.0]] #+html_head: #+html_link_home: ../.. =ffs= provides a minor mode for simple plain text presentations in Emacs, where the slides are separated using the ~page-delimiter~, by default the form feed character (=^L=). I wrote ~ffs~ in early 2022 for my LibrePlanet 2022 presentation [[file:../../essays/net-beyond-web.html][the Net beyond the Web]], and earlier this year decided to polish it towards being a proper package and submit it to GNU ELPA. The manual still needs some more work, but the overall package is in pretty good shape so I submitted for inclusion in GNU ELPA. - Package name (GNU ELPA): [[https://elpa.gnu.org/packages/ffs.html][=ffs=]] - Official manual: - Change log: - Git repository: - Backronyms: fabulous foolproof slides - for freedom's sake - ffs flips slides ~ffs~ and I owe a debt of gratitude to Protesilaos for rounds of code review and feedback for improving and polishing the package in preparation for submission to GNU ELPA. You can watch videos of these sessions posted earlier on my website: - [[file:ffs-code-review-prot.org][FFS code review with Protesilaos]] - [[file:ffs-emacs-ext-prot.org][FFS code review and Emacs extensibility with Protesilaos]] Further, inspiration for parts of ~ffs~'s implementation was gratefully drawn from Protesilaos's [[https://protesilaos.com/emacs/logos][Logos]] package for Emacs. Dedicated to the loving memory of [[file:../../life/farangis.html][Farangis Yousefinia]]. Below are the release notes. ---------------------------------------------------------------------- * Version 0.2.2 on 2026-05-21 :PROPERTIES: :CUSTOM_ID: ffs-0.2.2 :END: First release of ~ffs~ on GNU ELPA. The attempted build of ffs 0.2.1 within GNU ELPA build sandbox failed with an =Error: void-function (org-texinfo-kbd-macro)= due to use of =#+macro: kbd (eval (org-texinfo-kbd-macro $1))= in ffs.org for better formatting of key sequences in the exported Texinfo copy. This seems to have happened for the specific case of generating a plain text README using =ox-ascii= where ELPA didn't load =ox-texinfo=. To try and mitigate this, a =README.md= has been added for use as the package README instead of ffs.org. If not sufficient, a Texinfo copy of the ffs manual will be shipped instead of the Org one in the next release. ffs 0.2.2 also includes small fixes and improvements throughout =ffs.el= from Stefan Monnier, and additional feedback to be addressed in future releases. * Version 0.2.1 on 2026-05-20 :PROPERTIES: :CUSTOM_ID: ffs-0.2.1 :END: The attempted build of ffs 0.2.0 within GNU ELPA build sandbox failed with a "Cannot include file" error on the "#+include: fdl.org" in the manual. So, as a workaround, we switch to using the official Texinfo copy of the GNU FDL license rather than an Org copy. * Version 0.2.0 on 2026-05-19 :PROPERTIES: :CUSTOM_ID: ffs-0.2.0 :END: First release of ~ffs~ intended for GNU ELPA. After a few years of inactivity, in early 2026 I decided to dust off =ffs.el=, polish and document it, and offer for inclusion in GNU ELPA as a proper package. ** Default value of ~ffs-default-face-height~ changed to nil :PROPERTIES: :CUSTOM_ID: ffs-0.2.0-ffs-default-face-height :END: To minimize unexpected and/or unnecessary changes out-of-the-box, the default value of ~ffs-default-face-height~ has been changed to nil. ** ~ffs-edit-buffer-name~ demoted from user option to variable :PROPERTIES: :CUSTOM_ID: ffs-0.2.0-ffs-edit-buffer-name :END: This is not an important user-facing setting, so to help avoid overwhelming users with many options, this has been demoted from a user option to a variable. ** Several new user options for customizing ~ffs~'s behaviour :PROPERTIES: :CUSTOM_ID: ffs-0.2.0-new-user-options :END: As part of the effort to bring ~ffs~ more in line with the conventions of other existing Emacs packages, the mechanisms for toggling various parts of Emacs's interface to minimize visual clutter were changed from being minor modes to being customizable user options. These are the replacement new user options, with a default value of nil: - ~ffs-hide-cursor~ - ~ffs-hide-mode-line~ - ~ffs-hide-header-line~ Their value is buffer-local, and may be set globally using ~setq-default~. See the [[file:ffs.html#Sample-configuration][sample configuration]] in the manual for an example of how to customize them. The new ~ffs-page-delimiter~ user option defines the page delimiter inserted by ~ffs-edit-done~ when inserting a new slide. Emacs's ~page-delimiter~ regexp should be able to match ~ffs-page-delimiter~'s value, so if you use a custom ~page-delimiter~ be sure to customize ~ffs-page-delimiter~ accordingly. The new ~ffs-echo-progress~ user option controls whether to display in echo area the progress through the slides. When non-nil, changing slides will also display the progress through the slides in the echo area. The format of the displayed progress can be customized using the new ~ffs-echo-progress-format~ user option. The new ~ffs-edit-display-buffer-alist~ user option may be used to control the Window configuration for the ~ffs-edit~ buffer. By default, it will display the ~ffs-edit~ buffer in the same window. The new ~ffs-edit-done-hook~ user option may be used to define hooks to be run at the end of ~ffs-edit-done~ after returning to the main ~ffs~ presentation buffer. Lastly, a new ~ffs-find-speaker-notes-function~ variable was added to allow customizing the find function used for opening the speaker's notes file, defaulting to ~find-file-other-frame~. * Version 0.1.0 on 2022-05-19 :PROPERTIES: :CUSTOM_ID: ffs-0.1.0 :END: Initial publication of =ffs.el= as part of my personal configurations for GNU Emacs. My first attempt at this concept was a now-archived [[https://git.kelar.org/~bandali/ffs/tree/ffsanim.el?id=aed420fca1af108e023eabf2b527850b559cd24c][=ffsanim.el=]], a major mode implementation that used Emacs's ~animate~ library to animate slide texts onto the screen. Shortly after realizing the shortcomings of that approach, I abandoned it in favour a minor mode implementation and published version =0.1.0= of what is now =ffs= in my [[https://git.kelar.org/~bandali/configs][personal configs repository]]. I used this implementation for presenting my LibrePlanet 2022 talk, [[https://kelar.org/~bandali/essays/net-beyond-web.html][The Net beyond the Web]]. I picked "ffs" as the package name, the acronym for form feed slides.