12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830148311483214833148341483514836148371483814839148401484114842148431484414845148461484714848148491485014851148521485314854148551485614857148581485914860148611486214863148641486514866148671486814869148701487114872148731487414875148761487714878148791488014881148821488314884148851488614887148881488914890148911489214893148941489514896148971489814899149001490114902149031490414905149061490714908149091491014911149121491314914149151491614917149181491914920149211492214923149241492514926149271492814929149301493114932149331493414935149361493714938149391494014941149421494314944149451494614947149481494914950149511495214953149541495514956149571495814959149601496114962149631496414965149661496714968149691497014971149721497314974149751497614977149781497914980149811498214983149841498514986149871498814989149901499114992149931499414995149961499714998149991500015001150021500315004150051500615007150081500915010150111501215013150141501515016150171501815019150201502115022150231502415025150261502715028150291503015031150321503315034150351503615037150381503915040150411504215043150441504515046150471504815049150501505115052150531505415055150561505715058150591506015061150621506315064150651506615067150681506915070150711507215073150741507515076150771507815079150801508115082150831508415085150861508715088150891509015091150921509315094150951509615097150981509915100151011510215103151041510515106151071510815109151101511115112151131511415115151161511715118151191512015121151221512315124151251512615127151281512915130151311513215133151341513515136151371513815139151401514115142151431514415145151461514715148151491515015151151521515315154151551515615157151581515915160151611516215163151641516515166151671516815169151701517115172151731517415175151761517715178151791518015181151821518315184151851518615187151881518915190151911519215193151941519515196151971519815199152001520115202152031520415205152061520715208152091521015211152121521315214152151521615217152181521915220152211522215223152241522515226152271522815229152301523115232152331523415235152361523715238152391524015241152421524315244152451524615247152481524915250152511525215253152541525515256152571525815259152601526115262152631526415265152661526715268152691527015271152721527315274152751527615277152781527915280152811528215283152841528515286152871528815289152901529115292152931529415295152961529715298152991530015301153021530315304153051530615307153081530915310153111531215313153141531515316153171531815319153201532115322153231532415325153261532715328153291533015331153321533315334153351533615337153381533915340153411534215343153441534515346153471534815349153501535115352153531535415355153561535715358153591536015361153621536315364153651536615367153681536915370153711537215373153741537515376153771537815379153801538115382153831538415385153861538715388153891539015391153921539315394153951539615397153981539915400154011540215403154041540515406154071540815409154101541115412154131541415415154161541715418154191542015421154221542315424154251542615427154281542915430154311543215433154341543515436154371543815439154401544115442154431544415445154461544715448154491545015451154521545315454154551545615457154581545915460154611546215463154641546515466154671546815469154701547115472154731547415475154761547715478154791548015481154821548315484154851548615487154881548915490154911549215493154941549515496154971549815499155001550115502155031550415505155061550715508155091551015511155121551315514155151551615517155181551915520155211552215523155241552515526155271552815529155301553115532155331553415535155361553715538155391554015541155421554315544155451554615547155481554915550155511555215553155541555515556155571555815559155601556115562155631556415565155661556715568155691557015571155721557315574155751557615577155781557915580155811558215583155841558515586155871558815589155901559115592155931559415595155961559715598155991560015601156021560315604156051560615607156081560915610156111561215613156141561515616156171561815619156201562115622156231562415625156261562715628156291563015631156321563315634156351563615637156381563915640156411564215643156441564515646156471564815649156501565115652156531565415655156561565715658156591566015661156621566315664156651566615667156681566915670156711567215673156741567515676156771567815679156801568115682156831568415685156861568715688156891569015691156921569315694156951569615697156981569915700157011570215703157041570515706157071570815709157101571115712157131571415715157161571715718157191572015721157221572315724157251572615727157281572915730157311573215733157341573515736157371573815739157401574115742157431574415745157461574715748157491575015751157521575315754157551575615757157581575915760157611576215763157641576515766157671576815769157701577115772157731577415775157761577715778157791578015781157821578315784157851578615787157881578915790157911579215793157941579515796157971579815799158001580115802158031580415805158061580715808158091581015811158121581315814158151581615817158181581915820158211582215823158241582515826158271582815829158301583115832158331583415835158361583715838158391584015841158421584315844158451584615847158481584915850158511585215853158541585515856158571585815859158601586115862158631586415865158661586715868158691587015871158721587315874158751587615877158781587915880158811588215883158841588515886158871588815889158901589115892158931589415895158961589715898158991590015901159021590315904159051590615907159081590915910159111591215913159141591515916159171591815919159201592115922159231592415925159261592715928159291593015931159321593315934159351593615937159381593915940159411594215943159441594515946159471594815949159501595115952159531595415955159561595715958159591596015961159621596315964159651596615967159681596915970159711597215973159741597515976159771597815979159801598115982159831598415985159861598715988159891599015991159921599315994159951599615997159981599916000160011600216003160041600516006160071600816009160101601116012160131601416015160161601716018160191602016021160221602316024160251602616027160281602916030160311603216033160341603516036160371603816039160401604116042160431604416045160461604716048160491605016051160521605316054160551605616057160581605916060160611606216063160641606516066160671606816069160701607116072160731607416075160761607716078160791608016081160821608316084160851608616087160881608916090160911609216093160941609516096160971609816099161001610116102161031610416105161061610716108161091611016111161121611316114161151611616117161181611916120161211612216123161241612516126161271612816129161301613116132161331613416135161361613716138161391614016141161421614316144161451614616147161481614916150161511615216153161541615516156161571615816159161601616116162161631616416165161661616716168161691617016171161721617316174161751617616177161781617916180161811618216183161841618516186161871618816189161901619116192161931619416195161961619716198161991620016201162021620316204162051620616207162081620916210162111621216213162141621516216162171621816219162201622116222162231622416225162261622716228162291623016231162321623316234162351623616237162381623916240162411624216243162441624516246162471624816249162501625116252162531625416255162561625716258162591626016261162621626316264162651626616267162681626916270162711627216273162741627516276162771627816279162801628116282162831628416285162861628716288162891629016291162921629316294162951629616297162981629916300163011630216303163041630516306163071630816309163101631116312163131631416315163161631716318163191632016321163221632316324163251632616327163281632916330163311633216333163341633516336163371633816339163401634116342163431634416345163461634716348163491635016351163521635316354163551635616357163581635916360163611636216363163641636516366163671636816369163701637116372163731637416375163761637716378163791638016381163821638316384163851638616387163881638916390163911639216393163941639516396163971639816399164001640116402164031640416405164061640716408164091641016411164121641316414164151641616417164181641916420164211642216423164241642516426164271642816429164301643116432164331643416435164361643716438164391644016441164421644316444164451644616447164481644916450164511645216453164541645516456164571645816459164601646116462164631646416465164661646716468164691647016471164721647316474164751647616477164781647916480164811648216483164841648516486164871648816489164901649116492164931649416495164961649716498164991650016501165021650316504165051650616507165081650916510165111651216513165141651516516165171651816519 |
- \input texinfo
- setfilename ../../info/org
- set VERSION 7.8.03
- c Use proper quote and backtick for code sections in PDF output
- set txicodequoteundirected
- c Version and Contact Info
- uref{http://orgmode.org,maintainers webpage}
- set MAINTAINER Carsten Dominik
- email{carsten at orgmode dot org}
- uref{mailto:carsten at orgmode dot org,contact the maintainer}
- finalout
- c Macro definitions for commands and keys
- c The behavior of the key/command macros will depend on the flag cmdnames
- set cmdnames
- c orgkey{key} A key item
- c xorgcmd{key,cmmand} Key with command name as
- c orgcmdnki{key,cmd} Like orgcmd, but do not index the key
- c orgcmdkkc{key1,key2,cmd} Two keys with one command name, use "or"
- c different functions, so format as
- c orgcmdkskc{key1,key2,cmd} Same as orgcmdkkc, but use "or short"
- itemx
- c a key but no command
- item key
- kindex \key\
- kbd{\key\}
- macro xorgkey{key}
- itemx
- end macro
- c Inserts:
- macro orgcmd{key,command}
- kindex \key\
- iftex
- kbd{\key\} code{\command\}
- ifnottex
- kbd{\key\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- item
- end ifclear
- c One key with one command, formatted using
- c Inserts:
- macro xorgcmd{key,command}
- kindex \key\
- iftex
- kbd{\key\} code{\command\}
- ifnottex
- kbd{\key\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- itemx
- end ifclear
- c one key with a command, bit do not index the key
- item KEY COMMAND
- ifset cmdnames
- iftex
- kbd{\key\} code{\command\}
- ifnottex
- kbd{\key\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- kbd{\key\}
- end macro
- c Inserts:
- macro orgcmdtkc{text,key,command}
- kindex \key\
- iftex
- kbd{\text\} code{\command\}
- ifnottex
- kbd{\text\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- item
- end ifclear
- c two keys with one command
- item KEY1 or KEY2 COMMAND
- ifset cmdnames
- kindex \key2\
- iftex
- kbd{\key1\} r{or} kbd{\key2\} code{\command\}
- ifnottex
- kbd{\key1\} r{or} kbd{\key2\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- kindex \key2\
- kbd{\key1\} r{or} kbd{\key2\}
- end macro
- c
- c Inserts:
- c
- macro orgcmdkxkc{key1,key2,command}
- kindex \key1\
- findex \command\
- item
- itemx hskip 0pt plus 1filll
- end iftex
- item
- itemx tie{}tie{}code{\command\})
- end ifset
- kindex \key1\
- item
- itemx
- end ifclear
- c Same as previous, but use "or short"
- item KEY1 or short KEY2 COMMAND
- ifset cmdnames
- kindex \key2\
- iftex
- kbd{\key1\} r{or short} kbd{\key2\} code{\command\}
- ifnottex
- kbd{\key1\} r{or short} kbd{\key2\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- kindex \key2\
- kbd{\key1\} r{or short} kbd{\key2\}
- end macro
- itemx
- itemx KEY1 or short KEY2 COMMAND
- ifset cmdnames
- kindex \key2\
- iftex
- kbd{\key1\} r{or short} kbd{\key2\} code{\command\}
- ifnottex
- kbd{\key1\} r{or short} kbd{\key2\} tie{}tie{}(
- end ifnottex
- ifclear cmdnames
- kindex \key2\
- kbd{\key1\} r{or short} kbd{\key2\}
- end macro
- c Inserts:
- c
- macro orgcmdkkcc{key1,key2,command1,command2}
- kindex \key1\
- findex \command1\
- iftex
- kbd{\key1\} code{\command1\}
- kbd{\key2\} code{\command2\}
- ifnottex
- kbd{\key1\} tie{}tie{}(
- itemx tie{}tie{}code{\command2\})
- end ifset
- kindex \key1\
- item
- itemx
- end ifclear
- c -----------------------------------------------------------------------------
- c
- end iftex
- macro tsubheading{text}
- subsubheading \text\
- ifnotinfo
- b{\text\}
- end macro
- value{VERSION}.
- Copyright
- quotation
- Permission is granted to copy, distribute and/or modify this document
- under the terms of the GNU Free Documentation License, Version 1.3 or
- any later version published by the Free Software Foundation; with no
- Invariant Sections, with the Front-Cover texts being ``A GNU Manual,''
- and with the Back-Cover Texts as in (a) below. A copy of the license
- is included in the section entitled ``GNU Free Documentation License.''
- (a) The FSF's Back-Cover Text is: ``You have the freedom to copy and
- modify this GNU manual. Buying copies from the FSF supports it in
- developing GNU and promoting software freedom.''
- This document is part of a collection distributed under the GNU Free
- Documentation License. If you want to distribute this document
- separately from the collection, you can do so by adding a copy of the
- license to the document, as described in section 6 of the license.
- end copying
- direntry
- * Org Mode: (org). Outline-based notes management and organizer
- titlepage
- subtitle Release
- author by Carsten Dominik
- with contributions by David O'Toole, Bastien Guerry, Philip Rooke, Dan Davison, Eric Schulte, Thomas Dye and Jambunathan K.
- page
- insertcopying
- c Output the table of contents at the beginning.
- ifnottex
- top Org Mode Manual
- end ifnottex
- detailmenu
- --- The Detailed Node Listing ---
- Introduction
- * Summary:: Brief summary of what Org does
- * Installation:: How to install a downloaded version of Org
- * Activation:: How to activate Org for certain buffers
- * Feedback:: Bug reports, ideas, patches etc.
- * Conventions:: Type-setting conventions in the manual
- Document structure
- * Outlines:: Org is based on Outline mode
- * Headlines:: How to typeset Org tree headlines
- * Visibility cycling:: Show and hide, much simplified
- * Motion:: Jumping to other headlines
- * Structure editing:: Changing sequence and level of headlines
- * Sparse trees:: Matches embedded in context
- * Plain lists:: Additional structure within an entry
- * Drawers:: Tucking stuff away
- * Blocks:: Folding blocks
- * Footnotes:: How footnotes are defined in Org's syntax
- * Orgstruct mode:: Structure editing outside Org
- Tables
- * Built-in table editor:: Simple tables
- * Column width and alignment:: Overrule the automatic settings
- * Column groups:: Grouping to trigger vertical lines
- * Orgtbl mode:: The table editor as minor mode
- * The spreadsheet:: The table editor has spreadsheet capabilities
- * Org-Plot:: Plotting from org tables
- The spreadsheet
- * References:: How to refer to another field or range
- * Formula syntax for Calc:: Using Calc to compute stuff
- * Formula syntax for Lisp:: Writing formulas in Emacs Lisp
- * Durations and time values:: How to compute durations and time values
- * Field and range formulas:: Formula for specific (ranges of) fields
- * Column formulas:: Formulas valid for an entire column
- * Editing and debugging formulas:: Fixing formulas
- * Updating the table:: Recomputing all dependent fields
- * Advanced features:: Field and column names, parameters and automatic recalc
- Hyperlinks
- * Link format:: How links in Org are formatted
- * Internal links:: Links to other places in the current file
- * External links:: URL-like links to the world
- * Handling links:: Creating, inserting and following
- * Using links outside Org:: Linking from my C source code?
- * Link abbreviations:: Shortcuts for writing complex links
- * Search options:: Linking to a specific location
- * Custom searches:: When the default search is not enough
- Internal links
- * Radio targets:: Make targets trigger links in plain text
- TODO items
- * TODO basics:: Marking and displaying TODO entries
- * TODO extensions:: Workflow and assignments
- * Progress logging:: Dates and notes for progress
- * Priorities:: Some things are more important than others
- * Breaking down tasks:: Splitting a task into manageable pieces
- * Checkboxes:: Tick-off lists
- Extended use of TODO keywords
- * Workflow states:: From TODO to DONE in steps
- * TODO types:: I do this, Fred does the rest
- * Multiple sets in one file:: Mixing it all, and still finding your way
- * Fast access to TODO states:: Single letter selection of a state
- * Per-file keywords:: Different files, different requirements
- * Faces for TODO keywords:: Highlighting states
- * TODO dependencies:: When one task needs to wait for others
- Progress logging
- * Closing items:: When was this entry marked DONE?
- * Tracking TODO state changes:: When did the status change?
- * Tracking your habits:: How consistent have you been?
- Tags
- * Tag inheritance:: Tags use the tree structure of the outline
- * Setting tags:: How to assign tags to a headline
- * Tag searches:: Searching for combinations of tags
- Properties and columns
- * Property syntax:: How properties are spelled out
- * Special properties:: Access to other Org mode features
- * Property searches:: Matching property values
- * Property inheritance:: Passing values down the tree
- * Column view:: Tabular viewing and editing
- * Property API:: Properties for Lisp programmers
- Column view
- * Defining columns:: The COLUMNS format property
- * Using column view:: How to create and use column view
- * Capturing column view:: A dynamic block for column view
- Defining columns
- * Scope of column definitions:: Where defined, where valid?
- * Column attributes:: Appearance and content of a column
- Dates and times
- * Timestamps:: Assigning a time to a tree entry
- * Creating timestamps:: Commands which insert timestamps
- * Deadlines and scheduling:: Planning your work
- * Clocking work time:: Tracking how long you spend on a task
- * Effort estimates:: Planning work effort in advance
- * Relative timer:: Notes with a running timer
- * Countdown timer:: Starting a countdown timer for a task
- Creating timestamps
- * The date/time prompt:: How Org mode helps you entering date and time
- * Custom time format:: Making dates look different
- Deadlines and scheduling
- * Inserting deadline/schedule:: Planning items
- * Repeated tasks:: Items that show up again and again
- Clocking work time
- * Clocking commands:: Starting and stopping a clock
- * The clock table:: Detailed reports
- * Resolving idle time:: Resolving time when you've been idle
- Capture - Refile - Archive
- * Capture:: Capturing new stuff
- * Attachments:: Add files to tasks
- * RSS Feeds:: Getting input from RSS feeds
- * Protocols:: External (e.g.
- LaTeX{}:: LaTeX can be freely used inside Org documents
- Structural markup elements
- * Document title:: Where the title is taken from
- * Headings and sections:: The document structure as seen by the exporter
- * Table of contents:: The if and where of the table of contents
- * Initial text:: Text before the first heading?
- * Lists:: Lists
- * Paragraphs:: Paragraphs
- * Footnote markup:: Footnotes
- * Emphasis and monospace:: Bold, italic, etc.
- * Horizontal rules:: Make a line
- * Comment lines:: What will *not* be exported
- Embedded
- LaTeX{} fragments:: Complex formulas made easy
- * Previewing
- LaTeX{} and PDF export:: Exporting to
- LaTeX{} and PDF export
- *
- LaTeX{} code:: Incorporating literal
- LaTeX{} export:: Options for exporting tables to
- LaTeX{} export:: How to insert figures into
- acronym{ODT} export:: What packages
- acronym{ODT} export commands:: How to invoke
- acronym{ODT} export:: How links will be interpreted and formatted
- * Tables in
- acronym{ODT} export:: How to insert images
- * Math formatting in LaTeX{} fragments are formatted
- * Literal examples in
- acronym{ODT} export:: Read this if you are a power user
- Math formatting in
- LaTeX{} math snippets:: How to embed
- acronym{ODT} export
- * Exporting and converting to other formats:: How to produce
- acronym{ODT} export:: How to define and use Table templates
- * Validating OpenDocument XML:: How to debug corrupt OpenDocument files
- Publishing
- * Configuration:: Defining projects
- * Uploading files:: How to get files up on the server
- * Sample configuration:: Example projects
- * Triggering publication:: Publication commands
- Configuration
- * Project alist:: The central configuration variable
- * Sources and destinations:: From here to there
- * Selecting files:: What files are part of the project?
- * Publishing action:: Setting the function doing the publishing
- * Publishing options:: Tweaking HTML/
- LaTeX{} and other programs
- * Dynamic blocks:: Automatically filled blocks
- * Special agenda views:: Customized views
- * Extracting agenda information:: Postprocessing of agenda information
- * Using the property API:: Writing programs that use entry properties
- * Using the mapping API:: Mapping over all or selected entries
- Tables and lists in arbitrary syntax
- * Radio tables:: Sending and receiving radio tables
- * A
- end detailmenu
- node Introduction, Document Structure, Top, Top
- cindex introduction
- end menu
- section Summary
- i{agenda views}.
- Org mode contains the Org Babel environment which allows you to work with
- embedded source code blocks in a file, to facilitate code evaluation,
- documentation, and literate programming techniques.
- Org's automatic, context-sensitive table editor with spreadsheet
- capabilities can be integrated into any major mode by activating the
- minor Orgtbl mode. Using a translation step, it can be used to maintain
- tables in arbitrary file types, for example in
- example
- bullet{} an outline extension with visibility cycling and structure editing}
- bullet{} an ASCII system and table editor for taking structured notes}
- bullet{} a TODO list editor}
- bullet{} a full agenda and planner with deadlines and work scheduling}
- r{
- r{LaTeX{} export}
- bullet{} a publishing tool to create a set of interlinked webpages}
- bullet{} an environment for literate programming}
- cindex FAQ
- There is a website for Org which provides links to the newest
- version of Org, as well as additional information, frequently asked
- questions (FAQ), links to tutorials, etc
- uref{http://orgmode.org}.
- uref{http://www.network-theory.co.uk/org/manual/, paperback book from Network
- Theory Ltd.}
- node Installation, Activation, Summary, Introduction
- cindex installation
- b{Important:}
- ref{Activation}. To see what version of Org (if any) is part of your
- Emacs distribution, type kbd{M-x
- org-version}.}
- If you have downloaded Org from the Web, either as a distribution
- file{.tar} file, or as a Git archive, you must take the following steps
- to install it: go into the unpacked Org distribution directory and edit the
- top section of the file
- file{emacs} or
- file{lisp} subdirectory to the
- Emacs load path. To do this, add the following line to
- example
- (setq load-path (cons "~/path/to/orgdir/lisp" load-path))
- noindent
- If you plan to use code from the
- example
- (setq load-path (cons "~/path/to/orgdir/contrib/lisp" load-path))
- noindent Now byte-compile the Lisp files with the shell command:
- end example
- example
- make install
- file{install-info} program. The following should correctly install the Info
- files on most systems, please send a bug report if not
- example
- This is not dpkg install-info anymore, but GNU install-info
- See the man page for ginstall-info for command line arguments
- noindent which can be safely ignored.}.
- end example
- Then add the following line to
- lisp
- (require 'org-install)
- page
- section Activation
- cindex autoload
- cindex key bindings, global
- To make sure files with extension
- file{.emacs} file.
- end lisp
- footnote{If you don't use font-lock globally, turn it on in
- Org buffer with
- command{org-store-link},
- command{org-agenda}, and
- : anywhere in Emacs, not just in Org buffers). Here are
- suggested bindings for these keys, please modify the keys to your own
- liking.
- end lisp
- samp{.org} will be put
- into Org mode. As an alternative, make the first line of a file look
- like this:
- end example
- noindent which will select Org mode for this buffer no matter what
- the file's name is. See also the variable
- i{active}. To make
- use of this, you need to have
- code{zmacs-regions} in XEmacs) turned on. In Emacs 23 this is the default,
- in Emacs 22 you need to do this yourself with
- end lisp
- code{transient-mark-mode}, you can create an
- active region by using the mouse to select a region, or pressing
- key{SPC}} twice before moving the cursor.
- section Feedback
- cindex bug reports
- cindex author
- If you find problems with Org, or if you have questions, remarks, or ideas
- about it, please mail to the Org mailing list
- footnote{Please consider subscribing
- to the mailing list, in order to minimize the work the mailing list
- moderators have to do.}.
- For bug reports, please first try to reproduce the bug with the latest
- version of Org available---if you are running an outdated version, it is
- quite possible that the bug has been fixed already. If the bug persists,
- prepare a report and provide as much information as possible, including the
- version information of Emacs (key{RET}}) and Org
- (key{RET}}), as well as the Org related setup in
- example
- end example
- example
- $ emacs -Q -l /path/to/minimal-org.el
- code{emacs
- -Q}. The
- example
- ;;; Minimal setup to load latest `org-mode'
- ;; activate debugging
- (setq debug-on-error t
- debug-on-signal nil
- debug-on-quit nil)
- ;; add latest org-mode to load path
- (add-to-list 'load-path (expand-file-name "/path/to/org-mode/lisp"))
- (add-to-list 'load-path (expand-file-name "/path/to/org-mode/contrib/lisp"))
- ;; activate org
- (require 'org-install)
- enumerate
- item What did you expect to happen?
- end enumerate
- subsubheading How to create a useful backtrace
- emph{backtrace}.
- This is information from the built-in debugger about where and how the
- error occurred. Here is how to produce a useful backtrace:
- item
- Reload uncompiled versions of all Org mode Lisp files. The backtrace
- contains much more information if it is produced with uncompiled code.
- To do this, use
- end example
- code{Org -> Refresh/Reload -> Reload Org uncompiled} from the
- menu.
- code{Options} menu and select
- code{Troubleshooting} sub-menu).
- item
- When you hit the error, a
- kbd{C-x C-w}) and
- attach it to your bug report.
- node Conventions, , Feedback, Introduction
- table
- item TODO
- item boss
- item Release
- end table
- The manual lists both the keys and the corresponding commands for accessing
- functionality. Org mode often uses the same key for different functions,
- depending on context. The command that is bound to such keys has a generic
- name, like
- kbd{M-
- code{org-do-demote}, while in the chapter on tables, it will
- be listed to call org-table-move-column-right.
- If you prefer, you can compile the manual without the command names by
- unsetting the flag file{org.texi}.
- chapter Document structure
- cindex structure of document
- Org is based on Outline mode and provides flexible commands to
- edit the structure of the document.
- end menu
- section Outlines
- cindex Outline mode
- Org is implemented on top of Outline mode. Outlines allow a
- document to be organized in a hierarchical structure, which (at least
- for me) is the best representation of notes and thoughts. An overview
- of this structure is achieved by folding (hiding) large parts of the
- document to show only the general document structure and the parts
- currently being worked on. Org greatly simplifies the use of
- outlines by compressing the entire show/hide functionality into a single
- command, key{TAB} key.
- section Headlines
- cindex outline tree
- vindex org-special-ctrl-k
- footnote{See the variables
- code{org-special-ctrl-k}, and
- kbd{C-a},
- kbd{C-k} in headlines.}. For example:
- end example
- ref{Clean view}, describes a setup to realize this.
- code{org-cycle-separator-lines} to modify this behavior.
- section Visibility cycling
- cindex visibility cycling
- cindex show hidden text
- key{TAB} and
- key{TAB}} to change the visibility in the buffer.
- cindex subtree cycling
- cindex children, subtree visibility state
- table
- orgcmd{
- emph{Subtree cycling}: Rotate current subtree among the states
- end example
- vindex org-cycle-global-at-bob
- The cursor must be on a headline for this to work
- code{org-cycle-emulate-tab}.}. When the cursor is at the
- beginning of the buffer and the first line is not a headline, then
- footnote{see the
- option
- kbd{C-u
- cindex global visibility states
- cindex overview, global visibility state
- cindex show all, global visibility state
- key{TAB},org-global-cycle}
- key{TAB}
- example
- ,-> OVERVIEW -> CONTENTS -> SHOW ALL --.
- '--------------------------------------'
- kbd{S-
- kbd{S-
- cindex show all, command
- key{TAB},show-all}
- Show all, including drawers.
- pxref{Sparse trees}) or an agenda command
- (
- orgcmd{C-c C-k,show-branches}
- Expose all the headings of the subtree, CONTENT view for just one subtree.
- footnote{The indirect
- buffer
- pxref{Indirect Buffers,,,emacs,GNU Emacs Manual})
- ifnotinfo
- (see the Emacs manual for more information about indirect buffers)
- kbd{C-u} prefix, do not remove
- the previously used indirect buffer.
- i{visible} text in the region into the kill ring.
- vindex org-startup-folded
- code{overview}, STARTUP keyword
- code{content}, STARTUP keyword
- code{showall}, STARTUP keyword
- code{showeverything}, STARTUP keyword
- When Emacs first visits an Org file, the global state is set to
- OVERVIEW, i.e.
- code{org-startup-folded}, or on a
- per-file basis by adding one of the following lines anywhere in the
- buffer:
- end example
- noindent
- Furthermore, any entries with a pxref{Properties
- and Columns}) will get their visibility adapted accordingly. Allowed values
- for this property are code{children},
- code{all}.
- asis
- key{TAB},org-set-startup-visibility}
- Switch back to the startup visibility of the buffer, i.e.
- samp{VISIBILITY} properties in individual
- entries.
- node Motion, Structure editing, Visibility cycling, Document Structure
- cindex motion, between headlines
- cindex headline navigation
- The following commands jump to other headlines in the buffer.
- asis
- orgcmd{C-c C-p,outline-previous-visible-heading}
- Previous heading.
- orgcmd{C-c C-b,org-backward-same-level}
- Previous heading same level.
- orgcmd{C-c C-j,org-goto}
- Jump to a different place without changing the current outline
- visibility. Shows the document structure in a temporary buffer, where
- you can use the following keys to find your destination:
- example
- r{Cycle visibility.}
- key{up}
- key{RET}
- kbd{/}
- r{The following keys work if you turn off
- r{Next/previous visible headline.}
- f / b
- r{One level up.}
- 0-9
- r{Quit}
- vindex org-goto-interface
- code{org-goto-interface}.
- node Structure editing, Sparse trees, Motion, Document Structure
- cindex structure editing
- cindex promotion, of subtrees
- cindex subtree, cut and paste
- cindex cutting, of subtrees
- cindex sorting, of subtrees
- table
- orgcmd{M-
- vindex org-M-RET-may-split-line
- Insert new heading with same level as current. If the cursor is in a plain
- list item, a new item is created (
- footnote{If you do not want the line to be split, customize the
- variable
- :
- behind the ellipses at the end of a headline), then a headline like the
- current one will be inserted after the end of the subtree.
- key{RET},org-insert-heading-respect-content}
- Just like key{RET}}, except when adding a new heading below the
- current heading, the new heading is placed after the body instead of before
- it. This command works from anywhere in the entry.
- key{RET},org-insert-todo-heading}
- code{org-treat-insert-todo-heading-as-state-change}.
- key{RET},org-insert-todo-heading-respect-content}
- Insert new TODO entry with same level as current heading. Like
- key{RET}}, the new headline will be inserted after the current
- subtree.
- key{TAB},org-cycle}
- In a new entry with no text yet, the first
- key{TAB} makes it a parent,
- and so on, all the way to top level. Yet another
- orgcmd{M-
- orgcmd{M-
- orgcmd{M-S-
- orgcmd{M-S-
- orgcmd{M-S-
- orgcmd{M-S-
- orgcmd{C-c C-x C-w,org-cut-subtree}
- Kill subtree, i.e.
- orgcmd{C-c C-x M-w,org-copy-subtree}
- Copy subtree to kill ring. With a numeric prefix argument N, copy the N
- sequential subtrees.
- samp{****}.
- vindex org-yank-adjusted-subtrees
- code{org-yank-adjusted-subtrees} and
- code{yank} command will
- paste subtrees folded and in a clever way, using the same command as
- code{yank} to be executed, with the prefix passed along. A good way to
- force a normal yank is code{yank-pop} after a
- yank, it will yank previous kill items plainly, without adjustment and
- folding.
- code{org-clone-subtree-with-time-shift}.
- xref{Refiling notes}.
- kbd{C-u} prefix,
- sorting will be case-sensitive.
- orgcmd{C-x n b,org-narrow-to-block}
- Narrow buffer to current block.
- orgcmd{C-c *,org-toggle-heading}
- Turn a normal line or plain list item into a headline (so that it becomes a
- subheading at its location). Also turn a headline into a normal line by
- removing the stars. If there is an active region, turn all lines in the
- region into headlines. If the first line in the region was an item, turn
- only the item lines into headlines. Finally, if the first line is a
- headline, remove the stars from all headlines in the region.
- cindex region, active
- cindex transient mark mode
- When there is an active region (Transient Mark mode), promotion and
- demotion work on all headlines in the region. To select a region of
- headlines, it is best to place both point and mark at the beginning of a
- line, mark at the beginning of the first headline, and point at the line
- just after the last headline to change. Note that when the cursor is
- inside a table (
- node Sparse trees, Plain lists, Structure editing, Document Structure
- cindex sparse trees
- cindex folding, sparse trees
- vindex org-show-hierarchy-above
- vindex org-show-siblings
- emph{sparse
- trees} for selected information in an outline tree, so that the entire
- document is folded as much as possible, but the selected information is made
- visible along with the headline structure above it
- code{org-show-hierarchy-above},
- code{org-show-siblings}, and
- table
- orgcmd{C-c /,org-sparse-tree}
- This prompts for an extra key to select a sparse-tree creating command.
- vindex org-remove-highlights-with-change
- Prompts for a regexp and shows a sparse tree with all matches. If
- the match is in a headline, the headline is made visible. If the match is in
- the body of an entry, headline and body are made visible. In order to
- provide minimal context, also the full hierarchy of headlines above the match
- is shown, as well as the headline following the match. Each match is also
- highlighted; the highlights disappear when the buffer is changed by an
- editing command
- code{org-remove-highlights-with-change}}, or by pressing
- kbd{C-u} prefix argument, previous highlights are kept,
- so several calls to this command can be stacked.
- orgcmdkkc{M-g p,M-g M-p,previous-error}
- Jump to the previous sparse tree match in this buffer.
- noindent
- code{org-agenda-custom-commands} to define fast
- keyboard access to specific sparse trees. These commands will then be
- accessible through the agenda dispatcher (
- lisp
- (setq org-agenda-custom-commands
- '(("f" occur-tree "FIXME")))
- noindent will define the key
- samp{FIXME}.
- The other sparse tree commands select headings based on TODO keywords,
- tags, or properties and will be discussed later in this manual.
- cindex printing sparse trees
- code{ps-print-buffer-with-faces} which does not print invisible parts
- of the document
- kbd{C-c C-e v} to export only the visible
- part of the document and print the resulting file.
- section Plain lists
- cindex lists, plain
- cindex ordered lists
- Within an entry of the outline tree, hand-formatted lists can provide
- additional structure. They also provide a way to create lists of checkboxes
- (
- pxref{Exporting}) can parse and format them.
- Org knows ordered lists, unordered lists, and description lists.
- bullet
- emph{Unordered} list items start with samp{+}, or
- footnote{When using
- samp{*}
- is supported, it may be better to not use it for plain list items.} as
- bullets.
- vindex org-plain-list-ordered-item-terminator
- emph{Ordered} list items start with a numeral followed by either a period or
- a right parenthesis
- code{org-plain-list-ordered-item-terminator}.}, such as
- samp{1)}samp{a.}, samp{a)} and
- code{org-alphabetical-lists}. To minimize
- confusion with normal text, those are limited to one character only. Beyond
- that limit, bullets will automatically fallback to numbers.}. If you want a
- list to start with a different value (e.g.
- code{[20]}
- emph{before} the checkbox. If you have activated alphabetical
- lists, you can also use counters like
- item
- samp{ :: } to distinguish the description
- end itemize
- Items belonging to the same list must have the same indentation on the first
- line. In particular, if an ordered list reaches number
- vindex org-list-ending-method
- vindex org-empty-line-terminates-plain-lists
- Two methods
- code{org-list-ending-method}.} are provided to terminate lists. A list ends
- whenever every item has ended, which means before any line less or equally
- indented than items at top level. It also ends before two blank
- linescode{org-empty-line-terminates-plain-lists}.}. In
- that case, all items are closed. For finer control, you can end lists with
- any pattern set in
- example
- b{Elijah Wood} :: He plays Frodo
- -
- i{The Goonies}.
- end example
- Org supports these lists by tuning filling and wrapping commands to deal with
- them correctly
- file{filladapt.el}. To turn this on,
- put into code{(require 'filladapt)}}, and by exporting them
- properly (
- code{#+BEGIN_...}
- blocks can be indented to signal that they belong to a particular item.
- vindex org-list-indent-offset
- If you find that using a different bullet for a sub-list (than that used for
- the current list-level) improves readability, customize the variable
- code{org-list-indent-offset}.
- code{org-list-automatic-rules}
- to disable them individually.
- asis
- key{TAB},org-cycle}
- vindex org-cycle-include-plain-lists
- Items can be folded just like headline levels. Normally this works only if
- the cursor is on a plain list item. For more details, see the variable
- code{integrate}, plain list items will be treated like low-level
- headlines. The level of an item is then given by the indentation of the
- bullet/number. Items are always subordinate to real headlines, however; the
- hierarchies remain completely separated. In a new item with no text yet, the
- first
- key{TAB}s move the item to meaningful levels in the list
- and eventually get it back to its initial position.
- key{RET},org-insert-heading}
- vindex org-list-automatic-rules
- Insert new item at current level. With a prefix argument, force a new
- heading (
- emph{split} in two, and the second part becomes the
- new item
- code{org-M-RET-may-split-line}.}. If this command is executed
- emph{before} the current
- one.
- table
- kindex M-S-
- item M-S-RET
- Insert a new item with a checkbox (
- kindex S-
- item S-up
- cindex shift-selection-mode
- vindex org-list-use-circular-motion
- Jump to the previous/next item in the current list
- code{org-list-use-circular-motion}.}, but only if
- kbd{C-kbd{C-
- kindex M-
- kindex M-
- item M-up
- footnote{See
- kindex M-
- kindex M-
- item M-left
- kindex M-S-
- kindex M-S-
- item M-S-left
- code{org-list-automatic-rules}. The global indentation of a list has no
- influence on the text
- kindex C-c C-c
- pxref{Checkboxes}) in the item line, toggle the
- state of the checkbox. In any case, verify bullets and indentation
- consistency in the whole list.
- vindex org-plain-list-ordered-item-terminator
- item C-c -
- Cycle the entire list level through the different itemize/enumerate bullets
- (samp{+}, samp{1.},
- code{org-plain-list-ordered-item-terminator}, the type of list,
- and its positioncode{bullet} rule in
- kindex C-c *
- xref{Structure editing}, for a detailed explanation.
- item C-c C-*
- Turn the whole plain list into a subtree of the current heading. Checkboxes
- (
- kindex S-
- kindex S-
- item S-left/right
- code{org-support-shift-select}.
- item C-c ^
- Sort the plain list. You will be prompted for the sorting method:
- numerically, alphabetically, by time, or by custom function.
- node Drawers, Blocks, Plain lists, Document Structure
- cindex drawers
- cindex visibility cycling, drawers
- emph{drawers}.
- Drawers need to be configured with the variable
- footnote{You can define drawers on a per-file basis
- with a line like
- example
- ** This is a headline
- Still outside the drawer
- :DRAWERNAME:
- This is inside the drawer.
- :END:
- After the drawer.
- pxref{Visibility cycling}) on the headline will hide and
- show the entry, but keep the drawer collapsed to a single line. In order to
- look inside the drawer, you need to move the cursor to the drawer line and
- press code{PROPERTIES} drawer for
- storing properties (
- pxref{Tracking TODO state changes}) and clock times
- (code{LOGBOOK}. If you
- want to store a quick note in the LOGBOOK drawer, in a similar way to state changes, use
- kbd
- item C-c C-z
- Add a time-stamped note to the LOGBOOK drawer.
- node Blocks, Footnotes, Drawers, Document Structure
- vindex org-hide-block-startup
- pxref{Literal examples}) to capturing time logging
- information (
- code{org-hide-block-startup}
- or on a per-file basis by using
- code{hideblocks}, STARTUP keyword
- code{nohideblocks}, STARTUP keyword
- end example
- section Footnotes
- file{footnote.el} package, Org mode's footnotes are designed for work on a
- larger document, not only for one-off documents like emails. The basic
- syntax is similar to the one used by : a footnote is
- defined in a paragraph that is started by a footnote marker in square
- brackets in column 0, no indentation allowed. If you need a paragraph break
- inside a footnote, use the samp{\par}. The footnote reference
- is simply the marker in square brackets, inside text. For example:
- end example
- Org mode extends the number-based syntax to
- file{footnote.el} does) is supported for backward compatibility, but not
- encouraged because of possible conflicts with pxref{Embedded
- table
- item [1]
- A plain numeric footnote marker. Compatible with
- samp{[1]} could easily be part of a code
- snippet.
- code{name} is a unique label word, or, for
- simplicity of automatic creation, a number.
- LaTeX{}-like anonymous footnote where the definition is given directly at the
- reference point.
- code{[fn:name]} to create additional references.
- vindex org-footnote-auto-label
- Footnote labels can be created automatically, or you can create names yourself.
- This is handled by the variable
- code{#+STARTUP} keywords. See the docstring of that variable
- for details.
- table
- kindex C-c C-x f
- vindex org-footnote-define-inline
- vindex org-footnote-auto-adjust
- Otherwise, create a new footnote. Depending on the variable
- footnote{The corresponding in-buffer
- setting is: code{#+STARTUP: nofninline}}, the
- definition will be placed right into the text as part of the reference, or
- separately into the location determined by the variable
- example
- s
- r{Org makes no effort to sort footnote definitions into a particular}
-
- r{also move entries according to
- r{sorting after each insertion/deletion can be configured using the}
- code{org-footnote-auto-adjust}.}
- r code{fn:N} footnotes. Automatic renumbering}
-
- r{
- r{Short for first code{s} action.}
- n
- r{inline definitions) into a special section, and then numbering them}
-
- r{meant to be the final step before finishing a document (e.g.
- r{off an email). The exporters do this automatically, and so could}
- code{message-send-hook}.}
- d
- r{to it.}
- code{org-footnote-auto-adjust}
- code{fnadjust} and
- kindex C-c C-c
- kbd{C-c C-x f}.
- kindex mouse-1
- item C-c C-o
- end table
- section The Orgstruct minor mode
- cindex minor mode for structure editing
- If you like the intuitive way the Org mode structure editing and list
- formatting works, you might want to use these commands in other modes like
- Text mode or Mail mode as well. The minor mode
- kbd{M-x orgstruct-mode}, or
- turn it on by default, for example in Message mode, with one of:
- end lisp
- When this mode is active and the cursor is on a line that looks to Org like a
- headline or the first line of a list item, most structure editing commands
- will work, even if the same keys normally have different functionality in the
- major mode you are using. If the cursor is not in one of those special
- lines, Orgstruct mode lurks silently in the shadows. When you use
- node Tables, Hyperlinks, Document Structure, Top
- cindex tables
- file{calc} package
- pxref{Top,Calc,,Calc,Gnu Emacs Calculator Manual}).
- ifnotinfo
- (see the Emacs Calculator manual for more information about the Emacs
- calculator).
- menu
- * Built-in table editor:: Simple tables
- * Column width and alignment:: Overrule the automatic settings
- * Column groups:: Grouping to trigger vertical lines
- * Orgtbl mode:: The table editor as minor mode
- * The spreadsheet:: The table editor has spreadsheet capabilities
- * Org-Plot:: Plotting from org tables
- node Built-in table editor, Column width and alignment, Tables, Tables
- cindex table editor, built-in
- Org makes it easy to format tables in plain ASCII. Any line with
- samp{|}
- is also the column separator
- code{\vert} or, inside a word {
- example
- | Name | Phone | Age |
- |-------+-------+-----|
- | Peter | 1234 | 17 |
- | Anna | 4321 | 25 |
- key{TAB} or
- kbd{C-c C-c} inside the table.
- key{RET} to the next row) and creates new table rows
- at the end of the table or before horizontal lines. The indentation
- of the table is set by the first line. Any line starting with
- example
- |Name|Phone|Age|
- |-
- noindent and then press
- code{|Name|Phone|Age} followed by
- key{RET}}.
- vindex org-table-auto-blank-field
- When typing text into a field, Org treats
- key{Backspace}, and all character keys in a special way, so that
- inserting and deleting avoids shifting other fields. Also, when
- typing
- kbd{kbd{S-kbd{
- code{org-enable-table-editor} and
- table
- tsubheading{Creation and conversion}
- kbd{C-u} forces CSV,
- *
- If there is no active region, this command creates an empty Org
- table. But it is easier just to start typing, like
- key{RET} |-
- tsubheading{Re-aligning and field motion}
- c
- c
- key{TAB},org-table-previous-field}
- Re-align, move to previous field.
- orgcmd{
- key{RET} still does
- NEWLINE, so it can be used to split a table.
- orgcmd{M-a,org-table-beginning-of-field}
- Move to beginning of the current table field, or on to the previous field.
- tsubheading{Column and row editing}
- key{left},M-
- c
- key{left},org-table-delete-column}
- Kill the current column.
- orgcmd{M-S-
- c
- key{up},M-
- c
- key{up},org-table-kill-row}
- Kill the current row or horizontal line.
- orgcmd{M-S-
- c
- c
- key{RET},org-table-hline-and-move}
- Insert a horizontal line below current row, and move the cursor into the row
- below that line.
- orgcmd{C-c ^,org-table-sort-lines}
- Sort the table lines in the region. The position of point indicates the
- column to be used for sorting, and the range of lines is the range
- between the nearest horizontal separator lines, or the entire table. If
- point is before the first column, you will be prompted for the sorting
- column. If there is an active region, the mark specifies the first line
- and the sorting column, while point should be in the last line to be
- included into the sorting. The command prompts for the sorting type
- (alphabetically, numerically, or by time). When called with a prefix
- argument, alphabetic sorting will be case-sensitive.
- orgcmd{C-c C-x M-w,org-table-copy-region}
- Copy a rectangular region from a table to a special clipboard. Point and
- mark determine edge fields of the rectangle. If there is no active region,
- copy just the current field. The process ignores horizontal separator lines.
- orgcmd{C-c C-x C-w,org-table-cut-region}
- Copy a rectangular region from a table to a special clipboard, and
- blank all fields in the rectangle. So this is the ``cut'' operation.
- orgcmd{C-c C-x C-y,org-table-paste-rectangle}
- Paste a rectangular region into a table.
- The upper left corner ends up in the current field. All involved fields
- will be overwritten. If the rectangle does not fit into the present table,
- the table is enlarged as needed. The process ignores horizontal separator
- lines.
- orgcmd{M-
- tsubheading{Calculations}
- cindex calculations, in tables
- cindex active region
- orgcmd{C-c +,org-table-sum}
- Sum the numbers in the current column, or in the rectangle defined by
- the active region. The result is shown in the echo area and can
- be inserted with
- c
- key{RET},org-table-copy-down}
- code{org-table-copy-increment}, integer field
- values will be incremented during copy. Integers that are too large will not
- be incremented. Also, a
- pxref{Conflicts}).
- orgcmd{C-c `,org-table-edit-field}
- Edit the current field in a separate window. This is useful for fields that
- are not fully visible (
- kbd{C-u} prefix, just make the full field visible, so that it can be
- edited in place. When called with two
- kbd{C-u C-u C-c `}.
- item M-x org-table-import
- Import a file as a table. The table should be TAB or whitespace
- separated. Use, for example, to import a spreadsheet table or data
- from a database, because these programs generally can write
- TAB-separated text files. This command works by inserting the file into
- the buffer and then converting the region to a table. Any prefix
- argument is passed on to the converter, which uses it to determine the
- separator.
- kbd{C-x C-x} and then using the
- i{Creation and conversion}).
- item M-x org-table-export
- vindex org-table-export-default-format
- Export the table, by default as a TAB-separated file. Use for data
- exchange with, for example, spreadsheet or database programs. The format
- used to export the file can be configured in the variable
- code{TABLE_EXPORT_FILE} and
- ref{Translator functions}, for a
- detailed description.
- samp{|}, you can turn
- it off with
- end lisp
- kbd{C-c C-c} to do a manual re-align.
- section Column width and alignment
- cindex alignment in tables
- The width of columns is automatically determined by the table editor. And
- also the alignment of a column is determined automatically from the fraction
- of number-like versus non-number fields in the column.
- Sometimes a single field or a few fields need to carry more text, leading to
- inconveniently wide columns. Or maybe you want to make a table with several
- columns having a fixed width, regardless of content. To set
- samp{<N>} where
- example
- end group
- noindent
- Fields that are wider become clipped and end in the string
- kbd{C-c `} (that is
- kbd{C-c
- C-c}.
- code{org-startup-align-all-tables} will realign all tables in a file
- upon visiting, but also slow down startup. You can also set this option
- on a per-file basis with:
- end example
- If you would like to overrule the automatic alignment of number-rich columns
- to the right and of string-rich column to the left, you can use
- samp{c}
- samp{<l>} in a similar fashion. You may
- also combine alignment and field width like this:
- node Column groups, Orgtbl mode, Column width and alignment, Tables
- cindex grouping columns in tables
- When Org exports tables, it does so by default without vertical
- lines because that is visually more satisfying in general. Occasionally
- however, vertical lines can be useful to structure a table into groups
- of columns, much like horizontal lines can do for groups of rows. In
- order to specify column groups, you can use a special row where the
- first field contains only
- samp{<} to indicate that this column should start a group,
- samp{<>} to make a column
- a group of its own. Boundaries between column groups will upon export be
- marked with vertical lines. Here is an example:
- end example
- It is also sufficient to just insert the column group starters after
- every vertical line you would like to have:
- end example
- section The Orgtbl minor mode
- cindex minor mode for tables
- If you like the intuitive way the Org table editor works, you
- might also want to use it in other modes like Text mode or Mail mode.
- The minor mode Orgtbl mode makes this possible. You can always toggle
- the mode with
- lisp
- (add-hook 'message-mode-hook 'turn-on-orgtbl)
- LaTeX{} tables with the underlying ease and power of
- Orgtbl mode, including spreadsheet capabilities. For details, see
- node The spreadsheet, Org-Plot, Orgtbl mode, Tables
- cindex calculations, in tables
- cindex
- file{calc} package to implement
- spreadsheet-like capabilities. It can also evaluate Emacs Lisp forms to
- derive fields from other fields. While fully featured, Org's implementation
- is not identical to other spreadsheets. For example, Org knows the concept
- of a
- menu
- * References:: How to refer to another field or range
- * Formula syntax for Calc:: Using Calc to compute stuff
- * Formula syntax for Lisp:: Writing formulas in Emacs Lisp
- * Durations and time values:: How to compute durations and time values
- * Field and range formulas:: Formula for specific (ranges of) fields
- * Column formulas:: Formulas valid for an entire column
- * Editing and debugging formulas:: Fixing formulas
- * Updating the table:: Recomputing all dependent fields
- * Advanced features:: Field and column names, parameters and automatic recalc
- node References, Formula syntax for Calc, The spreadsheet, The spreadsheet
- cindex references
- To compute fields in the table from other fields, formulas must
- reference other fields or ranges. In Org, fields can be referenced
- by name, by absolute coordinates, and by relative coordinates. To find
- out what the coordinates of a field are, press
- kbd{C-c
- subsubheading Field references
- cindex references, to fields
- Formulas can reference the value of another field in two ways. Like in
- any other spreadsheet, you may reference fields with a letter/number
- combination like
- vindex org-table-use-standard-references
- However, Org prefers
- samp{B4}, but it will not use this syntax when offering a formula
- for editing. You can customize this behavior using the variable
- example
- var{column}
- code{$1},
- code{$: the
- column of the field which is being computed) like code{$-2}.
- code{$>} are immutable references to the first and last
- column, respectively, and you can use
- code{1}, code{
- code{+3} or code{<} and
- footnote{For backward compatibility
- you can also use special names like code{$LR12} to refer in
- a stable way to the 5th and 12th field in the last row of the table.
- However, this syntax is deprecated, it should not be used for new documents.
- Use
- code{I} refers to the first
- hline, .
- code{+I} to the first such line below the
- current line. You can also write
- code{0} and
- emph{unsigned} numbers are fixed references
- in the sense that if you use the same reference in the formula for two
- different fields, the same field will be referenced each time.
- Org's references with
- example
- 2$3 code{C2})}
- $5 code{E&})}
- 2
- r{the field one row up, three columns to the left}
- -I$2
- r{field in the last row, in column 5}
- subsubheading Range references
- cindex references, to ranges
- You may reference a rectangular range of fields by specifying two field
- references connected by two dots
- samp{$2..$7}, but if at least one field
- is in a different row, you need to use the general
- samp{} in order to be interpreted correctly). Examples:
- r{first three fields in the current row}
- $P..$Q
- r{start in third column, continue to the one but last}
- 2$1..4$3 code{A2..C4})}
- -1$-2..-1
- r{between first and second hline, short for
- end example
- samp{E} mode switch below). If there are no non-empty fields,
- subsubheading Field coordinates in formulas
- cindex coordinates, of field
- cindex column, of field coordinates
- For Calc formulas and Lisp formulas code{$#} can be used to
- get the row or column number of the field where the formula result goes.
- The traditional Lisp formula equivalents are
- code{org-table-current-column}. Examples:
- r{column number on odd lines only}
- $3 = remote(FOO, #$2)
- r{column 3 of the current table}
- noindent For the second example, table FOO must have at least as many rows
- as the current table. Note that this is inefficient
- subsubheading Named references
- cindex references, named
- cindex constants, in calculations
- vindex org-table-formula-constants
- code{org-table-formula-constants}, and locally (for the file) through a
- line like
- end example
- vindex constants-unit-system
- pxref{Properties and Columns}) can be used as
- constants in table formulas: for a property
- samp{$PROP_Xyz}, and the property will be searched in the current
- outline entry and in the hierarchy above it. If you have the
- samp{$h} for Planck's constant, and
- units like footnote{
- code{SI}
- and
- code{constants-unit-system}. You can use the
- code{constSI} and
- ref{Advanced features}. All
- names must start with a letter, and further consist of letters and
- numbers.
- cindex remote references
- cindex references, to a different table
- cindex constants, in calculations
- example
- remote(NAME-OR-ID,REF)
- noindent
- where NAME can be the name of a table in the current file as set by a
- code{3$3} or
- node Formula syntax for Calc, Formula syntax for Lisp, References, The spreadsheet
- cindex formula syntax, Calc
- file{Calc} package. file{calc} has the
- non-standard convention that
- samp{*}, so that samp{a/(b*c)}.} Before
- evaluation by pxref{Calling Calc from
- Your Programs,calc-eval,Calling Calc from Your Lisp Programs,Calc,GNU
- Emacs Calc Manual}),
- cindex vectors, in table calculations
- The range vectors can be directly fed into the Calc vector functions
- like samp{vsum}.
- cindex mode, for
- vindex org-calc-default-modes
- A formula can contain an optional mode string after a semicolon. This
- string consists of flags to influence Calc and other modes during
- execution. By default, Org uses the standard Calc modes (precision
- 12, angular units degrees, fraction and symbolic modes off). The display
- format, however, has been changed to
- code{org-calc-default-modes}.
- r{set the internal Calc calculation precision to 20 digits}
- n3 s3 e2 f4
- r{format of the result of Calc passed back to Org.}
-
- r{long as the Calc calculation precision is greater.}
- D R
- r{fraction and symbolic modes}
- N
- r{keep empty fields in ranges}
- L
- end example
- code{printf} format specifier to reformat the Calc result after it has been
- passed back to Org instead of letting Calc already do the
- formattingcode{printf} reformatting is limited in precision
- because the value passed to it is converted into an
- code{double}. The
- code{double} is limited in precision to 64
- bits overall which leaves approximately 16 significant decimal digits.}.
- A few examples:
- r{Sum of first and second field}
- $1+$2;%.2f
- r{Math functions can be used}
- $0;%.1f
- r{Degrees F -> C conversion}
- $c/$1/$cm file{constants.el}}
- tan($1);Dp3s1
- r{Same, but use printf specifier for display}
- vmean($2..$7)
- r{Same, but treat empty fields as 0}
- taylor($3,x=7,2)
- end example
- Calc also contains a complete set of logical operations. For example
- r{"teen" if age $1 less than 20, else empty}
- code{T} and
- ref{Durations and time values}.
- subsection Emacs Lisp forms as formulas
- file{calc} formulas, you
- can specify modes and a printf format after a semicolon. With Emacs Lisp
- forms, you need to be conscious about the way field references are
- interpolated into the form. By default, a reference will be interpolated as
- a Lisp string (in double-quotes) containing the field. If you provide the
- samp{L} flag, all fields will be interpolated literally,
- without quotes. I.e., if you want a reference to be interpreted as a string
- by the Lisp form, enclose the reference operator itself in double-quotes,
- like
- samp{N} mode is used when we do computations in Lisp:
- r{Swap the first two characters of the content of column 1}
- '(concat (substring $1 1 2) (substring $1 0 1) (substring $1 2))
- code{$1+$2}}
- '(+ $1 $2);N
- code{vsum($1..$4)}}
- '(apply '+ '($1..$4));N
- node Durations and time values, Field and range formulas, Formula syntax for Lisp, The spreadsheet
- cindex Duration, computing
- vindex org-table-duration-custom-format
- If you want to compute time values use the
- example
- end group
- code{[HH:MM[:SS]}, where seconds
- are optional. With the
- code{[HH:MM:SS} (see the first formula above). With the
- code{org-table-duration-custom-format}, which defaults to
- node Field and range formulas, Column formulas, Durations and time values, The spreadsheet
- cindex field formula
- cindex formula, for individual table field
- samp{:=}, for example
- key{TAB} or kbd{C-c C-c} with the cursor still in the field,
- the formula will be stored as the formula for this field, evaluated, and the
- current field will be replaced with the result.
- samp{#+TBLFM:} directly
- below the table. If you type the equation in the 4th field of the 3rd data
- line in the table, the formula will look like
- i{absolute references} (but not relative ones) in stored formulas are
- modified in order to still reference the same field. To avoid this from
- happening, in particular in range references, anchor ranges at the table
- borders (using code{>}, code{$>}), or at hlines
- using the
- table
- orgcmd{C-u C-c =,org-table-eval-formula}
- Install a new formula for the current field. The command prompts for a
- formula with default taken from the
- end table
- The left-hand side of a formula can also be a special expression in order to
- assign the formula to a number of different fields. There is no keyboard
- shortcut to enter such range formulas. To add them, use the formula editor
- (code{#+TBLFM:} line
- directly.
- code
- ref{Column formulas}.
- code{>=} means
- the last row.
- item $name=
- Named field, see
- end table
- subsection Column formulas
- cindex formula, for table column
- When you assign a formula to a simple column reference like
- emph{header} and will not be modified by column formulas. (ii) Fields that
- already get a value from a field/range formula will be left alone by column
- formulas. These conditions make column formulas very easy to use.
- To assign a formula to a column, type it directly into any field in the
- column, preceded by an equal sign, like
- key{TAB} or kbd{C-c C-c} with the cursor still in the field,
- the formula will be stored as the formula for the current column, evaluated
- and the current field replaced with the result. If the field contains only
- samp{#+TBLFM:} line, column formulas will look like
- code{$>}.
- Instead of typing an equation into the field, you may also use the
- following command:
- kbd
- samp{#+TBLFM} line, applies it to the current field and
- stores it. With a numeric prefix argument(e.g.kbd{C-5 C-c =}) the command
- will apply it to that many consecutive fields in the current column.
- node Editing and debugging formulas, Updating the table, Column formulas, The spreadsheet
- cindex formula editing
- vindex org-table-use-standard-references
- You can edit individual formulas in the minibuffer or directly in the
- field. Org can also prepare a special buffer with all active
- formulas of a table. When offering a formula for editing, Org
- converts references to the standard format (like code{D&})
- if possible. If you prefer to only work with the internal format (like
- code{$4}), configure the variable
- table
- orgcmdkkc{C-c =,C-u C-c =,org-table-eval-formula}
- Edit the formula associated with the current column/field in the
- minibuffer. See ref{Field and range formulas}.
- kbd{C-c ?}.
- kindex C-c
- findex org-table-toggle-coordinate-overlays
- }
- Toggle the display of row and column numbers for a table, using overlays
- (
- kbd{C-c C-c}.
- {
- item C-c
- command{org-table-toggle-formula-debugger}). See below.
- table
- orgcmdkkc{C-c C-c,C-x C-s,org-table-fedit-finish}
- Exit the formula editor and store the modified formulas. With
- orgcmd{C-c C-q,org-table-fedit-abort}
- Exit the formula editor without installing changes.
- code{B3}) and internal (like
- orgcmd{
- key{TAB} collapses the formula back again. In the open
- formula,
- orgcmd{M-
- kindex S-
- kindex S-
- kindex S-
- kindex S-
- findex org-table-fedit-ref-up
- findex org-table-fedit-ref-left
- item S-key{down}/key{right}
- Shift the reference at point. For example, if the reference is
- kbd{S-code{C3}.
- This also works for relative references and for hline references.
- key{up},M-S-
- orgcmdkkcc{M-key{down},org-table-fedit-scroll-down,org-table-fedit-scroll-up}
- Scroll the window displaying the table.
- }
- item C-c
- end table
- samp{#+TBLFM}
- line)---during the next recalculation the field will be filled again.
- To remove a formula from a field, you have to give an empty reply when
- prompted for the formula, or to edit the
- kindex C-c C-c
- You may edit the
- kbd{C-c C-c} in that line or with the normal
- recalculation commands in the table.
- cindex formula debugging
- samp{#ERROR}. If you would like see what is going
- on during variable substitution and calculation in order to find a bug,
- turn on formula debugging in the
- kbd{C-u C-u C-c =
- node Updating the table, Advanced features, Editing and debugging formulas, The spreadsheet
- cindex recomputing table fields
- ref{Advanced features}, for a way to make
- recalculation at least semi-automatic.
- In order to recalculate a line of a table or the entire table, use the
- following commands:
- kbd
- c
- item C-u C-c *
- itemx C-u C-c C-c
- Recompute the entire table, line by line. Any lines before the first
- hline are left alone, assuming that these are part of the table header.
- orgcmdkkc{C-u C-u C-c *,C-u C-u C-c C-c,org-table-iterate}
- Iterate the table by recomputing it until no further changes occur.
- This may be necessary if some computed fields use the value of other
- fields that are computed
- item M-x org-table-recalculate-buffer-tables
- item M-x org-table-iterate-buffer-tables
- end table
- subsection Advanced features
- If you want the recalculation of fields to happen automatically, or if you
- want to be able to assign footnote{Such names must start by an
- alphabetic character and use only alphanumeric/underscore characters.} to
- fields and columns, you need to reserve the first column of the table for
- special marking characters.
- kbd
- samp{ },
- samp{*}, samp{$}. When there is an active region,
- change all marks in the region.
- example
- end group
- noindent
- kbd{C-u C-c *} will only affect rows that
- are marked samp{*}, and fields that have a formula assigned
- to the field itself. The column formulas are not applied in rows with
- empty first field.
- table
- item !
- The fields in this line define names for the columns, so that you may
- refer to a column as samp{$6}.
- emph{above} the row. With such
- a definition, any formula in the table may use
- samp{10}. Also, if you assign a formula to a names field, it
- will be stored as
- item _
- Similar to
- emph{below}.
- emph{parameters} for formulas. For
- example, if a field in a samp{max=50}, then
- formulas in this table can refer to the value 50 using
- item #
- Fields in this row are automatically recalculated when pressing
- key{RET} or key{TAB}} in this row. Also, this row
- is selected for a global recalculation with
- item *
- Selects this line for global recalculation with
- item
- Unmarked lines are exempt from recalculation with
- samp{#}
- or
- item /
- Do not export this line. Useful for lines that contain the narrowing
- end table
- Finally, just to whet your appetite for what can be done with the
- fantastic
- code{n} at location
- example
- end group
- node Org-Plot, , The spreadsheet, Tables
- cindex graph, in tables
- cindex #+PLOT
- Org-Plot can produce 2D and 3D graphs of information stored in org tables
- using uref{http://www.gnuplot.info/} and
- uref{http://cars9.uchicago.edu/~ravel/software/gnuplot-mode.html}. To see
- this in action, ensure that you have both Gnuplot and Gnuplot mode installed
- on your system, then call
- example
- end group
- code{#+PLOT:} lines preceding a table. See below
- for a complete list of Org-plot options. For more information and examples
- see the Org-plot tutorial at
- subsubheading Plot Options
- code
- command{gnuplot} option to be set when graphing.
- item ind
- Specify which column of the table to use as the
- item deps
- Specify the columns to graph as a Lisp style list, surrounded by parentheses
- and separated by spaces for example
- code{ind}
- column).
- code{2d}, code{grid}.
- code{with} option to be inserted for every col being plotted
- (e.g.code{lines}, code{boxes},
- code{lines}.
- code{"@var{path/to/desired/output-file}"}.
- code{deps} (defaults to the column headers
- if they exist).
- item map
- When plotting code{grid} types, set this to
- code{3d} slope.
- samp{%Y-%m-%d-%H:%M:%S}.
- code{$datafile} in the specified script will be replaced with
- the path to the generated data file. Note: even if you set this option, you
- may still want to specify the plot type, as that can impact the content of
- the data file.
- node Hyperlinks, TODO Items, Tables, Top
- cindex hyperlinks
- Like HTML, Org provides links inside a file, external links to
- other files, Usenet articles, emails, and much more.
- end menu
- section Link format
- cindex format, of links
- Org will recognize plain URL-like links and activate them as
- clickable links. The general link format, however, looks like this:
- r{or alternatively} [[link]]
- noindent
- Once a link in the buffer is complete (all brackets present), Org
- will change the display so that
- samp{[[link][description]]} and
- samp{[[link]]}. Links will be highlighted in the face
- samp{link}
- part (if there is no description) or the
- samp{link} part, use
- key{BACKSPACE}, you will remove the
- (invisible) bracket at that location. This makes the link incomplete
- and the internals are again displayed as plain text. Inserting the
- missing bracket hides the link internals again. To show the
- internal structure of all links, use the menu entry
- node Internal links, External links, Link format, Hyperlinks
- cindex internal links
- cindex targets, for links
- samp{[[#my-custom-id]]} which will link to the entry with the
- samp{my-custom-id}. Such custom IDs are very good
- for HTML export (
- samp{[[My Target]]} or
- kbd{C-c C-o} when the cursor is on the link,
- or with a mouse click (
- i{dedicated target}: the same string in double angular brackets. Targets
- may be located anywhere; sometimes it is convenient to put them into a
- comment line. For example
- end example
- pxref{HTML export}), such targets will become
- named anchors for direct access through footnote{Note that
- text before the first headline is usually not exported, so the first such
- target should be after the first headline, or in the line directly before the
- first headline.}.
- If no dedicated target exists, Org will search for a headline that is exactly
- the link text but may also include a TODO keyword and tags
- kbd{M-
- samp{my target}.
- Following a link pushes a mark onto Org's own mark ring. You can
- return to the previous position with
- menu
- * Radio targets:: Make targets trigger links in plain text
- node Radio targets, , Internal links, Internal links
- cindex radio targets
- cindex links, radio targets
- Org can automatically turn any occurrences of certain target names
- in normal text into a link. So without explicitly creating a link, the
- text connects to the target radioing its position. Radio targets are
- enclosed by triple angular brackets. For example, a target
- samp{my target} in normal text to
- become activated as a link. The Org file is scanned automatically
- for radio targets only when the file is first loaded into Emacs. To
- update the target list during editing, press
- node External links, Handling links, Internal links, Hyperlinks
- cindex links, external
- cindex links, external
- cindex BBDB links
- cindex URL links
- cindex VM links
- cindex WANDERLUST links
- cindex USENET links
- cindex Info links
- example
- http://www.astro.uva.nl/~dominik
- r{DOI for an electronic resource}
- file:/home/dominik/images/jupiter.jpg
- r{same as above}
- file:papers/last.pdf
- r{same as above}
- file:/myselfsome.where:papers/last.pdf
- r{same as above}
- file:sometextfile::NNN
- r{another Org file}
- file:projects.org::some words footnote{
- The actual behavior of the search will depend on the value of
- the variable
- code{'query-to-create},
- then an exact headline will be searched; if it is not found, then the user
- will be queried to create it.}
- file:projects.org::*task title
- r{open via OS, like double-click}
- file+emacs:/path/to/file
- r{open in doc-view mode at page}
- id:B7423F4D-2E8A-471B-8810-C40F074717E9
- r{Usenet link}
- mailto:adentgalaxy.net
- r{VM folder link}
- vm:folder#id
- r{VM on remote machine}
- wl:folder
- r{WANDERLUST message link}
- mhe:folder
- r{MH-E message link}
- rmail:folder
- r{RMAIL message link}
- gnus:group
- r{Gnus article link}
- bbdb:R.*Stallman
- r{IRC link}
- info:org#External links
- r{A shell command}
- elisp:org-agenda
- r{Elisp form to evaluate}
- ref{Adding hyperlink types}.
- A link should be enclosed in double brackets and may contain a
- descriptive text to be displayed instead of the URL (
- example
- [[http://www.gnu.org/software/emacs/][GNU Emacs]]
- noindent
- If the description is a file name or URL that points to an image, HTML
- export (
- cindex square brackets, around links
- samp{bbdb:Richard Stallman}), or if you need to remove ambiguities
- about the end of the link, enclose them in square brackets.
- section Handling links
- table
- orgcmd{C-c l,org-store-link}
- emph{global} command (you
- must create the key binding yourself) which can be used in any buffer to
- create a link. The link will be stored for later insertion into an Org
- buffer (see below). What kind of link will be created depends on the current
- buffer:
- *
- For Org files, if there is a
- footnote{If the headline contains a timestamp, it will be
- removed from the link and result in a wrong link -- you should avoid putting
- timestamp in the headline.}.
- cindex property, CUSTOM_ID
- code{CUSTOM_ID} property, a link to this custom ID
- will be stored. In addition or alternatively (depending on the value of
- code{ID} property will be
- created and/or used to construct a link. So using this command in Org
- buffers will potentially create two links: a human-readable from the custom
- ID, and one that is globally unique and works even if the entry is moved from
- file to file. Later, when inserting the link, you need to decide which one
- to use.
- *
- Pretty much all Emacs mail clients are supported. The link will point to the
- current article, or, in some GNUS buffers, to the group. The description is
- constructed from the author and the subject.
- *
- Here the link will be the current URL, with the page title as description.
- *
- Links created in a BBDB buffer will point to the current entry.
- *
- code{org-irc-link-to-logs} to
- samp{file:/} style link to the relevant point in the logs for
- the current conversation is created. Otherwise an
- b{Other files}
- pxref{Search options}) pointing to the contents of the current line. If
- there is an active region, the selected words will form the basis of the
- search string. If the automatically created link is not working correctly or
- accurately enough, you can write custom functions to select the search string
- and to do the search for particular file types---see
- kbd{C-c l} is only a suggestion---see
- b{Agenda view}
- c
- cindex link completion
- cindex inserting links
- footnote{ Note that you don't have to use this command to
- insert a link. Links in Org are plain text, and you can type or paste them
- straight into the buffer. By using this command, the links are automatically
- enclosed in double brackets, and you will be asked for the optional
- descriptive text.}. This prompts for a link to be inserted into the buffer.
- You can just type a link, using text for an internal link, or one of the link
- type prefixes mentioned in the examples above. The link will be inserted
- into the buffer
- kbd{C-u} prefix argument to
- code{org-keep-stored-link-after-insertion}.}, along with a descriptive text.
- If some text was selected when this command is called, the selected text
- becomes the default description.
- *
- All links stored during the
- current session are part of the history for this prompt, so you can access
- them with key{down} (or
- b{Completion support}key{TAB} will help you to insert
- valid link prefixes like samp{ftp:}, including the prefixes
- defined through link abbreviations (
- key{RET} after inserting only the
- footnote{This works by
- calling a special function
- kbd{file
- kbd{C-u C-c C-l}, see below) will be offered, and after
- key{RET}} you can complete contact names.
- cindex file name completion
- kbd{C-c C-l} is called with a
- samp{../}. Otherwise an absolute path
- is used, if possible with
- kbd{C-u} prefixes.
- item C-c C-l r{(with cursor on existing link)}
- When the cursor is on an existing link,
- c
- orgcmd{C-c C-o,org-open-at-point}
- vindex org-link-frame-setup
- Open link at point. This will launch a web browser for URLs (using
- samp{file:} links
- with Emacs and select a suitable application for local non-text files.
- Classification of files is based on file extension only. See option
- kbd{C-u} prefix. If you want to avoid
- opening in Emacs, use a *
- If the cursor is on a headline, but not on a link, offer all links in the
- headline and entry text. If you want to setup the frame configuration for
- following links, customize
- orgkey
- vindex org-return-follows-link
- When kbd{
- c
- kindex mouse-1
- itemx mouse-1
- On links, kbd{C-c C-o}
- would. Under Emacs 22 and later,
- c
- item mouse-3
- kbd{mouse-2}, but force file links to be opened with Emacs, and
- internal links to be displayed in another window
- code{org-display-internal-link-with-indirect-buffer}}.
- orgcmd{C-c C-x C-v,org-toggle-inline-images}
- cindex images, inlining
- cindex
- cindex
- : images that will also
- be inlined during export. When called with a prefix argument, also display
- images that do have a link description. You can ask for inline images to be
- displayed at startup by configuring the variable
- footnote{with corresponding
- code{inlineimages} and
- orgcmd{C-c %,org-mark-ring-push}
- c
- cindex links, returning to
- Jump back to a recorded position. A position is recorded by the
- commands following internal links, and by
- c
- cindex links, finding next/previous
- Move forward/backward to the next link in the buffer. At the limit of
- the buffer, the search fails once, and then wraps around. The key
- bindings for this are really too long; you might want to bind this also
- to kbd{C-p}
- end lisp
- node Using links outside Org, Link abbreviations, Handling links, Hyperlinks
- lisp
- (global-set-key "\C-c L" 'org-insert-link-global)
- (global-set-key "\C-c o" 'org-open-at-point-global)
- node Link abbreviations, Search options, Using links outside Org, Hyperlinks
- cindex link abbreviations
- example
- [[linkword:tag][description]]
- noindent
- i{linkword} must be a word, starting with a letter, followed by
- letters, numbers, samp{_}. Abbreviations are resolved
- according to the information in the variable
- smalllisp
- end group
- samp{%s}, it will be
- replaced with the tag. Otherwise the tag will be appended to the string
- in order to create the link. You may also specify a function that will
- be called with the tag as the only argument to create the link.
- With the above setting, you could link to a specific bug with
- samp{OrgMode} with
- code{[[gmap:51 Franklin Street, Boston]]} or of Carsten office
- code{[[ads:Dominik,C]]}.
- If you need special abbreviations just for a single Org buffer, you
- can define them in the file with
- example
- #+LINK: bugzilla http://10.1.2.9/bugzilla/show_bug.cgi?id=
- #+LINK: google http://www.google.com/search?q=%s
- noindent
- In-buffer completion (samp{[} to
- complete link abbreviations. You may also define a function
- : completion)
- support for inserting such a link with
- node Search options, Custom searches, Link abbreviations, Hyperlinks
- cindex search option in file links
- footnote{For backward
- compatibility, line numbers can also follow a single colon.} colon. For
- example, when the command pxref{Handling
- links}) to a file, it encodes the words in the current line as a search
- string that can be used to find this line back later when following the
- link with
- example
- [[file:~/code/main.c::255]]
- [[file:~/xx.org::My Target]]
- [[file:~/xx.org::*My Target]]
- [[file:~/xx.org::#my-custom-id]]
- [[file:~/xx.org::/regexp/]]
- table
- item 255
- Jump to line 255.
- samp{<<My Target>>}, or do a text search for
- ref{Internal links}. In HTML export (
- item *My Target
- In an Org file, restrict search to headlines.
- code{CUSTOM_ID} property
- code{regexp}. This uses the Emacs
- command
- code{org-occur} is used to create a
- sparse tree with the matches.
- c
- end table
- As a degenerate case, a file link with an empty file name can be used
- to search the current file. For example,
- samp{find me} in the current file, just as
- node Custom searches, , Search options, Hyperlinks
- cindex custom search strings
- TeX{} database files have many entries like
- TeX{} entry is the
- citation key.
- vindex org-execute-file-search-functions
- If you come across such a problem, you can write custom functions to set
- the right search string for a particular file type, and to do the search
- for the string in the file. Using
- code{org-create-file-search-functions} and
- TeX{} database files, and you can use the corresponding code as
- an implementation example. See the file
- node TODO Items, Tags, Hyperlinks, Top
- cindex TODO items
- Org mode does not maintain TODO lists as separate documents
- menu
- * TODO basics:: Marking and displaying TODO entries
- * TODO extensions:: Workflow and assignments
- * Progress logging:: Dates and notes for progress
- * Priorities:: Some things are more important than others
- * Breaking down tasks:: Splitting a task into manageable pieces
- * Checkboxes:: Tick-off lists
- node TODO basics, TODO extensions, TODO Items, TODO Items
- samp{TODO}, for example:
- end example
- table
- orgcmd{C-c C-t,org-todo}
- example
- ,-> (unmarked) -> TODO -> DONE --.
- '--------------------------------'
- kbd{t} command key (
- orgkey{C-u C-c C-t}
- Select a specific keyword using completion or (if it has been set up)
- the fast selection interface. For the latter, you need to assign keys
- to TODO states, see ref{Setting tags}, for
- more information.
- key{right}
- key{left}
- key{right} r{/} key{left}
- pxref{TODO
- extensions}). See also
- code{shift-selection-mode}. See also the variable
- orgcmd{C-c / t,org-show-todo-key}
- vindex org-todo-keywords
- View TODO items in a pxref{Sparse trees}). Folds the
- entire buffer, but shows all TODO items (with not-DONE state) and the
- headings hierarchy above them. With a prefix argument (or by using
- code{KWD1|KWD2|...} to list
- entries that match any one of these keywords. With a numeric prefix argument
- N, show the tree for the Nth keyword in the variable
- orgcmd{C-c a t,org-todo-list}
- Show the global TODO list. Collects the TODO items (with not-DONE states)
- from all agenda files (
- code{agenda-mode}, which provides commands to examine and
- manipulate the TODO entries from the new buffer (
- xref{Global TODO list}, for more information.
- key{RET},org-insert-todo-heading}
- Insert a new TODO entry below the current one.
- noindent
- code{org-todo-state-tags-triggers} for details.
- section Extended use of TODO keywords
- vindex org-todo-keywords
- By default, marked TODO entries have one of only two states: TODO and
- DONE. Org mode allows you to classify TODO items in more complex ways
- with code{org-todo-keywords}). With
- special setup, the TODO keyword system can work differently in different
- files.
- Note that
- pxref{Tags}).
- end menu
- subsection TODO keywords as workflow states
- cindex workflow states as TODO keywords
- You can use TODO keywords to indicate different
- footnote{Changing
- this variable only becomes effective after restarting Org mode in a
- buffer.}:
- end lisp
- The vertical bar separates the TODO keywords (states that
- emph{no further action}). If
- you don't provide the separator bar, the last state is used as the DONE
- state.
- kbd{C-c C-t} will cycle an entry from TODO
- to FEEDBACK, then to VERIFY, and finally to DONE and DELEGATED. You may
- also use a numeric prefix argument to quickly select a specific state. For
- example
- kbd{S-
- pxref{Completion}) or even a special one-key selection scheme
- (
- ref{Tracking TODO state changes}, for more information.
- subsection TODO keywords as types
- cindex names as TODO keywords
- emph{types} of action items. For example, you might want to indicate
- that items are for ``work'' or ``home''. Or, when you work with several
- people on a single project, you might want to assign action items
- directly to persons, by using their names as TODO keywords. This would
- be set up like this:
- end lisp
- In this case, different keywords do not indicate a sequence, but rather
- different types. So the normal work flow would be to assign a task to a
- person, and later to mark it DONE. Org mode supports this style by adapting
- the workings of the command footnote{This is also true for the
- kbd{C-c C-t} again, it will switch from any name directly
- to DONE. Use prefix arguments or completion to quickly select a specific
- name. You can also review the items of a specific TODO type in a sparse tree
- by using a numeric prefix to
- kbd{C-3 C-c / t}. To collect Lucy's items
- from all agenda files into a single buffer, you would use the numeric prefix
- argument as well when creating the global TODO list:
- node Multiple sets in one file, Fast access to TODO states, TODO types, TODO extensions
- cindex TODO keyword sets
- Sometimes you may want to use different sets of TODO keywords in
- parallel. For example, you may want to have the basic
- code{DONE}, but also a workflow for bug fixing, and a
- separate state indicating that an item has been canceled (so it is not
- DONE, but also does not require action). Your setup would then look
- like this:
- end lisp
- The keywords should all be different, this helps Org mode to keep track
- of which subsequence should be used for a given entry. In this setup,
- code{DONE} to (nothing) to code{FIXED} to
- (nothing) to
- table
- kindex C-S-
- kindex C-S-
- kindex C-u C-u C-c C-t
- itemx C-S-
- itemx C-S-
- kbd{C-u C-u C-c C-t} or key{right}} would jump from
- code{DONE} to
- code{CANCELED}. Note that the
- code{shift-selection-mode} (
- kindex S-
- kindex S-
- item S-
- itemx S-
- kbd{S-kbd{S-emph{all}
- keywords from all sets, so for example key{<right>}} would switch
- from code{REPORT} in the example above. See also
- code{shift-selection-mode}.
- node Fast access to TODO states, Per-file keywords, Multiple sets in one file, TODO extensions
- lisp
- (setq org-todo-keywords
- '((sequence "TODO(t)" "|" "DONE(d)")
- (sequence "REPORT(r)" "BUG(b)" "KNOWNCAUSE(k)" "|" "FIXED(f)")
- (sequence "|" "CANCELED(c)")))
- vindex org-fast-tag-selection-include-todo
- If you then press
- kbd{SPC} can be used to remove any TODO
- keyword from an entry.
- code{org-fast-tag-selection-include-todo}, it allows you to change the TODO
- state through the tags interface (
- node Per-file keywords, Faces for TODO keywords, Fast access to TODO states, TODO extensions
- cindex keyword options
- cindex #+TODO
- cindex #+SEQ_TODO
- It can be very useful to use different aspects of the TODO mechanism in
- different files. For file-local settings, you need to add special lines
- to the file which set the keywords and interpretation for that file
- only. For example, to set one of the two examples discussed above, you
- need one of the following lines, starting in column zero anywhere in the
- file:
- end example
- code{#+SEQ_TODO} to be explicit about the
- interpretation, but it means the same as
- example
- #+TYP_TODO: Fred Sara Lucy Mike | DONE
- example
- #+TODO: TODO | DONE
- #+TODO: REPORT BUG KNOWNCAUSE | FIXED
- #+TODO: | CANCELED
- cindex completion, of option keywords
- key{TAB}
- samp{#+} into the buffer and then use key{TAB}} completion.
- kbd{C-c C-c} with the cursor still in the line to make the changes
- known to Org mode
- kbd{C-c C-c} with the
- cursor in a line starting with
- node Faces for TODO keywords, TODO dependencies, Per-file keywords, TODO extensions
- cindex faces, for TODO keywords
- r{(face)}
- r{(face)}
- code{org-todo}
- for keywords indicating that an item still has to be acted upon, and
- code{org-todo-keyword-faces}. For example:
- group
- (setq org-todo-keyword-faces
- '(("TODO" . org-warning) ("STARTED" . "yellow")
- ("CANCELED" . (:foreground "blue" :weight bold))))
- end lisp
- While using a list with face properties as shown for CANCELED
- code{org-faces-easy-properties} determines if that color is interpreted as a
- foreground or a background color.
- subsection TODO dependencies
- cindex dependencies, of TODO states
- cindex property, ORDERED
- The structure of Org files (hierarchy and lists) makes it easy to define TODO
- dependencies. Usually, a parent TODO task should not be marked DONE until
- all subtasks (defined as children tasks) are marked as DONE. And sometimes
- there is a logical sequence to a number of (sub)tasks, so that one task
- cannot be acted upon before all siblings above it are done. If you customize
- the variable
- code{ORDERED}, each of its children
- will be blocked until all earlier siblings are marked DONE. Here is an
- example:
- end example
- kbd
- vindex org-track-ordered-property-with-tag
- code{ORDERED} property of the current entry. A property is used
- for this behavior because this should be local to the current entry, not
- inherited like a tag. However, if you would like to
- code{org-track-ordered-property-with-tag}.
- end table
- code{org-agenda-dim-blocked-tasks}, TODO entries
- that cannot be closed because of such dependencies will be shown in a dimmed
- font or even made invisible in agenda views (
- cindex checkboxes and TODO dependencies
- pxref{Checkboxes}). If you set the variable
- file{org-depend.el}.
- node Progress logging, Priorities, TODO extensions, TODO Items
- cindex progress logging
- ref{Clocking
- work time}.
- end menu
- subsection Closing items
- The most basic logging is to keep track of
- footnote{The corresponding
- in-buffer setting is:
- lisp
- (setq org-log-done 'time)
- noindent
- Then each time you turn an entry from a TODO (not-done) state into any
- of the DONE states, a line
- footnote{The
- corresponding in-buffer setting is:
- lisp
- (setq org-log-done 'note)
- noindent
- You will then be prompted for a note, and that note will be stored below
- the entry with a
- pxref{Timeline}) and in the agenda
- (kbd{l} key to
- display the TODO items with a
- node Tracking TODO state changes, Tracking your habits, Closing items, Progress logging
- cindex drawer, for state change recording
- vindex org-log-into-drawer
- pxref{Workflow states}), you
- might want to keep track of when a state change occurred and maybe take a
- note about this change. You can either record just a timestamp, or a
- time-stamped note for a change. These records will be inserted after the
- headline as an itemized list, newest first
- code{org-log-states-order-reversed}}. When taking a lot of notes, you might
- want to get the notes out of the way into a drawer (
- code{org-log-into-drawer} to get this
- behavior---the recommended drawer for this is called
- code{LOG_INTO_DRAWER} property.
- Since it is normally too much to record a note for every state, Org mode
- expects configuration on a per-keyword basis for this. This is achieved by
- adding special markers samp{} (for a note
- with timestamp) in parentheses after each keyword. For example, with the
- setting
- end lisp
- To record a timestamp without a note for TODO keywords configured with
- kbd{C-c C-c} to enter a blank note when prompted.
- vindex org-log-done
- you not only define global TODO keywords and fast access keys, but also
- request that a time is recorded when the entry is set to
- DONE
- code{org-log-done} and state change logging.
- However, it will never prompt for two notes---if you have configured
- both, the state change recording note will take precedence and cancel
- the
- samp{!} after the slash means that in addition to the note taken when
- entering the state, a timestamp should be recorded when
- i{target} state does not configure
- logging for entering it. So it has no effect when switching from WAIT
- to DONE, because DONE is configured to record a timestamp only. But
- when switching from WAIT back to TODO, the
- example
- #+TODO: TODO(t) WAIT(w/!) | DONE(d!) CANCELED(c)
- cindex property, LOGGING
- In order to define logging settings that are local to a subtree or a
- single item, define a LOGGING property in this entry. Any non-empty
- LOGGING property resets all logging settings to nil. You may then turn
- on logging for this specific tree using STARTUP keywords like
- code{logrepeat}, as well as adding state specific
- settings like
- example
- * TODO Log each state with only a time
- :PROPERTIES:
- :LOGGING: TODO(!) WAIT(!) DONE(!) CANCELED(!)
- :END:
- * TODO Only log when switching to WAIT, and when repeating
- :PROPERTIES:
- :LOGGING: WAIT() logrepeat
- :END:
- * TODO No logging at all
- :PROPERTIES:
- :LOGGING: nil
- :END:
- node Tracking your habits, , Tracking TODO state changes, Progress logging
- cindex habits
- Org has the ability to track the consistency of a special category of TODOs,
- called ``habits''. A habit has the following properties:
- item
- You have enabled the
- code{org-modules}.
- item
- The property code{habit}.
- code{.+} style repeat
- interval. A
- code{+} style for an
- unusual habit that can have a backlog, e.g., weekly reports.
- samp{.+2d/3d}, which says that you want to do the task at least every
- three days, but at most every two days.
- code{DONE} state enabled, in order
- for historical data to be represented in the consistency graph. If it is not
- enabled it is not an error, but the consistency graphs will be largely
- meaningless.
- example
- ** TODO Shave
- SCHEDULED: <2009-10-17 Sat .+2d/4d>
- - State "DONE" from "TODO" [2009-10-15 Thu]
- - State "DONE" from "TODO" [2009-10-12 Mon]
- - State "DONE" from "TODO" [2009-10-10 Sat]
- - State "DONE" from "TODO" [2009-10-04 Sun]
- - State "DONE" from "TODO" [2009-10-02 Fri]
- - State "DONE" from "TODO" [2009-09-29 Tue]
- - State "DONE" from "TODO" [2009-09-25 Fri]
- - State "DONE" from "TODO" [2009-09-19 Sat]
- - State "DONE" from "TODO" [2009-09-16 Wed]
- - State "DONE" from "TODO" [2009-09-12 Sat]
- :PROPERTIES:
- :STYLE: habit
- :LAST_REPEAT: [2009-10-19 Mon 00:36]
- :END:
- code{SCHEDULED} date and repeat interval) and at least every 4 days. If
- today is the 15th, then the habit first appears in the agenda on Oct 17,
- after the minimum of 2 days has elapsed, and will appear overdue on Oct 19,
- after four days have elapsed.
- What's really useful about habits is that they are displayed along with a
- consistency graph, to show how consistent you've been at getting that task
- done in the past. This graph shows every day that the task was done over the
- past three weeks, with colors for each day. The colors used are:
- code
- item Green
- If the task could have been done on that day.
- item Red
- If the task was overdue on that day.
- table
- item org-habit-graph-column
- The buffer column at which the consistency graph should be drawn. This will
- overwrite any text in that column, so it is a good idea to keep your habits'
- titles brief and to the point.
- item org-habit-following-days
- The number of days after today that will appear in consistency graphs.
- end table
- Lastly, pressing
- kbd{K} again to
- bring them back. They are also subject to tag filtering, if you have habits
- which should only be done in certain contexts, for example.
- section Priorities
- emph{priority cookie} into the headline of a TODO item, like this
- end example
- vindex org-priority-faces
- By default, Org mode supports three priorities: samp{B}, and
- samp{A} is the highest priority. An entry without a cookie is
- treated just like priority
- pxref{Weekly/daily agenda}); outside the agenda, they
- have no inherent meaning to Org mode. The cookies can be highlighted with
- special faces by customizing the variable
- table
- item
- kindex
- findex org-priority
- Set the priority of the current headline (
- samp{A}, samp{C}.
- When you press
- kbd{,} command (
- c
- key{up},S-
- vindex org-priority-start-cycle-with-default
- Increase/decrease priority of current headline
- code{org-priority-start-cycle-with-default}.}. Note that these keys are
- also used to modify timestamps (
- ref{Conflicts}, for a discussion of the interaction with
- end table
- vindex org-lowest-priority
- code{org-highest-priority},
- code{org-default-priority}. For an individual buffer, you may set
- these values (highest, lowest, default) like this (please make sure that
- the highest priority is earlier in the alphabet than the lowest
- priority):
- example
- #+PRIORITIES: A C B
- node Breaking down tasks, Checkboxes, Priorities, TODO Items
- cindex tasks, breaking down
- vindex org-agenda-todo-list-sublevels
- It is often advisable to break down large tasks into smaller, manageable
- subtasks. You can do this by creating an outline tree below a TODO item,
- with detailed subtasks on the tree
- code{org-agenda-todo-list-sublevels}.}. To keep
- the overview over the fraction of subtasks that are already completed, insert
- either samp{[%]} anywhere in the headline. These cookies will
- be updated each time the TODO status of a child changes, or when pressing
- example
- * Organize Party [33%]
- ** TODO Call people [1/2]
- *** TODO Peter
- *** DONE Sarah
- ** TODO Buy food
- ** DONE Talk to neighbor
- cindex property, COOKIE_DATA
- If a heading has both checkboxes and TODO children below it, the meaning of
- the statistics cookie become ambiguous. Set the property
- samp{checkbox} or
- vindex org-hierarchical-todo-statistics
- If you would like to have the statistics cookie count any TODO entries in the
- subtree (not just direct children), configure the variable
- samp{recursive} into the value of the
- example
- * Parent capturing statistics [2/20]
- :PROPERTIES:
- :COOKIE_DATA: todo recursive
- :END:
- example
- (defun org-summary-todo (n-done n-not-done)
- "Switch entry to DONE when all subentries are done, to TODO otherwise."
- (let (org-log-done org-log-states) ; turn off logging
- (org-todo (if (= n-not-done 0) "DONE" "TODO"))))
- (add-hook 'org-after-todo-statistics-hook 'org-summary-todo)
- pxref{Checkboxes}).
- section Checkboxes
- vindex org-list-automatic-rules
- Every item in a plain list
- code{org-list-automatic-rules}
- accordingly.} (
- samp{[ ]}. This feature is similar to TODO items
- (
- kbd{C-c C-c}, or use the mouse (thanks to Piotr Zielinski's
- example
- * TODO Organize party [2/4]
- - [-] call people [1/3]
- - [ ] Peter
- - [X] Sarah
- - [ ] Sam
- - [X] order food
- - [ ] think about what music to play
- - [X] talk to the neighbors
- cindex statistics, for checkboxes
- cindex property, COOKIE_DATA
- samp{[2/4]} and
- footnote{Set the variable
- samp{[/]} or samp{[/]} you get an
- samp{[%]} you get information about
- the percentage of checkboxes checked (in the above example, this would be
- samp{[33%]}, respectively). In a headline, a cookie can
- count either checkboxes below the heading or TODO states of children, and it
- will display whatever was changed last. Set the property
- samp{checkbox} or
- cindex blocking, of checkboxes
- cindex property, ORDERED
- If the current outline node has an
- noindent The following commands work with checkboxes:
- kbd
- footnote{`C-u C-c C-c' on the
- samp{[-]}, which is
- considered to be an intermediate state.
- samp{[-]}, which is considered to be an
- intermediate state.
- minus
- item
- If the cursor is in a headline, toggle checkboxes in the region between
- this headline and the next (so
- item
- If there is no active region, just toggle the checkbox at point.
- orgcmd{M-S-
- pxref{Plain lists}).
- vindex org-track-ordered-property-with-tag
- code{ORDERED} property of the entry, to toggle if checkboxes must
- be checked off in sequence. A property is used for this behavior because
- this should be local to the current entry, not inherited like a tag.
- However, if you would like to
- code{org-track-ordered-property-with-tag}.
- kbd{C-u} prefix, update the entire file. Checkbox statistic cookies are
- updated automatically if you toggle checkboxes with
- kbd{M-S-
- end table
- chapter Tags
- cindex headline tagging
- cindex sparse tree, tag based
- An excellent way to implement labels and contexts for cross-correlating
- information is to assign
- vindex org-tag-faces
- Every headline can contain a list of tags; they occur at the end of the
- headline. Tags are normal words containing letters, numbers,
- samp{}. Tags must be preceded and followed by a single colon, e.g.,
- samp{:work:urgent:}.
- Tags will by default be in bold face with the same color as the headline.
- You may specify special faces for specific tags using the variable
- pxref{Faces for TODO keywords}).
- end menu
- section Tag inheritance
- cindex inheritance, of tags
- i{Tags} make use of the hierarchical structure of outline trees. If a
- heading has a certain tag, all subheadings will inherit the tag as
- well. For example, in the list
- end example
- samp{:work:},
- samp{:notes:}, and
- footnote{As
- with all these in-buffer settings, pressing
- cindex #+FILETAGS
- end example
- vindex org-use-tag-inheritance
- code{org-use-tag-inheritance} and
- vindex org-tags-match-list-sublevels
- When a headline matches during a tags search while tag inheritance is turned
- on, all the sublevels in the same tree will (for a simple match form) match
- as well
- pxref{Property searches}).}. The list
- of matches may then become very long. If you only want to see the first tags
- match in a subtree, configure the variable
- node Setting tags, Tag searches, Tag inheritance, Tags
- cindex setting tags
- kindex M-
- kbd{M-
- table
- orgcmd{C-c C-q,org-set-tags-command}
- vindex org-tags-column
- Enter new tags for the current headline. Org mode will either offer
- completion or a special single-key interface for setting tags, see
- below. After pressing
- code{org-tags-column}. When called with a
- pxref{TODO basics}).
- kbd{C-c C-q}.
- vindex org-tag-alist
- Org supports tag insertion based on a
- code{org-tag-alist}. Finally you can set
- the default tags for a given file with lines like
- example
- #+TAGS: work home tennisclub
- #+TAGS: laptop car pc sailboat
- code{org-tag-alist}, but would like to use a dynamic tag list
- in a specific file, add an empty TAGS option line to that file:
- end example
- code{org-tag-persistent-alist}. You may turn this off on a per-file basis
- by adding a STARTUP option line to that file:
- end example
- By default Org mode uses the standard minibuffer completion facilities for
- entering tags. However, it also implements another, quicker, tag selection
- method called
- code{org-tag-alist} in your
- samp{:home:}. In this case you can set something
- like:
- end lisp
- example
- #+TAGS: work(w) home(h) tennisclub(t) laptop(l) pc(p)
- noindent The tags interface will show the available tags in a splash
- window. If you want to start a new line after a specific tag, insert
- example
- #+TAGS: work(w) home(h) tennisclub(t) \n laptop(l) pc(p)
- noindent or write them in two lines:
- end example
- example
- #+TAGS: } laptop(l) pc(p)
- noindent you indicate that at most one of samp{home},
- and
- noindent Don't forget to press
- noindent
- To set these mutually exclusive groups in the variable
- code{:startgroup} and
- code{:newline} to indicate a line
- break. The previous example would be set globally by the following
- configuration:
- end lisp
- If at least one tag has a selection key then pressing
- footnote{Keys will automatically be assigned to tags which
- have no configured keys.}. In this interface, you can use the following
- keys:
- kbd
- kindex
- item
- kindex
- item
- kindex
- item
- item C-g
- Abort without installing changes.
- kbd{q} is not assigned to a tag, it aborts like
- item !
- Turn off groups of mutually exclusive tags. Use this to (as an
- exception) assign several tags from such a group.
- kbd{C-c} will display the
- selection window.
- noindent
- This method lets you assign tags to a headline with very few keys. With
- the above setup, you could clear the current tags and set
- samp{laptop} and kbd{C-c
- C-c key{RET}}. Switching from
- samp{work} would be done with key{RET}} or
- alternatively with
- samp{Sarah} could be done with key{TAB} S a r a h
- key{RET}}.
- code{org-fast-tag-selection-single-key}. Then you no longer have to
- press
- kbd{C-c} to turn off auto-exit for the current tag selection process
- (in effect: start selection with kbd{C-c
- C-c}). If you set the variable to the value
- kbd{C-c}.
- section Tag searches
- cindex searching for tags
- Once a system of tags has been set up, it can be used to collect related
- information into special lists.
- kbd
- kbd{C-u} prefix argument, ignore headlines that are not a TODO line.
- xref{Matching tags and properties}.
- vindex org-tags-match-list-sublevels
- Create a global list of tag matches from all agenda files, but check
- only TODO items and force checking subitems (see variable
- end table
- These commands all prompt for a match string which allows basic Boolean logic
- like samp{boss} and
- samp{project1}, or
- samp{Kathy} or
- ref{Matching tags and properties}.
- chapter Properties and columns
- code{:release_1:},
- code{:Release:}, that in different subtrees has different
- values, such as code{2.0}. Second, you can use properties to
- implement (very basic) database capabilities in an Org buffer. Imagine
- keeping track of your music CDs, where properties could be things such as the
- album, artist, date of release, number of tracks, and so on.
- Properties can be conveniently edited and viewed in column view
- (
- menu
- * Property syntax:: How properties are spelled out
- * Special properties:: Access to other Org mode features
- * Property searches:: Matching property values
- * Property inheritance:: Passing values down the tree
- * Column view:: Tabular viewing and editing
- * Property API:: Properties for Lisp programmers
- node Property syntax, Special properties, Properties and Columns, Properties and Columns
- cindex property syntax
- pxref{Drawers}) with the name
- example
- * CD collection
- ** Classic
- *** Goldberg Variations
- :PROPERTIES:
- :Title: Goldberg Variations
- :Composer: J.S. Bach
- :Artist: Glen Gould
- :Publisher: Deutsche Grammophon
- :NDisks: 1
- :END:
- code{org-use-property-inheritance}, a property set
- this way will either be associated with a single entry, or the sub-tree
- defined by the entry, see
- samp{:Xyz:}
- by setting a property
- emph{inherited}, so if you set it in a level 1 entry, it will apply to
- the entire tree. When allowed values are defined, setting the
- corresponding property becomes easier and is less prone to typing
- errors. For the example with the CD collection, we can predefine
- publishers and the number of disks in a box like this:
- end example
- If you want to set properties that can be inherited by any entry in a
- file, use a line like
- cindex #+PROPERTY
- end example
- If you want to add to the value of an existing property, append a
- code{var} having
- the value ``foo=1 bar=2''.
- example
- #+PROPERTY: var foo=1
- #+PROPERTY: var+ bar=2
- code{genres} property having the value ``Classic
- Baroque'' under the
- cindex property, +
- end example
- Note that a property can only have one entry per Drawer.
- code{org-global-properties} can be inherited by all entries in all
- Org files.
- table
- orgcmd{M-
- orgcmd{C-c C-x p,org-set-property}
- Set a property. This prompts for a property name and a value. If
- necessary, the property drawer is created as well.
- findex org-insert-property-drawer
- Insert a property drawer into the current entry. The drawer will be
- inserted early in the entry, but after the lines with planning
- information like deadlines.
- orgcmd{C-c C-c s,org-set-property}
- Set a property in the current entry. Both the property and the value
- can be inserted using completion.
- key{right},S-
- orgcmd{C-c C-c d,org-delete-property}
- Remove a property from the current entry.
- orgcmd{C-c C-c c,org-compute-property-at-point}
- Compute the property at point, using the operator and scope from the
- nearest column format definition.
- node Special properties, Property searches, Property syntax, Properties and Columns
- cindex properties, special
- Special properties provide an alternative access method to Org mode features,
- like the TODO state or the priority of an entry, discussed in the previous
- chapters. This interface exists so that you can include these states in a
- column view (
- code{:CATEGORY:}) should not be
- used as keys in the properties drawer:
- cindex property, special, TAGS
- cindex property, special, CATEGORY
- cindex property, special, DEADLINE
- cindex property, special, CLOSED
- cindex property, special, TIMESTAMP_IA
- cindex property, special, BLOCKED
- cindex property, special, ITEM
- example
- TODO
- r{The tags defined directly in the headline.}
- ALLTAGS
- r{The category of an entry.}
- PRIORITY
- r{The deadline time string, without the angular brackets.}
- SCHEDULED
- r{When was this entry closed?}
- TIMESTAMP
- r{The first inactive timestamp in the entry.}
- CLOCKSUM code{org-clock-sum}}
-
- r{"t" if task is currently blocked by children or siblings}
- ITEM
- r{The filename the entry is located in.}
- node Property searches, Property inheritance, Special properties, Properties and Columns
- cindex properties, searching
- pxref{Tag searches}).
- kbd
- kbd{C-u} prefix argument, ignore headlines that are not a TODO line.
- xref{Matching tags and properties}.
- vindex org-tags-match-list-sublevels
- Create a global list of tag matches from all agenda files, but check
- only TODO items and force checking of subitems (see variable
- end table
- The syntax for the search string is described in
- table
- orgkey{C-c / p}
- Create a sparse tree based on the value of a property. This first
- prompts for the name of a property, and then for a value. A sparse tree
- is created with all entries that define this property with the given
- value. If you enclose the value in curly braces, it is interpreted as
- a regular expression and matched against the property values.
- node Property inheritance, Column view, Property searches, Properties and Columns
- cindex properties, inheritance
- vindex org-use-property-inheritance
- The outline structure of Org mode documents lends itself to an
- inheritance model of properties: if the parent in a tree has a certain
- property, the children can inherit this property. Org mode does not
- turn this on by default, because it can slow down property searches
- significantly and is often not needed. However, if you find inheritance
- useful, you can turn it on by setting the variable
- code{t} to make
- all properties inherited from the parent, to a list of properties
- that should be inherited, or to a regular expression that matches
- inherited properties. If a property has the value
- code{nil}.
- Org mode has a few properties for which inheritance is hard-coded, at
- least for the special applications for which they are used:
- table
- item COLUMNS
- The
- pxref{Column view}). It is inherited in the sense that the level
- where a
- item CATEGORY
- code{:CATEGORY:} property
- applies to the entire subtree.
- cindex property, ARCHIVE
- For archiving, the
- pxref{Moving subtrees}).
- cindex property, LOGGING
- The LOGGING property may define logging settings for an entry or a
- subtree (
- end table
- section Column view
- A great way to view and edit properties in an outline tree is
- kbd{S-key{TAB}}, or simply
- pxref{Agenda Views}) where
- queries have collected selected items, possibly from a number of files.
- end menu
- subsection Defining columns
- cindex properties, column view
- Setting up a column view first requires defining the columns. This is
- done by defining a column format line.
- end menu
- subsubsection Scope of column definitions
- To define a column format for an entire file, use a line like
- example
- #+COLUMNS: %25ITEM %TAGS %PRIORITY %TODO
- code{:COLUMNS:} property to the top node of that tree, for example:
- end example
- If a
- node Column attributes, , Scope of column definitions, Defining columns
- example
- %[var{property}[({}]
- noindent
- Except for the percent sign and the property name, all items are
- optional. The individual parts have the following meaning:
- var{width}
- r{If omitted, the width will be determined automatically.}
- r{The property that should be edited in this column.}
-
- r{as well (
- var{title}
- r{name is used.}
- var{summary-type}r{The summary type. If specified, the column values for}
-
- r{Supported summary types are:}
- }
- {+;%.1fr{Like samp{%.1f}.}
- } samp{+;%.2f}.}
- }
- {Xr{Checkbox status, samp{[X]}.}
- } samp{[n/m]}.}
- } samp{[n%]}.}
- }
- {maxr{Largest number.}
- }
- {:minr{Smallest time value in column.}
- }
- {:meanr{Arithmetic mean of time values.}
- }
- {maxr{Maximum age (in days/hours/mins/seconds).}
- }
- {est+r{Add low-high estimates.}
- noindent
- Be aware that you can only have one summary type for any property you
- include. Subsequent columns referencing the same property will all display the
- same summary information.
- The
- code{est+} adds the
- statistical mean and variance of the sub-tasks, generating a final estimate
- from the sum. For example, suppose you had ten tasks, each of which was
- estimated at 0.5 to 2 days of work. Straight addition produces an estimate
- of 5 to 20 days, representing what to expect if everything goes either
- extremely well or extremely poorly. In contrast,
- example
- :COLUMNS: %25ITEM %9Approved(Approved?)} %Owner %11Status \
- {:
- end example
- samp{%25ITEM}, means the first 25 characters of the
- item itself, i.e.
- samp{ITEM} specifier. The other specifiers
- create columns
- samp{Status} with four different possible values, and for a checkbox
- field samp{%}
- character, the column will be exactly as wide as it needs to be in order
- to fully display all values. The
- samp{Approved?}, with a question mark). Summaries will
- be created for the
- samp{Approved} column, by providing
- an
- samp{CLOCKSUM} column is special, it lists the sum of CLOCK intervals
- in the subtree.
- subsection Using column view
- kbd
- orgcmd{C-c C-x C-c,org-columns}
- code{#+COLUMNS}
- definition. If the cursor is somewhere inside the outline, this command
- searches the hierarchy, up from point, for a
- code{:COLUMNS:}
- property. If no such property is found, the format is taken from the
- code{org-columns-default-format},
- and column view is established for the current entry and its subtree.
- orgcmd{g,org-columns-redo}
- Same as
- orgcmd{q,org-columns-quit}
- Exit column view.
- item key{right} key{down}
- Move through the column view from field to field.
- key{left}
- key{right}
- key{left}/
- item 1..9,0
- Directly select the Nth allowed value,
- orgcmdkkcc{n,p,org-columns-next-allowed-value,org-columns-previous-allowed-value}
- Same as key{left}/
- orgcmd{e,org-columns-edit-value}
- Edit the property at point. For the special properties, this will
- invoke the same interface that you normally use to change that
- property. For example, when editing a TAGS property, the tag completion
- or fast selection interface will pop up.
- orgcmd{v,org-columns-show-value}
- View the full value of this property. This is useful if the width of
- the column is smaller than that of the value.
- tsubheading{Modifying the table structure}
- orgcmd{S-M-
- orgcmd{S-M-
- end table
- subsection Capturing column view
- Since column view is just an overlay over a buffer, it cannot be
- exported or printed directly. If you want to capture a column view, use
- a pxref{Dynamic blocks}). The frame
- of this block looks like this:
- example
- * The column view
- #+BEGIN: columnview :hlines 1 :id "label"
- #+END:
- noindent This dynamic block has the following parameters:
- code
- cindex property, ID
- r{use the tree in which the capture block is located}
- global
- var{path-to-file}"
- @r{run column view at the top of this file}
- "r{call column view in the tree that has an
- r{property with the value
- r{
- r{the current entry and copy it to the kill-ring.}
- item :hlines
- When var{N}, insert
- an hline before each headline with level var{N}}.
- code{t}, force column groups to get vertical lines.
- item :skip-empty-rows
- When set to
- code{ITEM}.
- noindent
- The following commands insert or update the dynamic block:
- kbd
- orgcmdkkc{C-c C-c,C-c C-x C-u,org-dblock-update}
- Update dynamic block at point. The cursor needs to be in the
- orgcmd{C-u C-c C-x C-u,org-update-all-dblocks}
- Update all dynamic blocks (
- end table
- You can add formulas to the column view table and you may add plotting
- instructions in front of the table---these will survive an update of the
- block. If there is a
- file{org-collector.el} which is a contributed
- package
- uref{http://orgmode.org}).}. It provides a general API to collect
- properties from entries in a certain scope, and arbitrary Lisp expressions to
- process these values before inserting them into a table or a dynamic block.
- section The Property API
- cindex API, for properties
- There is a full API for accessing and changing properties. This API can
- be used by Emacs Lisp programs to work with properties and to implement
- features based on them. For more information see
- node Dates and Times, Capture - Refile - Archive, Properties and Columns, Top
- cindex dates
- cindex timestamp
- emph{timestamp} in Org mode. This may be a
- little confusing because timestamp is often used as indicating when
- something was created or last changed. However, in Org mode this term
- is used in a much wider sense.
- end menu
- section Timestamps, deadlines, and scheduling
- cindex ranges, time
- cindex deadlines
- samp{<2003-09-16 Tue>}
- samp{<2003-09-16 Tue 09:39>} or
- footnote{This is inspired by the standard ISO 8601
- date/time format. To use an alternative format, see
- pxref{Weekly/daily agenda}). We distinguish:
- var
- cindex timestamp
- example
- * Meet Peter at the movies <2006-11-01 Wed 19:15>
- * Discussion on climate change <2006-11-02 Thu 20:00-22:00>
- item Timestamp with repeater interval
- emph{repeater interval}, indicating that it
- applies not only on the given date, but again and again after a certain
- interval of N days (d), weeks (w), months (m), or years (y). The
- following will show up in the agenda every Wednesday:
- end example
- footnote{When working with the standard diary sexp functions, you
- need to be very careful with the order of the arguments. That order depend
- evilly on the variable
- code{european-calendar-style}). For example, to specify a date
- December 12, 2005, the call might look like
- code{(diary-date 1 12 2005)} or
- code{org-date} or
- code{diary-}
- functions, but with stable ISO order of arguments (year, month, day) wherever
- applicable, independent of the value of
- example
- * 22:00-23:00 The nerd meeting on every 2nd Thursday of the month
- <%%(org-float t 4 2)>
- item Time/Date range
- cindex date range
- Two timestamps connected by
- example
- ** Meeting in Amsterdam
- <2004-08-23 Mon>--<2004-08-26 Thu>
- item Inactive timestamp
- cindex inactive timestamp
- Just like a plain timestamp, but with square brackets instead of
- angular ones. These timestamps are inactive in the sense that they do
- example
- * Gillian comes late for the fifth time [2006-11-01 Wed]
- end table
- section Creating timestamps
- cindex timestamps, creating
- For Org mode to recognize timestamps, they need to be in the specific
- format. All commands listed below produce timestamps in the correct
- format.
- kbd
- c
- kbd{C-c .}, but insert an inactive timestamp that will not cause
- an agenda entry.
- kindex C-u C-c .
- item C-u C-c .
- vindex org-time-stamp-rounding-minutes
- Like kbd{C-c !}, but use the alternative format which
- contains date and time. The default time can be rounded to multiples of 5
- minutes, see the option
- c
- c
- c
- c
- pxref{Weekly/daily agenda}).
- orgcmdkkcc{S-key{right},org-timestamp-down-day,org-timestamp-up-day}
- Change date at cursor by one day. These key bindings conflict with
- shift-selection and related modes (
- c
- key{up},S-
- samp{15:30-16:30}, modifying the first time will also shift the second,
- shifting the time block with constant length. To change the length, modify
- the second time. Note that if the cursor is in a headline and not at a
- timestamp, these same keys modify the priority of an item.
- (
- pxref{Conflicts}).
- orgcmd{C-c C-y,org-evaluate-time-range}
- end table
- end menu
- subsection The date/time prompt
- cindex time, reading in minibuffer
- kbd{C-y} to paste a (possibly multi-line) string
- copied from an email message. Org mode will find whatever information is in
- there and derive anything you have not specified from the
- i{before} today, it will assume that you mean a future date
- code{org-read-date-prefer-future}. You may set that variable to
- the symbol
- samp{(=>F).}
- For example, let's assume that today is
- b{bold}.
- result{} 2003-02-05
- 2/5/3
- result{} b{06}-14
- 12 b{2006}-
- result{}
- result{} nearest Friday (default date or later)
- sep 15 b{2006}-09-15
- feb 15 b{2007}-02-15
- sep 12 9
- result{} b{06}-
- result{}
- result{} ISO week for of the current year
- result{} Friday of ISO week 4 in 2012
- 2012-w04-5
- end example
- Furthermore you can specify a relative date by giving, as the
- :
- result{} today
- .
- result{} four days from today
- +4
- result{} two weeks from today
- ++5
- result{} second Tuesday from now.
- vindex parse-time-months
- code{parse-time-months} and
- vindex org-read-date-force-compatible-dates
- Not all dates can be represented in a given Emacs implementation. By default
- Org mode forces dates into the compatibility range 1970--2037 which works on
- all Emacs implementations. If you want to use dates outside of this range,
- read the docstring of the variable
- :
- result{} 11:00-13:15
- 11am--1:15pm
- result{} same as above
- cindex calendar, for selecting date
- footnote{If
- you don't need/want the calendar, configure the variable
- key{RET}, the date selected in the calendar will be combined with the
- information entered at the prompt. You can control the calendar fully
- from the minibuffer:
- kindex >
- kindex C-v
- kindex S-
- kindex S-
- kindex S-
- kindex S-
- kindex M-S-
- kindex M-S-
- kindex
- example
- r{Choose date at cursor in calendar.}
- mouse-1
- key{right}/r{One day forward/backward.}
- S-key{up}
- key{right}/r{One month forward/backward.}
- > / <
- r{Scroll calendar forward/backward by 3 months.}
- vindex org-read-date-display-live
- The actions of the date/time prompt may seem complex, but I assure you they
- will grow on you, and you will start getting annoyed by pretty much any other
- way of entering a date/time out there. To help you understand what is going
- on, the current interpretation of your input will be displayed live in the
- minibuffer
- code{org-read-date-display-live}.}.
- subsection Custom time format
- cindex time format, custom
- vindex org-display-custom-times
- code{org-display-custom-times} and
- table
- orgcmd{C-c C-x C-t,org-toggle-time-stamp-overlays}
- Toggle the display of custom formats for dates and times.
- noindent
- Org mode needs the default format for scanning, so the custom date/time
- format does not
- emph{over} the default format using text properties. This has the
- following consequences:
- bullet
- item
- The key{up}/
- kbd{S-key{down}} will change the stamp by one day,
- just like key{left}/
- item
- If the timestamp contains a range of clock times or a repeater, these
- will not be overlaid, but remain in the buffer as they were.
- emph{all} (invisible) characters
- belonging to the ISO timestamp have been removed.
- end itemize
- section Deadlines and scheduling
- A timestamp may be preceded by special keywords to facilitate planning:
- var
- cindex DEADLINE keyword
- Meaning: the task (most likely a TODO item, though not necessarily) is supposed
- to be finished on that date.
- emph{today} will carry a warning about the
- approaching or missed deadline, starting
- example
- *** TODO write article about the Earth for the Guide
- The editor in charge is [[bbdb:Ford Prefect]]
- DEADLINE: <2004-02-29 Sun>
- code{DEADLINE: <2004-02-29 Sun -5d>}.
- cindex SCHEDULED keyword
- Meaning: you are planning to start working on that task on the given
- date.
- footnote{It will still
- be listed on that date after it has been marked DONE. If you don't like
- this, set the variable
- emph{today}, until the entry is marked DONE, i.e.
- example
- *** TODO Call Trillian for a date on New Years Eve.
- SCHEDULED: <2004-12-25 Sat>
- noindent
- i{not} be
- understood in the same way that we understand
- i{scheduling} means setting a date when you
- want to start working on an action item.
- i{nearest instance} of
- the repeater. However, the use of diary sexp entries like
- code{<%%(org-float t 42)>}
- menu
- * Inserting deadline/schedule:: Planning items
- * Repeated tasks:: Items that show up again and again
- node Inserting deadline/schedule, Repeated tasks, Deadlines and scheduling, Deadlines and scheduling
- footnote{The
- samp{DEADLINE} dates are inserted on the line right below the headline. Don't put
- any text between this line and the headline.} a deadline or to schedule
- an item:
- kbd
- orgcmd{C-c C-d,org-deadline}
- Insert
- code{org-log-redeadline}
- code{#+STARTUP} keywords code{lognoteredeadline},
- and
- orgcmd{C-c C-s,org-schedule}
- Insert
- code{org-log-reschedule}code{#+STARTUP}
- keywords code{lognotereschedule}, and
- c
- kindex k a
- kbd{k s} or
- c
- cindex sparse tree, for deadlines
- code{org-deadline-warning-days}.
- With
- kbd{C-1 C-c / d} shows
- all deadlines due tomorrow.
- orgcmd{C-c / b,org-check-before-date}
- Sparse tree for deadlines and scheduled items before a given date.
- orgcmd{C-c / a,org-check-after-date}
- Sparse tree for deadlines and scheduled items after a given date.
- code{org-schedule} and
- node Repeated tasks, , Inserting deadline/schedule, Deadlines and scheduling
- cindex tasks, repeated
- example
- ** TODO Pay the rent
- DEADLINE: <2005-10-01 Sat +1m>
- noindent
- the
- code{DEADLINE: <2005-10-01 Sat +1m -3d>}.
- emph{next} instance of the
- repeated entry will not be active. Org mode deals with this in the following
- way: When you try to mark such an entry DONE (using
- footnote{In fact, the target
- state is taken from, in this sequence, the
- code{org-todo-repeat-to-state}. If neither of these is
- specified, the target state defaults to the first state of the TODO state
- sequence.}. In the example above, setting the state to DONE would actually
- switch the date like this:
- end example
- footnote{You can change this using the option
- code{#+STARTUP} options
- code{lognoterepeat}, and code{lognoterepeat}, you
- will also be prompted for a note.} will be added under the deadline, to keep
- a record that you actually acted on the previous instance of this deadline.
- As a consequence of shifting the base date, this entry will no longer be
- visible in the agenda when checking past dates, but all future instances
- will be visible.
- With the
- i{after} the last time you did it. For these tasks, Org mode has
- special repeaters samp{.+}. For example:
- end example
- You may have both scheduling and deadline information for a specific
- task---just make sure that the repeater intervals on both are the same.
- An alternative to using a repeater is to create a number of copies of a task
- subtree, with dates shifted in each copy. The command
- ref{Structure editing}.
- section Clocking work time
- cindex time clocking
- Org mode allows you to clock the time you spend on specific tasks in a
- project. When you start working on an item, you can start the clock.
- When you stop working on that task, or when you mark the task done, the
- clock is stopped and the corresponding time interval is recorded. It
- also computes the total time spent on each subtree of a project. And it
- remembers a history or tasks recently clocked, to that you can jump quickly
- between a number of tasks absorbing your time.
- To save the clock history across Emacs sessions, use
- end lisp
- When you clock into a new task after resuming Emacs, the incomplete
- clock
- code{(setq org-clock-persist t)}.}
- will be found (
- menu
- * Clocking commands:: Starting and stopping a clock
- * The clock table:: Detailed reports
- * Resolving idle time:: Resolving time when you've been idle
- node Clocking commands, The clock table, Clocking work time, Clocking work time
- table
- orgcmd{C-c C-x C-i,org-clock-in}
- cindex property, LOG_INTO_DRAWER
- Start the clock on the current item (clock-in). This inserts the CLOCK
- keyword together with a timestamp. If this is not the first clocking of
- this item, the multiple CLOCK lines will be wrapped into a
- code{org-clock-into-drawer}). You can also overrule
- the setting of this variable for a subtree by setting a
- code{LOG_INTO_DRAWER} property.
- When called with a
- kbd{C-u
- C-u} prefixes, clock into the task at point and mark it as the default task.
- The default task will always be available when selecting a clocking task,
- with letter *
- cindex property: LAST_REPEAT
- pxref{Effort estimates}), the mode line displays the current
- clocking time against it
- code{org-clock-in-prepare-hook}.} If the task
- is a repeating one (
- footnote{as recorded by the
- code{CLOCK_MODELINE_TOTAL} property. It may have the values
- code{today} to
- show all time clocked on this tasks today (see also the variable
- code{all} to include all time, or
- footnote{See also the variable
- * Clicking with
- c
- vindex org-log-note-clock-out
- Stop the clock (clock-out). This inserts another timestamp at the same
- location where the clock was last started. It also directly computes
- the resulting time in inserts it after the time range as
- code{org-log-note-clock-out} for the
- possibility to record an additional note together with the clock-out
- timestamp
- code{#+STARTUP: lognoteclock-out}}.
- kindex C-c C-y
- orgcmdkkc{C-c C-c,C-c C-y,org-evaluate-time-range}
- Recompute the time interval after changing one of the timestamps. This
- is only necessary if you edit the timestamps directly. If you change
- them with key{cursor}} keys, the update is automatic.
- key{up/down},org-clock-timestamps-up/down}
- On
- orgcmd{C-c C-t,org-todo}
- Changing the TODO state of an item to DONE automatically stops the clock
- if it is running in this same item.
- orgcmd{C-c C-x C-j,org-clock-goto}
- Jump to the headline of the currently clocked in task. With a
- orgcmd{C-c C-x C-d,org-clock-display}
- code{org-remove-highlights-with-change}) or press
- end table
- The pxref{Timeline}) and in
- the agenda (
- node The clock table, Resolving idle time, Clocking commands, Clocking work time
- cindex clocktable, dynamic block
- emph{clock table}, because it is
- formatted as one or several Org tables.
- kbd
- pxref{Dynamic blocks}) containing a clock
- report as an Org mode table into the current file. When the cursor is
- at an existing clock table, just update it. When called with a prefix
- argument, jump to the first clock report in the current document and
- update it. The clock table always includes also trees with
- orgcmdkkc{C-c C-c,C-c C-x C-u,org-dblock-update}
- Update dynamic block at point. The cursor needs to be in the
- orgkey{C-u C-c C-x C-u}
- Update all dynamic blocks (
- orgcmdkxkc{S-key{right},org-clocktable-try-shift}
- Shift the current
- code{#+BEGIN: clocktable} line for this command. If
- code{today}, it will be shifted to
- end table
- Here is an example of the frame for a clock table as it is inserted into the
- buffer with the
- cindex #+BEGIN, clocktable
- end example
- vindex org-clocktable-defaults
- The
- code{org-clocktable-defaults}.
- example
- :maxlevel
- r{Clocks at deeper levels will be summed into the upper level.}
- :scope
- r{the current buffer or narrowed region}
- file
- r{the subtree where the clocktable is located}
- treer{the surrounding level code{tree3}}
- tree
- r{all agenda files}
- ("file"..)
- r{current file and its archives}
- agenda-with-archives
- r{The time block to consider. This block is specified either}
-
- r{these formats:}
- 2007-12-31
- r{December 2007}
- 2007-W50
- r{2nd quarter in 2007}
- 2007
- var{N}
- var{N}
- var{N}
- var{N}
- r{Use key{left}/
- r{A time string specifying when to start considering times.}
- :tend
- r{code{day}, to split the table into chunks.}
- code{:block} or code{:tend} are needed.}
- :stepskip0
- r{Do not show table sections from files which did not contribute.}
- :tags
- r{
- end example
- Then there are options which determine the formatting of the table. There
- options are interpreted by the function
- code{:formatter} parameter.
- r{When
- r{Languagecode{org-clock-clocktable-language-setup}.} to use for descriptive cells like "Task".}
- :link
- r{An integer to limit the width of the headline column in}
- samp{50!}, then the}
-
- r{Indent each headline field according to its level.}
- :tcolumns
- r{than
- r{Should a level number column be included?}
- :compact code{:level nil :indent t :narrow 40! :tcolumns 1}}
- code{:narrow}}
- :timestamp
- r{DEADLINE, TIMESTAMP and TIMESTAMP_IA, in this order.}
- :properties
- r{property will get its own column.}
- :inherit-props code{t}, the values for
- r{Content of a
- r{As a special case,
- r{If you do not specify a formula here, any existing formula}
-
- r{A function to format clock data and insert it into the buffer.}
- example
- #+BEGIN: clocktable :maxlevel 2 :block today :scope tree1 :link t
- #+END: clocktable
- noindent
- and to use a specific time range you could write
- example
- #+BEGIN: clocktable :tstart "<2006-08-10 Thu 10:00>"
- :tend "<2006-08-10 Thu 12:00>"
- #+END: clocktable
- example
- #+BEGIN: clocktable :scope subtree :link t :formula %
- #+END: clocktable
- example
- #+BEGIN: clocktable :scope agenda :block lastweek :compact t
- #+END: clocktable
- node Resolving idle time, , The clock table, Clocking work time
- cindex resolve idle time
- vindex org-clock-idle-time
- By customizing the variable
- footnote{On computers using Mac OS X,
- idleness is based on actual user idleness, not just Emacs' idle time. For
- X11, you can install a utility program
- table
- item k
- To keep some or all of the minutes and stay clocked in, press
- key{RET} to keep them all,
- effectively changing nothing, or enter a number to keep that many minutes.
- kbd{K}, it will keep however many minutes
- you request and then immediately clock out of that task. If you keep all of
- the minutes, this is the same as just clocking out of the current task.
- kbd{s} to subtract all the away time from
- the clock, and then check back in from the moment you returned.
- kbd{S}. Remember that using shift will always
- leave you clocked out, no matter which option you choose.
- kbd{C}. Note that if instead of
- canceling you subtract the away time, and the resulting clock amount is less
- than a minute, the clock will still be canceled rather than clutter up the
- log with an empty entry.
- kbd{M-x org-resolve-clocks}.
- section Effort estimates
- cindex property, Effort
- samp{Effort}
- code{org-effort-property}.}. You can set the effort
- for an entry with the following commands:
- kbd
- kbd{e} key.
- end table
- Clearly the best way to work with effort estimates is through column view
- (
- code{COLUMNS} format that displays these values
- together with clock sums (if you want to clock your time). For a specific
- buffer you can use
- {:
- end example
- vindex org-global-properties
- code{org-global-properties} and
- kbd{S-kbd{S-
- vindex org-agenda-columns-add-appointments-to-effort-sum
- If you switch to column view in the daily/weekly agenda, the effort column
- will summarize the estimated work effort for each day
- pxref{Agenda
- column view}).}, and you can use this to find space in your schedule. To get
- an overview of the entire part of the day that is committed, you can set the
- option
- kbd{/} key in the agenda (
- node Relative timer, Countdown timer, Effort estimates, Dates and Times
- cindex relative timer
- When taking notes during, for example, a meeting or a video viewing, it can
- be useful to have access to times relative to a starting time. Org provides
- such a relative timer and make it easy to create timed notes.
- kbd
- orgcmd{C-c C-x -,org-timer-item}
- Insert a description list item with the current relative time. With a prefix
- argument, first reset the timer to 0.
- key{RET},org-insert-heading}
- Once the timer list is started, you can also use key{RET}} to insert
- new timer items.
- kindex C-c C-x ,
- command{org-timer-pause-or-continue}).
- kindex C-u C-c C-x ,
- orgcmd{C-c C-x 0,org-timer-start}
- Reset the timer without inserting anything into the buffer. By default, the
- timer is reset to 0. When called with a
- kbd{C-u C-u}, change all timer strings in the active region
- by a certain amount. This can be used to fix timer strings if the timer was
- not started at exactly the right moment.
- node Countdown timer, , Relative timer, Dates and Times
- cindex Countdown timer
- kindex ;
- Calling
- kbd{;} from agenda buffers,
- code{org-timer-set-timer} prompts the user for a duration and displays a
- countdown timer in the modeline.
- node Capture - Refile - Archive, Agenda Views, Dates and Times, Top
- cindex capture
- An important part of any organization system is the ability to quickly
- capture new ideas and tasks, and to associate reference material with them.
- Org does this using a process called
- i{attachments}) in a special directory. Once in the
- system, tasks and projects need to be moved around. Moving completed project
- trees to an archive file keeps the system compact and fast.
- : Browser) access to Emacs and Org
- * Refiling notes:: Moving a tree from one place to another
- * Archiving:: What to do with finished projects
- node Capture, Attachments, Capture - Refile - Archive, Capture - Refile - Archive
- cindex capture
- Org's method for capturing new items is heavily inspired by John Wiegley
- excellent remember package. Up to version 6.36 Org used a special setup
- for file{org-remember.el} is still part of Org mode for
- backward compatibility with existing setups. You can find the documentation
- for org-remember at
- code{org-remember-templates}, run the command
- kbd{M-x org-capture-import-remember-templates
- end example
- kbd{M-x
- customize-variable org-capture-templates}, check the result, and save the
- customization. You can then use both remember and capture until
- you are familiar with the new mechanism.
- Capture lets you quickly store notes with little interruption of your work
- flow. The basic process of capturing is very similar to remember, but Org
- does enhance it with templates and more.
- end menu
- subsection Setting up capture
- The following customization sets a default target file for notes, and defines
- a global keykbd{C-c c} is only a
- suggestion.} for capturing new material.
- example
- (setq org-default-notes-file (concat org-directory "/notes.org"))
- (define-key global-map "\C-cc" 'org-capture)
- node Using capture, Capture templates, Setting up capture, Capture
- table
- orgcmd{C-c c,org-capture}
- Call the command
- cindex date tree
- defined
- orgcmd{C-c C-c,org-capture-finalize}
- Once you have finished entering information into the capture buffer,
- orgcmd{C-c C-w,org-capture-refile}
- Finalize the capture process by refiling (
- code{org-refile} command.
- end table
- You can also call
- kbd{k c} key combination. With this access, any timestamps inserted by
- the selected capture template will default to the cursor date in the agenda,
- rather than to the current date.
- To find the locations of the last stored capture, use
- table
- orgkey{C-u C-c c}
- Visit the target location of a capture template. You get to select the
- template in the usual way.
- end table
- subsection Capture templates
- table
- orgkey{C-c c C}
- Customize the variable
- end table
- Before we give the formal description of template definitions, let's look at
- an example. Say you would like to use one template to create general TODO
- entries, and you want to put these entries under the heading
- file{~/org/gtd.org}. Also, a date tree in the file
- example
- (setq org-capture-templates
- '(("t" "Todo" entry (file+headline "~/org/gtd.org" "Tasks")
- "* TODO %?\n %i\n %a")
- ("j" "Journal" entry (file+datetree "~/org/journal.org")
- "* %?\nEntered on %U\n %i\n %a")))
- noindent If you then press
- example
- * TODO
- [[file:
- end example
- code{%a} has been replaced by a link to
- the location from where you called the capture command. This can be
- extremely useful for deriving tasks from emails, for example. You fill in
- the task definition, press
- lisp
- (define-key global-map "\C-cx"
- (lambda () (interactive) (org-capture nil "x")))
- menu
- * Template elements:: What is needed for a complete template entry
- * Template expansion:: Filling in information about time and context
- node Template elements, Template expansion, Capture templates, Capture templates
- code{org-capture-templates} is a list with the following items:
- var
- code{"a"} for a template to be selected with a
- single key, or
- example
- ("b" "Templates for marking stuff to buy")
- noindent If you do not define a template for the
- item description
- A short string describing the template, which will be shown during
- selection.
- table
- item entry
- An Org mode node, with a headline. Will be filed as the child of the target
- entry or as a top-level entry. The target file should be an Org mode file.
- item checkitem
- A checkbox item. This only differs from the plain list item by the
- default template.
- code{:prepend} and
- item plain
- Text to be inserted as it is.
- item target
- code{org-default-notes-file}. A file can
- also be given as a variable, function, or Emacs Lisp form.
- Valid values are:
- code
- item (id "id of existing org entry")
- Filing as child of this entry, or in the body of the entry.
- item (file+olp "path/to/file" "Level 1 heading" "Level 2" ...)
- For non-unique headings, the full path is safer.
- item (file+datetree "path/to/file")
- Will create a heading in a date tree for today's date.
- item (file+function "path/to/file" function-finding-location)
- A function to find the right location in the file.
- item (function function-finding-location)
- Most general way, write your own function to find both
- file and location.
- item template
- The template for creating the capture item. If you leave this empty, an
- appropriate default template will be used. Otherwise this is a string with
- escape codes, which will be replaced depending on time and context of the
- capture call. The string with escapes may be loaded from a template file,
- using the special syntax
- item properties
- The rest of the entry is a property list of additional options.
- Recognized properties are:
- code
- item :immediate-finish
- When set, do not offer to edit the information, just
- file it away immediately. This makes sense if the template only needs
- information that can be added automatically.
- item :clock-in
- Start the clock in this item.
- item :clock-resume
- If starting the capture interrupted a clock, restart that clock when finished
- with the capture. Note that
- code{:clock-resume}. When setting both to
- item :unnarrowed
- Do not narrow the target buffer, simply show the full buffer. Default is to
- narrow it so that you only see the new material.
- code{"II-3"} meaning that the new
- line should become the third line before the second horizontal separator
- line.
- end table
- node Template expansion, , Template elements, Capture templates
- kbd{%}-escapes
- kbd{%} with a backslash.} allow
- dynamic insertion of content. The templates are expanded in the order given here:
- var{file}] var{file}.}
- %(r{evaluate Elisp
- r{the result of format-time-string on the ... format specification.}
- %t
- r{timestamp with date and time.}
- %u, %U
- r{annotation, normally the link created with
- r{initial content, the region when capture is called while the}
-
- r{The entire text will be indented like
- r{like
- r{Current kill ring head.}
- %x
- r{title of the currently clocked task.}
- %K
- r{user name (taken from
- r{file visited by current buffer when org-capture was called.}
- %F
- r{specific information for certain link types, see below.}
- %^g
- r{prompt for tags, with completion all tags in all agenda files.}
- %^t code{%t}, but prompt for date. Similarly code{%^u},
- r{You may define a prompt like {Birthday
- r{Interactive selection of which kill or clip to use.}
- %^L code{%^C}, but insert as link.}
- %^var{prop}r{Prompt the user for a value for property
- {}
- r{You may specify a default value and a completion table with}
- {prompt|default|completion2|completion3...
- r{The arrow keys access a prompt-specific history.}
- noindent
- For specific link types, the following keywords will be
- definedpxref{Adding
- hyperlink types}), any property you store with
- vindex org-from-is-user-regexp
- r{(message date header field)}
- | %:date-timestamp
- r{(date as inactive timestamp)}
- | %:fromto footnote{This will always be the other, not the user. See the variable
- r{for messages also all email fields}
- w3, w3m | %:url
- info | %:file %:node
- calendar | %:date
- noindent
- To place the cursor after template expansion use:
- r{After completing the template, position cursor here.}
- node Attachments, RSS Feeds, Capture, Capture - Refile - Archive
- cindex attachments
- pxref{Hyperlinks}) can establish associations with
- files that live elsewhere on your computer or in the cloud, like emails or
- source code files belonging to a project. Another method is
- file{data} directory which lives in the same directory where
- your Org file lives
- code{org-attach-directory}
- to contain an absolute path.}. If you initialize this directory with
- noindent The following commands deal with attachments:
- kbd
- table
- orgcmdtkc{a,C-c C-a a,org-attach-attach}
- code{org-attach-method}.
- Note that hard links are not supported on all systems.
- kindex C-c C-a m
- item c/m/l
- Attach a file using the copy/move/link method.
- Note that hard links are not supported on all systems.
- orgcmdtkc{z,C-c C-a z,org-attach-sync}
- Synchronize the current task with its attachment directory, in case you added
- attachments yourself.
- vindex org-file-apps
- Open current task's attachment. If there is more than one, prompt for a
- file name first. Opening will follow the rules set by
- pxref{Handling links}).
- orgcmdtkc{f,C-c C-a f,org-attach-reveal}
- Open the current task's attachment directory.
- command{dired} in Emacs.
- orgcmdtkc{D,C-c C-a D,org-attach-delete-all}
- Delete all of a task's attachments. A safer way is to open the directory in
- orgcmdtkc{s,C-c C-a s,org-attach-set-directory}
- code{ATTACH_DIR} property.
- cindex property, ATTACH_DIR_INHERIT
- Set the
- end table
- node RSS Feeds, Protocols, Attachments, Capture - Refile - Archive
- cindex RSS feeds
- code{org-feed-alist}. The docstring of this variable has detailed
- information. Here is just an example:
- end example
- code{rss.slashdot.org} will result in new entries in the file
- samp{Slashdot Entries}, whenever
- the following command is used:
- kbd
- item C-c C-x g
- Collect items from the feeds configured in
- orgcmd{C-c C-x G,org-feed-goto-inbox}
- Prompt for a feed name and go to the inbox configured for this feed.
- samp{FEEDSTATUS} in which
- it will store information about the status of items in the feed, to avoid
- adding the same item several times. You should add
- example
- #+DRAWERS: LOGBOOK PROPERTIES FEEDSTATUS
- file{org-feed.el} and the docstring of
- node Protocols, Refiling notes, RSS Feeds, Capture - Refile - Archive
- cindex protocols, for external access
- file{emacsserver}. For example, you can
- configure bookmarks in your web browser to send a link to the current page to
- Org and create a note from it using capture (
- uref{http://orgmode.org/worg/org-contrib/org-protocol.php} for detailed
- documentation and setup instructions.
- section Refiling notes
- table
- orgcmd{C-c C-w,org-refile}
- vindex org-refile-targets
- vindex org-outline-path-complete-in-steps
- vindex org-log-refile
- code{org-reverse-note-order}, it will be either the first or
- last subitem.
- code{org-refile-targets} for details. If you would like to
- select a location via a file-path-like completion along the outline path, see
- the variables
- code{org-outline-path-complete-in-steps}. If you would like to be able to
- create new nodes as new parents for refiling on the fly, check the
- variable
- code{org-log-refile}
- code{#+STARTUP} keywords code{lognoterefile},
- and
- orgkey{C-u C-c C-w}
- Use the refile interface to jump to a heading.
- code{org-refile} last moved a tree to.
- item C-0 C-c C-w r{or}
- orgcmdtkc{C-0 C-c C-w r{or}
- code{org-refile-use-cache}. To make the command see new possible
- targets, you have to clear the cache with this command.
- node Archiving, , Refiling notes, Capture - Refile - Archive
- cindex archiving
- When a project represented by a (sub)tree is finished, you may want
- to move the tree out of the way and to stop it from contributing to the
- agenda. Archiving is important to keep your working files compact and global
- searches like the construction of agenda views fast.
- kbd
- vindex org-archive-default-command
- Archive the current entry using the command specified in the variable
- end table
- end menu
- subsection Moving a tree to the archive file
- table
- orgcmdkskc{C-c C-x C-s,C-c $,org-archive-subtree}
- code{org-archive-location}.
- emph{not} on a headline when this command
- is invoked, the level 1 trees will be checked.
- cindex archive locations
- The default archive location is a file in the same directory as the
- current file, with the name derived by appending
- code{org-archive-location}. There is also an in-buffer option for
- setting this variable, for example
- emph{strongly} deprecated as it is incompatible
- with the outline structure of the document. The correct method for
- setting multiple archive locations in a buffer is using properties.}:
- example
- #+ARCHIVE: %s_done::
- cindex property, ARCHIVE
- code{:ARCHIVE:} property with the
- location as the value (
- vindex org-archive-save-context-info
- When a subtree is moved, it receives a number of special properties that
- record context information like the file from where the entry came, its
- outline path the archiving time etc. Configure the variable
- node Internal archiving, , Moving subtrees, Archiving
- code{ARCHIVE tag}.
- A headline that is marked with the ARCHIVE tag (
- itemize
- item
- pxref{Visibility cycling}). You can force cycling archived
- subtrees with key{TAB}}, or by setting the option
- code{show-all} will open archived subtrees.
- vindex org-sparse-tree-open-archived-trees
- During sparse tree construction (
- code{org-sparse-tree-open-archived-trees}.
- vindex org-agenda-skip-archived-trees
- During agenda view construction (
- code{org-agenda-skip-archived-trees}, in which case these trees will always
- be included. In the agenda you can press
- item
- pxref{Exporting}), only the headline
- is. Configure the details using the variable
- item
- code{org-columns-skip-archived-trees} is configured to
- end itemize
- The following commands help manage the ARCHIVE tag:
- kbd
- orgkey{C-u C-c C-x a}
- Check if any direct children of the current headline should be archived.
- To do this, each subtree is checked for open TODO entries. If none are
- found, the command offers to set the ARCHIVE tag for the child. If the
- cursor is
- orgcmd{C-
- orgcmd{C-c C-x A,org-archive-to-archive-sibling}
- Move the current entry to the
- samp{Archive} and the tag
- end table
- chapter Agenda views
- itemize
- item
- an
- item
- a
- item
- a
- item
- a
- item
- a
- item
- a
- item
- end itemize
- emph{agenda
- buffer}. This buffer is read-only, but provides commands to visit the
- corresponding locations in the original Org files, and even to
- edit these files remotely.
- vindex org-agenda-restore-windows-after-quit
- Two variables control how the agenda buffer is displayed and whether the
- window configuration is restored when the agenda exits:
- code{org-agenda-restore-windows-after-quit}.
- end menu
- section Agenda files
- cindex files for agenda
- emph{agenda
- files}, the files listed in the variable
- footnote{If the value of that variable is not a
- list, but a single file name, then the list of agenda files will be
- maintained in that external file.}. If a directory is part of this list,
- all files with the extension
- footnote{When using the dispatcher, pressing
- code{org-agenda-files} until the next
- dispatcher command.}. You can customize
- cindex files, adding to agenda list
- kbd
- orgcmd{C-c ],org-remove-file}
- Remove current file from the list of agenda files.
- cindex cycling, of agenda files
- itemx C-,
- Cycle through agenda file list, visiting one file after the other.
- item M-x org-iswitchb
- Command to use an
- end table
- kbd{<} once or several times in the dispatcher
- (
- table
- orgcmd{C-c C-x <,org-agenda-set-restriction-lock}
- Permanently restrict the agenda to the current subtree. When with a
- prefix argument, or with the cursor before the first headline in a file,
- the agenda scope is set to the entire file. This restriction remains in
- effect until removed with kbd{<}
- or
- orgcmd{C-c C-x >,org-agenda-remove-restriction-lock}
- Remove the permanent restriction created by
- end table
- file{speedbar.el}, you can use the following commands in
- the Speedbar frame:
- kbd
- r{in the speedbar frame},<,org-speedbar-set-agenda-restriction}
- Permanently restrict the agenda to the item---either an Org file or a subtree
- in such a file---at the cursor in the Speedbar frame.
- If there is a window displaying an agenda view, the new restriction takes
- effect immediately.
- r{in the speedbar frame},>,org-agenda-remove-restriction-lock}
- Lift the restriction.
- node Agenda dispatcher, Built-in agenda views, Agenda files, Agenda Views
- cindex agenda dispatcher
- kbd{C-c a} (
- kbd{C-c a} is indeed how the dispatcher
- is accessed and list keyboard access to commands accordingly. After
- pressing
- table
- item a
- Create the calendar-like agenda (
- item t
- pxref{Global TODO list}).
- r{/} M
- Create a list of headlines matching a TAGS expression (
- item L
- Create the timeline view for the current buffer (
- item s
- Create a list of entries selected by a boolean expression of keywords
- and/or regular expressions that must or must not occur in the entry.
- vindex org-agenda-text-search-extra-files
- Search for a regular expression in all agenda files and additionally in
- the files listed in
- code{multi-occur}. A prefix argument can be
- used to specify the number of context lines for each match, default is
- 1.
- r{/} !
- Create a list of stuck projects (
- item <
- Restrict an agenda command to the current buffer
- kbd{1} to restrict to the current
- buffer.}. After pressing
- item < <
- If there is an active region, restrict the following agenda command to
- the region. Otherwise, restrict it to the current subtree
- kbd{0} to restrict to the
- current region/subtree.}. After pressing
- end table
- You can also define custom commands that will be accessible through the
- dispatcher, just like the default commands. This includes the
- possibility to create extended agenda buffers that contain several
- blocks together, for example the weekly agenda, the global TODO list and
- a number of special tags matches.
- node Built-in agenda views, Presentation and sorting, Agenda dispatcher, Agenda Views
- menu
- * Weekly/daily agenda:: The calendar page with current tasks
- * Global TODO list:: All unfinished action items
- * Matching tags and properties:: Structured information with fine-tuned search
- * Timeline:: Time-sorted view for single file
- * Search view:: Find entries by searching for text
- * Stuck projects:: Find projects you need to review
- node Weekly/daily agenda, Global TODO list, Built-in agenda views, Built-in agenda views
- cindex agenda
- cindex daily agenda
- The purpose of the weekly/daily
- table
- cindex org-agenda, command
- footnote{For backward
- compatibility, the universal prefix
- pxref{Block agenda}).} (like
- end table
- vindex org-agenda-ndays
- The default number of days displayed in the agenda is set by the variable
- code{org-agenda-ndays}). This
- variable can be set to any number of days you want to see by default in the
- agenda, or to a span name, such a code{week},
- code{year}.
- Remote editing from the agenda buffer means, for example, that you can
- change the dates of deadlines and appointments from the agenda buffer.
- The commands available in the Agenda buffer are listed in
- subsubheading Calendar/Diary integration
- cindex diary integration
- Emacs contains the calendar and diary by Edward M. Reingold. The
- calendar displays a three-month calendar with holidays from different
- countries and cultures. The diary allows you to keep track of
- anniversaries, lunar phases, sunrise/set, recurrent appointments
- (weekly, monthly) and more. In this way, it is quite complementary to
- Org. It can be very useful to combine output from Org with
- the diary.
- In order to include entries from the Emacs diary into Org mode's
- agenda, you only need to customize the variable
- end lisp
- key{SPC},
- key{RET} can be used from the agenda buffer to jump to the diary
- file in order to edit existing diary entries. The
- kbd{S}, kbd{C} to display
- Sunrise/Sunset times, show lunar phases and to convert to other
- calendars, respectively.
- example
- * Birthdays and similar stuff
- #+CATEGORY: Holiday
- %%(org-calendar-holiday) ; special function for holiday names
- #+CATEGORY: Ann
- %%(org-anniversary 1956 5 14)code{org-anniversary} is just like code{calendar-date-style}.} Arthur Dent is %d years old
- %%(org-anniversary 1869 10 2) Mahatma Gandhi would be %d years old
- subsubheading Anniversaries from BBDB
- cindex anniversaries, from BBDB
- If you are using the Big Brothers Database to store your contacts, you will
- very likely prefer to store anniversaries in BBDB rather than in a
- separate Org or diary file. Org supports this and will show BBDB
- anniversaries as part of the agenda. All you need to do is to add the
- following to one your your agenda files:
- end example
- You can then go ahead and define anniversaries for a BBDB record. Basically,
- you need to press key{RET}} with the cursor in a BBDB
- record and then add the date in the format code{MM-DD},
- followed by a space and the class of the anniversary (
- samp{wedding}, or a format string). If you omit the class, it will default to
- file{org-bbdb.el} contains more detailed information.
- end example
- After a change to BBDB, or for the first agenda display during an Emacs
- session, the agenda display will suffer a short delay as Org updates its
- hash with anniversaries. However, from then on things will be very fast---much
- faster in fact than a long list of
- subsubheading Appointment reminders
- file{appt.el}
- cindex appointment
- code{org-agenda-to-appt}. This command also lets you filter through the
- list of your appointments and add only those belonging to a specific category
- or matching a regular expression. See the docstring for details.
- subsection The global TODO list
- cindex TODO list, global
- The global TODO list contains all unfinished TODO items formatted and
- collected into a single place.
- kbd
- pxref{Agenda Views}) into a single buffer. By default, this lists
- items with a state the is not a DONE state. The buffer is in
- pxref{Agenda commands}).
- cindex TODO keyword matching
- kbd{C-c a t}. You are
- prompted for a keyword, and you may also specify several keywords by
- separating them with
- code{org-todo-keywords} is selected.
- kbd{r} key in the agenda buffer regenerates it, and you can give
- a prefix argument to this command to change the selected TODO keyword,
- for example
- pxref{Agenda dispatcher}).
- pxref{Tag searches}).
- ref{Agenda commands}.
- itemize
- item
- vindex org-agenda-todo-ignore-deadlines
- vindex org-agenda-todo-ignore-with-date
- Some people view a TODO item that has been
- emph{deadline} (emph{open}.
- Configure the variables
- code{org-agenda-todo-ignore-deadlines},
- code{org-agenda-todo-ignore-with-date} to exclude such items from the global
- TODO list.
- vindex org-agenda-todo-list-sublevels
- TODO items may have sublevels to break up the task into subtasks. In
- such cases it may be enough to list only the highest level TODO headline
- and omit the sublevels from the global list. Configure the variable
- end itemize
- subsection Matching tags and properties
- cindex matching, of properties
- cindex match view
- If headlines in the agenda files are marked with pxref{Tags}),
- or have properties (
- kbd{C-c /
- m}.
- kbd
- samp{+work+urgent-withboss} or
- pxref{Tags}). If you often need a specific search,
- define a custom command for it (
- orgcmd{C-c a M,org-tags-view}
- vindex org-agenda-tags-todo-honor-ignore-options
- Like
- code{org-tags-match-list-sublevels}). To exclude scheduled/deadline items,
- see the variable
- ref{Tag searches}.
- ref{Agenda
- commands}.
- cindex Boolean logic, for tag/property searches
- A search string can use Boolean operators samp{|} for
- OR. samp{|}. Parentheses are currently
- not implemented. Each element in the search is either a tag, a regular
- expression matching tags, or an expression like
- samp{-}, to select against it, and
- samp{&} is optional when
- samp{-} is present. Here are some examples, using only tags.
- samp
- samp{:work:}, but discard those also tagged
- item work|laptop
- Selects lines tagged samp{:laptop:}.
- samp{:laptop:} lines to be tagged also
- end table
- samp{work+}} matches headlines that contain the tag
- i{starting} with
- cindex TODO keyword matching, with tags search
- cindex category, require for tags/property match
- pxref{Properties and Columns}) at the same
- time as matching tags. The properties may be real properties, or special
- properties that represent other metadata (
- code{TODO} represents the TODO keyword of the
- entry. Or, the ``property''
- samp{+LEVEL=3+boss-TODO="DONE"} lists all level three headlines
- that have the tag emph{not} marked with the TODO keyword
- DONE. In buffers with samp{LEVEL} does not
- count the number of stars, but
- table
- item work+TODO="WAITING"
- Select
- samp{WAITING}.
- end table
- When matching properties, a number of different operators can be used to test
- the value of a property. Here is a complex example:
- {Sarah\|Denny
- end example
- itemize
- item
- If the comparison value is a plain number, a numerical comparison is done,
- and the allowed operators are samp{=}, samp{<=},
- samp{<>}.
- item
- If the comparison value is enclosed in double-quotes
- samp{DEADLINE<="<2008-12-24 18:30>"}), both values are
- assumed to be date/time specifications in the standard Org way, and the
- comparison will be done accordingly. Special values that will be recognized
- are code{"<today>"}, and
- : without a time
- specification. Also strings like code{"<-2m>"} with units
- code{w}, code{y} for day, week, month, and year,
- respectively, can be used.
- samp{=} meaning that the
- regexp matches the property value, and
- end itemize
- So the search string in the example finds entries tagged
- samp{:boss:}, which also have a priority value
- samp{:Coffee:} property with the value samp{Effort}
- property that is numerically smaller than 2, a
- samp{Sarah\|Denny}, and that are scheduled
- on or after October 11, 2008.
- Accessing TODO, LEVEL, and CATEGORY during a search is fast. Accessing any
- other properties will slow down the search. However, once you have paid the
- price by accessing one property, testing additional properties is cheap
- again.
- You can configure Org mode to use property inheritance during a search, but
- beware that this can slow down searches considerably. See
- samp{|}) with a
- emph{negative selection} combined with AND can be meaningful. To
- make sure that only lines are checked that actually have any TODO keyword
- (resulting in a speed-up), use
- samp{!}. Using samp{/!} will
- not match TODO keywords in a DONE state. Examples:
- samp
- samp{work+TODO="WAITING"}
- samp{:work:}-tagged TODO lines that are neither
- samp{NEXT}
- samp{:work:}-tagged TODO lines that are either
- samp{NEXT}.
- node Timeline, Search view, Matching tags and properties, Built-in agenda views
- cindex timeline, single file
- emph{time-sorted view}. The main purpose of this command is
- to give an overview over events in a project.
- kbd
- kbd{C-u} prefix, all unfinished TODO entries
- (scheduled or not) are also listed under the current date.
- noindent
- The commands available in the timeline buffer are listed in
- node Search view, Stuck projects, Timeline, Built-in agenda views
- cindex search view
- cindex searching, for text
- This agenda view is a general text search facility for Org mode entries.
- It is particularly useful to find notes.
- kbd
- end table
- For example, the search string
- samp{computer equipment} as a substring. If the two words are
- separated by more space or a line break, the search will still match.
- Search view can also search for specific keywords in the entry, using Boolean
- logic. The search string {8\.11[bg]
- code{computer}
- and code{ethernet}, and which are also
- not matched by the regular expression
- samp{+} is necessary to turn on
- word search, other
- code{org-search-view}.
- code{org-agenda-text-search-extra-files}.
- subsection Stuck projects
- emph{stuck} project is a project that
- has no defined next actions, so it will never show up in the TODO lists
- Org mode produces. During the review, you need to identify such
- projects and define next actions for them.
- kbd
- kindex C-c a !
- vindex org-stuck-projects
- Customize the variable
- end table
- You almost certainly will have to configure this view before it will
- work for you. The built-in default assumes that all your projects are
- level-2 headlines, and that a project is not stuck if it has at least
- one entry marked with a TODO keyword TODO or NEXT or NEXTACTION.
- Let's assume that you, in your own way of using Org mode, identify
- projects with a tag PROJECT, and that you use a TODO keyword MAYBE to
- indicate a project that should not be considered yet. Let's further
- assume that the TODO keyword DONE marks finished projects, and that NEXT
- and TODO indicate next actions. The tag SHOP indicates shopping and
- is a next action even without the NEXT tag. Finally, if the project
- contains the special word IGNORE anywhere, it should not be listed
- either. In this case you would start by identifying eligible projects
- with a tags/todo matchxref{Tag searches}.}
- lisp
- (setq org-stuck-projects
- '("+PROJECT/-MAYBE-DONE" ("NEXT" "TODO") ("@@SHOP")
- "\\<IGNORE\\>"))
- node Presentation and sorting, Agenda commands, Built-in agenda views, Agenda Views
- cindex presentation, of agenda items
- vindex org-agenda-tags-column
- Before displaying items in an agenda view, Org mode visually prepares the
- items and sorts them. Each item occupies a single line. The line starts
- with a emph{category} (
- code{org-agenda-tags-column}. You can
- also customize the prefix using the option
- menu
- * Categories:: Not all tasks are equal
- * Time-of-day specifications:: How the agenda knows the time
- * Sorting of agenda items:: The order of things
- node Categories, Time-of-day specifications, Presentation and sorting, Presentation and sorting
- cindex category
- footnote{For
- backward compatibility, the following also works: if there are several
- such lines in a file, each specifies the category for the text below it.
- The first category also applies to any text before the first CATEGORY
- line. However, using this method is
- example
- #+CATEGORY: Thesis
- noindent
- code{:CATEGORY:} property with the
- special category you want to apply as the value.
- noindent
- You can set up icons for category by customizing the
- node Time-of-day specifications, Sorting of agenda items, Categories, Presentation and sorting
- cindex time-of-day specification
- Org mode checks each agenda item for a time-of-day specification. The
- time can be part of the timestamp that triggered inclusion into the
- agenda, for example as in samp{<2005-05-10 Tue 19:00>}}. Time
- ranges can be specified with two timestamps, like
- w{
- samp{12:45} or a
- pxref{Weekly/daily agenda}), time
- specifications in diary entries are recognized as well.
- For agenda display, Org mode extracts the time and displays it in a
- standard 24 hour format as part of the prefix. The example times in
- the previous paragraphs would end up in the agenda like this:
- end example
- example
- 8:00...... ------------------
- 8:30-13:00 Arthur Dent lies in front of the bulldozer
- 10:00...... ------------------
- 12:00...... ------------------
- 12:45...... Ford Prefect arrives and takes Arthur to the pub
- 14:00...... ------------------
- 16:00...... ------------------
- 18:00...... ------------------
- 19:00...... The Vogon reads his poem
- 20:00...... ------------------
- 20:30-22:15 Marvin escorts the Hitchhikers to the bridge
- vindex org-agenda-use-time-grid
- code{org-agenda-use-time-grid}, and can be configured with
- node Sorting of agenda items, , Time-of-day specifications, Presentation and sorting
- cindex sorting, of agenda items
- itemize
- item
- emph{schedule} for the day. After that, items remain
- grouped in categories, in the sequence given by
- pxref{Priorities}),
- which is composed of the base priority (2000 for priority
- samp{B}, and 0 for
- item
- For the TODO list, items remain in the order of categories, but within
- each category, sorting takes place according to priority
- (
- item
- For tags matches, items are not sorted at all, but just appear in the
- sequence in which they are found in the agenda files.
- vindex org-agenda-sorting-strategy
- Sorting can be customized using the variable
- pxref{Effort estimates}).
- section Commands in the agenda buffer
- table
- tsubheading{Motion}
- orgcmd{n,org-agenda-next-line}
- Next line (same as kbd{C-p}).
- key{down} and
- tsubheading{View/Go to Org file}
- key{SPC},mouse-3,org-agenda-show-and-scroll-up}
- Display the original location of the item in another window.
- With prefix arg, make sure that the entire entry is made visible in the
- outline, not only the heading.
- orgcmd{L,org-agenda-recenter}
- Display original location and recenter that window.
- orgcmdkkc{
- c
- key{RET},org-agenda-switch-to}
- Go to the original location of the item and delete other windows.
- orgcmd{F,org-agenda-follow-mode}
- code{org-agenda-start-with-follow-mode}.
- orgcmd{C-c C-x b,org-agenda-tree-to-indirect-buffer}
- Display the entire subtree of the current item in an indirect buffer. With a
- numeric prefix argument N, go up to level N and then take that tree. If N is
- negative, go up that many levels. With a
- orgcmd{C-c C-o,org-agenda-open-link}
- Follow a link in the entry. This will offer a selection of any links in the
- text belonging to the referenced Org node. If there is only one link, it
- will be followed without a selection prompt.
- cindex display changing, in agenda
- item A
- Interactively select another agenda view and append it to the current view.
- kindex o
- c
- xorgcmdkskc{v w,w,org-agenda-day-view}
- xorgcmd{v y,org-agenda-month-year}
- vindex org-agenda-span
- Switch to day/week/month/year view. When switching to day or week view, this
- setting becomes the default for subsequent agenda refreshes. Since month and
- year views are slow to create, they do not become the default. A numeric
- prefix argument may be used to jump directly to a specific day of the year,
- ISO week, month, or year, respectively. For example,
- kbd{9 w} to ISO week number 9. When setting day, week, or
- month view, a year may be encoded in the prefix argument as well. For
- example,
- kbd{v
- code{org-agenda-span}.
- orgcmd{f,org-agenda-later}
- Go forward in time to display the following
- code{org-agenda-current-span} days.
- orgcmd{b,org-agenda-earlier}
- Go backward in time to display earlier dates.
- orgcmd{.,org-agenda-goto-today}
- Go to today.
- orgcmd{j,org-agenda-goto-date}
- Prompt for a date and go there.
- orgcmd{J,org-agenda-clock-goto}
- Go to the currently clocked-in task
- c
- ref{Weekly/daily agenda}.
- orgcmdkskc{v l,l,org-agenda-log-mode}
- vindex org-log-done
- code{org-log-done}) are shown in the agenda, as are
- entries that have been clocked on that day. You can configure the entry
- types that should be included in log mode using the variable
- kbd{C-u} prefix, show
- all possible logbook entries, including state changes. When called with two
- prefix args
- kbd{v L} is equivalent to
- c
- c
- xorgcmd{v A,org-agenda-archives-mode 'files}
- Toggle Archives mode. In Archives mode, trees that are marked
- kbd{A}, even all archive files are included. To exit archives mode,
- press
- c
- vindex org-agenda-start-with-clockreport-mode
- code{org-agenda-start-with-clockreport-mode}. By using a prefix argument
- when toggling this mode (i.e.kbd{C-u R}), the clock table will not show
- contributions from entries that are hidden by agenda filtering
- code{org-clock-report-include-clocking-task}.
- orgkey{v c}
- code{org-agenda-clock-consistency-checks} for
- information on how to customize the definition of what constituted a clocking
- problem. To return to normal agenda display, press
- c
- vindex org-agenda-start-with-entry-text-mode
- code{org-agenda-entry-text-maxlines}. Calling this command with a numeric
- prefix argument will temporarily modify that number to the prefix value.
- orgcmd{G,org-agenda-toggle-time-grid}
- vindex org-agenda-time-grid
- Toggle the time grid on and off. See also the variables
- code{org-agenda-time-grid}.
- orgcmd{r,org-agenda-redo}
- Recreate the agenda buffer, for example to reflect the changes after
- modification of the timestamps of items with key{left}} and
- key{right}}. When the buffer is the global TODO list, a prefix
- argument is interpreted to create a selective list for a specific TODO
- keyword.
- kbd{r}.
- orgcmdkskc{C-x C-s,s,org-save-all-org-buffers}
- Save all Org buffers in the current Emacs session, and also the locations of
- IDs.
- orgcmd{C-c C-x C-c,org-agenda-columns}
- pxref{Column view}) in the agenda buffer. The column
- view format is taken from the entry at point, or (if there is no entry at
- point), from the first entry in the agenda view. So whatever the format for
- that entry would be in the original buffer (taken from a property, from a
- code{org-columns-default-format}), will be used in the agenda.
- pxref{Agenda files}).
- cindex filtering, by tag category and effort, in agenda
- cindex category filtering, in agenda
- cindex query editing, in agenda
- vindex org-agenda-category-filter-preset
- Filter the current agenda view with respect to the category of the item at
- point. Pressing
- code{org-agenda-category-filter-preset}
- (see below.)
- vindex org-agenda-tag-filter-preset
- Filter the current agenda view with respect to a tag and/or effort estimates.
- The difference between this and a custom agenda command is that filtering is
- very fast, so that you can switch quickly between different filters without
- having to recreate the agenda.
- code{org-agenda-tag-filter-preset} as an option. This
- filter will then be applied to the view and persist as a basic filter through
- refreshes and more secondary filtering. The filter is a global property of
- the entire agenda view---in a block agenda, you should only set this in the
- global options section, not in the section of an individual block.}
- You will be prompted for a tag selection letter;
- key{TAB} at that prompt will offer use completion to select a
- tag (including any tags that do not have a selection character). The command
- then hides all entries that do not contain or inherit this tag. When called
- with prefix arg, remove the entries that
- kbd{/} at the prompt will turn off the filter and unhide any hidden entries.
- If the first key you press is either kbd{-}, the previous filter
- will be narrowed by requiring or forbidding the selected additional tag.
- Instead of pressing kbd{-} after
- kbd{\} command.
- lisp
- (setq org-global-properties
- '(("Effort_ALL". "0 0:10 0:30 1:00 2:00 3:00 4:00")))
- kbd{<}, kbd{=}, and then the one-digit index of an effort
- estimate in your array of allowed values, where
- kbd{<} will be assumed. For
- application of the operator, entries without a defined effort will be treated
- according to the value of
- kbd{?} as the operator.
- Org also supports automatic, context-aware tag filtering. If the variable
- kbd{/} command then accepts
- code{Net} tag to identify tasks which need network access, an
- code{Call} tag for making phone
- calls. You could auto-exclude these tags based on the availability of the
- Internet, and outside of business hours, with something like this:
- group
- (defun org-my-auto-exclude-function (tag)
- (and (cond
- ((string= tag "Net")
- (/= 0 (call-process "/sbin/ping" nil nil nil
- "-c1" "-q" "-t1" "mail.gnu.org")))
- ((or (string= tag "Errand") (string= tag "Call"))
- (let ((hour (nth 2 (decode-time))))
- (or (< hour 8) (> hour 21)))))
- (concat "-" tag)))
- (setq org-agenda-auto-exclude-function 'org-my-auto-exclude-function)
- end lisp
- emph{do} have the tag, or that do match
- the effort criterion. You can achieve the same effect by pressing
- kbd{-} as the first key after the
- c
- kindex ]
- {
- }
- {
- table
- item
- kbd{[} and
- kbd{kbd{
- samp{+}, indicating that this search
- term
- i{must not} occur/match in the entry for it to be
- selected.
- tsubheading{Remote editing}
- item 0-9
- Digit argument.
- cindex undoing remote-editing events
- orgcmd{C-_,org-agenda-undo}
- Undo a change due to a remote editing command. The change is undone
- both in the agenda buffer and in the remote buffer.
- orgcmd{t,org-agenda-todo}
- Change the TODO state of the item, both in the agenda and in the
- original org file.
- orgcmd{C-S-
- orgcmd{C-S-
- c
- vindex org-agenda-confirm-kill
- Delete the current agenda item along with the entire subtree belonging
- to it in the original Org file. If the text to be deleted remotely
- is longer than one line, the kill needs to be confirmed by the user. See
- variable
- c
- c
- vindex org-archive-default-command
- Archive the subtree corresponding to the entry at point using the default
- archiving command set in
- code{a} key, confirmation will be required.
- orgcmd{C-c C-x a,org-agenda-toggle-archive-tag}
- Toggle the ARCHIVE tag for the current headline.
- orgcmd{C-c C-x A,org-agenda-archive-to-archive-sibling}
- Move the subtree corresponding to the current entry to its
- c
- c
- vindex org-agenda-show-inherited-tags
- Show all tags associated with the current item. This is useful if you have
- turned off
- c
- c
- item ,
- Set the priority for the current item (
- key{SPC},
- the priority cookie is removed from the entry.
- orgcmd{P,org-agenda-show-priority}
- Display weighted priority of current item.
- orgcmdkkc{+,S-
- kbd{r}
- key for this.
- orgcmdkkc{-,S-
- c
- vindex org-log-into-drawer
- Add a note to the entry. This note will be recorded, and then filed to the
- same location where state change notes are put. Depending on
- c
- c
- c
- c
- example
- m
- r{in Org files with
- r{Set the deadline of the marked entry to the date at point.}
- s
- r{Call
- end example
- kbd{r} afterward to refresh the agenda and see the effect of the
- command.
- orgcmd{S-
- *
- With a numeric prefix argument, change it by that many days. For example,
- key{right}} will change it by a year. With a
- kbd{C-u
- C-u} prefix, do the same for changing minutes.
- kbd{r} or
- c
- key{left},org-agenda-do-date-earlier}
- Change the timestamp associated with the current line by one day
- into the past.
- orgcmd{>,org-agenda-date-prompt}
- Change the timestamp associated with the current line. The key
- kbd{S-.} on my keyboard.
- orgcmd{I,org-agenda-clock-in}
- Start the clock on the current item. If a clock is running already, it
- is stopped first.
- orgcmd{O,org-agenda-clock-out}
- Stop the previously started clock.
- orgcmd{X,org-agenda-clock-cancel}
- Cancel the currently running clock.
- orgcmd{J,org-agenda-clock-goto}
- Jump to the running clock in another window.
- cindex remote editing, bulk, from agenda
- c
- c
- c
- c
- kbd{B}
- will be passed through to the kbd{d} commands, to bulk-remove
- these special timestamps.
- r{Prompt for a single refile target and move all entries. The entries}
- kbd{g}) to bring them back.}
- $
- r{Archive entries by moving them to their respective archive siblings.}
- t
- r{changes the state of all selected entries, bypassing blocking and}
-
- r{Add a tag to all selected entries.}
- -
- r{Schedule all items to a new date. To shift existing schedule dates}
-
- r{at the prompt, for example samp{++2w}.}
- S
- r{With prefix arg (
- r{Set deadline to a specific date.}
- f
- r{For example, the function below sets the CATEGORY property of the}
-
- r{(defun set-category ()}
-
- r{ (let* ((marker (or (org-get-at-bol 'org-hd-marker)}
-
- r{ (buffer (marker-buffer marker)))}
-
- r{ (save-excursion}
-
- r{ (widen)}
-
- r{ (org-back-to-heading t)}
-
- end example
- cindex calendar commands, from agenda
- c
- c
- orgcmd{i,org-agenda-diary-entry}
- footnote{This file is parsed for the agenda when
- kbd{i}
- command in the calendar. The diary file will pop up in another window, where
- you can add the entry.
- If you configure
- code{DATE_TREE} property, or else with years as
- top-level entries. Emacs will prompt you for the entry text---if you specify
- it, the entry will be created in
- key{RET} at the prompt without typing
- text, the target file will be shown in another window for you to finish the
- entry there. See also the
- c
- c
- c
- c
- item M-x org-export-icalendar-combine-agenda-files
- Export a single iCalendar file containing entries from all agenda files.
- This is a globally available command, and also available in the agenda menu.
- orgcmd{C-x C-w,org-write-agenda}
- cindex agenda views, exporting
- file{.html} or
- file{.ps}), PDF (extension
- kbd{C-u} prefix
- argument, immediately open the newly created file. Use the variable
- file{ps-print} and
- for
- tsubheading{Quit and Exit}
- c
- orgcmd{x,org-agenda-exit}
- Exit agenda, remove the agenda buffer and all buffers loaded by Emacs
- for the compilation of the agenda. Buffers created by the user to
- visit Org files will not be removed.
- node Custom agenda views, Exporting Agenda Views, Agenda commands, Agenda Views
- cindex custom agenda views
- pxref{Agenda dispatcher}), just like the default commands.
- end menu
- subsection Storing searches
- The first application of custom searches is the definition of keyboard
- shortcuts for frequently used searches, either creating an agenda
- buffer, or a sparse tree (the latter covering of course only the current
- buffer).
- vindex org-agenda-custom-commands
- Custom commands are configured in the variable
- kbd{C-c a C}. You can also directly set it with
- Emacs Lisp in
- lisp
- end group
- noindent
- The initial string in each entry defines the keys you have to press
- after the dispatcher command
- footnote{You can provide a description for a prefix key by
- inserting a cons cell with the prefix and the description.}. The second
- parameter is the search type, followed by the string or regular
- expression to be used for the matching. The example above will
- therefore define:
- kbd
- samp{WAITING} as the TODO
- keyword
- item C-c a u
- as a global tags search for headlines marked
- samp{:urgent:}
- kbd{C-c a u}, but limiting the search to
- headlines that are also TODO items
- kbd{C-c a u}, but only in the current buffer and
- displaying the result as a sparse tree
- samp{FIXME}
- kbd{l}, kbd{k}) to select a name (Lisa,
- Peter, or Kim) as additional tag to match.
- node Block agenda, Setting Options, Storing searches, Custom agenda views
- cindex block agenda
- emph{several} commands, each of which creates a block in
- the agenda buffer. The available commands include
- kbd{C-c a a}),
- kbd{C-c a t}), and the
- matching commands discussed above: code{tags}, and
- lisp
- end group
- noindent
- This will define
- samp{home}, and also all lines tagged with
- kbd{C-c a o} provides a similar view for office tasks.
- subsection Setting options for custom commands
- vindex org-agenda-custom-commands
- Org mode contains a number of variables regulating agenda construction
- and display. The global variables define the behavior for all agenda
- commands, including the custom commands. However, if you want to change
- some settings just for a single custom view, you can do so. Setting
- options requires inserting a list of variable names and values at the
- right spot in
- lisp
- end group
- noindent
- Now the
- samp{ Mixed: }
- instead of giving the category of the entry. The sparse tags tree of
- kbd{C-c a N} will do a text search limited
- to only a single file.
- code{org-agenda-custom-commands} has two separate spots for setting
- options. You can add options that should be valid for just a single
- command in the set, and options that should be valid for all commands in
- the set. The former are just added to the command entry; the latter
- must come after the list of command entries. Going back to the block
- agenda example (
- kbd{C-c a h} commands to
- code{priority-up}. This would look like this:
- group
- (setq org-agenda-custom-commands
- '(("h" "Agenda and Home-related tasks"
- ((agenda)
- (tags-todo "home")
- (tags "garden"
- ((org-agenda-sorting-strategy '(priority-up)))))
- ((org-agenda-sorting-strategy '(priority-down))))
- ("o" "Agenda and Office-related tasks"
- ((agenda)
- (tags-todo "work")
- (tags "office")))))
- end lisp
- As you see, the values and parentheses setting is a little complex.
- When in doubt, use the customize interface to set this variable---it
- fully supports its structure. Just one caveat: when setting options in
- this interface, the
- node Exporting Agenda Views, Agenda column view, Custom agenda views, Agenda Views
- cindex agenda views, exporting
- If you are away from your computer, it can be very useful to have a printed
- version of some agenda views to carry around. Org mode can export custom
- agenda views as plain text, HTML
- file{htmlize.el}.}, Postscript, PDF
- file{ps2pdf} utility must be installed on the system. Selecting
- a PDF file will also create the postscript file.}, and iCalendar files. If
- you want to do this only occasionally, use the command
- kbd
- cindex exporting agenda views
- vindex org-agenda-exporter-settings
- Write the agenda view to a file. Depending on the extension of the selected
- file name, the view will be exported as HTML (extension
- file{.htm}), Postscript (extension
- file{.ics}), or plain text (any other extension). Use the variable
- file{ps-print} and
- for
- vindex org-agenda-add-entry-text-maxlines
- vindex ps-number-of-columns
- lisp
- (setq org-agenda-exporter-settings
- '((ps-number-of-columns 2)
- (ps-landscape-mode t)
- (org-agenda-add-entry-text-maxlines 5)
- (htmlize-output-type 'css)))
- end table
- If you need to export certain agenda views frequently, you can associate
- any custom agenda command with a list of output file names
- lisp
- end group
- file{.html}, Org mode will use the
- file{.ps},
- file{.ics}, iCalendar export is
- run export over all files that were used to construct the agenda, and
- limit the export to entries listed in the agenda. Any other
- extension produces a plain ASCII file.
- The export files are
- emph{all} specified
- files in one step:
- kbd
- end table
- You can use the options section of the custom agenda commands to also
- set options for the export commands. For example:
- end lisp
- code{org-agenda-exporter-settings} will also apply, but the settings
- in
- noindent
- From the command line you may also use
- end example
- footnote{Quoting depends on the
- system you use, please check the FAQ for examples.}
- end example
- file{~/org/project.org}, without diary entries and with a 30-day
- extent.
- You can also extract agenda information in a way that allows further
- processing by other programs. See
- node Agenda column view, , Exporting Agenda Views, Agenda Views
- cindex column view, in agenda
- pxref{Column view}) is normally used to view and edit
- properties embedded in the hierarchical structure of an Org file. It can be
- quite useful to use column view also from the agenda, where entries are
- collected by certain criteria.
- kbd
- end table
- To understand how to use this properly, it is important to realize that the
- entries in the agenda are no longer in their proper outline environment.
- This causes the following issues:
- item
- vindex org-overriding-columns-format
- Org needs to make a decision which
- code{COLUMNS} formats, this is a non-trivial problem.
- Org first checks if the variable
- code{org-columns-default-format}.
- cindex property, special, CLOCKSUM
- If any of the columns has a summary type defined (
- code{CLOCKSUM} property. Org will then sum the
- values displayed in the agenda. In the daily/weekly agenda, the sums will
- cover a single day; in all other views they cover the entire block. It is
- vital to realize that the agenda may show the same entry
- emph{parent} and its
- item
- When the column view in the agenda shows the
- kbd{R} in
- the agenda).
- node Markup, Exporting, Agenda Views, Top
- LaTeX{}, or DocBook allow much richer formatting,
- Org mode has rules on how to prepare text for rich export. This section
- summarizes the markup rules used in an Org mode buffer.
- LaTeX{}:: LaTeX can be freely used inside Org documents
- node Structural markup elements, Images and tables, Markup, Markup
- menu
- * Document title:: Where the title is taken from
- * Headings and sections:: The document structure as seen by the exporter
- * Table of contents:: The if and where of the table of contents
- * Initial text:: Text before the first heading?
- * Lists:: Lists
- * Paragraphs:: Paragraphs
- * Footnote markup:: Footnotes
- * Emphasis and monospace:: Bold, italic, etc.
- * Horizontal rules:: Make a line
- * Comment lines:: What will *not* be exported
- node Document title, Headings and sections, Structural markup elements, Structural markup elements
- cindex document title, markup rules
- cindex #+TITLE
- end example
- cindex property, EXPORT_TITLE
- If you are exporting only a subtree by marking is as the region, the heading
- of the subtree will become the title of the document. If the subtree has a
- property
- node Headings and sections, Table of contents, Document title, Structural markup elements
- cindex headings and sections, markup rules
- ref{Document
- Structure}, forms the basis for defining sections of the exported document.
- However, since the outline structure is also used for (for example) lists of
- tasks, only the first three outline levels will be used as headings. Deeper
- levels will become itemized lists. You can change the location of this
- switch globally by setting the variable
- cindex #+OPTIONS
- end example
- subheading Table of contents
- vindex org-export-with-toc
- The table of contents is normally inserted directly before the first headline
- of the file. If you would like to get it to a different location, insert the
- string
- code{org-export-with-toc}, or on a per-file basis with a line like
- end example
- subheading Text before the first headline
- cindex #+TEXT
- Org mode normally exports the text before the first headline, and even uses
- the first line as the document title. The text will be fully marked up. If
- you need to include literal HTML,
- vindex org-export-skip-text-before-1st-heading
- Some people like to use the space before the first headline for setup and
- internal links and therefore would like to control the exported text before
- the first headline in a different way. You can do so by setting the variable
- code{t}. On a per-file
- basis, you can get the same effect with
- noindent
- If you still want to have some text before the first headline, use the
- example
- #+OPTIONS: skip:t
- #+TEXT: This text will go before the *first* headline.
- #+TEXT: [TABLE-OF-CONTENTS]
- #+TEXT: This goes between the table of contents and the *first* headline
- node Lists, Paragraphs, Initial text, Structural markup elements
- cindex lists, markup rules
- Plain lists as described in
- node Paragraphs, Footnote markup, Lists, Structural markup elements
- cindex paragraphs, markup rules
- Paragraphs are separated by at least one empty line. If you need to enforce
- a line break within a paragraph, use
- cindex #+BEGIN_VERSE
- end example
- When quoting a passage from another document, it is customary to format this
- as a paragraph that is indented on both the left and the right margin. You
- can include quotations in Org mode documents like this:
- example
- #+BEGIN_QUOTE
- Everything should be made as simple as possible,
- but not any simpler -- Albert Einstein
- #+END_QUOTE
- cindex #+BEGIN_CENTER
- end example
- subheading Footnote markup
- cindex
- ref{Footnotes}, will be exported
- by all backends. Org allows multiple references to the same note, and
- multiple footnotes side by side.
- subheading Emphasis and monospace
- cindex bold text, markup rules
- cindex verbatim text, markup rules
- cindex strike-through text, markup rules
- You can make words i{/italic/}, _underlined_,
- code{~verbatim~}, and, if you must,
- node Horizontal rules, Comment lines, Emphasis and monospace, Structural markup elements
- cindex horizontal rules, markup rules
- A line consisting of only dashes, and at least 5 of them, will be exported as
- a horizontal line (code{\hrule} in
- node Comment lines, , Horizontal rules, Structural markup elements
- cindex comment lines
- cindex #+BEGIN_COMMENT
- Lines starting with
- samp{#+ }. Also entire subtrees starting with the word
- samp{#+BEGIN_COMMENT} ...
- table
- kindex C-c ;
- end table
- section Images and Tables
- cindex #+CAPTION
- pxref{Tables}) and tables formatted with
- the
- code{\ref}}:
- end example
- Optionally, the caption can take the form:
- {Caption for table (or link).
- end example
- LaTeX{}, and DocBook) allow you to directly include
- images into the exported document. Org does this, if a link to an image
- files does not have a description part, for example
- code{#+CAPTION} and
- example
- #+CAPTION: This is the caption for the next figure link (or table)
- #+LABEL: fig:SED-HR4049
- [[./img/a.jpg]]
- xref{Handling links,the discussion of image links}.
- section Literal examples
- cindex code line references, markup rules
- You can include literal examples that should not be subjected to
- markup. Such examples will be typeset in monospace, so this is well suited
- for source code and similar examples.
- example
- #+BEGIN_EXAMPLE
- Some example from a text file.
- #+END_EXAMPLE
- i{indented} in order to align nicely with
- indented text and in particular with plain list structure (
- example
- Here is an example
- : Some example from a text file.
- cindex formatting source code, markup rules
- If the example is source code from a programming language, or any other text
- that can be marked up by font-lock in Emacs, you can ask for the example to
- look like the fontified Emacs buffer
- file{htmlize.el} package,
- which is distributed with Org). Fontified code chunks in
- url{http://code.google.com/p/minted, minted,} package. To use listings, turn
- on the variable
- LaTeX{} header (e.g.
- code{org-export-latex-packages-alist}). See the listings documentation for
- configuration options, including obtaining colored output. For minted it is
- necessary to install the program
- code{org-export-latex-minted}, ensuring that the minted
- package is included by the
- code{-shell-escape} option is passed to
- code{org-latex-to-pdf-process}). See the documentation of the variables
- code{org-export-latex-minted} for
- further details.}. This is done with the
- footnote{Code in
- pxref{Working With Source Code} for more
- information on evaluating code blocks.}, see
- cindex #+BEGIN_SRC
- end example
- Both in code{src} snippets, you can add a
- code{BEGIN} line, to get the lines of the example
- numbered. If you use a
- samp{(ref:name)} as labels, and use them as
- targets for special hyperlinks like : the reference name
- enclosed in single parenthesis). In HTML, hovering the mouse over such a
- link will remote-highlight the corresponding code line, which is kind of
- cool.
- You can also add a i{removes} the labels from the
- source codecode{-k} to i{keep} the
- labels in the source code while using line numbers for the links, which might
- be useful to explain those in an Org mode example code.}. With the
- example
- #+BEGIN_SRC emacs-lisp -n -r
- (save-excursion (ref:sc)
- (goto-char (point-min)) (ref:jump)
- #+END_SRC
- In line [[(sc)]] we remember the current position. [[(jump)][Line (jump)]]
- jumps to point-min.
- vindex org-coderef-label-format
- If the syntax for the label format conflicts with the language syntax, use a
- samp{#+BEGIN_SRC pascal
- -n -r -l "((%s))"}. See also the variable
- pxref{Text
- areas in HTML export}).
- Because the code{#+END_...} patterns need to be added
- so often, shortcuts are provided using the Easy Templates facility
- (
- table
- kindex C-c '
- kbd{C-c '} againsamp{*}
- or
- kbd{C-c '}, and also for export.}. The edited version will
- then replace the old version in the Org buffer. Fixed-width regions
- (where each line starts with a colon followed by a space) will be edited
- using footnote{You may select a different-mode with the
- variable
- kindex C-c l
- code{org-store-link} while editing a source code example in a
- temporary buffer created with
- samp{(ref:label)} at the end of the current line. Then the
- label is stored as a link kbd{C-c C-l}.
- node Include files, Index entries, Literal examples, Markup
- cindex include files, markup rules
- During export, you can include the content of another file. For example, to
- include your
- cindex #+INCLUDE
- end example
- :
- samp{example}, or samp{src}, the
- language for formatting the contents. The markup is optional; if it is not
- given, the text will be assumed to be in Org mode format and will be
- processed normally. The include line will also allow additional keyword
- parameters code{:prefix} to specify prefixes for the
- first line and for each following line,
- example
- #+INCLUDE: "~/snippets/xx" :prefix1 " + " :prefix " "
- code{:lines} parameter. The line at the upper end of the range will not
- be included. The start and/or the end of the range may be omitted to use the
- obvious defaults.
- r{Include lines 5 to 10, 10 excluded}
- #+INCLUDE: "~/.emacs" :lines "-10"
- r{Include lines from 10 to EOF}
- table
- kindex C-c '
- end table
- section Index entries
- code{#+INDEX}. An entry
- the contains an exclamation mark will create a sub item. See
- example
- * Curriculum Vitae
- #+INDEX: CV
- #+INDEX: Application!CV
- node Macro replacement, Embedded
- section Macro replacement
- cindex #+MACRO
- You can define text snippets with
- end example
- code{{}}}. In addition to
- defined macros, {{title}code{{}}}, etc.,
- will reference information set by the code{#+AUTHOR:}, and
- similar lines. Also, {{date(}}} and
- {{modification-time(}}} refer to current date time
- and to the modification time of the file being exported, respectively.
- code{format-time-string}.
- Macro expansion takes place during export, and some people use it to
- construct complex HTML code.
- LaTeX{}, , Macro replacement, Markup
- LaTeX{}
- TeX{} interpretation
- LaTeX{} interpretation
- Plain ASCII is normally sufficient for almost all note taking. Exceptions
- include scientific notes, which often require mathematical symbols and the
- occasional formula. footnote{
- TeX{} system. Many of the features described here as
- ``TeX{}, but for simplicity I am blurring this
- distinction.} is widely used to typeset scientific documents. Org mode
- supports embedding
- LaTeX{} source code, and because it can be
- readily processed to produce pretty output for a number of export backends.
- LaTeX{} fragments:: Complex formulas made easy
- * Previewing
- end menu
- LaTeX{}, Embedded
- subsection Special symbols
- cindex special symbols
- TeX{} macros
- LaTeX{} fragments, markup rules
- cindex
- LaTeX{} macros to insert special symbols like
- samp{\to} to indicate an arrow. Completion
- for these macros is available, just type
- kbd{M-LaTeX{}
- code, Org mode allows these macros to be present without surrounding math
- delimiters, for example:
- end example
- code{\alpha} will be exported as
- code{$\alpha$} in the
- code{\nbsp} will become
- code{~} in
- samp{\Aacute}stor}.
- A large number of entities is provided, with names taken from both HTML and
- code{org-entities} for the complete list.
- samp{--},
- samp{...} are all converted into special commands creating hyphens of
- different lengths or a compact set of dots.
- If you would like to see entities displayed as UTF8 characters, use the
- following command
- code{org-pretty-entities}, or on a per-file base with the
- code{entitiespretty}.}:
- kbd
- item C-c C-x \
- Toggle display of entities as UTF-8 characters. This does not change the
- buffer content which remains plain ASCII, but it overlays the UTF-8 character
- for display purposes only.
- node Subscripts and superscripts, LaTeX{}
- cindex subscript
- LaTeX{}, samp{_} are used to indicate super-
- and subscripts. Again, these can be used without embedding them in
- math-mode delimiters. To increase the readability of ASCII text, it is
- not necessary (but OK) to surround multi-character sub- and superscripts
- with curly braces. For example
- {sun
- end example
- samp{^} and
- samp{\^} and
- code{org-export-with-sub-superscripts} to globally change this
- convention, or use, on a per-file basis:
- {
- end example
- samp{a_b} will not be interpreted as a
- subscript, but {b
- table
- kindex C-c C-x \
- end table
- LaTeX{} fragments, Previewing LaTeX{}
- LaTeX{} fragments
- LaTeX{} fragments
- LaTeX{} math fragments, and it supports ways
- to process these for several export backends. When exporting to
- uref{http://www.mathjax.org, MathJax library} (
- footnote{If you plan to use
- this regularly or on pages with significant page views, you should install
- footnote{For this to work
- you need to be on a system with a working
- file{dvipng} program, available at
- LaTeX{} header that will
- be used when processing a fragment can be configured with the variable
- LaTeX{} fragments don't need any special marking at all. The following
- snippets will be identified as
- itemize
- item
- Environments of any kindfile{MathJax} is used, only the
- environment recognized by
- file{dvipng} is used to create images, any
- code{\begin} statement appears
- on a new line, preceded by only whitespace.
- LaTeX{} math delimiters. To avoid conflicts with
- currency specifications, single
- samp{$} characters with no whitespace in between,
- and if the closing
- samp{\(...\)} as inline math delimiters.
- noindent For example:
- {equation
- {b
- {equation
- {2{2
- end example
- vindex org-format-latex-options
- If you need any of the delimiter ASCII sequences for other purposes, you
- can configure the option
- LaTeX{} converter.
- LaTeX{} processing can be configured with the variable
- code{t}
- which means
- LaTeX{} backends. You can also set this variable on a per-file basis using one
- of these lines:
- r{Do the right thing automatically (MathJax)}
- #+OPTIONS: LaTeX:dvipng
- r{Do not process
- r{Verbatim export, for jsMath or so}
- node Previewing LaTeX{} fragments, Embedded
- subsection Previewing
- cindex
- file{dvipng} installed,
- table
- kindex C-c C-x C-l
- LaTeX{} fragment at point and overlay it
- over the source code. If there is no fragment at point, process all
- fragments in the current entry (between two headlines). When called
- with a prefix argument, process the entire subtree. When called with
- two prefix arguments, or when the cursor is before the first headline,
- process the entire buffer.
- item C-c C-c
- Remove the overlay preview images.
- vindex org-format-latex-options
- You can customize the variable
- code{:scale} (and for HTML
- export,
- node CDLaTeX mode, , Previewing LaTeX{}
- LaTeX{} to enter math
- LaTeX{}
- CD
- LaTeX{} mode like AUC
- LaTeX{} mode. You need to install
- file{texmathp.el} (the latter comes also with
- AUCurl{http://www.astro.uva.nl/~dominik/Tools/cdlatex}.
- Don't use CD
- code{org-cdlatex-mode} that comes as part of Org mode. Turn it
- on for the current buffer with
- lisp
- (add-hook 'org-mode-hook 'turn-on-org-cdlatex)
- LaTeX{} mode):
- bullet
- {
- kbd{C-c
- item
- key{TAB}
- The
- LaTeX{} fragment
- code{org-inside-LaTeX-fragment-p}.}. For example,
- code{fr} to {{
- key{TAB} will get you into
- the second brace. Even outside fragments,
- samp{equ} at the beginning of a line and press
- code{equation} environment.
- To get a list of all abbreviations, type
- item
- kindex ^
- kbd{_} and LaTeX{} fragment will insert these
- characters together with a pair of braces. If you use
- code{cdlatex-simplify-sub-super-scripts}).
- kindex `
- Pressing the backquote
- LaTeX{} fragments. If you wait more than 1.5 seconds
- after the backquote, a help window will pop up.
- kindex '
- Pressing the single-quote
- LaTeX{} fragments; outside the quote
- is normal.
- node Exporting, Publishing, Markup, Top
- cindex exporting
- Org mode documents can be exported into a variety of other formats. For
- printing and sharing of notes, ASCII export produces a readable and simple
- version of an Org file. HTML export allows you to publish a notes file on
- the web, while the XOXO format provides a solid base for exchange with a
- broad range of other applications.
- LaTeX{} files. DocBook
- export makes it possible to convert Org files to many other formats using
- DocBook tools. OpenDocument Text(
- code{transient-mark-mode} is
- enabled (default in Emacs 23).
- LaTeX{} and PDF export:: Exporting to
- end menu
- section Selective export
- vindex org-export-select-tags
- cindex org-export-with-tasks
- You may use tags to select the parts of a document that should be exported,
- or to exclude parts from export. This behavior is governed by two variables:
- code{org-export-exclude-tags},
- respectively defaulting to code{'(:noexport:)}.
- item
- Org first checks if any of the
- item
- If none of the select tags is found, the whole buffer will be selected for
- export.
- emph{exclude} tags will
- be removed from the export buffer.
- code{org-export-with-tasks} can be configured to select which
- kind of tasks should be included for export. See the docstring of the
- variable for more information.
- section Export options
- cindex completion, of option keywords
- The exporter recognizes special lines in the buffer which provide
- additional information. These lines may be put anywhere in the file.
- The whole set of lines can be inserted into the buffer with
- samp{#+} and then use key{TAB}} completion
- (
- ref{In-buffer settings}.
- In particular, note that you can place commonly-used (export) options in
- a separate file which can be included using
- table
- orgcmd{C-c C-e t,org-insert-export-options-template}
- Insert template with export options, see example below.
- cindex #+TITLE
- cindex #+DATE
- cindex #+DESCRIPTION
- cindex #+LANGUAGE
- cindex #+OPTIONS
- cindex #+LINK_UP
- cindex #+EXPORT_SELECT_TAGS
- cindex #+XSLT
- vindex user-full-name
- vindex org-export-default-language
- example
- #+TITLE: the title to be shown (default is the buffer name)
- #+AUTHOR: the author (default taken from
- footnote{code{format-time-string}
- #+EMAIL: his/her email address (default from
- : for the XHTML meta tag
- #+KEYWORDS: the page keywords, e.g.
- : code{org-export-default-language})
- #+TEXT: Some descriptive text to be inserted at the beginning.
- #+TEXT: Several lines may be given.
- #+OPTIONS: H:2 num:t toc:t \n:nil :t ::t |:t ^:t f:t TeX:t ...
- #+BIND: lisp-var lisp-val, e.g.code{org-export-latex-low-levels itemize}
- code{org-export-allow-BIND}}
- #+LINK_UP: the ``up'' link of an exported page
- #+LINK_HOME: the ``home'' link of an exported page
- #+LATEX_HEADER: extra line(s) for the {xyz
- end example
- code{#+OPTIONS} line is a compact
- code{#+OPTIONS} lines.} form to specify export
- settings. Here you can:
- cindex section-numbers
- cindex line-break preservation
- cindex fixed-width sections
- cindex
- cindex footnotes
- cindex emphasized text
- TeX{} macros
- LaTeX{} fragments
- cindex time info, in export
- vindex org-export-author-info
- vindex org-export-email-info
- example
- H:
- r{turn on/off section-numbers}
- toc:
- r{turn on/off line-break-preservation (DOES NOT WORK)}
- :
- r{turn on/off fixed-width sections}
- |:
- r{turn on/off
- r{you write "^:@{@}", {b
- r{the simple
- r{turn on/off conversion of special strings.}
- f:
- r{turn on/off inclusion of TODO keywords into exported text}
- tasks:
- r{all tasks,
- r{turn on/off priority cookies}
- tags: code{not-in-toc}}
- <:
- r{turn on/off emphasized text (bold, italic, underlined)}
- TeX: TeX{} macros in plain text}
- LaTeX: LaTeX{} fragments. Default
- r{turn on/off skipping the text before the first heading}
- author:
- r{turn on/off inclusion of author email into exported file}
- creator:
- r{turn on/off inclusion creation time into exported file}
- d:
- end example
- LaTeX{} export, except for
- code{LaTeX} options, which are respectively
- code{nil} for the
- pxref{Project alist}), see the constant
- kbd{C-c } before
- calling an export command, the subtree can overrule some of the file's export
- settings with properties code{EXPORT_TITLE},
- code{EXPORT_AUTHOR},
- code{EXPORT_OPTIONS}.
- section The export dispatcher
- table
- orgcmd{C-c C-e,org-export}
- kbd{C-u C-u} causes most commands to be executed in the background, in a
- separate Emacs process
- code{org-export-run-in-background}.}.
- kbd{C-c C-e}, but only export the text that is currently visible
- (i.e.
- orgcmd{C-u C-u C-c C-e,org-export}
- code{org-export-run-in-background}, i.e.
- end table
- section ASCII/Latin-1/UTF-8 export
- cindex Latin-1 export
- cindex region, active
- cindex transient-mark-mode
- kbd
- cindex property, EXPORT_FILE_NAME
- Export as ASCII file. For an Org file,
- file{myfile.txt}. The file will be overwritten without
- warning. If there is an active region
- code{transient-mark-mode} be turned on.}, only the region will be
- exported. If the selected region is a single tree
- kbd{C-c }.}, the tree head will
- become the document title. If the tree head entry has or inherits an
- orgcmd{C-c C-e A,org-export-as-ascii-to-buffer}
- Export to a temporary buffer. Do not create a file.
- xorgcmd{C-c C-e N,org-export-as-latin1-to-buffer}
- Like the above commands, but use Latin-1 encoding.
- xorgcmd{C-c C-e U,org-export-as-utf8-to-buffer}
- Like the above commands, but use UTF-8 encoding.
- end table
- example
- end example
- vindex org-export-ascii-links-to-notes
- Links will be exported in a footnote-like style, with the descriptive part in
- the text and the link in a note before the next heading. See the variable
- node HTML export,
- section HTML export
- emph{markdown}
- language, but with additional support for tables.
- end menu
- subsection HTML export commands
- cindex active region
- table
- orgcmd{C-c C-e h,org-export-as-html}
- file{myfile.org},
- the HTML file will be
- footnote{This requires
- footnote{To select the
- current subtree, use
- code{EXPORT_FILE_NAME}
- property, that name will be used for the export.
- orgcmd{C-c C-e H,org-export-as-html-to-buffer}
- Export to a temporary buffer. Do not create a file.
- item C-c C-e v h/b/H/R
- Export only the visible part of the document.
- item M-x org-replace-region-by-HTML
- Replace the active region (assumed to be in Org mode syntax) by HTML
- code.
- cindex headline levels, for exporting
- In the exported version, the first 3 outline levels will become headlines,
- defining a general document structure. Additional levels will be exported as
- itemized lists. If you want that transition to occur at a different level,
- specify it with a numeric prefix argument. For example,
- kbd{C-2 C-c C-e b}
- noindent
- creates two levels of headings and does the rest as items.
- subsection HTML preamble and postamble
- vindex org-export-html-postamble
- vindex org-export-html-postamble-format
- vindex org-export-author-info
- vindex org-export-creator-info
- code{org-export-html-preamble} is
- code{org-export-html-preamble-format}.
- Setting
- code{opt-plist}, which contains the list of
- publishing properties for the current file. Setting to
- code{org-export-html-postamble} is
- code{org-export-author-info},
- code{org-export-creator-info} and
- code{org-export-html-validation-link} and build the postamble from these
- values. Setting code{t} will insert the
- postamble from the relevant formatting string found in
- code{nil} will not
- insert any postamble.
- subsection Quoting HTML tags
- Plain samp{>} are always transformed to
- samp{>} in HTML export. If you want to include simple HTML tags
- which should be interpreted as such, mark them with
- samp{<b>bold text</b>}. Note that this really works only for
- simple tags. For more extensive HTML that should be copied verbatim to
- the exported file use either
- cindex #+BEGIN_HTML
- end example
- cindex #+BEGIN_HTML
- end example
- subsection Links in HTML export
- cindex internal links, in HTML export
- pxref{Internal links}) will continue to work in HTML. This
- includes automatic links created by radio targets (
- i{relative} path as the published Org file. Links to other
- samp{id:} links can then be used to jump to specific entries across
- files. For information related to linking files while publishing them to a
- publishing directory see
- code{#+ATTR_HTML} line to define attributes that will be added to the
- code{<img>} tags. Here is an example that sets
- code{style} attributes for a link:
- example
- #+ATTR_HTML: title="The Org mode homepage" style="color:red;"
- [[http://orgmode.org]]
- node Tables in HTML export, Images in HTML export, Links in HTML export, HTML export
- cindex tables, in HTML
- code{org-export-html-table-tag}. The default setting makes tables without
- cell borders and frame. If you would like to change this for individual
- tables, place something like the following before the table:
- cindex #+ATTR_HTML
- end example
- subsection Images in HTML export
- cindex inlining images in HTML
- footnote{But see the variable
- samp{[[file:myimg.jpg]]} will be inlined,
- while
- samp{the image} that points to the image. If the description part
- itself is a code{http:} URL pointing to an
- image, this image will be inlined and activated so that clicking on the
- image will activate the link. For example, to include a thumbnail that
- will link to a high resolution version of the image, you could use:
- end example
- If you need to add attributes to an inlined image, use a
- code{alt} and
- cindex #+CAPTION
- example
- #+CAPTION: A black cat stalking a spider
- #+ATTR_HTML: alt="cat/spider image" title="Action!" align="right"
- [[./img/a.jpg]]
- noindent
- You could use
- node Math formatting in HTML export, Text areas in HTML export, Images in HTML export, HTML export
- cindex MathJax
- LaTeX{} math snippets (LaTeX{} fragments}) can be displayed in two
- different ways on HTML pages. The default is to use the
- code{http://orgmode.org} serves
- b{If you plan to use this regularly or on pages with significant
- page views, you should install
- uref{http://www.mathjax.org/resources/docs/?installation.html}.} MathJax on
- your own server in order to limit the load of our server.} To configure
- code{org-export-html-mathjax-options} or
- insert something like the following into the buffer:
- end example
- code{org-export-html-mathjax-options} for the meaning of the parameters in
- this line.
- If you prefer, you can also request that
- file{dvipng} program is available on your system.
- You can still get this processing with
- end example
- subsection Text areas in HTML export
- code{-t} switch at an
- code{src} block. Using this switch disables any options for syntax and
- label highlighting, and line numbering, which may be present. You may also
- use code{-w} switches to specify the height and width of the
- text area, which default to the number of lines in the example, and 80,
- respectively. For example
- end example
- subsection CSS support
- cindex HTML export, CSS
- vindex org-export-html-tag-class-prefix
- You can also give style information for the exported file. The HTML exporter
- assigns the following special CSS classes
- code{org-export-html-todo-kwd-class-prefix} and
- example
- p.author
- r{publishing date}
- p.creator
- r{document title}
- .todo
- r{the DONE keywords, all states that count as done}
- .WAITING
- r{timestamp}
- .timestamp-kwd
- r{span around keyword plus timestamp}
- .tag
- r{each tag uses itself as a class, "@@" replaced by "_"}
- .target
- r{the line number in a code example}
- .code-highlighted
- r{div for outline level N (headline plus text))}
- div.outline-text-N
- r{section number in headlines, different for each level}
- div.figure
- r{formatted source code}
- pre.example
- r{verse paragraph}
- div.footnotes
- r{footnote definition paragraph, containing a footnote}
- .footref
- r{footnote number in footnote definition (always <sup>)}
- vindex org-export-html-style-default
- vindex org-export-html-style
- vindex org-export-html-style-default
- Each exported file contains a compact default style that defines these
- classes in a basic way
- code{org-export-html-style-default}, which you should not modify. To turn
- inclusion of these defaults off, customize
- code{org-export-html-style}
- (for Org-wide settings) and
- cindex #+STYLE
- end example
- code{<style>}
- code{:HTML_CONTAINER_CLASS:}
- property to assign a class to the tree. In order to specify CSS styles for a
- particular headline, you can use the id specified in a
- c FIXME: More about header and footer styles
- node JavaScript support, , CSS support, HTML export
- cindex Rose, Sebastian
- Sebastian Rose has written a JavaScript program especially designed to
- enhance the web viewing experience of HTML files created with Org. This
- program allows you to view large files in two different ways. The first one
- is an
- kbd{n} and
- kbd{?} for an overview of the available keys). The second
- view type is a
- url{http://orgmode.org/org-info.js} and you can find
- the documentation for it at
- url{orgmode.org} and prefer to install a local
- copy on your own web server.
- To use the script, you need to make sure that the
- kbd{M-x
- customize-variable key{RET}} to convince yourself that
- this is indeed the case. All it then takes to make use of the program is
- adding a single line to the Org file:
- example
- #+INFOJS_OPT: view:info toc:nil
- noindent
- If this line is found, the HTML header will automatically contain the code
- needed to invoke the script. Using the line above, you can set the following
- viewing options:
- r{The path to the script. The default is to grab the script from}
- url{http://orgmode.org/org-info.js}, but you might want to have}
- samp{../scripts/org-info.js}.}
- view:
- r{Info-like interface with one section per page.}
- overview
- r{Folding interface, starting with all headlines visible.}
- showall
- r{Maximum headline level that will still become an independent}
-
- r{code{H} switch in
- r{If this is smaller than in
- r{info/folding section can still contain child headlines.}
- toc: emph{initially} be visible?}
- code{nil}, you can always get to the "toc" with
- r{The depth of the table of contents. The defaults are taken from}
- code{org-export-headline-levels} and
- r{Does the CSS of the page specify a fixed position for the "toc"?}
-
- r{Should there be short contents (children) in each section?}
- code{above} if the section should be above initial text.}
- mouse:
- r{samp{#cccccc}.}
- buttons: code{nil} (the}
-
- end example
- vindex org-infojs-options
- code{org-infojs-options}. If you always want to apply the script to your
- pages, configure the variable
- node
- section
- cindex
- cindex PDF export
- LaTeX{} exporter written by Bastien Guerry. With
- further processingLaTeX{} output is designed for
- processing with LaTeX{}. It includes packages that are not
- compatible with code{luatex}. See the variables
- code{org-export-latex-packages-alist}.}, this backend is also used to
- produce PDF output. Since the file{hyperref} to
- implement links and cross references, the PDF output file will be fully
- linked. Beware of the fact that your
- menu
- *
- LaTeX{} code:: Incorporating literal
- LaTeX{} export:: Options for exporting tables to
- LaTeX{} export:: How to insert figures into
- end menu
- LaTeX{}/PDF export commands, Header and sectioning, LaTeX{} and PDF export
- LaTeX{} export commands
- cindex active region
- table
- orgcmd{C-c C-e l,org-export-as-latex}
- LaTeX{} file. For an Org file
- LaTeX{} file will be
- footnote{This
- requires
- footnote{To select the
- current subtree, use
- code{EXPORT_FILE_NAME}
- property, that name will be used for the export.
- item C-c C-e v l/L
- Export only the visible part of the document.
- LaTeX{} under the assumption that it was Org mode
- syntax before. This is a global command that can be invoked in any
- buffer.
- LaTeX{}
- code.
- LaTeX{} and then process to PDF.
- LaTeX{} and then process to PDF, then open the resulting PDF file.
- cindex headline levels, for exporting
- code{org-latex-low-levels}.
- If you want that transition to occur at a different level, specify it
- with a numeric prefix argument. For example,
- kbd{C-2 C-c C-e l}
- noindent
- creates two levels of headings and does the rest as items.
- LaTeX{} code, LaTeX{} and PDF export
- cindex
- cindex
- cindex
- cindex header, for
- cindex sectioning structure, for
- LaTeX{} output uses the class
- vindex org-export-latex-default-class
- vindex org-export-latex-default-packages-alist
- cindex #+LATEX_HEADER
- cindex #+LATEX_CLASS_OPTIONS
- cindex property, LATEX_CLASS_OPTIONS
- You can change this globally by setting a different value for
- code{#+LaTeX_CLASS: myclass} in your file, or with a
- code{org-export-latex-classes}. This variable
- defines a header template for each class
- code{org-export-latex-default-packages-alist} and
- code{#+LaTeX_CLASS_OPTIONS} or a
- code{\documentclass} macro. You
- can also use {xyz
- code{org-export-latex-classes} for more
- information.
- LaTeX{} code, Tables in LaTeX{} and PDF export
- LaTeX{} code
- Embedded ref{Embedded
- LaTeX{} file. This includes simple macros like
- {LABEL
- LaTeX{} export with
- the following constructs:
- cindex #+BEGIN_LaTeX
- LaTeX{} code for export
- noindent or
- example
- #+BEGIN_LaTeX
- All lines between these markers are exported literally
- #+END_LaTeX
- node Tables in LaTeX{} export, Quoting LaTeX{} and PDF export
- LaTeX{} export
- LaTeX{} export
- For
- pxref{Images and tables}). You can also use the
- code{longtable} environment for the
- table, so that it may span several pages, or to change the default table
- environment from code{table*} or to change the default inner
- tabular environment to code{tabulary}. Finally, you can
- set the alignment string, and (with code{tabulary}) the
- width:
- cindex #+LABEL
- example
- #+CAPTION: A long table
- #+LABEL: tbl:long
- #+ATTR_LaTeX: longtable align=l|lp}r|l
- | ..... | ..... |
- | ..... | ..... |
- code{tabulary}
- cindex #+LABEL
- example
- #+CAPTION: A wide table with tabulary
- #+LABEL: tbl:wide
- #+ATTR_LaTeX: table* tabulary width=\textwidth
- | ..... | ..... |
- | ..... | ..... |
- node Images in LaTeX{} export,
- subsection Images in
- cindex images, inline in
- cindex inlining images in
- samp{[[file:img.jpg]]} or
- LaTeX{} processing. Org will use an
- ref{Images and tables}, the figure
- will be wrapped into a
- code{#+ATTR_LaTeX:} line to specify various other
- options. You can ask org to export an image as a float without specifying
- a label or a caption by using the keyword
- code{\includegraphics} macro can also be specified
- in this fashion. To modify the placement option of the floating environment,
- add something like
- footnote{One can also take
- advantage of this option to pass other, unrelated options into the figure or
- table environment. For an example see the section ``Exporting org files'' in
- code{#+ATTR_LaTeX:} line below is exported as the
- samp{wrap}
- to the
- code{placement} field will be the set
- of additional arguments needed by the
- code{\includegraphics} and
- cindex #+CAPTION
- cindex #+ATTR_LaTeX
- {r{0.4\textwidth
- end example
- If you wish to include an image which spans multiple columns in a page, you
- can use the keyword code{#+ATTR_LaTeX} line. This
- will export the image wrapped in a
- samp{\ref}} just like in
- node Beamer class export, , Images in LaTeX{} and PDF export
- LaTeX{} class
- LaTeX{} and pdf processing. Org mode has special support for turning an
- Org mode file or tree into a
- LaTeX{} class for the current buffer (as set with
- code{LaTeX_CLASS} property) is
- code{org-beamer-frame-level} to a
- different level---then the hierarchy above frames will produce the sectioning
- structure of the presentation.
- A template for useful in-buffer settings or properties can be inserted into
- the buffer with
- table
- item BEAMER_env
- The environment that should be used to format this entry. Valid environments
- are defined in the constant
- code{org-beamer-environments-extra}. If this property is
- set, the entry will also get a
- item BEAMER_envargs
- The beamer-special arguments that should be used for the environment, like
- code{[<+->]} of code{BEAMER_col}
- property is also set, something like
- code{columns} environment.
- code{c<2->} will set an options for the implied
- item BEAMER_col
- The width of a column that should start with this entry. If this property is
- set, the entry will also get a
- code{\textwidth}. Otherwise it will be assumed
- that you have specified the units, like
- code{columns} environment to surround the columns.
- This environment is closed when an entry has a
- item BEAMER_extra
- Additional commands that should be inserted after the environment has been
- opened. For example, when creating a frame, this can be used to specify
- transitions.
- code{fragile} option if they contain
- source code that uses the verbatim environment. Special
- code{#+BEAMER:} and
- code{#+LaTeX:} stuff will be included
- in the presentation as well.
- Outline nodes with samp{note} or
- code{\note}}. The former will include the heading as part of the
- note text, the latter will ignore the heading of that node. To simplify note
- generation, it is actually enough to mark the note with a
- code{:B_note:} or
- code{BEAMER_env} property.
- You can turn on a special minor mode
- example
- #+STARTUP: beamer
- table
- orgcmd{C-c C-b,org-beamer-select-environment}
- In
- code{BEAMER_col} property.
- kbd{M-x
- org-insert-beamer-options-template} defines such a format.
- Here is a simple example Org document that is intended for beamer export.
- {Madrid{default
- end smallexample
- For more information, see the documentation on Worg.
- LaTeX{} and PDF export, Exporting
- cindex DocBook export
- cindex Cui, Baoqiu
- Org contains a DocBook exporter written by Baoqiu Cui. Once an Org file is
- exported to DocBook format, it can be further processed to produce other
- formats, including PDF, HTML, man pages, etc., using many available DocBook
- tools and stylesheets.
- Currently DocBook exporter only supports DocBook V5.0.
- end menu
- subsection DocBook export commands
- cindex active region
- table
- orgcmd{C-c C-e D,org-export-as-docbook}
- file{myfile.org}, the DocBook XML
- file will be
- footnote{This requires
- footnote{To select the
- current subtree, use
- code{EXPORT_FILE_NAME}
- property, that name will be used for the export.
- vindex org-export-docbook-xslt-proc-command
- code{org-export-docbook-xslt-proc-command} and
- vindex org-export-docbook-xslt-stylesheet
- The stylesheet argument
- code{org-export-docbook-xslt-proc-command} is replaced by the value of
- variable
- code{#+XSLT:} to the Org file.
- end table
- subsection Quoting DocBook code
- You can quote DocBook code in Org files and copy it verbatim into exported
- DocBook file with the following constructs:
- cindex #+BEGIN_DOCBOOK
- end example
- cindex #+BEGIN_DOCBOOK
- end example
- For example, you can use the following lines to include a DocBook warning
- admonition. As to what this warning says, you should pay attention to the
- document context when quoting DocBook code in Org files. You may make
- exported DocBook XML files invalid by not quoting DocBook code correctly.
- end example
- subsection Recursive sections
- code{article}
- element in DocBook. Recursive sections, i.e.code{section} elements, are
- used in exported articles. Top level headlines in Org files are exported as
- top level sections, and lower level headlines are exported as nested
- sections. The entire structure of Org files will be exported completely, no
- matter how many nested levels of headlines there are.
- Using recursive sections makes it easy to port and reuse exported DocBook
- code in other DocBook document types like code{set}.
- subsection Tables in DocBook export
- code{informaltable} element; otherwise, a formal table will be generated
- using the
- node Images in DocBook export, Special characters, Tables in DocBook export, DocBook export
- cindex images, inline in DocBook
- samp{[[file:img.jpg]]} or
- code{mediaobject} elements. Each
- code{imageobject} that wraps an
- ref{Images and tables}, a
- code{mediaobject}. If a label is
- also specified, it will be exported as an
- code{mediaobject} element.
- code{imagedata} element, like
- code{width}, can be specified in two ways: you can either customize
- variable
- code{#+ATTR_DOCBOOK:} line. Attributes specified in variable
- code{#+ATTR_DOCBOOK:} lines).
- The
- code{#+ATTR_DOCBOOK:} line and
- variable
- cindex #+CAPTION
- cindex #+ATTR_DOCBOOK
- end example
- file{jpeg}, file{png}, file{svg}. You can
- customize variable
- node Special characters, , Images in DocBook export, DocBook export
- cindex Special characters in DocBook export
- vindex org-entities
- Special characters that are written in code{\alpha},
- code{\Zeta}, are supported by DocBook exporter. These
- characters are rewritten to XML entities, like
- code{Γ}, and
- code{org-entities}. As long as the generated DocBook file includes the
- corresponding entities, these special characters are recognized.
- You can customize variable
- code{org-export-docbook-doctype} to the following value to recognize all
- special characters included in XHTML entities:
- end example
- node OpenDocument Text export, TaskJuggler export, DocBook export, Exporting
- cindex K, Jambunathan
- cindex OpenDocument
- cindex LibreOffice
- cindex org-modules
- Orgmode
- acronym{ODT}) format using the
- cite{OpenDocument-v1.2
- specification}url{http://docs.oasis-open.org/office/v1.2/OpenDocument-v1.2.html,
- Open Document Format for Office Applications (OpenDocument) Version 1.2}} and
- are compatible with LibreOffice 3.4.
- acronym{ODT} export:: What packages
- acronym{ODT} export commands:: How to invoke
- acronym{ODT} export:: How links will be interpreted and formatted
- * Tables in
- acronym{ODT} export:: How to insert images
- * Math formatting in LaTeX{} fragments are formatted
- * Literal examples in
- acronym{ODT} export:: Read this if you are a power user
- node Pre-requisites for acronym{ODT} export commands, OpenDocument Text export, OpenDocument Text export
- acronym{ODT} export
- acronym{ODT} exporter relies on the
- node acronym{ODT} export, OpenDocument Text export
- acronym{ODT} export commands
- acronym{ODT}
- cindex region, active
- cindex transient-mark-mode
- kbd
- cindex property EXPORT_FILE_NAME
- Export as OpenDocument Text file.
- code{org-export-odt-preferred-output-format} is specified, automatically
- convert the exported file to that format.
- file{myfile.org}, the
- file{myfile.odt}. The file will be overwritten without warning. If there
- is an active region,code{transient-mark-mode} to be
- turned on} only the region will be exported. If the selected region is a
- single tree,kbd{C-c }} the
- tree head will become the document title. If the tree head entry has, or
- inherits, an
- orgcmd{C-c C-e O,org-export-as-odt-and-open}
- Export as OpenDocument Text file and open the resulting file.
- code{org-export-odt-preferred-output-format} is specified, open the
- converted file instead.
- end table
- anchor{x-export-to-other-formats}
- acronym{ODT} format, only to
- immediately save the exported document to a different format like
- pxref{Exporting and converting to other formats}) and specify your
- preferred output format by customizing the variable
- pxref{x-export-to-odt,,Exporting to ODT}) can be extended to also export to
- the preferred format.
- acronym{ODT} export,
- subsection Applying custom styles
- cindex template, custom
- The
- pxref{Working with OpenDocument style files}) that ensure a well-formatted
- output. These factory styles, however, may not cater to your specific
- tastes. To customize the output, you can either modify the above styles
- files directly, or generate the required styles using an application like
- LibreOffice. The latter method is suitable for expert and non-expert
- users alike, and is described here.
- enumerate
- file{example.org} file with the below settings and export it
- to
- example
- #+OPTIONS: H:10 num:t
- item
- Open the above file{Stylist}
- to locate the target styles - these typically have the
- file{.odt}) or OpenDocument Template (
- item
- vindex org-export-odt-styles-file
- Customize the variable
- pxref{x-overriding-factory-styles,,Overriding factory styles}.
- If you would like to choose a style on a per-file basis, you can use the
- example
- #+ODT_STYLES_FILE: "/path/to/example.ott"
- example
- #+ODT_STYLES_FILE: ("/path/to/file.ott" ("styles.xml" "image/hdr.png"))
- end enumerate
- samp{ODT} exporter relies on. Unless this condition is
- met, the output is going to be less than satisfactory. So it is highly
- recommended that you only work with templates that are directly derived from
- the factory settings.
- acronym{ODT} export, Tables in
- subsection Links in
- cindex tables, in DocBook export
- The
- node Tables in acronym{ODT} export, Links in
- subsection Tables in
- cindex tables, in DocBook export
- Export of native Org mode tables (file{table.el}
- tables is supported. However, export of complex
- pxref{Column groups}). If the table
- specifies alignment and relative width for its columns (
- footnote{The column widths
- are interpreted as weighted ratios with the default weight being 1}
- code{#+ATTR_ODT} line. acronym{ODT} export}.
- acronym{ODT} export, Math formatting in acronym{ODT} export, OpenDocument Text export
- acronym{ODT} export
- acronym{ODT}
- acronym{ODT}
- samp{img.png} do either of the following:
- end example
- end example
- file{org-mode-unicorn.png} which when clicked jumps to
- example
- [[http://orgmode.org][./org-mode-unicorn.png]]
- subsubheading Sizing and scaling of embedded images
- You can control the size and scale of the embedded images using the
- vindex org-export-odt-pixels-per-inch
- Note that the exporter specifies the desired size of the image in the final
- document in units of centimetres. In order to scale the embedded images, the
- exporter needs to compute the size of the image. This is done by retrieving
- the image size in pixels and converting the pixel units to centimetres using
- code{display-pixels-per-inch}. You can tweak this variable to
- achieve the best results.
- The examples below illustrate the various possibilities.
- asis
- file{img.png} as a 10 cm x 10 cm image, do the following:
- end example
- file{img.png} at half its size, do the following:
- end example
- file{img.png} with a width of 10 cm while retaining the original
- height:width ratio, do the following:
- end example
- file{img.png} with a height of 10 cm while retaining the original
- height:width ratio, do the following
- end example
- node Math formatting in acronym{ODT} export, Images in
- subsection Math formatting in
- acronym{ODT} exporter has special support for handling math.
- LaTeX{} math snippets:: How to embed
- end menu
- LaTeX{} math snippets, Working with MathML or OpenDocument formula files, Math formatting in acronym{ODT} export
- LaTeX{} math snippets
- pxref{
- cindex MathML
- item MathML
- This option is activated on a per-file basis with
- end example
- With this option,
- LaTeX{}-to-MathML converter program. The
- resulting MathML fragments are then embedded as an OpenDocument Formula in
- the exported document.
- vindex org-latex-to-mathml-jar-file
- You can specify the
- code{org-latex-to-mathml-convert-command} and
- file{MathToWeb}
- uref{http://www.mathtoweb.com/cgi-bin/mathtoweb_home.pl, MathToWeb}} as your
- converter, you can configure the above variables as shown below.
- end lisp
- You can use the following commands to quickly verify the reliability of
- the
- table
- item M-x org-export-as-odf
- Convert a file{.odf}) file.
- LaTeX{} math snippet to OpenDocument formula (
- end table
- item PNG images
- This option is activated on a per-file basis with
- end example
- With this option,
- file{dvipng} program be available on your system.
- node Working with MathML or OpenDocument formula files, , Working with acronym{ODT} export
- LaTeX{} math snippets in an
- file{.mml}) source or its
- OpenDocument formula (
- example
- [[./equation.mml]]
- example
- [[./equation.odf]]
- node Literal examples in acronym{ODT} export, Math formatting in
- subsection Literal examples in
- pxref{Literal examples}) with full fontification
- is supported. This feature is enabled by default and is activated
- automatically if an enhanced version of
- code{load-path}.file{htmlfontify.el} that ships with
- standard Emacs <= 24.1 has no support for
- url{http://debbugs.gnu.org/cgi/bugreport.cgi?msg=5;filename=htmlfontify.el;att=9;bug=9914,
- Emacs Bug #9914}.}
- file{htmlfontify.el}
- library and need not be included in the default
- samp{OrgSrc} prefix and inherit their color
- based on the face used by Emacs
- vindex org-export-odt-create-custom-styles-for-srcblocks
- If you prefer to use your own custom styles for fontification and disable
- their auto-generation altogether, you can do so by customizing the variable
- code{org-export-odt-fontify-srcblocks}.
- acronym{ODT} export, , Literal examples in
- subsection Advanced topics in
- acronym{ODT} export, you may want to exploit the full
- set of features that the exporter offers. This section describes features
- that would be of interest to power users.
- samp{pdf} and other formats
- * Working with OpenDocument style files:: Explore the internals
- * Creating one-off styles:: How to produce custom highlighting etc
- * Customizing tables in
- end menu
- acronym{ODT} export, Advanced topics in
- subsubsection Exporting and converting to other formats
- cindex doc, docx
- The
- xref{x-export-to-other-formats,,Automatically exporting to other
- formats}. You can also use it to perform one-off document conversion as
- detailed below.
- table
- item M-x org-export-odt-convert
- Convert an existing document from one format to another as determined by the
- variable
- pxref{x-odt-converter-capabilities,,Configure converter
- capabilities}).
- acronym{ODT} format.
- subsubheading Pre-configured converters
- acronym{ODT} exporter supports two converters out of the box:
- cindex
- item
- cindex
- item
- vindex org-odt-data-dir
- This converter is distributed as a LibreOffice extension and can be found in
- your Org distribution. See the subdirectory pointed to by the variable
- end enumerate
- enumerate
- vindex org-export-odt-convert-processes
- Name your converter and add it to the list of known converters by customizing
- the variable
- item Configure its capabilities
- anchor{x-odt-converter-capabilities}
- Specify the set of formats the converter can handle by customizing the
- variable
- item Choose the converter
- code{org-export-odt-convert-process}.
- node Working with OpenDocument style files, Creating one-off styles, Exporting and converting to other formats, Advanced topics in
- subsubsection Working with OpenDocument style files
- cindex template, custom
- This section explores the internals of the
- anchor{x-factory-styles}
- acronym{ODT} exporter relies on two files for generating its output.
- These files are bundled with the distribution under the directory pointed to
- by the variable
- itemize
- item
- file{styles.xml} file of the final
- enumerate
- item
- To add styles generated by
- end enumerate
- item
- file{content.xml} file of the final
- samp{<office:text>}samp{</office:text>} elements of this file.
- Apart from serving as a template file for the final
- enumerate
- item
- It contains dots{}
- end enumerate
- anchor{x-overriding-factory-styles}
- acronym{ODT}
- exporter picks up the custom styles and content template files. You can
- customize these variables to override the factory styles used by the
- exporter.
- anchor{x-org-export-odt-styles-file}
- code{org-export-odt-styles-file}
- Use this variable to specify the
- enumerate
- file{styles.xml} file
- Use this file instead of the default
- item A file{.ott} file
- Use the
- item A file{.ott} file and a subset of files contained within them
- Use the
- samp{ODT} document.
- Use this option if the
- item
- file{styles.xml}
- anchor{x-org-export-odt-content-template-file}
- code{org-export-odt-content-template-file}
- Use this variable to specify the blank
- end itemize
- acronym{ODT} export, Working with OpenDocument style files, Advanced topics in
- subsubsection Creating one-off styles
- There are times when you would want one-off formatting in the exported
- document. You can achieve this by embedding raw OpenDocument XML in the Org
- file. The use of this feature is better illustrated with couple of examples.
- item Embedding ODT tags as part of regular text
- You can include simple OpenDocument tags by prefixing them with
- example
- <text:span text:style-name="Highlight">This is a
- highlighted text</text:span>. But this is a
- regular text.
- strong{Hint:} To see the above example in action, edit your
- pxref{x-orgodtstyles-xml,,Factory styles}) and add a
- custom
- example
- <style:style style:name="Highlight" style:family="text">
- <style:text-properties fo:background-color="#ff0000"/>
- </style:style>
- item Embedding a one-line OpenDocument XML
- You can add a simple OpenDocument one-liner using the
- example
- #+ODT: <text:p text:style-name="PageBreak"/>
- strong{Hint:} To see the above example in action, edit your
- pxref{x-orgodtstyles-xml,,Factory styles}) and add a
- custom
- example
- <style:style style:name="PageBreak" style:family="paragraph"
- style:parent-style-name="Text_20_body">
- <style:paragraph-properties fo:break-before="page"/>
- </style:style>
- item Embedding a block of OpenDocument XML
- You can add a large block of OpenDocument XML using the
- dots{}
- example
- #+BEGIN_ODT
- <text:p text:style-name="Text_20_body_20_bold">
- This paragraph is specially formatted and uses bold text.
- </text:p>
- #+END_ODT
- end enumerate
- acronym{ODT} export, Validating OpenDocument XML, Creating one-off styles, Advanced topics in
- subsubsection Customizing tables in
- cindex tables, in ODT export
- code{#+ATTR_ODT} line. For a discussion on default
- formatting of tables acronym{ODT} export}.
- This feature closely mimics the way table templates are defined in the
- OpenDocument-v1.2
- specification.url{http://docs.oasis-open.org/office/v1.2/OpenDocument-v1.2.html,
- OpenDocument-v1.2 Specification}}
- lisp
- (setq org-export-odt-table-styles
- (append org-export-odt-table-styles
- '(("TableWithHeaderRowAndColumn" "Custom"
- ((use-first-row-styles . t)
- (use-first-column-styles . t)))
- ("TableWithFirstRowandLastRow" "Custom"
- ((use-first-row-styles . t)
- (use-last-row-styles . t))))))
- example
- #+ATTR_ODT: TableWithHeaderRowAndColumn
- | Name | Phone | Age |
- | Peter | 1234 | 17 |
- | Anna | 4321 | 25 |
- samp{Custom} and installed
- two table styles with the names
- samp{TableWithFirstRowandLastRow}. (
- samp{Custom Table
- Template} in
- pxref{x-orgodtcontenttemplate-xml,,Factory styles}). If you need
- additional templates you have to define these styles yourselves.
- enumerate
- footnote{See the
- samp{table-cell} and
- itemize
- item Body
- item Last column
- item Last row
- item Odd row
- item Odd Column
- samp{Custom}, the needed style names are listed in
- the following table.
- headitem Table cell type
- code{table-cell} style
- code{paragraph} style
- tab
- item Body
- samp{CustomTableCell}
- samp{CustomTableParagraph}
- tab
- tab
- item Last column
- samp{CustomLastColumnTableCell}
- samp{CustomLastColumnTableParagraph}
- tab
- tab
- item Last row
- samp{CustomLastRowTableCell}
- samp{CustomLastRowTableParagraph}
- tab
- tab
- item Odd row
- samp{CustomOddRowTableCell}
- samp{CustomOddRowTableParagraph}
- tab
- tab
- item Odd column
- samp{CustomOddColumnTableCell}
- samp{CustomOddColumnTableParagraph}
- samp{Custom}, define the above
- styles in the
- code{</office:automatic-styles>} element
- of the content template file (
- item
- Define a table stylecode{table:template-name},
- code{table:use-last-row-styles},
- code{table:use-last-column-styles},
- code{table:use-banding-column-styles} of the
- vindex org-export-odt-table-styles
- To define a table style, create an entry for the style in the variable
- itemize
- item the name of the table template created in step (1)
- end itemize
- For example, the entry below defines two different table styles
- samp{TableWithHeaderColumns} based
- on the same template
- lisp
- (setq org-export-odt-table-styles
- (append org-export-odt-table-styles
- '(("TableWithHeaderRowAndColumn" "Custom"
- ((use-first-row-styles . t)
- (use-first-column-styles . t)))
- ("TableWithFirstRowandLastRow" "Custom"
- ((use-first-row-styles . t)
- (use-last-row-styles . t))))))
- item
- Associate a table with the table style
- To do this, specify the table style created in step (2) as part of
- the
- example
- #+ATTR_ODT: TableWithHeaderRowAndColumn
- | Name | Phone | Age |
- | Peter | 1234 | 17 |
- | Anna | 4321 | 25 |
- end enumerate
- acronym{ODT} export, Advanced topics in
- subsubsection Validating OpenDocument XML
- Occasionally, you will discover that the document created by the
- file{.odt} file is corrupt. In such
- cases, you may want to validate the document against the OpenDocument RELAX
- NG Compact Syntax (RNC) schema.
- For de-compressing the footnote{
- samp{zip} archives}:
- inforef{Introduction,,nxml-mode}.
- file{.rnc} files and the needed
- schema-locating rules in a single folder, you can customize the variable
- acronym{ODT} exporter will take care of updating the
- c end opendocument
- section TaskJuggler export
- cindex Project management
- code{HTML} and
- subsection TaskJuggler export commands
- kbd
- orgcmd{C-c C-e J,org-export-as-taskjuggler-and-open}
- Export as TaskJuggler file and then open the file with TaskJugglerUI.
- subsection Tasks
- url{http://www.contextualdevelopment.com/static/artifacts/articles/2008/project-planning/project-planning.org}.
- Now mark the top node of your tasks with a tag named
- code{org-export-taskjuggler-project-tag} to). You are now ready to export
- the project plan with
- subsection Resources
- code{:taskjuggler_resource:} (or whatever you customized
- samp{resource_id}) to the resources (using the standard
- Org properties commands,
- code{org-taskjuggler-get-unique-id}). Using that identifier you can then
- allocate resources to tasks. This is again done with the
- kbd{C-c C-x p allocate key{RET}}.
- Once the allocations are done you can again export to TaskJuggler and check
- in the Resource Allocation Graph which person is working on what task at what
- time.
- : if a
- task is marked as done it will have the corresponding attribute in
- TaskJuggler (
- samp{limits}, samp{shift},
- samp{efficiency}, samp{rate} for resources or
- samp{start}, samp{duration},
- samp{journalentry}, samp{reference},
- samp{scheduling}, etc for tasks.
- samp{ORDERED} attribute (
- samp{BLOCKER} attribute (see
- samp{depends} attribute. Both the samp{depends}
- attribute can be either
- samp{task_id}) which is defined for another task in the
- project. samp{depends} attribute can define multiple
- dependencies separated by either space or comma. You can also specify
- optional attributes on the dependency by simply appending it. The following
- examples should illustrate this:
- { gapduration 1d
- end example
- vindex org-export-taskjuggler-default-reports
- TaskJuggler can produce many kinds of reports (e.g.
- code{org-export-taskjuggler-default-reports}. They can be modified using
- customize along with a number of other options. For a more complete list, see
- key{RET} org-export-taskjuggler
- uref{http://orgmode.org/worg/org-tutorials/org-taskjuggler.html}.
- section Freemind export
- cindex mind map
- The Freemind exporter was written by Lennart Borgman.
- kbd
- file{myfile.org}, the Freemind
- file will be
- end table
- section XOXO export
- table
- orgcmd{C-c C-e x,org-export-as-xoxo}
- Export as XOXO file. For an Org file
- file{myfile.html}.
- end table
- section iCalendar export
- vindex org-icalendar-include-todo
- vindex org-icalendar-use-scheduled
- vindex org-icalendar-alarm-time
- Some people use Org mode for keeping track of projects, but still prefer a
- standard calendar application for anniversaries and appointments. In this
- case it can be useful to show deadlines and other time-stamped items in Org
- files in the calendar application. Org mode can export calendar information
- in the standard iCalendar format. If you also want to have TODO entries
- included in the export, configure the variable
- footnote{See the variables
- code{org-icalendar-use-scheduled}.}.
- As categories, it will use the tags locally defined in the heading, and the
- file/tree category
- code{org-icalendar-categories}.}. See the variable
- vindex org-icalendar-store-UID
- code{org-icalendar-store-UID}, the UID will be stored in the
- table
- orgcmd{C-c C-e i,org-export-icalendar-this-file}
- Create iCalendar entries for the current file and store them in the same
- directory, using a file extension
- orgcmd{C-c C-e I, org-export-icalendar-all-agenda-files}
- kbd{C-c C-e i}, but do this for all files in
- orgcmd{C-c C-e c,org-export-icalendar-combine-agenda-files}
- code{org-agenda-files} and write it to the file given by
- end table
- vindex org-icalendar-include-body
- cindex property, DESCRIPTION
- footnote{The LOCATION
- property can be inherited from higher in the hierarchy if you configure
- code{org-icalendar-include-body} characters).
- How this calendar is best read and updated, depends on the application
- you are using. The FAQ covers this issue.
- chapter Publishing
- emph{projects} composed of interlinked org
- files. You can also configure Org to automatically upload your exported HTML
- pages and related attachments, such as images and source code files, to a web
- server.
- You can also use Org to convert files into PDF, or even combine HTML and PDF
- conversion so that files are available in both formats on the server.
- Publishing has been contributed to Org by David O'Toole.
- end menu
- section Configuration
- Publishing needs significant configuration to specify files, destination
- and many other properties of a project.
- LaTeX{} export
- * Publishing links:: Which links keep working after publishing?
- * Sitemap:: Generating a list of all pages
- * Generating an index:: An index that reaches across pages
- node Project alist, Sources and destinations, Configuration, Configuration
- code{org-publish-project-alist}
- cindex projects, for publishing
- code{org-publish-project-alist}. Each element of the list
- configures one project, and may be in one of the two following forms:
- r{i.e.
- r{or}
- ("project-name" :components ("project-name" "project-name" ...))
- code{:components} property are taken to be sub-projects, which group
- together files requiring different publishing options. When you publish such
- a ``meta-project'', all the components will also be published, in the
- sequence given.
- subsection Sources and destinations for files
- multitable
- item
- tab Directory containing publishing source files
- code{:publishing-directory}
- file{tramp} package. Or you can publish to a local directory and
- use external tools to upload your website (
- item
- tab Function or list of functions to be called before starting the
- publishing process, for example, to run
- code{project-plist}.
- code{:completion-function}
- code{project-plist}.
- noindent
- subsection Selecting files
- file{.org} in the base directory
- are considered part of the project. This can be modified by setting the
- properties
- columnfractions 0.25 0.75
- code{:base-extension}
- code{any} if you want to get all
- files in
- item
- tab Regular expression to match file names that should not be
- published, even though they have been selected on the basis of their
- extension.
- code{:include}
- code{:base-extension}
- and
- item
- tab Non-nil means, check base-directory recursively for files to publish.
- node Publishing action, Publishing options, Selecting files, Configuration
- cindex action, for publishing
- Publishing means that a file is copied to the destination directory and
- possibly transformed in the process. The default transformation is to export
- Org files as HTML files, and this is done by the function
- pxref{HTML
- export}). But you also can publish your content as PDF files using
- code{ascii},
- code{utf8} encoded files using the corresponding functions. If you want to
- publish the Org file itself, but with i{commented}, and
- code{org-publish-org-to-org} and set the
- parameters code{:htmlized-source}. This will
- produce file{file.org.html} in the publishing
- directoryfile{file-source.org} and
- code{:exclude "-source\\.org"} to the project
- definition in
- code{org-publish-attachment}.
- For non-Org files, you always need to specify the publishing function:
- columnfractions 0.3 0.7
- code{:publishing-function}
- item
- tab Non-nil means, publish plain source.
- code{:htmlized-source}
- end multitable
- The function must accept three arguments: a property list containing at least
- a
- node Publishing options, Publishing links, Publishing action, Configuration
- LaTeX{} exporters
- LaTeX{} exporters. In most cases, these properties correspond to user
- variables in Org. The table below lists these properties along
- with the variable they belong to. See the documentation string for the
- respective variable for details.
- vindex org-export-html-link-home
- vindex org-display-custom-times
- vindex org-export-with-section-numbers
- vindex org-export-with-toc
- vindex org-export-with-archived-trees
- vindex org-export-with-sub-superscripts
- vindex org-export-with-footnotes
- vindex org-export-with-tags
- vindex org-export-with-tasks
- vindex org-export-with-priority
- vindex org-export-with-LaTeX-fragments
- vindex org-export-with-fixed-width
- vindex org-export-author-info
- vindex org-export-creator-info
- vindex org-export-with-tables
- vindex org-export-html-style-include-default
- vindex org-export-html-style
- vindex org-export-html-link-org-files-as-html
- vindex org-export-html-extension
- vindex org-export-html-expand
- vindex org-export-publishing-directory
- vindex org-export-html-postamble
- vindex user-mail-address
- vindex org-export-exclude-tags
- columnfractions 0.32 0.68
- code{:link-up} code{org-export-html-link-up}
- code{:link-home} code{org-export-html-link-home}
- code{:language} code{org-export-default-language}
- code{:customtime} code{org-display-custom-times}
- code{:headline-levels} code{org-export-headline-levels}
- code{:section-numbers} code{org-export-with-section-numbers}
- code{:section-number-format} code{org-export-section-number-format}
- code{:table-of-contents} code{org-export-with-toc}
- code{:preserve-breaks} code{org-export-preserve-breaks}
- code{:archived-trees} code{org-export-with-archived-trees}
- code{:emphasize} code{org-export-with-emphasize}
- code{:sub-superscript} code{org-export-with-sub-superscripts}
- code{:special-strings} code{org-export-with-special-strings}
- code{:footnotes} code{org-export-with-footnotes}
- code{:drawers} code{org-export-with-drawers}
- code{:tags} code{org-export-with-tags}
- code{:todo-keywords} code{org-export-with-todo-keywords}
- code{:tasks} code{org-export-with-tasks}
- code{:priority} code{org-export-with-priority}
- code{:TeX-macros} code{org-export-with-TeX-macros}
- code{:LaTeX-fragments} code{org-export-with-LaTeX-fragments}
- code{:latex-listings} code{org-export-latex-listings}
- code{:skip-before-1st-heading} code{org-export-skip-text-before-1st-heading}
- code{:fixed-width} code{org-export-with-fixed-width}
- code{:timestamps} code{org-export-with-timestamps}
- code{:author} code{user-full-name}
- code{:email} code{user-mail-address} :
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- end multitable
- Most of the
- LaTeX{} exporters, except for
- code{:LaTeX-fragments} options, respectively code{t} in the
- code{org-export-plist-vars} to check this list of
- options.
- code{org-publish-project-alist},
- its setting overrides the value of the corresponding user variable (if
- any) during publishing. Options set within a file (
- node Publishing links, Sitemap, Publishing options, Configuration
- cindex links, publishing
- To create a link from one Org file to another, you would use
- something like
- samp{file:foo.org.} (
- file{foo.html}. In this way, you can interlink the
- pages of your "org web" project and the links will work as expected when
- you publish them to HTML. If you also publish the Org source file and want
- to link to that, use an code{file:} link,
- because
- file{html} file.
- You may also link to related files, such as images. Provided you are careful
- with relative file names, and provided you have also configured Org to upload
- the related files, these links will work too. See
- multitable
- item
- tab Function to validate links
- noindent
- to define a function for checking link validity. This function must
- accept two arguments, the file name and a directory relative to which
- the file name is interpreted in the production environment. If this
- function returns
- code{org-publish-validate-link} which checks if the given
- file is part of any project in
- node Sitemap, Generating an index, Publishing links, Configuration
- cindex sitemap, of published pages
- The following properties may be used to control publishing of
- a map of files for a given project.
- columnfractions 0.35 0.65
- code{:auto-sitemap}
- code{org-publish-current-project}
- or
- item
- tab Filename for output of sitemap. Defaults to
- file{sitemap.html}).
- code{:sitemap-title}
- item
- tab Plug-in function to use for generation of the sitemap.
- Defaults to
- item
- tab Where folders should appear in the sitemap. Set this to
- code{last} to display folders first or last,
- respectively. Any other value will mix files and folders.
- code{:sitemap-sort-files}
- code{alphabetically} (default),
- code{anti-chronologically}.
- code{anti-chronologically} sorts the files with newer
- date first.
- code{org-publish-find-date}.
- code{:sitemap-ignore-case}
- code{nil}.
- code{:sitemap-file-entry-format}
- code{%t} stands
- for the title of the file,
- code{%d} stands for the date of the file. The date is retrieved with the
- code{org-publish-sitemap-date-format}. Default
- item
- tab Format string for the
- code{org-publish-sitemap-date-format} which defaults to
- item
- tab When non-nil, remove filenames' extensions from the generated sitemap.
- Useful to have cool URIs (see
- code{nil}.
- node Generating an index, , Sitemap, Configuration
- cindex index, in a publishing project
- Org mode can generate an index across the files of a publishing project.
- columnfractions 0.25 0.75
- code{:makeindex}
- file{theindex.org} and
- publish it as
- end multitable
- The file will be created when first publishing a project with the
- code{#+include:
- "theindex.inc"}. You can then build around this include statement by adding
- a title, style information, etc.
- section Uploading files
- cindex unison
- For those people already utilizing third party sync tools such as
- command{unison}, it might be preferable not to use the built in
- i{in place} with your Org files) and then use
- file{rsync} to do the synchronization with the remote host.
- Since Unison (for example) can be configured as to which files to transfer to
- a certain remote destination, it can greatly simplify the project publishing
- definition. Simply keep all files in the correct location, process your Org
- files with
- file{jpg},
- file{gif} files in the project definition since the 3rd party
- tool syncs them.
- Publishing to a local directory is also much faster than to a remote one, so
- that you can afford more easily to republish entire projects. If you set
- code{nil}, you gain the main
- benefit of re-including any changed external files such as source example
- files you might include with
- node Sample configuration, Triggering publication, Uploading files, Publishing
- menu
- * Simple example:: One-component publishing
- * Complex example:: A multi-component publishing example
- node Simple example, Complex example, Sample configuration, Sample configuration
- file{public_html}
- directory on the local machine.
- end lisp
- subsection Example: complex publishing configuration
- This more complicated example publishes an entire website, including
- Org files converted to HTML, image files, Emacs Lisp source code, and
- style sheets. The publishing directory is remote and private files are
- excluded.
- To ensure that links are preserved, care should be taken to replicate
- your directory structure on the web server, and to use relative file
- paths. For example, if your Org files are kept in
- file{~/images}, you would link to an image with
- example
- file:../images/myimage.png
- c
- On the web server, the relative path to the image should be the
- same. You can accomplish this by setting up an "images" folder in the
- right place on the web server, and publishing images to it.
- end lisp
- section Triggering publication
- Once properly configured, Org can publish with the following commands:
- kbd
- orgcmd{C-c C-e P,org-publish-current-project}
- Publish the project containing the current file.
- orgcmd{C-c C-e E,org-publish-all}
- Publish every project.
- vindex org-publish-use-timestamps-flag
- Org uses timestamps to track when a file has changed. The above functions
- normally only publish changed files. You can override this and force
- publishing of all files by giving a prefix argument to any of the commands
- above, or by customizing the variable
- code{#+SETUPFILE:} or
- comment node-name, next, previous, up
- node Working With Source Code, Miscellaneous, Publishing, Top
- cindex Schulte, Eric
- cindex source code, working with
- Source code can be included in Org mode documents using a
- :
- end example
- Org mode provides a number of features for working with live source code,
- including editing of code blocks in their native major-mode, evaluation of
- code blocks, converting code blocks into source files (known as
- menu
- * Structure of code blocks:: Code block syntax described
- * Editing source code:: Language major-mode editing
- * Exporting code blocks:: Export contents and/or results
- * Extracting source code:: Create pure source code files
- * Evaluating code blocks:: Place results of evaluation in the Org mode buffer
- * Library of Babel:: Use and contribute to a library of useful code blocks
- * Languages:: List of supported code block languages
- * Header arguments:: Configure code block functionality
- * Results of evaluation:: How evaluation results are handled
- * Noweb reference syntax:: Literate programming in Org mode
- * Key bindings and useful functions:: Work quickly with code blocks
- * Batch execution:: Call functions from the command line
- comment node-name, next, previous, up
- node Structure of code blocks, Editing source code, Working With Source Code, Working With Source Code
- cindex code block, structure
- cindex #+NAME
- samp{src} block or
- inline.samp{src} blocks may be inserted using Org mode's
- samp{src} block is
- end example
- The
- code{#+BEGIN_SRC} line. Switches and header arguments are optional.
- example
- src_<language>}
- example
- src_<language>[<header arguments>]}
- table
- item <#+NAME: name>
- This line associates a name with the code block. This is similar to the
- ref{The spreadsheet}). Names are assumed to be unique
- and the behavior of Org mode when two or more blocks share the same name is
- undefined.
- item <language>
- The language of the code in the block (see
- cindex source code, language
- ref{Literal examples})
- item <header arguments>
- Optional header arguments control many aspects of evaluation, export and
- tangling of code blocks (see
- item source code, header arguments
- end table
- comment Editing source code, Exporting code blocks, Structure of code blocks, Working With Source Code
- section Editing source code
- cindex source code, editing
- kbd{C-c '} to edit the current code block. This brings up
- a language major-mode edit buffer containing the body of the code
- block. Saving this buffer will write the new contents back to the Org
- buffer. Use
- code{org-src-mode} minor mode will be active in the edit buffer. The
- following variables can be used to configure the behavior of the edit
- buffer. See also the customization group
- table
- item org-src-lang-modes
- If an Emacs major-mode named
- code{<lang>} is the language named in the header line of the code block,
- then the edit buffer will be placed in that major-mode. This variable
- can be used to map arbitrary language names to existing major modes.
- item org-src-preserve-indentation
- This variable is especially useful for tangling languages such as
- Python, in which whitespace indentation in the output is critical.
- end table
- To turn on native code fontification in the
- code{org-src-fontify-natively}.
- comment Exporting code blocks, Extracting source code, Editing source code, Working With Source Code
- section Exporting code blocks
- cindex source code, exporting
- It is possible to export the emph{results}
- of code block evaluation,
- emph{none}. For most languages, the default exports code.
- However, for some languages (e.g.code{ditaa}) the default exports the
- results of code block evaluation. For information on exporting code block
- bodies, see
- code{:exports} header argument can be used to specify export
- behavior:
- table
- item :exports code
- The default in most languages. The body of the code block is exported, as
- described in
- item :exports results
- The code block will be evaluated and the results will be placed in the
- Org mode buffer for export, either updating previous results of the code
- block located anywhere in the buffer or, if no previous results exist,
- placing the results immediately after the code block. The body of the code
- block will not be exported.
- item :exports none
- Neither the code block nor its results will be exported.
- code{org-export-babel-evaluate} variable to
- comment node-name, next, previous, up
- node Extracting source code, Evaluating code blocks, Exporting code blocks, Working With Source Code
- cindex tangling
- cindex code block, extracting source code
- Creating pure source code files by extracting code from source blocks is
- referred to as ``tangling''---a term adopted from the literate programming
- community. During ``tangling'' of code blocks their bodies are expanded
- using
- ref{Noweb reference syntax}).
- table
- item :tangle no
- The default. The code block is not included in the tangled output.
- samp{.org} replaced by the extension
- for the block language.
- samp{filename}.
- kindex C-c C-v t
- table
- item org-babel-tangle
- Tangle the current file. Bound to
- item org-babel-tangle-file
- Choose a file to tangle. Bound to
- end table
- table
- item org-babel-post-tangle-hook
- This hook is run from within code files tangled by
- end table
- section Evaluating code blocks
- cindex source code, evaluating
- footnote{Whenever code is evaluated there is a
- potential for that code to do harm. Org mode provides safeguards to ensure
- that code is only evaluated after explicit confirmation from the user. For
- information on these safeguards (and on how to disable them) see
- code{#+RESULTS} and optionally a cache identifier
- and/or the name of the evaluated code block. The default value of
- code{org-babel-results-keyword}.
- By default, the evaluation facility is only enabled for Lisp code blocks
- specified as
- ref{Languages} for a list of supported
- languages and
- kindex C-c C-c
- There are a number of ways to evaluate code blocks. The simplest is to press
- kbd{C-c C-v e} with the point on a code block
- code{org-babel-no-eval-on-ctrl-c-ctrl-c} variable can be used to remove code
- evaluation from the
- code{org-babel-execute-src-block} function to evaluate the block and insert
- its results into the Org mode buffer.
- ref{Library of Babel})
- can be executed. Named code blocks can be executed with a separate
- code{#+CALL:} line is
- end example
- The syntax for inline evaluation of named code blocks is
- end example
- code
- ref{Structure of code blocks}).
- code{#+CALL:} line that passes the
- number four to a code block named
- code{:var n=2}, would be written as
- item <inside header arguments>
- Inside header arguments are passed through and applied to the named code
- block. These arguments use header argument syntax rather than standard
- function call syntax. Inside header arguments affect how the code block is
- evaluated. For example,
- code{STDOUT} during execution of the code block.
- code{:results html} will insert the results of the call line
- evaluation in the Org buffer, wrapped in a
- code{#+CALL:} lines see
- end table
- section Library of Babel
- cindex source code, library
- ref{Evaluating
- code blocks} for information on the syntax of remote code block evaluation).
- The central repository of code blocks in the ``Library of Babel'' is housed
- in an Org mode file located in the
- code{org-babel-lob-ingest}.
- code{org-babel-lob-ingest} function, bound to
- node Languages, Header arguments, Library of Babel, Working With Source Code
- cindex babel, languages
- cindex code block, languages
- Code blocks in the following languages are supported.
- columnfractions 0.28 0.3 0.22 0.2
- b{Language} b{Identifier} b{Language} b{Identifier}
- tab asymptote tab awk
- tab calc tab C
- tab C++ tab clojure
- tab css tab ditaa
- tab dot tab emacs-lisp
- tab gnuplot tab haskell
- tab java tab
- tab js tab latex
- tab ledger tab lisp
- tab lilypond tab matlab
- tab mscgen tab ocaml
- tab octave tab org
- tab oz tab perl
- tab plantuml tab python
- tab R tab ruby
- tab sass tab scheme
- tab screen tab sh
- tab sql tab sqlite
- uref{http://orgmode.org/worg/org-contrib/babel/languages}.
- The
- code{emacs-lisp} is enabled). This variable can
- be set using the customization interface or by adding code like the following
- to your emacs configuration.
- code{emacs-lisp} evaluation and enables evaluation of
- end quotation
- end lisp
- It is also possible to enable support for a language by loading the related
- elisp file with
- quotation
- The following adds support for evaluating
- end quotation
- end lisp
- section Header arguments
- cindex source code, block header arguments
- Code block functionality can be configured with header arguments. This
- section provides an overview of the use of header arguments, and then
- describes each header argument in detail.
- end menu
- subsection Using header arguments
- The values of header arguments can be set in six different ways, each more
- specific (and having higher priority) than the last.
- end menu
- subsubheading System-wide header arguments
- code{org-babel-default-header-args} variable:
- end example
- example
- c Its value is
- c (:results . "replace")
- c (:cache . "no")
- c Documentation:
- c
- code{:noweb} header arguments to
- code{:noweb} references by default when evaluating source code
- blocks.
- end lisp
- subsubheading Language-specific header arguments
- Each language can define its own set of default header arguments. See the
- language-specific documentation available online at
- node Buffer-wide header arguments, Header arguments in Org mode properties, Language-specific header arguments, Using header arguments
- code{#+PROPERTY:} lines placed anywhere in an Org mode file (see
- code{session} to
- code{results} to
- example
- #+PROPERTY: session *R*
- #+PROPERTY: results silent
- node Header arguments in Org mode properties, Code block specific header arguments, Buffer-wide header arguments, Using header arguments
- ref{Property
- syntax}), which can be set on a buffer-wide or per-heading basis. An example
- of setting a header argument for all code blocks in a buffer is
- end example
- code{org-use-property-inheritance}. In the following example the value of
- the code{yes} in all code
- blocks in the subtree rooted at the following heading:
- end example
- vindex org-babel-default-header-args
- Properties defined in this way override the properties set in
- code{org-set-property} function bound to
- node Code block specific header arguments, Header arguments in function calls, Header arguments in Org mode properties, Using header arguments
- code{#+BEGIN_SRC} line.
- Properties set in this way override both the values of
- code{:results} header argument
- is set to
- code{:exports} header argument is set to
- LaTeX{}.
- end example
- Similarly, it is possible to set header arguments for inline code blocks
- {fac 5
- end example
- Code block header arguments can span multiple lines using
- code{#+HEADERS:} lines preceding a code block or nested between the
- code{#+BEGIN_SRC} line of a named code block.
- cindex #+HEADERS:
- Multi-line header arguments on an un-named code block:
- end example
- Multi-line header arguments on a named code block:
- end example
- comment node-name, next, previous, up
- code{#+CALL:} lines can be set as shown in the two examples below. For more
- information on the structure of ref{Evaluating code
- blocks}.
- The following will apply the
- code{#+CALL:} line.
- end example
- The following will apply the
- code{factorial} code block.
- end example
- subsection Specific header arguments
- Header arguments consist of an initial colon followed by the name of the
- argument in lowercase letters. The following header arguments are defined:
- end menu
- Additional header arguments are defined on a language-specific basis, see
- node var, results, Specific header arguments, Specific header arguments
- code{:var}
- The
- ref{var, Emacs Lisp evaluation of variables}). References
- include anything in the Org mode file that takes a
- code{#+TBLNAME:}, or
- code{#+BEGIN_EXAMPLE} blocks, other code blocks, and the results of other
- code blocks.
- Argument values can be indexed in a manner similar to arrays (see
- code{:var} header argument.
- end example
- The argument,
- samp{"string"} or a number
- table
- item table
- an Org mode table named with either a code{#+TBLNAME:} line
- end example
- code{#+NAME:} line (note that nesting is not
- carried through to the source code block)
- end example
- code{#+NAME:},
- optionally followed by parentheses
- end example
- code{#+NAME:}, followed by parentheses and
- optional arguments passed within the parentheses following the
- code block name using standard function call syntax
- end example
- code{#+NAME:} line
- end example
- subsubheading Alternate argument syntax
- It is also possible to specify arguments in a potentially more natural way
- using the
- example
- #+NAME: double(input=0, x=2)
- #+BEGIN_SRC emacs-lisp
- (* 2 (+ input x))
- #+END_SRC
- subsubheading Indexable variable values
- It is possible to reference portions of variable values by ``indexing'' into
- the variables. Indexes are 0 based with negative values counting back from
- the end. If an index is separated by
- emph{before} other table related header arguments
- like code{:colnames} and
- code{example-table} to the variable
- example
- #+NAME: example-table
- | 1 | a |
- | 2 | b |
- | 3 | c |
- | 4 | d |
- #+BEGIN_SRC emacs-lisp :var data=example-table[0,-1]
- data
- #+END_SRC
- #+results:
- : a
- code{:}, in which case the entire inclusive range is referenced. For
- example the following assigns the middle three rows of
- code{data}.
- end example
- Additionally, an empty index, or the single character
- code{0:-1}, as shown in the following example in which the entire first
- column is referenced.
- end example
- It is possible to index into the results of code blocks as well as tables.
- Any number of dimensions can be indexed. Dimensions are separated from one
- another by commas, as shown in the following example.
- end example
- code{(}, code{'} or
- example
- #+BEGIN_SRC sh :var filename=(buffer-file-name) :exports both
- wc -w $filename
- #+END_SRC
- example
- #+NAME: table
- | (a b c) |
- #+HEADERS: :var data=table[0,0]
- #+BEGIN_SRC perl
- $data
- #+END_SRC
- #+results:
- : (a b c)
- node results, file, var, Specific header arguments
- code{:results}
- There are three classes of
- itemize
- item
- item
- item
- end itemize
- itemize
- item
- code{return} statement be included in the body of the source
- code block. E.g.,
- item
- code{:results output}.
- subsubheading Type
- The following options are mutually exclusive and specify what type of results
- the code block will return. By default, results are inserted as either a
- table or scalar depending on their value.
- bullet
- code{table},
- code{:results value table}.
- code{list}
- The results should be interpreted as an Org mode list. If a single scalar
- value is returned it will be converted into a list with only one element.
- code{scalar},
- code{:results value verbatim}.
- code{file}
- The results will be interpreted as the path to a file, and will be inserted
- into the Org mode buffer as a file link. E.g.,
- item code{org}
- The results are interpreted as raw Org mode code and are inserted directly
- into the buffer. If the results look like a table they will be aligned as
- such by Org mode. E.g.,
- item
- code{begin_html}
- block. E.g.,
- item
- LaTeX{} and are enclosed in a
- code{:results value latex}.
- code{code}
- Result are assumed to be parsable code and are enclosed in a code block.
- E.g.,
- item
- code{:results value pp}.
- code{wrap}
- The result is wrapped in a RESULTS drawer. This can be useful for
- inserting code{org} syntax results in such a way that their
- extent is known and they can be automatically removed or replaced.
- subsubheading Handling
- The following results options indicate what happens with the
- results once they are collected.
- bullet
- code{silent}
- The results will be echoed in the minibuffer but will not be inserted into
- the Org mode buffer. E.g.,
- item
- code{:results output replace}.
- code{append}
- If there are pre-existing results of the code block then the new results will
- be appended to the existing results. Otherwise the new results will be
- inserted as with
- item
- code{replace}.
- node file, dir, results, Specific header arguments
- code{:file}
- The header argument
- code{[[file:]]} link (see
- code{:file} header argument
- automatically wrapping the code block body in the boilerplate code required
- to save output to the specified file. This is often useful for saving
- graphical output of a code block to the specified file.
- The argument to
- node dir, exports, file, Specific header arguments
- code{:dir} and remote execution
- While the
- code{:dir} specifies the default directory during code block
- execution. If it is absent, then the directory associated with the current
- buffer is used. In other words, supplying
- kbd{M-x cd path}, and
- then not supplying code{:dir} simply sets
- the value of the Emacs variable
- code{:dir}, you should supply a relative path for file output
- (e.g.code{:file myfile.jpg} or
- file{Work}
- in your home directory, you could use
- end example
- example
- #+BEGIN_SRC R :file plot.png :dir /dandyakuba.princeton.edu:
- plot(1:10, main=system("hostname", intern=TRUE))
- #+END_SRC
- example
- [[file:/scp:dandyakuba.princeton.edu:/home/dand/plot.png][plot.png]]
- code{:dir}
- sets the value of the Emacs variable
- subsubheading Further points
- bullet
- code{:dir} is used in conjunction with
- item
- code{:exports results} or
- emph{not} be expanded against
- code{default-directory} is altered using
- end itemize
- subsubsection
- code{:exports} header argument specifies what should be included in HTML
- or
- itemize
- item
- code{:exports code}.
- code{results}
- The result of evaluating the code is included in the exported file. E.g.,
- item
- code{:exports both}.
- code{none}
- Nothing is included in the exported file. E.g.,
- end itemize
- subsubsection
- code{:tangle} header argument specifies whether or not the code
- block should be included in tangled extraction of source code files.
- bullet
- code{tangle}
- The code block is exported to a source code file named after the full path
- (including the directory) and file name (w/o extension) of the Org mode file.
- E.g.,
- item
- code{:tangle no}.
- code{:tangle} header argument is interpreted
- as a path (directory and file name relative to the directory of the Org mode
- file) to which the block will be exported. E.g.,
- end itemize
- subsubsection
- code{:mkdirp} header argument can be used to create parent directories
- of tangled files when missing. This can be set to
- code{no} to inhibit directory creation.
- subsubsection
- code{:comments} header argument can be set as follows to control
- the insertion of extra comments into the tangled code file.
- bullet
- code{no}
- The default. No extra comments are inserted during tangling.
- code{link}
- The code block is wrapped in comments which contain pointers back to the
- original Org file from which the code was tangled.
- code{yes}
- A synonym for ``link'' to maintain backwards compatibility.
- code{org}
- Include text from the Org mode file as a comment.
- The text is picked from the leading context of the tangled code and is
- limited by the nearest headline or source block as the case may be.
- code{both}
- Turns on both the ``link'' and ``org'' comment options.
- code{noweb}
- Turns on the ``link'' comment option, and additionally wraps expanded noweb
- references in the code block body in link comments.
- node padline, no-expand, comments, Specific header arguments
- code{:padline}
- Control in insertion of padding lines around code block bodies in tangled
- code files. The default value is
- itemize
- item
- item
- end itemize
- subsubsection
- code{org-babel-expand-src-block}
- during tangling. This has the effect of assigning values to variables
- specified with ref{var}), and of replacing ``noweb''
- references (see
- code{:no-expand} header argument can be used to turn off this behavior.
- subsubsection
- code{:session} header argument starts a session for an interpreted
- language where state is preserved.
- By default, a session is not started.
- A string passed to the
- node noweb, noweb-ref, session, Specific header arguments
- code{:noweb}
- The
- ref{Noweb reference syntax}) references in a code block. This header
- argument can have one of three values: code{no}, or
- itemize
- item
- item
- item
- end itemize
- code{<<reference>>}.
- This behavior is illustrated in the following example. Because the
- example
- -- <<example>>
- example
- -- this is the
- -- multi-line body of example
- node noweb-ref, noweb-sep, noweb, Specific header arguments
- code{:noweb-ref}
- When expanding ``noweb'' style references the bodies of all code block with
- emph{or} a
- footnote{(The example needs property inheritance
- to be turned on for the ref{Property
- inheritance}).}.
- {print $5 " " $6
- {print $2
- end example
- The ref{noweb-sep}) header argument holds the string
- used to separate accumulate noweb references like those above. By default a
- newline is used.
- subsubsection
- code{:noweb-sep} header argument holds the string used to separate
- accumulate noweb references (see
- node cache, sep, noweb-sep, Specific header arguments
- code{:cache}
- The
- code{yes} or
- itemize
- item
- item
- code{#+results:} line and will be checked on subsequent
- executions of the code block. If the code block has not
- changed since the last time it was evaluated, it will not be re-evaluated.
- code{caller} will not be re-run unless the results of
- example
- #+NAME: random
- #+BEGIN_SRC R :cache yes
- runif(1)
- #+END_SRC
- #+results[a2a72cd647ad44515fab62e144796432793d68e1]: random
- 0.4659510825295
- #+NAME: caller
- #+BEGIN_SRC emacs-lisp :var x=random :cache yes
- x
- #+END_SRC
- #+results[bec9c8724e397d5df3b696502df3ed7892fc4f5f]: caller
- 0.254227238707244
- node sep, hlines, cache, Specific header arguments
- code{:sep}
- The
- code{org-open-at-point} function bound to
- ref{file})
- header argument.
- By default, when
- node hlines, colnames, sep, Specific header arguments
- code{:hlines}
- Tables are frequently represented with one or more horizontal lines, or
- hlines. The
- code{yes} or code{no}.
- bullet
- code{no}
- Strips horizontal lines from the input table. In most languages this is the
- desired effect because an
- code{:hlines no} or relying on the
- default value yields the following results.
- end example
- code{yes}
- Leaves hlines in the table. Setting
- example
- #+TBLNAME: many-cols
- | a | b | c |
- |---+---+---|
- | d | e | f |
- |---+---+---|
- | g | h | i |
- #+NAME: echo-table
- #+BEGIN_SRC python :var tab=many-cols :hlines yes
- return tab
- #+END_SRC
- #+results: echo-table
- | a | b | c |
- |---+---+---|
- | d | e | f |
- |---+---+---|
- | g | h | i |
- end itemize
- subsubsection
- code{:colnames} header argument accepts the values
- code{no}, or code{nil}.
- Note that the behavior of the
- code{:colnames} header argument entirely given the ease with which tables
- with column names may be handled directly in Emacs Lisp.
- bullet
- code{nil}
- If an input table looks like it has column names
- (because its second row is an hline), then the column
- names will be removed from the table before
- processing, then reapplied to the results.
- end example
- Please note that column names are not removed before the table is indexed
- using variable indexing
- item
- item
- code{nil} even if the table
- does not ``look like'' it has column names (i.e.
- end itemize
- subsubsection
- code{:rownames} header argument can take on the values
- code{no}, with a default value of
- itemize
- item
- item
- example
- #+TBLNAME: with-rownames
- | one | 1 | 2 | 3 | 4 | 5 |
- | two | 6 | 7 | 8 | 9 | 10 |
- #+NAME: echo-table-once-again
- #+BEGIN_SRC python :var tab=with-rownames :rownames yes
- return [[val + 10 for val in row] for row in tab]
- #+END_SRC
- #+results: echo-table-once-again
- | one | 11 | 12 | 13 | 14 | 15 |
- | two | 16 | 17 | 18 | 19 | 20 |
- xref{var, Indexable variable values}.
- node shebang, eval, rownames, Specific header arguments
- code{:shebang}
- Setting the
- :
- node eval, , shebang, Specific header arguments
- code{:eval}
- The
- code{:eval} header argument can be useful for
- protecting against the evaluation of dangerous code blocks or to ensure that
- evaluation will require a query regardless of the value of the
- code{:eval} and their effects are shown below.
- code
- item query
- Evaluation of the code block will require a query.
- item query-export
- Evaluation of the code block during export will require a query.
- code{org-confirm-babel-evaluate} variable see
- node Results of evaluation, Noweb reference syntax, Header arguments, Working With Source Code
- cindex code block, results of evaluation
- code{:results value} or
- ref{results}.
- columnfractions 0.26 0.33 0.41
- tab tab
- item tab value of last expression
- item tab contents of STDOUT
- end multitable
- Note: With code{:session} and
- non-session is returned to Org mode as a table (a one- or two-dimensional
- vector of strings or numbers) when appropriate.
- subsubsection
- code{return} statement is present, and so a
- subsubsection
- subsection Session
- code{:results value}
- The code is passed to an interpreter running as an interactive Emacs inferior
- process. Only languages which provide tools for interactive evaluation of
- code have session support, so some language (e.g., C and ditaa) do not
- support the
- code{:session} header argument as well.
- Unless the
- code{_} in Python and Ruby, and the value of
- subsubsection
- code{STDOUT} if the same code
- were passed to a non-interactive interpreter running as an external
- process. For example, compare the following two blocks:
- end example
- In non-session mode, the `2' is not printed and does not appear.
- end example
- But in
- node Noweb reference syntax, Key bindings and useful functions, Results of evaluation, Working With Source Code
- cindex code block, noweb reference
- cindex source code, noweb reference
- The ``noweb'' (see
- example
- <<code-block-name>>
- code{:noweb} header
- argument. If
- code{:noweb no}, the default, then the reference is not
- expanded before evaluation. See the
- code{:noweb no}, was chosen to ensure that
- correct code is not broken in a language, such as Ruby, where
- code{<<arg>>} is not
- syntactically valid in languages that you use, then please consider setting
- the default value.
- Note: if noweb tangling is slow in large Org-mode files consider setting the
- code{:noweb-ref} header
- argument.
- section Key bindings and useful functions
- multitable
- kindex C-c C-c
- kbd{C-c C-c} code{org-babel-execute-src-block}
- item tab
- kindex C-up
- kbd{C-tab
- kindex M-down
- kbd{M-tab
- end multitable
- In an Org mode buffer, the following key bindings are active:
- columnfractions 0.45 0.55
- kindex C-c C-v C-a
- kbd{C-c C-v a} kbd{C-c C-v C-a} code{org-babel-sha1-hash}
- kindex C-c C-v C-b
- kbd{C-c C-v b} kbd{C-c C-v C-b} code{org-babel-execute-buffer}
- kindex C-c C-v C-f
- kbd{C-c C-v f} kbd{C-c C-v C-f} code{org-babel-tangle-file}
- item tab
- kindex C-c C-v h
- kbd{C-c C-v h} code{org-babel-describe-bindings}
- kindex C-c C-v C-l
- kbd{C-c C-v l} kbd{C-c C-v C-l} code{org-babel-lob-ingest}
- kindex C-c C-v C-p
- kbd{C-c C-v p} kbd{C-c C-v C-p} code{org-babel-expand-src-block}
- kindex C-c C-v C-s
- kbd{C-c C-v s} kbd{C-c C-v C-s} code{org-babel-execute-subtree}
- kindex C-c C-v C-t
- kbd{C-c C-v t} kbd{C-c C-v C-t} code{org-babel-tangle}
- kindex C-c C-v C-z
- kbd{C-c C-v z} kbd{C-c C-v C-z} code{org-babel-switch-to-session}
- c When possible these keybindings were extended to work when the control key is
- c columnfractions 0.25 0.75
- item tab
- c kbd{C-c C-v C-b} code{org-babel-execute-buffer}
- item tab
- c kbd{C-c C-v C-l} code{org-babel-lob-ingest}
- item tab
- c kbd{C-c C-v C-s} code{org-babel-execute-subtree}
- item tab
- c kbd{C-c C-v C-z} code{org-babel-switch-to-session}
- end multitable
- section Batch execution
- cindex source code, batch execution
- It is possible to call functions from the command line. This shell
- script calls
- example
- #!/bin/sh
- # -*- mode: shell-script -*-
- #
- # tangle files with org-mode
- #
- DIR=`pwd`
- FILES=""
- ORGINSTALL="~/src/org/lisp/org-install.el"
- # wrap each argument in the code required to call tangle on it
- for i in $; do
- FILES="$FILES \"$i\""
- done
- emacs -Q --batch -l $ORGINSTALL \
- --eval "(progn
- (add-to-list 'load-path (expand-file-name \"~/src/org/lisp/\"))
- (add-to-list 'load-path (expand-file-name \"~/src/org/contrib/lisp/\"))
- (require 'org)(require 'org-exp)(require 'ob)(require 'ob-tangle)
- (mapc (lambda (file)
- (find-file (expand-file-name file \"$DIR\"))
- (org-babel-tangle)
- (kill-buffer)) '($FILES)))" 2>&1 |grep tangled
- node Miscellaneous, Hacking, Working With Source Code, Top
- menu
- * Completion:: M-TAB knows what you need
- * Easy Templates:: Quick insertion of structural elements
- * Speed keys:: Electric commands at the beginning of a headline
- * Code evaluation security:: Org mode files evaluate inline code
- * Customization:: Adapting Org to your taste
- * In-buffer settings:: Overview of the #+KEYWORDS
- * The very busy C-c C-c key:: When in doubt, press C-c C-c
- * Clean view:: Getting rid of leading stars in the outline
- * TTY keys:: Using Org on a tty
- * Interaction:: Other Emacs packages
- * org-crypt.el:: Encrypting Org files
- node Completion, Easy Templates, Miscellaneous, Miscellaneous
- cindex completion, of
- cindex completion, of TODO keywords
- cindex completion, of option keywords
- cindex completion, of property keys
- cindex
- cindex TODO keywords completion
- cindex option keyword completion
- cindex link abbreviations, completion of
- Emacs would not be Emacs without completion, and Org mode uses it whenever it
- makes sense. If you prefer an i{ido}-like interface for
- some of the completion prompts, you can specify your preference by setting at
- most one of the variables
- code{org-completion-use-ido}.
- Org supports in-buffer completion. This type of completion does
- not make use of the minibuffer. You simply type a few letters into
- the buffer and use the key to complete text right there.
- kbd
- key{TAB}
- key{TAB}
- Complete word at point
- bullet
- item
- After TeX{} symbols supported by the exporter.
- samp{*}, complete headlines in the current buffer so that they
- can be used in search links like
- item
- After
- code{org-tag-alist} (possibly set through the
- pxref{Setting tags}), or it is created
- dynamically from all tags used in the current buffer.
- samp{:} and not in a headline, complete property keys. The list
- of keys is constructed dynamically from all keys used in the current
- buffer.
- samp{[}, complete link abbreviations (
- item
- After samp{TYP_TODO} or
- kbd{M-
- item
- In the line after
- : valid keys for this line.
- end itemize
- node Easy Templates, Speed keys, Completion, Miscellaneous
- cindex template insertion
- code{#+BEGIN_SRC} and
- file{yasnippet}.
- To insert a structural element, type a
- kbd{
- multitable
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- item tab
- end multitable
- For example, on an empty line, typing "<e" and then pressing TAB, will expand
- into a complete EXAMPLE template.
- You can install additional templates by customizing the variable
- node Speed keys, Code evaluation security, Easy Templates, Miscellaneous
- cindex speed keys
- vindex org-speed-commands-user
- Single keys can be made to execute commands when the cursor is at the
- beginning of a headline, i.e.
- code{org-use-speed-commands} to activate this feature. There is a
- pre-defined list of commands, and you can add more such commands using the
- variable
- kbd{?}
- with the cursor at the beginning of a headline.
- section Code evaluation and security issues
- Org provides tools to work with the code snippets, including evaluating them.
- Running code on your machine always comes with a security risk. Badly
- written or malicious code can be executed on purpose or by accident. Org has
- default settings which will only evaluate such code if you give explicit
- permission to do so, and as a casual user of these features you should leave
- these precautions intact.
- For people who regularly work with such code, the confirmation prompts can
- become annoying, and you might want to turn them off. This can be done, but
- you must be aware of the risks that are involved.
- Code evaluation can happen under the following circumstances:
- i
- kbd{C-c
- C-c} in the block. The most important thing to realize here is that Org mode
- files which contain code snippets are, in a certain sense, like executable
- files. So you should accept them and load them into Emacs only from trusted
- sources---just like you would do with a program you install on your computer.
- Make sure you know what you are doing before customizing the variables
- which take off the default security brakes.
- end defopt
- For example, here is how to execute "ditaa" code (which is considered safe)
- without asking:
- end example
- code{shell} and
- pxref{External
- links}). These links can be problematic because the code to be evaluated is
- not visible.
- end defopt
- end defopt
- pxref{The spreadsheet}) are code that is evaluated
- either by the i{Emacs Lisp} interpreter.
- node Customization, In-buffer settings, Code evaluation security, Miscellaneous
- cindex customization
- cindex variables, for customization
- There are more than 180 variables that can be used to customize
- Org. For the sake of compactness of the manual, I am not
- describing the variables here. A structured overview of customization
- variables is available with
- code{Browse Org Group} from the
- pxref{In-buffer settings}).
- section Summary of in-buffer settings
- cindex special keywords
- Org mode uses special lines in the buffer to define settings on a
- per-file basis. These lines start with a
- kbd{C-c C-c} with the cursor still in the line to
- activate the changes immediately. Otherwise they become effective only
- when the file is visited again in a new Emacs session.
- table
- item #+ARCHIVE: %s_done::
- This line sets the archive location for the agenda file. It applies for
- all subsequent lines until the next
- code{org-archive-location}.
- samp{#+CATEGORY} line, or the
- end of the file. The first such line also applies to any entries before it.
- cindex property, COLUMNS
- Set the default format for columns view. This format applies when
- columns view is invoked in locations where no
- item #+CONSTANTS: name1=value1 ...
- vindex org-table-formula
- Set file-local values for constants to be used in table formulas. This
- line sets the local variable
- code{org-table-formula-constants}.
- item #+DRAWERS: NAME1 .....
- code{org-drawers}.
- vindex org-link-abbrev-alist
- These lines (several are allowed) specify link abbreviations.
- code{org-link-abbrev-alist}.
- vindex org-highest-priority
- vindex org-default-priority
- This line sets the limits and the default for the priorities. All three
- must be either letters A-Z or numbers 0-9. The highest priority must
- have a lower ASCII number than the lowest priority.
- cindex #+SETUPFILE
- : when starting Org mode for a file, when pressing
- kbd{C-c '}.
- cindex #+STARTUP:
- This line sets options to be used at startup of Org mode, when an
- Org file is being visited.
- The first set of options deals with the initial visibility of the outline
- tree. The corresponding variable for global default settings is
- code{t}, which means
- vindex org-startup-folded
- code{overview}, STARTUP keyword
- code{content}, STARTUP keyword
- code{showall}, STARTUP keyword
- code{showeverything}, STARTUP keyword
- r{top-level headlines only}
- content
- r{no folding of any entries}
- showeverything
- end example
- cindex
- cindex
- code{org-startup-indented}
- example
- indent code{org-indent-mode} turned on}
- noindent code{org-indent-mode} turned off}
- vindex org-startup-align-all-tables
- Then there are options for aligning tables upon visiting a file. This
- is useful in files containing narrowed table columns. The corresponding
- variable is
- code{nil}.
- code{align}, STARTUP keyword
- code{noalign}, STARTUP keyword
- r{align all tables}
- noalign
- end example
- code{org-startup-with-inline-images}, with a
- default value
- cindex
- cindex
- example
- inlineimages
- r{don't show inline images on startup}
- vindex org-log-done
- vindex org-log-repeat
- Logging the closing and reopening of TODO items and clock intervals can be
- configured using these options (see variables
- code{org-log-note-clock-out} and
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- cindex
- example
- logdone
- r{record timestamp and a note when DONE}
- nologdone
- r{record a time when reinstating a repeating item}
- lognoterepeat
- r{do not record when reinstating repeating item}
- lognoteclock-out
- r{don't record a note when clocking out}
- logreschedule
- r{record a note when scheduling time changes}
- nologreschedule
- r{record a timestamp when deadline changes}
- lognoteredeadline
- r{do not record when a deadline date changes}
- logrefile
- r{record a note when refiling}
- nologrefile
- end example
- vindex org-odd-levels-only
- Here are the options for hiding leading stars in outline headings, and for
- indenting outlines. The corresponding variables are
- code{org-odd-levels-only}, both with a
- default setting code{showstars} and
- cindex
- cindex
- cindex
- cindex
- example
- hidestars
- r{show all stars starting a headline}
- indent
- r{no virtual indentation according to outline level}
- odd
- r{allow all outline levels}
- vindex org-put-time-stamp-overlays
- code{org-put-time-stamp-overlays} and
- cindex
- example
- customtime
- end example
- code{constants-unit-system}).
- code{constcgs}, STARTUP keyword
- code{constSI}, STARTUP keyword
- r{
- r{
- end example
- vindex org-footnote-auto-label
- code{org-footnote-define-inline},
- code{org-footnote-auto-adjust}.
- code{fninline}, STARTUP keyword
- code{nofninline}, STARTUP keyword
- code{fnlocal}, STARTUP keyword
- code{fnprompt}, STARTUP keyword
- code{fnauto}, STARTUP keyword
- code{fnconfirm}, STARTUP keyword
- code{fnplain}, STARTUP keyword
- code{fnadjust}, STARTUP keyword
- code{nofnadjust}, STARTUP keyword
- r{define footnotes inline}
- fnnoinline
- r{define footnotes near first reference, but not inline}
- fnprompt
- r{create
- r{offer automatic label for editing or confirmation}
- fnplain code{[1]}-like labels automatically}
- fnadjust
- r{do not renumber and sort automatically}
- cindex org-hide-block-startup
- To hide blocks on startup, use these keywords. The corresponding variable is
- cindex
- cindex
- example
- hideblocks
- r{Do not hide blocks on startup}
- cindex org-pretty-entities
- The display of entities as UTF-8 characters is governed by the variable
- cindex
- cindex
- example
- entitiespretty
- r{Leave entities plain}
- item #+TAGS: TAG1(c1) TAG2(c2)
- emph{fast tag selection}
- keys. The corresponding variable is
- item #+TBLFM:
- This line contains the formulas for the table directly above the line.
- itemx #+OPTIONS:, #+BIND:, #+XSLT:,
- itemx #+LATEX_HEADER:, #+STYLE:, #+LINK_UP:, #+LINK_HOME:,
- ref{Export options}.
- vindex org-todo-keywords
- These lines set the TODO keywords and their interpretation in the
- current file. The corresponding variable is
- end table
- section The very busy C-c C-c key
- cindex C-c C-c, overview
- The key
- emph{tags} to a headline (
- emph{``Hey Org, look
- here and update according to what you see here''}. Here is a summary of
- what this means in different contexts.
- minus
- item
- If the cursor is in one of the special
- item
- If the cursor is inside a table, realign the table. This command
- works even if the automatic table editor has been turned off.
- code{#+TBLFM} line, re-apply the formulas to
- the entire table.
- item
- If the cursor is on a
- item
- If the cursor is in a property line or at the start or end of a property
- drawer, offer property commands.
- item
- If the cursor is on a statistics cookie, update it.
- item
- If the cursor is on a numbered item in a plain list, renumber the
- ordered list.
- code{#+BEGIN} line of a dynamic block, the
- block is updated.
- end itemize
- section A cleaner outline view
- cindex dynamic indentation
- cindex clean outline view
- Some people find it noisy and distracting that the Org headlines start with a
- potentially large number of stars, and that text below the headlines is not
- indented. While this is no problem when writing a
- emph{list-oriented} outline, indented structure is a lot cleaner:
- group
- * Top level headline | * Top level headline
- ** Second level | * Second level
- *** 3rd level | * 3rd level
- some text | some text
- *** 3rd level | * 3rd level
- more text | more text
- * Another top level headline | * Another top level headline
- end example
- footnote{Emacs 23.1 can actually crash
- with
- code{org-indent-mode}. In
- this minor mode, all lines are prefixed for display with the necessary amount
- of spacecode{org-indent-mode} also sets the
- code{visual-line-mode} (or purely setting
- footnote{See the variable
- code{org-hide}
- facecode{org-indent-mode} sets
- code{t} and
- code{nil}.} - see below under
- code{org-indent-mode} for all files by customizing
- the variable
- example
- #+STARTUP: indent
- enumerate
- emph{Indentation of text below headlines}
- example
- *** 3rd level
- more text, now indented
- vindex org-adapt-indentation
- Org supports this with paragraph filling, line wrapping, and structure
- editingcode{org-adapt-indentation}.},
- preserving or adapting the indentation as appropriate.
- vindex org-hide-leading-stars
- * You can modify the display in such a way that
- all leading stars become invisible. To do this in a global way, configure
- the variable
- example
- #+STARTUP: hidestars
- #+STARTUP: showstars
- example
- end group
- noindent
- r{(face)}
- The leading stars are not truly replaced by whitespace, they are only
- fontified with the face
- i{almost} invisible, for
- example using the color
- item
- footnote{When you need to specify a level for a property search
- or refile targets, .}. In this
- way we get the outline view shown at the beginning of this section. In order
- to make the structure editing and export commands handle this convention
- correctly, configure the variable
- example
- #+STARTUP: odd
- #+STARTUP: oddeven
- kbd{M-x org-convert-to-odd-levels
- RET} in that file. The reverse operation is
- end enumerate
- section Using Org on a tty
- key{left},
- key{up}, key{TAB} and
- key{Meta} and/or
- kbd{S-
- kbd{C-c .} to re-insert the timestamp.
- columnfractions 0.15 0.2 0.1 0.2
- b{Default} b{Alternative 1} b{Speed key} b{Alternative 2}
- kbd{S-tab key{TAB}} kbd{C}
- item key{left}} kbd{C-c C-x l} kbd{l} kbd{key{left}}
- kbd{M-S-tab tab tab
- kbd{M-tab tab tab key{Esc}
- item key{right}} kbd{C-c C-x R} kbd{R}
- item key{up}} kbd{C-c C-x u} kbd{ } kbd{key{up}}
- kbd{M-S-tab tab tab
- kbd{M-tab tab tab key{Esc}
- item key{down}} kbd{C-c C-x D} kbd{D}
- item key{RET}} kbd{C-c C-x c} kbd{ }
- item key{RET}} kbd{C-c C-x m} kbd{ } kbd{key{RET}}
- kbd{M-S-tab tab tab
- kbd{S-tab key{left}} kbd{ }
- item key{right}} kbd{C-c tab tab
- kbd{S-tab key{up}} kbd{ }
- item key{down}} kbd{C-c tab tab
- kbd{C-S-tab key{left}} kbd{ }
- item key{right}} kbd{C-c C-x tab tab
- node Interaction, org-crypt.el, TTY keys, Miscellaneous
- cindex packages, interaction with other
- Org lives in the world of GNU Emacs and interacts in various ways
- with other code out there.
- end menu
- subsection Packages that Org cooperates with
- asis
- file{calc.el}
- item
- pxref{The spreadsheet}). Org
- checks for the availability of Calc by looking for the function
- xref{Embedded Mode,
- , Embedded Mode, Calc, GNU Emacs Calc Manual}.
- file{constants.el} by Carsten Dominik
- file{constants.el}
- vindex org-table-formula-constants
- In a table formula (
- code{org-table-formula-constants}, install
- the
- samp{M} for
- . You will need version 2.0 of this package, available
- at
- code{constants-get}, which has to be autoloaded in your
- setup. See the installation instructions in the file
- item
- cindex
- cindex Dominik, Carsten
- Org mode can make use of the CD
- LaTeX{} fragments into Org files. See
- item
- cindex
- lisp
- (add-hook 'org-mode-hook
- (lambda () (imenu-add-to-menubar "Imenu")))
- vindex org-imenu-depth
- By default the index is two levels deep---you can modify the depth using
- the option
- item
- cindex
- cindex Wiegley, John
- Org used to use this package for capture, but no longer does.
- file{speedbar.el} by Eric M. Ludlam
- file{speedbar.el}
- kbd{<} in the Speedbar frame.
- file{table.el}
- file{table.el} by Takaaki Ota
- cindex table editor,
- cindex
- cindex Ota, Takaaki
- Complex ASCII tables with automatic line wrapping, column- and row-spanning,
- and alignment can be created using the Emacs table package by Takaaki Ota
- (
- kbd{C-c '} to edit them, similar to source code snippets.
- kbd
- file{table.el} table. Works when the cursor is in a table.el table.
- orgcmd{C-c ~,org-table-create-with-table.el}
- Insert a
- file{table.el} format and the Org mode
- format. See the documentation string of the command
- end table
- item
- cindex
- cindex Baur, Steven L.
- Org mode recognizes numerical footnotes as provided by this package.
- However, Org mode also has its own footnote support (
- file{footnote.el} unnecessary.
- node Conflicts, , Cooperation, Interaction
- table
- cindex
- vindex org-support-shift-select
- In Emacs 23,
- kbd{S-
- kbd{S-
- code{org-support-shift-select}. Org mode then tries to accommodate shift
- selection by (i) using it outside of the special contexts where special
- commands apply, and by (ii) extending an existing active region even if the
- cursor moves across a special context.
- file{CUA.el} by Kim. F. Storm
- file{CUA.el}
- vindex org-replace-disputed-keys
- Key bindings in Org conflict with the
- code{pc-select-mode} and
- code{shift-selection-mode}, see previous paragraph. If you are using Emacs
- 23, you probably don't want to use another package for this purpose. However,
- if you prefer to leave these keys to a different package while working in
- Org mode, configure the variable
- example
- S-UP result{} M-n
- S-LEFT result{} M-+
- C-S-LEFT result{} M-S-+
- vindex org-disputed-keys
- Yes, these are unfortunately more difficult to remember. If you want
- to have other replacement keys, look at the variable
- item
- cindex
- code{[tab]} instead of
- lisp
- (add-hook 'org-mode-hook
- (lambda ()
- (org-set-local 'yas/trigger-key [tab])
- (define-key yas/keymap [tab] 'yas/next-field-or-maybe-expand)))
- lisp
- (defun yas/org-very-safe-expand ()
- (let ((yas/fallback-behavior 'return-nil)) (yas/expand)))
- lisp
- (add-hook 'org-mode-hook
- (lambda ()
- (make-variable-buffer-local 'yas/trigger-key)
- (setq yas/trigger-key [tab])
- (add-to-list 'org-tab-first-hook 'yas/org-very-safe-expand)
- (define-key yas/keymap [tab] 'yas/next-field)))
- item
- cindex
- kbd{S-<cursor>} keys, so everything written
- in the paragraph above about CUA mode also applies here. If you want make
- the windmove function active in locations where Org mode does not have
- special functionality on key{cursor}}, add this to your
- configuration:
- end lisp
- file{viper.el} by Michael Kifer
- file{viper.el}
- kbd{C-c /} and therefore makes this key not access the
- corresponding Org mode command
- code{viper-vi-global-user-map} with
- end lisp
- node org-crypt.el, , Interaction, Miscellaneous
- cindex
- cindex
- samp{:crypt:} tag will be automatically
- be encrypted when the file is saved. If you want to use a different tag just
- customize the
- file{.emacs}:
- end example
- Excluding the crypt tag from inheritance prevents already encrypted text
- being encrypted again.
- appendix Hacking
- menu
- * Hooks:: Who to reach into Org's internals
- * Add-on packages:: Available extensions
- * Adding hyperlink types:: New custom link types
- * Context-sensitive commands:: How to add functionality to such commands
- * Tables in arbitrary syntax:: Orgtbl for
- end menu
- section Hooks
- uref{http://orgmode.org/worg/org-configs/org-hooks.php}.
- section Add-on packages
- uref{http://orgmode.org}. The list of contributed packages, along with
- documentation about each package, is maintained by the Worg project at
- node Adding hyperlink types, Context-sensitive commands, Add-on packages, Hacking
- cindex hyperlinks, adding new types
- Org has a large number of hyperlink types built-in
- (
- file{org-man.el}, that will add support for creating links like
- lisp
- ;;; org-man.el - Support for links to manpages in Org
- (require 'org)
- (org-add-link-type "man" 'org-man-open)
- (add-hook 'org-store-link-functions 'org-man-store-link)
- (defcustom org-man-command 'man
- "The Emacs command to be used to display a man page."
- :group 'org-link
- :type '(choice (const man) (const woman)))
- (defun org-man-open (path)
- "Visit the manpage on PATH.
- PATH should be a topic that can be thrown at the man command."
- (funcall org-man-command path))
- (defun org-man-store-link ()
- "Store a link to a manpage."
- (when (memq major-mode '(Man-mode woman-mode))
- ;; This is a man page, we do make this link
- (let* ((page (org-man-get-page-name))
- (link (concat "man:" page))
- (description (format "Manpage for %s" page)))
- (org-store-link-props
- :type "man"
- :link link
- :description description))))
- (defun org-man-get-page-name ()
- "Extract the page name from the buffer name."
- ;; This works for both `Man-mode' and `woman-mode'.
- (if (string-match " \\(\\S-+\\)\\*" (buffer-name))
- (match-string 1 (buffer-name))
- (error "Cannot create link to this man page")))
- (provide 'org-man)
- ;;; org-man.el ends here
- noindent
- You would activate this new link type in
- lisp
- (require 'org-man)
- noindent
- Let's go through the file and see what it does.
- item
- It does file{org.el} has been
- loaded.
- code{org-add-link-type} to define a new link type
- with prefix
- item
- code{org-store-link-functions}, in
- order to allow the command
- end enumerate
- The rest of the file defines the necessary variables and functions.
- First there is a customization variable that determines which Emacs
- command should be used to display man pages. There are two options,
- code{woman}. Then the function to follow a link is
- defined. It gets the link path as an argument---in this case the link
- path is just a topic for the manual command. The function calls the
- value of
- code{org-man-store-link} is defined. When you try
- to store a link with
- code{major-mode}. If not, the function must exit and
- return the value
- samp{man:}. Then it must call the command
- code{:type} and
- code{:description} property to provide a default for
- the link description when the link is later inserted into an Org
- buffer with
- code{org-PREFIX-complete-link} that implements special (e.g.
- kbd{C-c C-l}. Such a function should
- not accept any arguments, and return the full link with prefix.
- section Context-sensitive commands
- cindex add-ons, context-sensitive commands
- kbd{C-c C-c} (
- kbd{M-cursor} and
- file{org-R.el} which
- allows you to evaluate commands based on the
- footnote{
- ref{Working With Source Code} and is now obsolete.}. For this
- package, special contexts are lines that start with
- code{#+RR:}.
- end lisp
- The function first checks if the cursor is in such a line. If that is the
- case, code{t} to
- signal that action was taken, and
- code{nil} so that other, similar functions can have a try.
- section Tables and lists in arbitrary syntax
- cindex lists, in other modes
- LaTeX{}. However, this is extremely
- hard to do in a general way, would lead to a customization nightmare,
- and would take away much of the simplicity of the Orgtbl mode table
- editor.
- This appendix describes a different approach. We keep the Orgtbl mode
- table in its native format (the
- i{translate} the table to the correct syntax, and to
- i{target table}). This puts
- the burden of writing conversion functions on the user, but it allows
- for a very flexible system.
- Bastien added the ability to do the same with lists, in Orgstruct mode. You
- can use Org's facilities to edit and structure lists by turning
- LaTeX{} or Texinfo.)
- LaTeX{} example:: Step by step, almost a tutorial
- * Translator functions:: Copy and modify
- * Radio lists:: Doing the same for lists
- node Radio tables, A
- subsection Radio tables
- example
- noindent
- Just above the source table, we put a special line that tells
- Orgtbl mode how to translate this table and where to install it. For
- example:
- example
- #+ORGTBL: SEND table_name translation_function arguments....
- noindent
- code{translation_function} is the Lisp function
- that does the translation. Furthermore, the line can contain a list of
- arguments (alternating key and value) at the end. The arguments will be
- passed as a property list to the translation function for
- interpretation. A few standard parameters are already recognized and
- acted upon before the translation function is called:
- code
- item :skipcols (n1 n2 ...)
- List of columns that should be skipped. If the table has a column with
- calculation marks, that column is automatically discarded as well.
- Please note that the translator function sees the table
- end table
- LaTeX{} file. There are a
- number of different solutions:
- bullet
- samp{} lines.
- i{END}
- statement, for example TeX{} and {document
- LaTeX{}.
- kbd{M-x orgtbl-toggle-comment}
- makes this comment-toggling very easy, in particular if you bind it to a
- key.
- node A
- subsection A
- cindex
- LaTeX{} is to use the
- file{comment.sty}. It has to be
- activated by placing {comment
- footnote{By
- default this works only for
- code{orgtbl-radio-tables} to install templates for other
- modes.} with the command
- samp{salesfigures}. You
- will then get the following template:
- example
- % BEGIN RECEIVE ORGTBL salesfigures
- % END RECEIVE ORGTBL salesfigures
- \begin}
- #+ORGTBL: SEND salesfigures orgtbl-to-latex
- | | |
- \end}
- noindent
- LaTeX{}-verbatim-environments
- The
- code{orgtbl-to-latex} to convert the table into
- code{salesfigures}. You may now
- fill in the table---feel free to use the spreadsheet features
- samp{#+TBLFM} line contains an odd number of dollar characters,
- this may cause problems with font-lock in
- code{comment} environment that is used to balance the dollar
- expressions. If you are using AUC
- code{comment} environment to the
- variable
- example
- % BEGIN RECEIVE ORGTBL salesfigures
- % END RECEIVE ORGTBL salesfigures
- \begin}
- #+ORGTBL: SEND salesfigures orgtbl-to-latex
- | Month | Days | Nr sold | per day |
- |-------+------+---------+---------|
- | Jan | 23 | 55 | 2.4 |
- | Feb | 21 | 16 | 0.8 |
- | March | 22 | 278 | 12.6 |
- #+TBLFM: $4=$3/$2;%.1f
- % $ (optional extra dollar to keep font-lock happy, see footnote)
- \end}
- noindent
- When you are done, press
- . In this case we make sure
- that the table translator skips the first 2 lines of the source
- table, and tell the command to work as a : to not produce
- header and footer commands of the target table:
- {tabular{lrrr
- {1{c{Days
- {tabular
- {comment
- {comment
- end example
- The code{orgtbl-to-latex} is already part of
- Orgtbl mode. It uses a
- code{\hline}. Furthermore, it
- interprets the following parameters (see also
- table
- item :splice nil/t
- When set to t, return only table body lines, don't wrap them into a
- tabular environment. Default is nil.
- code{%s} for the
- original field value. For example, to wrap each field value in dollars,
- you could use
- code{:fmt (2 "$%s$" 4 "%s\\%%")}.
- A function of one argument can be used in place of the strings; the
- function must return a formatted string.
- code{%s} twice for inserting mantissa and exponent, for example
- {%scode{"%s\\,(%s)"}. This
- may also be a property list with column numbers and formats, for example
- {%s{%s
- code{efmt} has been applied to a value,
- code{fmt}, functions of two arguments can be
- supplied instead of strings.
- node Translator functions, Radio lists, A
- subsection Translator functions
- cindex translator function
- Orgtbl mode has several translator functions built-in:
- code{orgtbl-to-tsv} (TAB-separated values)
- code{orgtbl-to-html}, and
- code{orgtbl-to-html}
- code{orgtbl-to-generic}. For example,
- code{tabular} environment, defines a few field and line separators and then
- hands processing over to the generic translator. Here is the entire code:
- group
- (defun orgtbl-to-latex (table params)
- "Convert the Orgtbl mode TABLE to LaTeX."
- (let* ((alignment (mapconcat (lambda (x) (if x "r" "l"))
- org-table-last-alignment ""))
- (params2
- (list
- :tstart (concat "\\begin@{tabular@}@{" alignment "@}")
- :tend "\\end@{tabular@}"
- :lstart "" :lend " \\\\" :sep " & "
- :efmt "%s\\,(%s)" :hline "\\hline")))
- (orgtbl-to-generic table (org-combine-plists params2 params))))
- end lisp
- As you can see, the properties passed into the function (variable
- var{PARAMS2}). The ones passed into the function (i.e.
- samp{ORGTBL SEND} line) take precedence. So if you
- would like to use the
- samp{\\[2mm]} instead of the default
- example
- #+ORGTBL: SEND test orgtbl-to-latex :lend " \\\\[2mm]"
- LaTeX{} translator, or you can use the generic function
- directly. For example, if you have a language where a table is started
- with samp{!ETBL!}, and where table lines are
- started with samp{!EL!}, and where the field
- separator is a TAB, you could call the generic translator like this (on
- a single line!):
- end example
- code{orgtbl-to-generic} for a full list of parameters understood by
- that function, and remember that you can pass each of them into
- code{orgtbl-to-texinfo}, and any other function
- using the generic function.
- Of course you can also write a completely new function doing complicated
- things the generic translator cannot do. A translator function takes
- two arguments. The first argument is the table, a list of lines, each
- line either the symbol
- samp{#+ORGTBL: SEND} line. The function must return a single string
- containing the formatted table. If you write a generally useful
- translator, please post it on
- node Radio lists, , Translator functions, Tables in arbitrary syntax
- cindex radio lists
- pxref{Radio tables}). As for radio tables, you can
- insert radio list templates in HTML,
- code{org-list-insert-radio-list}.
- Here are the differences with radio tables:
- minus
- item
- Use the code{ORGTBL}.
- item
- end itemize
- Here is a
- LaTeX{} file:
- example
- % BEGIN RECEIVE ORGLST to-buy
- % END RECEIVE ORGLST to-buy
- \begin}
- #+ORGLST: SEND to-buy org-list-to-latex
- - a new house
- - a new computer
- + a new keyboard
- + a new mouse
- - a new life
- \end}
- code{a new house} and will insert the converted
- node Dynamic blocks, Special agenda views, Tables in arbitrary syntax, Hacking
- cindex dynamic blocks
- Org documents can contain
- kbd{C-c C-x C-r} (
- cindex #+BEGIN:dynamic block
- end example
- Dynamic blocks are updated with the following commands
- kbd
- orgkey{C-u C-c C-x C-u}
- Update all dynamic blocks in the current file.
- code{:content}.
- For a block with name
- code{org-dblock-write:myblock} with as only parameter a property list
- with the parameters given in the begin line. Here is a trivial example
- of a block that keeps track of when the block update function was last
- run:
- end example
- lisp
- (defun org-dblock-write:block-update-time (params)
- (let ((fmt (or (plist-get params :format) "%d. %m. %Y")))
- (insert "Last block update at: "
- (format-time-string fmt (current-time)))))
- code{org-update-all-dblocks} to a hook, for
- example code{org-update-all-dblocks} is
- written in a way such that it does nothing in buffers that are not in
- code{org-narrow-to-block}.
- section Special agenda views
- vindex org-agenda-skip-function
- code{agenda}, code{alltodo},
- code{tags-todo},
- code{org-agenda-skip-function-global}. More
- commonly, such a definition is applied only to specific custom searches,
- using
- code{nil} to
- indicate that this match should not be skipped. If there is no such
- tag, return the location of the end of the subtree, to indicate that
- search should continue from there.
- end lisp
- Now you may use this function in an agenda custom command, for example
- like this:
- end lisp
- code{org-agenda-overriding-header} to get a
- meaningful header in the agenda view.
- vindex org-agenda-skip-function
- A general way to create custom searches is to base them on a search for
- entries with a certain level limit. If you want to study all entries with
- your custom search function, simply do a search for
- footnote{Note that, when using
- code{org-agenda-skip-function} to select the entries
- you really want to have.
- You may also put a Lisp form into
- code{org-agenda-skip-entry-if}
- and
- table
- item (org-agenda-skip-entry-if 'scheduled)
- Skip current entry if it has been scheduled.
- item (org-agenda-skip-entry-if 'deadline)
- Skip current entry if it has a deadline.
- item (org-agenda-skip-entry-if 'todo '("TODO" "WAITING"))
- Skip current entry if the TODO keyword is TODO or WAITING.
- item (org-agenda-skip-entry-if 'timestamp)
- Skip current entry if it has any timestamp, may also be deadline or scheduled.
- item (org-agenda-skip-entry 'notregexp "regular expression")
- Skip current entry unless the regular expression matches.
- end table
- Therefore we could also have written the search for WAITING projects
- like this, even without defining a special function:
- end lisp
- section Extracting agenda information
- cindex Scripts, for agenda processing
- code{org-batch-agenda}, that produces an agenda view and sends it as
- ASCII text to STDOUT. The command takes a single string as parameter.
- If the string has length 1, it is used as a key to one of the commands
- you have configured in
- kbd{C-c a}. For example, to directly print the
- current TODO list, you could use
- end example
- If the parameter is a string with 2 or more characters, it is used as a
- tags/TODO match string. For example, to print your local shopping list
- (all items with the tag
- samp{NewYork}), you could use
- end example
- example
- emacs -batch -l ~/.emacs \
- -eval '(org-batch-agenda "a" \
- org-agenda-span (quote month) \
- org-agenda-include-diary nil \
- org-agenda-files (quote ("~/org/project.org")))' \
- | lpr
- noindent
- which will produce a 30-day agenda, fully restricted to the Org file
- code{org-batch-agenda-csv} to get a comma-separated
- list of values for each agenda item. Each line in the output will
- contain a number of fields separated by commas. The fields in a line
- are:
- r{The category of the item}
- head
- r{The type of the agenda entry, can be}
- todo
- r{selected in tags match}
- diary
- r{a deadline}
- scheduled
- r{appointment, selected by timestamp}
- closed
- r{warning about nearing deadline}
- past-scheduled
- r{entry has date block including date}
- todo
- r{All tags including inherited ones, separated by colons}
- date
- r{The time, like 15:00-16:50}
- extra
- r{The priority letter if any was given}
- priority-n
- end example
- example
- #!/usr/bin/perl
- # define the Emacs command to run
- $cmd = "emacs -batch -l ~/.emacs -eval '(org-batch-agenda-csv \"t\")'";
- # run it and capture the output
- $agenda = qx};
- # loop over all lines
- foreach $line (split(/\n/,$agenda))
- }
- node Using the property API, Using the mapping API, Extracting agenda information, Hacking
- cindex API, for properties
- defun org-entry-properties &optional pom which
- Get all properties of the entry at point-or-marker POM.
- *
- POM may also be nil, in which case the current entry is used.
- If WHICH is nil or `all', get all properties. If WHICH is
- `special' or `standard', only get that subclass.
- vindex org-use-property-inheritance
- code{selective}, use inheritance if and only if the setting of
- end defun
- end defun
- end defun
- end defun
- end defun
- end defun
- end defun
- end defun
- emph{not} in this list.
- defun org-entry-member-in-multivalued-property pom property value
- Treat the value of the property PROPERTY as a whitespace-separated list of
- values and check if VALUE is in this list.
- defopt org-property-allowed-value-functions
- Hook for functions supplying allowed values for a specific property.
- The functions must take a single argument, the name of the property, and
- return a flat list of allowed values. If
- code{nil} if they are not
- responsible for this property.
- node Using the mapping API, , Using the property API, Hacking
- cindex API, for mapping
- defun org-map-entries func &optional match scope &rest skip
- Call FUNC at each headline selected by MATCH in SCOPE.
- FUNC is a function or a Lisp form. The function will be called without
- arguments, with the cursor positioned at the beginning of the headline.
- The return values of all calls to the function will be collected and
- returned as a list.
- The call to FUNC will be wrapped into a save-excursion form, so FUNC
- does not need to preserve point. After evaluation, the cursor will be
- moved to the end of the line (presumably of the headline of the
- processed entry) and search continues from there. Under some
- circumstances, this may not produce the wanted results. For example,
- if you have removed (e.g.
- example
- nil
- r{the subtree started with the entry at point}
- region
- r{the current buffer, without restriction}
- file-with-archives
-
- r{all agenda files}
- agenda-with-archives
-
- r{if this is a list, all files in the list will be scanned}
- noindent
- The remaining args are treated as settings for the skipping facilities of
- the scanner. The following items can be given here:
- example
- archive
- r{skip trees with the COMMENT keyword}
- function or Lisp form
- code{org-agenda-skip-function},}
-
- r{will not be called for that entry and search will}
-
- end example
- pxref{Using the property API}) to gather more
- information about the entry, or in order to change metadata in the entry.
- Here are a couple of functions that might be handy:
- end defun
- end defun
- code{on}
- or
- end defun
- end defun
- end defun
- Here is a simple example that will turn all entries in the current file with
- a tag code{UPCOMING}.
- Entries in comment trees and in archive trees will be ignored.
- end lisp
- The following example counts the number of entries with TODO keyword
- lisp
- (length (org-map-entries t "/+WAITING" 'agenda))
- node MobileOrg, History and Acknowledgments, Hacking, Top
- cindex iPhone
- uref{http://mobileorg.ncogni.to/, MobileOrg} is an application for the
- i{MobileOrg} offers offline viewing and capture support for an Org mode
- system rooted on a ``real'' computer. It does also allow you to record
- changes to existing entries. Android users should check out
- i{MobileOrg}, and for integrating notes
- captured and changes made by
- code{org-todo-keywords} and
- i{sets} (i{mutually exclusive} tags
- (
- menu
- * Setting up the staging area:: Where to interact with the mobile device
- * Pushing to MobileOrg:: Uploading Org files and agendas
- * Pulling from MobileOrg:: Integrating captured and flagged items
- node Setting up the staging area, Pushing to MobileOrg, MobileOrg, MobileOrg
- i{MobileOrg 1.5} (iPhone version), and you need an
- i{MobileOrg} and, on the Emacs side, configure the variable
- footnote{If you can safely store the
- password in your Emacs setup, you might also want to configure
- file{.org} files. The file names themselves will remain visible.}.
- The easiest way to create that directory is to use a free
- footnote{If you cannot use
- Dropbox, or if your version of MobileOrg does not support it, you can use a
- webdav server. For more information, check out the documentation of MobileOrg and also this
- i{MobileOrg} inside the Dropbox. After the directory has been created, tell
- Emacs about it:
- end lisp
- Org mode has commands to put files for
- node Pushing to MobileOrg, Pulling from MobileOrg, Setting up the staging area, MobileOrg
- code{org-mobile-files}
- to the directory
- code{org-agenda-files}), but additional files
- can be included by customizing
- code{org-directory}, so all files should be
- inside this directory. The push operation also creates a special Org file
- footnote{While creating the agendas, Org mode will force ID properties
- on all referenced entries, so that these entries can be uniquely identified
- if
- code{org-mobile-force-id-on-agenda-items} to
- file{index.org}, containing links to all other
- files.
- footnote{stored automatically
- in the file
- node Pulling from MobileOrg, , Pushing to MobileOrg, MobileOrg
- i{MobileOrg} synchronizes with the server, it not only pulls the Org
- files for viewing. It also appends captured entries and pointers to flagged
- and changed entries to the file
- emph{pull} operation that integrates this information into an inbox file
- and operates on the pointers to flagged entries. Here is how it works:
- item
- Org moves all entries found in
- footnote{
- code{org-mobile-inbox-for-pull}. Each captured entry and each editing event
- will be a top-level entry in the inbox file.
- i{MobileOrg}. Some changes are applied directly and without user
- interaction. Examples are all changes to tags, TODO state, headline and body
- text that can be cleanly applied. Entries that have been flagged for further
- action will receive a tag
- item
- Org will then generate an agenda view with all flagged entries. The user
- should then go through these entries and do whatever actions are necessary.
- If a note has been stored while flagging an entry in
- table
- kindex ?
- kbd{?} in that special agenda will display the full flagging note in
- another window and also push it onto the kill ring. So you could use
- kbd{?} twice in succession will offer to remove the
- end table
- kindex C-c a ?
- If you are not able to process all flagged entries directly, you can always
- return to this agenda view
- kbd{M-x org-mobile-pull
- kbd{C-c a ?} to regenerate the view, only
- the current agenda files will be searched.} using
- node History and Acknowledgments, Main Index, MobileOrg, Top
- cindex acknowledgments
- cindex thanks
- Org was born in 2003, out of frustration over the user interface of the Emacs
- Outline mode. I was trying to organize my notes and projects, and using
- Emacs seemed to be the natural way to go. However, having to remember eleven
- different commands with two or three keys per command, only to hide and show
- parts of the outline tree, that seemed entirely unacceptable to me. Also,
- when using outlines to take notes, I constantly wanted to restructure the
- tree, organizing it parallel to my thoughts and plans.
- emph{structure editing} were originally implemented in the
- package
- file{org.el}. As this environment became comfortable for project planning,
- the next step was adding emph{timestamps}, and
- email{emacs-orgmodegnu.org} have provided a constant stream of bug
- reports, feedback, new ideas, and sometimes patches and add-on code.
- Many thanks to everyone who has helped to improve this package. I am
- trying to keep here a list of the people who had significant influence
- in shaping one or more aspects of Org. The list may not be
- complete, if I have forgotten someone, please accept my apologies and
- let me know.
- Before I get to this list, a few special mentions are in order:
- i
- LaTeX{} exporter and the plain
- list parser. His support during the early days, when he basically acted as
- co-maintainer, was central to the success of this project. Bastien also
- invented Worg, helped establishing the Web presence of Org, and sponsors
- hosting costs for the orgmode.org website.
- item John Wiegley
- John has contributed a number of great ideas and patches directly to Org,
- including the attachment system (
- file{org-mac-message.el}), hierarchical dependencies of TODO
- items, habit tracking (
- file{org-crypt.el}). Also, the capture system is really an extended copy
- of his great
- item Sebastian Rose
- Without Sebastian, the HTML/XHTML publishing of Org would be the pitiful work
- of an ignorant amateur. Sebastian has pushed this part of Org onto a much
- higher level. He also wrote
- end table
- itemize
- item
- item
- file{org-bbdb.el} and
- item
- item
- item
- file{org-docview.el}.
- i{Brad Bozarth} showed how to pull RSS feed data into Org mode files.
- i{Tom Breton} wrote
- item
- item
- item
- file{nouline.el} to XEmacs.
- i{Sacha Chua} suggested copying some linking code from Planner.
- i{Baoqiu Cui} contributed the DocBook exporter.
- i{Eddward DeVilla} proposed and tested checkbox statistics. He also
- came up with the idea of properties, and that there should be an API for
- them.
- i{Nick Dokos} tracked down several nasty bugs.
- i{Kees Dullemond} used to edit projects lists directly in HTML and so
- inspired some of the early development, including HTML export. He also
- asked for a way to narrow wide table columns.
- i{Thomas S. Dye} contributed documentation on Worg and helped integrating
- the Org-Babel documentation into the manual.
- i{Christian Egli} converted the documentation into Texinfo format, inspired
- the agenda, patched CSS formatting into the HTML exporter, and wrote
- item
- item
- item
- item
- item
- file{org-git-line.el}.
- i{Mikael Fornius} works as a mailing list moderator.
- i{Austin Frank} works as a mailing list moderator.
- i{Eric Fraga} drove the development of BEAMER export with ideas and
- testing.
- i{Barry Gidden} did proofreading the manual in preparation for the book
- publication through Network Theory Ltd.
- i{Niels Giesen} had the idea to automatically archive DONE trees.
- i{Nicolas Goaziou} rewrote much of the plain list code.
- i{Kai Grossjohann} pointed out key-binding conflicts with other packages.
- i{Brian Gough} of Network Theory Ltd publishes the Org mode manual as a
- book.
- i{Bernt Hansen} has driven much of the support for auto-repeating tasks,
- task state change logging, and the clocktable. His clear explanations have
- been critical when we started to adopt the Git version control system.
- i{Manuel Hermenegildo} has contributed various ideas, small fixes and
- patches.
- i{Phil Jackson} wrote
- item
- item
- i{MobileOrg Android}.
- i{Tokuya Kameshima} wrote file{org-mew.el}.
- i{Shidai Liu} ("Leo") asked for embedded
- item
- item
- file{org-atom.el}, maintains the issues file for Org,
- and is a prolific contributor on the mailing list with competent replies,
- small fixes and patches.
- i{Jason F. McBrayer} suggested agenda export to CSV format.
- i{Max Mikhanosha} came up with the idea of refiling.
- i{Dmitri Minaev} sent a patch to set priority limits on a per-file
- basis.
- i{Stefan Monnier} provided a patch to keep the Emacs-Lisp compiler
- happy.
- i{Richard Moreland} wrote
- item
- item
- item
- item
- item
- file{orgcard2ref.pl}, a Perl program to create a text
- version of the reference card.
- i{Takeshi Okano} translated the manual and David O'Toole's tutorial
- into Japanese.
- i{Oliver Oppitz} suggested multi-state TODO items.
- i{Scott Otterson} sparked the introduction of descriptive text for
- links, among other things.
- i{Pete Phillips} helped during the development of the TAGS feature, and
- provided frequent feedback.
- i{Martin Pohlack} provided the code snippet to bundle character insertion
- into bundles of 20 for undo.
- i{T.V. Raman} reported bugs and suggested improvements.
- i{Matthias Rempe} (Oelde) provided ideas, Windows support, and quality
- control.
- i{Paul Rivier} provided the basic implementation of named footnotes. He
- also acted as mailing list moderator for some time.
- i{Kevin Rogers} contributed code to access VM files on remote hosts.
- i{Frank Ruell} solved the mystery of the
- file{allout.el}.
- i{Jason Riedy} generalized the send-receive mechanism for Orgtbl tables with
- extensive patches.
- i{Philip Rooke} created the Org reference card, provided lots
- of feedback, developed and applied standards to the Org documentation.
- i{Christian Schlauer} proposed angular brackets around links, among
- other things.
- i{Paul Sexton} wrote
- item
- Linking to VM/BBDB/Gnus was first inspired by
- file{organizer-mode.el}.
- i{Ilya Shlyakhter} proposed the Archive Sibling, line numbering in literal
- examples, and remote highlighting for referenced code lines.
- i{Stathis Sideris} wrote the
- file{contrib} directory.
- i{Daniel Sinder} came up with the idea of internal archiving by locking
- subtrees.
- i{Dale Smith} proposed link abbreviations.
- i{James TD Smith} has contributed a large number of patches for useful
- tweaks and features.
- i{Adam Spiers} asked for global linking commands, inspired the link
- extension system, added support for mairix, and proposed the mapping API.
- i{Ulf Stegemann} created the table to translate special symbols to HTML,
- item
- file{org-w3m.el}, to copy HTML content
- with links transformation to Org syntax.
- i{David O'Toole} wrote
- item
- acronym{ODT} exporter.
- i{Sebastien Vauban} reported many issues with
- item
- item
- "urgen Vollmer} contributed code generating the table of contents
- in HTML output.
- @item
- @i{Samuel Wales} has provided important feedback and bug reports.
- @item
- @i{Chris Wallace} provided a patch implementing the @samp{QUOTE}
- keyword.
- @item
- @i{David Wainberg} suggested archiving, and improvements to the linking
- system.
- @item
- @i{Carsten Wimmer} suggested some changes and helped fix a bug in
- linking to Gnus.
- @item
- @i{Roland Winkler} requested additional key bindings to make Org
- work on a tty.
- @item
- @i{Piotr Zielinski} wrote @file{org-mouse.el}, proposed agenda blocks
- and contributed various ideas and code snippets.
- @item
- @end itemize
- @node Main Index, Key Index, History and Acknowledgments, Top
- @unnumbered Concept index
- @printindex cp
- @node Key Index, Command and Function Index, Main Index, Top
- @unnumbered Key index
- @printindex ky
- @node Command and Function Index, Variable Index, Key Index, Top
- @unnumbered Command and function index
- @printindex fn
- @node Variable Index, , Command and Function Index, Top
- @unnumbered Variable index
- This is not a complete index of variables and faces, only the ones that are
- mentioned in the manual. For a more complete list, use @kbd{M-x
- org-customize @key{RET}} and then click yourself through the tree.
- @printindex vr
- @bye
- @c Local variables:
- @c fill-column: 77
- @c indent-tabs-mode: nil
- @c paragraph-start: "\\|^x?org\\(key\\|cmd\\)\\|\f\\|[ ]*$"
- @c paragraph-separate: "\\|^x?org\\(key\\|cmd\\)\\|[ \f]*$"
- @c End:
- @c LocalWords: webdavhost pre
|