emacs-orgmode@gnu.org archives
 help / color / mirror / code / Atom feed
* 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

* 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-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  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  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  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-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-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-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-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-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-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-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

* 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

* 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

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).