Re: [O] [PATCH] Export of irc links in ox-html
Hello, Jay Kamat writes: > I need to stop forgetting to do this :). > > I've attached a patch which adds an entry to the 'Miscellaneous' > section. Please let me know if you think anything is wrong with it. It looks goods. Applied. Thank you. Regards, -- Nicolas Goaziou
Re: [O] [PATCH] Export of irc links in ox-html
Hi Nicolas, > Would you mind providing an ORG-NEWS entry about it? I need to stop forgetting to do this :). I've attached a patch which adds an entry to the 'Miscellaneous' section. Please let me know if you think anything is wrong with it. -Jay >From e321f926217460a506d6536ad494b1f25c247c4b Mon Sep 17 00:00:00 2001 From: Jay Kamat Date: Sun, 24 Sep 2017 21:30:39 -0400 Subject: [PATCH] ORG-NEWS: Add an entry for supporting export in org-irc.el --- etc/ORG-NEWS | 6 ++ 1 file changed, 6 insertions(+) diff --git a/etc/ORG-NEWS b/etc/ORG-NEWS index d2fb264b18..7c69efa89d 100644 --- a/etc/ORG-NEWS +++ b/etc/ORG-NEWS @@ -108,6 +108,12 @@ you should expect to see something like: ** Miscellaneous *** ~org-publish-resolve-external-link~ accepts a new optional argument. +*** ~org-irc.el~ now supports exporting =irc:= links properly + +Previously, irc links were exported by ~ox-md~ and ~ox-html~ as normal +file links, which lead to them being broken in web browsers. Now both +of these exporters will properly export to =irc:= links, which will +open properly in irc clients from web browsers. * Version 9.1 -- 2.11.0
Re: [O] [PATCH] Export of irc links in ox-html
Jay Kamat writes: > I've attached a second patch which adds a new function to org-irc.el, > which seems to handle export of irc links in ox-md and ox-html > properly. I'm very new to this system, so please make sure it's correct, > and I'll be happy to follow up with corrections if it isn't! Thank you! > Because I added support for md links in org-irc.el, I also removed the > workaround I added a while back for that in ox-md.el. Good catch. > +(defun org-irc-export (link description format) > + "Export an info link. I applied your patch with info changed into IRC above. Would you mind providing an ORG-NEWS entry about it? Regards,
Re: [O] [PATCH] Export of irc links in ox-html
Hi Nicolas, > The proper fix would be to patch "org-irc.el" and add an export function > there. "irc" links are not default links in Org, so there is no reason > to hard-code them in "ox-html.el". Thanks for pointing that out! I didn't even realize up until now org had support for custom link types. I've attached a second patch which adds a new function to org-irc.el, which seems to handle export of irc links in ox-md and ox-html properly. I'm very new to this system, so please make sure it's correct, and I'll be happy to follow up with corrections if it isn't! Because I added support for md links in org-irc.el, I also removed the workaround I added a while back for that in ox-md.el. -Jay >From e6c824f363bf6959f0eb35e4b8208a14d2cbffcb Mon Sep 17 00:00:00 2001 From: Jay Kamat Date: Sun, 24 Sep 2017 12:11:52 -0400 Subject: [PATCH] org-irc.el: Add proper export functions for irc * lisp/org-irc.el (org-irc-export): Add a new function, org-irc-export, which properly exports irc links to html and markdown * lisp/ox-md.el (org-md-link): Remove workaround to get irc links working properly in ox-md, and use org-irc's export functions instead --- lisp/org-irc.el | 20 +++- lisp/ox-md.el | 2 +- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/lisp/org-irc.el b/lisp/org-irc.el index 5889f6d2fe..eee71aef52 100644 --- a/lisp/org-irc.el +++ b/lisp/org-irc.el @@ -71,7 +71,10 @@ ;; Generic functions/config (extend these for other clients) -(org-link-set-parameters "irc" :follow #'org-irc-visit :store #'org-irc-store-link) +(org-link-set-parameters "irc" + :follow #'org-irc-visit + :store #'org-irc-store-link + :export #'org-irc-export) (defun org-irc-visit (link) "Parse LINK and dispatch to the correct function based on the client found." @@ -245,6 +248,21 @@ default." ;; no server match, make new connection (erc-select :server server :port port +(defun org-irc-export (link description format) + "Export an info link. +See `org-link-parameters' for details about LINK, DESCRIPTION and FORMAT." + (let* ((desc (or description link))) +(pcase format + (`html + (format "%s" + link + desc)) + (`md + (format "[%s](irc:%s)" + desc + link)) + (_ nil + (provide 'org-irc) ;; Local variables: diff --git a/lisp/ox-md.el b/lisp/ox-md.el index 5ba52e7faf..146956eedf 100644 --- a/lisp/ox-md.el +++ b/lisp/ox-md.el @@ -449,7 +449,7 @@ a communication channel." (t (let* ((raw-path (org-element-property :path link)) (path (cond - ((member type '("http" "https" "ftp" "mailto" "irc")) + ((member type '("http" "https" "ftp" "mailto")) (concat type ":" raw-path)) ((string= type "file") (org-export-file-uri (funcall link-org-files-as-md raw-path))) -- 2.11.0
Re: [O] [PATCH] Export of irc links in ox-html
Hello, Jay Kamat writes: > IRC links in ox-html are currently broken. They are not handled, which is slightly different. > There exists a special 'irc' > content handler on the web, telling browsers to open an irc link in an > external irc client. The format for such links seems identical to org > (irc:irc.freenode.net/user). > > Previously links such as: > > [[irc:irc.freenode.net/test][Irc link]] > > Would export to > > Irc link > > in ox-html. The proper fix would be to patch "org-irc.el" and add an export function there. "irc" links are not default links in Org, so there is no reason to hard-code them in "ox-html.el". You can look into `org-info-export' in "org-info.el", which is an example on how optional link types are handled. Thank you! Regards, -- Nicolas Goaziou