unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* Improving Emacs' iCalendar support
@ 2024-10-18  9:01 Richard Lawrence
  2024-10-18  9:24 ` Eli Zaretskii
                   ` (7 more replies)
  0 siblings, 8 replies; 64+ messages in thread
From: Richard Lawrence @ 2024-10-18  9:01 UTC (permalink / raw)
  To: emacs-devel

Dear emacs-devel,

Hello! I've been a happy Emacs user for almost twenty years now(!), but
this is my first time subscribing to this list, so please help me follow
the local conventions.

I would like to start a discussion about improving Emacs' iCalendar
support, beyond what is already available in icalendar.el. I personally
would like to see Emacs gain a more full-fledged RFC5545 implementation
that is primarily designed as a library for other applications to use.

This is an itch that's been bugging me for a while, and so for the past
couple of weeks I've been working on scratching it, and I now have a
reasonable chunk of work to share: I've drafted a new implementation of
the iCalendar grammar, and a major mode which uses this grammar to
provide syntax highlighting. I wrote up what I've done and why here:

https://recursewithless.net/emacs/icalendar-parser-and-mode.org

That's a literate Org mode file containing the code and my commentary.
If you just want to read the code itself, see:

https://recursewithless.net/emacs/icalendar/icalendar-parser.el
https://recursewithless.net/emacs/icalendar/icalendar-mode.el

I could release this work as a package, but as I describe in more
detail in the write-up, I think there's a good case that an improved
iCalendar library belongs in Emacs' core. There are currently at least
*three* partial iCalendar implementations in Emacs (icalendar.el,
gnus-icalendar.el, and ox-icalendar.el), which are each focused on a
particular major mode (diary, Gnus, and Org). I think it would be good
to consolidate this work in one place and generalize it so that all
three of these applications, as well as third party packages, can
benefit.

So, some questions for the list:

1) Is there interest in getting this code, and/or a future version of
such a library, into Emacs?

And if so, 
2) Would anyone here be willing to mentor me/collaborate with me on it?
3) What should the library's API look like? What would be most useful?

Many thanks for your thoughts and feedback!

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
@ 2024-10-18  9:24 ` Eli Zaretskii
  2024-10-19  8:22   ` Richard Lawrence
  2024-10-18 12:58 ` Sebastián Monía
                   ` (6 subsequent siblings)
  7 siblings, 1 reply; 64+ messages in thread
From: Eli Zaretskii @ 2024-10-18  9:24 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

> From: Richard Lawrence <rwl@recursewithless.net>
> Date: Fri, 18 Oct 2024 11:01:10 +0200
> 
> So, some questions for the list:
> 
> 1) Is there interest in getting this code, and/or a future version of
> such a library, into Emacs?

We are definitely interested in developing icalendar.el to cover the
missing functionalities and support the recent standards, guidelines
and accepted practices.

> And if so, 
> 2) Would anyone here be willing to mentor me/collaborate with me on it?

I hope someone will step forward, but the very least we can promise is
that any questions you ask here will be answered.

> 3) What should the library's API look like? What would be most useful?

I think this is up to you as the expert.

Thanks!



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
  2024-10-18  9:24 ` Eli Zaretskii
@ 2024-10-18 12:58 ` Sebastián Monía
  2024-10-19  8:28   ` Richard Lawrence
  2024-10-19  5:44 ` Adam Porter
                   ` (5 subsequent siblings)
  7 siblings, 1 reply; 64+ messages in thread
From: Sebastián Monía @ 2024-10-18 12:58 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel


Hello Richard!

Richard Lawrence <rwl@recursewithless.net> writes:
> Dear emacs-devel,
>
> This is an itch that's been bugging me for a while, and so for the past
> couple of weeks I've been working on scratching it, and I now have a
> reasonable chunk of work to share: I've drafted a new implementation of
> the iCalendar grammar, and a major mode which uses this grammar to
> provide syntax highlighting. I wrote up what I've done and why here:
>
> https://recursewithless.net/emacs/icalendar-parser-and-mode.org
>
> That's a literate Org mode file containing the code and my commentary.
> If you just want to read the code itself, see:
>
> https://recursewithless.net/emacs/icalendar/icalendar-parser.el
> https://recursewithless.net/emacs/icalendar/icalendar-mode.el

Will take a look, thank you for sharing!

> I could release this work as a package, but as I describe in more
> detail in the write-up, I think there's a good case that an improved
> iCalendar library belongs in Emacs' core. There are currently at least
> *three* partial iCalendar implementations in Emacs (icalendar.el,
> gnus-icalendar.el, and ox-icalendar.el), which are each focused on a
> particular major mode (diary, Gnus, and Org). I think it would be good
> to consolidate this work in one place and generalize it so that all
> three of these applications, as well as third party packages, can
> benefit.

I am only familiar with icalendar.el, which I consumed in this CalDAV
sync package: https://git.sr.ht/~sebasmonia/cdsync.el
I haven't used it much lately, but while testing it I found a few cases
not supported by icalendar.el At some point I wanted to try my hand at
fixing some bugs reported in the ical -> diary conversion.

> So, some questions for the list:
> 2) Would anyone here be willing to mentor me/collaborate with me on
> it?

I would be happy to help.

> 3) What should the library's API look like? What would be most useful?

Like Eli said in another reply, you are probably the best person to
define this now - until the library is merged, the API can change, so
don't stress too much over that _yet_ :)

Regards,
Seb

-- 
Sebastián Monía
https://site.sebasmonia.com/



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
  2024-10-18  9:24 ` Eli Zaretskii
  2024-10-18 12:58 ` Sebastián Monía
@ 2024-10-19  5:44 ` Adam Porter
  2024-10-19  8:39   ` Richard Lawrence
  2024-10-21  6:10 ` Björn Bidar
                   ` (4 subsequent siblings)
  7 siblings, 1 reply; 64+ messages in thread
From: Adam Porter @ 2024-10-19  5:44 UTC (permalink / raw)
  To: rwl; +Cc: emacs-devel

Hi Richard,

I don't have much to add to what's been said, but my first thought is 
that a robust iCal library would probably be most useful for importing 
and exporting between the iCal format, obviously.  So I'd suggest that 
its API should help with transforming iCal data into other formats, 
probably by converting it into a simple Lisp data structure that other 
libraries could work with.  And then, it should also provide a function 
to transform that data structure back into an iCal file.

Also, it would be good if it were designed to be extensible in case the 
standards receive updates, or in case vendor-specific functionality is 
needed by users.

So I'd suggest looking at the existing Emacs/Org applications that use 
iCal, and designing your API so that such applications would find it 
easy to use (not that it should directly imitate what already exists, 
unless such APIs are already ideal).

Finally, I'd suggest that you consider using structs as the primary 
internal data structure, because they provide setter and accessor 
functions, which are helpful to developers (e.g. they help catch some 
mistakes at compilation time).  If you do, I've found it helpful to 
define an "etc" slot in various structs to which an alist or plist can 
be attached, which provides the ability for the structs to carry 
additional data that wasn't foreseen during its design.

--Adam



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:24 ` Eli Zaretskii
@ 2024-10-19  8:22   ` Richard Lawrence
  2024-10-19 10:11     ` Eli Zaretskii
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-19  8:22 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: emacs-devel

Hi Eli,

Eli Zaretskii <eliz@gnu.org> writes:

>> 1) Is there interest in getting this code, and/or a future version of
>> such a library, into Emacs?
>
> We are definitely interested in developing icalendar.el to cover the
> missing functionalities and support the recent standards, guidelines
> and accepted practices.

Great!

>> And if so, 
>> 2) Would anyone here be willing to mentor me/collaborate with me on it?
>
> I hope someone will step forward, but the very least we can promise is
> that any questions you ask here will be answered.

Will do. I'm glad a few other people have already expressed interest!

Another question: what is the best place for this work to happen? In a
separate repo for now? In a feature branch in the Emacs repo? Should I
send what I've already got as a patch to this list?

I believe I signed FSF paperwork about ten years ago but am no longer
100% sure that I completed the process (there was some uncertainty
because of my employer back then, UC Berkeley). Does someone here know
how I can check my status?

Thanks!
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18 12:58 ` Sebastián Monía
@ 2024-10-19  8:28   ` Richard Lawrence
  0 siblings, 0 replies; 64+ messages in thread
From: Richard Lawrence @ 2024-10-19  8:28 UTC (permalink / raw)
  To: Sebastián Monía; +Cc: emacs-devel

Hi Sebastián,

Sebastián Monía <sebastian@sebasmonia.com> writes:

> I am only familiar with icalendar.el, which I consumed in this CalDAV
> sync package: https://git.sr.ht/~sebasmonia/cdsync.el

This looks great! A working CalDAV implementation would be a very useful
addition to the library I'm envisioning.

> I would be happy to help.

Wonderful! Since you're on sr.ht I posted the work I've done so far in a
repository there:

https://git.sr.ht/~wyleyr/icalendar-el

Perhaps you could take a look and let me know what you'd be interested
in working on. 

Thanks!
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-19  5:44 ` Adam Porter
@ 2024-10-19  8:39   ` Richard Lawrence
  2024-10-20  3:09     ` Adam Porter
  2024-10-22 18:40     ` Ihor Radchenko
  0 siblings, 2 replies; 64+ messages in thread
From: Richard Lawrence @ 2024-10-19  8:39 UTC (permalink / raw)
  To: Adam Porter; +Cc: emacs-devel

Hi Adam,

Adam Porter <adam@alphapapa.net> writes:

> I don't have much to add to what's been said, but my first thought is 
> that a robust iCal library would probably be most useful for importing 
> and exporting between the iCal format, obviously.  So I'd suggest that 
> its API should help with transforming iCal data into other formats, 
> probably by converting it into a simple Lisp data structure that other 
> libraries could work with.  And then, it should also provide a function 
> to transform that data structure back into an iCal file.
>
> Also, it would be good if it were designed to be extensible in case the 
> standards receive updates, or in case vendor-specific functionality is 
> needed by users.

Yep, that's exactly the plan! Thanks for confirming that this is a good
idea.

> So I'd suggest looking at the existing Emacs/Org applications that use 
> iCal, and designing your API so that such applications would find it 
> easy to use (not that it should directly imitate what already exists, 
> unless such APIs are already ideal).

Yes, I was hoping especially to hear from Org/Gnus/diary developers if
they have any thoughts about what would make such a library easy (or
-ier) for them to use. Perhaps I should ask on their respective
lists...does Gnus have a separate mailing list? I will also grep through
the code to see if anything else in Emacs is using the icalendar--*
internal functions.

> Finally, I'd suggest that you consider using structs as the primary 
> internal data structure, because they provide setter and accessor 
> functions, which are helpful to developers (e.g. they help catch some 
> mistakes at compilation time).  If you do, I've found it helpful to 
> define an "etc" slot in various structs to which an alist or plist can 
> be attached, which provides the ability for the structs to carry 
> additional data that wasn't foreseen during its design.

Thanks, that's useful advice. I've been toying with the idea of using
EIEIO classes to represent at least the "component"-level data
structures (events, to-dos, journals, timezones, whole calendars), which
if I understand correctly use structs under the hood. But I don't really
have any experience with EIEIO and I'm not sure if the added complexity
of the object system will buy much over using plain structs. Do you have
any thoughts about this?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-19  8:22   ` Richard Lawrence
@ 2024-10-19 10:11     ` Eli Zaretskii
  2024-10-20  5:08       ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Eli Zaretskii @ 2024-10-19 10:11 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

> From: Richard Lawrence <rwl@recursewithless.net>
> Cc: emacs-devel@gnu.org
> Date: Sat, 19 Oct 2024 10:22:13 +0200
> 
> I believe I signed FSF paperwork about ten years ago but am no longer
> 100% sure that I completed the process (there was some uncertainty
> because of my employer back then, UC Berkeley). Does someone here know
> how I can check my status?

I don't see any assignment from you on file, so I think you will need
to do the paperwork again, unless you did it under some different name
and/or email address.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-19  8:39   ` Richard Lawrence
@ 2024-10-20  3:09     ` Adam Porter
  2024-10-22 18:40     ` Ihor Radchenko
  1 sibling, 0 replies; 64+ messages in thread
From: Adam Porter @ 2024-10-20  3:09 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Hi Richard,

On 10/19/24 03:39, Richard Lawrence wrote:

> Thanks, that's useful advice. I've been toying with the idea of using
> EIEIO classes to represent at least the "component"-level data
> structures (events, to-dos, journals, timezones, whole calendars), which
> if I understand correctly use structs under the hood. But I don't really
> have any experience with EIEIO and I'm not sure if the added complexity
> of the object system will buy much over using plain structs. Do you have
> any thoughts about this?

I'd recommend sticking with CL-STRUCTs unless and until you find a real 
need for EIEIO's additional functionality.

My point of experience is having used EIEIO for my work on the 
now-obsolete matrix-client.el package: It worked fine, but I found that 
I never used more than what CL-STRUCT's API offers; so in the successor, 
Ement.el, I've just used structs, and it's worked out very well.

If you're still not sure which to use, you might talk with Jonas 
Bernoulli (aka tarsius, the Magit maintainer), as he's written more 
EIEIO-related code than I have, and his perspective could be valuable.

--Adam



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-19 10:11     ` Eli Zaretskii
@ 2024-10-20  5:08       ` Richard Lawrence
  2024-10-20  5:21         ` Eli Zaretskii
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-20  5:08 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: emacs-devel

Eli Zaretskii <eliz@gnu.org> writes:

>> From: Richard Lawrence <rwl@recursewithless.net>
>> Cc: emacs-devel@gnu.org
>> Date: Sat, 19 Oct 2024 10:22:13 +0200
>> 
>> I believe I signed FSF paperwork about ten years ago but am no longer
>> 100% sure that I completed the process (there was some uncertainty
>> because of my employer back then, UC Berkeley). Does someone here know
>> how I can check my status?
>
> I don't see any assignment from you on file, so I think you will need
> to do the paperwork again, unless you did it under some different name
> and/or email address.

It would have been the same name but a different email address (probably
wyley.r@gmail.com, possibly richard.lawrence@berkeley.edu). Also, FWIW,
I did the paperwork through the Org Mode maintainers back then, so if
that's a separate list, you could check there.

In any case, if you send me the paperwork, I'm happy to do it again.

Best,
Richard




^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-20  5:08       ` Richard Lawrence
@ 2024-10-20  5:21         ` Eli Zaretskii
  0 siblings, 0 replies; 64+ messages in thread
From: Eli Zaretskii @ 2024-10-20  5:21 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

> From: Richard Lawrence <rwl@recursewithless.net>
> Cc: emacs-devel@gnu.org
> Date: Sun, 20 Oct 2024 07:08:57 +0200
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> >> From: Richard Lawrence <rwl@recursewithless.net>
> >> Cc: emacs-devel@gnu.org
> >> Date: Sat, 19 Oct 2024 10:22:13 +0200
> >> 
> >> I believe I signed FSF paperwork about ten years ago but am no longer
> >> 100% sure that I completed the process (there was some uncertainty
> >> because of my employer back then, UC Berkeley). Does someone here know
> >> how I can check my status?
> >
> > I don't see any assignment from you on file, so I think you will need
> > to do the paperwork again, unless you did it under some different name
> > and/or email address.
> 
> It would have been the same name but a different email address (probably
> wyley.r@gmail.com, possibly richard.lawrence@berkeley.edu). Also, FWIW,
> I did the paperwork through the Org Mode maintainers back then, so if
> that's a separate list, you could check there.

I don't see anything like that.  I think Org assignments are handled
the same as Emacs assignments and should be recorded on the same file.

> In any case, if you send me the paperwork, I'm happy to do it again.

Form sent off-list.

Thanks.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
                   ` (2 preceding siblings ...)
  2024-10-19  5:44 ` Adam Porter
@ 2024-10-21  6:10 ` Björn Bidar
  2024-10-21  6:22 ` Visuwesh
                   ` (3 subsequent siblings)
  7 siblings, 0 replies; 64+ messages in thread
From: Björn Bidar @ 2024-10-21  6:10 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel


Good Morning from Finland,

Richard Lawrence <rwl@recursewithless.net> writes:

> Dear emacs-devel,
>
> Hello! I've been a happy Emacs user for almost twenty years now(!), but
> this is my first time subscribing to this list, so please help me follow
> the local conventions.
>
> I would like to start a discussion about improving Emacs' iCalendar
> support, beyond what is already available in icalendar.el. I personally
> would like to see Emacs gain a more full-fledged RFC5545 implementation
> that is primarily designed as a library for other applications to use.
>
> This is an itch that's been bugging me for a while, and so for the past
> couple of weeks I've been working on scratching it, and I now have a
> reasonable chunk of work to share: I've drafted a new implementation of
> the iCalendar grammar, and a major mode which uses this grammar to
> provide syntax highlighting. I wrote up what I've done and why here:
>
> https://recursewithless.net/emacs/icalendar-parser-and-mode.org
>
> That's a literate Org mode file containing the code and my commentary.
> If you just want to read the code itself, see:
>
> https://recursewithless.net/emacs/icalendar/icalendar-parser.el
> https://recursewithless.net/emacs/icalendar/icalendar-mode.el
>
> I could release this work as a package, but as I describe in more
> detail in the write-up, I think there's a good case that an improved
> iCalendar library belongs in Emacs' core. There are currently at least
> *three* partial iCalendar implementations in Emacs (icalendar.el,
> gnus-icalendar.el, and ox-icalendar.el), which are each focused on a
> particular major mode (diary, Gnus, and Org). I think it would be good
> to consolidate this work in one place and generalize it so that all
> three of these applications, as well as third party packages, can
> benefit.

From my dealings will the latter two I noticed that currently these
separatism make it harder to support all features and maybe in some way
easier.

For example Gnus does deal with the responding to these invitations
while org focuses on the exporting. Not all features are support with
any of these making some things such as recurring events quite dangerous
to deal with if you interact with others.

It would be great to have these features supported better. In think
some limitations in for example org-mode come also into play here as
last time I looked it can't deal with timezones.

Some parts of the current approach limit the amount of features or make
it harder as all of these move on.
For example Gnus uses org-capture to convert an icalendar
event to org instead of some form of native API to synchronize the
invite with-org.

Any advancement in regards of icalendar hopefully also helps the
other related formats such as vtodo and vcard.

Maybe also cc the org-mode mailing-list.

Another consumer of such efforts would be also (indirectly) org-caldav.
When it comes to the -dav part of this than also bbdb.

Have a good day,

Björn





^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
                   ` (3 preceding siblings ...)
  2024-10-21  6:10 ` Björn Bidar
@ 2024-10-21  6:22 ` Visuwesh
  2024-10-23  9:15   ` Richard Lawrence
       [not found] ` <87wmi29eaf.fsf@>
                   ` (2 subsequent siblings)
  7 siblings, 1 reply; 64+ messages in thread
From: Visuwesh @ 2024-10-21  6:22 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

[வெள்ளி அக்டோபர் 18, 2024] Richard Lawrence wrote:

> Dear emacs-devel,
>
> Hello! I've been a happy Emacs user for almost twenty years now(!), but
> this is my first time subscribing to this list, so please help me follow
> the local conventions.
>
> I would like to start a discussion about improving Emacs' iCalendar
> support, beyond what is already available in icalendar.el. I personally
> would like to see Emacs gain a more full-fledged RFC5545 implementation
> that is primarily designed as a library for other applications to use.
>
> This is an itch that's been bugging me for a while, and so for the past
> couple of weeks I've been working on scratching it, and I now have a
> reasonable chunk of work to share: I've drafted a new implementation of
> the iCalendar grammar, and a major mode which uses this grammar to
> provide syntax highlighting. I wrote up what I've done and why here:
>
> https://recursewithless.net/emacs/icalendar-parser-and-mode.org
>
> That's a literate Org mode file containing the code and my commentary.
> If you just want to read the code itself, see:
>
> https://recursewithless.net/emacs/icalendar/icalendar-parser.el
> https://recursewithless.net/emacs/icalendar/icalendar-mode.el
>
> I could release this work as a package, but as I describe in more
> detail in the write-up, I think there's a good case that an improved
> iCalendar library belongs in Emacs' core. There are currently at least
> *three* partial iCalendar implementations in Emacs (icalendar.el,
> gnus-icalendar.el, and ox-icalendar.el), which are each focused on a
> particular major mode (diary, Gnus, and Org). I think it would be good
> to consolidate this work in one place and generalize it so that all
> three of these applications, as well as third party packages, can
> benefit.
>
> So, some questions for the list:
>
> 1) Is there interest in getting this code, and/or a future version of
> such a library, into Emacs?

I don't use much of the icalendar stuff except this one function that I
use to extract holidays from govt. supplied ical file:

    (defun vz/get-indian-holidays ()
      "Parse the icalendar file provided by the Indian government.
    This returns a list that can be used in calendar's holiday."
      (unless (file-exists-p (expand-file-name "~/lib/indianical/"))
        (make-directory (expand-file-name "~/lib/indianical/") t))
      (let* ((year (decoded-time-year (decode-time)))
             (file (expand-file-name (format "~/lib/indianical/%d" year))))
        (unless (file-exists-p file)
          (url-copy-file
           (format "http://www.india.gov.in/calendar/%d/export.ics" year)
           file))
        (with-temp-buffer
          (require 'icalendar)
          (insert-file-contents file)
          ;; (set-buffer-file-coding-system 'unix)
          (goto-char (point-min))
          (seq-keep
           (lambda (x)
             (when-let* ((description (icalendar--get-event-property x 'DESCRIPTION))
                         ((seq-find (lambda (h) (let (case-fold-search)
                                                    (string-match-p h description)))
                                      vz/indian-holidays)))
               (let ((time (icalendar--decode-isodatetime (icalendar--get-event-property x 'DTSTART))))
                 (list 'holiday-fixed (decoded-time-month time) (decoded-time-day time)
                       (string-trim-right description " +([GR])")))))
           (icalendar--all-events (icalendar--read-element nil nil))))))

It has been at least a couple years since I wrote this function so I
don't remember the hurdles I faced when I wrote it very well but it
perplexed me that there were no "public" functions that were geared
towards parsing an ical file.  In retrospect, it would have been less
confusing if these functions were "public" functions.  AFAIR, and this
very well might not be true, the structure returned
icalendar--read-element is not really documented anywhere which further
added to the confusion.

That said, this function has been rock solid ever since I wrote it.
Going by the ical files I have, it is working just fine since 2021.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-19  8:39   ` Richard Lawrence
  2024-10-20  3:09     ` Adam Porter
@ 2024-10-22 18:40     ` Ihor Radchenko
  2024-10-23  7:29       ` Björn Bidar
                         ` (2 more replies)
  1 sibling, 3 replies; 64+ messages in thread
From: Ihor Radchenko @ 2024-10-22 18:40 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: Adam Porter, emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

>> So I'd suggest looking at the existing Emacs/Org applications that use 
>> iCal, and designing your API so that such applications would find it 
>> easy to use (not that it should directly imitate what already exists, 
>> unless such APIs are already ideal).

Some kind of icalendar parser could be useful.

In Org mode, we currently do icalendar export by hand-writing iCalendar
entries as strings and need to be careful about things like line endings
and special symbols.

What could be done instead is some kind of Elisp API similar to
`xml-parse-region' and `xml-print', so that things like escaping
symbols, exact literals, newlines, etc are handled behind the scenes, and
we could instead just define an AST and "print" it into a valid
iCalendar file.

So, my suggestion would be something akin xml.el and maybe (optionally)
https://github.com/ndwarshuis/org-ml - to manipulate the AST.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-22 18:40     ` Ihor Radchenko
@ 2024-10-23  7:29       ` Björn Bidar
       [not found]       ` <87plnr6zvk.fsf@>
  2024-10-23  9:01       ` Richard Lawrence
  2 siblings, 0 replies; 64+ messages in thread
From: Björn Bidar @ 2024-10-23  7:29 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: Richard Lawrence, Adam Porter, emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> What could be done instead is some kind of Elisp API similar to
> `xml-parse-region' and `xml-print', so that things like escaping
> symbols, exact literals, newlines, etc are handled behind the scenes, and
> we could instead just define an AST and "print" it into a valid
> iCalendar file.

Is the VCard and Vtodo file format similar enough to icalendar in the base form
that for these base line handling of these formats could be done
together for these?



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
       [not found]       ` <87plnr6zvk.fsf@>
@ 2024-10-23  8:09         ` Ihor Radchenko
  2024-10-23  9:05         ` Richard Lawrence
  1 sibling, 0 replies; 64+ messages in thread
From: Ihor Radchenko @ 2024-10-23  8:09 UTC (permalink / raw)
  To: Björn Bidar; +Cc: Richard Lawrence, Adam Porter, emacs-devel

Björn Bidar <bjorn.bidar@thaodan.de> writes:

> Is the VCard and Vtodo file format similar enough to icalendar in the base form
> that for these base line handling of these formats could be done
> together for these?

Not sure, but quick googling shows that icalendar is the successor of
vcard: https://stackoverflow.com/questions/1310420/difference-between-icalendar-ics-and-the-vcalendar-vcs

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-22 18:40     ` Ihor Radchenko
  2024-10-23  7:29       ` Björn Bidar
       [not found]       ` <87plnr6zvk.fsf@>
@ 2024-10-23  9:01       ` Richard Lawrence
  2024-10-23 20:24         ` Ferdinand Pieper
  2 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-23  9:01 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: Adam Porter, emacs-devel

Hi Ihor,

Ihor Radchenko <yantar92@posteo.net> writes:

> Some kind of icalendar parser could be useful.

Great to know you'd be interested in this!

> In Org mode, we currently do icalendar export by hand-writing iCalendar
> entries as strings and need to be careful about things like line endings
> and special symbols.

Yes. 

> What could be done instead is some kind of Elisp API similar to
> `xml-parse-region' and `xml-print', so that things like escaping
> symbols, exact literals, newlines, etc are handled behind the scenes, and
> we could instead just define an AST and "print" it into a valid
> iCalendar file.
>
> So, my suggestion would be something akin xml.el and maybe (optionally)
> https://github.com/ndwarshuis/org-ml - to manipulate the AST.

Thank you, this is a very useful suggestion. I wasn't aware that xml.el
had an API like this -- I will take a look.

At the moment, I am drafting a set of data structures that the parser
will produce, and the printer will consume. Following Adam's suggestion,
I've been basing these on cl-structs (except for simple atomic values). So
eventually you should be able to write code that's something like this:

(icalendar-make-vevent
  ;; properties:
  (list (icalendar-make-property "DTSTART"
           (icalendar-datetime-from-timestamp some-lisp-timestamp))
        (icalendar-make-property "DTEND"
           (icalendar-datetime-from-timestamp some-other-timestamp)))
  ;; subcomponents:
  (list (icalendar-make-valarm ...))
  ...)
           

and get a struct back that you could then send directly to a function
like 'icalendar-print-component' or similar. Does that seem like a
reasonable approach, or is it already too cumbersome? (Would you prefer
e.g. to just be able to write the appropriate data structure as a
backquoted (p)list?)

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
       [not found]       ` <87plnr6zvk.fsf@>
  2024-10-23  8:09         ` Ihor Radchenko
@ 2024-10-23  9:05         ` Richard Lawrence
  2024-10-23 10:03           ` Björn Bidar
  1 sibling, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-23  9:05 UTC (permalink / raw)
  To: Björn Bidar, Ihor Radchenko; +Cc: Adam Porter, emacs-devel

Hi Björn,

Björn Bidar <bjorn.bidar@thaodan.de> writes:

> Is the VCard and Vtodo file format similar enough to icalendar in the base form
> that for these base line handling of these formats could be done
> together for these?

I haven't looked at the RFC, but a quick look at the example on
Wikipedia tells me that vCard should be very similar and probably can
use the same parsing infrastructure that I'm building for iCalendar now.

However, I am unable to find any information about a "Vtodo file
format". There is a VTODO component within the iCalendar standard -- is
that what you mean, or do you have something else in mind?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-21  6:22 ` Visuwesh
@ 2024-10-23  9:15   ` Richard Lawrence
  2024-10-23  9:45     ` Visuwesh
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-23  9:15 UTC (permalink / raw)
  To: Visuwesh; +Cc: emacs-devel

Hi Visuwesh,

Visuwesh <visuweshm@gmail.com> writes:

> It has been at least a couple years since I wrote this function so I
> don't remember the hurdles I faced when I wrote it very well but it
> perplexed me that there were no "public" functions that were geared
> towards parsing an ical file.  In retrospect, it would have been less
> confusing if these functions were "public" functions.  AFAIR, and this
> very well might not be true, the structure returned
> icalendar--read-element is not really documented anywhere which further
> added to the confusion.

Yes, I had the same feeling. I spent a while looking through
icalendar.el about six months ago, hoping I could find an appropriate
point to hook into it/extend it. But the private function names and lack
of documentation of the data structures eventually caused me to give up.
I couldn't figure out a good way to use it or patch it to do what I
wanted, and it seemed like there were a lot of things it didn't
implement anyway...thus this current project ;)

> That said, this function has been rock solid ever since I wrote it.
> Going by the ical files I have, it is working just fine since 2021.

Are you saying it would be important to you to preserve the "private"
API of icalendar.el? or just that you're glad this API is still working? 

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-23  9:15   ` Richard Lawrence
@ 2024-10-23  9:45     ` Visuwesh
  0 siblings, 0 replies; 64+ messages in thread
From: Visuwesh @ 2024-10-23  9:45 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

[புதன் அக்டோபர் 23, 2024] Richard Lawrence wrote:

> Hi Visuwesh,
>
> Visuwesh <visuweshm@gmail.com> writes:
>
>> It has been at least a couple years since I wrote this function so I
>> don't remember the hurdles I faced when I wrote it very well but it
>> perplexed me that there were no "public" functions that were geared
>> towards parsing an ical file.  In retrospect, it would have been less
>> confusing if these functions were "public" functions.  AFAIR, and this
>> very well might not be true, the structure returned
>> icalendar--read-element is not really documented anywhere which further
>> added to the confusion.
>
> Yes, I had the same feeling. I spent a while looking through
> icalendar.el about six months ago, hoping I could find an appropriate
> point to hook into it/extend it. But the private function names and lack
> of documentation of the data structures eventually caused me to give up.
> I couldn't figure out a good way to use it or patch it to do what I
> wanted, and it seemed like there were a lot of things it didn't
> implement anyway...thus this current project ;)

Understood.  pp is the reason why that function exists.  It look a bit
of trial and error to write it.

>> That said, this function has been rock solid ever since I wrote it.
>> Going by the ical files I have, it is working just fine since 2021.
>
> Are you saying it would be important to you to preserve the "private"
> API of icalendar.el? or just that you're glad this API is still working? 

The latter.  It would be nice if the former could be achieved too but
that is not a hard requirement.  It wouldn't be too much of a hurdle if
the new library is well documented.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-23  9:05         ` Richard Lawrence
@ 2024-10-23 10:03           ` Björn Bidar
  0 siblings, 0 replies; 64+ messages in thread
From: Björn Bidar @ 2024-10-23 10:03 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: Ihor Radchenko, Adam Porter, emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> However, I am unable to find any information about a "Vtodo file
> format". There is a VTODO component within the iCalendar standard -- is
> that what you mean, or do you have something else in mind?

Yes that's what I meant, maybe I mixed something up or separated them
even thou they part of the same standard.

In general the basic parsing of all these V-format is very similar.
There are more of these such as vMessage[1] although that one is unrelated
to this.

[1] https://en.wikipedia.org/wiki/VMessage



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-23  9:01       ` Richard Lawrence
@ 2024-10-23 20:24         ` Ferdinand Pieper
  2024-10-24 14:52           ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ferdinand Pieper @ 2024-10-23 20:24 UTC (permalink / raw)
  To: emacs-devel

(Resending just to list due to messed up spf entry; sorry for the trouble)

Hi Richard,

this effort to consolidate the iCalendar support is fantastic!

Emacs is really lacking a central parser for iCalendar and a common internal representation of iCalendar items.
I have ran over this several times, but was always very quick to shy away from working on a central overhaul of icalendar.el. I resorted to small extensions of gnus-icalendar.el to bring event (request) creation to gnus, which still is very much in a prototype state [1].

While I started extending the gnus-icalendar-event EIEIO class to support property parameters, it ended up being very cumbersome to create new event objects with all parameters correctly set.

Richard Lawrence <rwl@recursewithless.net> writes:

> (icalendar-make-vevent
>   ;; properties:
>   (list (icalendar-make-property "DTSTART"
>            (icalendar-datetime-from-timestamp some-lisp-timestamp))
>         (icalendar-make-property "DTEND"
>            (icalendar-datetime-from-timestamp some-other-timestamp)))
>   ;; subcomponents:
>   (list (icalendar-make-valarm ...))
>   ...)
>            
>
> and get a struct back that you could then send directly to a function
> like 'icalendar-print-component' or similar. Does that seem like a
> reasonable approach, or is it already too cumbersome? (Would you prefer
> e.g. to just be able to write the appropriate data structure as a
> backquoted (p)list?)

I think structs could be a good fit for the internal representation. Creating these from scratch should still be kept fairly straightforward for ease of use.
There could also be a translation function that creates the appropriate struct from a very basic list representation like this:

--8<---------------cut here---------------start------------->8---
(VCALENDAR
 ((PRODID nil "-//...")
  (VERSION nil "2.0"))
 (VEVENT
  (;; ...
   (DTSTART ((VALUE "DATE")) "20241201")
   (DTEND ((VALUE "DATE")) "20241231"))))
--8<---------------cut here---------------end--------------->8---


Best,
Ferdinand

[1]  https://git.nand.xyz/emacs/gnus-icalendar-request/ or mirrored at 
https://github.com/fpiper/gnus-icalendar-request



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-23 20:24         ` Ferdinand Pieper
@ 2024-10-24 14:52           ` Richard Lawrence
  2024-10-24 17:45             ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-24 14:52 UTC (permalink / raw)
  To: Ferdinand Pieper, emacs-devel

Hi Ferdinand,

Ferdinand Pieper <ferdi@nand.xyz> writes:

> Emacs is really lacking a central parser for iCalendar and a common
> internal representation of iCalendar items. I have ran over this
> several times, but was always very quick to shy away from working on a
> central overhaul of icalendar.el. I resorted to small extensions of
> gnus-icalendar.el to bring event (request) creation to gnus, which
> still is very much in a prototype state [1].
>
> While I started extending the gnus-icalendar-event EIEIO class to
> support property parameters, it ended up being very cumbersome to
> create new event objects with all parameters correctly set.

This is good feedback, thank you. Can you say more about what exactly
was cumbersome about it? (Was it the need to call various constructors,
instead of just consing up lists? or the need to interact with objects
via setters/getters? or lack of validation of parameter lists? or...?)

> I think structs could be a good fit for the internal representation.
> Creating these from scratch should still be kept fairly
> straightforward for ease of use. There could also be a translation
> function that creates the appropriate struct from a very basic list
> representation like this:
>
> --8<---------------cut here---------------start------------->8---
> (VCALENDAR
>  ((PRODID nil "-//...")
>   (VERSION nil "2.0"))
>  (VEVENT
>   (;; ...
>    (DTSTART ((VALUE "DATE")) "20241201")
>    (DTEND ((VALUE "DATE")) "20241231"))))
> --8<---------------cut here---------------end--------------->8---

Yes, as I'm sure you're aware, icalendar.el creates a list
representation like this. I've been thinking we might need such a
function anyway for the sake of backward compatibility. And the more I
think about it, the more I realize that a list representation with a few
accessors should be just fine for the "container" types (components,
properties, attribute lists).

The disadvantage of a representation like the one above is there is no
structure yet in the *value* types: e.g. "20241201" is just a string,
not a date. This is fine for export (assuming you've already validated
the data...) but when reading the data, one needs to parse these values
too, and this is what I've been using structs for so far.

So do you think it would still be too cumbersome to have a
representation like

> ... (DTSTART ((VALUE "DATE")) (icalendar-read-date "20241201"))

or even just

> ... (DTSTART ((VALUE "DATE")) ('icalendar-date . "20241201"))

where in the latter, 'icalendar-date is a cl type symbol and some magic
type dispatch will call the associated read function on the string at
an appropriate time?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-24 14:52           ` Richard Lawrence
@ 2024-10-24 17:45             ` Ihor Radchenko
  2024-10-25 12:53               ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2024-10-24 17:45 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: Ferdinand Pieper, emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

>> While I started extending the gnus-icalendar-event EIEIO class to
>> support property parameters, it ended up being very cumbersome to
>> create new event objects with all parameters correctly set.

As an alternative option, you may consider using org-element-ast API -
it is a generic data structure and API that Org mode uses to handle
parsed AST. It is servility optimized for performance and does not
really depend on other parts of Org mode.

The top level commentary should have all the details.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-24 17:45             ` Ihor Radchenko
@ 2024-10-25 12:53               ` Richard Lawrence
  2024-10-25 18:59                 ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-10-25 12:53 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Hi Ihor,

Ihor Radchenko <yantar92@posteo.net> writes:

> Richard Lawrence <rwl@recursewithless.net> writes:
>
>>> While I started extending the gnus-icalendar-event EIEIO class to
>>> support property parameters, it ended up being very cumbersome to
>>> create new event objects with all parameters correctly set.
>
> As an alternative option, you may consider using org-element-ast API -
> it is a generic data structure and API that Org mode uses to handle
> parsed AST. It is servility optimized for performance and does not
> really depend on other parts of Org mode.

Thanks for pointing me to this! I took a look at the file commentary,
and I've played around with org-element before. I do like org-element's
plist-based format...it makes things simple and readable as an outside
tinkerer.

Can you tell me a bit more about the performance benefits? Do these
mostly just stem from the use of an array for :standard-properties?
(You get this for free with cl-structs, too.) Or is it more about when
and how parsing happens? (This is something I feel like I've never
grasped in org-element...in the past I've been confused because the
properties I'd see when calling e.g. org-element-at-point would be
different than the ones available in some other context.)

Thanks!

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-25 12:53               ` Richard Lawrence
@ 2024-10-25 18:59                 ` Ihor Radchenko
  0 siblings, 0 replies; 64+ messages in thread
From: Ihor Radchenko @ 2024-10-25 18:59 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> Can you tell me a bit more about the performance benefits? Do these
> mostly just stem from the use of an array for :standard-properties?

:standard-properties and lazy evaluation.

> (You get this for free with cl-structs, too.)

Not exactly for free. There are extra type checks in cl-structs, and they
are slower to create. I did the benchmarking and decided to go with less
sophisticated data structure supported by inlined accessors/setters.

Also, as a technical detail that is irrelevant to your case, I had to
preserve backwards compatibility with the existing design to the highest
extent possible.

> ... Or is it more about when
> and how parsing happens? (This is something I feel like I've never
> grasped in org-element...in the past I've been confused because the
> properties I'd see when calling e.g. org-element-at-point would be
> different than the ones available in some other context.)

org-element-ast has little to do with parsing details. However, it does
provide features we need during parsing: (1) storing arbitrary
properties in addition to "standard"; (2) supporting "plain string" as a
special variant of AST leaf; (3) supporting anonymous nodes - simple
list of AST nodes; (4) lazy evaluation of properties - org-element uses
the APIs from org-element-ast to defer large parts of parsing to when
the relevant part of the AST node is actually requested by a caller.

For org-element-at-point, you may be confused because Org parser can
work in several modes, parsing down to certain
"granularity". org-element-at-point usually limits itself to parsing
down to paragraph level (in particular, it does not parse markup
inside headline :title leaving it as a simple plain text leaf), while
what you see during export is the most complete parsing mode, reaching
down to markup (in headlines, :title then contains a collection of Org
"objects" - the markup is parsed).  This has nothing to do with the AST
layout.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
       [not found] ` <87wmi29eaf.fsf@>
@ 2024-10-26 17:49   ` Ihor Radchenko
  2024-10-28 10:44     ` Björn Bidar
       [not found]     ` <87r080tslf.fsf@>
  0 siblings, 2 replies; 64+ messages in thread
From: Ihor Radchenko @ 2024-10-26 17:49 UTC (permalink / raw)
  To: Björn Bidar; +Cc: Richard Lawrence, emacs-devel

Björn Bidar <bjorn.bidar@thaodan.de> writes:

> It would be great to have these features supported better. In think
> some limitations in for example org-mode come also into play here as
> last time I looked it can't deal with timezones.

Org can deal with timezones in a limited way, during export.
More generic support is indeed not available yet.
The future plan for time zone support has been discussed in
https://list.orgmode.org/orgmode/CAL9aZkusXaNVCu7+nO-ic8SHhwVdOiXYtDyF=Gz7h+NoLaOZXQ@mail.gmail.com/

> For example Gnus uses org-capture to convert an icalendar
> event to org instead of some form of native API to synchronize the
> invite with-org.

Sorry, but I do not understand how org-capture has anything to do with
conversion. Capture is just for capturing user text to be saved into Org
file, based on a provided template. It is basically an extended
remember.el.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-26 17:49   ` Ihor Radchenko
@ 2024-10-28 10:44     ` Björn Bidar
       [not found]     ` <87r080tslf.fsf@>
  1 sibling, 0 replies; 64+ messages in thread
From: Björn Bidar @ 2024-10-28 10:44 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: Richard Lawrence, emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

>> For example Gnus uses org-capture to convert an icalendar
>> event to org instead of some form of native API to synchronize the
>> invite with-org.
>
> Sorry, but I do not understand how org-capture has anything to do with
> conversion. Capture is just for capturing user text to be saved into Org
> file, based on a provided template. It is basically an extended
> remember.el.

Gnus uses org-capture instead of somekind ical->org conversion when
importing ical invites which limits the amount and quality of conversion to org it can
do in my opinion.




^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
       [not found]     ` <87r080tslf.fsf@>
@ 2024-10-28 19:09       ` Ihor Radchenko
  0 siblings, 0 replies; 64+ messages in thread
From: Ihor Radchenko @ 2024-10-28 19:09 UTC (permalink / raw)
  To: Björn Bidar; +Cc: Richard Lawrence, emacs-devel

Björn Bidar <bjorn.bidar@thaodan.de> writes:

>> Sorry, but I do not understand how org-capture has anything to do with
>> conversion. Capture is just for capturing user text to be saved into Org
>> file, based on a provided template. It is basically an extended
>> remember.el.
>
> Gnus uses org-capture instead of somekind ical->org conversion when
> importing ical invites which limits the amount and quality of conversion to org it can
> do in my opinion.

Then, it does not look like anything can be done on Org side.

I have no idea about Gnus internals, but abusing org-capture for
conversion seems like a strange design.

Maybe better CC Gnus maintainers?

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
                   ` (5 preceding siblings ...)
       [not found] ` <87wmi29eaf.fsf@>
@ 2024-11-23  8:44 ` Richard Lawrence
  2024-11-24  9:50   ` Eli Zaretskii
  2024-12-20 13:21 ` Richard Lawrence
  7 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-11-23  8:44 UTC (permalink / raw)
  To: emacs-devel

Dear emacs-devel,

Richard Lawrence <rwl@recursewithless.net> writes:

> I would like to start a discussion about improving Emacs' iCalendar
> support, beyond what is already available in icalendar.el. I personally
> would like to see Emacs gain a more full-fledged RFC5545 implementation
> that is primarily designed as a library for other applications to use.

Time for an update about this: I've been working steadily on the parser,
and I reached an important milestone this week: the parser can now parse
and reproduce all the examples in RFC5545, as well as my own calendar
data! There is still a lot of work to do, but this seems like a good
moment to ask again for feedback from anyone who's interested.

The repository where I've been doing this work is here:
https://sr.ht/~wyleyr/icalendar-el/

There are some instructions in the README for how to get started playing
around with the parser, for those interested in trying it out.

Based on the feedback I got earlier, I've made a few important design
decisions at this stage:

1) The basic form of the syntax tree is based on the format of the Org
parse tree in org-element-ast.el (though for now I have not implemented
any of the performance optimizations). Syntax nodes are a four-element
list of a type symbol, a metadata structure, a value, and a list of
children. Type symbols are used to store metadata about all the
iCalendar grammar categories and to do type-based dispatch in the
parser.

2) As far as possible, I have represented iCalendar data using "native"
data types in Emacs: dates are represented as calendar.el dates,
date-times as decoded-times, text as strings or buffer regions, etc.
This should hopefully make it as easy as possible to use iCalendar data
and parse trees from elsewhere in Emacs. In cases where no data type
already exists, the data types I defined are usually simple lists with
accessors defined for different fields.

(My initial attempts used cl-structs for the data types, following Adam
Porter's suggestion, but I quickly found myself writing tons of
boilerplate to convert between these structs and the "native" formats,
so I abandoned it. I am using a struct for syntactic metadata stored by
the parser, though.)

3) I have focused a lot on making good documentation, since I think
Emacs' documentation system is one of its best features, and the lack of
documentation in icalendar.el is one of the things that makes it
difficult to work with. All the symbols in the library should have good
documentation available via M-x describe-symbol -- please let me know if
you find anything confusing or broken in these docs.

Many thanks in advance for your thoughts!

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-23  8:44 ` Richard Lawrence
@ 2024-11-24  9:50   ` Eli Zaretskii
  2024-11-24 10:21     ` Ihor Radchenko
  2024-11-25  9:09     ` Improving Emacs' iCalendar support Richard Lawrence
  0 siblings, 2 replies; 64+ messages in thread
From: Eli Zaretskii @ 2024-11-24  9:50 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

> From: Richard Lawrence <rwl@recursewithless.net>
> Date: Sat, 23 Nov 2024 09:44:47 +0100
> 
> 1) The basic form of the syntax tree is based on the format of the Org
> parse tree in org-element-ast.el (though for now I have not implemented
> any of the performance optimizations). Syntax nodes are a four-element
> list of a type symbol, a metadata structure, a value, and a list of
> children. Type symbols are used to store metadata about all the
> iCalendar grammar categories and to do type-based dispatch in the
> parser.

Is it possible to use peg.el instead?  Since iCalendar is not tightly
coupled to Org, it would be best not to load Org for supporting
iCalendar features.

Thanks.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-24  9:50   ` Eli Zaretskii
@ 2024-11-24 10:21     ` Ihor Radchenko
  2024-11-24 10:41       ` Eli Zaretskii
  2024-11-25  9:09     ` Improving Emacs' iCalendar support Richard Lawrence
  1 sibling, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2024-11-24 10:21 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: Richard Lawrence, emacs-devel

Eli Zaretskii <eliz@gnu.org> writes:

> ... it would be best not to load Org for supporting
> iCalendar features.

AFAIU, it is a single library from Org that should be loaded. Nothing
more. It is no different than implementing data structure in some other way.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-24 10:21     ` Ihor Radchenko
@ 2024-11-24 10:41       ` Eli Zaretskii
  2024-11-24 10:58         ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Eli Zaretskii @ 2024-11-24 10:41 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: rwl, emacs-devel

> From: Ihor Radchenko <yantar92@posteo.net>
> Cc: Richard Lawrence <rwl@recursewithless.net>, emacs-devel@gnu.org
> Date: Sun, 24 Nov 2024 10:21:44 +0000
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> > ... it would be best not to load Org for supporting
> > iCalendar features.
> 
> AFAIU, it is a single library from Org that should be loaded. Nothing
> more. It is no different than implementing data structure in some other way.

Then why is org-element-ast.el part of Org, and not a general-purpose
library in lisp/emacs-lisp/, for example?



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-24 10:41       ` Eli Zaretskii
@ 2024-11-24 10:58         ` Ihor Radchenko
  2024-11-24 11:08           ` Eli Zaretskii
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2024-11-24 10:58 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: rwl, emacs-devel

Eli Zaretskii <eliz@gnu.org> writes:

> Then why is org-element-ast.el part of Org, and not a general-purpose
> library in lisp/emacs-lisp/, for example?

I planned to upstream it eventually. It is a relatively new library,
part of the effort to modularize Org.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-24 10:58         ` Ihor Radchenko
@ 2024-11-24 11:08           ` Eli Zaretskii
  2024-11-24 11:21             ` Upstreaming org-element-ast (was: Improving Emacs' iCalendar support) Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Eli Zaretskii @ 2024-11-24 11:08 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: rwl, emacs-devel

> From: Ihor Radchenko <yantar92@posteo.net>
> Cc: rwl@recursewithless.net, emacs-devel@gnu.org
> Date: Sun, 24 Nov 2024 10:58:23 +0000
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> > Then why is org-element-ast.el part of Org, and not a general-purpose
> > library in lisp/emacs-lisp/, for example?
> 
> I planned to upstream it eventually. It is a relatively new library,
> part of the effort to modularize Org.

OK, then let's move it and rename it soon, so that this work on
iCalendar could be based on the new name.  (I guess renaming will also
need to change the prefix of the symbols defined by the package?)



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-11-24 11:08           ` Eli Zaretskii
@ 2024-11-24 11:21             ` Ihor Radchenko
  2024-11-24 12:55               ` Eli Zaretskii
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2024-11-24 11:21 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: rwl, emacs-devel

Eli Zaretskii <eliz@gnu.org> writes:

>> I planned to upstream it eventually. It is a relatively new library,
>> part of the effort to modularize Org.
>
> OK, then let's move it and rename it soon, so that this work on
> iCalendar could be based on the new name.  (I guess renaming will also
> need to change the prefix of the symbols defined by the package?)

The major issue with renaming is how to do it and yet preserve the
ability to use the library from Org distributed via ELPA - in older
Emacs versions. I suspect that the right way to go will be creating a
separate ELPA package in addition to moving and renaming the library.

Also, there are certain things in the library that are specific to
Org:

1. org-element--standard-properties constant
2. commentary that is mostly talking about Org

They do not prevent usage outside Org mode, but should probably be
changed before upstreaming.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-11-24 11:21             ` Upstreaming org-element-ast (was: Improving Emacs' iCalendar support) Ihor Radchenko
@ 2024-11-24 12:55               ` Eli Zaretskii
  2024-12-25 11:31                 ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Eli Zaretskii @ 2024-11-24 12:55 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: rwl, emacs-devel

> From: Ihor Radchenko <yantar92@posteo.net>
> Cc: rwl@recursewithless.net, emacs-devel@gnu.org
> Date: Sun, 24 Nov 2024 11:21:38 +0000
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> >> I planned to upstream it eventually. It is a relatively new library,
> >> part of the effort to modularize Org.
> >
> > OK, then let's move it and rename it soon, so that this work on
> > iCalendar could be based on the new name.  (I guess renaming will also
> > need to change the prefix of the symbols defined by the package?)
> 
> The major issue with renaming is how to do it and yet preserve the
> ability to use the library from Org distributed via ELPA - in older
> Emacs versions. I suspect that the right way to go will be creating a
> separate ELPA package in addition to moving and renaming the library.

Something like that, yes.  An Org-specific compatibility package is
also a possibility.

> Also, there are certain things in the library that are specific to
> Org:
> 
> 1. org-element--standard-properties constant
> 2. commentary that is mostly talking about Org
> 
> They do not prevent usage outside Org mode, but should probably be
> changed before upstreaming.

Right.

My point is that the sooner we do this (quite unpleasant) job, the
smaller it is, and the smaller are the effects on other packages which
use it.

Thanks.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-24  9:50   ` Eli Zaretskii
  2024-11-24 10:21     ` Ihor Radchenko
@ 2024-11-25  9:09     ` Richard Lawrence
  2024-11-25 12:42       ` Eli Zaretskii
  1 sibling, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-11-25  9:09 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: emacs-devel, Ihor Radchenko

Eli Zaretskii <eliz@gnu.org> writes:

>> 1) The basic form of the syntax tree is based on the format of the Org
>> parse tree in org-element-ast.el (though for now I have not implemented
>> any of the performance optimizations). Syntax nodes are a four-element
>> list of a type symbol, a metadata structure, a value, and a list of
>> children. Type symbols are used to store metadata about all the
>> iCalendar grammar categories and to do type-based dispatch in the
>> parser.
>
> Since iCalendar is not tightly coupled to Org, it would be best not to
> load Org for supporting iCalendar features.

Sorry if I was unclear: I'm not loading org-element-ast.el or using it
directly; I have just adopted the same basic format for iCalendar syntax
nodes. This should make it easier to switch to org-element-ast.el
if/when it eventually becomes a more generalized library. But at the
moment, there are enough feature differences that I don't think that
makes sense.

> Is it possible to use peg.el instead? 

I was not aware of peg.el, and it doesn't seem to be installed in my
(Debian-built) Emacs -- find-library does not find it. Is it new? Where
can I take a look at it?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-25  9:09     ` Improving Emacs' iCalendar support Richard Lawrence
@ 2024-11-25 12:42       ` Eli Zaretskii
  2024-11-25 13:03         ` Rudolf Schlatte
  0 siblings, 1 reply; 64+ messages in thread
From: Eli Zaretskii @ 2024-11-25 12:42 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel, yantar92

> From: Richard Lawrence <rwl@recursewithless.net>
> Cc: emacs-devel@gnu.org, Ihor Radchenko <yantar92@posteo.net>
> Date: Mon, 25 Nov 2024 10:09:15 +0100
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> > Is it possible to use peg.el instead? 
> 
> I was not aware of peg.el, and it doesn't seem to be installed in my
> (Debian-built) Emacs -- find-library does not find it. Is it new? Where
> can I take a look at it?

It is new in Emacs 30.  You should be able to find it if you build the
latest emacs-30 branch of the Emacs Git repository, or build the
latest pretest of Emacs 30.1 (which you can find on alpha.gnu.org).



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-25 12:42       ` Eli Zaretskii
@ 2024-11-25 13:03         ` Rudolf Schlatte
  2024-11-25 13:36           ` Eli Zaretskii
  2024-11-25 17:14           ` Richard Lawrence
  0 siblings, 2 replies; 64+ messages in thread
From: Rudolf Schlatte @ 2024-11-25 13:03 UTC (permalink / raw)
  To: emacs-devel

Eli Zaretskii <eliz@gnu.org> writes:

>> From: Richard Lawrence <rwl@recursewithless.net>
>> Cc: emacs-devel@gnu.org, Ihor Radchenko <yantar92@posteo.net>
>> Date: Mon, 25 Nov 2024 10:09:15 +0100
>> 
>> Eli Zaretskii <eliz@gnu.org> writes:
>> 
>> > Is it possible to use peg.el instead? 
>> 
>> I was not aware of peg.el, and it doesn't seem to be installed in my
>> (Debian-built) Emacs -- find-library does not find it. Is it new? Where
>> can I take a look at it?
>
> It is new in Emacs 30.  You should be able to find it if you build the
> latest emacs-30 branch of the Emacs Git repository, or build the
> latest pretest of Emacs 30.1 (which you can find on alpha.gnu.org).

It is also on gnu elpa (https://elpa.gnu.org/packages/peg.html), and
claims to run on emacs versions >= 25.




^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-25 13:03         ` Rudolf Schlatte
@ 2024-11-25 13:36           ` Eli Zaretskii
  2024-11-25 17:14           ` Richard Lawrence
  1 sibling, 0 replies; 64+ messages in thread
From: Eli Zaretskii @ 2024-11-25 13:36 UTC (permalink / raw)
  To: Rudolf Schlatte; +Cc: emacs-devel

> From: Rudolf Schlatte <rudi@constantly.at>
> Date: Mon, 25 Nov 2024 14:03:21 +0100
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> >> I was not aware of peg.el, and it doesn't seem to be installed in my
> >> (Debian-built) Emacs -- find-library does not find it. Is it new? Where
> >> can I take a look at it?
> >
> > It is new in Emacs 30.  You should be able to find it if you build the
> > latest emacs-30 branch of the Emacs Git repository, or build the
> > latest pretest of Emacs 30.1 (which you can find on alpha.gnu.org).
> 
> It is also on gnu elpa (https://elpa.gnu.org/packages/peg.html), and
> claims to run on emacs versions >= 25.

Yes, but code in core cannot depend on a package that is only on ELPA.



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-11-25 13:03         ` Rudolf Schlatte
  2024-11-25 13:36           ` Eli Zaretskii
@ 2024-11-25 17:14           ` Richard Lawrence
  1 sibling, 0 replies; 64+ messages in thread
From: Richard Lawrence @ 2024-11-25 17:14 UTC (permalink / raw)
  To: Rudolf Schlatte, emacs-devel

Rudolf Schlatte <rudi@constantly.at> writes:

> Eli Zaretskii <eliz@gnu.org> writes:

>> [peg.el] is new in Emacs 30.  You should be able to find it if you build the
>> latest emacs-30 branch of the Emacs Git repository, or build the
>> latest pretest of Emacs 30.1 (which you can find on alpha.gnu.org).
>
> It is also on gnu elpa (https://elpa.gnu.org/packages/peg.html), and
> claims to run on emacs versions >= 25.

Thanks to both of you for the pointers; I'll take a look.

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Improving Emacs' iCalendar support
  2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
                   ` (6 preceding siblings ...)
  2024-11-23  8:44 ` Richard Lawrence
@ 2024-12-20 13:21 ` Richard Lawrence
  7 siblings, 0 replies; 64+ messages in thread
From: Richard Lawrence @ 2024-12-20 13:21 UTC (permalink / raw)
  To: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> I would like to start a discussion about improving Emacs' iCalendar
> support, beyond what is already available in icalendar.el. I personally
> would like to see Emacs gain a more full-fledged RFC5545 implementation
> that is primarily designed as a library for other applications to use.

Just an update for anyone who is interested in discussing this further:
I have created a bug report with this as a wishlist item, Bug#74994 at 

https://debbugs.gnu.org/cgi/bugreport.cgi?bug=74994

and will be posting patches there soon. 

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-11-24 12:55               ` Eli Zaretskii
@ 2024-12-25 11:31                 ` Ihor Radchenko
  2024-12-29 20:19                   ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2024-12-25 11:31 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: rwl, emacs-devel

Eli Zaretskii <eliz@gnu.org> writes:

>> Also, there are certain things in the library that are specific to
>> Org:
>> ...
>
> My point is that the sooner we do this (quite unpleasant) job, the
> smaller it is, and the smaller are the effects on other packages which
> use it.

In bug#74994, Richard made a decision not to use org-element-ast and
instead implement a custom parser generator.

Richard, is there any specific reason why you had to make things from
scratch? May org-element-ast be changed to fit your needs?

If org-element-ast is not going to be useful outside Org mode, I see no
good reason to invest time into upstreaming it, after all.

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-12-25 11:31                 ` Ihor Radchenko
@ 2024-12-29 20:19                   ` Richard Lawrence
  2024-12-29 20:53                     ` Richard Lawrence
  2024-12-30 17:16                     ` bug#74994: " Ihor Radchenko
  0 siblings, 2 replies; 64+ messages in thread
From: Richard Lawrence @ 2024-12-29 20:19 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel, 74994

Ihor Radchenko <yantar92@posteo.net> writes:

> In bug#74994, Richard made a decision not to use org-element-ast and
> instead implement a custom parser generator.
>
> Richard, is there any specific reason why you had to make things from
> scratch? May org-element-ast be changed to fit your needs?
>
> If org-element-ast is not going to be useful outside Org mode, I see no
> good reason to invest time into upstreaming it, after all.

No, it was more that, as things stood, I wanted to wait and see what
would happen with upstreaming org-element-ast. My idea was to make it
easy to switch once that happened, but not to wait to make progress in
the meantime, that's all.

One thing about your question confuses me, namely: 

> ...instead implement a custom parser generator.

As I understand org-element-ast, it basically just defines the parse
tree representation and various accessors for working with it, not the
parser itself. Was your suggestion that I could also use the Org parser,
not just the parse tree representation? If so, then I misunderstood, and
presumably more code is involved than is found in org-element-ast.el,
right?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-12-29 20:19                   ` Richard Lawrence
@ 2024-12-29 20:53                     ` Richard Lawrence
  2024-12-30 17:18                       ` Ihor Radchenko
  2024-12-30 17:16                     ` bug#74994: " Ihor Radchenko
  1 sibling, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-12-29 20:53 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel, 74994

Richard Lawrence <rwl@recursewithless.net> writes:

> Ihor Radchenko <yantar92@posteo.net> writes:
>
>> In bug#74994, Richard made a decision not to use org-element-ast and
>> instead implement a custom parser generator.
>>
>> Richard, is there any specific reason why you had to make things from
>> scratch? May org-element-ast be changed to fit your needs?
>>
>> If org-element-ast is not going to be useful outside Org mode, I see no
>> good reason to invest time into upstreaming it, after all.
>
> No, it was more that, as things stood, I wanted to wait and see what
> would happen with upstreaming org-element-ast. My idea was to make it
> easy to switch once that happened, but not to wait to make progress in
> the meantime, that's all.

Ah, looking over this again, there was one thing that I felt didn't fit
very well with org-element-ast: in iCalendar, "properties" can have both
a "value" and a list of "parameters". These are different types of
objects and it's most natural and useful not to lump them together, but
in the Org element AST they would probably both just be "contents" of a
property node (i.e., child nodes). Thus, in my draft icalendar-ast.el,
instead of using

(TYPE PROPERTIES CONTENTS)

as the basic representation for a node, I used

(TYPE META VALUE CHILDREN).

The org-element-ast representation is obviously capable of making the
distinction between values and parameters in some other way; but it's
pretty much the only example I can think of where I felt the
org-element-ast representation might not be the best for the needs of
iCalendar.

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* bug#74994: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-12-29 20:19                   ` Richard Lawrence
  2024-12-29 20:53                     ` Richard Lawrence
@ 2024-12-30 17:16                     ` Ihor Radchenko
  2024-12-31  7:55                       ` Richard Lawrence
  1 sibling, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2024-12-30 17:16 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: 74994, emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

>> Richard, is there any specific reason why you had to make things from
>> scratch? May org-element-ast be changed to fit your needs?
> ...
> No, it was more that, as things stood, I wanted to wait and see what
> would happen with upstreaming org-element-ast. My idea was to make it
> easy to switch once that happened, but not to wait to make progress in
> the meantime, that's all.

org-element-ast is already a part of Emacs. The process of upstreaming
in this particular case is simply a question of (1) making the library
more useful outside Org mode; (2) renaming it.

Renaming is trivial.
The main question is making things usable outside Org mode.
And that's where your work is the most valuable.
So, it was me who is waiting for your input before upstreaming :)

> One thing about your question confuses me, namely: 
>
>> ...instead implement a custom parser generator.
>
> As I understand org-element-ast, it basically just defines the parse
> tree representation and various accessors for working with it, not the
> parser itself. Was your suggestion that I could also use the Org parser,
> not just the parse tree representation? If so, then I misunderstood, and
> presumably more code is involved than is found in org-element-ast.el,
> right?

No, I did not mean that you should use org-element to generate parser.
I mostly referred to the way you implement the parser where part of the
parser configuration is stored in the AST. But I was reading your patch
very quickly and could have misunderstood something.

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-12-29 20:53                     ` Richard Lawrence
@ 2024-12-30 17:18                       ` Ihor Radchenko
  0 siblings, 0 replies; 64+ messages in thread
From: Ihor Radchenko @ 2024-12-30 17:18 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel, 74994

Richard Lawrence <rwl@recursewithless.net> writes:

> Ah, looking over this again, there was one thing that I felt didn't fit
> very well with org-element-ast: in iCalendar, "properties" can have both
> a "value" and a list of "parameters". These are different types of
> objects and it's most natural and useful not to lump them together, but
> in the Org element AST they would probably both just be "contents" of a
> property node (i.e., child nodes). Thus, in my draft icalendar-ast.el,
> instead of using
>
> (TYPE PROPERTIES CONTENTS)
>
> as the basic representation for a node, I used
>
> (TYPE META VALUE CHILDREN).
>
> The org-element-ast representation is obviously capable of making the
> distinction between values and parameters in some other way; but it's
> pretty much the only example I can think of where I felt the
> org-element-ast representation might not be the best for the needs of
> iCalendar.

Have you looked into secondary nodes?

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-12-30 17:16                     ` bug#74994: " Ihor Radchenko
@ 2024-12-31  7:55                       ` Richard Lawrence
  2025-01-01  9:29                         ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2024-12-31  7:55 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Hi Ihor,

Ihor Radchenko <yantar92@posteo.net> writes:

> The main question is making things usable outside Org mode.
> And that's where your work is the most valuable.
> So, it was me who is waiting for your input before upstreaming :)

Got it! I sat down yesterday and tried to convert to using
org-element-ast, and I've run into a couple of questions:

1) Is there any way to use my own list of standard-properties? In
   particular, besides :begin, :end, :contents-begin, :contents-end, I'd
   like to have :value-begin and :value-end as standard properties, and
   always include (:value) in :secondary. If there's no way to do that
   yet, I think it would be useful to add for use outside of org.
   
2) I'm finding org-element-create rather unintuitive to work with, I
   think because of its &rest argument for children and the handling of
   "anonymous" nodes.

   In all my use cases, I build up children as an explicit list of nodes
   before calling icalendar-make-ast-node, which stores the list in
   the children slot, and returns that list from icalendar-ast-node-children.

   An interface like
     (org-element-create type props children)
   would be sufficient for me, where children is a list of
   nodes (and hence can be nil).

   As it is, I can't figure out how to call org-element-create and
   org-element-contents in the right way to set the contents of a node
   to a list of other nodes, and return that list from
   org-element-contents.

   I always seem to end up with an extra level of nesting. 
   e.g. Instead of (child1 child2 child3 ...)
   org-element-contents returns ((child1 child2 child3 ...)).
   Likewise, if there are no children, instead of nil it returns (nil).
   I can't figure out why this happens; as far as I can tell, I'm
   calling both org-element-create and org-element-contents in the right
   way.

   I tried to write a wrapper for org-element-create using apply, with
   children as the last argument, like
     (apply #'org-element-create type props children)
   but that didn't help. I also tried just unconditionally unwrapping
   the list returned by org-element-contents by just taking its car. But
   (if I remember right) that seemed to create one level too *few* of
   nesting in at least some cases, such that org-element-contents would
   return stuff from the properties list.

   Can you help me understand what the right thing for me to do here is?
   All I want to do is store a list of child nodes at construction time,
   and get that list back later on, which seems like it should be a
   simple thing to do.

   In any case, it might be worth reviewing the interfaces and
   docstrings for these functions, because there is something about how
   they work that I clearly don't understand yet, and might be
   surprising to other library consumers.

Hope that's useful feedback!

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2024-12-31  7:55                       ` Richard Lawrence
@ 2025-01-01  9:29                         ` Ihor Radchenko
  2025-01-01 12:38                           ` Richard Lawrence
  2025-01-01 13:01                           ` Richard Lawrence
  0 siblings, 2 replies; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-01  9:29 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> 1) Is there any way to use my own list of standard-properties? In
>    particular, besides :begin, :end, :contents-begin, :contents-end, I'd
>    like to have :value-begin and :value-end as standard properties, and
>    always include (:value) in :secondary. If there's no way to do that
>    yet, I think it would be useful to add for use outside of org.

Currently, there is no such way. But it is one of the obvious problems
that need to be solved to make the library truly generic.

I am not 100% sure how though.
The idea behind standard properties is inlining the calls to
`org-element-property' for faster access.
Dynamic standard-properties will defeat the purpose of this whole arrangement.

The only thing coming to my mind is asking the libraries to use

(let ((org-element--standard-properties <custom value>))
  (defun library-x (...)
    ...))

Or maybe the library can somehow flag to org-element-ast during compile
time about the properties to be optimized.
        
> 2) I'm finding org-element-create rather unintuitive to work with, I
>    think because of its &rest argument for children and the handling of
>    "anonymous" nodes.
> ...
>    As it is, I can't figure out how to call org-element-create and
>    org-element-contents in the right way to set the contents of a node
>    to a list of other nodes, and return that list from
>    org-element-contents.

Should be just
(org-element-create type props contents)
and then
(org-element-contents new-node)

>    I always seem to end up with an extra level of nesting. 
>    e.g. Instead of (child1 child2 child3 ...)
>    org-element-contents returns ((child1 child2 child3 ...)).
>    Likewise, if there are no children, instead of nil it returns (nil).
>    I can't figure out why this happens; as far as I can tell, I'm
>    calling both org-element-create and org-element-contents in the right
>    way.

May you give some examples when things misbehave?

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-01  9:29                         ` Ihor Radchenko
@ 2025-01-01 12:38                           ` Richard Lawrence
  2025-01-02 18:03                             ` Ihor Radchenko
  2025-01-01 13:01                           ` Richard Lawrence
  1 sibling, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-01 12:38 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:
         
>> 2) I'm finding org-element-create rather unintuitive to work with, I
>>    think because of its &rest argument for children and the handling of
>>    "anonymous" nodes.
>> ...
>>    As it is, I can't figure out how to call org-element-create and
>>    org-element-contents in the right way to set the contents of a node
>>    to a list of other nodes, and return that list from
>>    org-element-contents.
>
> Should be just
> (org-element-create type props contents)
> and then
> (org-element-contents new-node)

That's what I would have thought. In my experiment, I have done this:

(defun ical:make-ast-node (type &optional props &rest children)
  ;; automatically mark :value as a seconary property for org-element-ast:
  (let ((full-props (plist-put props :secondary (list :value))))
        (org-element-create type full-props children)))

(so basically just aliasing org-element-create) and

(defalias 'ical:ast-node-children #'org-element-contents)

I also changed all my calls to ical:make-ast-node to reflect the calling
convention of org-element-create, e.g. in ical:read-property-value I now
have

(ical:make-ast-node type
                    (list :value value :original-value unrecognized-val)
                    params)

The calls to ical:ast-node-children shouldn't need adjusting, since both
the old version and org-element-set-contents just take a single
argument, the syntax node.

But when I run my parser tests with the above changes, they (almost) all
fail with errors like this:

Test string:
"ATTENDEE;RSVP=TRUE;ROLE=REQ-PARTICIPANT:mailto:jsmith@example.com\n"

Error:
    (icalendar-validation-error
     "`icalendar-attendee' may not contain `nil'"
     (icalendar-attendee
      (:standard-properties
       [1 nil nil nil 66 nil (:value) nil nil nil ...] :value
       (icalendar-cal-address
        (:standard-properties
         [nil nil nil nil nil nil ... nil nil nil ...] :value
         "mailto:jsmith@example.com")
        nil)
       :original-value nil :value-begin 41 :value-end 66)
      ((icalendar-rsvpparam
        (:standard-properties [10 nil nil nil 19 nil ... nil nil nil ...]
                              :value (icalendar-boolean ... nil)
                              :original-value nil :value-begin 15
                              :value-end 19)
        nil)
       (icalendar-roleparam
        (:standard-properties [20 nil nil nil 40 nil ... nil nil nil ...]
                              :value "REQ-PARTICIPANT" :original-value nil
                              :value-begin 25 :value-end 40)
        nil))))

And probing with the debugger reveals e.g. that (icalendar-node-children node)
returns in this example:

(((icalendar-rsvpparam
   (:standard-properties
    [10 nil nil nil 19 nil (:value) nil nil nil nil nil nil nil
        #<buffer *iCalendar Parse Test*> nil nil nil]
    :value
    (icalendar-boolean
     (:standard-properties
      [nil nil nil nil nil nil (:value) nil nil nil nil nil nil nil
           nil nil nil nil]
      :value t)
     nil)
    :original-value nil :value-begin 15 :value-end 19)
   nil)
  (icalendar-roleparam
   (:standard-properties
    [20 nil nil nil 40 nil (:value) nil nil nil nil nil nil nil
        #<buffer *iCalendar Parse Test*> nil nil nil]
    :value "REQ-PARTICIPANT" :original-value nil :value-begin 25
    :value-end 40)
   nil)))

That is, the list of parameter nodes is wrapped in an extra list, which
causes my function which counts children by type to fail and signal the
error.

Initially I thought that this is because org-element-contents is
implemented in the relevant case as (nthcdr 2 node) rather than e.g.
(nth 2 node). Changing the definition of ical:ast-node-children from the
above alias to

(defun ical:ast-node-children (node)
  (nth 2 node))

helps -- more tests pass -- but I'm not sure why this change should be
necessary. (I feel like I'm missing something really obvious here but so
far it eludes me!)

Even with this change, most tests still fail with an error like the
above, because an *empty* list of children is still returned as (nil)
rather than nil. The problem here is apparently that I am passing nil as
an explicit &rest argument to org-element-create; if I then change the
definition of ical:make-ast-node to work around this, e.g.

(defun ical:make-ast-node (type &optional props &rest children)
  ;; automatically mark :value as a seconary property for org-element-ast:
  (let ((full-props (plist-put props :secondary (list :value))))
    (if (equal children '(nil))
        (org-element-create type full-props)
      (org-element-create type full-props children))))

then all the tests pass again. But this is where I find the calling
convention of org-element-create unintuitive and would prefer an
interface where I can just always pass a list of child nodes, including
an empty list, and org-element-contents will always give me exactly that
list back.

This got a bit long, but I hope it's detailed enough to make things clear!

Best,
Richard




^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-01  9:29                         ` Ihor Radchenko
  2025-01-01 12:38                           ` Richard Lawrence
@ 2025-01-01 13:01                           ` Richard Lawrence
  2025-01-05  8:33                             ` Ihor Radchenko
  1 sibling, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-01 13:01 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> Richard Lawrence <rwl@recursewithless.net> writes:
>
>> 1) Is there any way to use my own list of standard-properties?
>
> Currently, there is no such way. But it is one of the obvious problems
> that need to be solved to make the library truly generic.
> I am not 100% sure how though.
>
> The only thing coming to my mind is asking the libraries to use
>
> (let ((org-element--standard-properties <custom value>))
>   (defun library-x (...)
>     ...))

Personally I think this would be a bit much to ask...it would be fairly
annoying to have to wrap all one's functions like this, even if there
was a macro to do it.

> Or maybe the library can somehow flag to org-element-ast during compile
> time about the properties to be optimized.

What about asking library users to say something like

(eval-when-compile (defvar org-element-custom-standard-properties ...))

and then using a with-standard-properties macro within
org-element-ast.el to make use of this value at compile time?

I don't know if that would work if e.g. org-element-ast gets compiled
before the user's code, but an interface like that seems preferable to
me.

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-01 12:38                           ` Richard Lawrence
@ 2025-01-02 18:03                             ` Ihor Radchenko
  2025-01-02 20:01                               ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-02 18:03 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

>> Should be just
>> (org-element-create type props contents)
>> and then
>> (org-element-contents new-node)
>
> That's what I would have thought. In my experiment, I have done this:
>
> (defun ical:make-ast-node (type &optional props &rest children)
>   ;; automatically mark :value as a seconary property for org-element-ast:
>   (let ((full-props (plist-put props :secondary (list :value))))
>         (org-element-create type full-props children)))
>
> (so basically just aliasing org-element-create) and

That's not what you did.
You did not replicate the calling convention
 (org-element-create 'type properties '(<child1> <child2> ...))

  (ical:make-ast-node 'test nil '("a" "b" "c"))

will have CHILDREN = '(("a" "b" "c"))
and pass this argument to `org-element-create' that will faithfully
create a node with a single child - anonymous node ("a" "b" "c").

You should do

  (apply #'org-element-create type full-props children)

This is a common pattern when passing argument to a function with &rest.

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-02 18:03                             ` Ihor Radchenko
@ 2025-01-02 20:01                               ` Richard Lawrence
  2025-01-02 20:09                                 ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-02 20:01 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> That's not what you did.
> You did not replicate the calling convention
>  (org-element-create 'type properties '(<child1> <child2> ...))
>
>   (ical:make-ast-node 'test nil '("a" "b" "c"))
>
> will have CHILDREN = '(("a" "b" "c"))
> and pass this argument to `org-element-create' that will faithfully
> create a node with a single child - anonymous node ("a" "b" "c").
>
> You should do
>
>   (apply #'org-element-create type full-props children)

D'oh. You're right; sorry for the noise.

In fact, I had already tried that in a previous iteration, but it didn't
fix the issue(s) I was seeing in the tests and so I had already
backpedaled on it by the time I wrote my previous email. 

I think this bit of the docstring had convinced me by that time that
calling org-element-create via apply wasn't necessary:

> When CHILDREN is a single anonymous node, use its contents as children
> nodes.  

In any case, the issue with passing nil as the &rest argument is what
causes most of the tests to fail. This remains so even once I change the
call to use (apply #'org-element-create ...) as you suggested. This *is*
documented in the Elisp manual, and I guess it makes sense, but I still
find it somewhat unintuitive to reason about.  

So again, at least for all my uses, an additional/alternative interface
to org-element-create that doesn't make children a &rest argument would
be useful. I had hoped I could just make ical:make-ast-node an alias of
org-element-create, but for now I will leave it as a wrapper around
org-element-create with a different calling convention. Otherwise, I
haven't run into anything that would prevent me from using
org-element-ast and I'd be happy to use a more general version of it in
icalendar-ast.el.

Thanks for your help!

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-02 20:01                               ` Richard Lawrence
@ 2025-01-02 20:09                                 ` Ihor Radchenko
  2025-01-05  9:52                                   ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-02 20:09 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> In any case, the issue with passing nil as the &rest argument is what
> causes most of the tests to fail. This remains so even once I change the
> call to use (apply #'org-element-create ...) as you suggested. This *is*
> documented in the Elisp manual, and I guess it makes sense, but I still
> find it somewhat unintuitive to reason about.  

May you please give an example illustrating the issue? I am not sure if
I understand it fully.

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-01 13:01                           ` Richard Lawrence
@ 2025-01-05  8:33                             ` Ihor Radchenko
  2025-01-10  9:48                               ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-05  8:33 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

>> Or maybe the library can somehow flag to org-element-ast during compile
>> time about the properties to be optimized.
>
> What about asking library users to say something like
>
> (eval-when-compile (defvar org-element-custom-standard-properties ...))
>
> and then using a with-standard-properties macro within
> org-element-ast.el to make use of this value at compile time?
>
> I don't know if that would work if e.g. org-element-ast gets compiled
> before the user's code, but an interface like that seems preferable to
> me.

It will not work.
I thought about multiple ways to make things work, but everything seems
ugly or confusing as an API.

I think that the simplest approach could be just leaving
`org-element--standard-properties' constant, but stuffing it with truly
generic properties that are common for all the possible parsers.

WDYT?

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-02 20:09                                 ` Ihor Radchenko
@ 2025-01-05  9:52                                   ` Richard Lawrence
  2025-01-05 13:30                                     ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-05  9:52 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> Richard Lawrence <rwl@recursewithless.net> writes:
>
>> In any case, the issue with passing nil as the &rest argument is what
>> causes most of the tests to fail. This remains so even once I change the
>> call to use (apply #'org-element-create ...) as you suggested. This *is*
>> documented in the Elisp manual, and I guess it makes sense, but I still
>> find it somewhat unintuitive to reason about.  
>
> May you please give an example illustrating the issue? I am not sure if
> I understand it fully.

OK, revisiting this after a few days...I'm not 100% sure I understand
it either.

Here is what I see: if I define ical:make-ast-node like

(defun ical:make-ast-node (type &optional props &rest children)
  ;; ...
  (apply #'org-element-create type full-props children))

which is what I was doing in the hope that I could eventually just use
defalias, most of my parser tests fail with "X may not contain `nil'"
errors as I showed in a previous message. If instead I change the
definition to:

(defun ical:make-ast-node (type props &optional children)
  ;; ...
  (apply #'org-element-create type full-props children))

which better reflects the usage pattern I need, then all the tests pass again.

The reason is that, with the former definition, children will be bound to
`(nil)' in the call to org-element-create, while in the latter it will
be bound to `nil'. The root of the problem is that

(org-element-create 'foo (list ...))
(org-element-create 'foo (list ...) nil)

are not equivalent; in particular

(org-element-contents (org-element-create 'foo (list ...))) ; => nil
(org-element-contents (org-element-create 'foo (list ...) nil)) ; => (nil)

This is the documented behavior of passing nil for a &rest argument (see
info node `(elisp)Argument list': "Note that exactly five arguments with
an explicit ‘nil’ argument provided for ‘e’ will cause that ‘nil’
argument to be passed as a list with one element, ‘(nil)’, as with any
other single value for ‘e’"). So it's not a problem per se.

But this interface to org-element-contents is not a good match for the
way my iCalendar parser works: a list of child nodes is always built up
*before* calling ical:make-ast-node/org-element-create. Sometimes this
list is empty, and sometimes it isn't, but it is always a list, and I
always have a variable bound to this list which I want to provide as an
argument to the constructor. I imagine other parsers often work
similarly. Thus, it would be nice to have an interface where children is
not a &rest argument, so that calling it like

(org-element-create* 'foo (list ...) the-child-nodes)

will work even if the-child-nodes is nil, rather than having to either
(a) say

(if the-child-nodes
    (org-element-create* 'foo (list ...) the-child-nodes)
  (org-element-create* 'foo (list ...)))

or (b) write a wrapper for org-element-create with a different argument
list definition, as I have now.

Is that clearer?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-05  9:52                                   ` Richard Lawrence
@ 2025-01-05 13:30                                     ` Ihor Radchenko
  2025-01-10  9:42                                       ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-05 13:30 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> The reason is that, with the former definition, children will be bound to
> `(nil)' in the call to org-element-create, while in the latter it will
> be bound to `nil'. The root of the problem is that
>
> (org-element-create 'foo (list ...))
> (org-element-create 'foo (list ...) nil)
>
> are not equivalent; in particular
>
> (org-element-contents (org-element-create 'foo (list ...))) ; => nil
> (org-element-contents (org-element-create 'foo (list ...) nil)) ; => (nil)

I see.
In other words, you want to make
(org-element-create 'foo (list ...) children)
work when CHILDREN=nil

I think I can just add a special case to `org-element-create':
when CHILDREN is (nil), ignore it.

Does it make sense?

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-05 13:30                                     ` Ihor Radchenko
@ 2025-01-10  9:42                                       ` Richard Lawrence
  2025-01-12  9:04                                         ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-10  9:42 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> I think I can just add a special case to `org-element-create':
> when CHILDREN is (nil), ignore it.
>
> Does it make sense?

That would be enough for my purposes. I don't know if it's enough for
Org's (and worry that the change might introduce hard-to-find bugs). I
wonder therefore if it might be better to create a wrapper with a
different argument list like

(defun org-element-create* (type &optional props children)
  (if children 
      (apply #'org-element-create type props children)
     (org-element-create type props))

But either would be fine with me.

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-05  8:33                             ` Ihor Radchenko
@ 2025-01-10  9:48                               ` Richard Lawrence
  2025-01-10 18:32                                 ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-10  9:48 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> I think that the simplest approach could be just leaving
> `org-element--standard-properties' constant, but stuffing it with truly
> generic properties that are common for all the possible parsers.
>
> WDYT?

Well, it doesn't seem ideal, but maybe it's sufficient.

Another idea: could one use aliasing or symbol properties somehow to
allow library users to "rename" standard properties they don't need? All
that really needs to happen dynamically is mapping a keyword to an array
index, right?

Best,
Richard



^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-10  9:48                               ` Richard Lawrence
@ 2025-01-10 18:32                                 ` Ihor Radchenko
  2025-01-11 17:44                                   ` Richard Lawrence
  0 siblings, 1 reply; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-10 18:32 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

>> I think that the simplest approach could be just leaving
>> `org-element--standard-properties' constant, but stuffing it with truly
>> generic properties that are common for all the possible parsers.
>>
>> WDYT?
>
> Well, it doesn't seem ideal, but maybe it's sufficient.
>
> Another idea: could one use aliasing or symbol properties somehow to
> allow library users to "rename" standard properties they don't need? All
> that really needs to happen dynamically is mapping a keyword to an array
> index, right?

The whole idea behind standard properties is that they are resolved
statically, at compile time. Adding any kind of dynamic resolution will
defeat their purpose (speed).

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-10 18:32                                 ` Ihor Radchenko
@ 2025-01-11 17:44                                   ` Richard Lawrence
  2025-01-12  8:15                                     ` Ihor Radchenko
  0 siblings, 1 reply; 64+ messages in thread
From: Richard Lawrence @ 2025-01-11 17:44 UTC (permalink / raw)
  To: Ihor Radchenko; +Cc: emacs-devel

Ihor Radchenko <yantar92@posteo.net> writes:

> Richard Lawrence <rwl@recursewithless.net> writes:
>
>> Another idea: could one use aliasing or symbol properties somehow to
>> allow library users to "rename" standard properties they don't need? All
>> that really needs to happen dynamically is mapping a keyword to an array
>> index, right?
>
> The whole idea behind standard properties is that they are resolved
> statically, at compile time. Adding any kind of dynamic resolution will
> defeat their purpose (speed).

Sorry, maybe "dynamically" was a poor word choice...I guess I meant
something more like "statically, but outside org-element-ast.el, in the
calling program".

I looked briefly at the definition of org-element--property-idx and at
its disassembly, which makes it look like one can actually do something
like what I was suggesting by modifying the property list
org-element--standard-properties-idxs, like:

(let ((org-element--standard-properties-idxs
       (plist-put org-element--standard-properties-idxs
                  :value 5))) ;; use the :post-blank slot for :value instead
   ...)

but maybe I'm not understanding something. Would modifying this plist
from the calling code work as a strategy for "renaming" the standard
properties slots?






^ permalink raw reply	[flat|nested] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-11 17:44                                   ` Richard Lawrence
@ 2025-01-12  8:15                                     ` Ihor Radchenko
  0 siblings, 0 replies; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-12  8:15 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

Richard Lawrence <rwl@recursewithless.net> writes:

> I looked briefly at the definition of org-element--property-idx and at
> its disassembly, which makes it look like one can actually do something
> like what I was suggesting by modifying the property list
> org-element--standard-properties-idxs, like:
>
> (let ((org-element--standard-properties-idxs
>        (plist-put org-element--standard-properties-idxs
>                   :value 5))) ;; use the :post-blank slot for :value instead
>    ...)
>
> but maybe I'm not understanding something. Would modifying this plist
> from the calling code work as a strategy for "renaming" the standard
> properties slots?

It might work, but you will need to wrap your code into the let above.
I think that it is what I suggested at the very beginning:

> > The only thing coming to my mind is asking the libraries to use
> >
> > (let ((org-element--standard-properties <custom value>))
> >   (defun library-x (...)
> >     ...))
> 
> Personally I think this would be a bit much to ask...it would be fairly
> annoying to have to wrap all one's functions like this, even if there
> was a macro to do it.

-- 
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] 64+ messages in thread

* Re: Upstreaming org-element-ast (was: Improving Emacs' iCalendar support)
  2025-01-10  9:42                                       ` Richard Lawrence
@ 2025-01-12  9:04                                         ` Ihor Radchenko
  0 siblings, 0 replies; 64+ messages in thread
From: Ihor Radchenko @ 2025-01-12  9:04 UTC (permalink / raw)
  To: Richard Lawrence; +Cc: emacs-devel

[-- Attachment #1: Type: text/plain, Size: 744 bytes --]

Richard Lawrence <rwl@recursewithless.net> writes:

> Ihor Radchenko <yantar92@posteo.net> writes:
>
>> I think I can just add a special case to `org-element-create':
>> when CHILDREN is (nil), ignore it.
>>
>> Does it make sense?
>
> That would be enough for my purposes. I don't know if it's enough for
> Org's (and worry that the change might introduce hard-to-find bugs). I
> wonder therefore if it might be better to create a wrapper with a
> different argument list like ...

I think that yet another function will simply add to the confusion.
As for bugs, org-element-ast has tests that should prevent such issues.

Attaching tentative patch that will make `org-element-create' ignore
nils in CHILDREN. nils are not valid nodes anyway.


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-org-element-create-Ignore-nils-in-CHILDREN.patch --]
[-- Type: text/x-patch, Size: 4510 bytes --]

From 59d425a1af9829825d771ead63f73efe614044ba Mon Sep 17 00:00:00 2001
Message-ID: <59d425a1af9829825d771ead63f73efe614044ba.1736672541.git.yantar92@posteo.net>
From: Ihor Radchenko <yantar92@posteo.net>
Date: Sun, 12 Jan 2025 10:01:24 +0100
Subject: [PATCH] org-element-create: Ignore nils in CHILDREN

* lisp/org-element-ast.el (org-element-create): When CHILDREN contain
nil entries, ignore them.
* testing/lisp/test-org-element.el (test-org-element/org-element-create):
Add more test cases.
* etc/ORG-NEWS (~org-element-create~ now ignores ~nil~s in CHILDREN argument):
Announce the change.

Link: https://yhetil.org/emacs-devel/87sepr2ee5.fsf@recursewithless.net
---
 etc/ORG-NEWS                     | 11 +++++++++++
 lisp/org-element-ast.el          | 16 ++++++++++++----
 testing/lisp/test-org-element.el | 10 +++++++++-
 3 files changed, 32 insertions(+), 5 deletions(-)

diff --git a/etc/ORG-NEWS b/etc/ORG-NEWS
index aebd0dedd7..adc48f3044 100644
--- a/etc/ORG-NEWS
+++ b/etc/ORG-NEWS
@@ -365,6 +365,17 @@ elisp level ~org-datetree-find-create-entry~ and
 ~org-datetree-find-date-create~, ~org-datetree-find-month-create~, and
 ~org-datetree-find-iso-week-create~ to new datetree types.
 
+*** ~org-element-create~ now ignores ~nil~s in CHILDREN argument
+
+When CHILDREN contains ~nil~ elements, they are skipped.  This way,
+
+#+begin_src emacs-lisp
+(let ((children nil))
+  (org-element-create 'section nil children)) ; => (section nil)
+#+end_src
+
+will yield expected results rather than assigning literal ~nil~ as a child.
+
 ** Removed or renamed functions and variables
 
 *** ~org-cycle-display-inline-images~ is renamed to ~org-cycle-display-link-previews~
diff --git a/lisp/org-element-ast.el b/lisp/org-element-ast.el
index 69a37c26a1..f56a76a28a 100644
--- a/lisp/org-element-ast.el
+++ b/lisp/org-element-ast.el
@@ -729,6 +729,11 @@ (defun org-element-create (type &optional props &rest children)
 will yield expected results with contents of another node adopted into
 a newly created one.
 
+nil elements in CHILDREN are ignored.  This way,
+   (let ((children nil))
+     (org-element-create \\='section nil children))
+will yield expected results.
+
 When TYPE is `plain-text', CHILDREN must contain a single node -
 string.  Alternatively, TYPE can be a string.  When TYPE is nil or
 `anonymous', PROPS must be nil."
@@ -736,6 +741,12 @@ (defun org-element-create (type &optional props &rest children)
    ;; FIXME: Just use `plistp' from Emacs 29 when available.
    (let ((len (proper-list-p props)))
      (and len (zerop (% len 2)))))
+  ;; Special case: CHILDREN is a single anonymous node
+  (when (and (= 1 (length children))
+             (org-element-type-p (car children) 'anonymous))
+    (setq children (car children)))
+  ;; Filter out nil values from CHILDREN
+  (setq children (delq nil children))
   ;; Assign parray.
   (when (and props (not (stringp type)) (not (eq type 'plain-text)))
     (let ((node (list 'dummy props)))
@@ -762,10 +773,7 @@ (defun org-element-create (type &optional props &rest children)
     ((pred stringp)
      (if props (org-add-props type props) type))
     (_
-     (if (and (= 1 (length children))
-              (org-element-type-p (car children) 'anonymous))
-         (apply #'org-element-adopt (list type props) (car children))
-       (apply #'org-element-adopt (list type props) children)))))
+     (apply #'org-element-adopt (list type props) children))))
 
 (defun org-element-copy (datum &optional keep-contents)
   "Return a copy of DATUM.
diff --git a/testing/lisp/test-org-element.el b/testing/lisp/test-org-element.el
index ad96c3106d..d4ec00fba3 100644
--- a/testing/lisp/test-org-element.el
+++ b/testing/lisp/test-org-element.el
@@ -515,7 +515,15 @@ (ert-deftest test-org-element/org-element-create ()
   ;; Children
   (let ((children '("a" "b" (org-element-create 'foo))))
     (should (equal (cddr (apply #'org-element-create 'bar nil children))
-                   children))))
+                   children)))
+  (let ((children nil))
+    (should (equal (cddr (org-element-create 'bar nil children))
+                   children))
+    (should (equal (cddr (apply #'org-element-create 'bar nil children))
+                   children)))
+  (let ((children '("foo" nil "bar")))
+    (should (equal (cddr (apply #'org-element-create 'bar nil children))
+                   (delq nil children)))))
 
 (ert-deftest test-org-element/put-property ()
   "Test `org-element-put-property' specifications."
-- 
2.47.1


[-- Attachment #3: Type: text/plain, Size: 223 bytes --]


-- 
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 related	[flat|nested] 64+ messages in thread

end of thread, other threads:[~2025-01-12  9:04 UTC | newest]

Thread overview: 64+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-18  9:01 Improving Emacs' iCalendar support Richard Lawrence
2024-10-18  9:24 ` Eli Zaretskii
2024-10-19  8:22   ` Richard Lawrence
2024-10-19 10:11     ` Eli Zaretskii
2024-10-20  5:08       ` Richard Lawrence
2024-10-20  5:21         ` Eli Zaretskii
2024-10-18 12:58 ` Sebastián Monía
2024-10-19  8:28   ` Richard Lawrence
2024-10-19  5:44 ` Adam Porter
2024-10-19  8:39   ` Richard Lawrence
2024-10-20  3:09     ` Adam Porter
2024-10-22 18:40     ` Ihor Radchenko
2024-10-23  7:29       ` Björn Bidar
     [not found]       ` <87plnr6zvk.fsf@>
2024-10-23  8:09         ` Ihor Radchenko
2024-10-23  9:05         ` Richard Lawrence
2024-10-23 10:03           ` Björn Bidar
2024-10-23  9:01       ` Richard Lawrence
2024-10-23 20:24         ` Ferdinand Pieper
2024-10-24 14:52           ` Richard Lawrence
2024-10-24 17:45             ` Ihor Radchenko
2024-10-25 12:53               ` Richard Lawrence
2024-10-25 18:59                 ` Ihor Radchenko
2024-10-21  6:10 ` Björn Bidar
2024-10-21  6:22 ` Visuwesh
2024-10-23  9:15   ` Richard Lawrence
2024-10-23  9:45     ` Visuwesh
     [not found] ` <87wmi29eaf.fsf@>
2024-10-26 17:49   ` Ihor Radchenko
2024-10-28 10:44     ` Björn Bidar
     [not found]     ` <87r080tslf.fsf@>
2024-10-28 19:09       ` Ihor Radchenko
2024-11-23  8:44 ` Richard Lawrence
2024-11-24  9:50   ` Eli Zaretskii
2024-11-24 10:21     ` Ihor Radchenko
2024-11-24 10:41       ` Eli Zaretskii
2024-11-24 10:58         ` Ihor Radchenko
2024-11-24 11:08           ` Eli Zaretskii
2024-11-24 11:21             ` Upstreaming org-element-ast (was: Improving Emacs' iCalendar support) Ihor Radchenko
2024-11-24 12:55               ` Eli Zaretskii
2024-12-25 11:31                 ` Ihor Radchenko
2024-12-29 20:19                   ` Richard Lawrence
2024-12-29 20:53                     ` Richard Lawrence
2024-12-30 17:18                       ` Ihor Radchenko
2024-12-30 17:16                     ` bug#74994: " Ihor Radchenko
2024-12-31  7:55                       ` Richard Lawrence
2025-01-01  9:29                         ` Ihor Radchenko
2025-01-01 12:38                           ` Richard Lawrence
2025-01-02 18:03                             ` Ihor Radchenko
2025-01-02 20:01                               ` Richard Lawrence
2025-01-02 20:09                                 ` Ihor Radchenko
2025-01-05  9:52                                   ` Richard Lawrence
2025-01-05 13:30                                     ` Ihor Radchenko
2025-01-10  9:42                                       ` Richard Lawrence
2025-01-12  9:04                                         ` Ihor Radchenko
2025-01-01 13:01                           ` Richard Lawrence
2025-01-05  8:33                             ` Ihor Radchenko
2025-01-10  9:48                               ` Richard Lawrence
2025-01-10 18:32                                 ` Ihor Radchenko
2025-01-11 17:44                                   ` Richard Lawrence
2025-01-12  8:15                                     ` Ihor Radchenko
2024-11-25  9:09     ` Improving Emacs' iCalendar support Richard Lawrence
2024-11-25 12:42       ` Eli Zaretskii
2024-11-25 13:03         ` Rudolf Schlatte
2024-11-25 13:36           ` Eli Zaretskii
2024-11-25 17:14           ` Richard Lawrence
2024-12-20 13:21 ` Richard Lawrence

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).