12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699 |
- \input texinfo
- setfilename ../../info/orgguide
- include org-version.inc
- c Cf. Texinfo manual 14.2
- set txicodequotebacktick
- set MAINTAINERSITE
- set AUTHOR Carsten Dominik
- set MAINTAINEREMAIL
- set MAINTAINERCONTACT
- c %**end of header
- c Macro definitions
- c
- end iftex
- macro tsubheading{text}
- subsubheading \text\
- ifnotinfo
- b{\text\}
- end macro
- noindent
- *
- end macro
- copyright{} 2010--2019 Free Software Foundation
- end quotation
- dircategory Emacs
- end direntry
- title The compact Org-mode Guide
- value{VERSION}
- c The following two commands start the copyright page.
- vskip 0pt plus 1filll
- end titlepage
- shortcontents
- node Top, Introduction, (dir), (dir)
- insertcopying
- menu
- * Introduction:: Getting started
- * Document Structure:: A tree works like your brain
- * Tables:: Pure magic for quick formatting
- * Hyperlinks:: Notes in context
- * TODO Items:: Every tree branch can be a TODO item
- * Tags:: Tagging headlines and matching sets of tags
- * Properties:: Properties
- * Dates and Times:: Making items useful for planning
- * Capture - Refile - Archive:: The ins and outs for projects
- * Agenda Views:: Collecting information into views
- * Markup:: Prepare text for rich export
- * Exporting:: Sharing and publishing of notes
- * Publishing:: Create a web site of linked Org files
- * Working With Source Code:: Source code snippets embedded in Org
- * Miscellaneous:: All the rest which did not fit elsewhere
- * GNU Free Documentation License:: This manual license.
- LaTeX{}::
- LaTeX{} and PDF export:: Exporting to
- end detailmenu
- node Introduction, Document Structure, Top, Top
- menu
- * Preface:: Welcome
- * Installation:: How to install a downloaded version of Org
- * Activation:: How to activate Org for certain buffers
- * Feedback:: Bug reports, ideas, patches etc.
- node Preface, Installation, Introduction, Introduction
- i{This document is a much compressed derivative of the
- node Installation, Activation, Preface, Introduction
- b{Important:}
- ref{Activation}.}
- If you have downloaded Org from the Web, either as a distribution
- file{.tar} file, or as a Git archive, it is best to run it directly from
- the distribution directory. You need to add the
- file{.emacs}:
- end smallexample
- smallexample
- make autoloads
- node Activation, Feedback, Installation, Introduction
- file{.emacs} file. The last four lines
- define
- smalllisp
- ;; The following lines are always needed. Choose your own keys.
- (global-set-key "\C-cl" 'org-store-link)
- (global-set-key "\C-ca" 'org-agenda)
- (global-set-key "\C-cc" 'org-capture)
- (global-set-key "\C-cb" 'org-switchb)
- samp{.org} will be put into Org mode automatically.
- section Feedback
- If you find problems with Org, or if you have questions, remarks, or ideas
- about it, please mail to the Org mailing list
- node Document Structure, Tables, Introduction, Top
- menu
- * 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
- * Footnotes:: How footnotes are defined in Org's syntax
- node Outlines, Headlines, Document Structure, Document Structure
- command{org-cycle}, which is bound to the
- node Headlines, Visibility cycling, Outlines, Document Structure
- footnote{See
- the variable
- kbd{C-a} and
- smallexample
- * Top level headline
- ** Second level
- *** 3rd level
- some text
- *** 3rd level
- more text
- * Another top level headline
- noindent Note that a headline named after
- samp{Footnotes}, is considered as special. A subtree with
- this headline will be silently ignored by exporting functions.
- Some people find the many stars too noisy and would prefer an
- outline that has whitespace followed by a single star as headline
- starters.
- node Visibility cycling, Motion, Headlines, Document Structure
- key{TAB} and
- key{TAB}} to change the visibility in the buffer.
- kbd
- key{TAB}
- smallexample
- ,-> FOLDED -> CHILDREN -> SUBTREE --.
- '-----------------------------------'
- kbd{C-u
- item S-r{and} C-u
- emph{Global cycling}: Rotate the entire buffer among the states
- end smallexample
- key{TAB}
- Show all, including drawers.
- : only the top level headlines are visible. This can be
- configured through the variable
- code{overview},
- code{showall}, like this:
- end smallexample
- section Motion
- The following commands jump to other headlines in the buffer.
- kbd
- item C-c C-p
- Previous heading.
- item C-c C-b
- Previous heading same level.
- end table
- section Structure editing
- kbd
- key{RET}
- 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
- item M-S-
- item r{in new, empty entry}
- In a new entry with no text yet,
- item M-r{/}
- item M-S-r{/}
- item M-S-r{/}
- item C-c C-w
- Refile entry or region to a different location.
- item C-x n s/w
- Narrow buffer to current subtree / widen it again
- node Sparse trees, Plain lists, Structure editing, Document Structure
- 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-context-detail} to decide how much context is shown
- around each match.}. Just try it out and you will see immediately how it
- works.
- Org mode contains several commands creating such trees, all these
- commands can be accessed through a dispatcher:
- kbd
- item C-c / r
- Occur. Prompts for a regexp and shows a sparse tree with all matches. Each
- match is also highlighted; the highlights disappear by pressing
- end table
- The other sparse tree commands select headings based on TODO keywords,
- tags, or properties and will be discussed later in this manual.
- section Plain 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}) parses and formats them.
- Org knows ordered lists, unordered lists, and description lists.
- bullet
- emph{Unordered} list items start with samp{+}, or
- item
- samp{1.} or
- item
- samp{ :: } to separate the
- end itemize
- Items belonging to the same list must have the same indentation on the first
- line. An item ends before the next line that is indented like its
- bullet/number, or less. A list ends when all items are closed, or before two
- blank lines. An example:
- group
- ** Lord of the Rings
- My favorite scenes are (in this order)
- 1. The attack of the Rohirrim
- 2. Eowyn's fight with the witch king
- + this was already my favorite scene in the book
- + I really like Miranda Otto.
- Important actors in this film are:
- -
- b{Sean Astin} :: He plays Sam, Frodo's friend.
- end smallexample
- The following commands act on items when the cursor is in the first line of
- an item (the line with the bullet or number).
- kbd
- key{TAB}
- Items can be folded just like headline levels.
- key{RET}
- Insert new item at current level. With a prefix argument, force a new
- heading (
- item M-S-
- pxref{Checkboxes}).
- key{up}key{down}
- Move the item including subitems up/down (swap with previous/next item
- of same indentation). If the list is ordered, renumbering is
- automatic.
- key{left}key{right}
- Decrease/increase the indentation of an item, leaving children alone.
- key{left}key{right}
- Decrease/increase the indentation of the item, including subitems.
- pxref{Checkboxes}) in the item line, toggle the
- state of the checkbox. Also verify bullets and indentation consistency in
- the whole list.
- samp{-}, samp{*}, samp{1)}).
- node Footnotes, , Plain lists, Document Structure
- smallexample
- The Org homepage[fn:1] now looks a lot better than it used to.
- ...
- [fn:1] The link is: https://orgmode.org
- noindent
- The following commands handle footnotes:
- kbd
- item C-c C-c
- Jump between definition and reference.
- seealso{
- *
- node Tables, Hyperlinks, Document Structure, Top
- file{calc}
- package
- pxref{Top,Calc,,Calc,Gnu Emacs Calculator Manual}).
- ifnotinfo
- (see the Emacs Calculator manual for more information about the Emacs
- calculator).
- samp{|} as the first non-whitespace character is considered part of a
- table.
- smallexample
- | 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
- smallexample
- |Name|Phone|Age|
- |-
- noindent
- and then press
- code{|Name|Phone|Age} followed by
- key{RET}}.
- 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{
- table
- tsubheading{Creation and conversion}
- *
- If there is no active region, this command creates an empty Org
- table. But it's easier just to start typing, like
- key{RET}}.
- item C-c C-c
- Re-align the table without moving the cursor.
- item
- c
- key{TAB}
- Re-align, move to previous field.
- item
- c
- key{up}
- key{down}
- key{left}
- key{right}
- Move a cell up, down, left, and right by swapping with adjacent cell.
- item M-
- itemx M-
- c
- key{left}
- Kill the current column.
- item M-S-
- c
- key{up}
- key{down}
- Move the current row up/down.
- item M-S-
- c
- key{down}
- Insert a new row above the current row. With a prefix argument, the line is
- created below the current one.
- item C-c -
- Insert a horizontal line below current row. With a prefix argument, the line
- is created above the current line.
- item C-c
- c
- end table
- uref{https://orgmode.org/manual/Tables.html#Tables, Chapter 3 of the
- manual}
- uref{https://orgmode.org/worg/org-tutorials/tables.html, Bastien's
- table tutorial}
- uref{https://orgmode.org/worg/org-tutorials/org-spreadsheet-intro.html,
- Bastien's spreadsheet tutorial}
- uref{https://orgmode.org/worg/org-tutorials/org-plot.html, Eric's plotting tutorial}}
- chapter 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
- 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]]}. To edit the invisible kbd{C-c
- C-l} with the cursor on the link.
- section Internal links
- If the link does not look like a URL, it is considered to be internal in the
- current file. The most important case is a link like
- code{CUSTOM_ID} property
- samp{[[My Target]]} or
- samp{<<My Target>>}.
- Internal links will be used to reference their destination, through links or
- numbers, when possible.
- section External links
- Org supports links to files, websites, Usenet and email messages,
- BBDB database entries and links to both IRC conversations and their
- logs. External links are URL-like locators. They start with a short
- identifying string followed by a colon. There can be no space after
- the colon. Here are some examples:
- r{on the web}
- file:/home/dominik/images/jupiter.jpg
- r{same as above}
- file:papers/last.pdf
- r{another Org file}
- docview:papers/last.pdf::NNN
- r{Link to heading by ID}
- news:comp.emacs
- r{Mail link}
- vm:folder
- r{VM message link}
- wl:folder#id
- r{MH-E message link}
- rmail:folder#id
- r{Gnus article link}
- bbdb:R.*Stallman
- r{IRC link}
- info:org:External%20links
- end smallexample
- A link should be enclosed in double brackets and may contain a
- descriptive text to be displayed instead of the URL (
- smallexample
- [[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
- (
- node Handling links, Targeted links, External links, Hyperlinks
- table
- item C-c l
- Store a link to the current location. This is a
- c
- key{up} and
- kbd{C-u} prefix argument, file name completion is used to
- link to a file.
- item C-c C-l
- kbd{C-c C-l} allows you to edit the
- link and description parts of the link.
- item C-c C-o r{or} mouse-2
- Open link at point.
- kbd{C-c %}. Using this
- command several times in direct succession moves through a ring of
- previously recorded positions.
- end table
- section Targeted links
- File links can contain additional information to make Emacs jump to a
- particular location in the file when following a link. This can be a
- line number or a search option after a double colon.
- Here is the syntax of the different ways to attach a search to a file
- link, together with an explanation:
- r{Find line 255}
- [[file:~/xx.org::My Target]] samp{<<My Target>>}}
- [[file:~/xx.org::#my-custom-id]]
- end smallexample
- uref{https://orgmode.org/manual/Hyperlinks.html#Hyperlinks, Chapter 4 of the
- manual}}
- chapter TODO Items
- Org mode does not require TODO lists to live in separate documents. Instead,
- TODO items are part of a notes file, because TODO items usually
- come up while taking notes! With Org mode, simply mark any entry in a tree
- as being a TODO item. In this way, information is not duplicated, and TODO
- items remain in the context from which they emerged.
- Org mode provides methods to give you an overview of all the things that you
- have to do, collected from many files.
- end menu
- section Using TODO states
- Any headline becomes a TODO item when it starts with the word
- smallexample
- *** TODO Write letter to Sam Fortune
- noindent
- The most important commands to work with TODO entries are:
- kbd
- smallexample
- (unmarked) -> TODO -> DONE -> (unmarked)
- kbd{t} command key (
- item S-r{/}
- item C-c / t
- View TODO items in a pxref{Sparse trees}). Folds the
- buffer, but shows all TODO items and the headings hierarchy above
- them.
- pxref{Agenda Views}) into a single buffer.
- item S-M-
- end table
- code{org-todo-state-tags-triggers} for details.
- section Multi-state workflows
- You can use TODO keywords to indicate
- smalllisp
- (setq org-todo-keywords
- '((sequence "TODO" "FEEDBACK" "VERIFY" "|" "DONE" "DELEGATED")))
- emph{need action})
- from the DONE states (which need
- kbd{C-c C-t} will cycle an entry from TODO to
- FEEDBACK, then to VERIFY, and finally to DONE and DELEGATED. 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. Your setup would then look like this:
- end smalllisp
- The keywords should all be different, this helps Org mode to keep track of
- which subsequence should be used for a given entry. The example also shows
- how to define keys for fast access of a particular state, by adding a letter
- in parenthesis after each keyword---you will be prompted for the key after
- smallexample
- #+TODO: TODO(t) | DONE(d)
- #+TODO: REPORT(r) BUG(b) KNOWNCAUSE(k) | FIXED(f)
- #+TODO: | CANCELED(c)
- kbd{C-c C-c} with the cursor still in
- the line to make the changes known to Org mode.
- section Progress logging
- Org mode can automatically record a timestamp and possibly a note when
- you mark a TODO item as DONE, or even each time you change the state of
- a TODO item. This system is highly configurable; settings can be on a
- per-keyword basis and can be localized to a file or even a subtree. For
- information on how to clock working time for a task, see
- menu
- * Closing items:: When was this entry marked DONE?
- * Tracking TODO state changes:: When did the status change?
- node Closing items, Tracking TODO state changes, Progress logging, Progress logging
- emph{when} a certain TODO
- item was finished. This is achieved with
- code{#+STARTUP: logdone}}.
- end smalllisp
- samp{CLOSED: [timestamp]} will be inserted just after
- the headline. If you want to record a note along with the timestamp,
- usecode{#+STARTUP:
- lognotedone}}
- end smalllisp
- samp{Closing Note} heading.
- unnumberedsubsec Tracking TODO state changes
- You might want to keep track of TODO state changes. 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. When taking a lot of notes,
- you might want to get the notes out of the way into a drawer. Customize the
- variable
- samp{!} (for a timestamp) and
- smallexample
- #+TODO: TODO(t) WAIT(w/!) | DONE(d!) CANCELED(c)
- noindent
- will define TODO keywords and fast access keys, and also request that a time
- is recorded when the entry is set to DONE, and that a note is recorded when
- switching to WAIT or CANCELED. The same syntax works also when setting
- node Priorities, Breaking down tasks, Progress logging, TODO Items
- emph{priority cookie} into the headline of a TODO item, like this
- end smallexample
- samp{A}, samp{C}.
- samp{B} the default if none is given. Priorities
- make a difference only in the agenda.
- kbd
- kbd{C-c ,}
- Set the priority of the current headline. Press samp{B} or
- key{SPC} to remove the cookie.
- item S-key{dwn}
- Increase/decrease priority of current headline
- node Breaking down tasks, Checkboxes, Priorities, TODO Items
- samp{[/]} or
- kbd{C-c C-c} on the
- cookie. For example:
- end smallexample
- section Checkboxes
- Every item in a plain list (
- samp{[ ]}. Checkboxes are not included in
- the global TODO list, so they are often great to split a task into a number
- of simple steps.
- Here is an example of a checkbox list.
- end smallexample
- Checkboxes work hierarchically, so if a checkbox item has children that
- are checkboxes, toggling one of the children checkboxes will make the
- parent checkbox reflect if none, some, or all of the children are
- checked.
- table
- item C-c C-c
- Toggle checkbox status or (with prefix arg) checkbox presence at point.
- key{RET}
- Insert a new item with a checkbox.
- This works only if the cursor is already in a plain list item
- (
- end table
- uref{https://orgmode.org/manual/TODO-items.html#TODO-items, Chapter 5 of the manual}
- uref{https://orgmode.org/worg/org-tutorials/orgtutorial_dto.html, David
- O'Toole's introductory tutorial}
- uref{http://members.optusnet.com.au/~charles57/GTD/gtd_workflow.html,
- Charles Cave's GTD setup}}
- chapter Tags
- An excellent way to implement labels and contexts for cross-correlating
- information is to assign
- samp{_}, and
- samp{:work:}. Several tags can be specified, as in
- menu
- * Tag inheritance:: Tags use the tree structure of the outline
- * Setting tags:: How to assign tags to a headline
- * Tag groups:: Use one tag to search for several tags
- * Tag searches:: Searching for combinations of tags
- node Tag inheritance, Setting tags, Tags, 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 smallexample
- samp{:work:},
- samp{:notes:}, and
- footnote{As
- with all these in-buffer settings, pressing
- smallexample
- #+FILETAGS: :Peter:Boss:Secret:
- node Setting tags, Tag groups, Tag inheritance, Tags
- kbd{M-
- table
- item C-c C-q
- 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
- item C-c C-c
- When the cursor is in a headline, this does the same as
- end table
- Org will support tag insertion based on a
- code{org-tag-alist}. Finally you can set
- the default tags for a given file with lines like
- end smallexample
- 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 smalllisp
- smallexample
- #+TAGS: work(w) home(h) tennisclub(t) laptop(l) pc(p)
- node Tag groups, Tag searches, Setting tags, Tags
- cindex group tags
- emph{group tag}. When you search for a group tag, it will return matches
- for all members in the group. In an agenda view, filtering by a group tag
- will display headlines tagged with at least one of the members of the
- group. This makes tag searches and filters even more flexible.
- You can set group tags by inserting a colon between the group tag and other
- tags, like this:
- { read : read_book read_ebook
- end example
- In this example, emph{group tag} for a set of three
- tags: samp{read_book} and
- code{:grouptags} keyword directly when setting
- kindex C-c C-x q
- command{org-toggle-tags-groups}, bound to
- var{org-group-tags} to nil.
- section Tag searches
- Once a system of tags has been set up, it can be used to collect related
- information into special lists.
- kbd
- itemx C-c / m
- Create a sparse tree with all headlines matching a tags search. With a
- item C-c a m
- Create a global list of tag matches from all agenda files.
- item C-c a M
- 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}.
- uref{https://orgmode.org/manual/Tags.html#Tags, Chapter 6 of the manual}
- uref{http://sachachua.com/wp/2008/01/tagging-in-org-plus-bonus-code-for-timeclocks-and-tags/,
- Sacha Chua's article about tagging in Org-mode}}
- chapter Properties
- Properties are key-value pairs associated with an entry. They live in a
- special drawer with the name
- smallexample
- * CD collection
- ** Classic
- *** Goldberg Variations
- :PROPERTIES:
- :Title: Goldberg Variations
- :Composer: J.S. Bach
- :Publisher: Deutsche Grammophon
- :NDisks: 1
- :END:
- 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 smallexample
- or globally using
- smallexample
- #+PROPERTY: NDisks_ALL 1 2 3 4
- table
- item C-c C-x p
- Set a property. This prompts for a property name and a value.
- end table
- To create sparse trees and special lists with selection based on properties,
- the same commands are used as for tag searches (
- ref{Matching tags and
- properties}.
- kbd
- seealso{
- *
- node Dates and Times, Capture - Refile - Archive, Properties, Top
- emph{timestamp} in Org mode.
- end menu
- section Timestamps
- A timestamp is a specification of a date (possibly with a time or a range of
- times) in a special format, either
- samp{<2003-09-16 Tue 09:39>} or
- pxref{Weekly/daily agenda}). We distinguish:
- b{Plain timestamp; Event; Appointment}
- smallexample
- * Meet Peter at the movies
- <2006-11-01 Wed 19:15>
- * Discussion on climate change
- <2006-11-02 Thu 20:00-22:00>
- noindent
- *
- A timestamp may contain a
- smallexample
- * Pick up Sam at school
- <2007-05-16 Wed 12:30 +1w>
- noindent
- *
- For more complex date specifications, Org mode supports using the
- special sexp diary entries implemented in the Emacs calendar/diary
- package. For example
- end smallexample
- b{Time/Date range}
- samp{--} denote a range.
- end smallexample
- b{Inactive timestamp}
- emph{not} trigger an entry to show up in the agenda.
- end smallexample
- section Creating timestamps
- 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.
- item S-r{/}
- c
- key{up}key{down}
- Change the item under the cursor in a timestamp. The cursor can be on a
- year, month, day, hour or minute. When the timestamp contains a time range
- like
- end table
- When Org mode prompts for a date/time, it will accept any string containing
- some date and/or time information, and intelligently interpret the string,
- deriving defaults for unspecified information from the current date and time.
- You can also select a date in the pop-up calendar. See the manual for more
- information on how exactly the date/time prompt works.
- section Deadlines and scheduling
- A timestamp may be preceded by special keywords to facilitate planning:
- b{DEADLINE}
- table
- item C-c C-d
- Insert
- end table
- On the deadline date, the task will be listed in the agenda. In
- addition, the agenda for
- code{org-deadline-warning-days} before the due date, and continuing
- until the entry is marked DONE. An example:
- end smallexample
- b{SCHEDULED}
- i{planning to start working} on that task on the given
- date
- i{scheduling a meeting}, which is done in Org-mode by just inserting a time
- stamp without keyword.}.
- kbd
- samp{SCHEDULED} keyword along with a stamp, in the line following the
- headline.
- 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.
- smallexample
- *** TODO Call Trillian for a date on New Years Eve.
- SCHEDULED: <2004-12-25 Sat>
- smallexample
- ** TODO Pay the rent
- DEADLINE: <2005-10-01 Sat +1m>
- noindent
- the
- node Clocking work time, , Deadlines and scheduling, Dates and Times
- table
- item C-c C-x C-i
- Start the clock on the current item (clock-in). This inserts the CLOCK
- keyword together with a timestamp. When called with a
- c
- samp{=>
- HH:MM}.
- item C-c C-x C-q
- Cancel the current clock. This is useful if a clock was started by
- mistake, or if you ended up working on something else.
- kbd{C-u} prefix arg, select the target task from a list of recently clocked
- tasks.
- smallexample
- #+BEGIN: clocktable :maxlevel 2 :emphasize nil :scope file
- #+END: clocktable
- noindent
- For details about how to customize this view, see
- item C-c C-c
- Update dynamic block at point. The cursor needs to be in the
- end table
- The pxref{Weekly/daily agenda}) to
- show which tasks have been worked on or closed during a day.
- uref{https://orgmode.org/manual/Dates-and-times.html#Dates-and-times,
- Chapter 8 of the manual}
- uref{http://members.optusnet.com.au/~charles57/GTD/org_dates/, Charles
- Cave's Date and Time tutorial}
- uref{http://doc.norang.ca/org-mode.html#Clocking, Bernt Hansen's clocking workflow}}
- chapter Capture - Refile - Archive
- 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 defines a capture process to create tasks. 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.
- end menu
- section Capture
- Org's lets you store quick notes with little interruption of your work flow.
- You can define templates for new entries and associate them with different
- targets for storing notes.
- end menu
- unnumberedsubsec Setting up a capture location
- The following customization sets a default target
- ref{Capture templates}.} file for notes, and defines a global
- key for capturing new stuff.
- end example
- unnumberedsubsec Using capture
- kbd
- item C-c C-c
- Once you are done entering information into the capture buffer,
- item C-c C-w
- Finalize by moving the entry to a refile location (see section 9.2).
- end table
- unnumberedsubsec Capture templates
- You can use templates to generate different types of capture notes, and to
- store them in different places. For example, if you would like
- to store new tasks under a heading file{TODO.org}, and
- journal entries in a date tree in
- smallexample
- (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
- In these entries, the first string is the key to reach the
- template, the second is a short description. Then follows the type of the
- entry and a definition of the target location for storing the note. Finally,
- the template itself, a string with %-escapes to fill in information based on
- time and context.
- When you call
- smallexample
- * TODO
- [[file:
- end smallexample
- kbd{%}-escapes
- kbd{%} with a backslash.}
- allow dynamic insertion of content. Here is a small selection of the
- possibilities, consult the manual for more.
- r{annotation, normally the link created with
- r{initial content, the region when capture is called with C-u.}
- %t, %T
- r{like above, but inactive timestamps}
- node Refile and copy, Archiving, Capture, Capture - Refile - Archive
- table
- item C-c M-x
- Copy the entry or region at point. This command behaves like
- item C-c C-w
- Refile the entry or region at point. This command offers possible locations
- for refiling the entry and lets you select one with completion. The item (or
- all items in the region) is filed below the target heading as a subitem.
- code{org-refile-targets} for details.
- item C-u C-u C-c C-w
- Jump to the location where
- end table
- section 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.
- The most common archiving action is to move a project tree to another file,
- the archive file.
- kbd
- code{org-archive-default-command}.
- C-c $
- Archive the subtree starting at the cursor position to the location
- given by
- end table
- 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
- end smallexample
- uref{https://orgmode.org/manual/Capture-_002d-Refile-_002d-Archive.html#Capture-_002d-Refile-_002d-Archive,
- Chapter 9 of the manual}
- uref{https://orgmode.org/worg/org-tutorials/org-protocol-custom-handler.html,
- Sebastian Rose's tutorial for capturing from a web browser}}*
- chapter Agenda Views
- Due to the way Org works, TODO items, time-stamped items, and tagged
- headlines can be scattered throughout a file or even a number of files. To
- get an overview of open action items, or of events that are important for a
- particular date, this information must be collected, sorted and displayed in
- an organized way. There are several different views, see below.
- The extracted information is displayed in a special
- ref{Agenda
- commands}.
- end menu
- section Agenda files
- The information to be shown is normally collected from all
- code{org-agenda-files}.
- kbd
- item C-c ]
- Remove current file from the list of agenda files.
- end table
- section The agenda dispatcher
- The views are created through a dispatcher, which should be bound to a
- global key---for example pxref{Installation}). After
- pressing
- table
- item a
- The calendar-like agenda (
- item t
- pxref{Global TODO list}).
- r{/} M
- A list of headlines matching a TAGS expression (
- item s
- A list of entries selected by a boolean expression of keywords
- and/or regular expressions that must or must not occur in the entry.
- node Built-in agenda views, Agenda commands, 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
- * Search view:: Find entries by searching for text
- node Weekly/daily agenda, Global TODO list, Built-in agenda views, Built-in agenda views
- emph{agenda} is to act like a page of a
- paper agenda, showing all the tasks for the current week or day.
- kbd
- end table
- Emacs contains the calendar and diary by Edward M. Reingold. Org-mode
- understands the syntax of the diary and allows you to use diary sexp entries
- directly in Org files:
- footnote{Note that the order of the arguments (month, day, year) depends on the setting of
- end smallexample
- Org can interact with Emacs appointments notification facility. To add all
- the appointments of your agenda files, use the command
- node Global TODO list, Matching tags and properties, Weekly/daily agenda, Built-in agenda views
- ref{Agenda commands}.
- kbd
- pxref{Agenda Views}) into a single buffer.
- end table
- subsection Matching tags and properties
- If headlines in the agenda files are marked with pxref{Tags}),
- or have properties (
- kbd{C-c /
- m}. The commands available in the tags list are described in
- table
- item C-c a m
- Produce a list of all headlines that match a given set of tags. The
- command prompts for a selection criterion, which is a boolean logic
- expression with tags, like
- samp{work|home} (
- pxref{Agenda dispatcher}).
- kbd{C-c a m}, but only select headlines that are also TODO items.
- subsubheading Match syntax
- 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
- You may also test for properties at the same
- time as matching tags, see the manual for more information.
- subsection Search view
- 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.
- 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
- code{org-agenda-text-search-extra-files}.
- section Commands in the agenda buffer
- Entries in the agenda buffer are linked back to the Org file or diary
- file where they originate. Commands are provided to show and jump to the
- original entry location, and to edit the Org files ``remotely'' from
- the agenda buffer. This is just a selection of the many commands, explore
- the
- table
- tsubheading{Motion}
- key{up} and
- item p
- Previous line (same as kbd{C-n}).
- item mouse-3
- key{SPC}
- 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.
- item
- kbd{mouse-1} will also work for this.
- item
- c
- item o
- Delete other windows.
- item d
- c
- r{and} b
- Go forward/backward in time to display the following
- c
- c
- c
- l
- Toggle Logbook mode. In Logbook mode, entries that were marked DONE while
- logging was on (variable
- kbd{C-u}
- prefix, show all possible logbook entries, including state changes.
- item r
- item s
- Save all Org buffers in the current Emacs session, and also the locations of
- IDs.
- item /
- Filter the current agenda view with respect to a tag. You are prompted for a
- letter to select a tag. Press
- item \
- Narrow the current agenda filter by an additional condition.
- item 0--9
- Digit argument.
- item t
- Change the TODO state of the item, in the agenda and in the
- org file.
- item C-k
- Delete the current agenda item along with the entire subtree belonging
- to it in the original Org file.
- item C-c C-w
- Refile the entry at point.
- item C-c C-x C-a r{or short}
- code{org-archive-default-command}.
- item C-c C-x C-s r{or short}
- c
- c
- c
- key{right} key{left}
- Change the timestamp associated with the current line by one day.
- item I
- Start the clock on the current item.
- item O / X
- Stop/cancel the previously started clock.
- end table
- section Custom agenda views
- The main 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).
- Custom commands are configured in the variable
- kbd{C-c a C}. You can also directly set it with
- Emacs Lisp in
- smalllisp
- end group
- noindent
- The initial string in each entry defines the keys you have to press after the
- dispatcher command
- table
- item C-c a w
- as a global search for TODO entries with
- 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
- seealso{
- *
- *
- 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{}::
- end menu
- section Structural markup elements
- end menu
- subheading Document title
- smallexample
- #+TITLE: This is the title of the document
- node Headings and sections, Table of contents, Document title, Structural markup elements
- 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
- smallexample
- #+OPTIONS: H:4
- node Table of contents, Paragraphs, Headings and sections, Structural markup elements
- smallexample
- #+OPTIONS: toc:2 (only to two levels in TOC)
- #+OPTIONS: toc:nil (no TOC at all)
- node Paragraphs, Emphasis and monospace, Table of contents, Structural markup elements
- samp{\\} at the end of a line.
- To keep the line breaks in a region, but otherwise use normal formatting, you
- can use this construct, which can also be used to format poetry.
- end smallexample
- 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:
- end smallexample
- If you would like to center some text, do it like this:
- end smallexample
- subheading Emphasis and monospace
- You can make words i{/italic/}, _underlined_,
- code{~code~}, and, if you must,
- node Comment lines, , Emphasis and monospace, Structural markup elements
- samp{#}
- and a whitespace are treated as comments and, as such, are not exported.
- Likewise, regions surrounded by
- samp{#+END_COMMENT} are not exported.
- Finally, a
- table
- item C-c ;
- Toggle the COMMENT keyword at the beginning of an entry.
- node Images and tables, Literal examples, Structural markup elements, Markup
- code{[[tab:basic-data]]}:
- end smallexample
- Some backends 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
- smallexample
- #+CAPTION: This is the caption for the next figure link (or table)
- #+NAME: fig:SED-HR4049
- [[./img/a.jpg]]
- LaTeX{} equations, source code blocks), provided the chosen export
- back-end supports them.
- section Literal examples
- 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.
- end smallexample
- For simplicity when using small examples, you can also start the example
- lines with a colon followed by a space. There may also be additional
- whitespace before the colon:
- end smallexample
- For source code from a programming language, or any other text
- that can be marked up by font-lock in Emacs, you can ask for it to
- look like the fontified Emacs buffer
- end smallexample
- To edit the example in a special buffer supporting this language, use
- node Include files, Embedded
- section Include files
- During export, you can include the content of another file. For example, to
- include your
- smallexample
- #+INCLUDE: "~/.emacs" src emacs-lisp
- noindent
- The optional second and third parameter are the markup (i.e.,
- samp{src}), and, if the markup is
- smallexample
- #+INCLUDE: "./otherfile.org::#my_custom_id" :only-contents t
- noindent
- node Embedded
- section Embedded
- LaTeX{} code into
- its files. You can directly use TeX-like syntax for special symbols, enter
- formulas and entire
- smallexample
- Angles are written as Greek letters \alpha, \beta and \gamma. The mass if
- the sun is M_sun = 1.989 x 10^30 kg. The radius of the sun is R_} =
- 6.96 x 10^8 m. If $a^2=b$ and $b=2$, then the solution must be either
- $a=+\sqrt}$ or $a=-\sqrt}$.
- \begin}
- x=\sqrt}
- \end}
- noindent
- With
- LaTeX{} snippets will be included as images when exporting to HTML.
- uref{https://orgmode.org/manual/Markup.html#Markup, Chapter 11 of the manual}}
- chapter Exporting
- Org-mode documents can be exported into a variety of other formats: ASCII
- export for inclusion into emails, HTML to publish on the web,
- menu
- * Export options:: Per-file export settings
- * The export dispatcher:: How to access exporter commands
- * ASCII/Latin-1/UTF-8 export:: Exporting to flat files with encoding
- * HTML export:: Exporting to HTML
- * LaTeX{}, and processing to PDF
- * iCalendar export:: Exporting to iCalendar
- node Export options, The export dispatcher, Exporting, Exporting
- kbd{C-c C-e #}.
- kbd
- end table
- code{user-full-name})
- #+DATE: a date, fixed, or an Org timestamp
- #+EMAIL: his/her email address (default from
- : code{org-export-default-language})
- #+OPTIONS: H:2 num:t toc:t \n:nil ::t |:t ^:t f:t tex:t ...
- node The export dispatcher, ASCII/Latin-1/UTF-8 export, Export options, Exporting
- table
- item C-c C-e
- Dispatcher for export and publishing commands.
- node ASCII/Latin-1/UTF-8 export, HTML export, The export dispatcher, Exporting
- table
- item C-c C-e t a
- item C-c C-e t n
- item C-c C-e t u
- end table
- LaTeX{} and PDF export, ASCII/Latin-1/UTF-8 export, Exporting
- table
- item C-c C-e h h
- Export as HTML file
- item C-c C-e h o
- Export as HTML file and immediately open it with a browser.
- smallexample
- #+HTML: Literal HTML code for export
- noindent
- or
- end smallexample
- LaTeX{} and PDF export, iCalendar export, HTML export, Exporting
- LaTeX{} and PDF export
- kbd
- LaTeX{} file
- item C-c C-e l p
- Export as
- item C-c C-e l o
- Export as
- end table
- By default, the code{article}. You can
- change this by adding an option like
- code{org-latex-classes}.
- Embedded ref{Embedded
- LaTeX{} file. Similarly to the HTML exporter, you can use
- code{#+BEGIN_EXPORT latex ... #+END_EXPORT} construct to
- add verbatim
- node iCalendar export, ,
- section iCalendar export
- kbd
- file{.ics} file.
- code{org-agenda-files} and write it to the file given by
- end table
- uref{https://orgmode.org/manual/Exporting.html#Exporting, Chapter 12 of the manual}
- uref{https://orgmode.org/worg/org-tutorials/images-and-xhtml-export.html,
- Sebastian Rose's image handling tutorial}
- uref{https://orgmode.org/worg/org-tutorials/org-latex-export.html, Thomas
- Dye's LaTeX export tutorial}
- node Publishing, Working With Source Code, Exporting, Top
- 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. For detailed instructions about setup, see the manual.
- Here is an example:
- end smalllisp
- kbd
- item C-c C-e P p
- Publish the project containing the current file.
- item C-c C-e P a
- Publish every project.
- seealso{
- *
- *
- node Working With Source Code, Miscellaneous, Publishing, Top
- subheading Structure of Code Blocks
- The structure of code blocks is as follows:
- end example
- Where
- code{<language>} specifies the language of the code block
- (e.g.code{emacs-lisp}, code{R},
- code{<switches>} can be used to control export of the code block,
- code{<body>} contains the actual source
- code.
- 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
- subheading Evaluating code blocks
- Use
- code{emacs-lisp} code blocks, however support exists for evaluating blocks
- in many languages. For a complete list of supported languages see the
- manual. The following shows a code block and its results.
- end example
- kbd{C-c C-v t} to create pure source code files by extracting code from
- source blocks in the current buffer. This is referred to as ``tangling''---a
- term adopted from the literate programming community. During ``tangling'' of
- code blocks their bodies are expanded using
- code{:tangle} header argument, see the
- manual for details.
- kbd{C-c C-v l} to load the code blocks from an Org-mode files into the
- ``Library of Babel'', these blocks can then be evaluated from any Org-mode
- buffer. A collection of generally useful code blocks is accessible through
- Org-mode’s community-driven documentation on
- subheading Header Arguments
- Many aspects of the evaluation and export of code blocks are controlled
- through header arguments. These can be specified globally, at the file
- level, at the outline subtree level, and at the individual code block level.
- The following describes some of the header arguments.
- code
- code{:var} header argument is used to pass arguments to code blocks.
- The values passed to arguments can be literal values, values from org-mode
- tables and literal example blocks, or the results of other named code blocks.
- code{:results} header argument controls the
- emph{type}, and
- code{output} or
- code{vector},
- code{file} code{html} code{code} specify the
- type of the results of the code block which dictates how they will be
- incorporated into the Org-mode buffer. Values of
- code{replace}, code{append} specify handling of code
- block results, specifically if and how the results should be inserted into
- the Org-mode buffer.
- code{:session} will cause the code block to be
- evaluated in a persistent interactive inferior process in Emacs. This allows
- for persisting state between code block evaluations, and for manual
- inspection of the results of evaluation.
- emph{code} or the
- code{:results} header
- argument to code{results} code{both}.
- code{:tangle yes} will cause a code block's contents to
- be tangled to a file named after the filename of the Org-mode buffer. An
- alternate file name can be specified with
- item :cache
- A header argument of
- item :noweb
- A header argument of
- item :file
- Code blocks which output results to files (e.g.
- code{:file filename} header argument in which case the results
- are saved to the named file, and a link to the file is inserted into the
- Org-mode buffer.
- seealso{
- *
- node Miscellaneous, GNU Free Documentation License, Working With Source Code, Top
- menu
- * Completion:: M-TAB knows what you need
- * Clean view:: Getting rid of leading stars in the outline
- * MobileOrg:: Org-mode on the iPhone
- node Completion, Clean view, Miscellaneous, Miscellaneous
- kbd{M-
- TeX{} symbols after
- samp{:} in a
- headline.
- section A cleaner 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 smallexample
- code{org-indent-mode}, which will prepend intangible space to each line.
- You can turn on
- code{org-startup-indented}, or you can turn it on for individual
- files using
- end smallexample
- If you want a similar effect in earlier version of Emacs and/or Org, or if
- you want the indentation to be hard space characters so that the plain text
- file looks as similar as possible to the Emacs display, Org supports you by
- helping to indent (with
- smallexample
- #+STARTUP: hidestars odd
- node MobileOrg, , Clean view, Miscellaneous
- i{MobileOrg} is the name of the mobile companion app for Org mode, currently
- available for iOS and for Android.
- uref{http://mobileorg.ncogni.to/, iOS implementation} for the
- uref{http://wiki.github.com/matburt/mobileorg-android/, MobileOrg Android}
- by Matt Jones. The two implementations are not identical but offer similar
- features.
- uref{https://orgmode.org/manual/Miscellaneous.html#Miscellaneous, Chapter 15
- of the manual}
- uref{https://orgmode.org/manual/MobileOrg.html#MobileOrg, Appendix B of the
- manual}
- uref{https://orgmode.org/orgcard.pdf,Key reference card}}
- appendix GNU Free Documentation License
- bye
- c fill-column: 77
- c LocalWords: webdavhost pre
|