As documented in [[plugins/write]], the current renamepage hook is
heavily oriented towards updating links in pages' content: it is run
once per page linking to the renamed page.
That's fine, but it can't be used to trigger more general actions on
page rename. E.g. it won't be run at all if the page being renamed is
an orphan one.
This is a real issue for the [[plugins/contrib/po]] development: what
I'm about to achieve is:
- when a master page is renamed, the plugin takes notice of it (using
the
rename hook), and later renames the translation pages
accordingly (in the change hook)
- when a master page is deleted, the plugin deletes its translations
(using the
delete hook)
With the current renamepage hook behavior, combining these two goals
has an annoying drawback: a plugin can't notice an orphan master page
has been renamed, so instead of renaming (and preserving) its
translations, it considers the oldpage as deleted, and deletes its
translations. Game over.
It may seem like a corner case, but I want to be very careful when
deleting files automatically in srcdir , which is not always under
version control.
As a sad workaround, I can still disable any deletion in srcdir
when it is not under version control. But I think ikiwiki deserves
a global renamepage hook that would be run once per rename
operation.
My proposal is thus:
- keep the documented
renamepage hook as it is
- use something inspired by the trick
preprocess uses: when hook
is passed an optional "global" parameter, set to a true value, the
declared renamepage hook is run once per rename operation, and is
passed named parameters: src , srcfile , dest and destfile .
I'm of course volunteering to implement this, or anything related that
would solve my problem. Hmmm? --[[intrigeri]]
I think it would be better to have a different hook that is called for
renames, since the two hook actions are very different (unlike the
preprocess hook, which does a very similar thing in scan mode).
Just calling it rename seems like a reasonable name, by analogy with
the delete and change hooks.
It might make sense to rename renamepage to renamelink to make it
clearer what it does. (I'm not very worried about this breaking things, at
this point.) --[[Joey]]
In my po branch, I renamed renamepage to renamelink , and
created a rename hook that is passed a reference to @torename .
--[[intrigeri]]
|