| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478 | ;;; org-e-odt.el --- OpenDocument Text exporter for Org-mode;; Copyright (C) 2010-2012 Free Software Foundation, Inc.;; Author: Jambunathan K <kjambunathan at gmail dot com>;; Keywords: outlines, hypermedia, calendar, wp;; Homepage: http://orgmode.org;; 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:;;; Code:(eval-when-compile  (require 'cl));; FIXMES;; org-e-odt-preprocess-latex-fragments;; org-export-as-e-odt-and-open;; org-export-as-e-odt-batch;; org-export-as-e-odt(defun org-e-odt-get-style-name-for-entity (category &optional entity)  (let ((entity (or entity 'default)))    (or     (cdr (assoc entity (cdr (assoc category				    org-e-odt-org-styles-alist))))     (cdr (assoc entity (cdr (assoc category				    org-e-odt-default-org-styles-alist))))     (error "Cannot determine style name for entity %s of type %s"	    entity category))));; Following variable is let bound when `org-do-lparse' is in;; progress. See org-html.el.(defun org-e-odt-format-preamble (info)  (let* ((title (org-export-secondary-string		 (plist-get info :title) 'e-odt info))	 (author (and (plist-get info :with-author)		      (let ((auth (plist-get info :author)))			(and auth (org-export-secondary-string				   auth 'e-odt info)))))	 (date (plist-get info :date))	 (iso-date (org-e-odt-format-date date))	 (date (org-e-odt-format-date date "%d %b %Y"))	 (email (plist-get info :email))	 ;; switch on or off above vars based on user settings	 (author (and (plist-get info :with-author) (or author email)))	 ;; (date (and (plist-get info :time-stamp-file) date))	 (email (and (plist-get info :with-email) email)))    (concat     ;; title     (when title       (concat	(org-e-odt-format-stylized-paragraph	 'title (format "\n<text:title>%s</text:title>" title))	;; separator	"\n<text:p text:style-name=\"OrgTitle\"/>"))     (cond      ((and author (not email))       ;; author only       (concat	(org-e-odt-format-stylized-paragraph	 'subtitle	 (format "<text:initial-creator>%s</text:initial-creator>" author))	;; separator	"\n<text:p text:style-name=\"OrgSubtitle\"/>"))      ((and author email)       ;; author and email       (concat	(org-e-odt-format-stylized-paragraph	 'subtitle	 (org-e-odt-format-link	  (format "<text:initial-creator>%s</text:initial-creator>" author)	  (concat "mailto:" email)))	;; separator	"\n<text:p text:style-name=\"OrgSubtitle\"/>")))     ;; date     (when date       (concat	(org-e-odt-format-stylized-paragraph	 'subtitle	 (org-e-odt-format-tags	  '("<text:date style:data-style-name=\"%s\" text:date-value=\"%s\">"	    . "</text:date>")	  date "N75" iso-date))	;; separator	"<text:p text:style-name=\"OrgSubtitle\"/>")))))(defun org-e-odt-begin-section (style &optional name)  (let ((default-name (car (org-e-odt-add-automatic-style "Section"))))    (format "<text:section text:style-name=\"%s\" text:name=\"%s\">"	    style (or name default-name))))(defun org-e-odt-end-section ()  "</text:section>")(defun org-e-odt-begin-paragraph (&optional style)  (format "<text:p%s>" (org-e-odt-get-extra-attrs-for-paragraph-style style)))(defun org-e-odt-end-paragraph ()  "</text:p>")(defun org-e-odt-get-extra-attrs-for-paragraph-style (style)  (let (style-name)    (setq style-name	  (cond	   ((stringp style) style)	   ((symbolp style) (org-e-odt-get-style-name-for-entity			     'paragraph style))))    (unless style-name      (error "Don't know how to handle paragraph style %s" style))    (format " text:style-name=\"%s\"" style-name)))(defun org-e-odt-format-stylized-paragraph (style text)  (format "\n<text:p%s>%s</text:p>"	  (org-e-odt-get-extra-attrs-for-paragraph-style style)	  text))(defun org-e-odt-format-author (&optional author )  (when (setq author (or author (plist-get org-lparse-opt-plist :author)))    (format "<dc:creator>%s</dc:creator>" author)))(defun org-e-odt-format-date (&optional org-ts fmt)  (save-match-data    (let* ((time	    (and (stringp org-ts)		 (string-match org-ts-regexp0 org-ts)		 (apply 'encode-time			(org-fix-decoded-time			 (org-parse-time-string (match-string 0 org-ts) t)))))	   date)      (cond       (fmt (format-time-string fmt time))       (t (setq date (format-time-string "%Y-%m-%dT%H:%M:%S%z" time))	  (format "%s:%s" (substring date 0 -2) (substring date -2)))))))(defun org-e-odt-begin-annotation (&optional author date)  (concat   "<office:annotation>\n"   (and author (org-e-odt-format-author author))   (org-e-odt-format-tags    '("<dc:date>" . "</dc:date>")    (org-e-odt-format-date     (or date (plist-get org-lparse-opt-plist :date))))   (org-e-odt-begin-paragraph)))(defun org-e-odt-end-annotation ()  "</office:annotation>")(defun org-e-odt-begin-plain-list (ltype)  (let* ((style-name (org-e-odt-get-style-name-for-entity 'list ltype))	 (extra (concat		 ;; (if (or org-lparse-list-table-p		 ;; 	 (and (= 1 (length org-lparse-list-stack))		 ;; 	      (null org-e-odt-list-stack-stashed)))		 ;;     " text:continue-numbering=\"false\""		 ;;   " text:continue-numbering=\"true\"")		 " text:continue-numbering=\"true\""		 (when style-name		   (format " text:style-name=\"%s\""  style-name)))))    (case ltype      ((ordered unordered descriptive)       (concat	;; (org-e-odt-end-paragraph)	(format "<text:list%s>" extra)))      (t (error "Unknown list type: %s"  ltype)))))(defun org-e-odt-end-plain-list (ltype)  (if ltype "</text:list>"    (error "Unknown list type: %s" ltype)))(defun org-e-odt-begin-list-item (ltype &optional arg headline)  (case ltype    (ordered     (assert (not headline) t)     (let* ((counter arg) (extra ""))       (concat "<text:list-item>" ;; (org-e-odt-begin-paragraph)	       )       ;; (if (= (length org-lparse-list-stack)       ;;        (length org-e-odt-list-stack-stashed))       ;;     "<text:list-header>" "<text:list-item>")       ))    (unordered     (let* ((id arg) (extra ""))       (concat	"<text:list-item>"	;; (org-e-odt-begin-paragraph)	(if headline (org-e-odt-format-target headline id)	  (org-e-odt-format-bookmark "" id)))       ;; (if (= (length org-lparse-list-stack)       ;;        (length org-e-odt-list-stack-stashed))       ;;     "<text:list-header>" "<text:list-item>")       ))    (descriptive     (assert (not headline) t)     (let ((term (or arg "(no term)")))       (concat	(org-e-odt-format-tags    	 '("<text:list-item>" . "</text:list-item>")    	 (org-e-odt-format-stylized-paragraph 'definition-term term))	(org-e-odt-begin-list-item 'unordered)	(org-e-odt-begin-plain-list 'descriptive)	(org-e-odt-begin-list-item 'unordered))))    (t (error "Unknown list type"))))(defun org-e-odt-end-list-item (ltype)  (case ltype    ((ordered unordered)     ;; (org-lparse-insert-tag     ;; (if (= (length org-lparse-list-stack)     ;; 	     (length org-e-odt-list-stack-stashed))     ;; 	  (prog1 "</text:list-header>"     ;; 	    (setq org-e-odt-list-stack-stashed nil))     ;; 	"</text:list-item>")     "</text:list-item>"     ;; )     )    (descriptive     (concat      (org-e-odt-end-list-item 'unordered)      (org-e-odt-end-plain-list 'descriptive)      (org-e-odt-end-list-item 'unordered)      ))    (t (error "Unknown list type"))))(defun org-e-odt-write-automatic-styles ()  "Write automatic styles to \"content.xml\"."  (with-current-buffer      (find-file-noselect (expand-file-name "content.xml") t)    ;; position the cursor    (goto-char (point-min))    (re-search-forward "  </office:automatic-styles>" nil t)    (goto-char (match-beginning 0))    ;; write automatic table styles    (loop for (style-name props) in	  (plist-get org-e-odt-automatic-styles 'Table) do	  (when (setq props (or (plist-get props :rel-width) 96))	    (insert (format org-e-odt-table-style-format style-name props))))))(defun org-e-odt-update-display-level (&optional level)  (with-current-buffer      (find-file-noselect (expand-file-name "content.xml") t)    ;; position the cursor.    (goto-char (point-min))    ;; remove existing sequence decls.    (when (re-search-forward "<text:sequence-decls" nil t)      (delete-region (match-beginning 0)		     (re-search-forward "</text:sequence-decls>" nil nil)))    ;; insert new ones.    (insert "      <text:sequence-decls>")    (loop for x in org-e-odt-category-map-alist	  do (insert (format "	<text:sequence-decl text:display-outline-level=\"%d\" text:name=\"%s\"/>"			     level (nth 1 x))))    (insert "      </text:sequence-decls>")))(defun org-e-odt-add-automatic-style (object-type &optional object-props)  "Create an automatic style of type OBJECT-TYPE with param OBJECT-PROPS.OBJECT-PROPS is (typically) a plist created by passing\"#+ATTR_ODT: \" option of the object in question to`org-e-odt-parse-block-attributes'.Use `org-e-odt-object-counters' to generate an automaticOBJECT-NAME and STYLE-NAME.  If OBJECT-PROPS is non-nil, add anew entry in `org-e-odt-automatic-styles'.  Return (OBJECT-NAME. STYLE-NAME)."  (assert (stringp object-type))  (let* ((object (intern object-type))	 (seqvar object)	 (seqno (1+ (or (plist-get org-e-odt-object-counters seqvar) 0)))	 (object-name (format "%s%d" object-type seqno)) style-name)    (setq org-e-odt-object-counters	  (plist-put org-e-odt-object-counters seqvar seqno))    (when object-props      (setq style-name (format "Org%s" object-name))      (setq org-e-odt-automatic-styles	    (plist-put org-e-odt-automatic-styles object		       (append (list (list style-name object-props))			       (plist-get org-e-odt-automatic-styles object)))))    (cons object-name style-name)))(defun org-e-odt-begin-toc (lang-specific-heading max-level)  (concat   (format "    <text:table-of-content text:style-name=\"Sect2\" text:protected=\"true\" text:name=\"Table of Contents1\">     <text:table-of-content-source text:outline-level=\"%d\">      <text:index-title-template text:style-name=\"Contents_20_Heading\">%s</text:index-title-template>" max-level lang-specific-heading)   (let ((entry-templates ""))     (loop for level from 1 upto 10	   do (setq entry-templates		    (concat entry-templates			    (format			     "      <text:table-of-content-entry-template text:outline-level=\"%d\" text:style-name=\"Contents_20_%d\">       <text:index-entry-link-start text:style-name=\"Internet_20_link\"/>       <text:index-entry-chapter/>       <text:index-entry-text/>       <text:index-entry-link-end/>      </text:table-of-content-entry-template>" level level))))     entry-templates)   (format  "     </text:table-of-content-source>     <text:index-body>      <text:index-title text:style-name=\"Sect1\" text:name=\"Table of Contents1_Head\">       <text:p text:style-name=\"Contents_20_Heading\">%s</text:p>      </text:index-title> " lang-specific-heading)))(defun org-e-odt-end-toc ()  (format "     </text:index-body>    </text:table-of-content>"))(defun org-e-odt-format-toc-entry (snumber todo headline tags href)  ;; FIXME  (setq headline (concat  		  (and org-export-with-section-numbers  		       (concat snumber ". "))  		  headline  		  (and tags  		       (concat  			(org-e-odt-format-spaces 3)  			(org-e-odt-format-fontify tags "tag")))))  (when todo    (setq headline (org-e-odt-format-fontify headline "todo")))  (let ((org-e-odt-suppress-xref t))    (org-e-odt-format-link headline (concat  "#" href))))(defun org-e-odt-format-toc-item (toc-entry level org-last-level)  (let ((style (format "Contents_20_%d" level)))    (concat "\n" (org-e-odt-format-stylized-paragraph style toc-entry) "\n")));; Following variable is let bound during 'ORG-LINK callback. See;; org-html.el(defun org-e-odt-format-link (desc href &optional attr)  (cond   ((and (= (string-to-char href) ?#) (not org-e-odt-suppress-xref))    (setq href (substring href 1))    (let ((xref-format "text"))      (when (numberp desc)	(setq desc (format "%d" desc) xref-format "number"))      (when (listp desc)	(setq desc (mapconcat 'identity desc ".") xref-format "chapter"))      (setq href (concat org-e-odt-bookmark-prefix href))      (org-e-odt-format-tags-simple       '("<text:bookmark-ref text:reference-format=\"%s\" text:ref-name=\"%s\">" .	 "</text:bookmark-ref>")       desc xref-format href)))   (org-lparse-link-description-is-image    (org-e-odt-format-tags     '("<draw:a xlink:type=\"simple\" xlink:href=\"%s\" %s>" . "</draw:a>")     desc href (or attr "")))   (t    (org-e-odt-format-tags-simple     '("<text:a xlink:type=\"simple\" xlink:href=\"%s\" %s>" . "</text:a>")     desc href (or attr "")))))(defun org-e-odt-format-spaces (n)  (cond   ((= n 1) " ")   ((> n 1) (concat	     " " (org-e-odt-format-tags "<text:s text:c=\"%d\"/>" "" (1- n))))   (t "")))(defun org-e-odt-format-tabs (&optional n)  (let ((tab "<text:tab/>")	(n (or n 1)))    (insert tab)))(defun org-e-odt-format-line-break ()  (org-e-odt-format-tags "<text:line-break/>" ""))(defun org-e-odt-format-horizontal-line ()  (org-e-odt-format-stylized-paragraph 'horizontal-line ""))(defun org-e-odt-encode-plain-text (line &optional no-whitespace-filling)  (setq line (org-e-html-encode-plain-text line))  (if no-whitespace-filling line    (org-e-odt-fill-tabs-and-spaces line)))(defun org-e-odt-format-line (line)  (case org-lparse-dyn-current-environment    (fixedwidth (concat		 (org-e-odt-format-stylized-paragraph		  'fixedwidth (org-e-odt-encode-plain-text line)) "\n"))    (t (concat line "\n"))))(defun org-e-odt-format-comment (fmt &rest args)  (let ((comment (apply 'format fmt args)))    (format "\n<!-- %s  -->\n" comment)))(defun org-e-odt-format-org-entity (wd)  (org-entity-get-representation wd 'utf8))(defun org-e-odt-fill-tabs-and-spaces (line)  (replace-regexp-in-string   "\\([\t]\\|\\([ ]+\\)\\)" (lambda (s)			       (cond				((string= s "\t") (org-e-odt-format-tabs))				(t (org-e-odt-format-spaces (length s))))) line))(defun org-e-odt-hfy-face-to-css (fn)  "Create custom style for face FN.When FN is the default face, use it's foreground and backgroundproperties to create \"OrgSrcBlock\" paragraph style.  Otherwiseuse it's color attribute to create a character style whose nameis obtained from FN.  Currently all attributes of FN other thancolor are ignored.The style name for a face FN is derived using the followingoperations on the face name in that order - de-dash, CamelCaseand prefix with \"OrgSrc\".  For example,`font-lock-function-name-face' is associated with\"OrgSrcFontLockFunctionNameFace\"."  (let* ((css-list (hfy-face-to-style fn))	 (style-name ((lambda (fn)			(concat "OrgSrc"				(mapconcat				 'capitalize (split-string					      (hfy-face-or-def-to-name fn) "-")				 ""))) fn))	 (color-val (cdr (assoc "color" css-list)))	 (background-color-val (cdr (assoc "background" css-list)))	 (style (and org-e-odt-create-custom-styles-for-srcblocks		     (cond		      ((eq fn 'default)		       (format org-src-block-paragraph-format			       background-color-val color-val))		      (t		       (format			"<style:style style:name=\"%s\" style:family=\"text\">  <style:text-properties fo:color=\"%s\"/> </style:style>" style-name color-val))))))    (cons style-name style)))(defun org-e-odt-insert-custom-styles-for-srcblocks (styles)  "Save STYLES used for colorizing of source blocks.Update styles.xml with styles that were collected as part of`org-e-odt-hfy-face-to-css' callbacks."  (when styles    (with-current-buffer	(find-file-noselect (expand-file-name "styles.xml") t)      (goto-char (point-min))      (when (re-search-forward "</office:styles>" nil t)	(goto-char (match-beginning 0))	(insert "\n<!-- Org Htmlfontify Styles -->\n" styles "\n")))))(defun org-e-odt-remap-stylenames (style-name)  (or   (cdr (assoc style-name '(("timestamp-wrapper" . "OrgTimestampWrapper")			    ("timestamp" . "OrgTimestamp")			    ("timestamp-kwd" . "OrgTimestampKeyword")			    ("tag" . "OrgTag")			    ("todo" . "OrgTodo")			    ("done" . "OrgDone")			    ("target" . "OrgTarget"))))   style-name))(defun org-e-odt-format-fontify (text style &optional id)  (let* ((style-name	  (cond	   ((stringp style)	    (org-e-odt-remap-stylenames style))	   ((symbolp style)	    (org-e-odt-get-style-name-for-entity 'character style))	   ((listp style)	    (assert (< 1 (length style)))	    (let ((parent-style (pop style)))	      (mapconcat (lambda (s)			   ;; (assert (stringp s) t)			   (org-e-odt-remap-stylenames s)) style "")	      (org-e-odt-remap-stylenames parent-style)))	   (t (error "Don't how to handle style %s"  style)))))    (org-e-odt-format-tags-simple     '("<text:span text:style-name=\"%s\">" . "</text:span>")     text style-name)))(defun org-e-odt-relocate-relative-path (path dir)  (if (file-name-absolute-p path) path    (file-relative-name (expand-file-name path dir)			(expand-file-name "eyecandy" dir))))(defun org-e-odt-format-formula (element info)  (let* ((src (cond	       ((eq (org-element-type element) 'link) ; FIXME		(let* ((type (org-element-property :type element))		       (raw-path (org-element-property :path element)))		  (cond		   ((file-name-absolute-p raw-path)		    (expand-file-name raw-path))		   (t raw-path))))	       ((member (org-element-type element)			'(latex-fragment latex-environment))		(let* ((latex-frag (org-remove-indentation				    (org-element-property				     :value element)))		       (formula-link (org-e-odt-format-latex				      latex-frag 'mathml)))		  (and formula-link		       (string-match "file:\\([^]]*\\)" formula-link)		       (match-string 1 formula-link))))	       (t (error "what is this?"))))	 (caption-from	  (case (org-element-type element)	    (link (org-export-get-parent-paragraph element info))	    (t element)))	 (captions (org-e-odt-format-label caption-from info 'definition))	 (caption (car captions))	 (href	  (org-e-odt-format-tags	   "<draw:object xlink:href=\"%s\" xlink:type=\"simple\" xlink:show=\"embed\" xlink:actuate=\"onLoad\"/>" ""	   (file-name-directory (org-e-odt-copy-formula-file src))))	 (embed-as (if caption 'paragraph 'character))	 width height)    (cond     ((eq embed-as 'character)      (org-e-odt-format-entity "InlineFormula" href width height))     (t      (let ((table-info nil)	    (table-info	     '(:alignment ["c" "c"]			  :column-groups [nil nil]			  :row-groups (0)			  :special-column-p nil :width [8 1]))	    (org-lparse-table-ncols 2)) ; FIXME	(org-e-odt-list-table		; FIXME	 (list	  (list	   (org-e-odt-format-entity	    "CaptionedDisplayFormula" href width height captions)	   (let* ((org-e-odt-category-map-alist		   '(("__Table__" "Table" "value")		     ("__Figure__" "Illustration" "value")		     ("__MathFormula__" "Text" "math-label")		     ("__DvipngImage__" "Equation" "value")		     ("__Listing__" "Listing" "value"))))	     (car (org-e-odt-format-label caption-from info 'definition)))))	 '(table (:attr_odt (":style \"OrgEquation\""))) info))))))(defun org-e-odt-copy-formula-file (path)  "Returns the internal name of the file"  (let* ((src-file (expand-file-name		    path (file-name-directory org-current-export-file)))	 (target-dir (format "Formula-%04d/"			     (incf org-e-odt-embedded-formulas-count)))	 (target-file (concat target-dir "content.xml")))    (message "Embedding %s as %s ..."	     (substring-no-properties path) target-file)    (make-directory target-dir)    (org-e-odt-create-manifest-file-entry     "application/vnd.oasis.opendocument.formula" target-dir "1.2")    (case (org-e-odt-is-formula-link-p src-file)      (mathml       (copy-file src-file target-file 'overwrite))      (odf       (org-e-odt-zip-extract-one src-file "content.xml" target-dir))      (t       (error "%s is not a formula file" src-file)))    (org-e-odt-create-manifest-file-entry "text/xml" target-file)    target-file))(defun org-e-odt-is-formula-link-p (file)  (let ((case-fold-search nil))    (cond     ((string-match "\\.\\(mathml\\|mml\\)\\'" file)      'mathml)     ((string-match "\\.odf\\'" file)      'odf))))(defun org-e-odt-format-org-link (opt-plist type-1 path fragment desc attr					    descp)  "Make a OpenDocument link.OPT-PLIST is an options list.TYPE-1 is the device-type of the link (THIS://foo.html).PATH is the path of the link (http://THIS#location).FRAGMENT is the fragment part of the link, if any (foo.html#THIS).DESC is the link description, if any.ATTR is a string of other attributes of the a element."  (declare (special org-lparse-par-open))  (save-match-data    (let* ((may-inline-p	    (and (member type-1 '("http" "https" "file"))		 (org-lparse-should-inline-p path descp)		 (not fragment)))	   (type (if (equal type-1 "id") "file" type-1))	   (filename path)	   (thefile path))      (cond       ;; check for inlined images       ((and (member type '("file"))	     (not fragment)	     (org-file-image-p	      filename org-e-odt-inline-image-extensions)	     (not descp))	(org-e-odt-format-inline-image thefile))       ;; check for embedded formulas       ((and (member type '("file"))	     (not fragment)	     (org-e-odt-is-formula-link-p filename)	     (or (not descp)))	(org-e-odt-format-formula thefile))       ((string= type "coderef")	(let* ((ref fragment)	       (lineno-or-ref (cdr (assoc ref org-export-code-refs)))	       (desc (and descp desc))	       (org-e-odt-suppress-xref nil)	       (href (org-xml-format-href (concat "#coderef-" ref))))	  (cond	   ((and (numberp lineno-or-ref) (not desc))	    (org-e-odt-format-link lineno-or-ref href))	   ((and (numberp lineno-or-ref) desc		 (string-match (regexp-quote (concat "(" ref ")")) desc))	    (format (replace-match "%s" t t desc)		    (org-e-odt-format-link lineno-or-ref href)))	   (t	    (setq desc (format			(if (and desc (string-match				       (regexp-quote (concat "(" ref ")"))				       desc))			    (replace-match "%s" t t desc)			  (or desc "%s"))			lineno-or-ref))	    (org-e-odt-format-link (org-xml-format-desc desc) href)))))       (t	(when (string= type "file")	  (setq thefile		(cond		 ((file-name-absolute-p path)		  (concat "file://" (expand-file-name path)))		 (t (org-e-odt-relocate-relative-path		     thefile org-current-export-file)))))	(when (and (member type '("" "http" "https" "file")) fragment)	  (setq thefile (concat thefile "#" fragment)))	(setq thefile (org-xml-format-href thefile))	(when (not (member type '("" "file")))	  (setq thefile (concat type ":" thefile)))	(let ((org-e-odt-suppress-xref nil))	  (org-e-odt-format-link	   (org-xml-format-desc desc) thefile attr)))))))(defun org-e-odt-format-anchor (text name &optional class)  (org-e-odt-format-target text name))(defun org-e-odt-format-bookmark (text id)  (if id      (org-e-odt-format-tags "<text:bookmark text:name=\"%s\"/>" text id)    text))(defun org-e-odt-format-target (text id)  (let ((name (concat org-e-odt-bookmark-prefix id)))    (concat     (and id (org-e-odt-format-tags	      "<text:bookmark-start text:name=\"%s\"/>" "" name))     (org-e-odt-format-bookmark text id)     (and id (org-e-odt-format-tags	      "<text:bookmark-end text:name=\"%s\"/>" "" name)))))(defun org-e-odt-format-footnote (n def)  (setq n (format "%d" n))  (let ((id (concat  "fn" n))	(note-class "footnote")	(par-style "Footnote"))    (org-e-odt-format-tags-simple     '("<text:note text:id=\"%s\" text:note-class=\"%s\">" . "</text:note>")     (concat      (org-e-odt-format-tags-simple       '("<text:note-citation>" . "</text:note-citation>") n)      (org-e-odt-format-tags-simple       '("<text:note-body>" . "</text:note-body>") def))     id note-class)))(defun org-e-odt-format-footnote-reference (n def refcnt)  (if (= refcnt 1)      (org-e-odt-format-footnote n def)    (org-e-odt-format-footnote-ref n)))(defun org-e-odt-format-footnote-ref (n)  (setq n (format "%d" n))  (let ((note-class "footnote")	(ref-format "text")	(ref-name (concat "fn" n)))    (org-e-odt-format-tags-simple     '("<text:span text:style-name=\"%s\">" . "</text:span>")     (org-e-odt-format-tags-simple      '("<text:note-ref text:note-class=\"%s\" text:reference-format=\"%s\" text:ref-name=\"%s\">" . "</text:note-ref>")      n note-class ref-format ref-name)     "OrgSuperscript")))(defun org-e-odt-element-attributes (element info)  (let* ((raw-attr (org-element-property :attr_odt element))	 (raw-attr (and raw-attr			(org-trim (mapconcat #'identity raw-attr " ")))))    (unless (and raw-attr (string-match "\\`(.*)\\'" raw-attr))      (setq raw-attr (format "(%s)" raw-attr)))    (ignore-errors (read raw-attr))))(defun org-e-odt-format-object-description (title description)  (concat (and title (org-e-odt-format-tags		      '("<svg:title>" . "</svg:title>")		      (org-e-odt-encode-plain-text title t)))	  (and description (org-e-odt-format-tags			    '("<svg:desc>" . "</svg:desc>")			    (org-e-odt-encode-plain-text description t)))))(defun org-e-odt-format-frame (text width height style &optional				    extra anchor-type)  (let ((frame-attrs	 (concat	  (if width (format " svg:width=\"%0.2fcm\"" width) "")	  (if height (format " svg:height=\"%0.2fcm\"" height) "")	  extra	  (format " text:anchor-type=\"%s\"" (or anchor-type "paragraph")))))    (org-e-odt-format-tags     '("<draw:frame draw:style-name=\"%s\"%s>" . "</draw:frame>")     (concat text (org-e-odt-format-object-description		   (get-text-property 0 :title text)		   (get-text-property 0 :description text)))     style frame-attrs)))(defun org-e-odt-format-textbox (text width height style &optional				      extra anchor-type)  (org-e-odt-format-frame   (org-e-odt-format-tags    '("<draw:text-box %s>" . "</draw:text-box>")    text (concat (format " fo:min-height=\"%0.2fcm\"" (or height .2))		 (unless width		   (format " fo:min-width=\"%0.2fcm\"" (or width .2)))))   width nil style extra anchor-type))(defun org-e-odt-merge-frame-params(default-frame-params user-frame-params)  (if (not user-frame-params) default-frame-params    (assert (= (length default-frame-params) 3))    (assert (= (length user-frame-params) 3))    (loop for user-frame-param in user-frame-params	  for default-frame-param in default-frame-params	  collect (or user-frame-param default-frame-param))))(defun org-e-odt-copy-image-file (path)  "Returns the internal name of the file"  (let* ((image-type (file-name-extension path))	 (media-type (format "image/%s" image-type))	 (src-file (expand-file-name		    path (file-name-directory org-current-export-file)))	 (target-dir "Images/")	 (target-file	  (format "%s%04d.%s" target-dir		  (incf org-e-odt-embedded-images-count) image-type)))    (message "Embedding %s as %s ..."	     (substring-no-properties path) target-file)    (when (= 1 org-e-odt-embedded-images-count)      (make-directory target-dir)      (org-e-odt-create-manifest-file-entry "" target-dir))    (copy-file src-file target-file 'overwrite)    (org-e-odt-create-manifest-file-entry media-type target-file)    target-file))(defun org-e-odt-do-image-size (probe-method file &optional dpi anchor-type)  (setq dpi (or dpi org-e-odt-pixels-per-inch))  (setq anchor-type (or anchor-type "paragraph"))  (flet ((size-in-cms (size-in-pixels)		      (flet ((pixels-to-cms (pixels)					    (let* ((cms-per-inch 2.54)						   (inches (/ pixels dpi)))					      (* cms-per-inch inches))))			(and size-in-pixels			     (cons (pixels-to-cms (car size-in-pixels))				   (pixels-to-cms (cdr size-in-pixels)))))))    (case probe-method      (emacs       (size-in-cms (ignore-errors	; Emacs could be in batch mode		      (clear-image-cache)		      (image-size (create-image file) 'pixels))))      (imagemagick       (size-in-cms	(let ((dim (shell-command-to-string		    (format "identify -format \"%%w:%%h\" \"%s\"" file))))	  (when (string-match "\\([0-9]+\\):\\([0-9]+\\)" dim)	    (cons (string-to-number (match-string 1 dim))		  (string-to-number (match-string 2 dim)))))))      (t       (cdr (assoc-string anchor-type			  org-e-odt-default-image-sizes-alist))))))(defun org-e-odt-image-size-from-file (file &optional user-width					    user-height scale dpi embed-as)  (unless (file-name-absolute-p file)    (setq file (expand-file-name		file (file-name-directory org-current-export-file))))  (let* (size width height)    (unless (and user-height user-width)      (loop for probe-method in org-e-odt-image-size-probe-method	    until size	    do (setq size (org-e-odt-do-image-size			   probe-method file dpi embed-as)))      (or size (error "Cannot determine Image size. Aborting ..."))      (setq width (car size) height (cdr size)))    (cond     (scale      (setq width (* width scale) height (* height scale)))     ((and user-height user-width)      (setq width user-width height user-height))     (user-height      (setq width (* user-height (/ width height)) height user-height))     (user-width      (setq height (* user-width (/ height width)) width user-width))     (t (ignore)))    ;; ensure that an embedded image fits comfortably within a page    (let ((max-width (car org-e-odt-max-image-size))	  (max-height (cdr org-e-odt-max-image-size)))      (when (or (> width max-width) (> height max-height))	(let* ((scale1 (/ max-width width))	       (scale2 (/ max-height height))	       (scale (min scale1 scale2)))	  (setq width (* scale width) height (* scale height)))))    (cons width height)))(defun org-e-odt-format-label (element info op)  (let* ((caption-from	  (case (org-element-type element)	    (link (org-export-get-parent-paragraph element info))	    (t element)))	 ;; get label and caption.	 (label (org-element-property :name caption-from))	 (caption (org-element-property :caption caption-from))	 (short-caption (cdr caption))	 ;; transcode captions.	 (caption (and (car caption) (org-export-secondary-string				      (car caption) 'e-odt info)))	 (short-caption (and short-caption (org-export-secondary-string					    short-caption 'e-odt info))))    (when (or label caption)      (let* ((default-category	       (cond		((eq (org-element-type element) 'table)		 "__Table__")		((org-e-odt-standalone-image-p element info)		 "__Figure__")		((member (org-element-type element)			 '(latex-environment latex-fragment))		 (let ((processing-type (plist-get info :LaTeX-fragments)))		   (cond		    ((eq processing-type 'dvipng) "__DvipngImage__")		    ((eq processing-type 'mathjax) "__MathFormula__")		    ((eq processing-type 't) "__MathFormula__")		    (t (error "Handle LaTeX:verbatim")))))		((eq (org-element-type element) 'src-block)		 "__Listing__")		(t (error "Handle enumeration of %S" element))))	     (predicate	      (cond	       ((member (org-element-type element)			'(table latex-environment src-block))		nil)	       ((org-e-odt-standalone-image-p element info)		'org-e-odt-standalone-image-p)	       (t (error "Handle enumeration of %S" element))))	     (seqno (org-e-odt-enumerate-element		     element info predicate)) ; FIXME	     ;; handle label props.	     (label-props (assoc default-category org-e-odt-category-map-alist))	     ;; identify opendocument counter	     (counter (nth 1 label-props))	     ;; identify label style	     (label-style (nth 2 label-props))	     ;; grok language setting	     (en-strings (assoc-default "en" org-e-odt-category-strings))	     (lang (plist-get info :language)) ; FIXME	     (lang-strings (assoc-default lang org-e-odt-category-strings))	     ;; retrieve localized category sting	     (pos (- (length org-e-odt-category-map-alist)		     (length (memq label-props org-e-odt-category-map-alist))))	     (category (or (nth pos lang-strings) (nth pos en-strings))))	(case op	  (definition	    ;; assign an internal label, if user has not provided one	    (setq label (or label (format  "%s-%s" default-category seqno)))	    (setq label (org-solidify-link-text label))	    (cons	     (format-spec	      (cadr (assoc-string label-style org-e-odt-label-styles t))	      `((?e . ,category)		(?n . ,(org-e-odt-format-tags-simple			'("<text:sequence text:ref-name=\"%s\" text:name=\"%s\" text:formula=\"ooow:%s+1\" style:num-format=\"1\">" . "</text:sequence>")			seqno label counter counter))		(?c . ,(or caption ""))))	     short-caption))	  (reference	   (assert label)	   (setq label (org-solidify-link-text label))	   (let* ((fmt (cddr (assoc-string label-style org-e-odt-label-styles t)))		  (fmt1 (car fmt))		  (fmt2 (cadr fmt)))	     (org-e-odt-format-tags-simple	      '("<text:sequence-ref text:reference-format=\"%s\" text:ref-name=\"%s\">"		. "</text:sequence-ref>")	      (format-spec fmt2 `((?e . ,category)				  (?n . ,seqno))) fmt1 label)))	  (t (error "Unknow %S on label" op)))))))(defun org-e-odt-format-tags-1 (tag text prefix suffix &rest args)  (cond   ((consp tag)    (concat prefix (apply 'format (car tag) args) text suffix	    (format (cdr tag))))   ((stringp tag)			; singleton tag    (concat prefix (apply 'format tag args) text))))(defun org-e-odt-format-tags (tag text &rest args)  (apply 'org-e-odt-format-tags-1 tag text "\n" "\n" args))(defun org-e-odt-format-tags-simple (tag text &rest args)  (apply 'org-e-odt-format-tags-1 tag text nil nil args))(defun org-e-odt-init-outfile ()  (unless (executable-find "zip")    ;; Not at all OSes ship with zip by default    (error "Executable \"zip\" needed for creating OpenDocument files"))  (let* ((outdir (make-temp-file		  (format org-e-odt-tmpdir-prefix 'odt) t)) ; FIXME	 (content-file (expand-file-name "content.xml" outdir)))    ;; reset variables    (setq org-e-odt-manifest-file-entries nil	  org-e-odt-embedded-images-count 0	  org-e-odt-embedded-formulas-count 0	  org-e-odt-section-count 0	  org-e-odt-entity-labels-alist nil	  org-e-odt-list-stack-stashed nil	  org-e-odt-automatic-styles nil	  org-e-odt-object-counters nil	  org-e-odt-entity-counts-plist nil)    ;; let `htmlfontify' know that we are interested in collecting    ;; styles - FIXME    (setq hfy-user-sheet-assoc nil)    ;; init conten.xml    (with-current-buffer	(find-file-noselect content-file t)      (current-buffer))))(defun org-e-odt-save-as-outfile (target opt-plist)  ;; write automatic styles  (org-e-odt-write-automatic-styles)  ;; update display levels  (org-e-odt-update-display-level org-e-odt-display-outline-level)  ;; write styles file  ;; (when (equal org-lparse-backend 'odt) FIXME  ;;   )  ;; (org-e-odt-update-styles-file opt-plist)  ;; create mimetype file  (let ((mimetype (org-e-odt-write-mimetype-file ;; org-lparse-backend FIXME		   'odt)))    (org-e-odt-create-manifest-file-entry mimetype "/" "1.2"))  ;; create a manifest entry for content.xml  (org-e-odt-create-manifest-file-entry "text/xml" "content.xml")  ;; write out the manifest entries before zipping  (org-e-odt-write-manifest-file)  (let ((xml-files '("mimetype" "META-INF/manifest.xml" "content.xml"		     "meta.xml"))	(zipdir default-directory))    (when (or t (equal org-lparse-backend 'odt)) ; FIXME      (push "styles.xml" xml-files))    (message "Switching to directory %s" (expand-file-name zipdir))    ;; save all xml files    (mapc (lambda (file)	    (with-current-buffer		(find-file-noselect (expand-file-name file) t)	      ;; prettify output if needed	      (when org-e-odt-prettify-xml		(indent-region (point-min) (point-max)))	      (save-buffer 0)))	  xml-files)    (let* ((target-name (file-name-nondirectory target))	   (target-dir (file-name-directory target))	   (cmds `(("zip" "-mX0" ,target-name "mimetype")		   ("zip" "-rmTq" ,target-name "."))))      (when (file-exists-p target)	;; FIXME: If the file is locked this throws a cryptic error	(delete-file target))      (let ((coding-system-for-write 'no-conversion) exitcode err-string)	(message "Creating odt file...")	(mapc	 (lambda (cmd)	   (message "Running %s" (mapconcat 'identity cmd " "))	   (setq err-string		 (with-output-to-string		   (setq exitcode			 (apply 'call-process (car cmd)				nil standard-output nil (cdr cmd)))))	   (or (zerop exitcode)	       (ignore (message "%s" err-string))	       (error "Unable to create odt file (%S)" exitcode)))	 cmds))      ;; move the file from outdir to target-dir      (rename-file target-name target-dir)      ;; kill all xml buffers      (mapc (lambda (file)	      (kill-buffer	       (find-file-noselect (expand-file-name file zipdir) t)))	    xml-files)      (delete-directory zipdir)))  (message "Created %s" target)  (set-buffer (find-file-noselect target t)))(defun org-e-odt-create-manifest-file-entry (&rest args)  (push args org-e-odt-manifest-file-entries))(defun org-e-odt-write-manifest-file ()  (make-directory "META-INF")  (let ((manifest-file (expand-file-name "META-INF/manifest.xml")))    (with-current-buffer	(find-file-noselect manifest-file t)      (insert       "<?xml version=\"1.0\" encoding=\"UTF-8\"?>     <manifest:manifest xmlns:manifest=\"urn:oasis:names:tc:opendocument:xmlns:manifest:1.0\" manifest:version=\"1.2\">\n")      (mapc       (lambda (file-entry)	 (let* ((version (nth 2 file-entry))		(extra (if version			   (format  " manifest:version=\"%s\"" version)			 "")))	   (insert	    (format org-e-odt-manifest-file-entry-tag		    (nth 0 file-entry) (nth 1 file-entry) extra))))       org-e-odt-manifest-file-entries)      (insert "\n</manifest:manifest>"))))(defun org-e-odt-update-meta-file (info) ; FIXME opt-plist  (let ((title (org-export-secondary-string		(plist-get info :title) 'e-odt info))	(author (or (let ((auth (plist-get info :author)))		      (and auth (org-export-secondary-string				 auth 'e-odt info))) ""))	(date (org-e-odt-format-date (plist-get info :date)))	(email (plist-get info :email))	(keywords (plist-get info :keywords))	(description (plist-get info :description)))    (write-region     (concat      "<?xml version=\"1.0\" encoding=\"UTF-8\"?>     <office:document-meta         xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\"         xmlns:xlink=\"http://www.w3.org/1999/xlink\"         xmlns:dc=\"http://purl.org/dc/elements/1.1/\"         xmlns:meta=\"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\"         xmlns:ooo=\"http://openoffice.org/2004/office\"         office:version=\"1.2\">       <office:meta>\n"      (org-e-odt-format-author author) "\n"      (format "<meta:initial-creator>%s</meta:initial-creator>\n" author)      (format "<dc:date>%s</dc:date>\n" date)      (format "<meta:creation-date>%s</meta:creation-date>\n" date)      (format "<meta:generator>%s</meta:generator>\n"	      (concat (and org-export-creator-info org-export-creator-string)))      (format "<meta:keyword>%s</meta:keyword>\n" keywords)      (format "<dc:subject>%s</dc:subject>\n" description)      (format "<dc:title>%s</dc:title>\n" title)      "\n"      "  </office:meta>\n" "</office:document-meta>")     nil (expand-file-name "meta.xml")))  ;; create a manifest entry for meta.xml  (org-e-odt-create-manifest-file-entry "text/xml" "meta.xml"))(defun org-e-odt-update-styles-file (info)  ;; write styles file  (let ((styles-file (plist-get info :odt-styles-file)))    (org-e-odt-copy-styles-file (and styles-file				     (read (org-trim styles-file))))    ;; FIXME: Who is opening an empty styles.xml before this point?    (with-current-buffer	(find-file-noselect (expand-file-name "styles.xml") t)      (revert-buffer t t)))  ;; Write custom styles for source blocks  (org-e-odt-insert-custom-styles-for-srcblocks   (mapconcat    (lambda (style)      (format " %s\n" (cddr style)))    hfy-user-sheet-assoc "")))(defun org-e-odt-write-mimetype-file (format)  ;; create mimetype file  (let ((mimetype	 (case format	   (odt "application/vnd.oasis.opendocument.text")	   (odf "application/vnd.oasis.opendocument.formula")	   (t (error "Unknown OpenDocument backend %S" org-lparse-backend)))))    (write-region mimetype nil (expand-file-name "mimetype"))    mimetype))(declare-function org-create-math-formula "org"		  (latex-frag &optional mathml-file))(defun org-e-odt-get (what &optional opt-plist)  (case what    (EXPORT-DIR (org-export-directory :html opt-plist))    (TABLE-FIRST-COLUMN-AS-LABELS nil)    (CODING-SYSTEM-FOR-WRITE 'utf-8)    (CODING-SYSTEM-FOR-SAVE 'utf-8)    (t (error "Unknown property: %s"  what))))(defun org-e-odt-do-preprocess-latex-fragments ()  "Convert LaTeX fragments to images."  (let* ((latex-frag-opt (plist-get org-lparse-opt-plist :LaTeX-fragments))	 (latex-frag-opt		;  massage the options	  (or (and (member latex-frag-opt '(mathjax t))		   (not (and (fboundp 'org-format-latex-mathml-available-p)			     (org-format-latex-mathml-available-p)))		   (prog1 org-lparse-latex-fragment-fallback		     (org-lparse-warn		      (concat		       "LaTeX to MathML converter not available. "		       (format "Using %S instead."			       org-lparse-latex-fragment-fallback)))))	      latex-frag-opt))	 cache-dir display-msg)    (cond     ((eq latex-frag-opt 'dvipng)      (setq cache-dir "ltxpng/")      (setq display-msg "Creating LaTeX image %s"))     ((member latex-frag-opt '(mathjax t))      (setq latex-frag-opt 'mathml)      (setq cache-dir "ltxmathml/")      (setq display-msg "Creating MathML formula %s")))    (when (and org-current-export-file)      (org-format-latex       (concat cache-dir (file-name-sans-extension			  (file-name-nondirectory org-current-export-file)))       org-current-export-dir nil display-msg       nil nil latex-frag-opt))))(eval-after-load 'org-odt  '(ad-deactivate 'org-format-latex-as-mathml)) ; FIXME;; (defadvice org-format-latex-as-mathml	; FIXME;;   (after org-e-odt-protect-latex-fragment activate);;   "Encode LaTeX fragment as XML.;; Do this when translation to MathML fails.";;   (when (or (not (> (length ad-return-value) 0));; 	    (get-text-property 0 'org-protected ad-return-value));;     (setq ad-return-value;; 	  (org-propertize (org-e-odt-encode-plain-text (ad-get-arg 0));; 			  'org-protected t))))(defun org-e-odt-zip-extract-one (archive member &optional target)  (require 'arc-mode)  (let* ((target (or target default-directory))	 (archive (expand-file-name archive))	 (archive-zip-extract	  (list "unzip" "-qq" "-o" "-d" target))	 exit-code command-output)    (setq command-output	  (with-temp-buffer	    (setq exit-code (archive-zip-extract archive member))	    (buffer-string)))    (unless (zerop exit-code)      (message command-output)      (error "Extraction failed"))))(defun org-e-odt-zip-extract (archive members &optional target)  (when (atom members) (setq members (list members)))  (mapc (lambda (member)	  (org-e-odt-zip-extract-one archive member target))	members))(defun org-e-odt-copy-styles-file (&optional styles-file)  ;; Non-availability of styles.xml is not a critical error. For now  ;; throw an error purely for aesthetic reasons.  (setq styles-file (or styles-file			org-e-odt-styles-file			(expand-file-name "OrgOdtStyles.xml"					  org-e-odt-styles-dir)			(error "org-e-odt: Missing styles file?")))  (cond   ((listp styles-file)    (let ((archive (nth 0 styles-file))	  (members (nth 1 styles-file)))      (org-e-odt-zip-extract archive members)      (mapc       (lambda (member)	 (when (org-file-image-p member)	   (let* ((image-type (file-name-extension member))		  (media-type (format "image/%s" image-type)))	     (org-e-odt-create-manifest-file-entry media-type member))))       members)))   ((and (stringp styles-file) (file-exists-p styles-file))    (let ((styles-file-type (file-name-extension styles-file)))      (cond       ((string= styles-file-type "xml")	(copy-file styles-file (expand-file-name "styles.xml") t))       ((member styles-file-type '("odt" "ott"))	(org-e-odt-zip-extract styles-file "styles.xml")))))   (t    (error (format "Invalid specification of styles.xml file: %S"		   org-e-odt-styles-file))))  ;; create a manifest entry for styles.xml  (org-e-odt-create-manifest-file-entry "text/xml" "styles.xml"))(defun org-e-odt-configure-outline-numbering ()  "Outline numbering is retained only upto LEVEL.To disable outline numbering pass a LEVEL of 0."  (goto-char (point-min))  (let ((regex	 "<text:outline-level-style\\([^>]*\\)text:level=\"\\([^\"]*\\)\"\\([^>]*\\)>")	(replacement	 "<text:outline-level-style\\1text:level=\"\\2\" style:num-format=\"\">"))    (while (re-search-forward regex nil t)      (unless (let ((sec-num (plist-get info :section-numbers))		    (level (string-to-number (match-string 2))))		(if (wholenump sec-num) (<= level sec-num) sec-num))	(replace-match replacement t nil))))  (save-buffer 0));;;###autoload(defun org-export-as-odf (latex-frag &optional odf-file)  "Export LATEX-FRAG as OpenDocument formula file ODF-FILE.Use `org-create-math-formula' to convert LATEX-FRAG first toMathML.  When invoked as an interactive command, use`org-latex-regexps' to infer LATEX-FRAG from currently activeregion.  If no LaTeX fragments are found, prompt for it.  PushMathML source to kill ring, if `org-export-copy-to-kill-ring' isnon-nil."  (interactive   `(,(let (frag)	(setq frag (and (setq frag (and (region-active-p)					(buffer-substring (region-beginning)							  (region-end))))			(loop for e in org-latex-regexps			      thereis (when (string-match (nth 1 e) frag)					(match-string (nth 2 e) frag)))))	(read-string "LaTeX Fragment: " frag nil frag))     ,(let ((odf-filename (expand-file-name			   (concat			    (file-name-sans-extension			     (or (file-name-nondirectory buffer-file-name)))			    "." "odf")			   (file-name-directory buffer-file-name))))	(read-file-name "ODF filename: " nil odf-filename nil			(file-name-nondirectory odf-filename)))))  (let* ((org-lparse-backend 'odf)	 org-lparse-opt-plist	 (filename (or odf-file		       (expand-file-name			(concat			 (file-name-sans-extension			  (or (file-name-nondirectory buffer-file-name)))			 "." "odf")			(file-name-directory buffer-file-name))))	 (buffer (find-file-noselect (org-e-odt-init-outfile filename)))	 (coding-system-for-write 'utf-8)	 (save-buffer-coding-system 'utf-8))    (set-buffer buffer)    (set-buffer-file-coding-system coding-system-for-write)    (let ((mathml (org-create-math-formula latex-frag)))      (unless mathml (error "No Math formula created"))      (insert mathml)      (or (org-export-push-to-kill-ring	   (upcase (symbol-name org-lparse-backend)))	  (message "Exporting... done")))    (org-e-odt-save-as-outfile filename nil ; FIXME			       )));;;###autoload(defun org-export-as-odf-and-open ()  "Export LaTeX fragment as OpenDocument formula and immediately open it.Use `org-export-as-odf' to read LaTeX fragment and OpenDocumentformula file."  (interactive)  (org-lparse-and-open   nil nil nil (call-interactively 'org-export-as-odf)));;; Driver Starts here;;; Dependencies(require 'format-spec)(eval-when-compile (require 'cl) (require 'table));;; Hooks;; FIXME: it already exists in org-e-odt.el;;; Function Declarations(declare-function org-element-property "org-element" (property element))(declare-function org-element-normalize-string "org-element" (s))(declare-function org-element-parse-secondary-string		  "org-element" (string restriction &optional buffer))(defvar org-element-string-restrictions)(defvar org-element-object-restrictions)(declare-function org-export-clean-table "org-export" (table specialp))(declare-function org-export-data "org-export" (data backend info))(declare-function org-export-directory "org-export" (type plist))(declare-function org-export-expand-macro "org-export" (macro info))(declare-function org-export-first-sibling-p "org-export" (headline info))(declare-function org-export-footnote-first-reference-p "org-export"		  (footnote-reference info))(declare-function org-export-get-coderef-format "org-export" (path desc))(declare-function org-export-get-footnote-definition "org-export"		  (footnote-reference info))(declare-function org-export-get-footnote-number "org-export" (footnote info))(declare-function org-export-get-previous-element "org-export" (blob info))(declare-function org-export-get-relative-level "org-export" (headline info))(declare-function org-export-handle-code		  "org-export" (element info &optional num-fmt ref-fmt delayed))(declare-function org-export-included-file "org-export" (keyword backend info))(declare-function org-export-inline-image-p "org-export"		  (link &optional extensions))(declare-function org-export-last-sibling-p "org-export" (headline info))(declare-function org-export-low-level-p "org-export" (headline info))(declare-function org-export-output-file-name		  "org-export" (extension &optional subtreep pub-dir))(declare-function org-export-resolve-coderef "org-export" (ref info))(declare-function org-export-resolve-fuzzy-link "org-export" (link info))(declare-function org-export-secondary-string "org-export"		  (secondary backend info))(declare-function org-export-solidify-link-text "org-export" (s))(declare-function org-export-table-format-info "org-export" (table))(declare-function org-export-to-buffer "org-export" (backend buffer &optional subtreep visible-only body-only ext-plist))(declare-function org-export-to-file "org-export" (backend file &optional subtreep visible-only body-only ext-plist))(declare-function org-id-find-id-file "org-id" (id))(declare-function htmlize-region "ext:htmlize" (beg end))(declare-function org-pop-to-buffer-same-window		  "org-compat" (&optional buffer-or-name norecord label))(declare-function hfy-face-to-style "htmlfontify" (fn))(declare-function hfy-face-or-def-to-name "htmlfontify" (fn))(declare-function archive-zip-extract "arc-mode.el" (archive name));;; Internal Variables;;;; ODT Internal Variables(defconst org-e-odt-lib-dir  (file-name-directory load-file-name)  "Location of ODT exporter.Use this to infer values of `org-e-odt-styles-dir' and`org-e-odt-schema-dir'.")(defvar org-e-odt-data-dir  (expand-file-name "../../etc/" org-e-odt-lib-dir)  "Data directory for ODT exporter.Use this to infer values of `org-e-odt-styles-dir' and`org-e-odt-schema-dir'.")(defconst org-e-odt-special-string-regexps  '(("\\\\-" . "­\\1")		; shy    ("---\\([^-]\\)" . "—\\1")	; mdash    ("--\\([^-]\\)" . "–\\1")	; ndash    ("\\.\\.\\." . "…"))		; hellip  "Regular expressions for special string conversion.")(defconst org-e-odt-schema-dir-list  (list   (and org-e-odt-data-dir	(expand-file-name "./schema/" org-e-odt-data-dir)) ; bail out   (eval-when-compile     (and (boundp 'org-e-odt-data-dir) org-e-odt-data-dir ; see make install	  (expand-file-name "./schema/" org-e-odt-data-dir))))  "List of directories to search for OpenDocument schema files.Use this list to set the default value of`org-e-odt-schema-dir'.  The entries in this list arepopulated heuristically based on the values of `org-e-odt-lib-dir'and `org-e-odt-data-dir'.")(defconst org-e-odt-styles-dir-list  (list   (and org-e-odt-data-dir	(expand-file-name "./styles/" org-e-odt-data-dir)) ; bail out   (eval-when-compile     (and (boundp 'org-e-odt-data-dir) org-e-odt-data-dir ; see make install	  (expand-file-name "./styles/" org-e-odt-data-dir)))   (expand-file-name "../../etc/styles/" org-e-odt-lib-dir) ; git   (expand-file-name "./etc/styles/" org-e-odt-lib-dir)  ; elpa   (expand-file-name "./org/" data-directory)	       ; system   )  "List of directories to search for OpenDocument styles files.See `org-e-odt-styles-dir'.  The entries in this list are populatedheuristically based on the values of `org-e-odt-lib-dir' and`org-e-odt-data-dir'.")(defconst org-e-odt-styles-dir  (let* ((styles-dir	  (catch 'styles-dir	    (message "Debug (org-e-odt): Searching for OpenDocument styles files...")	    (mapc (lambda (styles-dir)		    (when styles-dir		      (message "Debug (org-e-odt): Trying %s..." styles-dir)		      (when (and (file-readable-p				  (expand-file-name				   "OrgOdtContentTemplate.xml" styles-dir))				 (file-readable-p				  (expand-file-name				   "OrgOdtStyles.xml" styles-dir)))			(message "Debug (org-e-odt): Using styles under %s"				 styles-dir)			(throw 'styles-dir styles-dir))))		  org-e-odt-styles-dir-list)	    nil)))    (unless styles-dir      (error "Error (org-e-odt): Cannot find factory styles files. Aborting."))    styles-dir)  "Directory that holds auxiliary XML files used by the ODT exporter.This directory contains the following XML files - \"OrgOdtStyles.xml\" and \"OrgOdtContentTemplate.xml\".  These XML files are used as the default values of `org-e-odt-styles-file' and `org-e-odt-content-template-file'.The default value of this variable varies depending on theversion of org in use and is initialized from`org-e-odt-styles-dir-list'.  Note that the user could be using orgfrom one of: org's own private git repository, GNU ELPA tar orstandard Emacs.")(defconst org-e-odt-tmpdir-prefix "%s-")(defconst org-e-odt-bookmark-prefix "OrgXref.")(defconst org-e-odt-manifest-file-entry-tag  "<manifest:file-entry manifest:media-type=\"%s\" manifest:full-path=\"%s\"%s/>")(defvar org-lparse-dyn-first-heading-pos) ; let bound during org-do-lparse(defvar org-e-odt-suppress-xref nil)(defvar org-e-odt-file-extensions  '(("odt" . "OpenDocument Text")    ("ott" . "OpenDocument Text Template")    ("odm" . "OpenDocument Master Document")    ("ods" . "OpenDocument Spreadsheet")    ("ots" . "OpenDocument Spreadsheet Template")    ("odg" . "OpenDocument Drawing (Graphics)")    ("otg" . "OpenDocument Drawing Template")    ("odp" . "OpenDocument Presentation")    ("otp" . "OpenDocument Presentation Template")    ("odi" . "OpenDocument Image")    ("odf" . "OpenDocument Formula")    ("odc" . "OpenDocument Chart")))(defvar org-e-odt-default-org-styles-alist  '((paragraph . ((default . "Text_20_body")		  (fixedwidth . "OrgFixedWidthBlock")		  (verse . "OrgVerse")		  (quote . "Quotations")		  (blockquote . "Quotations")		  (center . "OrgCenter")		  (left . "OrgLeft")		  (right . "OrgRight")		  (title . "OrgTitle")		  (subtitle . "OrgSubtitle")		  (footnote . "Footnote")		  (src . "OrgSrcBlock")		  (illustration . "Illustration")		  (table . "Table")		  (listing . "Listing")		  (definition-term . "Text_20_body_20_bold")		  (horizontal-line . "Horizontal_20_Line")))    (character . ((bold . "Bold")		  (emphasis . "Emphasis")		  (code . "OrgCode")		  (verbatim . "OrgCode")		  (strike . "Strikethrough")		  (underline . "Underline")		  (subscript . "OrgSubscript")		  (superscript . "OrgSuperscript")))    (list . ((ordered . "OrgNumberedList")	     (unordered . "OrgBulletedList")	     (descriptive . "OrgDescriptionList"))))  "Default styles for various entities.")(defvar org-e-odt-org-styles-alist org-e-odt-default-org-styles-alist);;;_. callbacks;;;_. control callbacks;;;_ , document body(defvar org-lparse-body-only)		; let bound during org-do-lparse(defvar org-lparse-opt-plist)		    ; bound during org-do-lparse(defvar org-lparse-list-stack) ; dynamically bound in org-do-lparse(defvar org-e-odt-list-stack-stashed)(defvar org-lparse-table-ncols)(defvar org-e-odt-table-rowgrp-open)(defvar org-e-odt-table-rownum)(defvar org-e-odt-table-cur-rowgrp-is-hdr)(defvar org-lparse-table-is-styled)(defvar org-lparse-table-rowgrp-info)(defvar org-lparse-table-colalign-vector)(defvar org-e-odt-table-style nil  "Table style specified by \"#+ATTR_ODT: <style-name>\" line.This is set during `org-e-odt-begin-table'.")(defvar org-e-odt-table-style-spec nil  "Entry for `org-e-odt-table-style' in `org-e-odt-table-styles'.")(defvar org-e-odt-table-style-format  "<style:style style:name=\"%s\" style:family=\"table\">  <style:table-properties style:rel-width=\"%d%%\" fo:margin-top=\"0cm\" fo:margin-bottom=\"0.20cm\" table:align=\"center\"/></style:style>"  "Template for auto-generated Table styles.")(defvar org-e-odt-automatic-styles '()  "Registry of automatic styles for various OBJECT-TYPEs.The variable has the following form:\(\(OBJECT-TYPE-A  \(\(OBJECT-NAME-A.1 OBJECT-PROPS-A.1\)   \(OBJECT-NAME-A.2 OBJECT-PROPS-A.2\) ...\)\) \(OBJECT-TYPE-B  \(\(OBJECT-NAME-B.1 OBJECT-PROPS-B.1\)   \(OBJECT-NAME-B.2 OBJECT-PROPS-B.2\) ...\)\) ...\).OBJECT-TYPEs could be \"Section\", \"Table\", \"Figure\" etc.OBJECT-PROPS is (typically) a plist created by passing\"#+ATTR_ODT: \" option to `org-e-odt-parse-block-attributes'.Use `org-e-odt-add-automatic-style' to add update this variable.'")(defvar org-e-odt-object-counters nil  "Running counters for various OBJECT-TYPEs.Use this to generate automatic names and style-names. See`org-e-odt-add-automatic-style'.")(defvar org-e-odt-table-indentedp nil)(defvar org-lparse-table-colalign-info)(defvar org-lparse-link-description-is-image nil)(defvar org-src-block-paragraph-format  "<style:style style:name=\"OrgSrcBlock\" style:family=\"paragraph\" style:parent-style-name=\"Preformatted_20_Text\">   <style:paragraph-properties fo:background-color=\"%s\" fo:padding=\"0.049cm\" fo:border=\"0.51pt solid #000000\" style:shadow=\"none\">    <style:background-image/>   </style:paragraph-properties>   <style:text-properties fo:color=\"%s\"/>  </style:style>"  "Custom paragraph style for colorized source and example blocks.This style is much the same as that of \"OrgFixedWidthBlock\"except that the foreground and background colors are setaccording to the default face identified by the `htmlfontify'.")(defvar hfy-optimisations)(defvar org-e-odt-embedded-formulas-count 0)(defvar org-e-odt-entity-frame-styles  '(("As-CharImage" "__Figure__" ("OrgInlineImage" nil "as-char"))    ("ParagraphImage" "__Figure__" ("OrgDisplayImage" nil "paragraph"))    ("PageImage" "__Figure__" ("OrgPageImage" nil "page"))    ("CaptionedAs-CharImage" "__Figure__"     ("OrgCaptionedImage"      " style:rel-width=\"100%\" style:rel-height=\"scale\"" "paragraph")     ("OrgInlineImage" nil "as-char"))    ("CaptionedParagraphImage" "__Figure__"     ("OrgCaptionedImage"      " style:rel-width=\"100%\" style:rel-height=\"scale\"" "paragraph")     ("OrgImageCaptionFrame" nil "paragraph"))    ("CaptionedPageImage" "__Figure__"     ("OrgCaptionedImage"      " style:rel-width=\"100%\" style:rel-height=\"scale\"" "paragraph")     ("OrgPageImageCaptionFrame" nil "page"))    ("InlineFormula" "__MathFormula__" ("OrgInlineFormula" nil "as-char"))    ("DisplayFormula" "__MathFormula__" ("OrgDisplayFormula" nil "as-char"))    ("CaptionedDisplayFormula" "__MathFormula__"     ("OrgCaptionedFormula" nil "paragraph")     ("OrgFormulaCaptionFrame" nil "as-char"))))(defvar org-e-odt-embedded-images-count 0)(defvar org-e-odt-image-size-probe-method  (append (and (executable-find "identify") '(imagemagick)) ; See Bug#10675	  '(emacs fixed))  "Ordered list of methods for determining image sizes.")(defvar org-e-odt-default-image-sizes-alist  '(("as-char" . (5 . 0.4))    ("paragraph" . (5 . 5)))  "Hardcoded image dimensions one for each of the anchor  methods.");; A4 page size is 21.0 by 29.7 cms;; The default page settings has 2cm margin on each of the sides. So;; the effective text area is 17.0 by 25.7 cm(defvar org-e-odt-max-image-size '(17.0 . 20.0)  "Limiting dimensions for an embedded image.")(defvar org-e-odt-entity-labels-alist nil  "Associate Labels with the Labeled entities.Each element of the alist is of the form (LABEL-NAMECATEGORY-NAME SEQNO LABEL-STYLE-NAME).  LABEL-NAME is same asthat specified by \"#+LABEL: ...\" line.  CATEGORY-NAME is thetype of the entity that LABEL-NAME is attached to.  CATEGORY-NAMEcan be one of \"Table\", \"Figure\" or \"Equation\".  SEQNO isthe unique number assigned to the referenced entity on aper-CATEGORY basis.  It is generated sequentially and is 1-based.LABEL-STYLE-NAME is a key `org-e-odt-label-styles'.See `org-e-odt-add-label-definition' and`org-e-odt-fixup-label-references'.")(defvar org-e-odt-entity-counts-plist nil  "Plist of running counters of SEQNOs for each of the CATEGORY-NAMEs.See `org-e-odt-entity-labels-alist' for known CATEGORY-NAMEs.")(defvar org-e-odt-label-styles  '(("math-formula" "%c" "text" "(%n)")    ("math-label" "(%n)" "text" "(%n)")    ("category-and-value" "%e %n: %c" "category-and-value" "%e %n")    ("value" "%e %n: %c" "value" "%n"))  "Specify how labels are applied and referenced.This is an alist where each element is of theform (LABEL-STYLE-NAME LABEL-ATTACH-FMT LABEL-REF-MODELABEL-REF-FMT).LABEL-ATTACH-FMT controls how labels and captions are attached toan entity.  It may contain following specifiers - %e, %n and %c.%e is replaced with the CATEGORY-NAME.  %n is replaced with\"<text:sequence ...> SEQNO </text:sequence>\".  %c is replacedwith CAPTION. See `org-e-odt-format-label-definition'.LABEL-REF-MODE and LABEL-REF-FMT controls how label referencesare generated.  The following XML is generated for a labelreference - \"<text:sequence-reftext:reference-format=\"LABEL-REF-MODE\" ...> LABEL-REF-FMT</text:sequence-ref>\".  LABEL-REF-FMT may contain followingspecifiers - %e and %n.  %e is replaced with the CATEGORY-NAME.%n is replaced with SEQNO. See`org-e-odt-format-label-reference'.")(defcustom org-e-odt-category-strings  '(("en" "Table" "Figure" "Equation" "Equation" "Listing"))  "Specify category strings for various captionable entities.Captionable entity can be one of a Table, an Embedded Image, aLaTeX fragment (generated with dvipng) or a Math Formula.For example, when `org-export-default-language' is \"en\", anembedded image will be captioned as \"Figure 1: Orgmode Logo\".If you want the images to be captioned instead as \"Illustration1: Orgmode Logo\", then modify the entry for \"en\" as shownbelow.  \(setq org-e-odt-category-strings	'\(\(\"en\" \"Table\" \"Illustration\"	   \"Equation\" \"Equation\"\)\)\)"  :group 'org-export-e-odt  :version "24.1"  :type '(repeat (list (string :tag "Language tag")		       (choice :tag "Table"			       (const :tag "Use Default" nil)			       (string :tag "Category string"))		       (choice :tag "Figure"			       (const :tag "Use Default" nil)			       (string :tag "Category string"))		       (choice :tag "Math Formula"			       (const :tag "Use Default" nil)			       (string :tag "Category string"))		       (choice :tag "Dvipng Image"			       (const :tag "Use Default" nil)			       (string :tag "Category string"))		       (choice :tag "Listing"			       (const :tag "Use Default" nil)			       (string :tag "Category string")))))(defvar org-e-odt-category-map-alist  '(("__Table__" "Table" "value")    ("__Figure__" "Illustration" "value")    ("__MathFormula__" "Text" "math-formula")    ("__DvipngImage__" "Equation" "value")    ("__Listing__" "Listing" "value")    ;; ("__Table__" "Table" "category-and-value")    ;; ("__Figure__" "Figure" "category-and-value")    ;; ("__DvipngImage__" "Equation" "category-and-value")    )  "Map a CATEGORY-HANDLE to OD-VARIABLE and LABEL-STYLE.This is a list where each entry is of the form \\(CATEGORY-HANDLEOD-VARIABLE LABEL-STYLE\\).  CATEGORY_HANDLE identifies thecaptionable entity in question.  OD-VARIABLE is the OpenDocumentsequence counter associated with the entity.  These counters aredeclared within\"<text:sequence-decls>...</text:sequence-decls>\" block of`org-e-odt-content-template-file'.  LABEL-STYLE is a keyinto `org-e-odt-label-styles' and specifies how a given entityshould be captioned and referenced.The position of a CATEGORY-HANDLE in this list is used as anindex in to per-language entry for`org-e-odt-category-strings' to retrieve a CATEGORY-NAME.This CATEGORY-NAME is then used for qualifying the user-specifiedcaptions on export.")(defvar org-e-odt-manifest-file-entries nil)(defvar hfy-user-sheet-assoc)		; bound during org-do-lparse(defvar org-lparse-latex-fragment-fallback) ; set by org-do-lparse;;;; HTML Internal Variables(defvar org-e-odt-option-alist  '(    ;; (:agenda-style nil nil org-agenda-export-html-style)    ;; (:convert-org-links nil nil org-e-odt-link-org-files-as-html)    ;; ;; FIXME Use (org-xml-encode-org-text-skip-links s) ??    ;; ;; (:expand-quoted-html nil "@" org-e-odt-expand)    ;; (:inline-images nil nil org-e-odt-inline-images)    ;; ;; (:link-home nil nil org-e-odt-link-home) FIXME    ;; ;; (:link-up nil nil org-e-odt-link-up) FIXME    ;; (:style nil nil org-e-odt-style)    ;; (:style-extra nil nil org-e-odt-style-extra)    ;; (:style-include-default nil nil org-e-odt-style-include-default)    ;; (:style-include-scripts nil nil org-e-odt-style-include-scripts)    ;; ;; (:timestamp nil nil org-e-odt-with-timestamp)    ;; (:html-extension nil nil org-e-odt-extension)    ;; (:html-postamble nil nil org-e-odt-postamble)    ;; (:html-preamble nil nil org-e-odt-preamble)    ;; (:html-table-tag nil nil org-e-odt-table-tag)    ;; (:xml-declaration nil nil org-e-odt-xml-declaration)    (:odt-styles-file "ODT_STYLES_FILE" nil nil t)    (:LaTeX-fragments nil "LaTeX" org-export-with-LaTeX-fragments))  "Alist between export properties and ways to set them.The car of the alist is the property name, and the cdr is a listlike \(KEYWORD OPTION DEFAULT BEHAVIOUR\) where:KEYWORD is a string representing a buffer keyword, or nil.OPTION is a string that could be found in an #+OPTIONS: line.DEFAULT is the default value for the property.BEHAVIOUR determine how Org should handle multiple keywords forthe same property.  It is a symbol among:  nil       Keep old value and discard the new one.  t         Replace old value with the new one.  `space'   Concatenate the values, separating them with a space.  `newline' Concatenate the values, separating them with            a newline.  `split'   Split values at white spaces, and cons them to the            previous list.KEYWORD and OPTION have precedence over DEFAULT.All these properties should be back-end agnostic.  For back-endspecific properties, define a similar variable named`org-BACKEND-option-alist', replacing BACKEND with the name ofthe appropriate back-end.  You can also redefine propertiesthere, as they have precedence over these.")(defvar html-table-tag nil) ; dynamically scoped into this.;; FIXME: it already exists in org-e-odt.el(defconst org-e-odt-cvt-link-fn   nil   "Function to convert link URLs to exportable URLs.Takes two arguments, TYPE and PATH.Returns exportable url as (TYPE PATH), or nil to signal that itdidn't handle this case.Intended to be locally bound around a call to `org-export-as-html'." )(defvar org-e-odt-format-table-no-css)(defvar htmlize-buffer-places)  ; from htmlize.el(defvar body-only) ; dynamically scoped into this.(defvar org-e-odt-table-rowgrp-open)(defvar org-e-odt-table-rownum)(defvar org-e-odt-table-cur-rowgrp-is-hdr)(defvar org-lparse-table-is-styled)(defvar org-e-odt-headline-formatter  (lambda (level snumber todo todo-type priority		 title tags target extra-targets extra-class)    (concat snumber " " title)));;; User Configuration Variables(defgroup org-export-e-odt nil  "Options for exporting Org mode files to ODT."  :tag "Org Export ODT"  :group 'org-export)(defcustom org-e-odt-protect-char-alist  '(("&" . "&")    ("<" . "<")    (">" . ">"))  "Alist of characters to be converted by `org-e-html-protect'."  :group 'org-export-e-html  :type '(repeat (cons (string :tag "Character")		       (string :tag "ODT equivalent"))))(defcustom org-e-odt-schema-dir  (let* ((schema-dir	  (catch 'schema-dir	    (message "Debug (org-e-odt): Searching for OpenDocument schema files...")	    (mapc	     (lambda (schema-dir)	       (when schema-dir		 (message "Debug (org-e-odt): Trying %s..." schema-dir)		 (when (and (file-readable-p			     (expand-file-name "od-manifest-schema-v1.2-cs01.rnc"					       schema-dir))			    (file-readable-p			     (expand-file-name "od-schema-v1.2-cs01.rnc"					       schema-dir))			    (file-readable-p			     (expand-file-name "schemas.xml" schema-dir)))		   (message "Debug (org-e-odt): Using schema files under %s"			    schema-dir)		   (throw 'schema-dir schema-dir))))	     org-e-odt-schema-dir-list)	    (message "Debug (org-e-odt): No OpenDocument schema files installed")	    nil)))    schema-dir)  "Directory that contains OpenDocument schema files.This directory contains:1. rnc files for OpenDocument schema2. a \"schemas.xml\" file that specifies locating rules needed   for auto validation of OpenDocument XML files.Use the customize interface to set this variable.  This ensuresthat `rng-schema-locating-files' is updated and auto-validationof OpenDocument XML takes place based on the value`rng-nxml-auto-validate-flag'.The default value of this variable varies depending on theversion of org in use and is initialized from`org-e-odt-schema-dir-list'.  The OASIS schema files are availableonly in the org's private git repository.  It is *not* bundledwith GNU ELPA tar or standard Emacs distribution."  :type '(choice	  (const :tag "Not set" nil)	  (directory :tag "Schema directory"))  :group 'org-export-e-odt  :version "24.1"  :set  (lambda (var value)    "Set `org-e-odt-schema-dir'.Also add it to `rng-schema-locating-files'."    (let ((schema-dir value))      (set var	   (if (and		(file-readable-p		 (expand-file-name "od-manifest-schema-v1.2-cs01.rnc" schema-dir))		(file-readable-p		 (expand-file-name "od-schema-v1.2-cs01.rnc" schema-dir))		(file-readable-p		 (expand-file-name "schemas.xml" schema-dir)))	       schema-dir	     (when value	       (message "Error (org-e-odt): %s has no OpenDocument schema files"			value))	     nil)))    (when org-e-odt-schema-dir      (eval-after-load 'rng-loc	'(add-to-list 'rng-schema-locating-files		      (expand-file-name "schemas.xml"					org-e-odt-schema-dir))))))(defcustom org-e-odt-content-template-file nil  "Template file for \"content.xml\".The exporter embeds the exported content just before\"</office:text>\" element.If unspecified, the file named \"OrgOdtContentTemplate.xml\"under `org-e-odt-styles-dir' is used."  :type 'file  :group 'org-export-e-odt  :version "24.1")(defcustom org-e-odt-styles-file nil  "Default styles file for use with ODT export.Valid values are one of:1. nil2. path to a styles.xml file3. path to a *.odt or a *.ott file4. list of the form (ODT-OR-OTT-FILE (FILE-MEMBER-1 FILE-MEMBER-2...))In case of option 1, an in-built styles.xml is used. See`org-e-odt-styles-dir' for more information.In case of option 3, the specified file is unzipped and thestyles.xml embedded therein is used.In case of option 4, the specified ODT-OR-OTT-FILE is unzippedand FILE-MEMBER-1, FILE-MEMBER-2 etc are copied in to thegenerated odt file.  Use relative path for specifying theFILE-MEMBERS.  styles.xml must be specified as one of theFILE-MEMBERS.Use options 1, 2 or 3 only if styles.xml alone suffices forachieving the desired formatting.  Use option 4, if the styles.xmlreferences additional files like header and footer images forachieving the desired formatting.Use \"#+ODT_STYLES_FILE: ...\" directive to set this variable ona per-file basis.  For example,#+ODT_STYLES_FILE: \"/path/to/styles.xml\" or#+ODT_STYLES_FILE: (\"/path/to/file.ott\" (\"styles.xml\" \"image/hdr.png\"))."  :group 'org-export-e-odt  :version "24.1"  :type  '(choice    (const :tag "Factory settings" nil)    (file :must-match t :tag "styles.xml")    (file :must-match t :tag "ODT or OTT file")    (list :tag "ODT or OTT file + Members"	  (file :must-match t :tag "ODF Text or Text Template file")	  (cons :tag "Members"		(file :tag "	Member" "styles.xml")		(repeat (file :tag "Member"))))))(defcustom org-e-odt-inline-image-extensions  '("png" "jpeg" "jpg" "gif")  "Extensions of image files that can be inlined into HTML."  :type '(repeat (string :tag "Extension"))  :group 'org-export-e-odt  :version "24.1")(defcustom org-e-odt-pixels-per-inch display-pixels-per-inch  "Scaling factor for converting images pixels to inches.Use this for sizing of embedded images.  See Info node `(org)Images in ODT export' for more information."  :type 'float  :group 'org-export-e-odt  :version "24.1")(defcustom org-e-odt-create-custom-styles-for-srcblocks t  "Whether custom styles for colorized source blocks be automatically created.When this option is turned on, the exporter creates custom stylesfor source blocks based on the advice of `htmlfontify'.  Creationof custom styles happen as part of `org-e-odt-hfy-face-to-css'.When this option is turned off exporter does not create suchstyles.Use the latter option if you do not want the custom styles to bebased on your current display settings.  It is necessary that thestyles.xml already contains needed styles for colorizing to work.This variable is effective only if`org-e-odt-fontify-srcblocks' is turned on."  :group 'org-export-e-odt  :version "24.1"  :type 'boolean)(defcustom org-e-odt-preferred-output-format nil  "Automatically post-process to this format after exporting to \"odt\".Interactive commands `org-export-as-e-odt' and`org-export-as-e-odt-and-open' export first to \"odt\" format andthen use `org-e-odt-convert-process' to convert theresulting document to this format.  During customization of thisvariable, the list of valid values are populated based on`org-e-odt-convert-capabilities'."  :group 'org-export-e-odt  :version "24.1"  :type '(choice :convert-widget		 (lambda (w)		   (apply 'widget-convert (widget-type w)			  (eval (car (widget-get w :args)))))		 `((const :tag "None" nil)		   ,@(mapcar (lambda (c)			       `(const :tag ,c ,c))			     (org-e-odt-reachable-formats "odt")))))(defcustom org-e-odt-table-styles  '(("OrgEquation" "OrgEquation"     ((use-first-column-styles . t)      (use-last-column-styles . t))))  "Specify how Table Styles should be derived from a Table Template.This is a list where each element is of theform (TABLE-STYLE-NAME TABLE-TEMPLATE-NAME TABLE-CELL-OPTIONS).TABLE-STYLE-NAME is the style associated with the table through`org-e-odt-table-style'.TABLE-TEMPLATE-NAME is a set of - upto 9 - automaticTABLE-CELL-STYLE-NAMEs and PARAGRAPH-STYLE-NAMEs (as definedbelow) that is included in`org-e-odt-content-template-file'.TABLE-CELL-STYLE-NAME := TABLE-TEMPLATE-NAME + TABLE-CELL-TYPE +                         \"TableCell\"PARAGRAPH-STYLE-NAME  := TABLE-TEMPLATE-NAME + TABLE-CELL-TYPE +                         \"TableParagraph\"TABLE-CELL-TYPE       := \"FirstRow\"   | \"LastColumn\" |                         \"FirstRow\"   | \"LastRow\"    |                         \"EvenRow\"    | \"OddRow\"     |                         \"EvenColumn\" | \"OddColumn\"  | \"\"where \"+\" above denotes string concatenation.TABLE-CELL-OPTIONS is an alist where each element is of theform (TABLE-CELL-STYLE-SELECTOR . ON-OR-OFF).TABLE-CELL-STYLE-SELECTOR := `use-first-row-styles'       |                             `use-last-row-styles'        |                             `use-first-column-styles'    |                             `use-last-column-styles'     |                             `use-banding-rows-styles'    |                             `use-banding-columns-styles' |                             `use-first-row-styles'ON-OR-OFF                 := `t' | `nil'For example, with the following configuration\(setq org-e-odt-table-styles      '\(\(\"TableWithHeaderRowsAndColumns\" \"Custom\"         \(\(use-first-row-styles . t\)          \(use-first-column-styles . t\)\)\)        \(\"TableWithHeaderColumns\" \"Custom\"         \(\(use-first-column-styles . t\)\)\)\)\)1. A table associated with \"TableWithHeaderRowsAndColumns\"   style will use the following table-cell styles -   \"CustomFirstRowTableCell\", \"CustomFirstColumnTableCell\",   \"CustomTableCell\" and the following paragraph styles   \"CustomFirstRowTableParagraph\",   \"CustomFirstColumnTableParagraph\", \"CustomTableParagraph\"   as appropriate.2. A table associated with \"TableWithHeaderColumns\" style will   use the following table-cell styles -   \"CustomFirstColumnTableCell\", \"CustomTableCell\" and the   following paragraph styles   \"CustomFirstColumnTableParagraph\", \"CustomTableParagraph\"   as appropriate..Note that TABLE-TEMPLATE-NAME corresponds to the\"<table:table-template>\" elements contained within\"<office:styles>\".  The entries (TABLE-STYLE-NAMETABLE-TEMPLATE-NAME TABLE-CELL-OPTIONS) correspond to\"table:template-name\" and \"table:use-first-row-styles\" etcattributes of \"<table:table>\" element.  Refer ODF-1.2specification for more information.  Also consult theimplementation filed under `org-e-odt-get-table-cell-styles'.The TABLE-STYLE-NAME \"OrgEquation\" is used internally forformatting of numbered display equations.  Do not delete thisstyle from the list."  :group 'org-export-e-odt  :version "24.1"  :type '(choice          (const :tag "None" nil)          (repeat :tag "Table Styles"                  (list :tag "Table Style Specification"			(string :tag "Table Style Name")			(string  :tag "Table Template Name")			(alist :options (use-first-row-styles					 use-last-row-styles					 use-first-column-styles					 use-last-column-styles					 use-banding-rows-styles					 use-banding-columns-styles)			       :key-type symbol			       :value-type (const :tag "True" t))))))(defcustom org-e-odt-fontify-srcblocks t  "Specify whether or not source blocks need to be fontified.Turn this option on if you want to colorize the source codeblocks in the exported file.  For colorization to work, you needto make available an enhanced version of `htmlfontify' library."  :type 'boolean  :group 'org-export-e-odt  :version "24.1")(defcustom org-e-odt-prettify-xml t ; FIXME  "Specify whether or not the xml output should be prettified.When this option is turned on, `indent-region' is run on allcomponent xml buffers before they are saved.  Turn this off forregular use.  Turn this on if you need to examine the xmlvisually."  :group 'org-export-e-odt  :version "24.1"  :type 'boolean)(defcustom org-e-odt-convert-processes  '(("LibreOffice"     "soffice --headless --convert-to %f%x --outdir %d %i")    ("unoconv"     "unoconv -f %f -o %d %i"))  "Specify a list of document converters and their usage.The converters in this list are offered as choices whilecustomizing `org-e-odt-convert-process'.This variable is a list where each element is of theform (CONVERTER-NAME CONVERTER-CMD).  CONVERTER-NAME is the nameof the converter.  CONVERTER-CMD is the shell command for theconverter and can contain format specifiers.  These formatspecifiers are interpreted as below:%i input file name in full%I input file name as a URL%f format of the output file%o output file name in full%O output file name as a URL%d output dir in full%D output dir as a URL.%x extra options as set in `org-e-odt-convert-capabilities'."  :group 'org-export-e-odt  :version "24.1"  :type  '(choice    (const :tag "None" nil)    (alist :tag "Converters"	   :key-type (string :tag "Converter Name")	   :value-type (group (string :tag "Command line")))))(defcustom org-e-odt-convert-process "LibreOffice"  "Use this converter to convert from \"odt\" format to other formats.During customization, the list of converter names are populatedfrom `org-e-odt-convert-processes'."  :group 'org-export-e-odt  :version "24.1"  :type '(choice :convert-widget		 (lambda (w)		   (apply 'widget-convert (widget-type w)			  (eval (car (widget-get w :args)))))		 `((const :tag "None" nil)		   ,@(mapcar (lambda (c)			       `(const :tag ,(car c) ,(car c)))			     org-e-odt-convert-processes))))(defcustom org-e-odt-convert-capabilities  '(("Text"     ("odt" "ott" "doc" "rtf" "docx")     (("pdf" "pdf") ("odt" "odt") ("rtf" "rtf") ("ott" "ott")      ("doc" "doc" ":\"MS Word 97\"") ("docx" "docx") ("html" "html")))    ("Web"     ("html")     (("pdf" "pdf") ("odt" "odt") ("html" "html")))    ("Spreadsheet"     ("ods" "ots" "xls" "csv" "xlsx")     (("pdf" "pdf") ("ots" "ots") ("html" "html") ("csv" "csv") ("ods" "ods")      ("xls" "xls") ("xlsx" "xlsx")))    ("Presentation"     ("odp" "otp" "ppt" "pptx")     (("pdf" "pdf") ("swf" "swf") ("odp" "odp") ("otp" "otp") ("ppt" "ppt")      ("pptx" "pptx") ("odg" "odg"))))  "Specify input and output formats of `org-e-odt-convert-process'.More correctly, specify the set of input and output formats thatthe user is actually interested in.This variable is an alist where each element is of theform (DOCUMENT-CLASS INPUT-FMT-LIST OUTPUT-FMT-ALIST).INPUT-FMT-LIST is a list of INPUT-FMTs.  OUTPUT-FMT-ALIST is analist where each element is of the form (OUTPUT-FMTOUTPUT-FILE-EXTENSION EXTRA-OPTIONS).The variable is interpreted as follows:`org-e-odt-convert-process' can take any document that is inINPUT-FMT-LIST and produce any document that is in theOUTPUT-FMT-LIST.  A document converted to OUTPUT-FMT will haveOUTPUT-FILE-EXTENSION as the file name extension.  OUTPUT-FMTserves dual purposes:- It is used for populating completion candidates during  `org-e-odt-convert' commands.- It is used as the value of \"%f\" specifier in  `org-e-odt-convert-process'.EXTRA-OPTIONS is used as the value of \"%x\" specifier in`org-e-odt-convert-process'.DOCUMENT-CLASS is used to group a set of file formats inINPUT-FMT-LIST in to a single class.Note that this variable inherently captures how LibreOffice basedconverters work.  LibreOffice maps documents of various formatsto classes like Text, Web, Spreadsheet, Presentation etc andallow document of a given class (irrespective of it's sourceformat) to be converted to any of the export formats associatedwith that class.See default setting of this variable for an typicalconfiguration."  :group 'org-export-e-odt  :version "24.1"  :type  '(choice    (const :tag "None" nil)    (alist :tag "Capabilities"	   :key-type (string :tag "Document Class")	   :value-type	   (group (repeat :tag "Input formats" (string :tag "Input format"))		  (alist :tag "Output formats"			 :key-type (string :tag "Output format")			 :value-type			 (group (string :tag "Output file extension")				(choice				 (const :tag "None" nil)				 (string :tag "Extra options"))))))));;;; Debugging;;;; Document;;;; Document Header (Styles);;;; Document Header (Scripts);;;; Document Header (Mathjax);;;; Preamble;;;; Postamble;;;; Emphasis;;;; Todos;;;; Tags;;;; Time-stamps;;;; Statistics Cookie;;;; Subscript;;;; Superscript;;;; Inline images;;;; Block;;;; Comment;;;; Comment Block;;;; Drawer;;;; Dynamic Block;;;; Emphasis;;;; Entity;;;; Example Block;;;; Export Snippet;;;; Export Block;;;; Fixed Width;;;; Footnotes;;;; Headline;;;; Horizontal Rule;;;; Inline Babel Call;;;; Inline Src Block;;;; Inlinetask;;;; Item;;;; Keyword;;;; Latex Environment;;;; Latex Fragment;;;; Line Break;;;; Link;;;; Babel Call;;;; Macro;;;; Paragraph;;;; Plain List;;;; Plain Text;;;; Property Drawer;;;; Quote Block;;;; Quote Section;;;; Section;;;; Radio Target;;;; Special Block;;;; Src Block;;;; Table;;;; Target;;;; Time-stamp;;;; Verbatim;;;; Verse Block;;;; Headline;;;; Links;;;; Drawers;;;; Inlinetasks;;;; Publishing;;;; Compilation;;; User Configurable Variables (MAYBE);;;; Preamble;;;; Headline;;;; Emphasis(defcustom org-e-odt-format-headline-function nil  "Function to format headline text.This function will be called with 5 arguments:TODO      the todo keyword \(string or nil\).TODO-TYPE the type of todo \(symbol: `todo', `done', nil\)PRIORITY  the priority of the headline \(integer or nil\)TEXT      the main headline text \(string\).TAGS      the tags string, separated with colons \(string or nil\).The function result will be used in the section format string.As an example, one could set the variable to the following, inorder to reproduce the default set-up:\(defun org-e-odt-format-headline \(todo todo-type priority text tags\)  \"Default format function for an headline.\"  \(concat \(when todo            \(format \"\\\\textbf{\\\\textsc{\\\\textsf{%s}}} \" todo\)\)	  \(when priority            \(format \"\\\\framebox{\\\\#%c} \" priority\)\)	  text	  \(when tags \(format \"\\\\hfill{}\\\\textsc{%s}\" tags\)\)\)\)"  :group 'org-export-e-odt  :type 'function);;;; Footnotes;;;; Time-stamps(defcustom org-e-odt-active-timestamp-format "\\textit{%s}"  "A printf format string to be applied to active time-stamps."  :group 'org-export-e-odt  :type 'string)(defcustom org-e-odt-inactive-timestamp-format "\\textit{%s}"  "A printf format string to be applied to inactive time-stamps."  :group 'org-export-e-odt  :type 'string)(defcustom org-e-odt-diary-timestamp-format "\\textit{%s}"  "A printf format string to be applied to diary time-stamps."  :group 'org-export-e-odt  :type 'string);;;; Links(defcustom org-e-odt-inline-image-rules  '(("file" . "\\.\\(jpeg\\|jpg\\|png\\|gif\\)\\'"))  "Rules characterizing image files that can be inlined into HTML.A rule consists in an association whose key is the type of linkto consider, and value is a regexp that will be matched againstlink's path.Note that, by default, the image extension *actually* alloweddepend on the way the HTML file is processed.  When used withpdflatex, pdf, jpg and png images are OK.  When processingthrough dvi to Postscript, only ps and eps are allowed.  Thedefault we use here encompasses both."  :group 'org-export-e-odt  :type '(alist :key-type (string :tag "Type")		:value-type (regexp :tag "Path")));;;; Tables(defcustom org-e-odt-table-caption-above t  "When non-nil, place caption string at the beginning of the table.Otherwise, place it near the end."  :group 'org-export-e-odt  :type 'boolean);;;; Drawers(defcustom org-e-odt-format-drawer-function nil  "Function called to format a drawer in HTML code.The function must accept two parameters:  NAME      the drawer name, like \"LOGBOOK\"  CONTENTS  the contents of the drawer.The function should return the string to be exported.For example, the variable could be set to the following functionin order to mimic default behaviour:\(defun org-e-odt-format-drawer-default \(name contents\)  \"Format a drawer element for HTML export.\"  contents\)"  :group 'org-export-e-odt  :type 'function);;;; Inlinetasks(defcustom org-e-odt-format-inlinetask-function nil  "Function called to format an inlinetask in HTML code.The function must accept six 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 string.  CONTENTS  the contents of the inlinetask, as a string.The function should return the string to be exported.For example, the variable could be set to the following functionin order to mimic default behaviour:\(defun org-e-odt-format-inlinetask \(todo type priority name tags contents\)\"Format an inline task element for HTML export.\"  \(let \(\(full-title	 \(concat	  \(when todo            \(format \"\\\\textbf{\\\\textsf{\\\\textsc{%s}}} \" todo\)\)	  \(when priority \(format \"\\\\framebox{\\\\#%c} \" priority\)\)	  title	  \(when tags \(format \"\\\\hfill{}\\\\textsc{%s}\" tags\)\)\)\)\)    \(format \(concat \"\\\\begin{center}\\n\"		    \"\\\\fbox{\\n\"		    \"\\\\begin{minipage}[c]{.6\\\\textwidth}\\n\"		    \"%s\\n\\n\"		    \"\\\\rule[.8em]{\\\\textwidth}{2pt}\\n\\n\"		    \"%s\"		    \"\\\\end{minipage}}\"		    \"\\\\end{center}\"\)	    full-title contents\)\)"  :group 'org-export-e-odt  :type 'function);; Src blocks;;;; Plain text(defcustom org-e-odt-quotes  '(("fr" ("\\(\\s-\\|[[(]\\)\"" . "«~") ("\\(\\S-\\)\"" . "~»") ("\\(\\s-\\|(\\)'" . "'"))    ("en" ("\\(\\s-\\|[[(]\\)\"" . "``") ("\\(\\S-\\)\"" . "''") ("\\(\\s-\\|(\\)'" . "`")))  "Alist for quotes to use when converting english double-quotes.The CAR of each item in this alist is the language code.The CDR of each item in this alist is a list of three CONS:- the first CONS defines the opening quote;- the second CONS defines the closing quote;- the last CONS defines single quotes.For each item in a CONS, the first string is a regexpfor allowed characters before/after the quote, the secondstring defines the replacement string for this quote."  :group 'org-export-e-odt  :type '(list	  (cons :tag "Opening quote"		(string :tag "Regexp for char before")		(string :tag "Replacement quote     "))	  (cons :tag "Closing quote"		(string :tag "Regexp for char after ")		(string :tag "Replacement quote     "))	  (cons :tag "Single quote"		(string :tag "Regexp for char before")		(string :tag "Replacement quote     "))));;;; Compilation;;; Internal Functions (HTML);; (defun org-e-odt-format-inline-image (path &optional caption label attr);;   ;; FIXME: alt text missing here?;;   (let ((inline-image (format "<img src=\"%s\" alt=\"%s\"/>";; 			      path (file-name-nondirectory path))));;     (if (not label) inline-image;;       (org-e-odt-format-section inline-image "figure" label))));;;; Bibliography(defun org-e-odt-bibliography ()  "Find bibliography, cut it out and return it."  (catch 'exit    (let (beg end (cnt 1) bib)      (save-excursion	(goto-char (point-min))	(when (re-search-forward	       "^[ \t]*<div \\(id\\|class\\)=\"bibliography\"" nil t)	  (setq beg (match-beginning 0))	  (while (re-search-forward "</?div\\>" nil t)	    (setq cnt (+ cnt (if (string= (match-string 0) "<div") +1 -1)))	    (when (= cnt 0)	      (and (looking-at ">") (forward-char 1))	      (setq bib (buffer-substring beg (point)))	      (delete-region beg (point))	    (throw 'exit bib))))	nil))));;;; Table(defun org-e-odt-format-table (lines olines)  (let ((org-e-odt-format-table-no-css nil))    (org-lparse-format-table lines olines)))(defun org-e-odt-splice-attributes (tag attributes)  "Read attributes in string ATTRIBUTES, add and replace in HTML tag TAG."  (if (not attributes)      tag    (let (oldatt newatt)      (setq oldatt (org-extract-attributes-from-string tag)	    tag (pop oldatt)	    newatt (cdr (org-extract-attributes-from-string attributes)))      (while newatt	(setq oldatt (plist-put oldatt (pop newatt) (pop newatt))))      (if (string-match ">" tag)	  (setq tag		(replace-match (concat (org-attributes-to-string oldatt) ">")			       t t tag)))      tag)))(defun org-export-splice-style (style extra)  "Splice EXTRA into STYLE, just before \"</style>\"."  (if (and (stringp extra)	   (string-match "\\S-" extra)	   (string-match "</style>" style))      (concat (substring style 0 (match-beginning 0))	      "\n" extra "\n"	      (substring style (match-beginning 0)))    style))(defun org-e-odt-toc-entry-formatter  (level snumber todo todo-type priority	 headline tags target extra-targets extra-class)  (org-e-odt-format-toc-entry snumber todo headline tags target))(defun org-e-odt-make-string (n string)  (let (out) (dotimes (i n out) (setq out (concat string out)))))(defun org-e-odt-toc-text (toc-entries)  (let* ((prev-level (1- (nth 1 (car toc-entries))))	 (start-level prev-level))    (mapconcat     (lambda (entry)       (let ((headline (nth 0 entry))	     (level (nth 1 entry)))	 (prog1 (org-e-odt-format-toc-item headline level prev-level)	   (setq prev-level level))))     toc-entries "")))(defun* org-e-odt-format-toc-headline    (todo todo-type priority text tags	  &key level section-number headline-label &allow-other-keys)  ;; FIXME  (setq text (concat	      (and org-export-with-section-numbers		   (concat section-number ". "))	      text	      (and tags		   (concat		    (org-e-odt-format-spaces 3)		    (org-e-odt-format-fontify tags "tag")))))  (when todo    (setq text (org-e-odt-format-fontify text "todo")))  (let ((org-e-odt-suppress-xref t))    (org-e-odt-format-link text (concat "#" headline-label))))(defun org-e-odt-toc (depth info)  (assert (wholenump depth))  (let* ((headlines (org-export-collect-headlines info depth))	 (toc-entries	  (loop for headline in headlines collect		(list (org-e-odt-format-headline--wrap		       headline info 'org-e-odt-format-toc-headline)		      (org-export-get-relative-level headline info)))))    (when toc-entries      (let* ((lang-specific-heading "Table of Contents")) ; FIXME	(concat	 (org-e-odt-begin-toc  lang-specific-heading depth)	 (org-e-odt-toc-text toc-entries)	 (org-e-odt-end-toc))))))(defun org-e-odt-begin-outline (level1 snumber title tags				      target extra-targets extra-class)  (let* ((class (format "outline-%d" level1))	 (class (if extra-class (concat  class " " extra-class) class))	 (id (format "outline-container-%s"		     (org-lparse-suffix-from-snumber snumber)))	 (extra (concat (when id (format " id=\"%s\"" id))			(when class (format " class=\"%s\"" class)))))    (org-lparse-insert-tag "<div%s>" extra)    (insert     (org-lparse-format 'HEADING		       (org-lparse-format			'HEADLINE title extra-targets tags snumber level1)		       level1 target))))(defun org-e-odt-end-outline ()  (org-lparse-insert-tag  "</div>"))(defun org-e-odt-suffix-from-snumber (snumber)  (let* ((snu (replace-regexp-in-string "\\." "-" snumber))	 (href (cdr (assoc (concat "sec-" snu)			   org-export-preferred-target-alist))))    (org-solidify-link-text (or href snu))))(defun org-e-odt-format-outline (contents level1 snumber title					  tags target extra-targets extra-class));; (defun org-e-odt-format-line (line);;   (case org-lparse-dyn-current-environment;;     ((quote fixedwidth) (concat (org-e-odt-encode-plain-text line) "\n"));;     (t (concat line "\n"))))(defun org-e-odt-fix-class-name (kwd) 	; audit callers of this function  "Turn todo keyword into a valid class name.Replaces invalid characters with \"_\"."  (save-match-data    (while (string-match "[^a-zA-Z0-9_]" kwd)      (setq kwd (replace-match "_" t t kwd))))  kwd)(defun org-e-odt-format-internal-link (text href &optional extra)  (org-e-odt-format-link text (concat "#" href) extra))(defun org-e-odt-format-extra-targets (extra-targets)  (if (not extra-targets) ""    (mapconcat (lambda (x)		 (when x		   (setq x (org-solidify-link-text			    (if (org-uuidgen-p x) (concat "ID-" x) x)))		   (org-e-odt-format-anchor "" x))) extra-targets "")))(defun org-e-odt-format-org-tags (tags)  (if (not tags) ""    (org-e-odt-format-fontify     (mapconcat      (lambda (x)	(org-e-odt-format-fontify	 x (concat "" ;; org-e-odt-tag-class-prefix		   (org-e-odt-fix-class-name x))))      (org-split-string tags ":")      (org-e-odt-format-spaces 1)) "tag")))(defun org-e-odt-format-section-number (&optional snumber level)  ;; FIXME  (and nil org-export-with-section-numbers       ;; (not org-lparse-body-only)       snumber level       (org-e-odt-format-fontify snumber (format "section-number-%d" level))));; (defun org-e-odt-format-headline (title extra-targets tags;; 				       &optional snumber level);;   (concat;;    (org-e-odt-format-extra-targets extra-targets);;    (concat (org-e-odt-format-section-number snumber level) " ");;    title;;    (and tags (concat (org-e-odt-format-spaces 3);; 		     (org-e-odt-format-org-tags tags)))));; (defun org-e-odt-format-date (info);;   (let ((date (plist-get info :date)));;     (cond;;      ((and date (string-match "%" date));;       (format-time-string date));;      (date date);;      (t (format-time-string "%Y-%m-%d %T %Z")))));;; Internal Functions (Ngz)(defun org-e-odt--caption/label-string (caption label info)  "Return caption and label HTML string for floats.CAPTION is a cons cell of secondary strings, the car being thestandard caption and the cdr its short form.  LABEL is a stringrepresenting the label.  INFO is a plist holding contextualinformation.If there's no caption nor label, return the empty string.For non-floats, see `org-e-odt--wrap-label'."  (setq label nil) ;; FIXME  (let ((label-str (if label (format "\\label{%s}" label) "")))    (cond     ((and (not caption) (not label)) "")     ((not caption) (format "\\label{%s}\n" label))     ;; Option caption format with short name.     ((cdr caption)      (format "\\caption[%s]{%s%s}\n"	      (org-export-secondary-string (cdr caption) 'e-odt info)	      label-str	      (org-export-secondary-string (car caption) 'e-odt info)))     ;; Standard caption format.     ;; (t (format "\\caption{%s%s}\n"     ;; 		label-str     ;; 		(org-export-secondary-string (car caption) 'e-odt info)))     (t (org-export-secondary-string (car caption) 'e-odt info)))))(defun org-e-odt--find-verb-separator (s)  "Return a character not used in string S.This is used to choose a separator for constructs like \\verb."  (let ((ll "~,./?;':\"|!@#%^&-_=+abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ<>()[]{}"))    (loop for c across ll	  when (not (string-match (regexp-quote (char-to-string c)) s))	  return (char-to-string c))))(defun org-e-odt--quotation-marks (text info)  "Export quotation marks depending on language conventions.TEXT is a string containing quotation marks to be replaced.  INFOis a plist used as a communication channel."  (mapc (lambda(l)	  (let ((start 0))	    (while (setq start (string-match (car l) text start))	      (let ((new-quote (concat (match-string 1 text) (cdr l))))		(setq text (replace-match new-quote  t t text))))))	(cdr (or (assoc (plist-get info :language) org-e-odt-quotes)		 ;; Falls back on English.		 (assoc "en" org-e-odt-quotes))))  text)(defun org-e-odt--wrap-label (element output)  "Wrap label associated to ELEMENT around OUTPUT, if appropriate.This function shouldn't be used for floats.  See`org-e-odt--caption/label-string'."  ;; (let ((label (org-element-property :name element)))  ;;   (if (or (not output) (not label) (string= output "") (string= label ""))  ;; 	output  ;;     (concat (format "\\label{%s}\n" label) output)))  output);;; Transcode Helpers(defun* org-e-odt-format-headline    (todo todo-type priority text tags	  &key level section-number headline-label &allow-other-keys)  (concat  (org-e-odt-todo todo) (and todo " ") text	   (and tags (org-e-odt-format-spaces 3))	   (and tags (org-e-odt-format-org-tags tags))));;;; Src Code(defun org-e-odt-htmlfontify-string (line)  (let* ((hfy-html-quote-regex "\\([<\"&> 	]\\)")	 (hfy-html-quote-map '(("\"" """)			       ("<" "<")			       ("&" "&")			       (">" ">")			       (" " "<text:s/>")			       ("	" "<text:tab/>")))	 (hfy-face-to-css 'org-e-odt-hfy-face-to-css)	 (hfy-optimisations-1 (copy-seq hfy-optimisations))	 (hfy-optimisations (add-to-list 'hfy-optimisations-1					 'body-text-only))	 (hfy-begin-span-handler	  (lambda (style text-block text-id text-begins-block-p)	    (insert (format "<text:span text:style-name=\"%s\">" style))))	 (hfy-end-span-handler (lambda nil (insert "</text:span>"))))    (htmlfontify-string line)))(defun org-e-odt-do-format-code  (code &optional lang refs retain-labels num-start)  (let* ((lang (or (assoc-default lang org-src-lang-modes) lang))	 (lang-mode (and lang (intern (format "%s-mode" lang))))	 (code-lines (org-split-string code "\n"))	 (code-length (length code-lines))	 (use-htmlfontify-p (and (functionp lang-mode)				 org-e-odt-fontify-srcblocks				 (require 'htmlfontify nil t)				 (fboundp 'htmlfontify-string)))	 (code (if (not use-htmlfontify-p) code		 (with-temp-buffer		   (insert code)		   (funcall lang-mode)		   (font-lock-fontify-buffer)		   (buffer-string))))	 (fontifier (if use-htmlfontify-p 'org-e-odt-htmlfontify-string		      'org-e-odt-encode-plain-text))	 (par-style (if use-htmlfontify-p "OrgSrcBlock"		      "OrgFixedWidthBlock"))	 (i 0))    (assert (= code-length (length (org-split-string code "\n"))))    (setq code	  (org-export-format-code	   code	   (lambda (loc line-num ref)	     (setq par-style		   (concat par-style (and (= (incf i) code-length) "LastLine")))	     (setq loc (concat loc (and ref retain-labels (format " (%s)" ref))))	     (setq loc (funcall fontifier loc))	     (when ref	       (setq loc (org-e-odt-format-target loc (concat "coderef-" ref))))	     (setq loc (org-e-odt-format-stylized-paragraph par-style loc))	     (if (not line-num) loc	       (org-e-odt-format-tags		'("<text:list-item>" . "</text:list-item>") loc)))	   num-start refs))    (cond     ((not num-start) code)     ((equal num-start 0)      (org-e-odt-format-tags       '("<text:list text:style-name=\"OrgSrcBlockNumberedLine\"%s>"	 . "</text:list>") code " text:continue-numbering=\"false\""))     (t (org-e-odt-format-tags	 '("<text:list text:style-name=\"OrgSrcBlockNumberedLine\"%s>"	   . "</text:list>") code " text:continue-numbering=\"true\"")))))(defun org-e-odt-format-code (element info)  (let* ((lang (org-element-property :language element))	 ;; Extract code and references.	 (code-info (org-export-unravel-code element))	 (code (car code-info))	 (refs (cdr code-info))	 ;; Does the src block contain labels?	 (retain-labels (org-element-property :retain-labels element))	 ;; Does it have line numbers?	 (num-start (case (org-element-property :number-lines element)		      (continued (org-export-get-loc element info))		      (new 0))))    (org-e-odt-do-format-code code lang refs retain-labels num-start)));;; Template(defun org-e-odt-template (contents info)  "Return complete document string after HTML conversion.CONTENTS is the transcoded contents string.  RAW-DATA is theoriginal parsed data.  INFO is a plist holding export options."  ;; write meta file  (org-e-odt-update-meta-file info)  (with-temp-buffer    (insert-file-contents     (or org-e-odt-content-template-file	 (expand-file-name "OrgOdtContentTemplate.xml"			   org-e-odt-styles-dir)))    (goto-char (point-min))    (re-search-forward "</office:text>" nil nil)    (goto-char (match-beginning 0))    ;; Title    (insert (org-e-odt-format-preamble info))    ;; Table of Contents    (let ((depth (plist-get info :with-toc)))      (when (wholenump depth) (insert (org-e-odt-toc depth info))))    ;; Copy styles.xml.  Also dump htmlfontify styles, if there is any.    (org-e-odt-update-styles-file info)    ;; Update styles.xml - take care of outline numbering    (with-current-buffer	(find-file-noselect (expand-file-name "styles.xml") t)      ;; Don't make automatic backup of styles.xml file. This setting      ;; prevents the backed-up styles.xml file from being zipped in to      ;; odt file. This is more of a hackish fix. Better alternative      ;; would be to fix the zip command so that the output odt file      ;; includes only the needed files and excludes any auto-generated      ;; extra files like backups and auto-saves etc etc. Note that      ;; currently the zip command zips up the entire temp directory so      ;; that any auto-generated files created under the hood ends up in      ;; the resulting odt file.      (set (make-local-variable 'backup-inhibited) t)      (org-e-odt-configure-outline-numbering))    ;; Contents    (insert contents)    (buffer-substring-no-properties (point-min) (point-max))));;; Transcode Functions;;;; Block(defun org-e-odt-center-block (center-block contents info)  "Transcode a CENTER-BLOCK element from Org to HTML.CONTENTS holds the contents of the block.  INFO is a plistholding contextual information."  (org-e-odt--wrap-label center-block contents));;;; Comment;; Comments are ignored.;;;; Comment Block;; Comment Blocks are ignored.;;;; Drawer(defun org-e-odt-drawer (drawer contents info)  "Transcode a DRAWER element from Org to HTML.CONTENTS holds the contents of the block.  INFO is a plistholding contextual information."  (let* ((name (org-element-property :drawer-name drawer))	 (output (if (functionp org-e-odt-format-drawer-function)		     (funcall org-e-odt-format-drawer-function			      name contents)		   ;; If there's no user defined function: simply		   ;; display contents of the drawer.		   contents)))    (org-e-odt--wrap-label drawer output)));;;; Dynamic Block(defun org-e-odt-dynamic-block (dynamic-block contents info)  "Transcode a DYNAMIC-BLOCK element from Org to HTML.CONTENTS holds the contents of the block.  INFO is a plistholding contextual information.  See`org-export-data'."  (org-e-odt--wrap-label dynamic-block contents));;;; Emphasis(defun org-e-odt-emphasis (emphasis contents info)  "Transcode EMPHASIS from Org to HTML.CONTENTS is the contents of the emphasized text.  INFO is a plistholding contextual information.."  ;; (format (cdr (assoc (org-element-property :marker emphasis)  ;; 		      org-e-odt-emphasis-alist))  ;; 	  contents)  (org-e-odt-format-fontify   contents (cadr (assoc		   (org-element-property :marker emphasis)		   '(("*" bold)		     ("/" emphasis)		     ("_" underline)		     ("=" code)		     ("~" verbatim)		     ("+" strike))))));;;; Entity(defun org-e-odt-entity (entity contents info)  "Transcode an ENTITY object from Org to HTML.CONTENTS are the definition itself.  INFO is a plist holdingcontextual information."  ;; (let ((ent (org-element-property :latex entity)))  ;;   (if (org-element-property :latex-math-p entity)  ;; 	(format "$%s$" ent)  ;;     ent))  (org-element-property :utf-8 entity));;;; Example Block(defun org-e-odt-example-block (example-block contents info)  "Transcode a EXAMPLE-BLOCK element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (let* ((options (or (org-element-property :options example-block) ""))	 (value (org-export-handle-code example-block info nil nil t)))    (org-e-odt--wrap-label     example-block (org-e-odt-format-source-code-or-example value nil))));;;; Export Snippet(defun org-e-odt-export-snippet (export-snippet contents info)  "Transcode a EXPORT-SNIPPET object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (when (eq (org-export-snippet-backend export-snippet) 'e-odt)    (org-element-property :value export-snippet)));;;; Export Block(defun org-e-odt-export-block (export-block contents info)  "Transcode a EXPORT-BLOCK element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (when (string= (org-element-property :type export-block) "latex")    (org-remove-indentation (org-element-property :value export-block))));;;; Fixed Width(defun org-e-odt-fixed-width (fixed-width contents info)  "Transcode a FIXED-WIDTH element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (let* ((value (org-element-normalize-string		 (replace-regexp-in-string		  "^[ \t]*: ?" ""		  (org-element-property :value fixed-width)))))    (org-e-odt--wrap-label     fixed-width (org-e-odt-format-source-code-or-example value nil))));;;; Footnote Definition;; Footnote Definitions are ignored.;;;; Footnote Reference(defun org-e-odt-footnote-def (raw info) ; FIXME  (if (equal (org-element-type raw) 'org-data)      (org-trim (org-export-data raw 'e-odt info)) ; fix paragraph					; style    (org-e-odt-format-stylized-paragraph     'footnote (org-trim (org-export-secondary-string raw 'e-odt info)))))(defvar org-e-odt-footnote-separator  (org-e-odt-format-fontify "," 'superscript))(defun org-e-odt-footnote-reference (footnote-reference contents info)  "Transcode a FOOTNOTE-REFERENCE element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (concat   ;; Insert separator between two footnotes in a row.   (let ((prev (org-export-get-previous-element footnote-reference info)))     (when (eq (org-element-type prev) 'footnote-reference)       org-e-odt-footnote-separator))   (cond    ((not (org-export-footnote-first-reference-p footnote-reference info))     (let* ((n (org-export-get-footnote-number footnote-reference info)))       (org-e-odt-format-footnote-reference n "IGNORED" 100)))    ;; Inline definitions are secondary strings.    ((eq (org-element-property :type footnote-reference) 'inline)     (let* ((raw (org-export-get-footnote-definition footnote-reference info))	    (n (org-export-get-footnote-number footnote-reference info))	    (def (org-e-odt-footnote-def raw info)))       (org-e-odt-format-footnote-reference n def 1)))    ;; Non-inline footnotes definitions are full Org data.    (t     (let* ((raw (org-export-get-footnote-definition footnote-reference info))	    (n (org-export-get-footnote-number footnote-reference info))	    (def (org-e-odt-footnote-def raw info)))       (org-e-odt-format-footnote-reference n def 1))))));;;; Headline(defun org-e-odt-todo (todo)  (when todo    (org-e-odt-format-fontify     (concat      ""				; org-e-odt-todo-kwd-class-prefix      (org-e-odt-fix-class-name todo))     (list (if (member todo org-done-keywords) "done" "todo")	   todo))))(defun org-e-odt-format-headline--wrap (headline info						  &optional format-function						  &rest extra-keys)  "Transcode an HEADLINE element from Org to ODT.CONTENTS holds the contents of the headline.  INFO is a plistholding contextual information."  (let* ((level (+ (org-export-get-relative-level headline info)))	 (headline-number (org-export-get-headline-number headline info))	 (section-number (and (org-export-numbered-headline-p headline info)			      (mapconcat 'number-to-string					 headline-number ".")))	 (todo (and (plist-get info :with-todo-keywords)		    (let ((todo (org-element-property				 :todo-keyword headline)))		      (and todo			   (org-export-secondary-string todo 'e-odt info)))))	 (todo-type (and todo (org-element-property :todo-type headline)))	 (priority (and (plist-get info :with-priority)			(org-element-property :priority headline)))	 (text (org-export-secondary-string		(org-element-property :title headline) 'e-odt info))	 (tags (and (plist-get info :with-tags)		    (org-element-property :tags headline)))	 (headline-label (concat "sec-" (mapconcat 'number-to-string						   headline-number "-")))	 (format-function (cond			   ((functionp format-function) format-function)			   ((functionp org-e-odt-format-headline-function)			    (function*			     (lambda (todo todo-type priority text tags					   &allow-other-keys)			       (funcall org-e-odt-format-headline-function					todo todo-type priority text tags))))			   (t 'org-e-odt-format-headline))))    (apply format-function    	   todo todo-type  priority text tags    	   :headline-label headline-label :level level    	   :section-number section-number extra-keys)))(defun org-e-odt-headline (headline contents info)  "Transcode an HEADLINE element from Org to HTML.CONTENTS holds the contents of the headline.  INFO is a plistholding contextual information."  (let* ((numberedp (org-export-numbered-headline-p headline info))	 ;; Get level relative to current parsed data.	 (level (org-export-get-relative-level headline info))	 (text (org-export-secondary-string		(org-element-property :title headline) 'e-odt info))	 ;; Create the headline text.	 (full-text (org-e-odt-format-headline--wrap headline info)))    (cond     ;; Case 1: This is a footnote section: ignore it.     ((org-element-property :footnote-section-p headline) nil)     ;; Case 2. This is a deep sub-tree: export it as a list item.     ;;         Also export as items headlines for which no section     ;;         format has been found.     ((org-export-low-level-p headline info) ; FIXME (or (not section-fmt))      ;; Build the real contents of the sub-tree.      (let* ((type (if numberedp 'unordered 'unordered)) ; FIXME	     (itemized-body (org-e-odt-format-list-item			     contents type nil nil full-text)))	(concat	 (and (org-export-first-sibling-p headline info)	      (org-e-odt-begin-plain-list type))	 itemized-body	 (and (org-export-last-sibling-p headline info)	      (org-e-odt-end-plain-list type)))))     ;; Case 3. Standard headline.  Export it as a section.     (t      (let* ((extra-ids (list (org-element-property :custom-id headline)			      (org-element-property :id headline)))	     (extra-ids nil)		; FIXME	     (id (concat "sec-" (mapconcat 'number-to-string					   (org-export-get-headline-number					    headline info) "-"))))	(concat	 (org-e-odt-format-tags	  '("<text:h text:style-name=\"Heading_20_%s\" text:outline-level=\"%s\">" .	    "</text:h>")	  (concat (org-e-odt-format-extra-targets extra-ids)		  (if (not id) full-text (org-e-odt-format-target full-text id) ))	  level level)	 contents))))));;;; Horizontal Rule(defun org-e-odt-horizontal-rule (horizontal-rule contents info)  "Transcode an HORIZONTAL-RULE  object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (let ((attr (mapconcat #'identity			 (org-element-property :attr_odt horizontal-rule)			 " ")))    (org-e-odt--wrap-label horizontal-rule			    (org-e-odt-format-horizontal-line))));;;; Inline Babel Call;; Inline Babel Calls are ignored.;;;; Inline Src Block(defun org-e-odt-inline-src-block (inline-src-block contents info)  "Transcode an INLINE-SRC-BLOCK element from Org to HTML.CONTENTS holds the contents of the item.  INFO is a plist holdingcontextual information."  (let* ((org-lang (org-element-property :language inline-src-block))	 (code (org-element-property :value inline-src-block))	 (separator (org-e-odt--find-verb-separator code)))    (error "FIXME")));;;; Inlinetask(defun org-e-odt-format-section (text class &optional id)  (let ((extra (concat (when id (format " id=\"%s\"" id)))))    (concat (format "<div class=\"%s\"%s>\n" class extra) text "</div>\n")))(defun org-e-odt-inlinetask (inlinetask contents info)  "Transcode an INLINETASK element from Org to ODT.CONTENTS holds the contents of the block.  INFO is a plistholding contextual information."  (cond   ;; If `org-e-odt-format-inlinetask-function' is provided, call it   ;; with appropriate arguments.   ((functionp org-e-odt-format-inlinetask-function)    (let ((format-function	   (function*	    (lambda (todo todo-type priority text tags			  &key contents &allow-other-keys)	      (funcall org-e-odt-format-inlinetask-function		       todo todo-type priority text tags contents)))))      (org-e-odt-format-headline--wrap       inlinetask info format-function :contents contents)))   ;; Otherwise, use a default template.   (t (org-e-odt--wrap-label       inlinetask       (org-e-odt-format-stylized-paragraph	nil (org-e-odt-format-textbox	     (concat (org-e-odt-format-stylized-paragraph		      "OrgInlineTaskHeading" (org-e-odt-format-headline--wrap					      inlinetask info))		     contents)	     nil nil "OrgInlineTaskFrame" " style:rel-width=\"100%\""))))));;;; Item(defun org-e-odt-format-list-item (contents type checkbox					    &optional term-counter-id					    headline)  (when checkbox    (setq checkbox	  (org-e-odt-format-fontify (case checkbox				      (on "[X]")				      (off "[ ]")				      (trans "[-]")) 'code)))  (concat   (org-e-odt-begin-list-item type term-counter-id headline)   ;; FIXME checkbox (and checkbox " ")   contents   (org-e-odt-end-list-item type)))(defun org-e-odt-item (item contents info)  "Transcode an ITEM element from Org to HTML.CONTENTS holds the contents of the item.  INFO is a plist holdingcontextual information."  ;; Grab `:level' from plain-list properties, which is always the  ;; first element above current item.  (let* ((plain-list (org-export-get-parent item info))	 (type (org-element-property :type plain-list))	 (level (org-element-property :level plain-list))	 (counter (org-element-property :counter item))	 (checkbox (org-element-property :checkbox item))	 (tag (let ((tag (org-element-property :tag item)))		(and tag (org-export-secondary-string tag 'e-odt info)))))    (org-e-odt-format-list-item     contents type checkbox (or tag counter))));;;; Keyword(defun org-e-odt-keyword (keyword contents info)  "Transcode a KEYWORD element from Org to HTML.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 "LATEX") value)     ((string= key "INDEX") (format "\\index{%s}" value))     ((string= key "TARGET") nil	; FIXME      ;; (format "\\label{%s}" (org-export-solidify-link-text 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))))	    (when (wholenump depth) (org-e-odt-toc depth info))))	 ((string= "tables" value) "FIXME")	 ((string= "figures" value) "FIXME")	 ((string= "listings" value)	  (cond	   ;; At the moment, src blocks with a caption are wrapped	   ;; into a figure environment.	   (t "FIXME")))))))));;;; Latex Environment(defun org-e-odt-format-latex (latex-frag processing-type)  (let* ((prefix (case processing-type		   (dvipng "ltxpng/")		   (mathml "ltxmathml/")))	 (cache-relpath	  (concat prefix (file-name-sans-extension			  (file-name-nondirectory (buffer-file-name)))))	 (cache-dir (file-name-directory (buffer-file-name )))	 (display-msg (case processing-type			(dvipng "Creating LaTeX Image...")			(mathml "Creating MathML snippet..."))))    (with-temp-buffer      (insert latex-frag)      (org-format-latex cache-relpath cache-dir nil display-msg			nil nil processing-type)      (buffer-string))))(defun org-e-odt-latex-environment (latex-environment contents info)  "Transcode a LATEX-ENVIRONMENT element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (org-e-odt--wrap-label   latex-environment   (let* ((latex-frag	   (org-remove-indentation	    (org-element-property :value latex-environment)))	  (processing-type (plist-get info :LaTeX-fragments))	  (caption (org-element-property :caption latex-environment))	  (short-caption (and (cdr caption) (org-export-secondary-string					     (cdr caption) 'e-odt info)))	  (caption (and (car caption) (org-export-secondary-string				       (car caption) 'e-odt info)))	  (label (org-element-property :name latex-environment))	  (attr nil)			; FIXME	  (label (org-element-property :name latex-environment)))     (cond      ((member processing-type '(t mathjax))       (org-e-odt-format-formula latex-environment info))      ((equal processing-type 'dvipng)       (org-e-odt-format-stylized-paragraph	nil (org-e-odt-link--inline-image latex-environment info)))      (t latex-frag)))));;;; Latex Fragment;; (when latex-frag			; FIXME;; 	(setq href (org-propertize href :title "LaTeX Fragment";; 				   :description latex-frag)));; handle verbatim;; provide descriptions(defun org-e-odt-latex-fragment (latex-fragment contents info)  "Transcode a LATEX-FRAGMENT object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (let* ((latex-frag (org-element-property :value latex-fragment))	 (processing-type (plist-get info :LaTeX-fragments)))    (cond     ((member processing-type '(t mathjax))      (org-e-odt-format-formula latex-fragment info))     ((equal processing-type 'dvipng)      (org-e-odt-link--inline-image latex-fragment info))     (t latex-frag))));;;; Line Break(defun org-e-odt-line-break (line-break contents info)  "Transcode a LINE-BREAK object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  "<text:line-break/>\n");;;; Link(defun org-e-odt-link--inline-image (element info)  "Return HTML code for an inline image.LINK is the link pointing to the inline image.  INFO is a plistused as a communication channel."  (let* ((src (cond	       ((eq (org-element-type element) 'link)		(let* ((type (org-element-property :type element))		       (raw-path (org-element-property :path element)))		  (cond ((member type '("http" "https"))			 (concat type ":" raw-path))			((file-name-absolute-p raw-path)			 (expand-file-name raw-path))			(t raw-path))))	       ((member (org-element-type element)			'(latex-fragment latex-environment))		(let* ((latex-frag (org-remove-indentation				    (org-element-property				     :value element)))		       (formula-link (org-e-odt-format-latex				      latex-frag 'dvipng)))		  (and formula-link		       (string-match "file:\\([^]]*\\)" formula-link)		       (match-string 1 formula-link))))	       (t (error "what is this?"))))	 (href (org-e-odt-format-tags		"<draw:image xlink:href=\"%s\" xlink:type=\"simple\" xlink:show=\"embed\" xlink:actuate=\"onLoad\"/>" ""		(org-e-odt-copy-image-file src)))	 ;; extract attributes from #+ATTR_ODT line.	 (attr-from (case (org-element-type element)		      (link (org-export-get-parent-paragraph element info))		      (t element)))	 ;; convert attributes to a plist.	 (attr-plist (org-e-odt-element-attributes attr-from info))	 ;; handle `:anchor', `:style' and `:attributes' properties.	 (user-frame-anchor	  (car (assoc-string (plist-get attr-plist :anchor)			     '(("as-char") ("paragraph") ("page")) t)))	 (user-frame-style	  (and user-frame-anchor (plist-get attr-plist :style)))	 (user-frame-attrs	  (and user-frame-anchor (plist-get attr-plist :attributes)))	 (user-frame-params	  (list user-frame-style user-frame-attrs user-frame-anchor))	 ;; (embed-as (or embed-as user-frame-anchor "paragraph"))	 ;; extrac	 ;; handle `:width', `:height' and `:scale' properties.	 (size (org-e-odt-image-size-from-file		src (plist-get attr-plist :width)		(plist-get attr-plist :height)		(plist-get attr-plist :scale) nil ;; embed-as		"paragraph"			  ; FIXME		))	 (width (car size)) (height (cdr size))	 (embed-as	  (case (org-element-type element)	    ((org-e-odt-standalone-image-p element info) "paragraph")	    (latex-fragment "as-char")	    (latex-environment "paragraph")	    (t "paragraph")))	 (captions (org-e-odt-format-label element info 'definition))	 (caption (car captions)) (short-caption (cdr captions))	 (entity (concat (and caption "Captioned") embed-as "Image")))    (org-e-odt-format-entity entity href width height			     captions user-frame-params )))(defun org-e-odt-format-entity (entity href width height &optional				       captions user-frame-params)  (let* ((caption (car captions)) (short-caption (cdr captions))	 (entity-style (assoc-string entity org-e-odt-entity-frame-styles t))	 default-frame-params frame-params)    (cond     ((not caption)      (setq default-frame-params (nth 2 entity-style))      (setq frame-params (org-e-odt-merge-frame-params			  default-frame-params user-frame-params))      (apply 'org-e-odt-format-frame href width height frame-params))     (t      (setq default-frame-params (nth 3 entity-style))      (setq frame-params (org-e-odt-merge-frame-params			  default-frame-params user-frame-params))      (apply 'org-e-odt-format-textbox	     (org-e-odt-format-stylized-paragraph	      'illustration	      (concat	       (apply 'org-e-odt-format-frame href width height		      (let ((entity-style-1 (copy-sequence					     (nth 2 entity-style))))			(setcar (cdr entity-style-1)				(concat				 (cadr entity-style-1)				 (and short-caption				      (format " draw:name=\"%s\" "					      short-caption))))			entity-style-1))	       caption))	     width height frame-params)))))(defvar org-e-odt-standalone-image-predicate  (function (lambda (paragraph)	      (or (org-element-property :caption paragraph)		  (org-element-property :name paragraph)))))(defun org-e-odt-standalone-image-p (element info &optional predicate)  "Test if ELEMENT is a standalone image for the purpose ODT export.INFO is a plist holding contextual information.Return non-nil, if ELEMENT is of type paragraph and it's solecontent, save for whitespaces, is a link that qualifies as aninline image.Return non-nil, if ELEMENT is of type link and it's containingparagraph has no other content save for leading and trailingwhitespaces.Return nil, otherwise.Bind `org-e-odt-standalone-image-predicate' to constrainparagraph further.  For example, to check for only captionedstandalone images, do the following.  \(setq org-e-odt-standalone-image-predicate	\(lambda \(paragraph\)	  \(org-element-property :caption paragraph\)\)\)"  (let ((paragraph (case (org-element-type element)		     (paragraph element)		     (link (and (org-export-inline-image-p				 element org-e-odt-inline-image-rules)				(org-export-get-parent element info)))		     (t nil))))    (when paragraph      (assert (eq (org-element-type paragraph) 'paragraph))      (when (or (not (and (boundp 'org-e-odt-standalone-image-predicate)			  (functionp org-e-odt-standalone-image-predicate)))		(funcall org-e-odt-standalone-image-predicate paragraph))	(let ((contents (org-element-contents paragraph)))	  (loop for x in contents		with inline-image-count = 0		always (cond			((eq (org-element-type x) 'plain-text)			 (not (org-string-nw-p x)))			((eq (org-element-type x) 'link)			 (when (org-export-inline-image-p				x org-e-odt-inline-image-rules)			   (= (incf inline-image-count) 1)))			(t nil))))))))(defun org-e-odt-link (link desc info)  "Transcode a LINK object from Org to HTML.DESC is the description part of the link, or the empty string.INFO is a plist holding contextual information.  See`org-export-data'."  (let* ((type (org-element-property :type link))	 (raw-path (org-element-property :path link))	 ;; Ensure DESC really exists, or set it to nil.	 (desc (and (not (string= desc "")) desc))	 (imagep (org-export-inline-image-p		  link org-e-odt-inline-image-rules))	 (path (cond		((member type '("http" "https" "ftp" "mailto"))		 (concat type ":" raw-path))		((string= type "file")		 (when (string-match "\\(.+\\)::.+" raw-path)		   (setq raw-path (match-string 1 raw-path)))		 (if (file-name-absolute-p raw-path)		     (concat "file://" (expand-file-name raw-path))		   ;; TODO: Not implemented yet.  Concat also:		   ;; (org-export-directory :HTML info)		   (concat "file://" raw-path)))		(t raw-path)))	 protocol)    (cond     ;; Image file.     ((and (not desc) (org-export-inline-image-p		       link org-e-odt-inline-image-rules))      (org-e-odt-link--inline-image link info))     ;; Radioed target: Target's name is obtained from original raw     ;; link.  Path is parsed and transcoded in order to have a proper     ;; display of the contents.     ((string= type "radio")      (org-e-odt-format-internal-link       (org-export-secondary-string	(org-element-parse-secondary-string	 path (org-element-restriction 'radio-target))	'e-odt info)       (org-export-solidify-link-text path)))     ;; Links pointing to an headline: Find destination and build     ;; appropriate referencing command.     ((member type '("custom-id" "fuzzy" "id"))      (let ((destination (if (string= type "fuzzy")			     (org-export-resolve-fuzzy-link link info)			   (org-export-resolve-id-link link info))))	(case (org-element-type destination)	  ;; Fuzzy link points nowhere.	  ('nil	   (org-e-odt-format-fontify	    (or desc (org-export-secondary-string		      (org-element-property :raw-link link)		      'e-odt info)) 'emphasis))	  ;; Fuzzy link points to an invisible target.	  (keyword nil)	  ;; LINK points to an headline.  If headlines are numbered	  ;; and the link has no description, display headline's	  ;; number.  Otherwise, display description or headline's	  ;; title.	  (headline	   (let* ((headline-no (org-export-get-headline-number destination info))		  (label (format "sec-%s" (mapconcat 'number-to-string						     headline-no "-")))		  (section-no (mapconcat 'number-to-string headline-no ".")))	     (setq desc		   (cond		    (desc desc)		    ((plist-get info :section-numbers) section-no)		    (t (org-export-secondary-string			(org-element-property :title destination)			'e-odt info))))	     (org-e-odt-format-internal-link desc label)))	  ;; Fuzzy link points to a target.  Do as above.	  (otherwise	   ;; (unless desc	   ;;   (setq number (cond	   ;; 		   ((org-e-odt-standalone-image-p destination info)	   ;; 		    (org-export-get-ordinal	   ;; 		     (assoc 'link (org-element-contents destination))	   ;; 		     info 'link 'org-e-odt-standalone-image-p))	   ;; 		   (t (org-export-get-ordinal destination info))))	   ;;   (setq desc (when number	   ;; 		  (if (atom number) (number-to-string number)	   ;; 		    (mapconcat 'number-to-string number ".")))))	   (let ((label-reference		  (org-e-odt-format-label destination info 'reference)))	     (assert label-reference)	     label-reference)))))     ;; Coderef: replace link with the reference name or the     ;; equivalent line number.     ((string= type "coderef")      (let* ((fmt (org-export-get-coderef-format path (or desc "%s")))	     (res (org-export-resolve-coderef path info))	     (org-e-odt-suppress-xref nil)	     (href (org-xml-format-href (concat "#coderef-" path))))	(format fmt (org-e-odt-format-link res href))))     ;; Link type is handled by a special function.     ((functionp (setq protocol (nth 2 (assoc type org-link-protocols))))      (funcall protocol (org-link-unescape path) desc 'html))     ;; External link with a description part.     ((and path desc) (org-e-odt-format-link desc path))     ;; External link without a description part.     (path (org-e-odt-format-link path path))     ;; No path, only description.  Try to do something useful.     (t (org-e-odt-format-fontify desc 'emphasis)))));;;; Babel Call;; Babel Calls are ignored.;;;; Macro(defun org-e-odt-macro (macro contents info)  "Transcode a MACRO element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  ;; Use available tools.  (org-export-expand-macro macro info));;;; Paragraph(defun org-e-odt-paragraph (paragraph contents info)  "Transcode a PARAGRAPH element from Org to HTML.CONTENTS is the contents of the paragraph, as a string.  INFO isthe plist used as a communication channel."  (let* ((style nil)			; FIXME	 (class (cdr (assoc style '((footnote . "footnote")				    (verse . nil)))))	 (extra (if class (format " class=\"%s\"" class) ""))	 (parent (org-export-get-parent paragraph info))	 (parent-type (org-element-type parent))	 (style (case parent-type		  (quote-block 'quote)		  (center-block 'center)		  (footnote-definition 'footnote)		  (t nil))))    (org-e-odt-format-stylized-paragraph style contents)));;;; Plain List(defun org-e-odt-plain-list (plain-list contents info)  "Transcode a PLAIN-LIST element from Org to HTML.CONTENTS is the contents of the list.  INFO is a plist holdingcontextual information."  (let* (arg1 ;; FIXME	 (type (org-element-property :type plain-list))	 (attr (mapconcat #'identity			  (org-element-property :attr_odt plain-list)			  " ")))    (org-e-odt--wrap-label     plain-list (format "%s\n%s%s"			(org-e-odt-begin-plain-list type)			contents (org-e-odt-end-plain-list type)))));;;; Plain Text(defun org-e-odt-convert-special-strings (string)  "Convert special characters in STRING to ODT."  (let ((all org-e-odt-special-string-regexps)	e a re rpl start)    (while (setq a (pop all))      (setq re (car a) rpl (cdr a) start 0)      (while (string-match re string start)	(setq string (replace-match rpl t nil string))))    string));; (defun org-e-odt-encode-plain-text (s);;   "Convert plain text characters to HTML equivalent.;; Possible conversions are set in `org-export-html-protect-char-alist'.";;   (let ((cl org-e-odt-protect-char-alist) c);;     (while (setq c (pop cl));;       (let ((start 0));; 	(while (string-match (car c) s start);; 	  (setq s (replace-match (cdr c) t t s);; 		start (1+ (match-beginning 0))))));;     s))(defun org-e-odt-plain-text (text info)  "Transcode a TEXT string from Org to HTML.TEXT is the string to transcode.  INFO is a plist holdingcontextual information."  (setq text (org-e-odt-encode-plain-text text t))  ;; Protect %, #, &, $, ~, ^, _,  { and }.  ;; (while (string-match "\\([^\\]\\|^\\)\\([%$#&{}~^_]\\)" text)  ;;   (setq text  ;; 	  (replace-match (format "\\%s" (match-string 2 text)) nil t text 2)))  ;; Protect \  ;; (setq text (replace-regexp-in-string  ;; 	      "\\(?:[^\\]\\|^\\)\\(\\\\\\)\\(?:[^%$#&{}~^_\\]\\|$\\)"  ;; 	      "$\\backslash$" text nil t 1))  ;; HTML into \HTML{} and TeX into \TeX{}.  ;; (let ((case-fold-search nil)  ;; 	(start 0))  ;;   (while (string-match "\\<\\(\\(?:La\\)?TeX\\)\\>" text start)  ;;     (setq text (replace-match  ;; 		  (format "\\%s{}" (match-string 1 text)) nil t text)  ;; 	    start (match-end 0))))  ;; Handle quotation marks  ;; (setq text (org-e-odt--quotation-marks text info))  ;; Convert special strings.  ;; (when (plist-get info :with-special-strings)  ;;   (while (string-match (regexp-quote "...") text)  ;;     (setq text (replace-match "\\ldots{}" nil t text))))  (when (plist-get info :with-special-strings)    (setq text (org-e-odt-convert-special-strings text)))  ;; Handle break preservation if required.  (when (plist-get info :preserve-breaks)    (setq text (replace-regexp-in-string "\\(\\\\\\\\\\)?[ \t]*\n" " \\\\\\\\\n"					 text)))  ;; Return value.  text);;;; Property Drawer(defun org-e-odt-property-drawer (property-drawer contents info)  "Transcode a PROPERTY-DRAWER element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextualinformation."  ;; The property drawer isn't exported but we want separating blank  ;; lines nonetheless.  "");;;; Quote Block(defun org-e-odt-quote-block (quote-block contents info)  "Transcode a QUOTE-BLOCK element from Org to HTML.CONTENTS holds the contents of the block.  INFO is a plistholding contextual information."  (org-e-odt--wrap-label quote-block contents));;;; Quote Section(defun org-e-odt-quote-section (quote-section contents info)  "Transcode a QUOTE-SECTION element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (let ((value (org-remove-indentation		(org-element-property :value quote-section))))    (when value (org-e-odt-format-source-code-or-example value nil))));;;; Section(defun org-e-odt-section (section contents info) ; FIXME  "Transcode a SECTION element from Org to HTML.CONTENTS holds the contents of the section.  INFO is a plistholding contextual information."  contents);;;; Radio Target(defun org-e-odt-radio-target (radio-target text info)  "Transcode a RADIO-TARGET object from Org to HTML.TEXT is the text of the target.  INFO is a plist holdingcontextual information."  (org-e-odt-format-anchor   text (org-export-solidify-link-text	 (org-element-property :value radio-target))));;;; Special Block(defun org-e-odt-special-block (special-block contents info)  "Transcode a SPECIAL-BLOCK element from Org to HTML.CONTENTS holds the contents of the block.  INFO is a plistholding contextual information."  (let ((type (downcase (org-element-property :type special-block))))    (org-e-odt--wrap-label     special-block     (format "\\begin{%s}\n%s\\end{%s}" type contents type))));;;; Src Block(defun org-e-odt-src-block (src-block contents info)  "Transcode a SRC-BLOCK element from Org to HTML.CONTENTS holds the contents of the item.  INFO is a plist holdingcontextual information."  (let* ((lang (org-element-property :language src-block))	 (caption (org-element-property :caption src-block))	 (short-caption (and (cdr caption) (org-export-secondary-string					    (cdr caption) 'e-odt info)))	 (caption (and (car caption) (org-export-secondary-string				      (car caption) 'e-odt info)))	 (label (org-element-property :name src-block)))    ;; FIXME: Handle caption    ;; caption-str (when caption)    ;; (main (org-export-secondary-string (car caption) 'e-odt info))    ;; (secondary (org-export-secondary-string (cdr caption) 'e-odt info))    ;; (caption-str (org-e-odt--caption/label-string caption label info))    (let* ((captions (org-e-odt-format-label src-block info 'definition))	   (caption (car captions)) (short-caption (cdr captions)))      (concat       (and caption (org-e-odt-format-stylized-paragraph 'listing caption))       (org-e-odt-format-code src-block info)))));;;; Statistics Cookie(defun org-e-odt-statistics-cookie (statistics-cookie contents info)  "Transcode a STATISTICS-COOKIE object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (let ((cookie-value (org-element-property :value statistics-cookie)))    (org-e-odt-format-fontify cookie-value 'code)));;;; Subscript(defun org-e-odt-subscript (subscript contents info)  "Transcode a SUBSCRIPT object from Org to HTML.CONTENTS is the contents of the object.  INFO is a plist holdingcontextual information."  ;; (format (if (= (length contents) 1) "$_%s$" "$_{\\mathrm{%s}}$") contents)  (org-e-odt-format-fontify contents 'subscript));;;; Superscript(defun org-e-odt-superscript (superscript contents info)  "Transcode a SUPERSCRIPT object from Org to HTML.CONTENTS is the contents of the object.  INFO is a plist holdingcontextual information."  ;; (format (if (= (length contents) 1) "$^%s$" "$^{\\mathrm{%s}}$") contents)  (org-e-odt-format-fontify contents 'superscript));;;; Table Cell(defun org-e-odt-table-style-spec (element info)  (let* ((table (org-export-get-parent-table element info))	 (table-attributes (org-e-odt-element-attributes table info))	 (table-style (plist-get table-attributes :style)))    (assoc table-style org-e-odt-table-styles)))(defun org-e-odt-get-table-cell-styles (table-cell info)  "Retrieve styles applicable to a table cell.R and C are (zero-based) row and column numbers of the tablecell.  STYLE-SPEC is an entry in `org-e-odt-table-styles'applicable to the current table.  It is `nil' if the table is notassociated with any style attributes.Return a cons of (TABLE-CELL-STYLE-NAME . PARAGRAPH-STYLE-NAME).When STYLE-SPEC is nil, style the table cell the conventional way- choose cell borders based on row and column groupings andchoose paragraph alignment based on `org-col-cookies' textproperty.  See also`org-e-odt-get-paragraph-style-cookie-for-table-cell'.When STYLE-SPEC is non-nil, ignore the above cookie and returnstyles congruent with the ODF-1.2 specification."  (let* ((table-cell-address (org-export-table-cell-address table-cell info))	 (r (car table-cell-address)) (c (cdr table-cell-address))	 (style-spec (org-e-odt-table-style-spec table-cell info))	 (table-dimensions (org-export-table-dimensions			    (org-export-get-parent-table table-cell info)			    info)))    (when style-spec      ;; LibreOffice - particularly the Writer - honors neither table      ;; templates nor custom table-cell styles.  Inorder to retain      ;; inter-operability with LibreOffice, only automatic styles are      ;; used for styling of table-cells.  The current implementation is      ;; congruent with ODF-1.2 specification and hence is      ;; future-compatible.      ;; Additional Note: LibreOffice's AutoFormat facility for tables -      ;; which recognizes as many as 16 different cell types - is much      ;; richer. Unfortunately it is NOT amenable to easy configuration      ;; by hand.      (let* ((template-name (nth 1 style-spec))	     (cell-style-selectors (nth 2 style-spec))	     (cell-type	      (cond	       ((and (cdr (assoc 'use-first-column-styles cell-style-selectors))		     (= c 0)) "FirstColumn")	       ((and (cdr (assoc 'use-last-column-styles cell-style-selectors))		     (= (1+ c) (cdr table-dimensions)))		"LastColumn")	       ((and (cdr (assoc 'use-first-row-styles cell-style-selectors))		     (= r 0)) "FirstRow")	       ((and (cdr (assoc 'use-last-row-styles cell-style-selectors))		     (= (1+ r) (car table-dimensions)))		"LastRow")	       ((and (cdr (assoc 'use-banding-rows-styles cell-style-selectors))		     (= (% r 2) 1)) "EvenRow")	       ((and (cdr (assoc 'use-banding-rows-styles cell-style-selectors))		     (= (% r 2) 0)) "OddRow")	       ((and (cdr (assoc 'use-banding-columns-styles cell-style-selectors))		     (= (% c 2) 1)) "EvenColumn")	       ((and (cdr (assoc 'use-banding-columns-styles cell-style-selectors))		     (= (% c 2) 0)) "OddColumn")	       (t ""))))	(concat template-name cell-type)))))(defun org-e-odt-table-cell (table-cell contents info)  "Transcode a TABLE-CELL element from Org to ODT.CONTENTS is nil.  INFO is a plist used as a communicationchannel."  (let* ((table-cell-address (org-export-table-cell-address table-cell info))	 (r (car table-cell-address))	 (c (cdr table-cell-address))	 (horiz-span (or (org-export-table-cell-width table-cell info) 0))	 (table-row (org-export-get-parent table-cell info))	 (custom-style-prefix (org-e-odt-get-table-cell-styles			       table-cell info))	 (paragraph-style	  (or	   (and custom-style-prefix		(format "%sTableParagraph" custom-style-prefix))	   (concat	    (cond	     ((and (= 1 (org-export-table-row-group table-row info))		   (org-export-table-has-header-p		    (org-export-get-parent-table table-row info) info))	      "OrgTableHeading")	     ((and (zerop c) t ;; (org-lparse-get 'TABLE-FIRST-COLUMN-AS-LABELS)		   )	      "OrgTableHeading")	     (t "OrgTableContents"))	    (capitalize (symbol-name (org-export-table-cell-alignment				      table-cell info))))))	 (cell-style-name	  (or	   (and custom-style-prefix (format "%sTableCell"					    custom-style-prefix))	   (concat	    "OrgTblCell"	    (when (or (org-export-table-row-starts-rowgroup-p table-row info)		      (zerop r)) "T")	    (when (org-export-table-row-ends-rowgroup-p table-row info) "B")	    (when (and (org-export-table-cell-starts-colgroup-p table-cell info)		       (not (zerop c)) ) "L"))))	 (cell-attributes	  (concat	   (format " table:style-name=\"%s\"" cell-style-name)	   (and (> horiz-span 0)		(format " table:number-columns-spanned=\"%d\""			(1+ horiz-span))))))    (unless contents (setq contents ""))    (concat     (org-e-odt-format-tags      '("<table:table-cell%s>" . "</table:table-cell>")      (org-e-odt-format-stylized-paragraph paragraph-style contents)      cell-attributes)     (let (s)       (dotimes (i horiz-span s)	 (setq s (concat s "\n<table:covered-table-cell/>"))))     "\n")));;;; Table Row(defun org-e-odt-table-row (table-row contents info)  "Transcode a TABLE-ROW element from Org to ODT.CONTENTS is the contents of the row.  INFO is a plist used as acommunication channel."  ;; Rules are ignored since table separators are deduced from  ;; borders of the current row.  (when (eq (org-element-property :type table-row) 'standard)    (let* ((rowgroup-tags	    (if (and (= 1 (org-export-table-row-group table-row info))		     (org-export-table-has-header-p		      (org-export-get-parent-table table-row info) info))		;; If the row belongs to the first rowgroup and the		;; table has more than one row groups, then this row		;; belongs to the header row group.		'("\n<table:table-header-rows>" . "\n</table:table-header-rows>")	      ;; Otherwise, it belongs to non-header row group.	      '("\n<table:table-rows>" . "\n</table:table-rows>"))))      (concat       ;; Does this row begin a rowgroup?       (when (org-export-table-row-starts-rowgroup-p table-row info)  	 (car rowgroup-tags))       ;; Actual table row       (org-e-odt-format-tags	'("<table:table-row>" . "</table:table-row>") contents)       ;; Does this row end a rowgroup?       (when (org-export-table-row-ends-rowgroup-p table-row info)  	 (cdr rowgroup-tags))))));;;; Table(defun org-e-odt-table-first-row-data-cells (table info)  (let ((table-row	 (org-element-map	  table 'table-row	  (lambda (row)	    (unless (eq (org-element-property :type row) 'rule) row))	  info 'first-match))	(special-column-p (org-export-table-has-special-column-p table)))    (if (not special-column-p) (org-element-contents table-row)      (cdr (org-element-contents table-row)))))(defun org-e-odt-table (table contents info)  "Transcode a TABLE element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  (case (org-element-property :type table)    (table.el nil)    (t     (let* ((captions (org-e-odt-format-label table info 'definition))	    (caption (car captions)) (short-caption (cdr captions))	    (attributes (org-e-odt-element-attributes table info))	    (custom-table-style (nth 1 (org-e-odt-table-style-spec table info)))	    (table-column-specs	     (function	      (lambda (table info)		(let* ((table-style (or custom-table-style "OrgTable"))		       (column-style (format "%sColumn" table-style)))		  (mapconcat		   (lambda (table-cell)		     (let ((width (1+ (or (org-export-table-cell-width					   table-cell info) 0))))		       (org-e-odt-make-string			width			(org-e-odt-format-tags			 "<table:table-column table:style-name=\"%s\"/>"			 "" column-style))))		   (org-e-odt-table-first-row-data-cells table info) "\n"))))))       (concat	;; caption.	(when caption (org-e-odt-format-stylized-paragraph 'table caption))	;; begin table.	(let* ((automatic-name		(org-e-odt-add-automatic-style "Table" attributes)))	  (format	   "\n<table:table table:name=\"%s\" table:style-name=\"%s\">\n"	   (or short-caption (car automatic-name))	   (or custom-table-style (cdr automatic-name) "OrgTable")))	;; column specification.      	(funcall table-column-specs table info)	;; actual contents.	"\n" contents	;; end table.	"</table:table>")))));;;; Target(defun org-e-odt-target (target contents info)  "Transcode a TARGET object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextualinformation."  (org-e-odt-format-anchor   "" (org-export-solidify-link-text (org-element-property :value target))));;;; Time-stamp(defun org-e-odt-time-stamp (time-stamp contents info)  "Transcode a TIME-STAMP object from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextualinformation."  ;; (let ((value (org-element-property :value time-stamp))  ;; 	(type (org-element-property :type time-stamp))  ;; 	(appt-type (org-element-property :appt-type time-stamp)))  ;;   (concat (cond ((eq appt-type 'scheduled)  ;; 		   (format "\\textbf{\\textsc{%s}} " org-scheduled-string))  ;; 		  ((eq appt-type 'deadline)  ;; 		   (format "\\textbf{\\textsc{%s}} " org-deadline-string))  ;; 		  ((eq appt-type 'closed)  ;; 		   (format "\\textbf{\\textsc{%s}} " org-closed-string)))  ;; 	    (cond ((memq type '(active active-range))  ;; 		   (format org-e-odt-active-timestamp-format value))  ;; 		  ((memq type '(inactive inactive-range))  ;; 		   (format org-e-odt-inactive-timestamp-format value))  ;; 		  (t  ;; 		   (format org-e-odt-diary-timestamp-format value)))))  (let ((value (org-element-property :value time-stamp))        (type (org-element-property :type time-stamp))        (appt-type (org-element-property :appt-type time-stamp)))    (setq value (org-export-secondary-string value 'e-odt info))    (org-e-odt-format-fontify     (concat      (org-e-odt-format-fontify       (cond ((eq appt-type 'scheduled) org-scheduled-string)	     ((eq appt-type 'deadline) org-deadline-string)	     ((eq appt-type 'closed) org-closed-string)) "timestamp-kwd")      ;; FIXME: (org-translate-time value)      (org-e-odt-format-fontify value "timestamp"))     "timestamp-wrapper")));;;; Verbatim(defun org-e-odt-verbatim (verbatim contents info)  "Transcode a VERBATIM object from Org to HTML.CONTENTS is nil.  INFO is a plist used as a communicationchannel."  (org-e-odt-emphasis   verbatim (org-element-property :value verbatim) info));;;; Verse Block(defun org-e-odt-verse-block (verse-block contents info)  "Transcode a VERSE-BLOCK element from Org to HTML.CONTENTS is nil.  INFO is a plist holding contextual information."  ;; Replace each newline character with line break.  Also replace  ;; each blank line with a line break.  (setq contents (replace-regexp-in-string		  "^ *\\\\\\\\$" "<br/>\n"		  (replace-regexp-in-string		   "\\(\\\\\\\\\\)?[ \t]*\n" " <br/>\n"		   (org-remove-indentation		    (org-export-secondary-string		     (org-element-property :value verse-block)		     'e-odt info)))))  ;; Replace each white space at beginning of a line with a  ;; non-breaking space.  (while (string-match "^[ \t]+" contents)    (let ((new-str (org-e-odt-format-spaces		    (length (match-string 0 contents)))))      (setq contents (replace-match new-str nil t contents))))  (org-e-odt--wrap-label   verse-block (format "<p class=\"verse\">\n%s</p>" contents)));;; Filter Functions;;;; Filter Settings;;;; Filters;;; Interactive functions(defun org-e-odt-export-to-odt  (&optional subtreep visible-only body-only ext-plist pub-dir)  "Export current buffer to a HTML file.If narrowing is active in the current buffer, only export itsnarrowed part.If a region is active, export that region.When optional argument SUBTREEP is non-nil, export the sub-treeat point, extracting information from the headline propertiesfirst.When optional argument VISIBLE-ONLY is non-nil, don't exportcontents of hidden elements.When optional argument BODY-ONLY is non-nil, only write codebetween \"\\begin{document}\" and \"\\end{document}\".EXT-PLIST, when provided, is a property list with externalparameters overriding Org default settings, but still inferior tofile-local settings.When optional argument PUB-DIR is set, use it as the publishingdirectory.Return output file's name."  (interactive)  (setq debug-on-error t)  ;; (let* ((outfile (org-export-output-file-name ".html" subtreep pub-dir))  ;; 	 (outfile "content.xml"))  ;;   (org-export-to-file  ;;    'e-odt outfile subtreep visible-only body-only ext-plist))  (let* ((outbuf (org-e-odt-init-outfile))	 (target (org-export-output-file-name ".odt" subtreep pub-dir))	 (outdir (file-name-directory (buffer-file-name outbuf)))	 (default-directory outdir))    ;; FIXME: for copying embedded images    (setq org-current-export-file	  (file-name-directory	   (org-export-output-file-name ".odt" subtreep nil)))    (org-export-to-buffer     'e-odt outbuf     (memq 'subtree optns) (memq 'visible optns) (memq 'body optns))    (setq org-lparse-opt-plist nil) 	; FIXME    (org-e-odt-save-as-outfile target	;; info			       nil			       )    ;; return outfile    (if (not org-e-odt-preferred-output-format) target      (or (org-e-odt-convert target org-e-odt-preferred-output-format)	  target))))(defun org-e-odt-reachable-p (in-fmt out-fmt)  "Return non-nil if IN-FMT can be converted to OUT-FMT."  (catch 'done    (let ((reachable-formats (org-e-odt-do-reachable-formats in-fmt)))      (dolist (e reachable-formats)	(let ((out-fmt-spec (assoc out-fmt (cdr e))))	  (when out-fmt-spec	    (throw 'done (cons (car e) out-fmt-spec))))))))(defun org-e-odt-do-convert (in-file out-fmt &optional prefix-arg)  "Workhorse routine for `org-e-odt-convert'."  (require 'browse-url)  (let* ((in-file (expand-file-name (or in-file buffer-file-name)))	 (dummy (or (file-readable-p in-file)		    (error "Cannot read %s" in-file)))	 (in-fmt (file-name-extension in-file))	 (out-fmt (or out-fmt (error "Output format unspecified")))	 (how (or (org-e-odt-reachable-p in-fmt out-fmt)		  (error "Cannot convert from %s format to %s format?"			 in-fmt out-fmt)))	 (convert-process (car how))	 (out-file (concat (file-name-sans-extension in-file) "."			   (nth 1 (or (cdr how) out-fmt))))	 (extra-options (or (nth 2 (cdr how)) ""))	 (out-dir (file-name-directory in-file))	 (cmd (format-spec convert-process			   `((?i . ,(shell-quote-argument in-file))			     (?I . ,(browse-url-file-url in-file))			     (?f . ,out-fmt)			     (?o . ,out-file)			     (?O . ,(browse-url-file-url out-file))			     (?d . , (shell-quote-argument out-dir))			     (?D . ,(browse-url-file-url out-dir))			     (?x . ,extra-options)))))    (when (file-exists-p out-file)      (delete-file out-file))    (message "Executing %s" cmd)    (let ((cmd-output (shell-command-to-string cmd)))      (message "%s" cmd-output))    (cond     ((file-exists-p out-file)      (message "Exported to %s" out-file)      (when prefix-arg	(message "Opening %s..."  out-file)	(org-open-file out-file))      out-file)     (t      (message "Export to %s failed" out-file)      nil))))(defun org-e-odt-do-reachable-formats (in-fmt)  "Return verbose info about formats to which IN-FMT can be converted.Return a list where each element is of theform (CONVERTER-PROCESS . OUTPUT-FMT-ALIST).  See`org-e-odt-convert-processes' for CONVERTER-PROCESS and see`org-e-odt-convert-capabilities' for OUTPUT-FMT-ALIST."  (let* ((converter	  (and org-e-odt-convert-process	       (cadr (assoc-string org-e-odt-convert-process				   org-e-odt-convert-processes t))))	 (capabilities	  (and org-e-odt-convert-process	       (cadr (assoc-string org-e-odt-convert-process				   org-e-odt-convert-processes t))	       org-e-odt-convert-capabilities))	 reachable-formats)    (when converter      (dolist (c capabilities)	(when (member in-fmt (nth 1 c))	  (push (cons converter (nth 2 c)) reachable-formats))))    reachable-formats))(defun org-e-odt-reachable-formats (in-fmt)  "Return list of formats to which IN-FMT can be converted.The list of the form (OUTPUT-FMT-1 OUTPUT-FMT-2 ...)."  (let (l)    (mapc (lambda (e) (add-to-list 'l e))	  (apply 'append (mapcar			  (lambda (e) (mapcar 'car (cdr e)))			  (org-e-odt-do-reachable-formats in-fmt))))    l))(defun org-e-odt-convert-read-params ()  "Return IN-FILE and OUT-FMT params for `org-e-odt-do-convert'.This is a helper routine for interactive use."  (let* ((input (if (featurep 'ido) 'ido-completing-read 'completing-read))	 (in-file (read-file-name "File to be converted: "				  nil buffer-file-name t))	 (in-fmt (file-name-extension in-file))	 (out-fmt-choices (org-e-odt-reachable-formats in-fmt))	 (out-fmt	  (or (and out-fmt-choices		   (funcall input "Output format:  "			    out-fmt-choices nil nil nil))	      (error	       "No known converter or no known output formats for %s files"	       in-fmt))))    (list in-file out-fmt)));;;###autoload(defun org-e-odt-convert (&optional in-file out-fmt prefix-arg)  "Convert IN-FILE to format OUT-FMT using a command line converter.IN-FILE is the file to be converted.  If unspecified, it defaultsto variable `buffer-file-name'.  OUT-FMT is the desired outputformat.  Use `org-e-odt-convert-process' as the converter.If PREFIX-ARG is non-nil then the newly converted file is openedusing `org-open-file'."  (interactive   (append (org-e-odt-convert-read-params) current-prefix-arg))  (org-e-odt-do-convert in-file out-fmt prefix-arg));;; FIXMES, TODOS, FOR REVIEW etc;; (defun org-e-odt-discontinue-list ();;   (let ((stashed-stack org-lparse-list-stack));;     (loop for list-type in stashed-stack;; 	  do (org-lparse-end-list-item-1 list-type);; 	  (org-lparse-end-list list-type));;     (setq org-e-odt-list-stack-stashed stashed-stack)));; (defun org-e-odt-continue-list ();;   (setq org-e-odt-list-stack-stashed (nreverse org-e-odt-list-stack-stashed));;   (loop for list-type in org-e-odt-list-stack-stashed;; 	do (org-lparse-begin-list list-type);; 	(org-lparse-begin-list-item list-type)));; FIXME: Begin indented table;; (setq org-e-odt-table-indentedp (not (null org-lparse-list-stack)));; (setq org-e-odt-table-indentedp nil) ; FIXME;; (when org-e-odt-table-indentedp;;   ;; Within the Org file, the table is appearing within a list item.;;   ;; OpenDocument doesn't allow table to appear within list items.;;   ;; Temporarily terminate the list, emit the table and then;;   ;; re-continue the list.;;   (org-e-odt-discontinue-list);;   ;; Put the Table in an indented section.;;   (let ((level (length org-e-odt-list-stack-stashed)));; 	(org-e-odt-begin-section (format "OrgIndentedSection-Level-%d" level))));; FIXME: End indented table;; (when org-e-odt-table-indentedp;;   (org-e-odt-end-section);;   (org-e-odt-continue-list));;;; org-format-table-html;;;; org-format-org-table-html;;;; org-format-table-table-html;;;; org-table-number-fraction;;;; org-table-number-regexp;;;; org-e-odt-table-caption-above;;;; org-whitespace;;;; "<span style=\"visibility:hidden;\">%s</span>";;;; Remove display properties;;;; org-e-odt-with-timestamp;;;; org-e-odt-html-helper-timestamp;;;; org-export-as-html-and-open;;;; org-export-as-html-batch;;;; org-export-as-html-to-buffer;;;; org-replace-region-by-html;;;; org-export-region-as-html;;;; org-export-as-html;;;; (org-export-directory :html opt-plist);;;; (plist-get opt-plist :html-extension);;;; org-e-odt-toplevel-hlevel;;;; org-e-odt-inline-image-extensions;;;; org-e-odt-protect-char-alist;;;; org-e-odt-table-use-header-tags-for-first-column;;;; org-e-odt-todo-kwd-class-prefix;;;; org-e-odt-tag-class-prefix;;;; org-e-odt-footnote-separator;;; Library Initializations(mapc (lambda (desc)   ;; Let Org open all OpenDocument files using system-registered app   (add-to-list 'org-file-apps		(cons (concat  "\\." (car desc) "\\'") 'system))   ;; Let Emacs open all OpenDocument files in archive mode   (add-to-list 'auto-mode-alist		(cons (concat  "\\." (car desc) "\\'") 'archive-mode))) org-e-odt-file-extensions)(defvar org-e-odt-display-outline-level 2)(defun org-e-odt-enumerate-element (element info &optional predicate n)  (let* ((numbered-parent-headline-at-<=-n	  (function	   (lambda (element n info)	     (loop for x in (org-export-get-genealogy element info)		   thereis (and (eq (org-element-type x) 'headline)		   		(<= (org-export-get-relative-level x info) n)		   		(org-export-numbered-headline-p x info)		   		x)))))	 (enumerate	  (function	   (lambda (element scope info &optional predicate)	     (let ((counter 0))	       (org-element-map		(or scope (plist-get info :parse-tree))		(org-element-type element)		(lambda (el)		  (and (or (not predicate) (funcall predicate el info))		       (incf counter)		       (equal element el)		       counter))		info 'first-match)))))	 (scope (funcall numbered-parent-headline-at-<=-n			 element (or n org-e-odt-display-outline-level) info))	 (ordinal (funcall enumerate element scope info predicate))	 (tag	  (concat	   ;; section number	   (and scope		(mapconcat 'number-to-string			   (org-export-get-headline-number scope info) "."))	   ;; separator	   (and scope ".")	   ;; ordinal	   (number-to-string ordinal))))    ;; (message "%s:\t%s" (org-element-property :name element) tag)    tag))(provide 'org-e-odt);;; org-e-odt.el ends here
 |