[[!meta title="Thomas Schwinge"]] # Thomas Schwinge <tschwinge@gnu.org> <http://www.thomas.schwinge.homeip.net/> I have converted the [GNU Hurd](http://www.gnu.org/software/hurd/)'s previous web pages and previous wiki pages to a *[[ikiwiki]]* system; and all that while preserving the previous content's history, which was stored in a CVS repository for the HTML web pages and a TWiki RCS repository for the wiki; see <http://www.gnu.org/software/hurd/colophon.html>. # Issues to Work On ## Stability of Separate Builds The goal is that separate builds of the same source files should yield the exactly same HTML code (of course, except for changes due to differences in Markdown rendering, for example). * Timestamps -- [[forum/ikiwiki__39__s_notion_of_time]], [[forum/How_does_ikiwiki_remember_times__63__]] Git set's the current *mtime* when checking out files. The result is that <http://www.gnu.org/software/hurd/contact_us.html> and <http://www.bddebian.com:8888/~hurd-web/contact_us/> show different *Last edited* timestamps. This can either be solved by adding a facility to Git to set the checked-out files' *mtime* according to the *AuthorDate* / *CommitDate* (which one...), or doing that retroactively with the <http://www.gnu.org/software/hurd/set_mtimes> script before building, or with a ikiwiki-internal solution. * HTML character entities <http://www.gnu.org/software/hurd/purify_html> ### \[[!map]] behavior The \[[!map]] on, for example, <http://www.gnu.org/software/hurd/tag/open_issue_hurd.html>, should not show the complete hierarchy of pages, but instead just the pages that actually *do* contain the \[[!tag open_issue_hurd]]. > `tagged(open_issue_hurd)` in its pagespec should do that. --[[Joey]] >> Well, that's exactly what this page contains: \[[!map >> pages="tagged(open_issue_hurd) and !open_issues and !*/discussion" >> show=title]] >> >> This is currently rendered as can be seen on >> <http://www.gnu.org/software/hurd/tag/open_issue_hurd.html>, but I'd imagine >> it to be rendered by **only** linking to the pages that actually do contain >> the tag, (**only** the outer leaf ones, which are *capturing stdout and >> stderr*, *ramdisk*, *syncfs*, ...; but **not** to *hurd*, *debugging*, >> *translator*, *libstore*, *examples*, ...). Otherwise, the way it's being >> rendered at the moment, it appears to the reader that *hurd*, *debugging*, >> *translator*, *libstore*, *examples*, ... were all tagged, too, and not only >> the outer ones. ## Anchors -- [[ikiwiki/wikilink/discussion]] ## Default Content for Meta Values -- [[plugins/contrib/default_content_for___42__copyright__42___and___42__license__42__]] This will decrease to be relevant, as we're going to add copyright and licensing headers to every single file. ## [[bugs/img vs align]] ## Texinfo -- [[plugins/contrib/texinfo]] Not very important. Have to consider external commands / files / security (see [[plugins/teximg]] source code)? ## Shortcuts -- [[plugins/shortcut/discussion]] ## \[[!meta redir]] -- [[todo/__42__forward__42__ing_functionality_for_the_meta_plugin]] Implement a checker that makes sure that no pages that use \[[!meta redir]] redirect to another page (and are thus considered legacy pages for providing stable URLs, for example) are linked to from other wiki pages. This is useful w.r.t. backlinks. Alternative, the backlinks to the \[[!meta redir]]-using pages could perhaps be passed on to the referred-to page? > I found that backlinks was an easy way to find such links to such pages. > (Although the redirection made it hard to see the backlinks!) --[[Joey]] ## \[[!meta redir]] -- tell what's going on Add functionality that a text like *this page's content has moved to [new page]; in a few seconds you'll be redirected thither* is displayed on every page that uses \[[!meta redir]]. ## Sendmail -- [[todo/passwordauth:_sendmail_interface]] ## [[bugs/Broken Parentlinks]] ## Modifying [[plugins/inline]] for showing only an *appetizer* Currently ikiwiki's inline plugin will either show the full page or nothing of it. Often that's too much. One can manually use the [[plugins/toggle]] plugin -- see the *News* section on <http://www.gnu.org/software/hurd/>. Adding a new mode to the inline plugin to only show an *appetizer* ending with *... (read on)* after a customizable amount of characters (or lines) would be a another possibility. The *... (read on)* would then either toggle the full content being displayed or link to the complete page. > You're looking for [[plugins/more]] (or possibly a way to do that automatically, > I suppose. --[[Joey]] ## Prefix For the HTML Title The title of each page (as in `<html><head><title>`...) should be prefixed with *GNU Project - GNU Hurd -*. We can either do this directly in `page.tmpl`, or create a way to modify the `TITLE` template variable suitably. ## [[plugins/inline]] feedfile option Not that important. Git commit b67632cdcdd333cf0a88d03c0f7e6e62921f32c3. This would be nice to have even when *not* using *usedirs*. Might involve issues as discussed in *N-to-M Mapping of Input and Output Files* on [[plugins/contrib/texinfo]]. ## Unverified -- these may be bugs, but have yet to be verified * ikiwiki doesn't change its internal database when \[[!meta date]] / \[[!meta updated]] are added / removed, and thusly these meta values are not promulgated in RSS / Atom feeds. > I would rather see this filed as a bug, but FWIW, the problem > is probably that meta does not override the mdate_3339 > template variable used by the atom and rss templates. > (Meta does store ctime directly in the ikiwiki database, but cannot > store mtime in \%pagemtime because it would mess up detection of when > actual file mtimes change.) --[[Joey]] * Complicated issue w.r.t. *no text was copied in this page* ([[plugins/cutpaste]]) in RSS feed (only; not Atom?) under some conditions (refresh only, but not rebuild?). Perhaps missing to read in / parse some files? [[Reported|bugs/Error:_no_text_was_copied_in_this_page_--_missing_page_dependencies]]. * [[plugins/recentchanges]] * Creates non-existing links to changes. * Invalid *directory link* with `--usedirs`. * Doesn't honor `$timeformat`. * Does create `recentchangees.*` files even if that is overridden.