From: Thorsten Jolitz <tjolitz@gmail.com>
To: emacs-orgmode@gnu.org
Subject: How to deal with 'contents' in (derived) exporter backend
Date: Mon, 04 Nov 2013 13:30:48 +0100 [thread overview]
Message-ID: <87r4awjqmf.fsf@gmail.com> (raw)
Hi List,
assume I want to derive an exporter backend from ox-org.el, and there
are just a few new transcoder functions, so all other elements/object
should be exported as Org-syntax (with inherited function
`org-org-identity').
Using this example Org-snippet
#+begin_src org
* A1
Text *A1*
** A2
Text *A2*
* B1
Text *B1*
** B2
Text *B2*
#+end_src
I get something like this if I write a transcoder function for 'headline'
ignoring argument 'contents' (don't bother with the details please):
#+begin_src emacs-lisp
(org-data nil "(headline (title-string \"A1\"
alt-title-string \"A1\" category \"tmp5\" level 1 priority nil tags nil
todo-keyword nil quotedp nil archivedp nil commentedp nil footnote-secion-p
nil))
(headline (title-string \"B1\" alt-title-string \"B1\" category \"tmp5\" level
1 priority nil tags nil todo-keyword nil quotedp nil archivedp nil commentedp
nil footnote-secion-p nil)) ")
#+end_src
Only the two 1st level headlines are successfully transcoded, their content is
missing.
But when I use something like this in the headline transcode function
#+begin_src emacs-lisp
(format "(headline %S %s) "
[... return headline string ...]
contents)
#+end_src
I get the parse-tree structure as output instead of elements/object
in their original Org text syntax as expected:
#+begin_src emacs-lisp
(org-data nil "(headline (title-string \"A1\" alt-title-string \"A1\"
category \"tmp5\" level 1 priority nil tags nil todo-keyword nil
quotedp nil archivedp nil commentedp nil footnote-secion-p nil)
(section (#(\"Text *A1* \" 0 5 (:parent (paragraph (:begin 6 :end 16
:contents-begin 6 :contents-end 16 :post-blank 0 :post-affiliated 6
:parent (section (:begin 6 :end 16 :contents-begin 6 :contents-end 16
:post-blank 0 :parent (headline (:raw-value \"A1\" :begin 1 :end 32
:pre-blank 0 :contents-begin 6 :contents-end 32 :level 1 :priority nil
:tags [...]
#+end_src
Note that I have a simple filter-function for section that looks like this:
#+begin_src emacs-lisp
(defun org-iorg-data-filter-section-function (section backend info)
(format "(section (%S))" section))
#+end_src
I'm sure there is some misunderstanding on my side here. I would expect
that all elements/objects inside the section have already been
transcoded back to Org-syntax when this filter is applied, so I should
not see parse-tree structures in the output.
I had a look at other backends for inspiration on how to deal with
'contents' in my headline transcoder function, e.g.
#+begin_src emacs-lisp
(defun org-html-section (section contents info)
[...]
;; Build return value.
(format "<div class=\"outline-text-%d\" id=\"text-%s\">\n%s</div>"
class-num
(or (org-element-property :CUSTOM_ID parent) section-number)
contents)))))
#+end_src
but that looks to me just how I treated 'contents' above.
Any tips would be appreciated.
--
cheers,
Thorsten
next reply other threads:[~2013-11-04 12:31 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-04 12:30 Thorsten Jolitz [this message]
2013-11-05 20:21 ` How to deal with 'contents' in (derived) exporter backend Nicolas Goaziou
2013-11-06 14:36 ` Thorsten Jolitz
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.orgmode.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87r4awjqmf.fsf@gmail.com \
--to=tjolitz@gmail.com \
--cc=emacs-orgmode@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).