[[TOC(TracGuide, TracInstall, TracUpgrade, TracIni, TracAdmin, TracBackup, TracLogging, TracPermissions, TracWiki, WikiFormatting, TracBrowser, TracRoadmap, TracChangeset, TracTickets, TracReports, TracQuery, TracTimeline, TracRss, TracNotification)]] = Table of Contents Macro = == Description == The TocMacro generates a table of contents for the current page or a set of pages. If no arguments are given, a table of contents is generated for the current page, with the top-level title stripped: {{{ [[TOC]] }}} To generate a table of contents for a set of pages, simply pass them as comma separated arguments to the TOC macro. This is the macro call for the table of contents visible on the right side of this page: {{{ [[TOC(TracGuide, TracInstall, TracUpgrade, TracIni, TracAdmin, TracBackup, TracLogging, TracPermissions, TracWiki, WikiFormatting, TracBrowser, TracRoadmap, TracChangeset, TracTickets, TracReports, TracQuery, TracTimeline, TracRss, TracNotification)]] }}} A wildcard '*' can be used to fetch a sorted list of all pages starting with the preceding pagename stub (Since [2801]): {{{ [[TOC(Trac*, WikiFormatting, WikiMacros)]] }}} For 'titleindex' argument, an empty pagelist will evaluate to all pages (Since [2801]): {{{ [[TOC(titleindex, notitle, heading=All pages)]] }}} 'sectionindex' allows to generate a title index for all pages in a given section of the wiki. A section is defined by wiki page name, using '/' as a section level delimiter (like directories in a file system). Giving '/' or '*' as the page name produces the same result as 'titleindex' (title of all pages). If a page name ends with a '/', only children of this page will be processed. Else the page given in the argument is also included, if it exists. For 'sectionindex' argument, an empty pagelist will evaluate to all page below the same parent as the current page: {{{ [[TOC(sectionindex, notitle, heading=This section pages)]] }}} The following ''control'' arguments change the default behaviour of the TOC macro (Since [22]): || '''Argument''' || '''Meaning''' || || `heading=` || Override the default heading of "Table of Contents" or "Page Index" for titleindex. || || `noheading` || Suppress display of the heading. || || `depth=` || Display headings of ''subsequent'' pages to a maximum depth of ''''''. || || `inline` || Display TOC inline rather than as a side-bar. || || `sectionindex`|| Only display the page name and title of each page for all pages in a given section. (Since [3417]). || || `titleindex`|| Only display the page name and title of each page, similar to TitleIndex. (Since [37]). || || `notitle` || Supress display of page title (Since [2801]). || == Bugs/Feature Requests == Existing bugs and feature requests are [query:status!=closed&component=TocMacro&order=priority here]. If you have any issues, create a [/newticket?component=TocMacro new ticket]. == Installation == Both 0.10 and 0.11 entries at Python Package Index (pypi) are not up-to-date with latest versions and dependencies. To install the most recent versions, use direct installation from source: {{{ easy_install http://trac-hacks.org/svn/tocmacro/0.10 # 0.10 easy_install http://trac-hacks.org/svn/tocmacro/0.11 # 0.11 }}} ...or download / check out the source from repository (see below) and install it in usual manner. Do not forget to '''enable''' the '''macro''' in trac.ini (at least with 0.11 and 0.10.4) in the components section like this: {{{ tractoc.* = enabled }}} == Download == Download the zipped source from [download:tocmacro here]. TocMacro requires that AnchorPatch be applied to [wiki:0.8] Trac. Trac [wiki:0.9] already includes this patch. == Source == You can check out TocMacro from [http://trac-hacks.org/svn/tocmacro here] using Subversion, or [source:tocmacro browse the source] with Trac. == Example == {{{ [[TOC(inline, heading=Trac Table of Contents, TracGuide, TracInstall, depth=2, TracLogging, depth=99, TracPermissions)]] }}} On the right you can see the TOC macro version of the default !TracGuideToc macro. == Alternatives == Trac 0.12 (maybe earlier?) has the [wiki:WikiMacros#PageOutline-macro PageOutline] macro built-in which can produce output identical to the simpler use cases for the TOC macro. For example, this is equivalent to the no-argument form of TOC: {{{ [[PageOutline(2-5, Table of Contents, floated)]] }}} == Change Log == [[ChangeLog(/tocmacro, 3)]] == Author/Contributors == '''Authors:''' [wiki:athomas], [wiki:jouvin], [wiki:coderanger], [wiki:cboos], [wiki:osimons] [[BR]] '''Maintainer:''' [wiki:osimons] [[BR]] '''Contributors:'''