| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967 | 
							- ;;; ox-ascii.el --- ASCII Back-End for Org Export Engine
 
- ;; Copyright (C) 2012-2013 Free Software Foundation, Inc.
 
- ;; Author: Nicolas Goaziou <n.goaziou at gmail dot com>
 
- ;; Keywords: outlines, hypermedia, calendar, wp
 
- ;; This file is part of GNU Emacs.
 
- ;; GNU Emacs is free software: you can redistribute it and/or modify
 
- ;; it under the terms of the GNU General Public License as published by
 
- ;; the Free Software Foundation, either version 3 of the License, or
 
- ;; (at your option) any later version.
 
- ;; GNU Emacs is distributed in the hope that it will be useful,
 
- ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
 
- ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
- ;; GNU General Public License for more details.
 
- ;; You should have received a copy of the GNU General Public License
 
- ;; along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.
 
- ;;; Commentary:
 
- ;;
 
- ;; This library implements an ASCII back-end for Org generic exporter.
 
- ;; See Org manual for more information.
 
- ;;; Code:
 
- (eval-when-compile (require 'cl))
 
- (require 'ox)
 
- (require 'ox-publish)
 
- (declare-function aa2u "ext:ascii-art-to-unicode" ())
 
- ;;; Define Back-End
 
- ;;
 
- ;; The following setting won't allow to modify preferred charset
 
- ;; through a buffer keyword or an option item, but, since the property
 
- ;; will appear in communication channel nonetheless, it allows to
 
- ;; override `org-ascii-charset' variable on the fly by the ext-plist
 
- ;; mechanism.
 
- ;;
 
- ;; We also install a filter for headlines and sections, in order to
 
- ;; control blank lines separating them in output string.
 
- (org-export-define-backend 'ascii
 
-   '((bold . org-ascii-bold)
 
-     (center-block . org-ascii-center-block)
 
-     (clock . org-ascii-clock)
 
-     (code . org-ascii-code)
 
-     (comment . (lambda (&rest args) ""))
 
-     (comment-block . (lambda (&rest args) ""))
 
-     (drawer . org-ascii-drawer)
 
-     (dynamic-block . org-ascii-dynamic-block)
 
-     (entity . org-ascii-entity)
 
-     (example-block . org-ascii-example-block)
 
-     (export-block . org-ascii-export-block)
 
-     (export-snippet . org-ascii-export-snippet)
 
-     (fixed-width . org-ascii-fixed-width)
 
-     (footnote-reference . org-ascii-footnote-reference)
 
-     (headline . org-ascii-headline)
 
-     (horizontal-rule . org-ascii-horizontal-rule)
 
-     (inline-src-block . org-ascii-inline-src-block)
 
-     (inlinetask . org-ascii-inlinetask)
 
-     (inner-template . org-ascii-inner-template)
 
-     (italic . org-ascii-italic)
 
-     (item . org-ascii-item)
 
-     (keyword . org-ascii-keyword)
 
-     (latex-environment . org-ascii-latex-environment)
 
-     (latex-fragment . org-ascii-latex-fragment)
 
-     (line-break . org-ascii-line-break)
 
-     (link . org-ascii-link)
 
-     (node-property . org-ascii-node-property)
 
-     (paragraph . org-ascii-paragraph)
 
-     (plain-list . org-ascii-plain-list)
 
-     (plain-text . org-ascii-plain-text)
 
-     (planning . org-ascii-planning)
 
-     (property-drawer . org-ascii-property-drawer)
 
-     (quote-block . org-ascii-quote-block)
 
-     (quote-section . org-ascii-quote-section)
 
-     (radio-target . org-ascii-radio-target)
 
-     (section . org-ascii-section)
 
-     (special-block . org-ascii-special-block)
 
-     (src-block . org-ascii-src-block)
 
-     (statistics-cookie . org-ascii-statistics-cookie)
 
-     (strike-through . org-ascii-strike-through)
 
-     (subscript . org-ascii-subscript)
 
-     (superscript . org-ascii-superscript)
 
-     (table . org-ascii-table)
 
-     (table-cell . org-ascii-table-cell)
 
-     (table-row . org-ascii-table-row)
 
-     (target . org-ascii-target)
 
-     (template . org-ascii-template)
 
-     (timestamp . org-ascii-timestamp)
 
-     (underline . org-ascii-underline)
 
-     (verbatim . org-ascii-verbatim)
 
-     (verse-block . org-ascii-verse-block))
 
-   :export-block "ASCII"
 
-   :menu-entry
 
-   '(?t "Export to Plain Text"
 
-        ((?A "As ASCII buffer"
 
- 	    (lambda (a s v b)
 
- 	      (org-ascii-export-as-ascii a s v b '(:ascii-charset ascii))))
 
- 	(?a "As ASCII file"
 
- 	    (lambda (a s v b)
 
- 	      (org-ascii-export-to-ascii a s v b '(:ascii-charset ascii))))
 
- 	(?L "As Latin1 buffer"
 
- 	    (lambda (a s v b)
 
- 	      (org-ascii-export-as-ascii a s v b '(:ascii-charset latin1))))
 
- 	(?l "As Latin1 file"
 
- 	    (lambda (a s v b)
 
- 	      (org-ascii-export-to-ascii a s v b '(:ascii-charset latin1))))
 
- 	(?U "As UTF-8 buffer"
 
- 	    (lambda (a s v b)
 
- 	      (org-ascii-export-as-ascii a s v b '(:ascii-charset utf-8))))
 
- 	(?u "As UTF-8 file"
 
- 	    (lambda (a s v b)
 
- 	      (org-ascii-export-to-ascii a s v b '(:ascii-charset utf-8))))))
 
-   :filters-alist '((:filter-headline . org-ascii-filter-headline-blank-lines)
 
- 		   (:filter-parse-tree org-ascii-filter-paragraph-spacing
 
- 				       org-ascii-filter-comment-spacing)
 
- 		   (:filter-section . org-ascii-filter-headline-blank-lines))
 
-   :options-alist '((:ascii-charset nil nil org-ascii-charset)))
 
- ;;; User Configurable Variables
 
- (defgroup org-export-ascii nil
 
-   "Options for exporting Org mode files to ASCII."
 
-   :tag "Org Export ASCII"
 
-   :group 'org-export)
 
- (defcustom org-ascii-text-width 72
 
-   "Maximum width of exported text.
 
- This number includes margin size, as set in
 
- `org-ascii-global-margin'."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'integer)
 
- (defcustom org-ascii-global-margin 0
 
-   "Width of the left margin, in number of characters."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'integer)
 
- (defcustom org-ascii-inner-margin 2
 
-   "Width of the inner margin, in number of characters.
 
- Inner margin is applied between each headline."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'integer)
 
- (defcustom org-ascii-quote-margin 6
 
-   "Width of margin used for quoting text, in characters.
 
- This margin is applied on both sides of the text."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'integer)
 
- (defcustom org-ascii-inlinetask-width 30
 
-   "Width of inline tasks, in number of characters.
 
- This number ignores any margin."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'integer)
 
- (defcustom org-ascii-headline-spacing '(1 . 2)
 
-   "Number of blank lines inserted around headlines.
 
- This variable can be set to a cons cell.  In that case, its car
 
- represents the number of blank lines present before headline
 
- contents whereas its cdr reflects the number of blank lines after
 
- contents.
 
- A nil value replicates the number of blank lines found in the
 
- original Org buffer at the same place."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type '(choice
 
- 	  (const :tag "Replicate original spacing" nil)
 
- 	  (cons :tag "Set an uniform spacing"
 
- 		(integer :tag "Number of blank lines before contents")
 
- 		(integer :tag "Number of blank lines after contents"))))
 
- (defcustom org-ascii-indented-line-width 'auto
 
-   "Additional indentation width for the first line in a paragraph.
 
- If the value is an integer, indent the first line of each
 
- paragraph by this number.  If it is the symbol `auto' preserve
 
- indentation from original document."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type '(choice
 
- 	  (integer :tag "Number of white spaces characters")
 
- 	  (const :tag "Preserve original width" auto)))
 
- (defcustom org-ascii-paragraph-spacing 'auto
 
-   "Number of white lines between paragraphs.
 
- If the value is an integer, add this number of blank lines
 
- between contiguous paragraphs.  If is it the symbol `auto', keep
 
- the same number of blank lines as in the original document."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type '(choice
 
- 	  (integer :tag "Number of blank lines")
 
- 	  (const :tag "Preserve original spacing" auto)))
 
- (defcustom org-ascii-charset 'ascii
 
-   "The charset allowed to represent various elements and objects.
 
- Possible values are:
 
- `ascii'    Only use plain ASCII characters
 
- `latin1'   Include Latin-1 characters
 
- `utf-8'    Use all UTF-8 characters"
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type '(choice
 
- 	  (const :tag "ASCII" ascii)
 
- 	  (const :tag "Latin-1" latin1)
 
- 	  (const :tag "UTF-8" utf-8)))
 
- (defcustom org-ascii-underline '((ascii ?= ?~ ?-)
 
- 				 (latin1 ?= ?~ ?-)
 
- 				 (utf-8 ?═ ?─ ?╌ ?┄ ?┈))
 
-   "Characters for underlining headings in ASCII export.
 
- Alist whose key is a symbol among `ascii', `latin1' and `utf-8'
 
- and whose value is a list of characters.
 
- For each supported charset, this variable associates a sequence
 
- of underline characters.  In a sequence, the characters will be
 
- used in order for headlines level 1, 2, ...  If no character is
 
- available for a given level, the headline won't be underlined."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type '(list
 
- 	  (cons :tag "Underline characters sequence"
 
- 		(const :tag "ASCII charset" ascii)
 
- 		(repeat character))
 
- 	  (cons :tag "Underline characters sequence"
 
- 		(const :tag "Latin-1 charset" latin1)
 
- 		(repeat character))
 
- 	  (cons :tag "Underline characters sequence"
 
- 		(const :tag "UTF-8 charset" utf-8)
 
- 		(repeat character))))
 
- (defcustom org-ascii-bullets '((ascii ?* ?+ ?-)
 
- 			       (latin1 ?§ ?¶)
 
- 			       (utf-8 ?◊))
 
-   "Bullet characters for headlines converted to lists in ASCII export.
 
- Alist whose key is a symbol among `ascii', `latin1' and `utf-8'
 
- and whose value is a list of characters.
 
- The first character is used for the first level considered as low
 
- level, and so on.  If there are more levels than characters given
 
- here, the list will be repeated.
 
- Note that this variable doesn't affect plain lists
 
- representation."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type '(list
 
- 	  (cons :tag "Bullet characters for low level headlines"
 
- 		(const :tag "ASCII charset" ascii)
 
- 		(repeat character))
 
- 	  (cons :tag "Bullet characters for low level headlines"
 
- 		(const :tag "Latin-1 charset" latin1)
 
- 		(repeat character))
 
- 	  (cons :tag "Bullet characters for low level headlines"
 
- 		(const :tag "UTF-8 charset" utf-8)
 
- 		(repeat character))))
 
- (defcustom org-ascii-links-to-notes t
 
-   "Non-nil means convert links to notes before the next headline.
 
- When nil, the link will be exported in place.  If the line
 
- becomes long in this way, it will be wrapped."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'boolean)
 
- (defcustom org-ascii-table-keep-all-vertical-lines nil
 
-   "Non-nil means keep all vertical lines in ASCII tables.
 
- When nil, vertical lines will be removed except for those needed
 
- for column grouping."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'boolean)
 
- (defcustom org-ascii-table-widen-columns t
 
-   "Non-nil means widen narrowed columns for export.
 
- When nil, narrowed columns will look in ASCII export just like in
 
- Org mode, i.e. with \"=>\" as ellipsis."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'boolean)
 
- (defcustom org-ascii-table-use-ascii-art nil
 
-   "Non-nil means table.el tables are turned into ascii-art.
 
- It only makes sense when export charset is `utf-8'.  It is nil by
 
- default since it requires ascii-art-to-unicode.el package.  You
 
- can download it here:
 
-   http://gnuvola.org/software/j/aa2u/ascii-art-to-unicode.el."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'boolean)
 
- (defcustom org-ascii-caption-above nil
 
-   "When non-nil, place caption string before the element.
 
- Otherwise, place it right after it."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'boolean)
 
- (defcustom org-ascii-verbatim-format "`%s'"
 
-   "Format string used for verbatim text and inline code."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'string)
 
- (defcustom org-ascii-format-drawer-function
 
-   (lambda (name contents width) contents)
 
-   "Function called to format a drawer in ASCII.
 
- The function must accept three parameters:
 
-   NAME      the drawer name, like \"LOGBOOK\"
 
-   CONTENTS  the contents of the drawer.
 
-   WIDTH     the text width within the drawer.
 
- The function should return either the string to be exported or
 
- nil to ignore the drawer.
 
- The default value simply returns the value of CONTENTS."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.0")
 
-   :type 'function)
 
- (defcustom org-ascii-format-inlinetask-function
 
-   'org-ascii-format-inlinetask-default
 
-   "Function called to format an inlinetask in ASCII.
 
- The function must accept nine parameters:
 
-   TODO       the todo keyword, as a string
 
-   TODO-TYPE  the todo type, a symbol among `todo', `done' and nil.
 
-   PRIORITY   the inlinetask priority, as a string
 
-   NAME       the inlinetask name, as a string.
 
-   TAGS       the inlinetask tags, as a list of strings.
 
-   CONTENTS   the contents of the inlinetask, as a string.
 
-   WIDTH      the width of the inlinetask, as a number.
 
-   INLINETASK the inlinetask itself.
 
-   INFO       the info channel.
 
- The function should return either the string to be exported or
 
- nil to ignore the inline task."
 
-   :group 'org-export-ascii
 
-   :version "24.4"
 
-   :package-version '(Org . "8.3")
 
-   :type 'function)
 
- ;;; Internal Functions
 
- ;; Internal functions fall into three categories.
 
- ;; The first one is about text formatting.  The core function is
 
- ;; `org-ascii--current-text-width', which determines the current
 
- ;; text width allowed to a given element.  In other words, it helps
 
- ;; keeping each line width within maximum text width defined in
 
- ;; `org-ascii-text-width'.  Once this information is known,
 
- ;; `org-ascii--fill-string', `org-ascii--justify-string',
 
- ;; `org-ascii--box-string' and `org-ascii--indent-string' can
 
- ;; operate on a given output string.
 
- ;; The second category contains functions handling elements listings,
 
- ;; triggered by "#+TOC:" keyword.  As such, `org-ascii--build-toc'
 
- ;; returns a complete table of contents, `org-ascii--list-listings'
 
- ;; returns a list of referenceable src-block elements, and
 
- ;; `org-ascii--list-tables' does the same for table elements.
 
- ;; The third category includes general helper functions.
 
- ;; `org-ascii--build-title' creates the title for a given headline
 
- ;; or inlinetask element.  `org-ascii--build-caption' returns the
 
- ;; caption string associated to a table or a src-block.
 
- ;; `org-ascii--describe-links' creates notes about links for
 
- ;; insertion at the end of a section.  It uses
 
- ;; `org-ascii--unique-links' to get the list of links to describe.
 
- ;; Eventually, `org-ascii--translate' translates a string according
 
- ;; to language and charset specification.
 
- (defun org-ascii--fill-string (s text-width info &optional justify)
 
-   "Fill a string with specified text-width and return it.
 
- S is the string being filled.  TEXT-WIDTH is an integer
 
- specifying maximum length of a line.  INFO is the plist used as
 
- a communication channel.
 
- Optional argument JUSTIFY can specify any type of justification
 
- among `left', `center', `right' or `full'.  A nil value is
 
- equivalent to `left'.  For a justification that doesn't also fill
 
- string, see `org-ascii--justify-string'.
 
- Return nil if S isn't a string."
 
-   ;; Don't fill paragraph when break should be preserved.
 
-   (cond ((not (stringp s)) nil)
 
- 	((plist-get info :preserve-breaks) s)
 
- 	(t (let ((double-space-p sentence-end-double-space))
 
- 	     (with-temp-buffer
 
- 	       (let ((fill-column text-width)
 
- 		     (use-hard-newlines t)
 
- 		     (sentence-end-double-space double-space-p))
 
- 		 (insert s)
 
- 		 (fill-region (point-min) (point-max) justify))
 
- 	       (buffer-string))))))
 
- (defun org-ascii--justify-string (s text-width how)
 
-   "Justify string S.
 
- TEXT-WIDTH is an integer specifying maximum length of a line.
 
- HOW determines the type of justification: it can be `left',
 
- `right', `full' or `center'."
 
-   (with-temp-buffer
 
-     (insert s)
 
-     (goto-char (point-min))
 
-     (let ((fill-column text-width)
 
- 	  ;; Disable `adaptive-fill-mode' so it doesn't prevent
 
- 	  ;; filling lines matching `adaptive-fill-regexp'.
 
- 	  (adaptive-fill-mode nil))
 
-       (while (< (point) (point-max))
 
- 	(justify-current-line how)
 
- 	(forward-line)))
 
-     (buffer-string)))
 
- (defun org-ascii--indent-string (s width)
 
-   "Indent string S by WIDTH white spaces.
 
- Empty lines are not indented."
 
-   (when (stringp s)
 
-     (replace-regexp-in-string
 
-      "\\(^\\)\\(?:.*\\S-\\)" (make-string width ? ) s nil nil 1)))
 
- (defun org-ascii--box-string (s info)
 
-   "Return string S with a partial box to its left.
 
- INFO is a plist used as a communicaton channel."
 
-   (let ((utf8p (eq (plist-get info :ascii-charset) 'utf-8)))
 
-     (format (if utf8p "╭────\n%s\n╰────" ",----\n%s\n`----")
 
- 	    (replace-regexp-in-string
 
- 	     "^" (if utf8p "│ " "| ")
 
- 	     ;; Remove last newline character.
 
- 	     (replace-regexp-in-string "\n[ \t]*\\'" "" s)))))
 
- (defun org-ascii--current-text-width (element info)
 
-   "Return maximum text width for ELEMENT's contents.
 
- INFO is a plist used as a communication channel."
 
-   (case (org-element-type element)
 
-     ;; Elements with an absolute width: `headline' and `inlinetask'.
 
-     (inlinetask org-ascii-inlinetask-width)
 
-     ('headline
 
-      (- org-ascii-text-width
 
- 	(let ((low-level-rank (org-export-low-level-p element info)))
 
- 	  (if low-level-rank (* low-level-rank 2) org-ascii-global-margin))))
 
-     ;; Elements with a relative width: store maximum text width in
 
-     ;; TOTAL-WIDTH.
 
-     (otherwise
 
-      (let* ((genealogy (cons element (org-export-get-genealogy element)))
 
- 	    ;; Total width is determined by the presence, or not, of an
 
- 	    ;; inline task among ELEMENT parents.
 
- 	    (total-width
 
- 	     (if (loop for parent in genealogy
 
- 		       thereis (eq (org-element-type parent) 'inlinetask))
 
- 		 org-ascii-inlinetask-width
 
- 	       ;; No inlinetask: Remove global margin from text width.
 
- 	       (- org-ascii-text-width
 
- 		  org-ascii-global-margin
 
- 		  (let ((parent (org-export-get-parent-headline element)))
 
- 		    ;; Inner margin doesn't apply to text before first
 
- 		    ;; headline.
 
- 		    (if (not parent) 0
 
- 		      (let ((low-level-rank
 
- 			     (org-export-low-level-p parent info)))
 
- 			;; Inner margin doesn't apply to contents of
 
- 			;; low level headlines, since they've got their
 
- 			;; own indentation mechanism.
 
- 			(if low-level-rank (* low-level-rank 2)
 
- 			  org-ascii-inner-margin))))))))
 
-        (- total-width
 
- 	  ;; Each `quote-block', `quote-section' and `verse-block' above
 
- 	  ;; narrows text width by twice the standard margin size.
 
- 	  (+ (* (loop for parent in genealogy
 
- 		      when (memq (org-element-type parent)
 
- 				 '(quote-block quote-section verse-block))
 
- 		      count parent)
 
- 		2 org-ascii-quote-margin)
 
- 	     ;; Text width within a plain-list is restricted by
 
- 	     ;; indentation of current item.  If that's the case,
 
- 	     ;; compute it with the help of `:structure' property from
 
- 	     ;; parent item, if any.
 
- 	     (let ((parent-item
 
- 		    (if (eq (org-element-type element) 'item) element
 
- 		      (loop for parent in genealogy
 
- 			    when (eq (org-element-type parent) 'item)
 
- 			    return parent))))
 
- 	       (if (not parent-item) 0
 
- 		 ;; Compute indentation offset of the current item,
 
- 		 ;; that is the sum of the difference between its
 
- 		 ;; indentation and the indentation of the top item in
 
- 		 ;; the list and current item bullet's length.  Also
 
- 		 ;; remove checkbox length, and tag length (for
 
- 		 ;; description lists) or bullet length.
 
- 		 (let ((struct (org-element-property :structure parent-item))
 
- 		       (beg-item (org-element-property :begin parent-item)))
 
- 		   (+ (- (org-list-get-ind beg-item struct)
 
- 			 (org-list-get-ind
 
- 			  (org-list-get-top-point struct) struct))
 
- 		      (length (org-ascii--checkbox parent-item info))
 
- 		      (length
 
- 		       (or (org-list-get-tag beg-item struct)
 
- 			   (org-list-get-bullet beg-item struct)))))))))))))
 
- (defun org-ascii--build-title
 
-   (element info text-width &optional underline notags toc)
 
-   "Format ELEMENT title and return it.
 
- ELEMENT is either an `headline' or `inlinetask' element.  INFO is
 
- a plist used as a communication channel.  TEXT-WIDTH is an
 
- integer representing the maximum length of a line.
 
- When optional argument UNDERLINE is non-nil, underline title,
 
- without the tags, according to `org-ascii-underline'
 
- specifications.
 
- If optional argument NOTAGS is non-nil, no tags will be added to
 
- the title.
 
- When optional argument TOC is non-nil, use optional title if
 
- possible.  It doesn't apply to `inlinetask' elements."
 
-   (let* ((headlinep (eq (org-element-type element) 'headline))
 
- 	 (numbers
 
- 	  ;; Numbering is specific to headlines.
 
- 	  (and headlinep (org-export-numbered-headline-p element info)
 
- 	       ;; All tests passed: build numbering string.
 
- 	       (concat
 
- 		(mapconcat
 
- 		 'number-to-string
 
- 		 (org-export-get-headline-number element info) ".")
 
- 		" ")))
 
- 	 (text
 
- 	  (org-trim
 
- 	   (org-export-data
 
- 	    (if (and toc headlinep) (org-export-get-alt-title element info)
 
- 	      (org-element-property :title element))
 
- 	    info)))
 
- 	 (todo
 
- 	  (and (plist-get info :with-todo-keywords)
 
- 	       (let ((todo (org-element-property :todo-keyword element)))
 
- 		 (and todo (concat (org-export-data todo info) " ")))))
 
- 	 (tags (and (not notags)
 
- 		    (plist-get info :with-tags)
 
- 		    (let ((tag-list (org-export-get-tags element info)))
 
- 		      (and tag-list
 
- 			   (format ":%s:"
 
- 				   (mapconcat 'identity tag-list ":"))))))
 
- 	 (priority
 
- 	  (and (plist-get info :with-priority)
 
- 	       (let ((char (org-element-property :priority element)))
 
- 		 (and char (format "(#%c) " char)))))
 
- 	 (first-part (concat numbers todo priority text)))
 
-     (concat
 
-      first-part
 
-      ;; Align tags, if any.
 
-      (when tags
 
-        (format
 
- 	(format " %%%ds"
 
- 		(max (- text-width  (1+ (length first-part))) (length tags)))
 
- 	tags))
 
-      ;; Maybe underline text, if ELEMENT type is `headline' and an
 
-      ;; underline character has been defined.
 
-      (when (and underline headlinep)
 
-        (let ((under-char
 
- 	      (nth (1- (org-export-get-relative-level element info))
 
- 		   (cdr (assq (plist-get info :ascii-charset)
 
- 			      org-ascii-underline)))))
 
- 	 (and under-char
 
- 	      (concat "\n"
 
- 		      (make-string (length first-part) under-char))))))))
 
- (defun org-ascii--has-caption-p (element info)
 
-   "Non-nil when ELEMENT has a caption affiliated keyword.
 
- INFO is a plist used as a communication channel.  This function
 
- is meant to be used as a predicate for `org-export-get-ordinal'."
 
-   (org-element-property :caption element))
 
- (defun org-ascii--build-caption (element info)
 
-   "Return caption string for ELEMENT, if applicable.
 
- INFO is a plist used as a communication channel.
 
- The caption string contains the sequence number of ELEMENT along
 
- with its real caption.  Return nil when ELEMENT has no affiliated
 
- caption keyword."
 
-   (let ((caption (org-export-get-caption element)))
 
-     (when caption
 
-       ;; Get sequence number of current src-block among every
 
-       ;; src-block with a caption.
 
-       (let ((reference
 
- 	     (org-export-get-ordinal
 
- 	      element info nil 'org-ascii--has-caption-p))
 
- 	    (title-fmt (org-ascii--translate
 
- 			(case (org-element-type element)
 
- 			  (table "Table %d:")
 
- 			  (src-block "Listing %d:"))
 
- 			info)))
 
- 	(org-ascii--fill-string
 
- 	 (concat (format title-fmt reference)
 
- 		 " "
 
- 		 (org-export-data caption info))
 
- 	 (org-ascii--current-text-width element info) info)))))
 
- (defun org-ascii--build-toc (info &optional n keyword)
 
-   "Return a table of contents.
 
- INFO is a plist used as a communication channel.
 
- Optional argument N, when non-nil, is an integer specifying the
 
- depth of the table.
 
- Optional argument KEYWORD specifies the TOC keyword, if any, from
 
- which the table of contents generation has been initiated."
 
-   (let ((title (org-ascii--translate "Table of Contents" info)))
 
-     (concat
 
-      title "\n"
 
-      (make-string (length title)
 
- 		  (if (eq (plist-get info :ascii-charset) 'utf-8) ?─ ?_))
 
-      "\n\n"
 
-      (let ((text-width
 
- 	    (if keyword (org-ascii--current-text-width keyword info)
 
- 	      (- org-ascii-text-width org-ascii-global-margin))))
 
-        (mapconcat
 
- 	(lambda (headline)
 
- 	  (let* ((level (org-export-get-relative-level headline info))
 
- 		 (indent (* (1- level) 3)))
 
- 	    (concat
 
- 	     (unless (zerop indent) (concat (make-string (1- indent) ?.) " "))
 
- 	     (org-ascii--build-title
 
- 	      headline info (- text-width indent) nil
 
- 	      (or (not (plist-get info :with-tags))
 
- 		  (eq (plist-get info :with-tags) 'not-in-toc))
 
- 	      'toc))))
 
- 	(org-export-collect-headlines info n) "\n")))))
 
- (defun org-ascii--list-listings (keyword info)
 
-   "Return a list of listings.
 
- KEYWORD is the keyword that initiated the list of listings
 
- generation.  INFO is a plist used as a communication channel."
 
-   (let ((title (org-ascii--translate "List of Listings" info)))
 
-     (concat
 
-      title "\n"
 
-      (make-string (length title)
 
- 		  (if (eq (plist-get info :ascii-charset) 'utf-8) ?─ ?_))
 
-      "\n\n"
 
-      (let ((text-width
 
- 	    (if keyword (org-ascii--current-text-width keyword info)
 
- 	      (- org-ascii-text-width org-ascii-global-margin)))
 
- 	   ;; Use a counter instead of retreiving ordinal of each
 
- 	   ;; src-block.
 
- 	   (count 0))
 
-        (mapconcat
 
- 	(lambda (src-block)
 
- 	  ;; Store initial text so its length can be computed.  This is
 
- 	  ;; used to properly align caption right to it in case of
 
- 	  ;; filling (like contents of a description list item).
 
- 	  (let ((initial-text
 
- 		 (format (org-ascii--translate "Listing %d:" info)
 
- 			 (incf count))))
 
- 	    (concat
 
- 	     initial-text " "
 
- 	     (org-trim
 
- 	      (org-ascii--indent-string
 
- 	       (org-ascii--fill-string
 
- 		;; Use short name in priority, if available.
 
- 		(let ((caption (or (org-export-get-caption src-block t)
 
- 				   (org-export-get-caption src-block))))
 
- 		  (org-export-data caption info))
 
- 		(- text-width (length initial-text)) info)
 
- 	       (length initial-text))))))
 
- 	(org-export-collect-listings info) "\n")))))
 
- (defun org-ascii--list-tables (keyword info)
 
-   "Return a list of tables.
 
- KEYWORD is the keyword that initiated the list of tables
 
- generation.  INFO is a plist used as a communication channel."
 
-   (let ((title (org-ascii--translate "List of Tables" info)))
 
-     (concat
 
-      title "\n"
 
-      (make-string (length title)
 
- 		  (if (eq (plist-get info :ascii-charset) 'utf-8) ?─ ?_))
 
-      "\n\n"
 
-      (let ((text-width
 
- 	    (if keyword (org-ascii--current-text-width keyword info)
 
- 	      (- org-ascii-text-width org-ascii-global-margin)))
 
- 	   ;; Use a counter instead of retreiving ordinal of each
 
- 	   ;; src-block.
 
- 	   (count 0))
 
-        (mapconcat
 
- 	(lambda (table)
 
- 	  ;; Store initial text so its length can be computed.  This is
 
- 	  ;; used to properly align caption right to it in case of
 
- 	  ;; filling (like contents of a description list item).
 
- 	  (let ((initial-text
 
- 		 (format (org-ascii--translate "Table %d:" info)
 
- 			 (incf count))))
 
- 	    (concat
 
- 	     initial-text " "
 
- 	     (org-trim
 
- 	      (org-ascii--indent-string
 
- 	       (org-ascii--fill-string
 
- 		;; Use short name in priority, if available.
 
- 		(let ((caption (or (org-export-get-caption table t)
 
- 				   (org-export-get-caption table))))
 
- 		  (org-export-data caption info))
 
- 		(- text-width (length initial-text)) info)
 
- 	       (length initial-text))))))
 
- 	(org-export-collect-tables info) "\n")))))
 
- (defun org-ascii--unique-links (element info)
 
-   "Return a list of unique link references in ELEMENT.
 
- ELEMENT is either a headline element or a section element.  INFO
 
- is a plist used as a communication channel."
 
-   (let* (seen
 
- 	 (unique-link-p
 
- 	  (function
 
- 	   ;; Return LINK if it wasn't referenced so far, or nil.
 
- 	   ;; Update SEEN links along the way.
 
- 	   (lambda (link)
 
- 	     (let ((footprint
 
- 		    (cons (org-element-property :raw-link link)
 
- 			  (org-element-contents link))))
 
- 	       ;; Ignore LINK if it hasn't been translated already.
 
- 	       ;; It can happen if it is located in an affiliated
 
- 	       ;; keyword that was ignored.
 
- 	       (when (and (org-string-nw-p
 
- 			   (gethash link (plist-get info :exported-data)))
 
- 			  (not (member footprint seen)))
 
- 		 (push footprint seen) link)))))
 
- 	 ;; If at a section, find parent headline, if any, in order to
 
- 	 ;; count links that might be in the title.
 
- 	 (headline
 
- 	  (if (eq (org-element-type element) 'headline) element
 
- 	    (or (org-export-get-parent-headline element) element))))
 
-     ;; Get all links in HEADLINE.
 
-     (org-element-map headline 'link
 
-       (lambda (l) (funcall unique-link-p l)) info nil nil t)))
 
- (defun org-ascii--describe-links (links width info)
 
-   "Return a string describing a list of links.
 
- LINKS is a list of link type objects, as returned by
 
- `org-ascii--unique-links'.  WIDTH is the text width allowed for
 
- the output string.  INFO is a plist used as a communication
 
- channel."
 
-   (mapconcat
 
-    (lambda (link)
 
-      (let ((type (org-element-property :type link))
 
- 	   (anchor (let ((desc (org-element-contents link)))
 
- 		     (if desc (org-export-data desc info)
 
- 		       (org-element-property :raw-link link)))))
 
-        (cond
 
- 	;; Coderefs, radio links and fuzzy links are ignored.
 
- 	((member type '("coderef" "radio" "fuzzy")) nil)
 
- 	;; Id and custom-id links: Headlines refer to their numbering.
 
- 	((member type '("custom-id" "id"))
 
- 	 (let ((dest (org-export-resolve-id-link link info)))
 
- 	   (concat
 
- 	    (org-ascii--fill-string
 
- 	     (format
 
- 	      "[%s] %s"
 
- 	      anchor
 
- 	      (if (not dest) (org-ascii--translate "Unknown reference" info)
 
- 		(format
 
- 		 (org-ascii--translate "See section %s" info)
 
- 		 (mapconcat 'number-to-string
 
- 			    (org-export-get-headline-number dest info) "."))))
 
- 	     width info) "\n\n")))
 
- 	;; Do not add a link that cannot be resolved and doesn't have
 
- 	;; any description: destination is already visible in the
 
- 	;; paragraph.
 
- 	((not (org-element-contents link)) nil)
 
- 	(t
 
- 	 (concat
 
- 	  (org-ascii--fill-string
 
- 	   (format "[%s] %s" anchor (org-element-property :raw-link link))
 
- 	   width info)
 
- 	  "\n\n")))))
 
-    links ""))
 
- (defun org-ascii--checkbox (item info)
 
-   "Return checkbox string for ITEM or nil.
 
- INFO is a plist used as a communication channel."
 
-   (let ((utf8p (eq (plist-get info :ascii-charset) 'utf-8)))
 
-     (case (org-element-property :checkbox item)
 
-       (on (if utf8p "☑ " "[X] "))
 
-       (off (if utf8p "☐ " "[ ] "))
 
-       (trans (if utf8p "☒ " "[-] ")))))
 
- ;;; Template
 
- (defun org-ascii-template--document-title (info)
 
-   "Return document title, as a string.
 
- INFO is a plist used as a communication channel."
 
-   (let* ((text-width org-ascii-text-width)
 
- 	 ;; Links in the title will not be resolved later, so we make
 
- 	 ;; sure their path is located right after them.
 
- 	 (org-ascii-links-to-notes nil)
 
- 	 (title (org-export-data (plist-get info :title) info))
 
- 	 (author (and (plist-get info :with-author)
 
- 		      (let ((auth (plist-get info :author)))
 
- 			(and auth (org-export-data auth info)))))
 
- 	 (email (and (plist-get info :with-email)
 
- 		     (org-export-data (plist-get info :email) info)))
 
- 	 (date (and (plist-get info :with-date)
 
- 		    (org-export-data (org-export-get-date info) info))))
 
-     ;; There are two types of title blocks depending on the presence
 
-     ;; of a title to display.
 
-     (if (string= title "")
 
- 	;; Title block without a title.  DATE is positioned at the top
 
- 	;; right of the document, AUTHOR to the top left and EMAIL
 
- 	;; just below.
 
- 	(cond
 
- 	 ((and (org-string-nw-p date) (org-string-nw-p author))
 
- 	  (concat
 
- 	   author
 
- 	   (make-string (- text-width (length date) (length author)) ? )
 
- 	   date
 
- 	   (when (org-string-nw-p email) (concat "\n" email))
 
- 	   "\n\n\n"))
 
- 	 ((and (org-string-nw-p date) (org-string-nw-p email))
 
- 	  (concat
 
- 	   email
 
- 	   (make-string (- text-width (length date) (length email)) ? )
 
- 	   date "\n\n\n"))
 
- 	 ((org-string-nw-p date)
 
- 	  (concat
 
- 	   (org-ascii--justify-string date text-width 'right)
 
- 	   "\n\n\n"))
 
- 	 ((and (org-string-nw-p author) (org-string-nw-p email))
 
- 	  (concat author "\n" email "\n\n\n"))
 
- 	 ((org-string-nw-p author) (concat author "\n\n\n"))
 
- 	 ((org-string-nw-p email) (concat email "\n\n\n")))
 
-       ;; Title block with a title.  Document's TITLE, along with the
 
-       ;; AUTHOR and its EMAIL are both overlined and an underlined,
 
-       ;; centered.  Date is just below, also centered.
 
-       (let* ((utf8p (eq (plist-get info :ascii-charset) 'utf-8))
 
- 	     ;; Format TITLE.  It may be filled if it is too wide,
 
- 	     ;; that is wider than the two thirds of the total width.
 
- 	     (title-len (min (length title) (/ (* 2 text-width) 3)))
 
- 	     (formatted-title (org-ascii--fill-string title title-len info))
 
- 	     (line
 
- 	      (make-string
 
- 	       (min (+ (max title-len (length author) (length email)) 2)
 
- 		    text-width) (if utf8p ?━ ?_))))
 
- 	(org-ascii--justify-string
 
- 	 (concat line "\n"
 
- 		 (unless utf8p "\n")
 
- 		 (upcase formatted-title)
 
- 		 (cond
 
- 		  ((and (org-string-nw-p author) (org-string-nw-p email))
 
- 		   (concat (if utf8p "\n\n\n" "\n\n") author "\n" email))
 
- 		  ((org-string-nw-p author)
 
- 		   (concat (if utf8p "\n\n\n" "\n\n") author))
 
- 		  ((org-string-nw-p email)
 
- 		   (concat (if utf8p "\n\n\n" "\n\n") email)))
 
- 		 "\n" line
 
- 		 (when (org-string-nw-p date) (concat "\n\n\n" date))
 
- 		 "\n\n\n") text-width 'center)))))
 
- (defun org-ascii-inner-template (contents info)
 
-   "Return complete document string after ASCII conversion.
 
- CONTENTS is the transcoded contents string.  INFO is a plist
 
- holding export options."
 
-   (org-element-normalize-string
 
-    (org-ascii--indent-string
 
-     (concat
 
-      ;; 1. Document's body.
 
-      contents
 
-      ;; 2. Footnote definitions.
 
-      (let ((definitions (org-export-collect-footnote-definitions
 
- 			 (plist-get info :parse-tree) info))
 
- 	   ;; Insert full links right inside the footnote definition
 
- 	   ;; as they have no chance to be inserted later.
 
- 	   (org-ascii-links-to-notes nil))
 
-        (when definitions
 
- 	 (concat
 
- 	  "\n\n\n"
 
- 	  (let ((title (org-ascii--translate "Footnotes" info)))
 
- 	    (concat
 
- 	     title "\n"
 
- 	     (make-string
 
- 	      (length title)
 
- 	      (if (eq (plist-get info :ascii-charset) 'utf-8) ?─ ?_))))
 
- 	  "\n\n"
 
- 	  (let ((text-width (- org-ascii-text-width org-ascii-global-margin)))
 
- 	    (mapconcat
 
- 	     (lambda (ref)
 
- 	       (let ((id (format "[%s] " (car ref))))
 
- 		 ;; Distinguish between inline definitions and
 
- 		 ;; full-fledged definitions.
 
- 		 (org-trim
 
- 		  (let ((def (nth 2 ref)))
 
- 		    (if (eq (org-element-type def) 'org-data)
 
- 			;; Full-fledged definition: footnote ID is
 
- 			;; inserted inside the first parsed paragraph
 
- 			;; (FIRST), if any, to be sure filling will
 
- 			;; take it into consideration.
 
- 			(let ((first (car (org-element-contents def))))
 
- 			  (if (not (eq (org-element-type first) 'paragraph))
 
- 			      (concat id "\n" (org-export-data def info))
 
- 			    (push id (nthcdr 2 first))
 
- 			    (org-export-data def info)))
 
- 		      ;; Fill paragraph once footnote ID is inserted
 
- 		      ;; in order to have a correct length for first
 
- 		      ;; line.
 
- 		      (org-ascii--fill-string
 
- 		       (concat id (org-export-data def info))
 
- 		       text-width info))))))
 
- 	     definitions "\n\n"))))))
 
-     org-ascii-global-margin)))
 
- (defun org-ascii-template (contents info)
 
-   "Return complete document string after ASCII conversion.
 
- CONTENTS is the transcoded contents string.  INFO is a plist
 
- holding export options."
 
-   (concat
 
-    ;; 1. Build title block.
 
-    (org-ascii--indent-string
 
-     (concat (org-ascii-template--document-title info)
 
- 	    ;; 2. Table of contents.
 
- 	    (let ((depth (plist-get info :with-toc)))
 
- 	      (when depth
 
- 		(concat
 
- 		 (org-ascii--build-toc info (and (wholenump depth) depth))
 
- 		 "\n\n\n"))))
 
-     org-ascii-global-margin)
 
-    ;; 3. Document's body.
 
-    contents
 
-    ;; 4. Creator.  Ignore `comment' value as there are no comments in
 
-    ;;    ASCII.  Justify it to the bottom right.
 
-    (org-ascii--indent-string
 
-     (let ((creator-info (plist-get info :with-creator))
 
- 	  (text-width (- org-ascii-text-width org-ascii-global-margin)))
 
-       (unless (or (not creator-info) (eq creator-info 'comment))
 
- 	(concat
 
- 	 "\n\n\n"
 
- 	 (org-ascii--fill-string
 
- 	  (plist-get info :creator) text-width info 'right))))
 
-     org-ascii-global-margin)))
 
- (defun org-ascii--translate (s info)
 
-   "Translate string S according to specified language and charset.
 
- INFO is a plist used as a communication channel."
 
-   (let ((charset (intern (format ":%s" (plist-get info :ascii-charset)))))
 
-     (org-export-translate s charset info)))
 
- ;;; Transcode Functions
 
- ;;;; Bold
 
- (defun org-ascii-bold (bold contents info)
 
-   "Transcode BOLD from Org to ASCII.
 
- CONTENTS is the text with bold markup.  INFO is a plist holding
 
- contextual information."
 
-   (format "*%s*" contents))
 
- ;;;; Center Block
 
- (defun org-ascii-center-block (center-block contents info)
 
-   "Transcode a CENTER-BLOCK element from Org to ASCII.
 
- CONTENTS holds the contents of the block.  INFO is a plist
 
- holding contextual information."
 
-   (org-ascii--justify-string
 
-    contents (org-ascii--current-text-width center-block info) 'center))
 
- ;;;; Clock
 
- (defun org-ascii-clock (clock contents info)
 
-   "Transcode a CLOCK object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (concat org-clock-string " "
 
- 	  (org-translate-time
 
- 	   (org-element-property :raw-value
 
- 				 (org-element-property :value clock)))
 
- 	  (let ((time (org-element-property :duration clock)))
 
- 	    (and time
 
- 		 (concat " => "
 
- 			 (apply 'format
 
- 				"%2s:%02s"
 
- 				(org-split-string time ":")))))))
 
- ;;;; Code
 
- (defun org-ascii-code (code contents info)
 
-   "Return a CODE object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (format org-ascii-verbatim-format (org-element-property :value code)))
 
- ;;;; Drawer
 
- (defun org-ascii-drawer (drawer contents info)
 
-   "Transcode a DRAWER element from Org to ASCII.
 
- CONTENTS holds the contents of the block.  INFO is a plist
 
- holding contextual information."
 
-   (let ((name (org-element-property :drawer-name drawer))
 
- 	(width (org-ascii--current-text-width drawer info)))
 
-     (funcall org-ascii-format-drawer-function name contents width)))
 
- ;;;; Dynamic Block
 
- (defun org-ascii-dynamic-block (dynamic-block contents info)
 
-   "Transcode a DYNAMIC-BLOCK element from Org to ASCII.
 
- CONTENTS holds the contents of the block.  INFO is a plist
 
- holding contextual information."
 
-   contents)
 
- ;;;; Entity
 
- (defun org-ascii-entity (entity contents info)
 
-   "Transcode an ENTITY object from Org to ASCII.
 
- CONTENTS are the definition itself.  INFO is a plist holding
 
- contextual information."
 
-   (org-element-property
 
-    (intern (concat ":" (symbol-name (plist-get info :ascii-charset))))
 
-    entity))
 
- ;;;; Example Block
 
- (defun org-ascii-example-block (example-block contents info)
 
-   "Transcode a EXAMPLE-BLOCK element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (org-ascii--box-string
 
-    (org-export-format-code-default example-block info) info))
 
- ;;;; Export Snippet
 
- (defun org-ascii-export-snippet (export-snippet contents info)
 
-   "Transcode a EXPORT-SNIPPET object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (when (eq (org-export-snippet-backend export-snippet) 'ascii)
 
-     (org-element-property :value export-snippet)))
 
- ;;;; Export Block
 
- (defun org-ascii-export-block (export-block contents info)
 
-   "Transcode a EXPORT-BLOCK element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (when (string= (org-element-property :type export-block) "ASCII")
 
-     (org-remove-indentation (org-element-property :value export-block))))
 
- ;;;; Fixed Width
 
- (defun org-ascii-fixed-width (fixed-width contents info)
 
-   "Transcode a FIXED-WIDTH element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (org-ascii--box-string
 
-    (org-remove-indentation
 
-     (org-element-property :value fixed-width)) info))
 
- ;;;; Footnote Definition
 
- ;; Footnote Definitions are ignored.  They are compiled at the end of
 
- ;; the document, by `org-ascii-inner-template'.
 
- ;;;; Footnote Reference
 
- (defun org-ascii-footnote-reference (footnote-reference contents info)
 
-   "Transcode a FOOTNOTE-REFERENCE element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (format "[%s]" (org-export-get-footnote-number footnote-reference info)))
 
- ;;;; Headline
 
- (defun org-ascii-headline (headline contents info)
 
-   "Transcode a HEADLINE element from Org to ASCII.
 
- CONTENTS holds the contents of the headline.  INFO is a plist
 
- holding contextual information."
 
-   ;; Don't export footnote section, which will be handled at the end
 
-   ;; of the template.
 
-   (unless (org-element-property :footnote-section-p headline)
 
-     (let* ((low-level-rank (org-export-low-level-p headline info))
 
- 	   (width (org-ascii--current-text-width headline info))
 
- 	   ;; Blank lines between headline and its contents.
 
- 	   ;; `org-ascii-headline-spacing', when set, overwrites
 
- 	   ;; original buffer's spacing.
 
- 	   (pre-blanks
 
- 	    (make-string
 
- 	     (if org-ascii-headline-spacing (car org-ascii-headline-spacing)
 
- 	       (org-element-property :pre-blank headline)) ?\n))
 
- 	   ;; Even if HEADLINE has no section, there might be some
 
- 	   ;; links in its title that we shouldn't forget to describe.
 
- 	   (links
 
- 	    (unless (or (eq (caar (org-element-contents headline)) 'section))
 
- 	      (let ((title (org-element-property :title headline)))
 
- 		(when (consp title)
 
- 		  (org-ascii--describe-links
 
- 		   (org-ascii--unique-links title info) width info))))))
 
-       ;; Deep subtree: export it as a list item.
 
-       (if low-level-rank
 
- 	  (concat
 
- 	   ;; Bullet.
 
- 	   (let ((bullets (cdr (assq (plist-get info :ascii-charset)
 
- 				     org-ascii-bullets))))
 
- 	     (char-to-string
 
- 	      (nth (mod (1- low-level-rank) (length bullets)) bullets)))
 
- 	   " "
 
- 	   ;; Title.
 
- 	   (org-ascii--build-title headline info width) "\n"
 
- 	   ;; Contents, indented by length of bullet.
 
- 	   pre-blanks
 
- 	   (org-ascii--indent-string
 
- 	    (concat contents
 
- 		    (when (org-string-nw-p links) (concat "\n\n" links)))
 
- 	    2))
 
- 	;; Else: Standard headline.
 
- 	(concat
 
- 	 (org-ascii--build-title headline info width 'underline)
 
- 	 "\n" pre-blanks
 
- 	 (concat (when (org-string-nw-p links) links) contents))))))
 
- ;;;; Horizontal Rule
 
- (defun org-ascii-horizontal-rule (horizontal-rule contents info)
 
-   "Transcode an HORIZONTAL-RULE object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (let ((text-width (org-ascii--current-text-width horizontal-rule info))
 
- 	(spec-width
 
- 	 (org-export-read-attribute :attr_ascii horizontal-rule :width)))
 
-     (org-ascii--justify-string
 
-      (make-string (if (and spec-width (string-match "^[0-9]+$" spec-width))
 
- 		      (string-to-number spec-width)
 
- 		    text-width)
 
- 		  (if (eq (plist-get info :ascii-charset) 'utf-8) ?― ?-))
 
-      text-width 'center)))
 
- ;;;; Inline Src Block
 
- (defun org-ascii-inline-src-block (inline-src-block contents info)
 
-   "Transcode an INLINE-SRC-BLOCK element from Org to ASCII.
 
- CONTENTS holds the contents of the item.  INFO is a plist holding
 
- contextual information."
 
-   (format org-ascii-verbatim-format
 
- 	  (org-element-property :value inline-src-block)))
 
- ;;;; Inlinetask
 
- (defun org-ascii-format-inlinetask-default
 
-     (todo type priority name tags contents width inlinetask info)
 
-   "Format an inline task element for ASCII export.
 
- See `org-ascii-format-inlinetask-function' for a description
 
- of the paramaters."
 
-   (let* ((utf8p (eq (plist-get info :ascii-charset) 'utf-8))
 
- 	 (width (or width org-ascii-inlinetask-width)))
 
-     (org-ascii--indent-string
 
-      (concat
 
-       ;; Top line, with an additional blank line if not in UTF-8.
 
-       (make-string width (if utf8p ?━ ?_)) "\n"
 
-       (unless utf8p (concat (make-string width ? ) "\n"))
 
-       ;; Add title.  Fill it if wider than inlinetask.
 
-       (let ((title (org-ascii--build-title inlinetask info width)))
 
- 	(if (<= (length title) width) title
 
- 	  (org-ascii--fill-string title width info)))
 
-       "\n"
 
-       ;; If CONTENTS is not empty, insert it along with
 
-       ;; a separator.
 
-       (when (org-string-nw-p contents)
 
-         (concat (make-string width (if utf8p ?─ ?-)) "\n" contents))
 
-       ;; Bottom line.
 
-       (make-string width (if utf8p ?━ ?_)))
 
-      ;; Flush the inlinetask to the right.
 
-      (- org-ascii-text-width org-ascii-global-margin
 
- 	(if (not (org-export-get-parent-headline inlinetask)) 0
 
- 	  org-ascii-inner-margin)
 
- 	(org-ascii--current-text-width inlinetask info)))))
 
- (defun org-ascii-inlinetask (inlinetask contents info)
 
-   "Transcode an INLINETASK element from Org to ASCII.
 
- CONTENTS holds the contents of the block.  INFO is a plist
 
- holding contextual information."
 
-   (let ((width (org-ascii--current-text-width inlinetask info)))
 
-     (funcall org-ascii-format-inlinetask-function
 
- 	     ;; todo.
 
- 	     (and (plist-get info :with-todo-keywords)
 
- 		  (let ((todo (org-element-property
 
- 			       :todo-keyword inlinetask)))
 
- 		    (and todo (org-export-data todo info))))
 
- 	     ;; todo-type
 
- 	     (org-element-property :todo-type inlinetask)
 
- 	     ;; priority
 
- 	     (and (plist-get info :with-priority)
 
- 		  (org-element-property :priority inlinetask))
 
- 	     ;; title
 
- 	     (org-export-data (org-element-property :title inlinetask) info)
 
- 	     ;; tags
 
- 	     (and (plist-get info :with-tags)
 
- 		  (org-element-property :tags inlinetask))
 
- 	     ;; contents and width
 
- 	     contents width inlinetask info)))
 
- ;;;; Italic
 
- (defun org-ascii-italic (italic contents info)
 
-   "Transcode italic from Org to ASCII.
 
- CONTENTS is the text with italic markup.  INFO is a plist holding
 
- contextual information."
 
-   (format "/%s/" contents))
 
- ;;;; Item
 
- (defun org-ascii-item (item contents info)
 
-   "Transcode an ITEM element from Org to ASCII.
 
- CONTENTS holds the contents of the item.  INFO is a plist holding
 
- contextual information."
 
-   (let* ((utf8p (eq (plist-get info :ascii-charset) 'utf-8))
 
- 	 (checkbox (org-ascii--checkbox item info))
 
- 	 (list-type (org-element-property :type (org-export-get-parent item)))
 
- 	 (bullet
 
- 	  ;; First parent of ITEM is always the plain-list.  Get
 
- 	  ;; `:type' property from it.
 
- 	  (org-list-bullet-string
 
- 	   (case list-type
 
- 	     (descriptive
 
- 	      (concat checkbox
 
- 		      (org-export-data (org-element-property :tag item) info)
 
- 		      ": "))
 
- 	     (ordered
 
- 	      ;; Return correct number for ITEM, paying attention to
 
- 	      ;; counters.
 
- 	      (let* ((struct (org-element-property :structure item))
 
- 		     (bul (org-element-property :bullet item))
 
- 		     (num (number-to-string
 
- 			   (car (last (org-list-get-item-number
 
- 				       (org-element-property :begin item)
 
- 				       struct
 
- 				       (org-list-prevs-alist struct)
 
- 				       (org-list-parents-alist struct)))))))
 
- 		(replace-regexp-in-string "[0-9]+" num bul)))
 
- 	     (t (let ((bul (org-element-property :bullet item)))
 
- 		  ;; Change bullets into more visible form if UTF-8 is active.
 
- 		  (if (not utf8p) bul
 
- 		    (replace-regexp-in-string
 
- 		     "-" "•"
 
- 		     (replace-regexp-in-string
 
- 		      "+" "⁃"
 
- 		      (replace-regexp-in-string "*" "‣" bul))))))))))
 
-     (concat
 
-      bullet
 
-      (unless (eq list-type 'descriptive) checkbox)
 
-      ;; Contents: Pay attention to indentation.  Note: check-boxes are
 
-      ;; already taken care of at the paragraph level so they don't
 
-      ;; interfere with indentation.
 
-      (let ((contents (org-ascii--indent-string contents (length bullet))))
 
-        (if (eq (org-element-type (car (org-element-contents item))) 'paragraph)
 
- 	   (org-trim contents)
 
- 	 (concat "\n" contents))))))
 
- ;;;; Keyword
 
- (defun org-ascii-keyword (keyword contents info)
 
-   "Transcode a KEYWORD element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (let ((key (org-element-property :key keyword))
 
- 	(value (org-element-property :value keyword)))
 
-     (cond
 
-      ((string= key "ASCII") value)
 
-      ((string= key "TOC")
 
-       (let ((value (downcase value)))
 
- 	(cond
 
- 	 ((string-match "\\<headlines\\>" value)
 
- 	  (let ((depth (or (and (string-match "[0-9]+" value)
 
- 				(string-to-number (match-string 0 value)))
 
- 			   (plist-get info :with-toc))))
 
- 	    (org-ascii--build-toc
 
- 	     info (and (wholenump depth) depth) keyword)))
 
- 	 ((string= "tables" value)
 
- 	  (org-ascii--list-tables keyword info))
 
- 	 ((string= "listings" value)
 
- 	  (org-ascii--list-listings keyword info))))))))
 
- ;;;; Latex Environment
 
- (defun org-ascii-latex-environment (latex-environment contents info)
 
-   "Transcode a LATEX-ENVIRONMENT element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (when (plist-get info :with-latex)
 
-     (org-remove-indentation (org-element-property :value latex-environment))))
 
- ;;;; Latex Fragment
 
- (defun org-ascii-latex-fragment (latex-fragment contents info)
 
-   "Transcode a LATEX-FRAGMENT object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (when (plist-get info :with-latex)
 
-     (org-element-property :value latex-fragment)))
 
- ;;;; Line Break
 
- (defun org-ascii-line-break (line-break contents info)
 
-   "Transcode a LINE-BREAK object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
-   information."  hard-newline)
 
- ;;;; Link
 
- (defun org-ascii-link (link desc info)
 
-   "Transcode a LINK object from Org to ASCII.
 
- DESC is the description part of the link, or the empty string.
 
- INFO is a plist holding contextual information."
 
-   (let ((raw-link (org-element-property :raw-link link))
 
- 	(type (org-element-property :type link)))
 
-     (cond
 
-      ((string= type "coderef")
 
-       (let ((ref (org-element-property :path link)))
 
- 	(format (org-export-get-coderef-format ref desc)
 
- 		(org-export-resolve-coderef ref info))))
 
-      ;; Do not apply a special syntax on radio links.  Though, use
 
-      ;; transcoded target's contents as output.
 
-      ((string= type "radio")
 
-       (let ((destination (org-export-resolve-radio-link link info)))
 
- 	(when destination
 
- 	  (org-export-data (org-element-contents destination) info))))
 
-      ;; Do not apply a special syntax on fuzzy links pointing to
 
-      ;; targets.
 
-      ((string= type "fuzzy")
 
-       (let ((destination (org-export-resolve-fuzzy-link link info)))
 
- 	(if (org-string-nw-p desc) desc
 
- 	  (when destination
 
- 	    (let ((number
 
- 		   (org-export-get-ordinal
 
- 		    destination info nil 'org-ascii--has-caption-p)))
 
- 	      (when number
 
- 		(if (atom number) (number-to-string number)
 
- 		  (mapconcat 'number-to-string number "."))))))))
 
-      (t
 
-       (if (not (org-string-nw-p desc)) (format "[%s]" raw-link)
 
- 	(concat
 
- 	 (format "[%s]" desc)
 
- 	 (unless org-ascii-links-to-notes (format " (%s)" raw-link))))))))
 
- ;;;; Node Properties
 
- (defun org-ascii-node-property (node-property contents info)
 
-   "Transcode a NODE-PROPERTY element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual
 
- information."
 
-   (format "%s:%s"
 
-           (org-element-property :key node-property)
 
-           (let ((value (org-element-property :value node-property)))
 
-             (if value (concat " " value) ""))))
 
- ;;;; Paragraph
 
- (defun org-ascii-paragraph (paragraph contents info)
 
-   "Transcode a PARAGRAPH element from Org to ASCII.
 
- CONTENTS is the contents of the paragraph, as a string.  INFO is
 
- the plist used as a communication channel."
 
-   (let ((contents (if (not (wholenump org-ascii-indented-line-width)) contents
 
- 		    (concat
 
- 		     (make-string org-ascii-indented-line-width ? )
 
- 		     (replace-regexp-in-string "\\`[ \t]+" "" contents)))))
 
-     (org-ascii--fill-string
 
-      contents (org-ascii--current-text-width paragraph info) info)))
 
- ;;;; Plain List
 
- (defun org-ascii-plain-list (plain-list contents info)
 
-   "Transcode a PLAIN-LIST element from Org to ASCII.
 
- CONTENTS is the contents of the list.  INFO is a plist holding
 
- contextual information."
 
-   contents)
 
- ;;;; Plain Text
 
- (defun org-ascii-plain-text (text info)
 
-   "Transcode a TEXT string from Org to ASCII.
 
- INFO is a plist used as a communication channel."
 
-   (let ((utf8p (eq (plist-get info :ascii-charset) 'utf-8)))
 
-     (when (and utf8p (plist-get info :with-smart-quotes))
 
-       (setq text (org-export-activate-smart-quotes text :utf-8 info)))
 
-     (if (not (plist-get info :with-special-strings)) text
 
-       (setq text (replace-regexp-in-string "\\\\-" "" text))
 
-       (if (not utf8p) text
 
- 	;; Usual replacements in utf-8 with proper option set.
 
- 	(replace-regexp-in-string
 
- 	 "\\.\\.\\." "…"
 
- 	 (replace-regexp-in-string
 
- 	  "--" "–"
 
- 	  (replace-regexp-in-string "---" "—" text)))))))
 
- ;;;; Planning
 
- (defun org-ascii-planning (planning contents info)
 
-   "Transcode a PLANNING element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist used as a communication
 
- channel."
 
-   (mapconcat
 
-    'identity
 
-    (delq nil
 
- 	 (list (let ((closed (org-element-property :closed planning)))
 
- 		 (when closed
 
- 		   (concat org-closed-string " "
 
- 			   (org-translate-time
 
- 			    (org-element-property :raw-value closed)))))
 
- 	       (let ((deadline (org-element-property :deadline planning)))
 
- 		 (when deadline
 
- 		   (concat org-deadline-string " "
 
- 			   (org-translate-time
 
- 			    (org-element-property :raw-value deadline)))))
 
- 	       (let ((scheduled (org-element-property :scheduled planning)))
 
- 		 (when scheduled
 
- 		   (concat org-scheduled-string " "
 
- 			   (org-translate-time
 
- 			    (org-element-property :raw-value scheduled)))))))
 
-    " "))
 
- ;;;; Property Drawer
 
- (defun org-ascii-property-drawer (property-drawer contents info)
 
-   "Transcode a PROPERTY-DRAWER element from Org to ASCII.
 
- CONTENTS holds the contents of the drawer.  INFO is a plist
 
- holding contextual information."
 
-   (org-string-nw-p contents))
 
- ;;;; Quote Block
 
- (defun org-ascii-quote-block (quote-block contents info)
 
-   "Transcode a QUOTE-BLOCK element from Org to ASCII.
 
- CONTENTS holds the contents of the block.  INFO is a plist
 
- holding contextual information."
 
-   (org-ascii--indent-string contents org-ascii-quote-margin))
 
- ;;;; Quote Section
 
- (defun org-ascii-quote-section (quote-section contents info)
 
-   "Transcode a QUOTE-SECTION element from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (let ((width (org-ascii--current-text-width quote-section info))
 
- 	(value
 
- 	 (org-export-data
 
- 	  (org-remove-indentation (org-element-property :value quote-section))
 
- 	  info)))
 
-     (org-ascii--indent-string
 
-      value
 
-      (+ org-ascii-quote-margin
 
- 	;; Don't apply inner margin if parent headline is low level.
 
- 	(let ((headline (org-export-get-parent-headline quote-section)))
 
- 	  (if (org-export-low-level-p headline info) 0
 
- 	    org-ascii-inner-margin))))))
 
- ;;;; Radio Target
 
- (defun org-ascii-radio-target (radio-target contents info)
 
-   "Transcode a RADIO-TARGET object from Org to ASCII.
 
- CONTENTS is the contents of the target.  INFO is a plist holding
 
- contextual information."
 
-   contents)
 
- ;;;; Section
 
- (defun org-ascii-section (section contents info)
 
-   "Transcode a SECTION element from Org to ASCII.
 
- CONTENTS is the contents of the section.  INFO is a plist holding
 
- contextual information."
 
-   (org-ascii--indent-string
 
-    (concat
 
-     contents
 
-     (when org-ascii-links-to-notes
 
-       ;; Add list of links at the end of SECTION.
 
-       (let ((links (org-ascii--describe-links
 
- 		    (org-ascii--unique-links section info)
 
- 		    (org-ascii--current-text-width section info) info)))
 
- 	;; Separate list of links and section contents.
 
- 	(when (org-string-nw-p links) (concat "\n\n" links)))))
 
-    ;; Do not apply inner margin if parent headline is low level.
 
-    (let ((headline (org-export-get-parent-headline section)))
 
-      (if (or (not headline) (org-export-low-level-p headline info)) 0
 
-        org-ascii-inner-margin))))
 
- ;;;; Special Block
 
- (defun org-ascii-special-block (special-block contents info)
 
-   "Transcode a SPECIAL-BLOCK element from Org to ASCII.
 
- CONTENTS holds the contents of the block.  INFO is a plist
 
- holding contextual information."
 
-   contents)
 
- ;;;; Src Block
 
- (defun org-ascii-src-block (src-block contents info)
 
-   "Transcode a SRC-BLOCK element from Org to ASCII.
 
- CONTENTS holds the contents of the item.  INFO is a plist holding
 
- contextual information."
 
-   (let ((caption (org-ascii--build-caption src-block info))
 
- 	(code (org-export-format-code-default src-block info)))
 
-     (if (equal code "") ""
 
-       (concat
 
-        (when (and caption org-ascii-caption-above) (concat caption "\n"))
 
-        (org-ascii--box-string code info)
 
-        (when (and caption (not org-ascii-caption-above))
 
- 	 (concat "\n" caption))))))
 
- ;;;; Statistics Cookie
 
- (defun org-ascii-statistics-cookie (statistics-cookie contents info)
 
-   "Transcode a STATISTICS-COOKIE object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (org-element-property :value statistics-cookie))
 
- ;;;; Subscript
 
- (defun org-ascii-subscript (subscript contents info)
 
-   "Transcode a SUBSCRIPT object from Org to ASCII.
 
- CONTENTS is the contents of the object.  INFO is a plist holding
 
- contextual information."
 
-   (if (org-element-property :use-brackets-p subscript)
 
-       (format "_{%s}" contents)
 
-     (format "_%s" contents)))
 
- ;;;; Superscript
 
- (defun org-ascii-superscript (superscript contents info)
 
-   "Transcode a SUPERSCRIPT object from Org to ASCII.
 
- CONTENTS is the contents of the object.  INFO is a plist holding
 
- contextual information."
 
-   (if (org-element-property :use-brackets-p superscript)
 
-       (format "_{%s}" contents)
 
-     (format "_%s" contents)))
 
- ;;;; Strike-through
 
- (defun org-ascii-strike-through (strike-through contents info)
 
-   "Transcode STRIKE-THROUGH from Org to ASCII.
 
- CONTENTS is text with strike-through markup.  INFO is a plist
 
- holding contextual information."
 
-   (format "+%s+" contents))
 
- ;;;; Table
 
- (defun org-ascii-table (table contents info)
 
-   "Transcode a TABLE element from Org to ASCII.
 
- CONTENTS is the contents of the table.  INFO is a plist holding
 
- contextual information."
 
-   (let ((caption (org-ascii--build-caption table info)))
 
-     (concat
 
-      ;; Possibly add a caption string above.
 
-      (when (and caption org-ascii-caption-above) (concat caption "\n"))
 
-      ;; Insert table.  Note: "table.el" tables are left unmodified.
 
-      (cond ((eq (org-element-property :type table) 'org) contents)
 
- 	   ((and org-ascii-table-use-ascii-art
 
- 		 (eq (plist-get info :ascii-charset) 'utf-8)
 
- 		 (require 'ascii-art-to-unicode nil t))
 
- 	    (with-temp-buffer
 
- 	      (insert (org-remove-indentation
 
- 		       (org-element-property :value table)))
 
- 	      (goto-char (point-min))
 
- 	      (aa2u)
 
- 	      (goto-char (point-max))
 
- 	      (skip-chars-backward " \r\t\n")
 
- 	      (buffer-substring (point-min) (point))))
 
- 	   (t (org-remove-indentation (org-element-property :value table))))
 
-      ;; Possible add a caption string below.
 
-      (and (not org-ascii-caption-above) caption))))
 
- ;;;; Table Cell
 
- (defun org-ascii--table-cell-width (table-cell info)
 
-   "Return width of TABLE-CELL.
 
- INFO is a plist used as a communication channel.
 
- Width of a cell is determined either by a width cookie in the
 
- same column as the cell, or by the maximum cell's length in that
 
- column.
 
- When `org-ascii-table-widen-columns' is non-nil, width cookies
 
- are ignored."
 
-   (let* ((row (org-export-get-parent table-cell))
 
- 	 (table (org-export-get-parent row))
 
- 	 (col (let ((cells (org-element-contents row)))
 
- 		(- (length cells) (length (memq table-cell cells)))))
 
- 	 (cache
 
- 	  (or (plist-get info :ascii-table-cell-width-cache)
 
- 	      (plist-get (setq info
 
- 			       (plist-put info :ascii-table-cell-width-cache
 
- 					  (make-hash-table :test 'equal)))
 
- 			 :ascii-table-cell-width-cache)))
 
- 	 (key (cons table col)))
 
-     (or (gethash key cache)
 
- 	(puthash
 
- 	 key
 
- 	 (or (and (not org-ascii-table-widen-columns)
 
- 		  (org-export-table-cell-width table-cell info))
 
- 	     (let* ((max-width 0))
 
- 	       (org-element-map table 'table-row
 
- 		 (lambda (row)
 
- 		   (setq max-width
 
- 			 (max (length
 
- 			       (org-export-data
 
- 				(org-element-contents
 
- 				 (elt (org-element-contents row) col))
 
- 				info))
 
- 			      max-width)))
 
- 		 info)
 
- 	       max-width))
 
- 	 cache))))
 
- (defun org-ascii-table-cell (table-cell contents info)
 
-   "Transcode a TABLE-CELL object from Org to ASCII.
 
- CONTENTS is the cell contents.  INFO is a plist used as
 
- a communication channel."
 
-   ;; Determine column width.  When `org-ascii-table-widen-columns'
 
-   ;; is nil and some width cookie has set it, use that value.
 
-   ;; Otherwise, compute the maximum width among transcoded data of
 
-   ;; each cell in the column.
 
-   (let ((width (org-ascii--table-cell-width table-cell info)))
 
-     ;; When contents are too large, truncate them.
 
-     (unless (or org-ascii-table-widen-columns (<= (length contents) width))
 
-       (setq contents (concat (substring contents 0 (- width 2)) "=>")))
 
-     ;; Align contents correctly within the cell.
 
-     (let* ((indent-tabs-mode nil)
 
- 	   (data
 
- 	    (when contents
 
- 	      (org-ascii--justify-string
 
- 	       contents width
 
- 	       (org-export-table-cell-alignment table-cell info)))))
 
-       (setq contents (concat data (make-string (- width (length data)) ? ))))
 
-     ;; Return cell.
 
-     (concat (format " %s " contents)
 
- 	    (when (memq 'right (org-export-table-cell-borders table-cell info))
 
- 	      (if (eq (plist-get info :ascii-charset) 'utf-8) "│" "|")))))
 
- ;;;; Table Row
 
- (defun org-ascii-table-row (table-row contents info)
 
-   "Transcode a TABLE-ROW element from Org to ASCII.
 
- CONTENTS is the row contents.  INFO is a plist used as
 
- a communication channel."
 
-   (when (eq (org-element-property :type table-row) 'standard)
 
-     (let ((build-hline
 
- 	   (function
 
- 	    (lambda (lcorner horiz vert rcorner)
 
- 	      (concat
 
- 	       (apply
 
- 		'concat
 
- 		(org-element-map table-row 'table-cell
 
- 		  (lambda (cell)
 
- 		    (let ((width (org-ascii--table-cell-width cell info))
 
- 			  (borders (org-export-table-cell-borders cell info)))
 
- 		      (concat
 
- 		       ;; In order to know if CELL starts the row, do
 
- 		       ;; not compare it with the first cell in the
 
- 		       ;; row as there might be a special column.
 
- 		       ;; Instead, compare it with first exportable
 
- 		       ;; cell, obtained with `org-element-map'.
 
- 		       (when (and (memq 'left borders)
 
- 				  (eq (org-element-map table-row 'table-cell
 
- 					'identity info t)
 
- 				      cell))
 
- 			 lcorner)
 
- 		       (make-string (+ 2 width) (string-to-char horiz))
 
- 		       (cond
 
- 			((not (memq 'right borders)) nil)
 
- 			((eq (car (last (org-element-contents table-row))) cell)
 
- 			 rcorner)
 
- 			(t vert)))))
 
- 		  info)) "\n"))))
 
- 	  (utf8p (eq (plist-get info :ascii-charset) 'utf-8))
 
- 	  (borders (org-export-table-cell-borders
 
- 		    (org-element-map table-row 'table-cell 'identity info t)
 
- 		    info)))
 
-       (concat (cond
 
- 	       ((and (memq 'top borders) (or utf8p (memq 'above borders)))
 
- 		(if utf8p (funcall build-hline "┍" "━" "┯" "┑")
 
- 		  (funcall build-hline "+" "-" "+" "+")))
 
- 	       ((memq 'above borders)
 
- 		(if utf8p (funcall build-hline "├" "─" "┼" "┤")
 
- 		  (funcall build-hline "+" "-" "+" "+"))))
 
- 	      (when (memq 'left borders) (if utf8p "│" "|"))
 
- 	      contents "\n"
 
- 	      (when (and (memq 'bottom borders) (or utf8p (memq 'below borders)))
 
- 		(if utf8p (funcall build-hline "┕" "━" "┷" "┙")
 
- 		  (funcall build-hline "+" "-" "+" "+")))))))
 
- ;;;; Timestamp
 
- (defun org-ascii-timestamp (timestamp contents info)
 
-   "Transcode a TIMESTAMP object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (org-ascii-plain-text (org-timestamp-translate timestamp) info))
 
- ;;;; Underline
 
- (defun org-ascii-underline (underline contents info)
 
-   "Transcode UNDERLINE from Org to ASCII.
 
- CONTENTS is the text with underline markup.  INFO is a plist
 
- holding contextual information."
 
-   (format "_%s_" contents))
 
- ;;;; Verbatim
 
- (defun org-ascii-verbatim (verbatim contents info)
 
-   "Return a VERBATIM object from Org to ASCII.
 
- CONTENTS is nil.  INFO is a plist holding contextual information."
 
-   (format org-ascii-verbatim-format
 
- 	  (org-element-property :value verbatim)))
 
- ;;;; Verse Block
 
- (defun org-ascii-verse-block (verse-block contents info)
 
-   "Transcode a VERSE-BLOCK element from Org to ASCII.
 
- CONTENTS is verse block contents.  INFO is a plist holding
 
- contextual information."
 
-   (let ((verse-width (org-ascii--current-text-width verse-block info)))
 
-     (org-ascii--indent-string
 
-      (org-ascii--justify-string contents verse-width 'left)
 
-      org-ascii-quote-margin)))
 
- ;;; Filters
 
- (defun org-ascii-filter-headline-blank-lines (headline back-end info)
 
-   "Filter controlling number of blank lines after a headline.
 
- HEADLINE is a string representing a transcoded headline.
 
- BACK-END is symbol specifying back-end used for export.  INFO is
 
- plist containing the communication channel.
 
- This function only applies to `ascii' back-end.  See
 
- `org-ascii-headline-spacing' for information."
 
-   (if (not org-ascii-headline-spacing) headline
 
-     (let ((blanks (make-string (1+ (cdr org-ascii-headline-spacing)) ?\n)))
 
-       (replace-regexp-in-string "\n\\(?:\n[ \t]*\\)*\\'" blanks headline))))
 
- (defun org-ascii-filter-paragraph-spacing (tree back-end info)
 
-   "Filter controlling number of blank lines between paragraphs.
 
- TREE is the parse tree.  BACK-END is the symbol specifying
 
- back-end used for export.  INFO is a plist used as
 
- a communication channel.
 
- See `org-ascii-paragraph-spacing' for information."
 
-   (when (wholenump org-ascii-paragraph-spacing)
 
-     (org-element-map tree 'paragraph
 
-       (lambda (p)
 
- 	(when (eq (org-element-type (org-export-get-next-element p info))
 
- 		  'paragraph)
 
- 	  (org-element-put-property
 
- 	   p :post-blank org-ascii-paragraph-spacing)))))
 
-   tree)
 
- (defun org-ascii-filter-comment-spacing (tree backend info)
 
-   "Filter removing blank lines between comments.
 
- TREE is the parse tree.  BACK-END is the symbol specifying
 
- back-end used for export.  INFO is a plist used as
 
- a communication channel."
 
-   (org-element-map tree '(comment comment-block)
 
-     (lambda (c)
 
-       (when (memq (org-element-type (org-export-get-next-element c info))
 
- 		  '(comment comment-block))
 
- 	(org-element-put-property c :post-blank 0))))
 
-   tree)
 
- ;;; End-user functions
 
- ;;;###autoload
 
- (defun org-ascii-export-as-ascii
 
-   (&optional async subtreep visible-only body-only ext-plist)
 
-   "Export current buffer to a text buffer.
 
- If narrowing is active in the current buffer, only export its
 
- narrowed part.
 
- If a region is active, export that region.
 
- A non-nil optional argument ASYNC means the process should happen
 
- asynchronously.  The resulting buffer should be accessible
 
- through the `org-export-stack' interface.
 
- When optional argument SUBTREEP is non-nil, export the sub-tree
 
- at point, extracting information from the headline properties
 
- first.
 
- When optional argument VISIBLE-ONLY is non-nil, don't export
 
- contents of hidden elements.
 
- When optional argument BODY-ONLY is non-nil, strip title and
 
- table of contents from output.
 
- EXT-PLIST, when provided, is a property list with external
 
- parameters overriding Org default settings, but still inferior to
 
- file-local settings.
 
- Export is done in a buffer named \"*Org ASCII Export*\", which
 
- will be displayed when `org-export-show-temporary-export-buffer'
 
- is non-nil."
 
-   (interactive)
 
-   (org-export-to-buffer 'ascii "*Org ASCII Export*"
 
-     async subtreep visible-only body-only ext-plist (lambda () (text-mode))))
 
- ;;;###autoload
 
- (defun org-ascii-export-to-ascii
 
-   (&optional async subtreep visible-only body-only ext-plist)
 
-   "Export current buffer to a text file.
 
- If narrowing is active in the current buffer, only export its
 
- narrowed part.
 
- If a region is active, export that region.
 
- A non-nil optional argument ASYNC means the process should happen
 
- asynchronously.  The resulting file should be accessible through
 
- the `org-export-stack' interface.
 
- When optional argument SUBTREEP is non-nil, export the sub-tree
 
- at point, extracting information from the headline properties
 
- first.
 
- When optional argument VISIBLE-ONLY is non-nil, don't export
 
- contents of hidden elements.
 
- When optional argument BODY-ONLY is non-nil, strip title and
 
- table of contents from output.
 
- EXT-PLIST, when provided, is a property list with external
 
- parameters overriding Org default settings, but still inferior to
 
- file-local settings.
 
- Return output file's name."
 
-   (interactive)
 
-   (let ((file (org-export-output-file-name ".txt" subtreep)))
 
-     (org-export-to-file 'ascii file
 
-       async subtreep visible-only body-only ext-plist)))
 
- ;;;###autoload
 
- (defun org-ascii-publish-to-ascii (plist filename pub-dir)
 
-   "Publish an Org file to ASCII.
 
- FILENAME is the filename of the Org file to be published.  PLIST
 
- is the property list for the given project.  PUB-DIR is the
 
- publishing directory.
 
- Return output file name."
 
-   (org-publish-org-to
 
-    'ascii filename ".txt" `(:ascii-charset ascii ,@plist) pub-dir))
 
- ;;;###autoload
 
- (defun org-ascii-publish-to-latin1 (plist filename pub-dir)
 
-   "Publish an Org file to Latin-1.
 
- FILENAME is the filename of the Org file to be published.  PLIST
 
- is the property list for the given project.  PUB-DIR is the
 
- publishing directory.
 
- Return output file name."
 
-   (org-publish-org-to
 
-    'ascii filename ".txt" `(:ascii-charset latin1 ,@plist) pub-dir))
 
- ;;;###autoload
 
- (defun org-ascii-publish-to-utf8 (plist filename pub-dir)
 
-   "Publish an org file to UTF-8.
 
- FILENAME is the filename of the Org file to be published.  PLIST
 
- is the property list for the given project.  PUB-DIR is the
 
- publishing directory.
 
- Return output file name."
 
-   (org-publish-org-to
 
-    'ascii filename ".txt" `(:ascii-charset utf-8 ,@plist) pub-dir))
 
- (provide 'ox-ascii)
 
- ;; Local variables:
 
- ;; generated-autoload-file: "org-loaddefs.el"
 
- ;; coding: utf-8-emacs
 
- ;; End:
 
- ;;; ox-ascii.el ends here
 
 
  |