* Re: Link preview generation with new link preview property [not found] <6755f138.0c0a0220.40388.51fbSMTPIN_ADDED_BROKEN@mx.google.com> @ 2024-12-13 5:49 ` Karthik Chikmagalur 2024-12-14 0:03 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Karthik Chikmagalur @ 2024-12-13 5:49 UTC (permalink / raw) To: Björn Bidar, emacs-orgmode > The PR do port the package to this new handler property: > https://github.com/gaoDean/org-remoteimg/pull/4 > > However it left me with a few questions: > - Who is supposed to take care of the scaling/width of the preview > image, the handler or the caller of the handler? The handler is responsible for sizing the image. The reason for this is that the preview does not have to be an image -- it can be any kind of overlay decoration. If you decide to use an image file as the preview, you can call `org-link-preview-file' inside your handler to handle the geometry for you. This includes the size and alignment specified by #+attr_* keywords, `org-image-max-width' and `org-image-align'. If you are using a preview image from image data, you'll have to copy some of the code in `org-link-preview-file' to your handler if you want to respect these user options. > - When calling the link preview function for a description with prefix > argument 1 I noticed that it doesn't get the contents of the > description. > Why is that? In this instance the link looked like this: > [[https://stable.melpa.org/#/rpm-spec-mode][file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg]] I don't follow. What do you mean by "it doesn't get the contents"? Did the preview work as expected when you used a prefix arg of 1? Karthik ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-13 5:49 ` Link preview generation with new link preview property Karthik Chikmagalur @ 2024-12-14 0:03 ` Björn Bidar 2024-12-14 7:04 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2024-12-14 0:03 UTC (permalink / raw) To: Karthik Chikmagalur; +Cc: emacs-orgmode Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: >> The PR do port the package to this new handler property: >> https://github.com/gaoDean/org-remoteimg/pull/4 >> >> However it left me with a few questions: >> - Who is supposed to take care of the scaling/width of the preview >> image, the handler or the caller of the handler? > > The handler is responsible for sizing the image. The reason for this is > that the preview does not have to be an image -- it can be any kind of > overlay decoration. > > If you decide to use an image file as the preview, you can call > `org-link-preview-file' inside your handler to handle the geometry for > you. This includes the size and alignment specified by #+attr_* > keywords, `org-image-max-width' and `org-image-align'. > > If you are using a preview image from image data, you'll have to copy > some of the code in `org-link-preview-file' to your handler if you want > to respect these user options. Would it be possible to also handle image data in the function or refactor the org-link-preview-file function in a way that the geometry handling is done in a helper function which can be reused by other handlers. In the example I mentioned it should be possible to use the cached file from the url cache but that might be not so easy in other cases. >> - When calling the link preview function for a description with prefix >> argument 1 I noticed that it doesn't get the contents of the >> description. >> Why is that? In this instance the link looked like this: >> [[https://stable.melpa.org/#/rpm-spec-mode][file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg]] > > I don't follow. What do you mean by "it doesn't get the contents"? Did > the preview work as expected when you used a prefix arg of 1? The link element passed towards the handler didn't contain the description e.g. in this case file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg. ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-14 0:03 ` Björn Bidar @ 2024-12-14 7:04 ` Ihor Radchenko 2024-12-17 2:46 ` Björn Bidar 2024-12-17 3:42 ` Karthik Chikmagalur 0 siblings, 2 replies; 28+ messages in thread From: Ihor Radchenko @ 2024-12-14 7:04 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: > Would it be possible to also handle image data in the function or > refactor the org-link-preview-file function in a way that the geometry > handling is done in a helper function which can be reused by other > handlers. There is such function: `org-display-inline-image--width'. We may consider exposing it as public function. > The link element passed towards the handler didn't contain the > description e.g. in this case file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg. This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a You can access the contents by looking at buffer text between :contents-begin and :contents-end. Either directly, or by invoking sub-parser on the text. -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-14 7:04 ` Ihor Radchenko @ 2024-12-17 2:46 ` Björn Bidar 2024-12-17 17:39 ` Ihor Radchenko 2024-12-17 3:42 ` Karthik Chikmagalur 1 sibling, 1 reply; 28+ messages in thread From: Björn Bidar @ 2024-12-17 2:46 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode Ihor Radchenko <yantar92@posteo.net> writes: > Björn Bidar <bjorn.bidar@thaodan.de> writes: > >> Would it be possible to also handle image data in the function or >> refactor the org-link-preview-file function in a way that the geometry >> handling is done in a helper function which can be reused by other >> handlers. > > There is such function: `org-display-inline-image--width'. > We may consider exposing it as public function. That would be awesome, the easier it is for other modes to add their own handlers and them to survive org-mode updates. Although for this http link handler it could be better a function inside org-mode. >> The link element passed towards the handler didn't contain the >> description e.g. in this case file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg. > > This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a > You can access the contents by looking at buffer text between > :contents-begin and :contents-end. Either directly, or by invoking > sub-parser on the text. Oh thanks, will look into that. Is there a offline version of the manual like the org info manual? ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-17 2:46 ` Björn Bidar @ 2024-12-17 17:39 ` Ihor Radchenko 2024-12-19 21:55 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Ihor Radchenko @ 2024-12-17 17:39 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: >> This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a >> You can access the contents by looking at buffer text between >> :contents-begin and :contents-end. Either directly, or by invoking >> sub-parser on the text. > > Oh thanks, will look into that. Is there a offline version of the manual > like the org info manual? Nothing shipped with Org distribution. But you can always clone WORG - it is mostly a collection of .org files. -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-17 17:39 ` Ihor Radchenko @ 2024-12-19 21:55 ` Björn Bidar 2024-12-21 12:03 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2024-12-19 21:55 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode Ihor Radchenko <yantar92@posteo.net> writes: > Björn Bidar <bjorn.bidar@thaodan.de> writes: > >>> This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a >>> You can access the contents by looking at buffer text between >>> :contents-begin and :contents-end. Either directly, or by invoking >>> sub-parser on the text. >> >> Oh thanks, will look into that. Is there a offline version of the manual >> like the org info manual? > > Nothing shipped with Org distribution. > But you can always clone WORG - it is mostly a collection of .org files. That's a good suggestion. I never used org for reading only but it should be better than a website. Does view-mode mode work fine with org? Anyway it would be a good improvement to include the org-mode api manual with org-mode similar to how Emacs includes the Elisp manual. ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-19 21:55 ` Björn Bidar @ 2024-12-21 12:03 ` Ihor Radchenko 0 siblings, 0 replies; 28+ messages in thread From: Ihor Radchenko @ 2024-12-21 12:03 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: > Anyway it would be a good improvement to include the org-mode api manual > with org-mode similar to how Emacs includes the Elisp manual. Maybe. But we need to write that org-element API manual first. The WORG page is not a manual. It's a mixture of API reference (partial) with some elements of what supposed to be in the manual. -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-14 7:04 ` Ihor Radchenko 2024-12-17 2:46 ` Björn Bidar @ 2024-12-17 3:42 ` Karthik Chikmagalur 2024-12-17 17:40 ` Ihor Radchenko 2024-12-18 6:21 ` stardiviner 1 sibling, 2 replies; 28+ messages in thread From: Karthik Chikmagalur @ 2024-12-17 3:42 UTC (permalink / raw) To: Ihor Radchenko, Björn Bidar; +Cc: emacs-orgmode >> Would it be possible to also handle image data in the function or >> refactor the org-link-preview-file function in a way that the geometry >> handling is done in a helper function which can be reused by other >> handlers. > > There is such function: `org-display-inline-image--width'. > We may consider exposing it as public function. This will not be enough, we will also have to expose `org-image--align' and the alignment code: (when align (overlay-put ov 'before-string (propertize " " 'face 'default 'display (pcase align ("center" `(space :align-to (- center (0.5 . ,image)))) ("right" `(space :align-to (- right ,image))))))) I don't think we can expect third party packages to figure out and reimplement Org's image alignment logic. Considering this, it might be better to just split `org-link-preview-file' into two public functions, where the "inside" function accepts an image instead of a file. Karthik ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-17 3:42 ` Karthik Chikmagalur @ 2024-12-17 17:40 ` Ihor Radchenko 2024-12-19 23:20 ` Björn Bidar ` (2 more replies) 2024-12-18 6:21 ` stardiviner 1 sibling, 3 replies; 28+ messages in thread From: Ihor Radchenko @ 2024-12-17 17:40 UTC (permalink / raw) To: Karthik Chikmagalur; +Cc: Björn Bidar, emacs-orgmode Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: > ... > Considering this, it might be better to just split > `org-link-preview-file' into two public functions, where the "inside" > function accepts an image instead of a file. Agree. Would you be interested to create a patch? -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-17 17:40 ` Ihor Radchenko @ 2024-12-19 23:20 ` Björn Bidar 2024-12-20 0:45 ` Karthik Chikmagalur [not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com> 2 siblings, 0 replies; 28+ messages in thread From: Björn Bidar @ 2024-12-19 23:20 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode [-- Attachment #1: Type: text/plain, Size: 387 bytes --] Ihor Radchenko <yantar92@posteo.net> writes: > Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: > >> ... >> Considering this, it might be better to just split >> `org-link-preview-file' into two public functions, where the "inside" >> function accepts an image instead of a file. > > Agree. > Would you be interested to create a patch? Did you think of something like this? [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: 0001-org-link-Split-link-preview-into-two-functions.patch --] [-- Type: text/x-patch, Size: 2817 bytes --] From a3c682a7d730b0ae9492407d080ba8549a19e02d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Bidar?= <bjorn.bidar@thaodan.de> Date: Fri, 20 Dec 2024 01:00:46 +0200 Subject: [PATCH] org-link: Split link preview into two functions * lisp/ol.el (org-link-preview-file, org-link-preview-image-data): Split up the actual preview part into a separate function. The new preview function can be called by :preview handler to display the image according to the correct alignment for the link to be previewed. --- lisp/ol.el | 45 ++++++++++++++++++++++++++------------------- 1 file changed, 26 insertions(+), 19 deletions(-) diff --git a/lisp/ol.el b/lisp/ol.el index 032610bad..dd6b07152 100644 --- a/lisp/ol.el +++ b/lisp/ol.el @@ -2177,27 +2177,34 @@ (defun org-link-preview-file (ov path link) ((string-match-p (image-file-name-regexp) file)) ((file-exists-p file))) (let* ((width (org-display-inline-image--width link)) - (align (org-image--align link)) - (image (org--create-inline-image file width))) - (when image ; Add image to overlay - ;; See bug#59902. We cannot rely - ;; on Emacs to update image if the file - ;; has changed. - (image-flush image) - (overlay-put ov 'display image) - (overlay-put ov 'face 'default) - (overlay-put ov 'keymap image-map) - (when align - (overlay-put - ov 'before-string - (propertize - " " 'face 'default - 'display - (pcase align - ("center" `(space :align-to (- center (0.5 . ,image)))) - ("right" `(space :align-to (- right ,image))))))) + (image-data (org--create-inline-image file width))) + (when image-data + (org-link-preview-image-data ov image-data link) t))))) +(defun org-link-preview-image-data (ov image-data link) + "Display image data IMAGE-DATA in overlay OV for link. + +This intended to be used by functions which provide the :preview link property +of links such as in `org-link-preview-file'" + (let ((align (org-image--align link))) + ;; See bug#59902. We cannot rely + ;; on Emacs to update image if the file + ;; has changed. + (image-flush image-data) + (overlay-put ov 'display image-data) + (overlay-put ov 'face 'default) + (overlay-put ov 'keymap image-map) + (when align + (overlay-put + ov 'before-string + (propertize + " " 'face 'default + 'display + (pcase align + ("center" `(space :align-to (- center (0.5 . ,image-data)))) + ("right" `(space :align-to (- right ,image-data))))))))) + ;;;; "help" link type (defun org-link--open-help (path _) "Open a \"help\" type link. -- 2.45.2 ^ permalink raw reply related [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-17 17:40 ` Ihor Radchenko 2024-12-19 23:20 ` Björn Bidar @ 2024-12-20 0:45 ` Karthik Chikmagalur 2024-12-21 12:05 ` Ihor Radchenko [not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com> 2 siblings, 1 reply; 28+ messages in thread From: Karthik Chikmagalur @ 2024-12-20 0:45 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Björn Bidar, emacs-orgmode >> ... >> Considering this, it might be better to just split >> `org-link-preview-file' into two public functions, where the "inside" >> function accepts an image instead of a file. > > Agree. > Would you be interested to create a patch? Ihor, did you write a patch for this already? I thought I saw something from you but can't locate it now. If not, I can submit a patch but it will be a week or so before I can get to it. Karthik ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-20 0:45 ` Karthik Chikmagalur @ 2024-12-21 12:05 ` Ihor Radchenko 2024-12-23 20:41 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Ihor Radchenko @ 2024-12-21 12:05 UTC (permalink / raw) To: Karthik Chikmagalur; +Cc: Björn Bidar, emacs-orgmode Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: >>> ... >>> Considering this, it might be better to just split >>> `org-link-preview-file' into two public functions, where the "inside" >>> function accepts an image instead of a file. >> >> Agree. >> Would you be interested to create a patch? > > Ihor, did you write a patch for this already? I thought I saw something > from you but can't locate it now. No, I did not. (I hope I did not forget 🤦) > If not, I can submit a patch but it will be a week or so before I can > get to it. Maybe you can work with Bjorn on his patch instead? -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-21 12:05 ` Ihor Radchenko @ 2024-12-23 20:41 ` Björn Bidar 0 siblings, 0 replies; 28+ messages in thread From: Björn Bidar @ 2024-12-23 20:41 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode Ihor Radchenko <yantar92@posteo.net> writes: > Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: > >>>> ... >>>> Considering this, it might be better to just split >>>> `org-link-preview-file' into two public functions, where the "inside" >>>> function accepts an image instead of a file. >>> >>> Agree. >>> Would you be interested to create a patch? >> >> Ihor, did you write a patch for this already? I thought I saw something >> from you but can't locate it now. > > No, I did not. (I hope I did not forget 🤦) > >> If not, I can submit a patch but it will be a week or so before I can >> get to it. > > Maybe you can work with Bjorn on his patch instead? Anything is fine for me. Feedback on my last patch would be great. ^ permalink raw reply [flat|nested] 28+ messages in thread
[parent not found: <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com>]
* Re: Link preview generation with new link preview property [not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com> @ 2024-12-26 18:46 ` Karthik Chikmagalur 2024-12-29 15:44 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Karthik Chikmagalur @ 2024-12-26 18:46 UTC (permalink / raw) To: Björn Bidar, Ihor Radchenko; +Cc: emacs-orgmode >>> ... >>> Considering this, it might be better to just split >>> `org-link-preview-file' into two public functions, where the "inside" >>> function accepts an image instead of a file. >> >> Agree. >> Would you be interested to create a patch? > > Did you think of something like this? It looks like you are respecting the alignment specifications, set via org-image-align or the :align property of #+attr_*, but not the :width property. Is the idea that the preview implementation that provides the image should independently use org-display-inline-image--width? At minimum this requires making org-display-inline-image--width a public function. But it would be good for org-link-preview-image-data to respect both properties. Karthik ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-26 18:46 ` Karthik Chikmagalur @ 2024-12-29 15:44 ` Björn Bidar 2024-12-30 17:05 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2024-12-29 15:44 UTC (permalink / raw) To: Karthik Chikmagalur; +Cc: Ihor Radchenko, emacs-orgmode Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: >>>> ... >>>> Considering this, it might be better to just split >>>> `org-link-preview-file' into two public functions, where the "inside" >>>> function accepts an image instead of a file. >>> >>> Agree. >>> Would you be interested to create a patch? >> >> Did you think of something like this? > > It looks like you are respecting the alignment specifications, set via > org-image-align or the :align property of #+attr_*, but not the :width > property. Is the idea that the preview implementation that provides the > image should independently use org-display-inline-image--width? The width is set before the inline image is created. I'm not sure how this should be handled. Is the with set when creating the inline image Ihor? If the width is set before the image is created how should it be handled in the preview image-data function? > At minimum this requires making org-display-inline-image--width a public > function. But it would be good for org-link-preview-image-data to > respect both properties. I agree with both but I'm not sure what should be done on this. ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-29 15:44 ` Björn Bidar @ 2024-12-30 17:05 ` Ihor Radchenko 2025-01-04 2:01 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Ihor Radchenko @ 2024-12-30 17:05 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: >> It looks like you are respecting the alignment specifications, set via >> org-image-align or the :align property of #+attr_*, but not the :width >> property. Is the idea that the preview implementation that provides the >> image should independently use org-display-inline-image--width? > > The width is set before the inline image is created. I'm not sure how > this should be handled. Is the with set when creating the inline image > Ihor? > If the width is set before the image is created how should it be handled > in > the preview image-data function? Both alignment and width are derived from LINK AST node. I am not sure what is the problem. AFAIU, Karthik is simply asking why you decided to calculate alignment from LINK, but not width. >> At minimum this requires making org-display-inline-image--width a public >> function. But it would be good for org-link-preview-image-data to >> respect both properties. > > I agree with both but I'm not sure what should be done on this. If we think about the API function to be more useful, we can derive alignment and width from LINK itself by default, but also provide optional parameters, so that the caller can override the values manually. If both alignment and width parameters are explicitly specified, LINK does not have to be provided. -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-30 17:05 ` Ihor Radchenko @ 2025-01-04 2:01 ` Björn Bidar 2025-01-04 14:11 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2025-01-04 2:01 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode Ihor Radchenko <yantar92@posteo.net> writes: > Björn Bidar <bjorn.bidar@thaodan.de> writes: > >>> It looks like you are respecting the alignment specifications, set via >>> org-image-align or the :align property of #+attr_*, but not the :width >>> property. Is the idea that the preview implementation that provides the >>> image should independently use org-display-inline-image--width? >> >> The width is set before the inline image is created. I'm not sure how >> this should be handled. Is the with set when creating the inline image >> Ihor? >> If the width is set before the image is created how should it be handled >> in >> the preview image-data function? > > Both alignment and width are derived from LINK AST node. > I am not sure what is the problem. > AFAIU, Karthik is simply asking why you decided to calculate alignment > from LINK, but not width. My question was because the width is set through the width of the inline image, i.e. the image-data passed through the preview function. Is there no difference if function using org-link-review-image-data has not set the width of the image and then we set the with of the overlay instead? >>> At minimum this requires making org-display-inline-image--width a public >>> function. But it would be good for org-link-preview-image-data to >>> respect both properties. >> >> I agree with both but I'm not sure what should be done on this. > > If we think about the API function to be more useful, we can derive > alignment and width from LINK itself by default, but also provide > optional parameters, so that the caller can override the values > manually. If both alignment and width parameters are explicitly > specified, LINK does not have to be provided. How would that work? Make link align and with optional and fail if align or with are missing without link? ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2025-01-04 2:01 ` Björn Bidar @ 2025-01-04 14:11 ` Ihor Radchenko 2025-01-18 14:44 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Ihor Radchenko @ 2025-01-04 14:11 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: >> Both alignment and width are derived from LINK AST node. >> I am not sure what is the problem. >> AFAIU, Karthik is simply asking why you decided to calculate alignment >> from LINK, but not width. > > My question was because the width is set through the width of the inline > image, i.e. the image-data passed through the preview function. > Is there no difference if function using org-link-review-image-data has > not set the width of the image and then we set the with of the overlay instead? You are probably confused by `org--create-inline-image'? IMHO, it would be best to pass image file name/raw image data to `org-link-preview-image-data', not an image object and call `org--create-inline-image' from inside `org-link-preview-image-data'. That way, we can automatically obey Org customization wrt image alignment, image width, and image max width. >> If we think about the API function to be more useful, we can derive >> alignment and width from LINK itself by default, but also provide >> optional parameters, so that the caller can override the values >> manually. If both alignment and width parameters are explicitly >> specified, LINK does not have to be provided. > > How would that work? Make link align and with optional and fail if > align or with are missing without link? Yes. -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2025-01-04 14:11 ` Ihor Radchenko @ 2025-01-18 14:44 ` Björn Bidar 2025-01-18 15:03 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2025-01-18 14:44 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode Ihor Radchenko <yantar92@posteo.net> writes: > Björn Bidar <bjorn.bidar@thaodan.de> writes: > >>> Both alignment and width are derived from LINK AST node. >>> I am not sure what is the problem. >>> AFAIU, Karthik is simply asking why you decided to calculate alignment >>> from LINK, but not width. >> >> My question was because the width is set through the width of the inline >> image, i.e. the image-data passed through the preview function. >> Is there no difference if function using org-link-review-image-data has >> not set the width of the image and then we set the with of the overlay instead? > > You are probably confused by `org--create-inline-image'? Possibly but I simply was confused by some of the properties of the overlay being set and some of them being taken from the image object. > IMHO, it would be best to pass image file name/raw image data to > `org-link-preview-image-data', not an image object and call > `org--create-inline-image' from inside `org-link-preview-image-data'. > That way, we can automatically obey Org customization wrt image > alignment, image width, and image max width. For that case using org-link-preview-file should be sufficient? >>> If we think about the API function to be more useful, we can derive >>> alignment and width from LINK itself by default, but also provide >>> optional parameters, so that the caller can override the values >>> manually. If both alignment and width parameters are explicitly >>> specified, LINK does not have to be provided. >> >> How would that work? Make link align and with optional and fail if >> align or with are missing without link? > > Yes. ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2025-01-18 14:44 ` Björn Bidar @ 2025-01-18 15:03 ` Ihor Radchenko 2025-01-19 15:08 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Ihor Radchenko @ 2025-01-18 15:03 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: >> IMHO, it would be best to pass image file name/raw image data to >> `org-link-preview-image-data', not an image object and call >> `org--create-inline-image' from inside `org-link-preview-image-data'. >> That way, we can automatically obey Org customization wrt image >> alignment, image width, and image max width. > > For that case using org-link-preview-file should be sufficient? Sorry, I am lost. AFAIU, your original motivation was: >> Would it be possible to also handle image data in the function or >> refactor the org-link-preview-file function in a way that the geometry >> handling is done in a helper function which can be reused by other >> handlers. Did it change? -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2025-01-18 15:03 ` Ihor Radchenko @ 2025-01-19 15:08 ` Björn Bidar 2025-01-21 19:22 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2025-01-19 15:08 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode [-- Attachment #1: Type: text/plain, Size: 1795 bytes --] Ihor Radchenko <yantar92@posteo.net> writes: > Björn Bidar <bjorn.bidar@thaodan.de> writes: > >>> IMHO, it would be best to pass image file name/raw image data to >>> `org-link-preview-image-data', not an image object and call >>> `org--create-inline-image' from inside `org-link-preview-image-data'. >>> That way, we can automatically obey Org customization wrt image >>> alignment, image width, and image max width. >> >> For that case using org-link-preview-file should be sufficient? > > Sorry, I am lost. > AFAIU, your original motivation was: > > >> Would it be possible to also handle image data in the function or > >> refactor the org-link-preview-file function in a way that the geometry > >> handling is done in a helper function which can be reused by other > >> handlers. > > Did it change? It didn't but if the handler which would the uses a raw (temporary) file it could have used org-link-preview-file, which essentially meant that the handler which uses org-link-preview file is a proxy for it. The thing that confused me, but I think I wasn't aware of not getting it yesterday was that org--create-inline-image creates the actual image object. I was thinking that the image object would have been created in the handler and then passed to the helper function. I think what also confused me that org--create-inline-image talks about files not image-data. Do I understand correctly that for image-data the handling of files in line 1035 is just skipped? Another that I just came to mind what is better for such a use case the use of a buffer or a variable to store the image data? Url (and eww) for example usually uses buffers. I updated my patch with the recommended changes and updated the docstring accordingly. [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: 0001-org-link-Split-link-preview-into-two-functions.patch --] [-- Type: text/x-patch, Size: 3506 bytes --] From ee0d30fac48d1f3ee86a653fe537badde5e3174d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Bidar?= <bjorn.bidar@thaodan.de> Date: Fri, 20 Dec 2024 01:00:46 +0200 Subject: [PATCH] org-link: Split link preview into two functions * lisp/ol.el (org-link-preview-file, org-link-preview-image-data): Split up the actual preview part into a separate function. The new preview function can be called by :preview handler to display the raw image according to the correct alignment and with for the link to be previewed. Passing the link can be skipped if alignment and with are given. --- lisp/ol.el | 57 ++++++++++++++++++++++++++++++++++++------------------ 1 file changed, 38 insertions(+), 19 deletions(-) diff --git a/lisp/ol.el b/lisp/ol.el index 032610bad..ebfe926a1 100644 --- a/lisp/ol.el +++ b/lisp/ol.el @@ -2177,27 +2177,46 @@ (defun org-link-preview-file (ov path link) ((string-match-p (image-file-name-regexp) file)) ((file-exists-p file))) (let* ((width (org-display-inline-image--width link)) - (align (org-image--align link)) - (image (org--create-inline-image file width))) - (when image ; Add image to overlay - ;; See bug#59902. We cannot rely - ;; on Emacs to update image if the file - ;; has changed. - (image-flush image) - (overlay-put ov 'display image) - (overlay-put ov 'face 'default) - (overlay-put ov 'keymap image-map) - (when align - (overlay-put - ov 'before-string - (propertize - " " 'face 'default - 'display - (pcase align - ("center" `(space :align-to (- center (0.5 . ,image)))) - ("right" `(space :align-to (- right ,image))))))) + (image-data (org--create-inline-image file width))) + (when image-data + (org-link-preview-image-data ov image-data link) t))))) +(defun org-link-preview-image-data (ov image-data &optional link align width) + "Display raw image data IMAGE-DATA in overlay OV for LINK. + +If not given ALIGN and WIDTH is derived from LINK. +If LINK was not passed ALIGN and WIDTH have to be given. + +An image object is created from IMAGE-DATA to be displayed in overlay. + +This intended to be used by functions which provide the :preview link property +of links such as in `org-link-preview-file'" + (if (or (and align width) + link) + (let* ((align (or align + (org-image--align link))) + (width (or width + (org-display-inline-image--width link))) + (image-object (org--create-inline-image image-data width))) + ;; See bug#59902. We cannot rely + ;; on Emacs to update image if the file + ;; has changed. + (image-flush image-object) + (overlay-put ov 'display image-object) + (overlay-put ov 'face 'default) + (overlay-put ov 'keymap image-map) + (when align + (overlay-put + ov 'before-string + (propertize + " " 'face 'default + 'display + (pcase align + ("center" `(space :align-to (- center (0.5 . ,image-data)))) + ("right" `(space :align-to (- right ,image-data)))))))) + (error "Either align and width or link have to be passed"))) + ;;;; "help" link type (defun org-link--open-help (path _) "Open a \"help\" type link. -- 2.45.2 ^ permalink raw reply related [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2025-01-19 15:08 ` Björn Bidar @ 2025-01-21 19:22 ` Ihor Radchenko 2025-01-21 20:45 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Ihor Radchenko @ 2025-01-21 19:22 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: > The thing that confused me, but I think I wasn't aware of not getting it > yesterday was that org--create-inline-image creates the actual image > object. I was thinking that the image object would have been created in the > handler and then passed to the helper function. Feel free to improve the docstring. I do agree that it may be confusing. > I think what also confused me that org--create-inline-image talks about > files not image-data. Do I understand correctly that for image-data the > handling of files in line 1035 is just skipped? May you please elaborate? I do not quite get your question (or maybe have something else on that line number). > Another that I just came to mind what is better for such a use case the > use of a buffer or a variable to store the image data? Url (and eww) for example > usually uses buffers. I do not think that there is much difference. Unless we have a huge number of images (in which case we may create performance problems by increasing the number of buffers - some Emacs operations scale with the number of buffers). > +(defun org-link-preview-image-data (ov image-data &optional link align width) > + "Display raw image data IMAGE-DATA in overlay OV for LINK. > + > +If not given ALIGN and WIDTH is derived from LINK. If ALIGN and/or WIDTH are not given, they are derived from LINK object (ast node). > +If LINK was not passed ALIGN and WIDTH have to be given. If LINK is nil, ... Also, we need to explain the possible values of ALIGN and WIDTH. Maybe even provide some defaults (maybe even via cl-defun) -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2025-01-21 19:22 ` Ihor Radchenko @ 2025-01-21 20:45 ` Björn Bidar 0 siblings, 0 replies; 28+ messages in thread From: Björn Bidar @ 2025-01-21 20:45 UTC (permalink / raw) To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode [-- Attachment #1: Type: text/plain, Size: 2126 bytes --] Ihor Radchenko <yantar92@posteo.net> writes: > Björn Bidar <bjorn.bidar@thaodan.de> writes: > >> The thing that confused me, but I think I wasn't aware of not getting it >> yesterday was that org--create-inline-image creates the actual image >> object. I was thinking that the image object would have been created in the >> handler and then passed to the helper function. > > Feel free to improve the docstring. > I do agree that it may be confusing. create-image uses the term file-or-data instead of file would that be better? >> I think what also confused me that org--create-inline-image talks about >> files not image-data. Do I understand correctly that for image-data the >> handling of files in line 1035 is just skipped? > > May you please elaborate? I do not quite get your question (or maybe > have something else on that line number). I'm talking about the pcase, if the image is data the pcase largely doesn't apply. >> Another that I just came to mind what is better for such a use case the >> use of a buffer or a variable to store the image data? Url (and eww) for example >> usually uses buffers. > > I do not think that there is much difference. Unless we have a huge number of images (in which case we may create performance problems by > increasing the number of buffers - some Emacs operations scale with the > number of buffers). > ok >> +(defun org-link-preview-image-data (ov image-data &optional link align width) >> + "Display raw image data IMAGE-DATA in overlay OV for LINK. >> + >> +If not given ALIGN and WIDTH is derived from LINK. > > If ALIGN and/or WIDTH are not given, they are derived from LINK object > (ast node). > >> +If LINK was not passed ALIGN and WIDTH have to be given. > > If LINK is nil, ... > I fixed the docstrings and move the require image to the helper function. > Also, we need to explain the possible values of ALIGN and WIDTH. > Maybe even provide some defaults (maybe even via cl-defun) Would it make sense to provide defaults for ALIGN and WIDTH when they have to be supplied or be derived from link? [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: 0001-org-link-Split-link-preview-into-two-functions.patch --] [-- Type: text/x-patch, Size: 3568 bytes --] From 51d94bf20b043be635af3719464dccd0cc589f93 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Bidar?= <bjorn.bidar@thaodan.de> Date: Fri, 20 Dec 2024 01:00:46 +0200 Subject: [PATCH] org-link: Split link preview into two functions * lisp/ol.el (org-link-preview-file, org-link-preview-image-data): Split up the actual preview part into a separate function. The new preview function can be called by :preview handler to display the raw image according to the correct alignment and with for the link to be previewed. Passing the link can be skipped if alignment and with are given. --- lisp/ol.el | 44 ++++++++++++++++++++++++++++++-------------- 1 file changed, 30 insertions(+), 14 deletions(-) diff --git a/lisp/ol.el b/lisp/ol.el index 43fac7433..0429e257c 100644 --- a/lisp/ol.el +++ b/lisp/ol.el @@ -2178,23 +2178,39 @@ (defun org-link-preview-file (ov path link) This is intended to be used as the `:preview' link property of file links, see `org-link-parameters'." - (when (display-graphic-p) - (require 'image) (when-let* ((file-full (expand-file-name path)) (file (substitute-in-file-name file-full)) ((string-match-p (image-file-name-regexp) file)) ((file-exists-p file))) - (let* ((width (org-display-inline-image--width link)) - (align (org-image--align link)) - (image (org--create-inline-image file width))) - (when image ; Add image to overlay - ;; See bug#59902. We cannot rely + (org-link-preview-image-data ov file link))) + +(defun org-link-preview-image-data (ov image-data &optional link align width) + "Display raw image data IMAGE-DATA in overlay OV for LINK. + +If ALIGN and/or WIDTH are not given, they are derived from LINK object +\(ast node\). +If LINK is nil, ALIGN and WIDTH have to be given. + +An image object is created from IMAGE-DATA to be displayed in overlay. + +This intended to be used by functions which provide the :preview link property +of links such as in `org-link-preview-file'" + (if (or (and align width) + link) + (when (display-graphic-p) + (require 'image) + (when-let* ((align (or align + (org-image--align link))) + (width (or width + (org-display-inline-image--width link))) + (image-object (org--create-inline-image image-data width))) + ;; See bug#59902. We cannot rely ;; on Emacs to update image if the file ;; has changed. - (image-flush image) - (overlay-put ov 'display image) - (overlay-put ov 'face 'default) - (overlay-put ov 'keymap image-map) + (image-flush image-object) + (overlay-put ov 'display image-object) + (overlay-put ov 'face 'default) + (overlay-put ov 'keymap image-map) (when align (overlay-put ov 'before-string @@ -2202,9 +2218,9 @@ (defun org-link-preview-file (ov path link) " " 'face 'default 'display (pcase align - ("center" `(space :align-to (- center (0.5 . ,image)))) - ("right" `(space :align-to (- right ,image))))))) - t))))) + ("center" `(space :align-to (- center (0.5 . ,image-data)))) + ("right" `(space :align-to (- right ,image-data)))))))) + (error "Either align and width or link have to be passed")))) ;;;; "help" link type (defun org-link--open-help (path _) -- 2.45.2 ^ permalink raw reply related [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-17 3:42 ` Karthik Chikmagalur 2024-12-17 17:40 ` Ihor Radchenko @ 2024-12-18 6:21 ` stardiviner 2024-12-18 6:33 ` Karthik Chikmagalur 1 sibling, 1 reply; 28+ messages in thread From: stardiviner @ 2024-12-18 6:21 UTC (permalink / raw) To: Karthik Chikmagalur; +Cc: Ihor Radchenko, Björn Bidar, emacs-orgmode [-- Attachment #1: Type: text/plain, Size: 1643 bytes --] I don't think so, my package org-link-beautify ported to the new :preview mechanism. The file preview not always image. Could be text, or icon etc. So pass in image object is not a good idea. It will limit preview functionality extensibility. [stardiviner] <Hack this world!> GPG key ID: 47C32433 IRC(freeenode): stardiviner Twitter: @numbchild Key fingerprint = 9BAA 92BC CDDD B9EF 3B36 CB99 B8C4 B8E5 47C3 2433 Blog: http://stardiviner.github.io/ On Tue, Dec 17, 2024 at 11:43 AM Karthik Chikmagalur < karthikchikmagalur@gmail.com> wrote: > >> Would it be possible to also handle image data in the function or > >> refactor the org-link-preview-file function in a way that the geometry > >> handling is done in a helper function which can be reused by other > >> handlers. > > > > There is such function: `org-display-inline-image--width'. > > We may consider exposing it as public function. > > This will not be enough, we will also have to expose `org-image--align' > and the alignment code: > > (when align > (overlay-put > ov 'before-string > (propertize > " " 'face 'default > 'display > (pcase align > ("center" `(space :align-to (- center (0.5 . ,image)))) > ("right" `(space :align-to (- right ,image))))))) > > I don't think we can expect third party packages to figure out and > reimplement Org's image alignment logic. > > Considering this, it might be better to just split > `org-link-preview-file' into two public functions, where the "inside" > function accepts an image instead of a file. > > Karthik > > [-- Attachment #2: Type: text/html, Size: 2425 bytes --] ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-18 6:21 ` stardiviner @ 2024-12-18 6:33 ` Karthik Chikmagalur 2024-12-19 23:26 ` Björn Bidar 0 siblings, 1 reply; 28+ messages in thread From: Karthik Chikmagalur @ 2024-12-18 6:33 UTC (permalink / raw) To: stardiviner; +Cc: Ihor Radchenko, Björn Bidar, emacs-orgmode > I don't think so, my package org-link-beautify ported to the new > :preview mechanism. The file preview not always image. Could be text, or > icon etc. So pass in image object is not a good idea. It will limit > preview functionality extensibility. The API will not be changed. Org will provide a new `org-link-preview-image' function that you can use to preview links using image data. You'll have to write the adapter to register this as the :preview handler for a link type yourself. Karthik ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-18 6:33 ` Karthik Chikmagalur @ 2024-12-19 23:26 ` Björn Bidar 2024-12-21 12:09 ` Ihor Radchenko 0 siblings, 1 reply; 28+ messages in thread From: Björn Bidar @ 2024-12-19 23:26 UTC (permalink / raw) To: Karthik Chikmagalur; +Cc: stardiviner, Ihor Radchenko, emacs-orgmode Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes: >> I don't think so, my package org-link-beautify ported to the new >> :preview mechanism. The file preview not always image. Could be text, or >> icon etc. So pass in image object is not a good idea. It will limit >> preview functionality extensibility. > > The API will not be changed. Org will provide a new > `org-link-preview-image' function that you can use to preview links > using image data. You'll have to write the adapter to register this as > the :preview handler for a link type yourself. > > Karthik I'm also wondering how much could there be shared if the thing to be displayed on the overlay isn't an image. The org-image--align function talks about images but ultimately doesn't do anything specific to image. I think the alignment the only part which is generic. ^ permalink raw reply [flat|nested] 28+ messages in thread
* Re: Link preview generation with new link preview property 2024-12-19 23:26 ` Björn Bidar @ 2024-12-21 12:09 ` Ihor Radchenko 0 siblings, 0 replies; 28+ messages in thread From: Ihor Radchenko @ 2024-12-21 12:09 UTC (permalink / raw) To: Björn Bidar; +Cc: Karthik Chikmagalur, stardiviner, emacs-orgmode Björn Bidar <bjorn.bidar@thaodan.de> writes: > I'm also wondering how much could there be shared if the thing to be > displayed on the overlay isn't an image. > > The org-image--align function talks about images but ultimately > doesn't do anything specific to image. > I think the alignment the only part which is generic. If we provide a generic alignment, yes. We may or may not. Or we may choose some other way to control non-image alignment. I see no reason to generalize things needlessly. We can always do it is we wish to. We cannot go back as easily if we commit prematurely. -- Ihor Radchenko // yantar92, Org mode maintainer, Learn more about Org mode at <https://orgmode.org/>. Support Org development at <https://liberapay.com/org-mode>, or support my work at <https://liberapay.com/yantar92> ^ permalink raw reply [flat|nested] 28+ messages in thread
* Link preview generation with new link preview property @ 2024-12-08 19:18 Björn Bidar 0 siblings, 0 replies; 28+ messages in thread From: Björn Bidar @ 2024-12-08 19:18 UTC (permalink / raw) To: emacs-orgmode Hello, I have a few question regarding the new link preview handler property added recently. I ported the org-remoteimg package to it which was quite easy, much cleaner with the new property. The PR do port the package to this new handler property: https://github.com/gaoDean/org-remoteimg/pull/4 However it left me with a few questions: - Who is supposed to take care of the scaling/width of the preview image, the handler or the caller of the handler? - When calling the link preview function for a description with prefix argument 1 I noticed that it doesn't get the contents of the description. Why is that? In this instance the link looked like this: [[https://stable.melpa.org/#/rpm-spec-mode][file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg]] Thanks have a great day, Björn ^ permalink raw reply [flat|nested] 28+ messages in thread
end of thread, other threads:[~2025-01-21 20:46 UTC | newest] Thread overview: 28+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- [not found] <6755f138.0c0a0220.40388.51fbSMTPIN_ADDED_BROKEN@mx.google.com> 2024-12-13 5:49 ` Link preview generation with new link preview property Karthik Chikmagalur 2024-12-14 0:03 ` Björn Bidar 2024-12-14 7:04 ` Ihor Radchenko 2024-12-17 2:46 ` Björn Bidar 2024-12-17 17:39 ` Ihor Radchenko 2024-12-19 21:55 ` Björn Bidar 2024-12-21 12:03 ` Ihor Radchenko 2024-12-17 3:42 ` Karthik Chikmagalur 2024-12-17 17:40 ` Ihor Radchenko 2024-12-19 23:20 ` Björn Bidar 2024-12-20 0:45 ` Karthik Chikmagalur 2024-12-21 12:05 ` Ihor Radchenko 2024-12-23 20:41 ` Björn Bidar [not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com> 2024-12-26 18:46 ` Karthik Chikmagalur 2024-12-29 15:44 ` Björn Bidar 2024-12-30 17:05 ` Ihor Radchenko 2025-01-04 2:01 ` Björn Bidar 2025-01-04 14:11 ` Ihor Radchenko 2025-01-18 14:44 ` Björn Bidar 2025-01-18 15:03 ` Ihor Radchenko 2025-01-19 15:08 ` Björn Bidar 2025-01-21 19:22 ` Ihor Radchenko 2025-01-21 20:45 ` Björn Bidar 2024-12-18 6:21 ` stardiviner 2024-12-18 6:33 ` Karthik Chikmagalur 2024-12-19 23:26 ` Björn Bidar 2024-12-21 12:09 ` Ihor Radchenko 2024-12-08 19:18 Björn Bidar
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs/org-mode.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).