* Introducing Master of Ceremonies, a package for presentations @ 2024-12-03 16:01 Psionic K 2024-12-04 2:45 ` Psionic K ` (2 more replies) 0 siblings, 3 replies; 20+ messages in thread From: Psionic K @ 2024-12-03 16:01 UTC (permalink / raw) To: Emacs developers; +Cc: Psionic K I use this package for making videos and presentations. It's almost ready for archives. https://github.com/positron-solutions/master-of-ceremonies https://github.com/positron-solutions/master-of-ceremonies.git `mc-focus' is one of the most useful commands. Select a region, call it, and that region will be displayed full screen with appropriate scaling. You can highlight multiple regions by selecting and using the "l" key. The "." key will activate a "subtle" cursor that goes away after a short number of blinks to assist highlighting without needing to hide the cursor all the time. There is a magit-style interface for learning the rest of the modal bindings, available under "h". The `mc-kill-ring-save` command will save an expression that can play back this display, making it rather easy to step through sequences of highlights. This produces high quality illustrations of code that line up well with explanation. When combined with dslide (on non-GNU ELPA and MELPA), the two packages can create effective presentations about code that are missing almost nothing from dedicated presentation software. Many of the tools for accomplishing this were valuable as standalone modes for presentation - `mc-quiet-mode' suppresses messages - `mc-subtle-cursor-mode' is great for using the cursor like a transient laser pointer - `mc-face-remap' will remap many faces from presets. I use this to tweak faces for MC Focus screenshots. - `mc-fixed-frame' sets to preset resolutions for recording videos and corrects the size when minor actions like resizing buffer text change the size of the frame Bindings for built-in Emacs behaviors like hiding the mode line are provided. I only need to add support for modifying the transient to allow myself to add keycast toggling. These tools have been combined into a one-stop interface, `mc-dispatch'. The core code for `mc-focus' acquired numerous behaviors I was using personally and so the code is rather off. It needs to be re-architectured for smoothly supporting rectangle selection, whitespace trimming, and playback. I have experimented with translating overlays from the source into the text properties of the display. Numerous things work in numerous settings, so I have made it available ahead of publishing on package archives. Emacs conf participants may find it of use for some last minute embellishment. PRs and issues will be attended to. ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-03 16:01 Introducing Master of Ceremonies, a package for presentations Psionic K @ 2024-12-04 2:45 ` Psionic K 2024-12-04 3:01 ` Dmitry Gutov 2024-12-04 9:16 ` Jean Louis 2024-12-06 19:57 ` Jean Louis 2 siblings, 1 reply; 20+ messages in thread From: Psionic K @ 2024-12-04 2:45 UTC (permalink / raw) To: Emacs developers, Philip Kaludercic; +Cc: Psionic K [-- Attachment #1: Type: text/plain, Size: 3191 bytes --] I intend to submit Master of Ceremonies to Non-GNU ELPA. I'm deciding what changes are necessary to facilitate that and looking for low-hanging fruit to improve user results. - I'm likely to change the package file name and consequent naming over to mc. Please understand when this breaks use-package expressions. - Autoloads are being made for 29.4 since there is no stable 30.x release to target right now - Mark several customize variables as safe local variables - Generate a manual just to point users towards likely entry points like `mc-focus' and `mc-present' - More stable API for `mc-focus' playback The following architecture and feature changes are planned (this is as much rubber ducking as it is communication): One disappointment of mine that affects both dslide and mc is the lack of sufficient multi-monitor detection on XFCE even when xrandr is present. The feature I want to implement is to display a frame or presentation fullscreen on the "other" monitor because in dslide, the comments in the base buffer are visible and can be used for narration. At present, it appears I would need to interpret xrandr itself since the high-level interface Emacs ships with appears not to distinguish the two physical monitors when they are treated as a single virtual screen. Since we need a new frame either way, I may just do that for now and later add customize support to "guess" the correct location and fullscreen parameter of the new frame. All region selection for `mc-focus' will be re-architectured to normalize onto the rectangle selection case. The non-rectangle case will be translated internally to work like the rectangle case. The reason is that I need to support trimming and to "do the right thing" when the user begins the selection with indentation. The rectangle case is more general to every consequent problem. This path may also adapt to handle visual lines better, injecting newlines when the column exceeds the window column width. I've realized a common mc workflow of mine is to hide some text completely rather than just highlight substrings. Subsequently, un-hiding creates the effect of building up a larger expression with all text remaining fixed in place, invaluable when presenting code. The playback features of MC almost assuredly need keyword arguments. Display can be affected by the string, its text properties, overlays, and invisibility specs. One option is to merge all of the properties and overlays. A more flexible option for interactive explanation of display itself is to toggle the invisibility spec and overlays on the fly. This is unsupported during playback without retaining the "redundant" information of unmerged properties and overlays etc. I need to add support for propagating overlay priorities. Reducing all overlays is an option, but the rules for overlays that are fully contained etc are a bit tricky and I don't want to emulate all of the behavior within MC. Images in theory can work. The size of the image needs to be adjusted according to the scale of the text overlay. There could be edge cases. Any specified space used for centering would need to be adjusted. That holds for text as well. [-- Attachment #2: Type: text/html, Size: 3580 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 2:45 ` Psionic K @ 2024-12-04 3:01 ` Dmitry Gutov 2024-12-04 3:13 ` Psionic K 2024-12-05 5:09 ` Richard Stallman 0 siblings, 2 replies; 20+ messages in thread From: Dmitry Gutov @ 2024-12-04 3:01 UTC (permalink / raw) To: Psionic K, Emacs developers, Philip Kaludercic Hi! On 04/12/2024 04:45, Psionic K wrote: > - I'm likely to change the package file name and consequent naming over > to mc. Please understand when this breaks use-package expressions. Just FWIW, there is an existing package which effectively uses the prefix "mc" - just following it with "/", it's called multiple-cursors, and it's been pretty popular a number of years ago. Probably remains so (2.3K stars on GH). ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 3:01 ` Dmitry Gutov @ 2024-12-04 3:13 ` Psionic K 2024-12-05 5:09 ` Richard Stallman 1 sibling, 0 replies; 20+ messages in thread From: Psionic K @ 2024-12-04 3:13 UTC (permalink / raw) To: Dmitry Gutov; +Cc: Psionic K, Emacs developers, Philip Kaludercic [-- Attachment #1: Type: text/plain, Size: 380 bytes --] > Just FWIW, there is an existing package which effectively uses the > prefix "mc" - just following it with "/", it's called multiple-cursors, > and it's been pretty popular a number of years ago. Thanks, I hadn't seen that on MELPA, only its mc-* derivatives. `moc' was the fallback plan. It does not trivially complete together with any `mc' symbols. Anyone object to that? [-- Attachment #2: Type: text/html, Size: 569 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 3:01 ` Dmitry Gutov 2024-12-04 3:13 ` Psionic K @ 2024-12-05 5:09 ` Richard Stallman 1 sibling, 0 replies; 20+ messages in thread From: Richard Stallman @ 2024-12-05 5:09 UTC (permalink / raw) To: psionik; +Cc: emacs-devel [[[ To any NSA and FBI agents reading my email: please consider ]]] [[[ whether defending the US Constitution against all enemies, ]]] [[[ foreign or domestic, requires you to follow Snowden's example. ]]] The name "master of ceremonies" is poetical, but on practical grounds it might be better to call it "presenter". That is shorter, and would make its purpose clear to everyone. Bt "mc" is too terse -- it won't -- Dr Richard Stallman (https://stallman.org) Chief GNUisance of the GNU Project (https://gnu.org) Founder, Free Software Foundation (https://fsf.org) Internet Hall-of-Famer (https://internethalloffame.org) ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-03 16:01 Introducing Master of Ceremonies, a package for presentations Psionic K 2024-12-04 2:45 ` Psionic K @ 2024-12-04 9:16 ` Jean Louis 2024-12-04 9:55 ` Psionic K 2024-12-06 19:57 ` Jean Louis 2 siblings, 1 reply; 20+ messages in thread From: Jean Louis @ 2024-12-04 9:16 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers * Psionic K <psionik@positron.solutions> [2024-12-03 19:03]: > I use this package for making videos and presentations. It's almost > ready for archives. > > https://github.com/positron-solutions/master-of-ceremonies > https://github.com/positron-solutions/master-of-ceremonies.git Thanks, very nice and totally useful. But I do not need those 2 vertical lines left and right, I need it all over the screen. I am to use it for displaying phone number and short notes or passwords which have to be observed. Like (mc-focus "+123456678") but lines are only confusing. -- Jean Louis ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 9:16 ` Jean Louis @ 2024-12-04 9:55 ` Psionic K 2024-12-04 10:05 ` Psionic K 2024-12-04 17:51 ` Jean Louis 0 siblings, 2 replies; 20+ messages in thread From: Psionic K @ 2024-12-04 9:55 UTC (permalink / raw) To: Psionic K, bugs; +Cc: Emacs developers [-- Attachment #1: Type: text/plain, Size: 1410 bytes --] Help me understand the problem more. The current implementation uses window margins. If your Emacs has obviously visible margins, then the effect is less good. Can you set window margins to zero to see if that's the source of your "vertical lines"? I can switch the implementation to using specified space to overcome this if it is indeed what we're talking about. If there's a communication issue, feel free to drop a screenshot on a github issue. I have updated the git and package prefix as part of my preparation for Non-GNU ELPA and MELPA. https://github.com/positron-solutions/moc https://github.com/positron-solutions/moc.git On Wed, Dec 4, 2024 at 6:17 PM Jean Louis <bugs@gnu.support> wrote: > * Psionic K <psionik@positron.solutions> [2024-12-03 19:03]: > > I use this package for making videos and presentations. It's almost > > ready for archives. > > > > https://github.com/positron-solutions/master-of-ceremonies > > https://github.com/positron-solutions/master-of-ceremonies.git > > Thanks, very nice and totally useful. > > But I do not need those 2 vertical lines left and right, I need it all > over the screen. > > I am to use it for displaying phone number and short notes or passwords > which have to be observed. > > Like (mc-focus "+123456678") but lines are only confusing. > > -- > Jean Louis > -- Only the Future is Certain [-- Attachment #2: Type: text/html, Size: 2463 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 9:55 ` Psionic K @ 2024-12-04 10:05 ` Psionic K 2024-12-25 16:08 ` Philip Kaludercic 2024-12-04 17:51 ` Jean Louis 1 sibling, 1 reply; 20+ messages in thread From: Psionic K @ 2024-12-04 10:05 UTC (permalink / raw) To: Psionic K, Philip Kaludercic; +Cc: Emacs developers [-- Attachment #1: Type: text/plain, Size: 2520 bytes --] Hello Philip, I have updated the git and package prefix as part of my preparation for Non-GNU ELPA and MELPA. Unless someone has a good objection in the near future, moc is the new prefix. There has been a short time for discussion, but my search indicates it's not a common substring except for completing with "mock". https://github.com/positron-solutions/moc https://github.com/positron-solutions/moc.git The current package lint shows no issues and the compile is clean. I have added a NEWS.org and moc.texi. The overall scheme is similar to what I used in dslide. I have marked code I still consider unreliably unstable / experimental with 🚧 to note areas that should be ransacked by vandals at the first convenience. I'm currently working on adding some kind of anti-highlight to completely obscure a bit of text and some trimming to try and stabilize the playback API for use in dslide. On Wed, Dec 4, 2024 at 6:55 PM Psionic K <psionik@positron.solutions> wrote: > Help me understand the problem more. The current implementation uses > window margins. If your Emacs has obviously visible margins, then the > effect is less good. Can you set window margins to zero to see if that's > the source of your "vertical lines"? > > I can switch the implementation to using specified space to overcome this > if it is indeed what we're talking about. > > If there's a communication issue, feel free to drop a screenshot on a > github issue. > > I have updated the git and package prefix as part of my preparation for > Non-GNU ELPA and MELPA. > > https://github.com/positron-solutions/moc > https://github.com/positron-solutions/moc.git > > > On Wed, Dec 4, 2024 at 6:17 PM Jean Louis <bugs@gnu.support> wrote: > >> * Psionic K <psionik@positron.solutions> [2024-12-03 19:03]: >> > I use this package for making videos and presentations. It's almost >> > ready for archives. >> > >> > https://github.com/positron-solutions/master-of-ceremonies >> > https://github.com/positron-solutions/master-of-ceremonies.git >> >> Thanks, very nice and totally useful. >> >> But I do not need those 2 vertical lines left and right, I need it all >> over the screen. >> >> I am to use it for displaying phone number and short notes or passwords >> which have to be observed. >> >> Like (mc-focus "+123456678") but lines are only confusing. >> >> -- >> Jean Louis >> > > > -- > Only the Future is Certain > -- Only the Future is Certain [-- Attachment #2: Type: text/html, Size: 4346 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 10:05 ` Psionic K @ 2024-12-25 16:08 ` Philip Kaludercic 0 siblings, 0 replies; 20+ messages in thread From: Philip Kaludercic @ 2024-12-25 16:08 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers [-- Attachment #1: Type: text/plain, Size: 620 bytes --] Psionic K <psionik@positron.solutions> writes: > Hello Philip, > > I have updated the git and package prefix as part of my preparation for > Non-GNU ELPA and MELPA. Unless someone has a good objection in the near > future, moc is the new prefix. There has been a short time for discussion, > but my search indicates it's not a common substring except for completing > with "mock". > > https://github.com/positron-solutions/moc > https://github.com/positron-solutions/moc.git [...] Sorry for the delay in answering, it was a lot of code and I had less time. Either way, here are my comments; hope they are useful: [-- Attachment #2: Type: text/plain, Size: 20681 bytes --] diff --git a/moc.el b/moc.el index 23d684a..a14c67f 100644 --- a/moc.el +++ b/moc.el @@ -1,11 +1,11 @@ -;;; moc.el --- Master of Ceremonies -*- lexical-binding: t; -*- +;;; moc.el --- Master of Ceremonies -*- lexical-binding: t; -*- ;; Copyright (C) 2024 Positron Solutions <contact@positron.solutions> ;; Author: Positron Solutions <contact@positron.solutions> ;; Keywords: convenience, outline ;; Version: 0.6.3 -;; Package-Requires: ((emacs "29.4") (hide-mode-line "1.0.3") (transient "0.7.2")) +;; Package-Requires: ((emacs "29.4") (hide-mode-line "1.0.3") (transient "0.7.2")) <- "hide-mode-line" is not a known package? ;; Homepage: http://github.com/positron-solutions/moc ;;; Copying: @@ -58,8 +58,8 @@ When using a transient cursor effect, the duration of cursor visibility is the product of this and `moc-subtle-cursor-interval'. -\\[info] elisp::Cursor Parameters." - :type 'integer) +See the Info node `(elisp) Cursor Parameters'." + :type 'natnum) (defcustom moc-subtle-cursor-interval 0.2 "Length of cursor blink interval in seconds. @@ -69,7 +69,7 @@ Values smaller than 0.013 will be treated as 0.013." (defcustom moc-focus-max-height-factor 0.75 "Focused text maximum height fraction. This is never exceeded." - :type 'float) + :type 'float) ;what are the legal values? (defcustom moc-focus-max-width-factor 0.75 "Focused text maximum width fraction. @@ -92,7 +92,7 @@ When focusing extremely small regions, this value prevents the text from being scaled comically large. If you just want to render single symbols or extremely short expressions, this setting can be used to control excessively large results." - :type 'float) + :type 'float) ;are fixnums really not acceptable? (defcustom moc-focus-default-remaps '(org-block-no-background) "A list of remap presets to apply to focused text. @@ -105,7 +105,7 @@ The defaults will just be turned on to save time in the usual cases." ;; buffers are focus buffers. Either scan, track, or don't bother. Multiple ;; focus buffers are impossible without names. -(defcustom moc-screenshot-dir #'temporary-file-directory +(defcustom moc-screenshot-dir #'temporary-file-directory ;what about `xdg-cache-home'? "Directory path or function that returns a directory path. Directory path is a string." :type '(choice string function)) @@ -115,10 +115,20 @@ Directory path is a string." Options are same as supported by the backend, `x-export-frames' for now, either pdf (default), png, postscript, or svg. Supported types are determined by the compile-time configuration of cairo." - :type '(choice (const :tag "PNG" png) - (const :tag "Scalable Vector Graphics" svg) - (const :tag "PDF" pdf) - (const :tag "Postscript" postscript))) + :type + (eval-when-compile + (let ((choices '())) + (dolist (choice '((png . "PNG") + (svg . "Scalable Vector Graphics") + (pdf . "PDF") + (postscript . "Postscript"))) + (when (condition-case nil + (always (x-export-frames nil (car choice))) + (error nil)) + (push `(const :tag ,(cdr choice) ,(car choice)) + choices))) + ;; FIXME: What if (null choices)? + `(choice ,@choices)))) (defcustom moc-fixed-frame-sizes '((youtube-short . (1080 . 1920)) @@ -136,10 +146,10 @@ Form is one of: NAME is a symbol, WIDTH and HEIGHT are integers, and FULLSCREEN is valid value for the `fullscreen' frame parameter. -\\[info] elisp::Frame Parameters" - :type '(cons symbol - (choice (cons number number) - symbol))) +See the Info node `(elisp) Frame Parameters'." + :type '(repeat (cons symbol ;or `alist' + (choice (cons number number) + symbol)))) (defcustom moc-face-remap-presets '((bold . ((default :weight bold))) @@ -152,7 +162,7 @@ element of PRESET is a cons of FACE SPECS where SPECS is one of the forms understood by `face-remap-add-relative'. \\[info] elisp::Face Remapping" - :type 'alist) + :type 'alist) ;you can further specialise this type with :key-type and :value-type (defcustom moc-frame-text-scale-step 1.05 "The factor of increase or decrease. @@ -260,7 +270,7 @@ KEEP-EXISTING" (or (moc--read-remap remap) (user-error "Remapping not found")) remap))) - (mapc (lambda (r) + (mapc (lambda (r) ;dolist is cheaper (let ((face (car r)) (specs (cdr r))) (push (face-remap-add-relative face specs) @@ -273,7 +283,7 @@ KEEP-EXISTING" (define-minor-mode moc-hide-cursor-mode "Make cursor completely hidden." - :group 'moc + :global nil (cond (moc-hide-cursor-mode (if (minibufferp) @@ -294,20 +304,20 @@ scale and deactivating it resets their original scale. This mode is not aware of other mechanisms of tracking the frame's text scale and conflicting modes will clobber each other." - :group 'moc :global t (cond (moc-frame-text-scale-mode (cl-loop for f in (frame-list) - do (when-let ((step (frame-parameter f 'moc--frame-text-scale))) - (let* ((orig (or (frame-parameter f 'moc--frame-text-scale-orig) - (face-attribute 'default :height f)))) - (set-face-attribute - 'default f :height - (round (* orig (expt moc-frame-text-scale-step step)))))))) + do (when-let* ((step (frame-parameter f 'moc--frame-text-scale)) + (orig (or (frame-parameter f 'moc--frame-text-scale-orig) + (face-attribute 'default :height f)))) + (set-face-attribute + 'default f :height + ;; I infer that `orig' cannot be nil, as you are multiplying it here? + (round (* orig (expt moc-frame-text-scale-step step))))))) (t - (cl-loop + (cl-loop ;this seems like it would also be simpler with a dolist. for f in (frame-list) do (when-let ((orig (frame-parameter f 'moc--frame-text-scale-orig))) (set-face-attribute 'default f :height orig)))))) @@ -315,11 +325,11 @@ scale and conflicting modes will clobber each other." (defun moc--frame-text-scale-cleanup-when-done () "Self-explanatory. If no frames have a non-zero step value, turn off the mode." - (unless (cl-loop - for f in (frame-list) - when (when-let ((step (frame-parameter f 'moc--frame-text-scale))) - (not (= 0 step))) - return f) + (unless (catch 'found ;just a suggestion if you want to get rid of cl-lib + (dolist (frame (frame-list)) + (when-let* ((step (frame-parameter f 'moc--frame-text-scale)) + ((/= 0 step))) + (throw 'found frame)))) (moc-frame-text-scale-mode -1))) (defun moc-frame-text-scale-increase () @@ -392,8 +402,8 @@ PROMPT will be used as a prompt. INITIAL is an initial value. Shocking." (let ((str (read-from-minibuffer prompt - (when initial (number-to-string initial)) nil nil nil))) - (if (string-match-p "^-?[0-9]*$" str) + (and initial (number-to-string initial)) nil nil nil))) + (if (string-match-p "^-?[0-9]+$" str) ;or is the empty string a valid number? (string-to-number str) (user-error "Could not read number: %s" str)))) @@ -428,11 +438,11 @@ blink if appropriate." (internal-show-cursor nil (not (internal-show-cursor-p)))) ;; Suspend counting blinks when the w32 menu-bar menu is displayed, ;; since otherwise menu tooltips will behave erratically. - (or (and (fboundp 'w32--menu-bar-in-use) - (w32--menu-bar-in-use)) - ;; XXX guarding this expression upsets the blink count and I don't know - ;; how it's supposed to work. - (setq moc-subtle-cursor-blinks-done (1+ moc-subtle-cursor-blinks-done))) + (unless (and (fboundp 'w32--menu-bar-in-use) + (w32--menu-bar-in-use)) + ;; XXX guarding this expression upsets the blink count and I don't know + ;; how it's supposed to work. + (setq moc-subtle-cursor-blinks-done (1+ moc-subtle-cursor-blinks-done))) ;; Each blink is two calls to this function. (when (and (> moc-subtle-cursor-blinks 0) (>= moc-subtle-cursor-blinks-done (* 2 moc-subtle-cursor-blinks))) @@ -454,8 +464,8 @@ Returns whether we have any focused non-TTY frame." (while frame-list (let ((frame (pop frame-list))) (when (and (display-graphic-p frame) (frame-focus-state frame)) - (setf any-graphical-focused t) - (setf frame-list nil)))) + (setq any-graphical-focused t) ;you use `setq' everywhere else + (setq frame-list nil)))) any-graphical-focused))) (defun moc-subtle-cursor-check () @@ -489,6 +499,8 @@ found active. (blink-cursor-mode -1)) (when moc-hide-cursor-mode (moc-hide-cursor-mode -1)) + ;; Can you explain why you are advising the function behind the + ;; symbol instead of setting the function? (add-function :after after-focus-change-function #'moc-subtle-cursor-check) (add-hook 'after-delete-frame-functions #'moc-subtle-cursor-check) @@ -522,8 +534,7 @@ found active. (define-minor-mode moc-quiet-mode "Inhibit messages in the echo area. ⚠️ Inhibiting messages is a bit dangerous. If anything fails, because messages -are disabled, there may be no obvious user feedback ☠️" - :group 'moc +are disabled, there may be no obvious user feedback ☠️" ;I think it would be better to avoid emojis, as not everyone has the fonts installed. :global t (cond (moc-quiet-mode @@ -543,7 +554,7 @@ are disabled, there may be no obvious user feedback ☠️" "Clean up hook if not guarding any more frames." (let ((frames (frame-list)) guarded) - (while (and frames (not guarded)) + (while (and frames (not guarded)) ;I'd use `dolist'+`catch' here again (when (frame-parameter (pop frames) 'moc--fixed-frame-notify) (setq guarded t))) (unless guarded @@ -630,7 +641,7 @@ parameter for `fullscreen'." (if (consp size) (unless (and (= (car size) (frame-pixel-width frame)) (= (cdr size) (frame-pixel-height frame))) - (let ((frame-resize-pixelwise t)) + (let ((frame-resize-pixelwise t)) ;what happens in TUI Emacs? (set-frame-parameter nil 'fullscreen nil) (set-frame-size nil (car size) (cdr size) t) (message "set size: %sw %sh" @@ -667,12 +678,10 @@ these behaviors may become more consistent." (new (cond (revert (frame-parameter (selected-frame) 'moc--fixed-frame-revert)) - ((stringp frame-size) - (cdr (assoc-string frame-size moc-fixed-frame-sizes))) - ((symbolp frame-size) - (cdr (assq frame-size moc-fixed-frame-sizes))) + ((or (symbolp frame-size) (stringp frame-size)) + (cdr (assoc frame-size moc-fixed-frame-sizes))) ((consp frame-size) frame-size) - (t (error "Unrecognized size: %s" frame-size)))) + ((error "Unrecognized size: %s" frame-size)))) (current (if-let* ((fullscreen (frame-parameter nil 'fullscreen))) fullscreen (cons (frame-pixel-width) @@ -718,10 +727,10 @@ Used in suffix command." (defun moc--dispatch-cursor-mode () "Return cursor state for use in info class." (if-let* ((cursor (if (consp cursor-type) - (car cursor-type) - (if (eq cursor-type t) - (frame-parameter nil 'cursor-type) - cursor-type)))) + (car cursor-type) + (if (eq cursor-type t) + (frame-parameter nil 'cursor-type) + cursor-type)))) (if moc-subtle-cursor-mode (propertize (format "subtle %-4s" cursor) 'face 'transient-value) @@ -741,7 +750,7 @@ Use in suffix command." (defun moc--dispatch-frame-text-scale () "Return current frame text scale for info class." - (if-let ((step (frame-parameter (selected-frame) 'moc--frame-text-scale))) + (if-let* ((step (frame-parameter (selected-frame) 'moc--frame-text-scale))) (propertize (format "frame scale: %s" step) 'face 'transient-value) (propertize "off" 'face 'shadow))) @@ -749,7 +758,7 @@ Use in suffix command." (defun moc--dispatch-frame-text-scale-p () "Return if current frame has a non-zero text scale." (when-let ((step (frame-parameter (selected-frame) 'moc--frame-text-scale))) - (not (eq 0 step)))) + (not (eq 0 step)))) ;why `eq'? (defun moc--dispatch-text-scale () "Return current text scale for info class." @@ -761,9 +770,9 @@ Use in suffix command." (defun moc--dispatch-quiet-mode () "Return description and quiet mode state for suffix." (format - "quiet %s" + "quiet %-3s" (if moc-quiet-mode - (propertize "on " 'face 'success) + (propertize "on" 'face 'success) (propertize "off" 'face 'shadow)))) ;;;###autoload (autoload 'moc-dispatch "moc" nil t) @@ -828,7 +837,7 @@ This just provides minor conveniences like pre-configured save path with (let* ((timestamp (format-time-string "%F-%T" (current-time))) (filename (format "screenshot-%s.svg" timestamp)) (dir (moc--screenshot-save-dir)) - (path (concat dir filename)) + (path (file-name-concat dir filename)) (data (x-export-frames nil moc-screenshot-type))) (unless (file-exists-p dir) (make-directory dir t)) @@ -906,14 +915,14 @@ into Emacs text flow logic in the first place. checking the final text size before adjusting the horizontal and vertical offset in `moc-focus-replay'." (cond - ((member 'truncate-lines continuation) + ((memq 'truncate-lines continuation) (set-window-margins window (max 0 (- (window-width) (ceiling (* fill-column scale))))) (toggle-truncate-lines 1) (prog1 (window-text-pixel-size window) (set-window-margins window nil))) - ((member 'visual-line-mode continuation) + ((memq 'visual-line-mode continuation) (visual-line-mode 1) (set-window-margins window (max 0 (- (window-width) @@ -939,7 +948,7 @@ another window will likely leave something to be desired." (kill-buffer old)) (let* ((base (current-buffer)) (buffer (get-buffer-create "*MoC Focus*")) - (text (plist-get args :text)) + (text (plist-get args :text)) ;perhaps you'd like `map-let'? (overlay-specs (plist-get args :overlays)) (invisibility-spec (plist-get args :invisibility-spec)) (continuation (plist-get args :continuation)) @@ -1105,10 +1114,8 @@ Preserves total ordering of highlighted spans." (while-let ((h (pop highlights))) ;; If BEG and END include either or both ends of a highlight, we have to ;; modify spans. - (let ((h-beg-interior (and (>= (car h) beg) - (<= (car h) end))) - (h-end-interior (and (>= (cdr h) beg) - (<= (cdr h) end))) + (let ((h-beg-interior (not (< beg (car h) end))) + (h-end-interior (not (< beg (cdr h) end))) (h-beg-before (< (car h) beg)) (h-end-after (> (cdr h) end))) (cond @@ -1228,7 +1235,7 @@ OCCLUDES is a list of conses of BEG END to be occluded." "Raise user error if commands are called in wrong mode." (if-let* ((buffer (get-buffer "*MoC Focus*"))) (set-buffer buffer) - (user-error "No MoC buffer found"))) + (user-error "No MoC buffer found"))) ;this is really the mistake of the user? (defun moc-focus-highlight-clear () "Delete all highlights and occludes." @@ -1272,7 +1279,7 @@ to make occluded regions visible again." (moc--focus-assert-mode) (moc--focus-occlude beg end) ;; unnecessary to deactivate the mark when called any other way - (when (called-interactively-p 't) + (when (called-interactively-p t) (deactivate-mark)) (moc--focus-apply-occludes moc--focus-occludes)) @@ -1286,7 +1293,7 @@ The shadow face will be added to the region between BEG and END." (moc--focus-un-highlight beg end) (moc--focus-un-occlude beg end) ;; unnecessary to deactivate the mark when called any other way - (when (called-interactively-p 't) + (when (called-interactively-p t) (deactivate-mark)) (moc--focus-apply-highlights moc--focus-highlights) (moc--focus-apply-occludes moc--focus-occludes)) @@ -1297,8 +1304,7 @@ This enables independent demonstration of the effect of source overlays." (interactive nil moc-focus-mode) (moc--focus-assert-mode) (if moc--focus-overlays - (progn (mapc #'delete-overlay - moc--focus-overlays) + (progn (mapc #'delete-overlay moc--focus-overlays) (setq moc--focus-overlays nil)) (moc--focus-apply-overlays ;; whenever toggling overlays, a space exists at the 1 position, so we need @@ -1362,7 +1368,7 @@ It is assumed that BUFFER was offset by BEG." (let ((old (current-buffer))) (set-buffer buffer) (goto-char 1) - (insert (make-string padding 32)) ; 32 is space + (insert (make-string padding ?\s)) (set-buffer old))) (defun moc--focus-trim-rect (buffer _rect _offset) @@ -1384,9 +1390,10 @@ extract the rectangle and then trim each line down to it's span." "Move forward through all whitespace. Do not exceed LIMIT. Optional MULTILINE will also move forward through newlines." - (if multiline - (re-search-forward "[^[:space:]\t\n\r]" limit t) - (re-search-forward "[^ \t]" limit t)) + (re-search-forward (if multiline + "[^[:space:]\t\n\r]" + "[^ \t]") + limit t) (goto-char (match-beginning 0))) (defun moc--focus-backward-whitespace (limit &optional multiline) @@ -1396,7 +1403,7 @@ newlines." (while (and (> (point) limit) (not (bobp)) (looking-back (if multiline - "[[:space:]]+" + "[[:space:]\n]+" ;i assume? "[ \t]+") limit t)) (goto-char (match-beginning 0)))) @@ -1503,8 +1510,7 @@ PROPS is a list returned from `overlay-properties'." ;; TODO customization (defun moc--focus-filter-overlay (o) - (unless (eq (overlay-get o 'face) 'region) - o)) + (and (not(eq (overlay-get o 'face) 'region)) o)) (defun moc--focus-extract-overlays (buffer) "Grab and serialize overlays from BUFFER." @@ -1580,14 +1586,14 @@ ARGS contains the following keys: " *MoC Processing*") :warning)) (let* ((buffer (get-buffer-create " *MoC Processing*")) - (rect (when rectangle-mark-mode - (extract-rectangle-bounds (region-beginning) - (region-end)))) + (rect (and rectangle-mark-mode + (extract-rectangle-bounds (region-beginning) + (region-end)))) (beg (region-beginning)) (end (region-end)) before) (when (string= (buffer-name) " *MoC Processing*") - (user-error "Cannot process the processing buffer: %S" + (user-error "Cannot process the processing buffer: %S" ;here the same as above: is this the mistake of a user who is never interested in a backtrace? (buffer-name))) (goto-char beg) (beginning-of-line) @@ -1728,9 +1734,9 @@ Used in suffix." "Modal controls for focus windows." :interactive nil) -(provide 'moc) -;;; moc.el ends here - ;; Local Variables: ;; outline-regexp: ";; \\(*+\\)" ;; End: + +(provide 'moc) +;;; moc.el ends here [-- Attachment #3: Type: text/plain, Size: 194 bytes --] Otherwise, an .elpaignore file would be nice again. I see you have a NEWS.org file that I presume you want to use, but what about the manual? Should we use the .texi file or build from .org? ^ permalink raw reply related [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 9:55 ` Psionic K 2024-12-04 10:05 ` Psionic K @ 2024-12-04 17:51 ` Jean Louis 2024-12-05 1:25 ` Psionic K 1 sibling, 1 reply; 20+ messages in thread From: Jean Louis @ 2024-12-04 17:51 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers [-- Attachment #1: Type: text/plain, Size: 395 bytes --] * Psionic K <psionik@positron.solutions> [2024-12-04 12:57]: > Help me understand the problem more. The current implementation uses > window margins. If your Emacs has obviously visible margins, then the > effect is less good. Can you set window margins to zero to see if that's > the source of your "vertical lines"? See vertical lines on left and right side in attachment. -- Jean Louis [-- Attachment #2: 2024-12-04_20-50.png --] [-- Type: image/png, Size: 31178 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-04 17:51 ` Jean Louis @ 2024-12-05 1:25 ` Psionic K 2024-12-05 5:25 ` Jean Louis 2024-12-05 18:41 ` Jean Louis 0 siblings, 2 replies; 20+ messages in thread From: Psionic K @ 2024-12-05 1:25 UTC (permalink / raw) To: bugs; +Cc: Psionic K, Emacs developers I don't know what display behavior creates the bars. I think it's margins, but let's find out. I have added a branch, no-margins, which uses specified space instead of margins. Please let me know if it fixes your problem. Another critical bug fix is in both branches. The state of `moc-subtle-cursor-mode' was initialized to t during loading (visible after restart) and `moc-focus' inferred that it needed to restore `moc-subtle-cursor-mode' after the first call, leaving behind a very much activated `moc-subtle-cursor-mode' for the user to clean up manually. ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-05 1:25 ` Psionic K @ 2024-12-05 5:25 ` Jean Louis 2024-12-05 8:29 ` Psionic K 2024-12-05 18:41 ` Jean Louis 1 sibling, 1 reply; 20+ messages in thread From: Jean Louis @ 2024-12-05 5:25 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers * Psionic K <psionik@positron.solutions> [2024-12-05 04:26]: > I don't know what display behavior creates the bars. I think it's > margins, but let's find out. I have added a branch, no-margins, which > uses specified space instead of margins. Please let me know if it > fixes your problem. I tried new branch and I see same vertical bars. It is caused by `set-window-margins' of course. Point of displaying something large is to present it conclusively. If you introduce visible margins and those margins will be also in different colors in different themes. It makes the display inconclusive, it makes a bit confusing "what am I seeing there". -- Jean Louis ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-05 5:25 ` Jean Louis @ 2024-12-05 8:29 ` Psionic K 2024-12-05 17:40 ` Jean Louis 0 siblings, 1 reply; 20+ messages in thread From: Psionic K @ 2024-12-05 8:29 UTC (permalink / raw) To: Psionic K, bugs; +Cc: Emacs developers I've updated the no-margins branch. I reproduced your issue by setting a fringe face background different than my default face background. MoC now sets fringe face background to nil and restores it after done. While I did also resize the fringes to zero, unless I can handle the echo area fringes and restore those, I cannot be more surgical at this time. Tangentially, the branch also contains overlay persistence and playback I just added, which can help displaying fancy org modern excerpts. I hope this doesn't confound our effort. Let me know if this helps. ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-05 8:29 ` Psionic K @ 2024-12-05 17:40 ` Jean Louis 0 siblings, 0 replies; 20+ messages in thread From: Jean Louis @ 2024-12-05 17:40 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers * Psionic K <psionik@positron.solutions> [2024-12-05 11:29]: > I've updated the no-margins branch. > > I reproduced your issue by setting a fringe face background different > than my default face background. MoC now sets fringe face background > to nil and restores it after done. While I did also resize the > fringes to zero, unless I can handle the echo area fringes and restore > those, I cannot be more surgical at this time. with git branch --list I see no branches now any more, but it was before. And why you need branch? Just make it in the main. -- Jean Louis ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-05 1:25 ` Psionic K 2024-12-05 5:25 ` Jean Louis @ 2024-12-05 18:41 ` Jean Louis 2024-12-05 23:27 ` Psionic K 1 sibling, 1 reply; 20+ messages in thread From: Jean Louis @ 2024-12-05 18:41 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers * Psionic K <psionik@positron.solutions> [2024-12-05 04:28]: > I don't know what display behavior creates the bars. I think it's > margins, but let's find out. I have added a branch, no-margins, which > uses specified space instead of margins. Please let me know if it > fixes your problem. It works now, and I didn't use any branch. Good there are no lines on screen. I have now included it in RCD Notes & Hyperscope, The Dynamic Knowledge Repository for GNU Emacs, as it is going to be heavily used in demonstrations of phone numbers, email addresses, each time user has to write something on the paper, or call by watching the number, street address, zip code, the last killed information, and so on. Here is the video demonstration: https://gnu.support/images/2024/12/2024-12-05/2024-12-05-21:38:25.ogv I think that longer lines shall be wrapped, you have to include word wrap, as otherwise lines will become smaller thant the original line! -- Jean Louis ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-05 18:41 ` Jean Louis @ 2024-12-05 23:27 ` Psionic K 0 siblings, 0 replies; 20+ messages in thread From: Psionic K @ 2024-12-05 23:27 UTC (permalink / raw) To: Psionic K, Emacs developers [-- Attachment #1: Type: text/plain, Size: 251 bytes --] > I think that longer lines shall be wrapped, you have to include word > wrap, as otherwise lines will become smaller thant the original line! It's true. Especially with visual line mode, I need to decide how long the lines are and inject newlines. [-- Attachment #2: Type: text/html, Size: 326 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-03 16:01 Introducing Master of Ceremonies, a package for presentations Psionic K 2024-12-04 2:45 ` Psionic K 2024-12-04 9:16 ` Jean Louis @ 2024-12-06 19:57 ` Jean Louis 2024-12-07 12:02 ` Psionic K 2 siblings, 1 reply; 20+ messages in thread From: Jean Louis @ 2024-12-06 19:57 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers Programming/git/moc/moc.el: Warning: ‘when-let’ is an obsolete macro (as of 31.1); use ‘when-let*’ or ‘and-let*’ instead. [3 times] Programming/git/moc/moc.el: Warning: ‘if-let’ is an obsolete macro (as of 31.1); use ‘if-let*’ instead. [3 times] Programming/git/moc/moc.el: Warning: ‘when-let’ is an obsolete macro (as of 31.1); use ‘when-let*’ or ‘and-let*’ instead. [2 times] Programming/git/moc/moc.el: Warning: ‘if-let’ is an obsolete macro (as of 31.1); use ‘if-let*’ instead. [2 times] -- Jean Louis ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-06 19:57 ` Jean Louis @ 2024-12-07 12:02 ` Psionic K 2024-12-08 6:29 ` Jean Louis 0 siblings, 1 reply; 20+ messages in thread From: Psionic K @ 2024-12-07 12:02 UTC (permalink / raw) To: Psionic K, bugs; +Cc: Emacs developers [-- Attachment #1: Type: text/plain, Size: 1640 bytes --] To be clear, Jean, are you conducting this review for Non-GNU ELPA? > I think that longer lines shall be wrapped, you have to include word > wrap, as otherwise lines will become smaller thant the original line! Such a change is in progress. I'm just about to stash some re-work of the core logic for `moc-focus' to have general support for most cases. It's looking like 1k lines of rework and quite annoying. I suspect there must be a better way. I can fit visual lines by using their horizontal and vertical height after breaks to calculate what will provide the best aspect ratio. Such a calculation with reasonable accuracy can be done in one step without troubling Emacs. With some length of selection there is never anything I can do to make the text big, but we can make it pretty. The fundamental issue remains that translating overlays after such a reflow is not so trivial. That is unless I do the reflow within a buffer with editing commands after copying all of the necessary information over instead of stitching and welding overlays and strings together without the aid of a buffer. This would allow some savings by re-using editing logic to preserve overlays and property applications to injected whitespace. Instead of calculating things I can just read the final result of all the edits. This seems more robust and I think I will implement the easiest and most relevant cases first: - whitespace trimming of indentation - whitespace injection to maintain column alignment of first line in source - newline insertion to reflow long logical lines and match the target aspect ratio I might just need a break lol. [-- Attachment #2: Type: text/html, Size: 1837 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-07 12:02 ` Psionic K @ 2024-12-08 6:29 ` Jean Louis 2024-12-08 7:14 ` Psionic K 0 siblings, 1 reply; 20+ messages in thread From: Jean Louis @ 2024-12-08 6:29 UTC (permalink / raw) To: Psionic K; +Cc: Emacs developers * Psionic K <psionik@positron.solutions> [2024-12-07 15:03]: > To be clear, Jean, are you conducting this review for Non-GNU ELPA? For my software and for your improvement. It is presenting well, but only short words. It should at least present well sentences and paragraphs. > > I think that longer lines shall be wrapped, you have to include word > > wrap, as otherwise lines will become smaller thant the original line! > > Such a change is in progress. I'm just about to stash some re-work of the > core logic for `moc-focus' to have general support for most cases. It's > looking like 1k lines of rework and quite annoying. I suspect there must > be a better way. - calculate how many letters can fit in single line, for the maximum presentable width - I would remove any double horizontal white space from sentences or paragraphs - I would convert it to list of words - then make new list of concatenated chunks of words that fit in the single line - then concatenate maybe with new lines - then present it > I can fit visual lines by using their horizontal and vertical height after > breaks to calculate what will provide the best aspect ratio. Such a > calculation with reasonable accuracy can be done in one step without > troubling Emacs. With some length of selection there is never anything I > can do to make the text big, but we can make it pretty. I think yes with word parsing and deciding how to fit it. -- Jean Louis ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: Introducing Master of Ceremonies, a package for presentations 2024-12-08 6:29 ` Jean Louis @ 2024-12-08 7:14 ` Psionic K 0 siblings, 0 replies; 20+ messages in thread From: Psionic K @ 2024-12-08 7:14 UTC (permalink / raw) To: Psionic K, bugs; +Cc: Emacs developers [-- Attachment #1: Type: text/plain, Size: 2488 bytes --] I have pushed master with some packaging related fixups to make progress on adding to MELPA / Non-GNU ELPA. Among changes, I have adopted a new strategy that leans on Emacs text editing. The result is much more satisfactory than the overlay stitching and translation I had started work on in another stash which will now be deleted. As a benefit, we finally have some basic whitespace cleanup and indentation preservation when selections do not begin at a line beginning, such as can be required if the preceding text is not whitespace. What remains is an implementation of rectangle trimming and following up on my continuation strategy, I will describe below. > remove any double horizontal white space from sentences or paragraphs User responsibility. I can't make everyone or a reliable majority happy with either decision and input text expresses these decisions or should. > It is presenting well, but only short words. It should at least > present well sentences and paragraphs. The new `:continuation` key in `moc-focus` replay arg plist reveals my strategy for this. I read the state of `visual-line-mode` and `adaptive-wrap-prefix-mode`. I will default to truncation when these are not active. When they are active, I can calculate the right size as described earlier and allow Emacs logic to wrap the text. If in the future text can be justified by an overlay or buffer-wide via a mode, it will be easy to support, but I will not manually re-flow text because that is just asking to re-implement and maintain the entire ball of yarn in Elisp, an endeavour of very limited value to me and one that has workarounds for the user: Turn off read-only mode and make some edits. When filling code with long lines and comments etc, the user's fill column will usually be what they want. I don't want to reflow Elisp code without a lot more intelligence. That is LLM work, not fiddly text editing rule and heuristic based work. Truncation is very robust at limiting the max width. For visual lines, along with the continuation strategy described above, I am implementing a minimum character width, which is a heuristic to avoid re-shaping text that is extremely short, below 30 characters or so. Don't want one word per line. I can do manual justification, but honestly why not just do this with specified space in Emacs and apply a text property if desired? My implementation will be useless by comparison in terms of coverage. Images can center. Why not text? [-- Attachment #2: Type: text/html, Size: 2963 bytes --] ^ permalink raw reply [flat|nested] 20+ messages in thread
end of thread, other threads:[~2024-12-25 16:08 UTC | newest] Thread overview: 20+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-12-03 16:01 Introducing Master of Ceremonies, a package for presentations Psionic K 2024-12-04 2:45 ` Psionic K 2024-12-04 3:01 ` Dmitry Gutov 2024-12-04 3:13 ` Psionic K 2024-12-05 5:09 ` Richard Stallman 2024-12-04 9:16 ` Jean Louis 2024-12-04 9:55 ` Psionic K 2024-12-04 10:05 ` Psionic K 2024-12-25 16:08 ` Philip Kaludercic 2024-12-04 17:51 ` Jean Louis 2024-12-05 1:25 ` Psionic K 2024-12-05 5:25 ` Jean Louis 2024-12-05 8:29 ` Psionic K 2024-12-05 17:40 ` Jean Louis 2024-12-05 18:41 ` Jean Louis 2024-12-05 23:27 ` Psionic K 2024-12-06 19:57 ` Jean Louis 2024-12-07 12:02 ` Psionic K 2024-12-08 6:29 ` Jean Louis 2024-12-08 7:14 ` Psionic K
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).