From: Joey Hess Date: Sat, 8 Dec 2007 20:59:08 +0000 (-0500) Subject: MAJOR basewiki reorg X-Git-Tag: 2.16~78 X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/commitdiff_plain/7960031135e74f6d36abc4294dbadb687117222c?hp=7b125b45b025bc92e67ef6e9984f7eb5a1970987 MAJOR basewiki reorg Including redir pages for the moved basewiki pages. These will be removed in a future release. --- diff --git a/IkiWiki/CGI.pm b/IkiWiki/CGI.pm index 788d0487e..75f096e13 100644 --- a/IkiWiki/CGI.pm +++ b/IkiWiki/CGI.pm @@ -249,7 +249,7 @@ sub cgi_prefs ($$) { #{{{ $form->field(name => "email", size => 50, fieldset => "preferences"); $form->field(name => "subscriptions", size => 50, fieldset => "preferences", - comment => "(".htmllink("", "", "PageSpec", noimageinline => 1).")"); + comment => "(".htmllink("", "", "ikiwiki/PageSpec", noimageinline => 1).")"); $form->field(name => "banned_users", size => 50, fieldset => "admin"); @@ -386,7 +386,9 @@ sub cgi_editpage ($$) { #{{{ $form->tmpl_param("can_commit", $config{rcs}); $form->tmpl_param("indexlink", indexlink()); $form->tmpl_param("helponformattinglink", - htmllink("", "", "HelpOnFormatting", noimageinline => 1)); + htmllink("", "", "ikiwiki/formatting", + noimageinline => 1, + linktext => "FormattingHelp")); $form->tmpl_param("baseurl", baseurl()); if ($form->submitted eq "Cancel") { diff --git a/IkiWiki/Plugin/lockedit.pm b/IkiWiki/Plugin/lockedit.pm index 82ce1e7be..a829df1cf 100644 --- a/IkiWiki/Plugin/lockedit.pm +++ b/IkiWiki/Plugin/lockedit.pm @@ -42,7 +42,7 @@ sub formbuilder_setup (@) { #{{{ if ($form->title eq "preferences") { $form->field(name => "locked_pages", size => 50, fieldset => "admin", - comment => "(".htmllink("", "", "PageSpec", noimageinline => 1).")"); + comment => "(".htmllink("", "", "ikiwiki/PageSpec", noimageinline => 1).")"); if (! IkiWiki::is_admin($user_name)) { $form->field(name => "locked_pages", type => "hidden"); } diff --git a/IkiWiki/Plugin/openid.pm b/IkiWiki/Plugin/openid.pm index ab9fc560b..e8dbe964f 100644 --- a/IkiWiki/Plugin/openid.pm +++ b/IkiWiki/Plugin/openid.pm @@ -42,7 +42,7 @@ sub formbuilder_setup (@) { #{{{ $form->field( name => "openid_url", - label => gettext("Log in with")." ".htmllink("", "", "OpenID", noimageinline => 1), + label => gettext("Log in with")." ".htmllink("", "", "ikiwiki/OpenID", noimageinline => 1), fieldset => "OpenID", size => 30, comment => ($config{openidsignup} ? " | ".gettext("Get an OpenID")."" : "") diff --git a/debian/changelog b/debian/changelog index f23b77813..b96ae08c5 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,7 +1,11 @@ ikiwiki (2.16) UNRELEASED; urgency=low - * Remove .otl file from sandbox to avoid build ugliness. Closes: #454181 + * Major basewiki reorganisation. Most pages moved into ikiwiki/ subdirectory + to avoid polluting the main namespace, and some were further renamed. * meta: Add redir support, based on a patch by Thomas Schwinge. + * Redirs added for moved basewiki pages. These will be removed in a future + release. + * Remove .otl file from sandbox to avoid build ugliness. Closes: #454181 -- Joey Hess Mon, 03 Dec 2007 14:47:36 -0500 diff --git a/doc/TourBusStop.mdwn b/doc/TourBusStop.mdwn index 2a19d6eba..8276c0833 100644 --- a/doc/TourBusStop.mdwn +++ b/doc/TourBusStop.mdwn @@ -6,7 +6,7 @@ This wiki serves as the home for the ikiwiki wiki engine, providing collaborativ * Rather than inventing yet another simplistic, linear version control system, ikiwiki uses a standard version control system such as [[Subversion|rcs/svn]] or [[rcs/Git]]. You can edit a wiki by committing to your repository, as well as through a traditional web interface. This makes ikiwiki ideal for collaborative software development; just keep your wiki in version control next to your software. You can also take full advantage of the features of these systems; for instance, you can keep a local branch of your wiki via [[rcs/Git]]. -* You can turn any set of pages into a [[blog]] or similar news feed, +* You can turn any set of pages into a [[ikiwiki/blog]] or similar news feed, * complete with RSS and Atom support. You can run your weblog on ikiwiki (and [[many_people_do|ikiwikiusers]]), run a Planet-like [[aggregator|plugins/aggregate]] for external feeds, or keep a [[TODO]] and [[bug|bugs]] list with tags for completed items. * ikiwiki provides a wiki compiler, designed to transform your wiki content into a set of static pages. You can then serve these pages as static content. ikiwiki will not fall over during a Slashdotting, because page views don't require the ikiwiki CGI; as long as your web server can keep up, your site will survive. Furthermore, you can choose whether you want to run the ikiwiki CGI for web edits or only handle commits to the underlying version control system; you can even run ikiwiki privately and just manually copy the content to another server. So if you want to put a wiki up on a server without installing any software on that server, try ikiwiki. diff --git a/doc/basewiki.mdwn b/doc/basewiki.mdwn index fca8902eb..29f632375 100644 --- a/doc/basewiki.mdwn +++ b/doc/basewiki.mdwn @@ -6,15 +6,16 @@ It currently includes these pages: * [[index]] * [[sandbox]] -* [[blog]] -* [[HelpOnFormatting]] -* [[markdown]] -* [[openid]] -* [[pagespec]] -* [[PreprocessorDirective]] * [[shortcuts]] -* [[subpage]] -* [[wikilink]] +* [[templates]] +* [[ikiwiki/blog]] +* [[ikiwiki/formatting]] +* [[ikiwiki/markdown]] +* [[ikiwiki/openid]] +* [[ikiwiki/pagespec]] +* [[ikiwiki/PreprocessorDirective]] +* [[ikiwiki/subpage]] +* [[ikiwiki/wikilink]] As well as a few other files, like [[favicon.ico]], [[local.css]], [[style.css]], and some icons. diff --git a/doc/blog.mdwn b/doc/blog.mdwn deleted file mode 100644 index 6e5eec4aa..000000000 --- a/doc/blog.mdwn +++ /dev/null @@ -1,97 +0,0 @@ -[[if test="enabled(inline)" - then="This wiki has the inline plugin **enabled**." - else="This wiki has the inline plugin **disabled**."]] - -[[if test="enabled(inline)" - then="You can" - else="If this wiki had the inline plugin enabled, you could"]] -turn any page on this wiki into a weblog by using the `inline` -[[PreProcessorDirective]]. For example: - - \[[inline pages="blog/* and !*/Discussion" show="10" rootpage="blog"]] - -Any pages that match the specified [[PageSpec]] (in the example, any -[[SubPage]] of "blog") will be part of the blog, and the newest 10 -of them will appear in the page. Note that if files that are not pages -match the [[PageSpec]], they will be included in the feed using RSS -enclosures, which is useful for podcasting. - -The optional `rootpage` parameter tells the wiki that new posts to this blog -should default to being [[SubPage]]s of "blog", and enables a form at the -top of the blog that can be used to add new items. - -If you want your blog to have an archive page listing every post ever made -to it, you can accomplish that like this: - - \[[inline pages="blog/* and !*/Discussion" archive="yes"]] - -You can even create an automatically generated list of all the pages on the -wiki, with the most recently added at the top, like this: - - \[[inline pages="* and !*/Discussion" archive="yes"]] - -If you want to be able to add pages to a given blog feed by tagging them, -you can do that too. To tag a page, just make it link to a page or pages -that represent its tags. Then use the special `link()` [[PageSpec]] to match -all pages that have a given tag: - - \[[inline pages="link(life)"]] - -Or include some tags and exclude others: - - \[[inline pages="link(debian) and !link(social)"]] - -## usage - -Here are descriptions of all the supported parameters to the `inline` -directive: - -* `pages` - A [[PageSpec]] of the pages to inline. -* `show` - Specify the maximum number of matching pages to inline. - Default is 10, unless archiving, when the default is to show all. - Set to 0 to show all matching pages. -* `skip` - Specify a number of pages to skip displaying. Can be useful - to produce a feed that only shows archived pages. -* `rss` - controls generation of an rss feed. On by default if the wiki is - configured to use rss feeds, set to "no" to disable. -* `atom` - controls generation of an atom feed. On by default if the wiki is - configured to use atom feeds, set to "no" to disable. -* `feeds` - controls generation of all types of feeds. Set to "no" to - disable generating any feeds. -* `postform` - Set to "yes" to enables a form to post new pages to a [[blog]]. -* `postformtext` - Set to specify text that is displayed in a postform. -* `rootpage` - Also enables a form to post new pages to a [[blog]], and - allows specifying of a page that is used as the parent page for new pages. -* `archive` - If set to "yes", only list page titles and some metadata, not - full controls. -* `quick` - Build archives in quick mode, without reading page contents for - metadata. By default, this also turns off generation of any feeds. -* `template` - Specifies the template to fill out to display each inlined - page. By default the `inlinepage` template is used, while - the `archivepage` template is used for archives. Set this parameter to - use some other, custom template, such as the `titlepage` template that - only shows post titles. Note that you should still set `archive=yes` if - your custom template does not include the page content. -* `raw` - Rather than the default behavior of creating a [[blog]], - if raw is set to "yes", the page will be included raw, without additional - markup around it, as if it were a literal part of the source of the - inlining page. -* `description` - Sets the description of the rss feed if one is generated. - Defaults to the name of the wiki. -* `actions` - If set to "yes" add links to the bottom of the inlined pages - for editing and discussion (if they would be shown at the top of the page - itself). -* `sort` - Controls how inlined pages are sorted. The default, "age" is to - sort newest created pages first. Setting it to "title" will sort pages by - title, and "mtime" sorts most recently modified pages first. -* `reverse` - If set to "yes", causes the sort order to be reversed. -* `feedpages` - A [[PageSpec]] of inlined pages to include in the rss/atom - feeds. The default is the same as the `pages` value above, and only pages - matches by that value are included, but some of those can be excluded by - specifying a tighter [[PageSpec]] here. -* `feedshow` - Specify the maximum number of matching pages to include in - the rss/atom feeds. The default is the same as the `show` value above. -* `feedonly` - Only generate the feed, do not display the pages inline on - the page. -* `timeformat` - Use this to specify how to display the time or date for pages - in the blog. The format string is passed to the strftime(3) function. diff --git a/doc/blog/discussion.mdwn b/doc/blog/discussion.mdwn deleted file mode 100644 index 8e98e2e5e..000000000 --- a/doc/blog/discussion.mdwn +++ /dev/null @@ -1,37 +0,0 @@ -## How do you provide the per post discussion links in your own blog? - -> That's configured by the "actions" parameter to the inline directive. See -> docs in [[plugins/inline]]. --[[Joey]] - -And do you have any ideas/hints about implementing a "comments" feature. -What I'm after is something for users who don't quite understand the Wiki -style for discussions. I would like to have a form for them to post a -comment and have the comment appended to the discussion Wiki-style. Maybe -take it as far as implementing "replies" to other comments. - --- Marcelo - -> See [[todo/discussion_page_as_blog]] for some of my own thoughts on this -> --[[Joey]] - ---- - -## More dynamic `rootpage` parameter of inline plugin? - -I prefer to use a current year, month and day to archive my blog posts, for example -`post/2007/11/12/foo-bar-baz` path is better for me then `post/foo-bar-baz`. -Unfortunately it seems that `rootpage` parameter of inline plugin is very static. -Is it a chance to make it more dynamic? Now I have to use `svn mkdir` command -to create appropriate subdirectories by hand. - -I think that you could add builtin functions or variables, for example `current_year()` -or `$CURRENT_YEAR` to usage inside `rootpage` parameter. Something like for Manoj's -calendar plugin. Then my `rootpage` parameter could be like -`rootpage="post/current_year()/current_month()/current_day()"`. Another good hints -are welcomed ;) - -What's your opinion, Joey? I hope it's also useful for another ikiwiki lovers :) - ---[[Paweł|ptecza]] - ->> Hello Joey! Is it a taboo subject? ;) --[[Paweł|ptecza]] diff --git a/doc/bugs/Spaces_in_link_text_for_ikiwiki_links.mdwn b/doc/bugs/Spaces_in_link_text_for_ikiwiki_links.mdwn index 40081590d..d6e4e5a9b 100644 --- a/doc/bugs/Spaces_in_link_text_for_ikiwiki_links.mdwn +++ b/doc/bugs/Spaces_in_link_text_for_ikiwiki_links.mdwn @@ -16,7 +16,7 @@ reported in [[index/discussion#index11h1]]. > want multiple words. > > This was a decision I made a long time ago due to the ambiguity between a -> WikiLink and a [[PreProcessorDirective]]. Is "\[[foo bar|baz]]" a wikilink to +> WikiLink and a [[ikiwiki/PreProcessorDirective]]. Is "\[[foo bar|baz]]" a wikilink to > baz with a link text of "foo bar", or an instance of preprocessor > directive "foo" with a parameter of "bar|baz"? If it's interpreted as a > wikilink today, that could change tomorrow if a new preprocessor directive diff --git a/doc/bugs/brokenlinks_false_positives.mdwn b/doc/bugs/brokenlinks_false_positives.mdwn index 53d7768ba..3fdc43c40 100644 --- a/doc/bugs/brokenlinks_false_positives.mdwn +++ b/doc/bugs/brokenlinks_false_positives.mdwn @@ -1,6 +1,6 @@ The [[plugins/brokenlinks]] plugin falsely complains that -[[helponformatting]] has a broken link to [[smileys]], if the smiley plgin -is disabled. While the helponformatting page links to it inside a +[[ikiwiki/formatting]] has a broken link to [[smileys]], if the smiley plgin +is disabled. While the page links to it inside a conditional, and so doesn't show the link in this case, ikiwiki scans for links w/o looking at conditionals and so still thinks the page contains the link. diff --git a/doc/bugs/linkingrules_should_document_how_to_link_to_page_at_root_if_non-root_page_exists.mdwn b/doc/bugs/linkingrules_should_document_how_to_link_to_page_at_root_if_non-root_page_exists.mdwn index 27e07eb2e..715f8cd4d 100644 --- a/doc/bugs/linkingrules_should_document_how_to_link_to_page_at_root_if_non-root_page_exists.mdwn +++ b/doc/bugs/linkingrules_should_document_how_to_link_to_page_at_root_if_non-root_page_exists.mdwn @@ -1,3 +1,6 @@ -The [[linking_rules|subpage/linkingrules]] should document how to link to a page at the root of the wiki when a normal, unadorned link would use a page of the same name further down the hierarchy. For example, how should [[todo/latex]] link to [[logo]] rather than [[todo/logo|todo/logo]]? +The [[linking_rules|ikiwiki/subpage/linkingrules]] should document how to +link to a page at the root of the wiki when a normal, unadorned link would +use a page of the same name further down the hierarchy. For example, how +should [[todo/latex]] link to [[logo]] rather than [[todo/logo|todo/logo]]? > [[bugs/done]].. the syntax to use is "/logo" --[[Joey]] diff --git a/doc/bugs/wiki_links_still_processed_inside_code_blocks.mdwn b/doc/bugs/wiki_links_still_processed_inside_code_blocks.mdwn index 6d8a3b61d..2bda0cc0f 100644 --- a/doc/bugs/wiki_links_still_processed_inside_code_blocks.mdwn +++ b/doc/bugs/wiki_links_still_processed_inside_code_blocks.mdwn @@ -1,6 +1,6 @@ -In [[markdown]] syntax, none of the other special characters get processed +In [[ikiwiki/markdown]] syntax, none of the other special characters get processed inside a code block. However, in ikiwiki, [[wiki_links|wikilink]] and -[[preprocessor_directives|preprocessordirective]] still get processed +[[preprocessor_directives|ikiwiki/preprocessordirective]] still get processed inside a code block, requiring additional escaping. For example, `[links don't work](#here)`, but `a [[wikilink]] becomes HTML`. --[[JoshTriplett]] diff --git a/doc/features.mdwn b/doc/features.mdwn index 149908db6..a7b5c19ab 100644 --- a/doc/features.mdwn +++ b/doc/features.mdwn @@ -27,12 +27,12 @@ new pages and links that can indirectly cause a page to need a rebuild) ## Supports many markup languages -By default, pages in the wiki are written using the [[MarkDown]] format. +By default, pages in the wiki are written using the [[ikiwiki/MarkDown]] format. Any page with a filename ending in ".mdwn" is converted from markdown to html by ikiwiki. Markdown understands text formatted as it would be in an email, and is quite smart about converting it to html. The only additional markup -provided by ikiwiki on top of regular markdown is the [[WikiLink]] and -[[PreprocessorDirective]]. +provided by ikiwiki on top of regular markdown is the [[ikiwiki/WikiLink]] and +[[ikiwiki/PreprocessorDirective]]. If you prefer to use some other markup language, ikiwiki allows others to easily be added by [[plugins]]. For example it also supports traditional @@ -47,8 +47,8 @@ program, or other special file and link to it from your wiki pages. ## Blogging -You can turn any page in the wiki into a [[blog]]. Pages matching a -specified [[PageSpec]] will be displayed as a weblog within the blog +You can turn any page in the wiki into a [[ikiwiki/blog]]. Pages matching a +specified [[ikiwiki/PageSpec]] will be displayed as a weblog within the blog page. And RSS or Atom feeds can be generated to follow the blog. Ikiwiki's own [[TODO]], [[news]], and [[plugins]] pages are good examples @@ -74,7 +74,7 @@ can change the look and layout of all pages in any way you would like. Plugins can be used to add additional features to ikiwiki. The interface is quite flexible, allowing plugins to implement additional markup -languages, register [[PreProcessorDirective]]s, hook into [[CGI]] mode, +languages, register [[ikiwiki/PreProcessorDirective]]s, hook into [[CGI]] mode, and more. Most of ikiwiki's features are actually provided by plugins. Ikiwiki's backend RCS support is also pluggable, so support for new revision control systems can be added to ikiwiki. @@ -100,10 +100,10 @@ You can tag pages and use these tags in various ways. Tags will show up in the ways you'd expect, like at the bottom of pages, in blogs, and in RSS and Atom feeds. -### [[SubPages|SubPage]] +### [[SubPages|ikiwiki/SubPage]] Arbitrarily deep hierarchies of pages with fairly simple and useful -[[SubPage/LinkingRules]] +[[ikiwiki/SubPage/LinkingRules]] ### [[BackLinks]] diff --git a/doc/helponformatting.mdwn b/doc/helponformatting.mdwn deleted file mode 100644 index 4e8760c6b..000000000 --- a/doc/helponformatting.mdwn +++ /dev/null @@ -1,94 +0,0 @@ -[[meta title="Help on formatting wiki pages"]] - -Text on this wiki is, by default, written in a form very close to how you -might write text for an email message. This style of text formatting is -called [[MarkDown]], and it works like this: - -Leave blank lines between paragraphs. - -You can \**emphasise*\* or \*\***strongly emphasise**\*\* text by placing it -in single or double asterisks. - -To create a list, start each line with an asterisk: - -* "* this is my list" -* "* another item" - -To make a numbered list, start each line with a number (any number will -do) followed by a period: - -1. "1. first line" -2. "2. second line" -2. "2. third line" - -To create a header, start a line with one or more `#` characters followed -by a space and the header text. The number of `#` characters controls the -size of the header: - -# # h1 -## ## h2 -### ### h3 -#### #### h4 -##### ##### h5 -###### ###### h6 - -To create a horizontal rule, just write three or more dashes or stars on -their own line: - ----- - -To quote someone, prefix the quote with ">": - -> To be or not to be, -> that is the question. - -To write a code block, indent each line with a tab or 4 spaces: - - 10 PRINT "Hello, world!" - 20 GOTO 10 - -To link to an url or email address, you can just put the -url in angle brackets: <>, or you can use the -form \[link text\]\(url\) - ----- - -In addition to basic html formatting using [[MarkDown]], this wiki lets -you use the following additional features: - -* To link to another page on the wiki, place the page's name inside double - square brackets. So you would use `\[[WikiLink]]` to link to [[WikiLink]]. - -[[if test="enabled(smiley) and smileys" then=""" -* Insert [[smileys]] and some other useful symbols. :-) -"""]] - -[[if test="enabled(shortcut) and shortcuts" then=""" -* Use [[shortcuts]] to link to common resources. - - \[[wikipedia War\_of\_1812]] -"""]] - -[[if test="enabled(toc)" then=""" -* Add a table of contents to a page: - - \[[toc ]] -"""]] - - -[[if test="enabled(meta)" then=""" -* Change the title of a page: - - \[[meta title="full page title"]] -"""]] - -[[if test="enabled(inline) and blog" then=""" -* Create a [[blog]] by inlining a set of pages: - - \[[inline pages="blog/*"]] -"""]] - -[[if test="enabled(template) and templates" then=""" -* Create and fill out [[templates]] for repeated chunks of - parameterized wiki text. -"""]] diff --git a/doc/ikiwiki/blog.mdwn b/doc/ikiwiki/blog.mdwn new file mode 100644 index 000000000..6e5eec4aa --- /dev/null +++ b/doc/ikiwiki/blog.mdwn @@ -0,0 +1,97 @@ +[[if test="enabled(inline)" + then="This wiki has the inline plugin **enabled**." + else="This wiki has the inline plugin **disabled**."]] + +[[if test="enabled(inline)" + then="You can" + else="If this wiki had the inline plugin enabled, you could"]] +turn any page on this wiki into a weblog by using the `inline` +[[PreProcessorDirective]]. For example: + + \[[inline pages="blog/* and !*/Discussion" show="10" rootpage="blog"]] + +Any pages that match the specified [[PageSpec]] (in the example, any +[[SubPage]] of "blog") will be part of the blog, and the newest 10 +of them will appear in the page. Note that if files that are not pages +match the [[PageSpec]], they will be included in the feed using RSS +enclosures, which is useful for podcasting. + +The optional `rootpage` parameter tells the wiki that new posts to this blog +should default to being [[SubPage]]s of "blog", and enables a form at the +top of the blog that can be used to add new items. + +If you want your blog to have an archive page listing every post ever made +to it, you can accomplish that like this: + + \[[inline pages="blog/* and !*/Discussion" archive="yes"]] + +You can even create an automatically generated list of all the pages on the +wiki, with the most recently added at the top, like this: + + \[[inline pages="* and !*/Discussion" archive="yes"]] + +If you want to be able to add pages to a given blog feed by tagging them, +you can do that too. To tag a page, just make it link to a page or pages +that represent its tags. Then use the special `link()` [[PageSpec]] to match +all pages that have a given tag: + + \[[inline pages="link(life)"]] + +Or include some tags and exclude others: + + \[[inline pages="link(debian) and !link(social)"]] + +## usage + +Here are descriptions of all the supported parameters to the `inline` +directive: + +* `pages` - A [[PageSpec]] of the pages to inline. +* `show` - Specify the maximum number of matching pages to inline. + Default is 10, unless archiving, when the default is to show all. + Set to 0 to show all matching pages. +* `skip` - Specify a number of pages to skip displaying. Can be useful + to produce a feed that only shows archived pages. +* `rss` - controls generation of an rss feed. On by default if the wiki is + configured to use rss feeds, set to "no" to disable. +* `atom` - controls generation of an atom feed. On by default if the wiki is + configured to use atom feeds, set to "no" to disable. +* `feeds` - controls generation of all types of feeds. Set to "no" to + disable generating any feeds. +* `postform` - Set to "yes" to enables a form to post new pages to a [[blog]]. +* `postformtext` - Set to specify text that is displayed in a postform. +* `rootpage` - Also enables a form to post new pages to a [[blog]], and + allows specifying of a page that is used as the parent page for new pages. +* `archive` - If set to "yes", only list page titles and some metadata, not + full controls. +* `quick` - Build archives in quick mode, without reading page contents for + metadata. By default, this also turns off generation of any feeds. +* `template` - Specifies the template to fill out to display each inlined + page. By default the `inlinepage` template is used, while + the `archivepage` template is used for archives. Set this parameter to + use some other, custom template, such as the `titlepage` template that + only shows post titles. Note that you should still set `archive=yes` if + your custom template does not include the page content. +* `raw` - Rather than the default behavior of creating a [[blog]], + if raw is set to "yes", the page will be included raw, without additional + markup around it, as if it were a literal part of the source of the + inlining page. +* `description` - Sets the description of the rss feed if one is generated. + Defaults to the name of the wiki. +* `actions` - If set to "yes" add links to the bottom of the inlined pages + for editing and discussion (if they would be shown at the top of the page + itself). +* `sort` - Controls how inlined pages are sorted. The default, "age" is to + sort newest created pages first. Setting it to "title" will sort pages by + title, and "mtime" sorts most recently modified pages first. +* `reverse` - If set to "yes", causes the sort order to be reversed. +* `feedpages` - A [[PageSpec]] of inlined pages to include in the rss/atom + feeds. The default is the same as the `pages` value above, and only pages + matches by that value are included, but some of those can be excluded by + specifying a tighter [[PageSpec]] here. +* `feedshow` - Specify the maximum number of matching pages to include in + the rss/atom feeds. The default is the same as the `show` value above. +* `feedonly` - Only generate the feed, do not display the pages inline on + the page. +* `timeformat` - Use this to specify how to display the time or date for pages + in the blog. The format string is passed to the strftime(3) function. diff --git a/doc/ikiwiki/blog/discussion.mdwn b/doc/ikiwiki/blog/discussion.mdwn new file mode 100644 index 000000000..8e98e2e5e --- /dev/null +++ b/doc/ikiwiki/blog/discussion.mdwn @@ -0,0 +1,37 @@ +## How do you provide the per post discussion links in your own blog? + +> That's configured by the "actions" parameter to the inline directive. See +> docs in [[plugins/inline]]. --[[Joey]] + +And do you have any ideas/hints about implementing a "comments" feature. +What I'm after is something for users who don't quite understand the Wiki +style for discussions. I would like to have a form for them to post a +comment and have the comment appended to the discussion Wiki-style. Maybe +take it as far as implementing "replies" to other comments. + +-- Marcelo + +> See [[todo/discussion_page_as_blog]] for some of my own thoughts on this +> --[[Joey]] + +--- + +## More dynamic `rootpage` parameter of inline plugin? + +I prefer to use a current year, month and day to archive my blog posts, for example +`post/2007/11/12/foo-bar-baz` path is better for me then `post/foo-bar-baz`. +Unfortunately it seems that `rootpage` parameter of inline plugin is very static. +Is it a chance to make it more dynamic? Now I have to use `svn mkdir` command +to create appropriate subdirectories by hand. + +I think that you could add builtin functions or variables, for example `current_year()` +or `$CURRENT_YEAR` to usage inside `rootpage` parameter. Something like for Manoj's +calendar plugin. Then my `rootpage` parameter could be like +`rootpage="post/current_year()/current_month()/current_day()"`. Another good hints +are welcomed ;) + +What's your opinion, Joey? I hope it's also useful for another ikiwiki lovers :) + +--[[Paweł|ptecza]] + +>> Hello Joey! Is it a taboo subject? ;) --[[Paweł|ptecza]] diff --git a/doc/ikiwiki/formatting.mdwn b/doc/ikiwiki/formatting.mdwn new file mode 100644 index 000000000..69e28913f --- /dev/null +++ b/doc/ikiwiki/formatting.mdwn @@ -0,0 +1,94 @@ +[[meta title="Formatting wiki pages"]] + +Text on this wiki is, by default, written in a form very close to how you +might write text for an email message. This style of text formatting is +called [[MarkDown]], and it works like this: + +Leave blank lines between paragraphs. + +You can \**emphasise*\* or \*\***strongly emphasise**\*\* text by placing it +in single or double asterisks. + +To create a list, start each line with an asterisk: + +* "* this is my list" +* "* another item" + +To make a numbered list, start each line with a number (any number will +do) followed by a period: + +1. "1. first line" +2. "2. second line" +2. "2. third line" + +To create a header, start a line with one or more `#` characters followed +by a space and the header text. The number of `#` characters controls the +size of the header: + +# # h1 +## ## h2 +### ### h3 +#### #### h4 +##### ##### h5 +###### ###### h6 + +To create a horizontal rule, just write three or more dashes or stars on +their own line: + +---- + +To quote someone, prefix the quote with ">": + +> To be or not to be, +> that is the question. + +To write a code block, indent each line with a tab or 4 spaces: + + 10 PRINT "Hello, world!" + 20 GOTO 10 + +To link to an url or email address, you can just put the +url in angle brackets: <>, or you can use the +form \[link text\]\(url\) + +---- + +In addition to basic html formatting using [[MarkDown]], this wiki lets +you use the following additional features: + +* To link to another page on the wiki, place the page's name inside double + square brackets. So you would use `\[[WikiLink]]` to link to [[WikiLink]]. + +[[if test="enabled(smiley) and smileys" then=""" +* Insert [[smileys]] and some other useful symbols. :-) +"""]] + +[[if test="enabled(shortcut) and shortcuts" then=""" +* Use [[shortcuts]] to link to common resources. + + \[[wikipedia War\_of\_1812]] +"""]] + +[[if test="enabled(toc)" then=""" +* Add a table of contents to a page: + + \[[toc ]] +"""]] + + +[[if test="enabled(meta)" then=""" +* Change the title of a page: + + \[[meta title="full page title"]] +"""]] + +[[if test="enabled(inline) and blog" then=""" +* Create a [[blog]] by inlining a set of pages: + + \[[inline pages="blog/*"]] +"""]] + +[[if test="enabled(template) and templates" then=""" +* Create and fill out [[templates]] for repeated chunks of + parameterized wiki text. +"""]] diff --git a/doc/ikiwiki/markdown.mdwn b/doc/ikiwiki/markdown.mdwn new file mode 100644 index 000000000..73aee9c16 --- /dev/null +++ b/doc/ikiwiki/markdown.mdwn @@ -0,0 +1,12 @@ +[Markdown](http://daringfireball.net/projects/markdown/) +is a minimal markup language that resembles plain text as used in +email messages. It is the markup language used by this wiki by default. + +For documentation about the markdown syntax, see [[formatting]] and +[Markdown: syntax](http://daringfireball.net/projects/markdown/syntax). A +[markdown mode](http://jrblevin.freeshell.org/software/markdown-mode/) for +emacs can help in editing. + +Note that [[WikiLink]]s and [[PreProcessorDirective]]s are not part of the +markdown syntax, and are the only bit of markup that this wiki handles +internally. diff --git a/doc/ikiwiki/openid.mdwn b/doc/ikiwiki/openid.mdwn new file mode 100644 index 000000000..f02a0a62c --- /dev/null +++ b/doc/ikiwiki/openid.mdwn @@ -0,0 +1,32 @@ +[[meta title="OpenID"]] + +[[if test="enabled(openid)" + then="This wiki has OpenID **enabled**." + else="This wiki has OpenID **disabled**."]] + +[OpenID](http://openid.net) is a decentralized authentication mechanism +that allows you to have one login that you can use on a growing number of +websites. + +To sign up for an OpenID, visit one of the following identity providers: + +* [MyOpenID](https://www.myopenid.com/) +* [GetOpenID](https://getopenid.com/) +* [Videntity](http://videntity.org/) +* [LiveJournal](http://www.livejournal.com/openid/) +* or any of the [many others out there](http://openiddirectory.com/index.php?dir=1).. + +Your OpenID is the URL that you are given when you sign up. +[[if test="enabled(openid)" then=""" +To sign in to this wiki using OpenID, just enter it in the OpenID field in the +signin form. You do not need to give this wiki a password or go through any +registration process when using OpenID. +"""]] + +--- + +It's also possible to make a page in the wiki usable as an OpenID url, +by delegating it to an openid server. Here's an example of how to do that: + + \[[meta openid="http://yourid.myopenid.com/" + server="http://www.myopenid.com/server"]] diff --git a/doc/ikiwiki/pagespec.mdwn b/doc/ikiwiki/pagespec.mdwn new file mode 100644 index 000000000..5c6433ed3 --- /dev/null +++ b/doc/ikiwiki/pagespec.mdwn @@ -0,0 +1,79 @@ +To select a set of pages, such as pages that are locked, pages +whose commit emails you want subscribe to, or pages to combine into a +blog, the wiki uses a PageSpec. This is an expression that matches +a set of pages. + +The simplest PageSpec is a simple list of pages. For example, this matches +any of the three listed pages: + + foo or bar or baz + +More often you will want to match any pages that have a particular thing in +their name. You can do this using a glob pattern. "`*`" stands for any part +of a page name, and "`?`" for any single letter of a page name. So this +matches all pages about music, and any [[SubPage]]s of the SandBox, but does +not match the SandBox itself: + + *music* or SandBox/* + +You can also prefix an item with "`!`" to skip pages that match it. So to +match all pages except for Discussion pages and the SandBox: + + * and !SandBox and !*/Discussion + +Some more elaborate limits can be added to what matches using any of these +functions: + +* "`link(page)`" - match only pages that link to a given page (or glob) +* "`backlink(page)`" - match only pages that a given page links to +* "`creation_month(month)`" - match only pages created on the given month +* "`creation_day(mday)`" - or day of the month +* "`creation_year(year)`" - or year +* "`created_after(page)`" - match only pages created after the given page + was created +* "`created_before(page)`" - match only pages created before the given page + was created +* "`user(name)`" - only available in page subscription preferences, match + only changes made by this user + +For example, to match all pages in a blog that link to the page about music +and were written in 2005: + + blog/* and link(music) and creation_year(2005) + +Note the use of "and" in the above example, that means that only pages that +match each of the three expressions match the whole. Use "and" when you +want to combine expression like that; "or" when it's enough for a page to +match one expression. Note that it doesn't make sense to say "index and +SandBox", since no page can match both expressions. + +More complex expressions can also be created, by using parentheses for +grouping. For example, to match pages in a blog that are tagged with either +of two tags, use: + + blog/* and (link(tag/foo) or link(tag/bar)) + +Note that page names in PageSpecs are matched against the absolute +filenames of the pages in the wiki, so a pagespec "foo" used on page +"a/b" will not match a page named "a/foo" or "a/b/foo". To match +relative to the directory of the page containing the pagespec, you can +use "./". For example, "./foo" on page "a/b" matches page "a/foo". + +## Old syntax + +The old PageSpec syntax was called a "GlobList", and worked differently in +two ways: + +1. "and" and "or" were not used; any page matching any item from the list + matched. +2. If an item was prefixed with "`!`", then no page matching that item + matched, even if it matched an earlier list item. + +For example, here is the old way to match all pages except for the SandBox +and Discussion pages: + + * !SandBox !*/Discussion + +Using this old syntax is still supported. However, the old syntax is +deprecated and will be removed at some point, and using the new syntax is +recommended. diff --git a/doc/ikiwiki/pagespec/discussion.mdwn b/doc/ikiwiki/pagespec/discussion.mdwn new file mode 100644 index 000000000..ab05e3e78 --- /dev/null +++ b/doc/ikiwiki/pagespec/discussion.mdwn @@ -0,0 +1,52 @@ +I am using ikiwiki 2.6.1. + +I can't figure out the locked pages. + +As an admin in preferences, I put in my Locked Pages: + +index and downloads + +I don't want anyone to be able to edit the front page or my downloads page. + +That didn't work. I am using a different web browser as a different non-ikiwiki-admin user. + +So I changed it to + +/index and /downloads + +That stopped me from editing the front page. It didn't say it was locked just repeatedly gave me the ikiwiki login. (How can I get it to tell me it is locked instead?) + +I also tried + +/index and /downloads/index + +But I could still edit my downloads page. + +Can someone share some hints on how to lock these two pages? + +My source pages for the lock are: + +source/downloads.mdwn +source/index.mdwn + +My webpages to lock are: + +public\_html/downloads/index.html +public\_html/index.html + +> So I tried again with using "or" instead of "and": +> +> index or downloads +> +> And that worked. I now get a message saying it is locked and cannot be edited. +> To me saying "lock both 'index and downloads'" made sense while now it reads like: "lock either 'index or downloads'". Maybe the [[PageSpec]] should define "and" and "or" (beyond the examples it has). +> +> Also why did my "/index and /downloads" prevent editing the index by repeatedly showing login webpage? +> +> -JeremyReed + +>> I've clarified and/or in [[PageSpec]]. +>> +>> I can't reproduce "/index and /downloads" causing the login webpage to +>> be shown repeatedly. Sure you weren't having some independent issue with +>> logging in? --[[Joey]] diff --git a/doc/ikiwiki/preprocessordirective.mdwn b/doc/ikiwiki/preprocessordirective.mdwn new file mode 100644 index 000000000..1e2332c09 --- /dev/null +++ b/doc/ikiwiki/preprocessordirective.mdwn @@ -0,0 +1,33 @@ +Preprocessor directives are similar to a [[WikiLink]] in form, except they +contain spaces and parameters. The general form is: + + \[[directive param="value" param="value"]] + +This gets expanded before the rest of the page is processed, and can be used +to transform the page in various ways. + +The quotes around values can be omitted if the value is a simple word. +Also, some directives may use parameters without values, for example: + + \[[tag foo]] + +Note that if a preprocessor directive has no parameters, a space still must +be put after its name, to avoid confusion with a [[WikiLink]]. For example: + + \[[pagecount ]] + +A preprocessor directive does not need to all be on one line, it can be +wrapped to multiple lines if you like: + + \[[directive foo="baldersnatch" + bar="supercalifragalisticexpealadocious" baz=11]] + +Also, multiple lines of *quoted* text can be used for a value. +To allow quote marks inside the quoted text, delimit the block +of text with triple-quotes: + + \[[directive text=""" + 1. "foo" + 2. "bar" + 3. "baz" + """]] diff --git a/doc/ikiwiki/subpage.mdwn b/doc/ikiwiki/subpage.mdwn new file mode 100644 index 000000000..43669209c --- /dev/null +++ b/doc/ikiwiki/subpage.mdwn @@ -0,0 +1,11 @@ +ikiwiki supports placing pages in a directory hierarchy. For example, +this page, [[SubPage]] has some related pages placed under it, like +[[SubPage/LinkingRules]]. This is a useful way to add some order to your +wiki rather than just having a great big directory full of pages. + +To add a SubPage, just make a subdirectory and put pages in it. For +example, this page is SubPage.mdwn in this wiki's source, and there is also +a SubPage subdirectory, which contains SubPage/LinkingRules.mdwn. Subpages +can be nested as deeply as you'd like. + +Linking to and from a SubPage is explained in [[LinkingRules]]. diff --git a/doc/ikiwiki/subpage/linkingrules.mdwn b/doc/ikiwiki/subpage/linkingrules.mdwn new file mode 100644 index 000000000..c1062304a --- /dev/null +++ b/doc/ikiwiki/subpage/linkingrules.mdwn @@ -0,0 +1,32 @@ +To link to or from a [[SubPage]], you can normally use a regular +[[WikiLink]] that does not contain the name of the parent directory of +the [[SubPage]]. Ikiwiki descends the directory hierarchy looking for a +page that matches your link. + +For example, if FooBar/SubPage links to "OtherPage", ikiwiki will first +prefer pointing the link to FooBar/SubPage/OtherPage if it exists, next +to FooBar/OtherPage and finally to OtherPage in the root of the wiki. + +Note that this means that if a link on FooBar/SomePage to "OtherPage" +currently links to OtherPage, in the root of the wiki, and FooBar/OtherPage +is created, the link will _change_ to point to FooBar/OtherPage. On the +other hand, a link from BazBar to "OtherPage" would be unchanged by this +creation of a [[SubPage]] of FooBar. + +You can also specify a link that contains a directory name, like +"FooBar/OtherPage" to more exactly specify what page to link to. This is +the only way to link to an unrelated [[SubPage]]. + +You can use this to, for example, to link from BazBar to "FooBar/SubPage", +or from BazBar/SubPage to "FooBar/SubPage". + +You can also use "/" at the start of a link, to specify exactly which page +to link to, when there are multiple pages with similar names and the link +goes to the wrong page by default. For example, linking from +"FooBar/SubPage" to "/OtherPage" will link to the "OtherPage" in the root +of the wiki, even if there is a "FooBar/OtherPage". + +Also, if the wiki is configured with a userdir, you can link to pages +within the userdir without specifying a path to them. This is to allow for +easy linking to a user's page in the userdir, to sign a comment. These +links are checked for last of all. diff --git a/doc/ikiwiki/wikilink.mdwn b/doc/ikiwiki/wikilink.mdwn new file mode 100644 index 000000000..38df00f86 --- /dev/null +++ b/doc/ikiwiki/wikilink.mdwn @@ -0,0 +1,27 @@ +WikiLinks provide easy linking between pages of the wiki. To create a +[[WikiLink]], just put the name of the page to link to in double brackets. +For example `\[[WikiLink]]`. + +If you ever need to write something like `\[[WikiLink]]` without creating a +wikilink, just prefix it with a `\`, like `\\[[WikiLink]]`. + +There are some special [[SubPage/LinkingRules]] that come into play when +linking between [[SubPages|SubPage]]. + +Also, if the file linked to by a WikiLink looks like an image, it will +be displayed inline on the page. + +WikiLinks are matched with page names in a case-insensitive manner, so you +don't need to worry about getting the case the same, and can capitalise +links at the start of a sentence, and so on. + +It's also possible to write a WikiLink that uses something other than the page +name as the link text. For example `\[[foo_bar|SandBox]]` links to the SandBox +page, but the link will appear like this: [[foo_bar|SandBox]]. + +To link to an anchor inside a page, you can use something like +`\[[WikiLink#foo]]` + +**Note that you cannot use spaces in WikiLinks**. Replace spaces with +underscores. The presence of spaces is used to distinguish between a +[[PreprocessorDirective]] and a WikiLink. diff --git a/doc/ikiwiki/wikilink/discussion.mdwn b/doc/ikiwiki/wikilink/discussion.mdwn new file mode 100644 index 000000000..d81163670 --- /dev/null +++ b/doc/ikiwiki/wikilink/discussion.mdwn @@ -0,0 +1,29 @@ +# Creating an anchor in Markdown + +Is it a native Markdown "tag" for creating an anchor? Unfortunately, +I haven't any information about it at +[Markdown syntax](http://daringfireball.net/projects/markdown/syntax) page. + +Of course, I know that I can use HTML tag to do it, +for example <a name="foo" />, but I don't want to mix Markdown +and HTML code if it's not necessary. + +BTW, ikiwiki doesn't displays the #foo anchor in the example +("To link to an anchor inside a page...") at [[WikiLink]] page... + +--[[Paweł|ptecza]] + +> No such syntax exists in markdown. ikiwiki could certainly have a +> [[preprocessor_directive|preprocessordirective]] for it, though. +> +> The lack of the `#foo` anchor in the anchor example on [[wikilink]] +> definitely looks like a bug. --[[JoshTriplett]] + +>> Fixed that --[[Joey]] + +--- + +Considering a hierarchy like `foo/bar/bar`, I had the need to link from the +`foo/bar/bar` page to the `foo/bar` one. It would have been convenient to +simply write [[wikilink]]s like `\[[../bar]]` (or even just `\[[..]]`?), but +this doesn't work, so I had to resort to using `\[[foo/bar]]` instead. diff --git a/doc/index.mdwn b/doc/index.mdwn index 32dda57eb..22fc7f071 100644 --- a/doc/index.mdwn +++ b/doc/index.mdwn @@ -1,8 +1,8 @@ Ikiwiki is a **wiki compiler**. It converts wiki pages into HTML pages suitable for publishing on a website. Ikiwiki stores pages and history in a [[revision_control_system|rcs]] such as [[Subversion|rcs/svn]] or [[rcs/Git]]. -There are many other [[features]], including support for [[blogging|blog]], -as well as a large array of [[plugins]]. +There are many other [[features]], including support for +[[blogging|ikiwiki/blog]], as well as a large array of [[plugins]]. [[template id=links]] diff --git a/doc/markdown.mdwn b/doc/markdown.mdwn deleted file mode 100644 index e7823bbf6..000000000 --- a/doc/markdown.mdwn +++ /dev/null @@ -1,13 +0,0 @@ -[Markdown](http://daringfireball.net/projects/markdown/) -is a minimal markup language that resembles plain text as used in -email messages. It is the markup language used by this wiki by default. - -For documentation about the markdown syntax, see [[HelpOnFormatting]] and -[Markdown: syntax](http://daringfireball.net/projects/markdown/syntax). A -[markdown mode](http://jrblevin.freeshell.org/software/markdown-mode/) for -emacs can help in editing. - -Note that [[WikiLink]]s and [[PreProcessorDirective]]s are not part of the -markdown syntax, and are the only bit of markup that this wiki handles -internally. - diff --git a/doc/openid.mdwn b/doc/openid.mdwn deleted file mode 100644 index f02a0a62c..000000000 --- a/doc/openid.mdwn +++ /dev/null @@ -1,32 +0,0 @@ -[[meta title="OpenID"]] - -[[if test="enabled(openid)" - then="This wiki has OpenID **enabled**." - else="This wiki has OpenID **disabled**."]] - -[OpenID](http://openid.net) is a decentralized authentication mechanism -that allows you to have one login that you can use on a growing number of -websites. - -To sign up for an OpenID, visit one of the following identity providers: - -* [MyOpenID](https://www.myopenid.com/) -* [GetOpenID](https://getopenid.com/) -* [Videntity](http://videntity.org/) -* [LiveJournal](http://www.livejournal.com/openid/) -* or any of the [many others out there](http://openiddirectory.com/index.php?dir=1).. - -Your OpenID is the URL that you are given when you sign up. -[[if test="enabled(openid)" then=""" -To sign in to this wiki using OpenID, just enter it in the OpenID field in the -signin form. You do not need to give this wiki a password or go through any -registration process when using OpenID. -"""]] - ---- - -It's also possible to make a page in the wiki usable as an OpenID url, -by delegating it to an openid server. Here's an example of how to do that: - - \[[meta openid="http://yourid.myopenid.com/" - server="http://www.myopenid.com/server"]] diff --git a/doc/page_locking.mdwn b/doc/page_locking.mdwn index 01c687169..21f4fb027 100644 --- a/doc/page_locking.mdwn +++ b/doc/page_locking.mdwn @@ -5,10 +5,11 @@ from editing the pages, however. To lock a page, log into the wiki as whatever user is configured as the admin, and in your Preferences page, you'll find a field listing locked -pages. This is a [[PageSpec]], so you have a fair bit of control over what -kinds of pages to lock. For example, you could choose to lock all pages -created before 2006, or all pages that are linked to from the page named -"locked". More usually though, you'll just list some names of pages to lock. +pages. This is a [[ikiwiki/PageSpec]], so you have a fair bit of control +over what kinds of pages to lock. For example, you could choose to lock all +pages created before 2006, or all pages that are linked to from the page +named "locked". More usually though, you'll just list some names of pages +to lock. One handy thing to do if you're using ikiwiki for your blog is to lock "* and !*/Discussion". This prevents others from adding to or modifying diff --git a/doc/pagespec.mdwn b/doc/pagespec.mdwn deleted file mode 100644 index 5c6433ed3..000000000 --- a/doc/pagespec.mdwn +++ /dev/null @@ -1,79 +0,0 @@ -To select a set of pages, such as pages that are locked, pages -whose commit emails you want subscribe to, or pages to combine into a -blog, the wiki uses a PageSpec. This is an expression that matches -a set of pages. - -The simplest PageSpec is a simple list of pages. For example, this matches -any of the three listed pages: - - foo or bar or baz - -More often you will want to match any pages that have a particular thing in -their name. You can do this using a glob pattern. "`*`" stands for any part -of a page name, and "`?`" for any single letter of a page name. So this -matches all pages about music, and any [[SubPage]]s of the SandBox, but does -not match the SandBox itself: - - *music* or SandBox/* - -You can also prefix an item with "`!`" to skip pages that match it. So to -match all pages except for Discussion pages and the SandBox: - - * and !SandBox and !*/Discussion - -Some more elaborate limits can be added to what matches using any of these -functions: - -* "`link(page)`" - match only pages that link to a given page (or glob) -* "`backlink(page)`" - match only pages that a given page links to -* "`creation_month(month)`" - match only pages created on the given month -* "`creation_day(mday)`" - or day of the month -* "`creation_year(year)`" - or year -* "`created_after(page)`" - match only pages created after the given page - was created -* "`created_before(page)`" - match only pages created before the given page - was created -* "`user(name)`" - only available in page subscription preferences, match - only changes made by this user - -For example, to match all pages in a blog that link to the page about music -and were written in 2005: - - blog/* and link(music) and creation_year(2005) - -Note the use of "and" in the above example, that means that only pages that -match each of the three expressions match the whole. Use "and" when you -want to combine expression like that; "or" when it's enough for a page to -match one expression. Note that it doesn't make sense to say "index and -SandBox", since no page can match both expressions. - -More complex expressions can also be created, by using parentheses for -grouping. For example, to match pages in a blog that are tagged with either -of two tags, use: - - blog/* and (link(tag/foo) or link(tag/bar)) - -Note that page names in PageSpecs are matched against the absolute -filenames of the pages in the wiki, so a pagespec "foo" used on page -"a/b" will not match a page named "a/foo" or "a/b/foo". To match -relative to the directory of the page containing the pagespec, you can -use "./". For example, "./foo" on page "a/b" matches page "a/foo". - -## Old syntax - -The old PageSpec syntax was called a "GlobList", and worked differently in -two ways: - -1. "and" and "or" were not used; any page matching any item from the list - matched. -2. If an item was prefixed with "`!`", then no page matching that item - matched, even if it matched an earlier list item. - -For example, here is the old way to match all pages except for the SandBox -and Discussion pages: - - * !SandBox !*/Discussion - -Using this old syntax is still supported. However, the old syntax is -deprecated and will be removed at some point, and using the new syntax is -recommended. diff --git a/doc/pagespec/discussion.mdwn b/doc/pagespec/discussion.mdwn deleted file mode 100644 index ab05e3e78..000000000 --- a/doc/pagespec/discussion.mdwn +++ /dev/null @@ -1,52 +0,0 @@ -I am using ikiwiki 2.6.1. - -I can't figure out the locked pages. - -As an admin in preferences, I put in my Locked Pages: - -index and downloads - -I don't want anyone to be able to edit the front page or my downloads page. - -That didn't work. I am using a different web browser as a different non-ikiwiki-admin user. - -So I changed it to - -/index and /downloads - -That stopped me from editing the front page. It didn't say it was locked just repeatedly gave me the ikiwiki login. (How can I get it to tell me it is locked instead?) - -I also tried - -/index and /downloads/index - -But I could still edit my downloads page. - -Can someone share some hints on how to lock these two pages? - -My source pages for the lock are: - -source/downloads.mdwn -source/index.mdwn - -My webpages to lock are: - -public\_html/downloads/index.html -public\_html/index.html - -> So I tried again with using "or" instead of "and": -> -> index or downloads -> -> And that worked. I now get a message saying it is locked and cannot be edited. -> To me saying "lock both 'index and downloads'" made sense while now it reads like: "lock either 'index or downloads'". Maybe the [[PageSpec]] should define "and" and "or" (beyond the examples it has). -> -> Also why did my "/index and /downloads" prevent editing the index by repeatedly showing login webpage? -> -> -JeremyReed - ->> I've clarified and/or in [[PageSpec]]. ->> ->> I can't reproduce "/index and /downloads" causing the login webpage to ->> be shown repeatedly. Sure you weren't having some independent issue with ->> logging in? --[[Joey]] diff --git a/doc/plugins/aggregate.mdwn b/doc/plugins/aggregate.mdwn index 398da4b5e..d224516df 100644 --- a/doc/plugins/aggregate.mdwn +++ b/doc/plugins/aggregate.mdwn @@ -12,8 +12,8 @@ That example aggregates posts from the specified RSS feed, updating no more frequently than once every 15 minutes, and puts a page per post under the example/ directory in the wiki. -You can then use ikiwiki's [[blog]] support to create a blog of one or more -aggregated feeds. +You can then use ikiwiki's [[ikiwiki/blog]] support to create a blog of one or +more aggregated feeds. ## setup diff --git a/doc/plugins/brokenlinks.mdwn b/doc/plugins/brokenlinks.mdwn index 69aa54086..23fa04d7c 100644 --- a/doc/plugins/brokenlinks.mdwn +++ b/doc/plugins/brokenlinks.mdwn @@ -5,8 +5,8 @@ This plugin generates a list of broken links on pages in the wiki. This is a useful way to find pages that still need to be written, or links that are written wrong. -The optional parameter "pages" can be a [[PageSpec]] specifying the pages -to search for broken links, default is search them all. +The optional parameter "pages" can be a [[ikiwiki/PageSpec]] specifying the +pages to search for broken links, default is search them all. If this plugin is turned on, here's a list of broken links on this wiki: diff --git a/doc/plugins/calendar.mdwn b/doc/plugins/calendar.mdwn index 99e2ab126..784e949a0 100644 --- a/doc/plugins/calendar.mdwn +++ b/doc/plugins/calendar.mdwn @@ -33,7 +33,7 @@ the given time frame. * `type` - Used to specify the type of calendar wanted. Can be one of "month" or "year". The default is a month view calendar. -* `pages` - Specifies the [[PageSpec]] of pages to link to from the +* `pages` - Specifies the [[ikiwiki/PageSpec]] of pages to link to from the month calendar. Defaults to "*". * `archivebase` - Configures the base of the archives hierarchy. The default is "archives". Note that this default can also be overridden diff --git a/doc/plugins/conditional.mdwn b/doc/plugins/conditional.mdwn index ba1cf9bb2..7a230fbae 100644 --- a/doc/plugins/conditional.mdwn +++ b/doc/plugins/conditional.mdwn @@ -15,17 +15,17 @@ The `then` and `else` values can include any markup that would be allowed in the wiki page outside the template. Triple-quoting the values even allows quotes to be included. -The `test` is a [[PageSpec]]; if it matches any page in the wiki then it -succeeds. So you can do things like testing for the existence of a page or -pages, testing to see if any pages were created in a given month, and so -on. +The `test` is a [[ikiwiki/PageSpec]]; if it matches any page in the wiki +then it succeeds. So you can do things like testing for the existence of a +page or pages, testing to see if any pages were created in a given month, +and so on. -If you want the [[PageSpec]] to only match against the page that +If you want the [[ikiwiki/PageSpec]] to only match against the page that contains the conditional, rather than matching against all pages in the wiki, set the "all" parameter to "no". -The regular [[PageSpec]] syntax is expanded with the following additional -tests: +The regular [[ikiwiki/PageSpec]] syntax is expanded with the following +additional tests: * enabled(plugin) diff --git a/doc/plugins/inline.mdwn b/doc/plugins/inline.mdwn index d0d4eb66a..fc6f9e8af 100644 --- a/doc/plugins/inline.mdwn +++ b/doc/plugins/inline.mdwn @@ -1,10 +1,10 @@ [[template id=plugin name=inline core=1 author="[[Joey]]"]] -This is a [[PreProcessorDirective]] that allows including one wiki page +This is a [[ikiwiki/PreProcessorDirective]] that allows including one wiki page inside another. For example: \[[inline pages="blog/*"]] The most common use of inlining is generating blogs and RSS or Atom feeds. -See [[blog]] for details. +See [[ikiwiki/blog]] for details. diff --git a/doc/plugins/linkmap.mdwn b/doc/plugins/linkmap.mdwn index e85f1bde6..6cd23b5cb 100644 --- a/doc/plugins/linkmap.mdwn +++ b/doc/plugins/linkmap.mdwn @@ -17,7 +17,7 @@ wiki a bit slow. Here are descriptions of all the supported parameters to the `linkmap` directive: -* `pages` - A [[PageSpec]] of the pages to map. +* `pages` - A [[ikiwiki/PageSpec]] of the pages to map. * `height`, `width` - Limit the size of the map to a given height and width, in inches. Both must be specified for the limiting to take effect, otherwise the map's size is not limited. diff --git a/doc/plugins/map.mdwn b/doc/plugins/map.mdwn index 7afc915d6..44ce9edd4 100644 --- a/doc/plugins/map.mdwn +++ b/doc/plugins/map.mdwn @@ -9,7 +9,7 @@ If the pages to include are not specified, all pages (and other files) in the wiki are mapped. Hint: To limit the map to displaying pages less than a certain level deep, -use a [[PageSpec]] like this: `pages="* and !*/*/*"` +use a [[ikiwiki/PageSpec]] like this: `pages="* and !*/*/*"` [[if test="enabled(map)" then=""" Here's an example map, for the plugins section of this wiki: diff --git a/doc/plugins/mdwn.mdwn b/doc/plugins/mdwn.mdwn index c4de0cff9..c7c0ac7ce 100644 --- a/doc/plugins/mdwn.mdwn +++ b/doc/plugins/mdwn.mdwn @@ -2,7 +2,7 @@ [[tag type/format]] This plugin lets ikwiki convert files with names ending in ".mdwn" to html. -It uses the [[markdown]] minimal markup language. +It uses the [[ikiwiki/markdown]] minimal markup language. This is the standard markup language used by ikiwiki, although some others are also available in other plugins. diff --git a/doc/plugins/orphans.mdwn b/doc/plugins/orphans.mdwn index f40a4a1b9..798a5c8c2 100644 --- a/doc/plugins/orphans.mdwn +++ b/doc/plugins/orphans.mdwn @@ -4,8 +4,8 @@ This plugin generates a list of possibly orphaned pages -- pages that no other page links to. -The optional parameter "pages" can be a [[PageSpec]] specifying the pages -to check for orphans, default is search them all. +The optional parameter "pages" can be a [[ikiwiki/PageSpec]] specifying the +pages to check for orphans, default is search them all. Note that it takes [[BackLinks]] into account, but does not count inlining a page as linking to it, so will generally count many blog-type pages as diff --git a/doc/plugins/pagecount.mdwn b/doc/plugins/pagecount.mdwn index 34b871262..9a9768277 100644 --- a/doc/plugins/pagecount.mdwn +++ b/doc/plugins/pagecount.mdwn @@ -1,11 +1,11 @@ [[template id=plugin name=pagecount author="[[Joey]]"]] [[tag type/meta]] -Provides a \\[[pagecount ]] [[PreProcessorDirective]] that is replaced with -the total number of pages currently in the wiki. +Provides a \\[[pagecount ]] [[ikiwiki/PreProcessorDirective]] that is +replaced with the total number of pages currently in the wiki. -The optional parameter "pages" can be a [[PageSpec]] specifying the pages -to count, default is to count them all. +The optional parameter "pages" can be a [[ikiwiki/PageSpec]] specifying the +pages to count, default is to count them all. This plugin is included in ikiwiki, but is not enabled by default. diff --git a/doc/plugins/postsparkline.mdwn b/doc/plugins/postsparkline.mdwn index d799f0a0c..d716022e1 100644 --- a/doc/plugins/postsparkline.mdwn +++ b/doc/plugins/postsparkline.mdwn @@ -21,8 +21,8 @@ options are passed on to the sparkline plugin. You don't need to specify any data points (though you can if you want to). Instead, data points are automatically generated based on the creation -times of pages matched by the specified `pages` [[PageSpec]]. A maximum of -`max` data points will be generated. +times of pages matched by the specified `pages` [[ikiwiki/PageSpec]]. A +maximum of `max` data points will be generated. The `formula` parameter controls the formula used to generate data points. Available forumlae: diff --git a/doc/plugins/rst.mdwn b/doc/plugins/rst.mdwn index 1f8073517..6a6606f20 100644 --- a/doc/plugins/rst.mdwn +++ b/doc/plugins/rst.mdwn @@ -11,7 +11,7 @@ ikiwiki. Limitations include: * There are issues with inserting raw html into documents, as ikiwiki does with [[WikiLinks|WikiLink]] and many - [[PreprocessorDirectives|PreprocessorDirective]]. + [[PreprocessorDirectives|ikiwiki/PreprocessorDirective]]. So while you may find this useful for importing old files into your wiki, using this as your main markup language in ikiwiki isn't recommended at diff --git a/doc/plugins/sidebar.mdwn b/doc/plugins/sidebar.mdwn index 7e0ad5cf6..fd792400e 100644 --- a/doc/plugins/sidebar.mdwn +++ b/doc/plugins/sidebar.mdwn @@ -6,13 +6,13 @@ The content of the sidebar is simply the content of a page named "sidebar" (ie, create a "sidebar.mdwn"). Typically this will be a page in the root of the wiki, but it can also be a -[[SubPage]]. In fact, this page, [[plugins/sidebar|plugins/sidebar]], will -be treated as a sidebar for the [[plugins]] page, and of all of its -SubPages, if the plugin is enabled. +[[ikiwiki/SubPage]]. In fact, this page, +[[plugins/sidebar|plugins/sidebar]], will be treated as a sidebar for the +[[plugins]] page, and of all of its SubPages, if the plugin is enabled. -Note that to disable a sidebar for a [[SubPage]] of a page that has a sidebar, -you can create a sidebar page that is completely empty. This will turn off -the sidebar altogether. +Note that to disable a sidebar for a [[ikiwiki/SubPage]] of a page that has +a sidebar, you can create a sidebar page that is completely empty. This +will turn off the sidebar altogether. Warning: Any change to the sidebar will cause a rebuild of the whole wiki, since every page includes a copy that has to be updates. This can diff --git a/doc/plugins/tag.mdwn b/doc/plugins/tag.mdwn index caffaa692..98990973b 100644 --- a/doc/plugins/tag.mdwn +++ b/doc/plugins/tag.mdwn @@ -6,7 +6,7 @@ This plugin allows tagging pages. List tags as follows: \[[tag tech life linux]] The tags work the same as if you had put a (hidden) [[WikiLink]] on the page -for each tag, so you can use a [[PageSpec]] match all pages that are +for each tag, so you can use a [[ikiwiki/PageSpec]] match all pages that are tagged with a given tag, for example. The tags will also show up on blog entries and at the bottom of the tagged pages, as well as in RSS and Atom feeds. diff --git a/doc/plugins/testpagespec.mdwn b/doc/plugins/testpagespec.mdwn index 3d35d70ad..9a13ab590 100644 --- a/doc/plugins/testpagespec.mdwn +++ b/doc/plugins/testpagespec.mdwn @@ -1,22 +1,23 @@ [[template id=plugin name=testpagespec author="[[Joey]]"]] [[tag type/useful]] -This plugin allows testing a [[PageSpec]] to see if it matches a page, and -to see the part that matches, or causes the match to fail. +This plugin allows testing a [[ikiwiki/PageSpec]] to see if it matches a +page, and to see the part that matches, or causes the match to fail. Example uses: \[[testpagespec pagespec="foopage and barpage" match="foopage"]] -This will print out something like "no match: barpage does not match foopage", -highlighting which part of the [[PageSpec]] is causing the match to fail. +This will print out something like "no match: barpage does not match +foopage", highlighting which part of the [[ikiwiki/PageSpec]] is causing +the match to fail. \[[testpagespec pagespec="foopage or !bar*" match="barpage"]] This will print out something like "no match: bar* matches barpage", since -the part of the [[PageSpec]] that fails is this negated match. +the part of the [[ikiwiki/PageSpec]] that fails is this negated match. \[[testpagespec pagespec="foopage or barpage" match="barpage"]] This will print out something like "match: barpage matches barpage", -indicating the part of the [[PageSpec]] that caused it to match. +indicating the part of the [[ikiwiki/PageSpec]] that caused it to match. diff --git a/doc/plugins/write.mdwn b/doc/plugins/write.mdwn index beaa25125..3ed0a3017 100644 --- a/doc/plugins/write.mdwn +++ b/doc/plugins/write.mdwn @@ -101,8 +101,8 @@ make arbitrary changes. The function is passed named parameters "page", ### preprocess -Adding a [[PreProcessorDirective]] is probably the most common use of a -plugin. +Adding a [[ikiwiki/PreProcessorDirective]] is probably the most common use +of a plugin. hook(type => "preprocess", id => "foo", call => \&preprocess); @@ -126,11 +126,11 @@ the hook modifies data in `%links`. Note that doing so will make the hook be run twice per page build, so avoid doing it for expensive hooks. Note that if the [[htmlscrubber]] is enabled, html in -[[PreProcessorDirective]] output is sanitised, which may limit what your -plugin can do. Also, the rest of the page content is not in html format at -preprocessor time. Text output by a preprocessor directive will be -linkified and passed through markdown (or whatever engine is used to htmlize -the page) along with the rest of the page. +[[ikiwiki/PreProcessorDirective]] output is sanitised, which may limit what +your plugin can do. Also, the rest of the page content is not in html +format at preprocessor time. Text output by a preprocessor directive will +be linkified and passed through markdown (or whatever engine is used to +htmlize the page) along with the rest of the page. ### htmlize @@ -351,9 +351,10 @@ cleanup. Note that while any plugin can use this for a fatal error, plugins should try to avoid dying on bad input, as that will halt the entire wiki build -and make the wiki unusable. So for example, if a [[PreProcessorDirective]] -is passed bad parameters, it's better to return an error message, which can -appear on the wiki page, rather than calling error(). +and make the wiki unusable. So for example, if a +[[ikiwiki/PreProcessorDirective]] is passed bad parameters, it's better to +return an error message, which can appear on the wiki page, rather than +calling error(). #### `template($;@)` @@ -368,12 +369,12 @@ page created from it. (Ie, it appends ".html".) #### `add_depends($$)` -Makes the specified page depend on the specified [[PageSpec]]. +Makes the specified page depend on the specified [[ikiwiki/PageSpec]]. #### `pagespec_match($$;@)` -Passed a page name, and [[PageSpec]], returns true if the [[PageSpec]] -matches the page. +Passed a page name, and [[ikiwiki/PageSpec]], returns true if the +[[ikiwiki/PageSpec]] matches the page. Additional named parameters can be passed, to further limit the match. The most often used is "location", which specifies the location the @@ -386,7 +387,7 @@ Given a page and the text of a link on the page, determine which existing page that link best points to. Prefers pages under a subdirectory with the same name as the source page, failing that goes down the directory tree to the base looking for matching -pages, as described in [[SubPage/LinkingRules]]. +pages, as described in [[ikiwiki/SubPage/LinkingRules]]. #### `htmllink($$$;@)` @@ -514,9 +515,9 @@ See [[RCS_details|rcs/details]] for some more info. ## PageSpec plugins It's also possible to write plugins that add new functions to -[[PageSpecs|PageSpec]]. Such a plugin should add a function to the +[[PageSpecs|ikiwiki/PageSpec]]. Such a plugin should add a function to the IkiWiki::PageSpec package, that is named `match_foo`, where "foo()" is -how it will be accessed in a [[PageSpec]]. The function will be passed +how it will be accessed in a [[ikiwiki/PageSpec]]. The function will be passed two parameters: The name of the page being matched, and the thing to match against. It may also be passed additional, named parameters. It should return a IkiWiki::SuccessReason object if the match succeeds, or an diff --git a/doc/plugins/write/tutorial.mdwn b/doc/plugins/write/tutorial.mdwn index b4705fe31..8c2e986b8 100644 --- a/doc/plugins/write/tutorial.mdwn +++ b/doc/plugins/write/tutorial.mdwn @@ -39,10 +39,10 @@ register hooks that ikiwiki will call later. } This has hooked our plugin into the preprocess hook, which ikiwiki uses to -expand [[PreprocessorDirectives|preprocessordirective]]. Notice that "fib" -has shown up again. It doesn't actually have to match the module name this -time, but it generally will. This "fib" is telling ikiwiki what kind of -PreprocessorDirective to handle, namely one that looks like this: +expand [[PreprocessorDirectives|ikiwiki/preprocessordirective]]. Notice +that "fib" has shown up again. It doesn't actually have to match the module +name this time, but it generally will. This "fib" is telling ikiwiki what +kind of PreprocessorDirective to handle, namely one that looks like this: [[fib ]] diff --git a/doc/preprocessordirective.mdwn b/doc/preprocessordirective.mdwn deleted file mode 100644 index 1e2332c09..000000000 --- a/doc/preprocessordirective.mdwn +++ /dev/null @@ -1,33 +0,0 @@ -Preprocessor directives are similar to a [[WikiLink]] in form, except they -contain spaces and parameters. The general form is: - - \[[directive param="value" param="value"]] - -This gets expanded before the rest of the page is processed, and can be used -to transform the page in various ways. - -The quotes around values can be omitted if the value is a simple word. -Also, some directives may use parameters without values, for example: - - \[[tag foo]] - -Note that if a preprocessor directive has no parameters, a space still must -be put after its name, to avoid confusion with a [[WikiLink]]. For example: - - \[[pagecount ]] - -A preprocessor directive does not need to all be on one line, it can be -wrapped to multiple lines if you like: - - \[[directive foo="baldersnatch" - bar="supercalifragalisticexpealadocious" baz=11]] - -Also, multiple lines of *quoted* text can be used for a value. -To allow quote marks inside the quoted text, delimit the block -of text with triple-quotes: - - \[[directive text=""" - 1. "foo" - 2. "bar" - 3. "baz" - """]] diff --git a/doc/sandbox.mdwn b/doc/sandbox.mdwn index aad60506a..d145d48f3 100644 --- a/doc/sandbox.mdwn +++ b/doc/sandbox.mdwn @@ -119,8 +119,8 @@ span also doesn't work: ---- -This sandbox is also a [[blog]]! +This sandbox is also a [[ikiwiki/blog]]! [[inline pages="sandbox/* and !*/Discussion" rootpage="sandbox" show="4" archive="yes"]] -[[blubb]] \ No newline at end of file +[[blubb]] diff --git a/doc/setup.mdwn b/doc/setup.mdwn index 39a3a174d..af1adc235 100644 --- a/doc/setup.mdwn +++ b/doc/setup.mdwn @@ -41,7 +41,7 @@ In the editor, you could start by entering a simple page like This wiki is powered by [ikiwiki](http://ikiwiki.info). """]] -See [[HelpOnFormatting]] for details about the markup language. +See [[ikiwiki/formatting]] for details about the markup language. Note that several [[standard_wiki_pages|basewiki]] will be added to your wiki, from files in `/usr/share/ikiwiki/basewiki/`, so your wiki will diff --git a/doc/shortcuts.mdwn b/doc/shortcuts.mdwn index 788408459..38215b627 100644 --- a/doc/shortcuts.mdwn +++ b/doc/shortcuts.mdwn @@ -57,13 +57,14 @@ This page controls what shortcut links the wiki supports. * [[shortcut name=zooomr url="http://www.zooomr.com/photos/%s"]] * Note: You have to include the username and number in here, such as `bob/123455`. -To add a new shortcut, use the `shortcut` [[PreprocessorDirective]]. "%s" is -replaced with the text passed to the named shortcut. The optional `desc` -parameter controls the description of the link. +To add a new shortcut, use the `shortcut` +[[ikiwiki/PreprocessorDirective]]. In the url, "%s" is replaced with the +text passed to the named shortcut. The optional `desc` parameter controls +the description of the link. Remember that the `name` you give the shortcut will become a new -[[PreprocessorDirective]]. Avoid using a `name` that conflicts with an -existing directive. +[[ikiwiki/PreprocessorDirective]]. Avoid using a `name` that conflicts +with an existing directive. If you come up with a shortcut that you think others might find useful, consider contributing it to the [[iki shortcuts]] page on the ikiwiki diff --git a/doc/subpage.mdwn b/doc/subpage.mdwn deleted file mode 100644 index 43669209c..000000000 --- a/doc/subpage.mdwn +++ /dev/null @@ -1,11 +0,0 @@ -ikiwiki supports placing pages in a directory hierarchy. For example, -this page, [[SubPage]] has some related pages placed under it, like -[[SubPage/LinkingRules]]. This is a useful way to add some order to your -wiki rather than just having a great big directory full of pages. - -To add a SubPage, just make a subdirectory and put pages in it. For -example, this page is SubPage.mdwn in this wiki's source, and there is also -a SubPage subdirectory, which contains SubPage/LinkingRules.mdwn. Subpages -can be nested as deeply as you'd like. - -Linking to and from a SubPage is explained in [[LinkingRules]]. diff --git a/doc/subpage/linkingrules.mdwn b/doc/subpage/linkingrules.mdwn deleted file mode 100644 index c1062304a..000000000 --- a/doc/subpage/linkingrules.mdwn +++ /dev/null @@ -1,32 +0,0 @@ -To link to or from a [[SubPage]], you can normally use a regular -[[WikiLink]] that does not contain the name of the parent directory of -the [[SubPage]]. Ikiwiki descends the directory hierarchy looking for a -page that matches your link. - -For example, if FooBar/SubPage links to "OtherPage", ikiwiki will first -prefer pointing the link to FooBar/SubPage/OtherPage if it exists, next -to FooBar/OtherPage and finally to OtherPage in the root of the wiki. - -Note that this means that if a link on FooBar/SomePage to "OtherPage" -currently links to OtherPage, in the root of the wiki, and FooBar/OtherPage -is created, the link will _change_ to point to FooBar/OtherPage. On the -other hand, a link from BazBar to "OtherPage" would be unchanged by this -creation of a [[SubPage]] of FooBar. - -You can also specify a link that contains a directory name, like -"FooBar/OtherPage" to more exactly specify what page to link to. This is -the only way to link to an unrelated [[SubPage]]. - -You can use this to, for example, to link from BazBar to "FooBar/SubPage", -or from BazBar/SubPage to "FooBar/SubPage". - -You can also use "/" at the start of a link, to specify exactly which page -to link to, when there are multiple pages with similar names and the link -goes to the wrong page by default. For example, linking from -"FooBar/SubPage" to "/OtherPage" will link to the "OtherPage" in the root -of the wiki, even if there is a "FooBar/OtherPage". - -Also, if the wiki is configured with a userdir, you can link to pages -within the userdir without specifying a path to them. This is to allow for -easy linking to a user's page in the userdir, to sign a comment. These -links are checked for last of all. diff --git a/doc/tags.mdwn b/doc/tags.mdwn index cd54fed36..f1a3f9f9b 100644 --- a/doc/tags.mdwn +++ b/doc/tags.mdwn @@ -1,6 +1,6 @@ While ikiwiki supports hierarchically categorising pages by creating -[[SubPage]]s, that's often not flexible enough, and it can also be useful -to tag pages in various non-hierarchical ways. +[[SubPages|ikiwiki/SubPage]], that's often not flexible enough, and it can also be +useful to tag pages in various non-hierarchical ways. Since this is a wiki, tagging is just a form of linking. The general rule is that all tags are links, but not all links are tags. So a tag is a @@ -17,7 +17,7 @@ You can also tag a page with a visible link: This tag will be displayed just like a regular [[WikiLink]]. -One way to use these tags is to create a [[blog]] of pages that have a +One way to use these tags is to create a [[ikiwiki/blog]] of pages that have a particular set of tags. Or just look at the [[BackLinks]] to a tag page to see all the pages that are tagged with it. [[Plugins]] can be written to do anything else with tags that you might desire. diff --git a/doc/tips/howto_avoid_flooding_aggregators.mdwn b/doc/tips/howto_avoid_flooding_aggregators.mdwn index 4e2b2ac16..570baa5cc 100644 --- a/doc/tips/howto_avoid_flooding_aggregators.mdwn +++ b/doc/tips/howto_avoid_flooding_aggregators.mdwn @@ -1,4 +1,4 @@ -If you have a [[blog]] that is aggregated, either on a site like Planet +If you have a [[ikiwiki/blog]] that is aggregated, either on a site like Planet Debian, or just through user subscriptions, one common problem is that changes to the guids of items in the blog can "flood" the aggregator, causing all recent blog entries to be posted to the top of it. diff --git a/doc/todo/absolute_urls_in_wikilinks.mdwn b/doc/todo/absolute_urls_in_wikilinks.mdwn index ad6e5ff5c..50c2fe16f 100644 --- a/doc/todo/absolute_urls_in_wikilinks.mdwn +++ b/doc/todo/absolute_urls_in_wikilinks.mdwn @@ -5,7 +5,7 @@ for pages included into other pages out of the wiki rendering process (shtml for since these pages can be included from a subdir. Ditto, links from \[[ inline ..]] or \[[map ..]]. > You can make a wikilink absolute by prefixing it with a /, see -> [[subpage/linkingrules/]]. Pagespecs match absolute by default. But what do +> [[ikiwiki/subpage/linkingrules/]]. Pagespecs match absolute by default. But what do > you mean "included from a subdir"? If you inline a page, its links shouldn't > change. --Ethan diff --git a/doc/todo/automatic_use_of_syntax_plugin_on_source_code_files.mdwn b/doc/todo/automatic_use_of_syntax_plugin_on_source_code_files.mdwn index 869d479c1..c39261e82 100644 --- a/doc/todo/automatic_use_of_syntax_plugin_on_source_code_files.mdwn +++ b/doc/todo/automatic_use_of_syntax_plugin_on_source_code_files.mdwn @@ -1,3 +1,10 @@ -[[Wishlist]]: optionally use the [[plugins/contrib/syntax]] plugin automatically on source code files in the repository with recognized extensions or shebangs, and render them as though they consisted of an [[.mdwn|markdown]] page containing nothing but a single call to the syntax plugin with the file contents as the text argument and the recognized type as the type argument. +[[Wishlist]]: optionally use the [[plugins/contrib/syntax]] plugin +automatically on source code files in the repository with recognized +extensions or shebangs, and render them as though they consisted of an +[[.mdwn|ikiwiki/markdown]] page containing nothing but a single call to the syntax +plugin with the file contents as the text argument and the recognized type +as the type argument. -Together with the ability to have [[wiki-formatted_comments|wiki-formatted_comments_with_syntax_plugin]], this would allow the use of ikiwiki for [[wikipedia literate programming]]. +Together with the ability to have +[[wiki-formatted_comments|wiki-formatted_comments_with_syntax_plugin]], +this would allow the use of ikiwiki for [[wikipedia literate programming]]. diff --git a/doc/todo/basewiki_should_be_self_documenting.mdwn b/doc/todo/basewiki_should_be_self_documenting.mdwn index d467f2f0b..7dc767e76 100644 --- a/doc/todo/basewiki_should_be_self_documenting.mdwn +++ b/doc/todo/basewiki_should_be_self_documenting.mdwn @@ -1,5 +1,5 @@ The pages in the basewiki should be fully self-documenting as far as what -users need to know to edit pages in the wiki. [[HelpOnFormatting]] +users need to know to edit pages in the wiki. [[ikiwiki/Formatting]] documents the basics, but doesn't include every preprocessor directive. Note that there's a disctinction between being self-documenting for users, @@ -28,33 +28,4 @@ basewiki: Meta is another one. -The holdup on documenting these in full in the basewiki is that I'm not sure -where to put the docs. [[HelpOnFormatting]] should stay as simple as possible -and just give examples, not full lists of availavle parameters, etc. And -it's bad enough that [[blog]] uses that toplevel namespace, without adding -lots more toplevel pages to the basewiki. ([[blog]] really needs to be moved.. -I have several wikis that override it with their actual blog content). - -Maybe the thing to do would be to make a meta/ or usage/ or wiki/ or something -directory in the basewiki, and put new pages documenting how to use preprocesor -directives in there. - -Actually, if we look at the basewiki contents: - - blog.mdwn@ pagespec.mdwn@ subpage@ - favicon.ico@ preprocessordirective.mdwn@ subpage.mdwn@ - helponformatting.mdwn@ sandbox.mdwn@ templates/ - index.mdwn@ shortcuts.mdwn@ templates.mdwn@ - local.css@ smileys@ wikiicons@ - markdown.mdwn@ smileys.mdwn@ wikilink.mdwn@ - openid.mdwn@ style.css@ - -Most of this is meta stuff. Only index.mdwn, local.css, favicon.ico, -smileys, wikiicons, shortcuts, and templates are really content/configs that -are used as the base of a wiki. The rest is documentation. - -Moving a lot of these pages could be hard though.. Lots of wikis probably -link to them. Maybe the directory they're moved to could be in the search -path, like the userdir is, so that simple links keep working. - See also: [[Conditional_Underlay_Files]] diff --git a/doc/todo/conditional_text_based_on_ikiwiki_features.mdwn b/doc/todo/conditional_text_based_on_ikiwiki_features.mdwn index 2ace6a7ef..e5e23531e 100644 --- a/doc/todo/conditional_text_based_on_ikiwiki_features.mdwn +++ b/doc/todo/conditional_text_based_on_ikiwiki_features.mdwn @@ -1,6 +1,6 @@ I'd like to see some way to conditionally include wiki text based on whether the wiki enables or disables certain features. For example, -[[helponformatting]], could use `\[[if (enabled smiley) """Also, because +[[ikiwiki/formatting]], could use `\[[if (enabled smiley) """Also, because this wiki has the smiley plugin enabled, you can insert \[[smileys]] and some other useful symbols."""]]`, and a standard template for [[plugins]] pages could check for the given plugin name to print "enabled" or @@ -10,9 +10,9 @@ Some potentially useful conditionals: * `enabled pluginname` * `disabled pluginname` -* `any pagespec`: true if any of the pages in the [[PageSpec]] exist -* `all pagespec`: true if all of the pages in the [[PageSpec]] exist -* `no pagespec` or `none pagespec`: true if none of the pages in the [[PageSpec]] exist +* `any pagespec`: true if any of the pages in the [[ikiwiki/PageSpec]] exist +* `all pagespec`: true if all of the pages in the [[ikiwiki/PageSpec]] exist +* `no pagespec` or `none pagespec`: true if none of the pages in the [[ikiwiki/PageSpec]] exist * `thispage pagespec`: true if pagespec includes the page getting rendered (possibly one including the page with this content on it). * `sourcepage pagespec`: true if pagespec includes the page corresponding to the file actually containing this content, rather than a page including it. * `included`: true if included on another page, via [[plugins/inline]], [[plugins/sidebar]], [[plugins/contrib/navbar]], etc. @@ -24,8 +24,8 @@ keep the aliases for simplicity anyway). You also may or may not want to include an `else` clause; if so, you could label the text used if true as `then`. -Syntax could vary greatly here, both for the [[PreprocessorDirective]] and -for the condition itself. +Syntax could vary greatly here, both for the +[[ikiwiki/PreprocessorDirective]] and for the condition itself. > I think this is a good thing to consider, although conditionals tend to > make everything a lot more complicated, so I also want to KISS, and not @@ -56,10 +56,10 @@ for the condition itself. > > --[[Joey]] ->> [[PageSpec]] syntax seems perfect, and your proposed syntax for the `if` ->> [[PreprocessorDirective]] looks fine to me. +>> [[ikiwiki/PageSpec]] syntax seems perfect, and your proposed syntax for the `if` +>> [[ikiwiki/PreprocessorDirective]] looks fine to me. >> ->> [[PageSpec]]s don't give you `none` for free, since `!foo/*` as a boolean +>> [[ikiwiki/PageSpec]]s don't give you `none` for free, since `!foo/*` as a boolean >> would mean "does any page not matching `foo/*` exist", not "does `foo/*` >> match nothing"; however, I don't really care much about `none`, since I >> just threw it in while brainstorming, and I don't know any compelling use @@ -75,7 +75,7 @@ for the condition itself. >> pages."""]]. The help text would then only appear on the sidebar page >> itself, not the sidebar included on all pages. >> ->> * On [[blog]] entries, you could use `included` to implement a cut. +>> * On [[ikiwiki/blog]] entries, you could use `included` to implement a cut. >> (Please don't take that as an argument against. :) ) For instance, you >> could use included rather than [[plugins/toggle]] for the detailed >> changelogs of ikiwiki, or to embed an image as a link in the feed rather @@ -105,4 +105,4 @@ This is now completely [[todo/done]]! See [[plugins/conditional]]. --[[Joey]] -> You rock mightily. --[[JoshTriplett]] \ No newline at end of file +> You rock mightily. --[[JoshTriplett]] diff --git a/doc/todo/datearchives-plugin.mdwn b/doc/todo/datearchives-plugin.mdwn index 8c3faf9ca..4264b5895 100644 --- a/doc/todo/datearchives-plugin.mdwn +++ b/doc/todo/datearchives-plugin.mdwn @@ -42,7 +42,9 @@ Index: IkiWiki/Plugin/datearchives.pm +1 -This works (although accessing `%IkiWiki::pagectime` is not too clever), but it would be far more useful if the date pages were automatically created and populated with the relevant posts. A [[Pagespec]] works perfectly for displaying the relevant content, but we're still left with the issue of actually creating the page. What's the Right Way to do this? We could create them in the RCS working copy and check them in, or create them directly in the output directory... (I'd also like to create an option for the tags plugin to auto-create its targets in the same way). Any opinions? :-) +This works (although accessing `%IkiWiki::pagectime` is not too clever), +but it would be far more useful if the date pages were automatically +created and populated with the relevant posts. A [[ikiwiki/Pagespec]] works perfectly for displaying the relevant content, but we're still left with the issue of actually creating the page. What's the Right Way to do this? We could create them in the RCS working copy and check them in, or create them directly in the output directory... (I'd also like to create an option for the tags plugin to auto-create its targets in the same way). Any opinions? :-) > Ok, first, I don't understand what your plugin does. Maybe I need to get > some sleep, but a better explanation might help. :-) It seems to make diff --git a/doc/todo/discuss_without_login.mdwn b/doc/todo/discuss_without_login.mdwn index 74f3cde70..82311459d 100644 --- a/doc/todo/discuss_without_login.mdwn +++ b/doc/todo/discuss_without_login.mdwn @@ -5,7 +5,7 @@ Any plugin or option for allowing website visitors to edit the discuss page with Or any plugin to add a feedback form (and maybe threads) to extend a Wiki webpage? Or is there per-page access control that can be fine-tuned to lock some users or groups for specific pages? -(The [[pagespec]] does show a way to lock all pages except for Discussion pages, but I want some users to also be able to edit other pages.) +(The [[ikiwiki/pagespec]] does show a way to lock all pages except for Discussion pages, but I want some users to also be able to edit other pages.) I want a way for website visitors to be able to give feedback on the wiki pages without having to sign up or log in. I don't want them to be able to edit the exiting wiki pages except maybe Discussion page. diff --git a/doc/todo/format_escape.mdwn b/doc/todo/format_escape.mdwn index 7c9a7f1ec..0f5859b3e 100644 --- a/doc/todo/format_escape.mdwn +++ b/doc/todo/format_escape.mdwn @@ -219,7 +219,7 @@ Index: doc/plugins/rst.mdwn -* reStructuredText does not allow raw html to be inserted into - documents, but ikiwiki does so in many cases, including - [[WikiLinks|WikiLink]] and many -- [[PreprocessorDirectives|PreprocessorDirective]]. +- [[PreprocessorDirectives|ikiwiki/PreprocessorDirective]]. +* Some bits of ikiwiki may still assume that markdown is used or embed html + in ways that break reStructuredText. (Report bugs if you find any.) * It's slow; it forks a copy of python for each page. While there is a diff --git a/doc/todo/graphviz.mdwn b/doc/todo/graphviz.mdwn index 31d5787ae..c55a4aa23 100644 --- a/doc/todo/graphviz.mdwn +++ b/doc/todo/graphviz.mdwn @@ -1,4 +1,12 @@ -How about a plugin providing a [[preprocessor_directive|preprocessordirective]] to render a [[debpkg graphviz]] file as an image via one of the graphviz programs ("dot" by default) and include the resulting image on the page, using the "cmapx" image map format? graphviz files themselves could also render the same way into an HTML file with the same basename as the graphviz file; format and program could come either from an ikiwiki configuration option or comments/directives in the file. (For example, "digraph" could imply "dot", and "graph" could imply "neato".) +How about a plugin providing a +[[preprocessor_directive|ikiwiki/preprocessordirective]] to render a +[[debpkg graphviz]] file as an image via one of the graphviz programs +("dot" by default) and include the resulting image on the page, using the +"cmapx" image map format? graphviz files themselves could also render the +same way into an HTML file with the same basename as the graphviz file; +format and program could come either from an ikiwiki configuration option +or comments/directives in the file. (For example, "digraph" could imply +"dot", and "graph" could imply "neato".) To complement this, ikiwiki could support creating and editing graphviz files through the CGI interface, as a new page type; preview could render the file. It would also help to have some sort of graphviz extension attribute for linking to a wiki page, which would become a standard href or URL attribute in the input passed to the particular graphviz program. diff --git a/doc/todo/htmlvalidation.mdwn b/doc/todo/htmlvalidation.mdwn index 6fe2d56f2..96bcd926b 100644 --- a/doc/todo/htmlvalidation.mdwn +++ b/doc/todo/htmlvalidation.mdwn @@ -32,7 +32,7 @@ Ah didn't realize you meant it fixed it at the markdown level. I'll think about making postprocessordirectives into - [[preprocessordirective]]s instead, then I could use that fix (but I'm not + [[ikiwiki/preprocessordirective]]s instead, then I could use that fix (but I'm not sure how feasible it is to do that). --[[Joey]] Done.. inlining is now a preprocessor directive, happens before diff --git a/doc/todo/latex.mdwn b/doc/todo/latex.mdwn index 8822bd30b..01d927552 100644 --- a/doc/todo/latex.mdwn +++ b/doc/todo/latex.mdwn @@ -1,5 +1,5 @@ How about a plugin adding a -[[preprocessor_directive|preprocessordirective]] to render some given LaTeX +[[preprocessor_directive|ikiwiki/preprocessordirective]] to render some given LaTeX and include it in the page? This could either render the LaTeX as a PNG via [[debpkg dvipng]] and include the resulting image in the page, or perhaps render via [HeVeA](http://pauillac.inria.fr/~maranget/hevea/index.html), diff --git a/doc/todo/linktitle.mdwn b/doc/todo/linktitle.mdwn index 8f424fd30..8d6ce3c1f 100644 --- a/doc/todo/linktitle.mdwn +++ b/doc/todo/linktitle.mdwn @@ -1,19 +1,19 @@ Pages could have a `linktitle` (perhaps via [[plugins/meta]]), and [[wikilinks|wikilink]] could use that title by default when linking to the -page. That would allow pages to have a simple, easily linkable name (without -spaces, for instance), but use the proper title for links. For example, -[[PreprocessorDirective]] could use the `linktitle` "preprocessor directive", -and pages for [[users]] could have `linktitle`s that put spaces in their -names. +page. That would allow pages to have a simple, easily linkable name +(without spaces, for instance), but use the proper title for links. For +example, [[ikiwiki/PreprocessorDirective]] could use the `linktitle` +"preprocessor directive", and pages for [[users]] could have `linktitle`s +that put spaces in their names. -Ideally, perhaps two versions of the title could exist, one for general use, -and an optional one for if the case in the actual link starts with an -uppercase letter. That would allow [[preprocessordirective]] to use the link -text "preprocessor directive", but [[PreprocessorDirective]] to use the link -text "Preprocessor Directive", for use at the beginnings of sentences. If the -second version did not exist, the first version would apply to both cases. -However, that also seems like potential overkill, and less important than the -basic functionality of `linktitle`. ---[[JoshTriplett]] +Ideally, perhaps two versions of the title could exist, one for general +use, and an optional one for if the case in the actual link starts with an +uppercase letter. That would allow [[ikiwiki/preprocessordirective]] to +use the link text "preprocessor directive", but +[[ikiwiki/PreprocessorDirective]] to use the link text "Preprocessor +Directive", for use at the beginnings of sentences. If the second version +did not exist, the first version would apply to both cases. However, that +also seems like potential overkill, and less important than the basic +functionality of `linktitle`. --[[JoshTriplett]] [[wishlist]] diff --git a/doc/todo/preprocessor_directive_for_proposed_changes.mdwn b/doc/todo/preprocessor_directive_for_proposed_changes.mdwn index b8577c233..e73e6c09e 100644 --- a/doc/todo/preprocessor_directive_for_proposed_changes.mdwn +++ b/doc/todo/preprocessor_directive_for_proposed_changes.mdwn @@ -7,7 +7,7 @@ which can't be made through the web interface: Of course in these cases, you can add your request to a discussion page and wait for someone with the access/confidence to apply them. -Maybe this can be enhanced with a [[PreprocessorDirective]]: +Maybe this can be enhanced with a [[ikiwiki/PreprocessorDirective]]:
 \[[suggest op=merge dstfile=trunk srcfile=branches/jk oldrev=1234 newrev=1342]]
diff --git a/doc/todo/review_mechanism.mdwn b/doc/todo/review_mechanism.mdwn
index 03c0fa749..5e4ba212e 100644
--- a/doc/todo/review_mechanism.mdwn
+++ b/doc/todo/review_mechanism.mdwn
@@ -15,7 +15,7 @@ This would be done in a way that would trigger the appropriate VCS merge operati
 A generic "change queue" mechanism could be used for translations or other stuff as well.
 Each change would have its own wiki page under changes/revNNNN.
 Change queues would be wiki pages as well (probably using [[inlines|plugins/inline]]);
-[[Pagespecs|Pagespec]] and [[tags]] would be used to control the queues to which a given change would belong.
+[[Pagespecs|ikiwiki/Pagespec]] and [[tags]] would be used to control the queues to which a given change would belong.
 
 --[[JeremieKoenig]]
 
diff --git a/doc/todo/rss_title_description.mdwn b/doc/todo/rss_title_description.mdwn
index cb71a0f1b..3f56a10e0 100644
--- a/doc/todo/rss_title_description.mdwn
+++ b/doc/todo/rss_title_description.mdwn
@@ -18,7 +18,7 @@ A few pointers and I might be able to implement this myself. -- JamesWestby
 > Now, the description field currently defaults to the wiki name,
 > and that could indeed stand to be made configurable. Since the
 > current (svn) version of ikiwiki supports long, word-wrapped
-> blocks of text as parameters to [[PreProcessorDirective]]s, seems
+> blocks of text as parameters to [[ikiwiki/PreProcessorDirective]]s, seems
 > to me the best way would be to simple modify inline.pm to make the
 > descripion configurable by such parameter, with a fallback to the
 > wiki name. You'll need to modify rsspage.tmpl to use whatever new
diff --git a/doc/todo/shortcut_link_text.mdwn b/doc/todo/shortcut_link_text.mdwn
index 6842a911f..d03d37411 100644
--- a/doc/todo/shortcut_link_text.mdwn
+++ b/doc/todo/shortcut_link_text.mdwn
@@ -1,4 +1,4 @@
-[[plugins/shortcut]] creates link shortcut [[PreprocessorDirective]]s,
+[[plugins/shortcut]] creates link shortcut [[ikiwiki/PreprocessorDirective]]s,
 which substitute their argument into the specified shortcut URL to generate
 the link target, and use the argument as the link text.  For example, given
 the example [[shortcuts]], `\[[wikipedia ikiwiki]]` generates a link to
diff --git a/doc/todo/smileys_do_not_work_in_PreprocessorDirective_arguments.mdwn b/doc/todo/smileys_do_not_work_in_PreprocessorDirective_arguments.mdwn
index dabc58dee..a55a66141 100644
--- a/doc/todo/smileys_do_not_work_in_PreprocessorDirective_arguments.mdwn
+++ b/doc/todo/smileys_do_not_work_in_PreprocessorDirective_arguments.mdwn
@@ -1,11 +1,11 @@
-Several [[PreprocessorDirective]]s take ikiwiki-formatted text as arguments,
+Several [[ikiwiki/PreprocessorDirective]]s take ikiwiki-formatted text as arguments,
 such as the `then` and `else` arguments of the new `if` directive, or the
 `desc` argument of the `shortcut` directive.  However, smileys do not work in
 these arguments.
 
-Since the arguments to [[PreprocessorDirective]]s might use the same syntax as
+Since the arguments to [[ikiwiki/PreprocessorDirective]]s might use the same syntax as
 smileys for a different meaning, smiley substitution should not happen until
-after [[PreprocessorDirective]]s.
+after [[ikiwiki/PreprocessorDirective]]s.
 
 --[[JoshTriplett]]
 
diff --git a/doc/usage.mdwn b/doc/usage.mdwn
index 76e293ddc..836dda127 100644
--- a/doc/usage.mdwn
+++ b/doc/usage.mdwn
@@ -11,7 +11,7 @@ ikiwiki --setup configfile
 # DESCRIPTION
 
 `ikiwiki` is a wiki compiler. It builds static HTML pages for a wiki, from
-`source` in the [[Markdown]] language (or others), and writes it out to
+`source` in the [[ikiwiki/Markdown]] language (or others), and writes it out to
 `destination`.
 
 Note that most options can be shortened to single letters, and boolean
@@ -166,12 +166,12 @@ configuration options of their own.
 * --rss, --norss
 
   If rss is set, ikiwiki will generate RSS feeds for pages that inline
-  a [[blog]].
+  a [[ikiwiki/blog]].
 
 * --atom, --noatom
 
   If atom is set, ikiwiki will generate Atom feeds for pages that inline
-  a [[blog]].
+  a [[ikiwiki/blog]].
 
 * --pingurl URL
 
diff --git a/doc/wikilink.mdwn b/doc/wikilink.mdwn
deleted file mode 100644
index 38df00f86..000000000
--- a/doc/wikilink.mdwn
+++ /dev/null
@@ -1,27 +0,0 @@
-WikiLinks provide easy linking between pages of the wiki. To create a
-[[WikiLink]], just put the name of the page to link to in double brackets.
-For example `\[[WikiLink]]`.
-
-If you ever need to write something like `\[[WikiLink]]` without creating a
-wikilink, just prefix it with a `\`, like `\\[[WikiLink]]`.
-
-There are some special [[SubPage/LinkingRules]] that come into play when
-linking between [[SubPages|SubPage]].
-
-Also, if the file linked to by a WikiLink looks like an image, it will
-be displayed inline on the page.
-
-WikiLinks are matched with page names in a case-insensitive manner, so you
-don't need to worry about getting the case the same, and can capitalise
-links at the start of a sentence, and so on.
-
-It's also possible to write a WikiLink that uses something other than the page
-name as the link text. For example `\[[foo_bar|SandBox]]` links to the SandBox
-page, but the link will appear like this: [[foo_bar|SandBox]].
-
-To link to an anchor inside a page, you can use something like
-`\[[WikiLink#foo]]`
-
-**Note that you cannot use spaces in WikiLinks**. Replace spaces with
-underscores. The presence of spaces is used to distinguish between a
-[[PreprocessorDirective]] and a WikiLink.
diff --git a/doc/wikilink/discussion.mdwn b/doc/wikilink/discussion.mdwn
deleted file mode 100644
index d81163670..000000000
--- a/doc/wikilink/discussion.mdwn
+++ /dev/null
@@ -1,29 +0,0 @@
-# Creating an anchor in Markdown
-
-Is it a native Markdown "tag" for creating an anchor? Unfortunately,
-I haven't any information about it at
-[Markdown syntax](http://daringfireball.net/projects/markdown/syntax) page.
-
-Of course, I know that I can use HTML tag to do it,
-for example <a name="foo" />, but I don't want to mix Markdown
-and HTML code if it's not necessary.
-
-BTW, ikiwiki doesn't displays the #foo anchor in the example
-("To link to an anchor inside a page...") at [[WikiLink]] page...
-
---[[Paweł|ptecza]]
-
-> No such syntax exists in markdown.  ikiwiki could certainly have a
-> [[preprocessor_directive|preprocessordirective]] for it, though.
->
-> The lack of the `#foo` anchor in the anchor example on [[wikilink]]
-> definitely looks like a bug.  --[[JoshTriplett]]
-
->> Fixed that --[[Joey]]
-
----
-
-Considering a hierarchy like `foo/bar/bar`, I had the need to link from the
-`foo/bar/bar` page to the `foo/bar` one.  It would have been convenient to
-simply write [[wikilink]]s like `\[[../bar]]` (or even just `\[[..]]`?), but
-this doesn't work, so I had to resort to using `\[[foo/bar]]` instead.
diff --git a/doc/wikitemplates.mdwn b/doc/wikitemplates.mdwn
index 4fc163599..1beed649b 100644
--- a/doc/wikitemplates.mdwn
+++ b/doc/wikitemplates.mdwn
@@ -17,9 +17,9 @@ located in /usr/share/ikiwiki/templates by default.
   changes to a page.
 * `passwordmail.tmpl` - Not a html template, this is used to
   generate the mail with the user's password in it.
-* `rsspage.tmpl` - Used for generating rss feeds for [[blog]]s.
+* `rsspage.tmpl` - Used for generating rss feeds for [blogs|[ikiwiki/blog]].
 * `rssitem.tmpl` - Used for generating individual items on rss feeds.
-* `atompage.tmpl` - Used for generating atom feeds for [[blog]]s.
+* `atompage.tmpl` - Used for generating atom feeds for blogs.
 * `atomitem.tmpl` - Used for generating individual items on atom feeds.
 * `inlinepage.tmpl` - Used for adding a page inline in a blog
   page.
diff --git a/po/ikiwiki.pot b/po/ikiwiki.pot
index d8cdc9d2b..682928a99 100644
--- a/po/ikiwiki.pot
+++ b/po/ikiwiki.pot
@@ -8,7 +8,7 @@ msgid ""
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2007-12-08 15:22-0500\n"
+"POT-Creation-Date: 2007-12-08 15:44-0500\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME \n"
 "Language-Team: LANGUAGE \n"
@@ -41,29 +41,29 @@ msgstr ""
 msgid "%s is not an editable page"
 msgstr ""
 
-#: ../IkiWiki/CGI.pm:441 ../IkiWiki/Plugin/brokenlinks.pm:24
+#: ../IkiWiki/CGI.pm:443 ../IkiWiki/Plugin/brokenlinks.pm:24
 #: ../IkiWiki/Plugin/inline.pm:230 ../IkiWiki/Plugin/opendiscussion.pm:17
 #: ../IkiWiki/Plugin/orphans.pm:28 ../IkiWiki/Render.pm:99
 #: ../IkiWiki/Render.pm:179
 msgid "discussion"
 msgstr ""
 
-#: ../IkiWiki/CGI.pm:487
+#: ../IkiWiki/CGI.pm:489
 #, perl-format
 msgid "creating %s"
 msgstr ""
 
-#: ../IkiWiki/CGI.pm:505 ../IkiWiki/CGI.pm:524 ../IkiWiki/CGI.pm:534
-#: ../IkiWiki/CGI.pm:567 ../IkiWiki/CGI.pm:615
+#: ../IkiWiki/CGI.pm:507 ../IkiWiki/CGI.pm:526 ../IkiWiki/CGI.pm:536
+#: ../IkiWiki/CGI.pm:569 ../IkiWiki/CGI.pm:617
 #, perl-format
 msgid "editing %s"
 msgstr ""
 
-#: ../IkiWiki/CGI.pm:709
+#: ../IkiWiki/CGI.pm:711
 msgid "You are banned."
 msgstr ""
 
-#: ../IkiWiki/CGI.pm:729
+#: ../IkiWiki/CGI.pm:731
 msgid "login failed, perhaps you need to turn on cookies?"
 msgstr ""
 
diff --git a/underlays/basewiki/blog.mdwn b/underlays/basewiki/blog.mdwn
deleted file mode 120000
index 9ab431078..000000000
--- a/underlays/basewiki/blog.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/blog.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/blog.mdwn b/underlays/basewiki/blog.mdwn
new file mode 100644
index 000000000..b4f171c97
--- /dev/null
+++ b/underlays/basewiki/blog.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/blog delay=10]]
+
+This page has moved to [[ikiwiki/blog|ikiwiki/blog]]. Please update your
+links, as this redirection page will be removed in a future ikiwiki
+release.
diff --git a/underlays/basewiki/helponformatting.mdwn b/underlays/basewiki/helponformatting.mdwn
deleted file mode 120000
index 6d0d82f71..000000000
--- a/underlays/basewiki/helponformatting.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/helponformatting.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/helponformatting.mdwn b/underlays/basewiki/helponformatting.mdwn
new file mode 100644
index 000000000..ca8e91908
--- /dev/null
+++ b/underlays/basewiki/helponformatting.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/formatting delay=10]]
+
+This page has moved to [[ikiwiki/formatting|ikiwiki/formatting]]. Please
+update your links, as this redirection page will be removed in a future
+ikiwiki release.
diff --git a/underlays/basewiki/ikiwiki/blog.mdwn b/underlays/basewiki/ikiwiki/blog.mdwn
new file mode 120000
index 000000000..7735e9853
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/blog.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/blog.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/formatting.mdwn b/underlays/basewiki/ikiwiki/formatting.mdwn
new file mode 120000
index 000000000..cf9d704c6
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/formatting.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/formatting.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/markdown.mdwn b/underlays/basewiki/ikiwiki/markdown.mdwn
new file mode 120000
index 000000000..7e7417010
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/markdown.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/markdown.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/openid.mdwn b/underlays/basewiki/ikiwiki/openid.mdwn
new file mode 120000
index 000000000..f4644f74d
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/openid.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/openid.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/pagespec.mdwn b/underlays/basewiki/ikiwiki/pagespec.mdwn
new file mode 120000
index 000000000..0d7bba269
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/pagespec.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/pagespec.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/preprocessordirective.mdwn b/underlays/basewiki/ikiwiki/preprocessordirective.mdwn
new file mode 120000
index 000000000..3ccd8c8b3
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/preprocessordirective.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/preprocessordirective.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/subpage b/underlays/basewiki/ikiwiki/subpage
new file mode 120000
index 000000000..dc1833550
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/subpage
@@ -0,0 +1 @@
+../../../doc/ikiwiki/subpage
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/subpage.mdwn b/underlays/basewiki/ikiwiki/subpage.mdwn
new file mode 120000
index 000000000..f1109f251
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/subpage.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/subpage.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/ikiwiki/wikilink.mdwn b/underlays/basewiki/ikiwiki/wikilink.mdwn
new file mode 120000
index 000000000..0fb5cc3f2
--- /dev/null
+++ b/underlays/basewiki/ikiwiki/wikilink.mdwn
@@ -0,0 +1 @@
+../../../doc/ikiwiki/wikilink.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/markdown.mdwn b/underlays/basewiki/markdown.mdwn
deleted file mode 120000
index 7b555fd91..000000000
--- a/underlays/basewiki/markdown.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/markdown.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/markdown.mdwn b/underlays/basewiki/markdown.mdwn
new file mode 100644
index 000000000..96eba217c
--- /dev/null
+++ b/underlays/basewiki/markdown.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/markdown delay=10]]
+
+This page has moved to [[ikiwiki/markdown|ikiwiki/markdown]]. Please update
+your links, as this redirection page will be removed in a future ikiwiki
+release.
diff --git a/underlays/basewiki/openid.mdwn b/underlays/basewiki/openid.mdwn
deleted file mode 120000
index f2d584b4c..000000000
--- a/underlays/basewiki/openid.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/openid.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/openid.mdwn b/underlays/basewiki/openid.mdwn
new file mode 100644
index 000000000..26496fe1a
--- /dev/null
+++ b/underlays/basewiki/openid.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/openid delay=10]]
+
+This page has moved to [[ikiwiki/openid|ikiwiki/openid]]. Please update your
+links, as this redirection page will be removed in a future ikiwiki
+release.
diff --git a/underlays/basewiki/pagespec.mdwn b/underlays/basewiki/pagespec.mdwn
deleted file mode 120000
index b5eb02e04..000000000
--- a/underlays/basewiki/pagespec.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/pagespec.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/pagespec.mdwn b/underlays/basewiki/pagespec.mdwn
new file mode 100644
index 000000000..f42f41742
--- /dev/null
+++ b/underlays/basewiki/pagespec.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/pagespec delay=10]]
+
+This page has moved to [[ikiwiki/pagespec|ikiwiki/pagespec]]. Please update
+your links, as this redirection page will be removed in a future ikiwiki
+release.
diff --git a/underlays/basewiki/preprocessordirective.mdwn b/underlays/basewiki/preprocessordirective.mdwn
deleted file mode 120000
index 4b45d4966..000000000
--- a/underlays/basewiki/preprocessordirective.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/preprocessordirective.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/preprocessordirective.mdwn b/underlays/basewiki/preprocessordirective.mdwn
new file mode 100644
index 000000000..b0876ffe5
--- /dev/null
+++ b/underlays/basewiki/preprocessordirective.mdwn
@@ -0,0 +1,6 @@
+[[meta redir=ikiwiki/preprocessordirective delay=10]]
+
+This page has moved to
+[[ikiwiki/preprocessordirective|ikiwiki/preprocessordirective]]. Please
+update your links, as this redirection page will be removed in a future
+ikiwiki release.
diff --git a/underlays/basewiki/subpage b/underlays/basewiki/subpage
deleted file mode 120000
index a22701f64..000000000
--- a/underlays/basewiki/subpage
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/subpage
\ No newline at end of file
diff --git a/underlays/basewiki/subpage.mdwn b/underlays/basewiki/subpage.mdwn
deleted file mode 120000
index 6c225fc92..000000000
--- a/underlays/basewiki/subpage.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/subpage.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/subpage.mdwn b/underlays/basewiki/subpage.mdwn
new file mode 100644
index 000000000..ac24a6fed
--- /dev/null
+++ b/underlays/basewiki/subpage.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/subpage delay=10]]
+
+This page has moved to [[ikiwiki/subpage|ikiwiki/subpage]]. Please update your
+links, as this redirection page will be removed in a future ikiwiki
+release.
diff --git a/underlays/basewiki/wikilink.mdwn b/underlays/basewiki/wikilink.mdwn
deleted file mode 120000
index 146ac42bb..000000000
--- a/underlays/basewiki/wikilink.mdwn
+++ /dev/null
@@ -1 +0,0 @@
-../../doc/wikilink.mdwn
\ No newline at end of file
diff --git a/underlays/basewiki/wikilink.mdwn b/underlays/basewiki/wikilink.mdwn
new file mode 100644
index 000000000..c0c22aeae
--- /dev/null
+++ b/underlays/basewiki/wikilink.mdwn
@@ -0,0 +1,5 @@
+[[meta redir=ikiwiki/wikilink delay=10]]
+
+This page has moved to [[ikiwiki/wikilink|ikiwiki/wikilink]]. Please update
+your links, as this redirection page will be removed in a future ikiwiki
+release.