123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 |
- #!/usr/bin/env perl
- use strict;
- use v5.10;
- # ====================[ smarttitles.pl ]====================
- =head1 NAME
- smarttitles - An Oddmuse module for embedding user-readable titles and subtitles
- for a page in the content for that page.
- =head1 INSTALLATION
- smarttitles is easily installable: move this file into the B<wiki/modules/>
- directory of your Oddmuse Wiki.
- =cut
- AddModuleDescription('smarttitles.pl', 'Smarttitles Extension');
- our (%Page, $SiteName, @MyRules, %RuleOrder);
- # ....................{ CONFIGURATION }....................
- =head1 CONFIGURATION
- smarttitles is easily configurable; set these variables in the B<wiki/config.pl>
- file for your Oddmuse Wiki.
- =cut
- our ($SmartTitlesBrowserTitle,
- $SmartTitlesBrowserTitleWithoutSubtitle,
- $SmartTitlesSubUrlText);
- =head2 $SmartTitlesBrowserTitle
- The browser title for pages having a subtitle. The browser title is the string
- displayed in your browser's titlebar for each page.
- smarttitles performs variable substitution on this string, as follows:
- =over
- =item The first '%s' in this string, if present, is replaced with the Wiki's
- C<$SiteName>.
- =item The second '%s' in this string, if present, is replaced with this Wiki
- page's title.
- =item The third '%s' in this string, if present, is replaced with this Wiki
- page's subtitle.
- =back
- =cut
- $SmartTitlesBrowserTitle = '%s: %s (%s)';
- =head2 $SmartTitlesBrowserTitleWithoutSubtitle
- The browser title for pages lacking a subtitle.
- smarttitles performs variable substitution on this string, as follows:
- =over
- =item The first '%s' in this string, if present, is replaced with the Wiki's
- C<$SiteName>.
- =item The second '%s' in this string, if present, is replaced with this Wiki
- page's title.
- =back
- =cut
- $SmartTitlesBrowserTitleWithoutSubtitle = '%s: %s';
- $SmartTitlesSubUrlText = undef;
- # ....................{ RULES }....................
- push(@MyRules, \&SmartTitlesRule);
- # "#TITLE" and "#SUBTITLE" conflict with Creole-style numbered lists, and
- # "poetry.pl"-style poetry blocks; as such, rules filtering these strings should
- # be applied before rules filtering Creole- and "poetry.pl"-style strings. As it
- # is likely that these rules, also, conflict with other Oddmuse markup modules,
- # this module requests that these rules be applied with high priority -
- # presumably before another module is permitted to muck them up.
- $RuleOrder{\&SmartTitlesRule} = -50;
- =head2 SmartTitlesRule
- Strips "#TITLE ...\n" and "#SUBTITLE ...\n" text from the current Wiki page.
- Since GetHeaderSmartTitles() already parses this text, it serves little use past
- that point.
- =cut
- sub SmartTitlesRule {
- return '' if m/\G (^|\n)? \#(TITLE|SUBTITLE|SUBURL) [ \t]+ (.*?) \s*(\n+|$) /cgx;
- return;
- }
- # ....................{ FUNCTIONS }....................
- *GetHeaderSmartTitlesOld = \&GetHeader;
- *GetHeader = \&GetHeaderSmartTitles;
- =head2 GetSmartTitles
- Returns the title and subtitle for this page. (Presumably, this page has been
- opened with an earlier call to C<OpenPage()>.)
- This function is provided as a separate subroutine so as to permit other
- extensions (namely, hibernal) to obtain the title and subtitle for pages.
- =cut
- sub GetSmartTitles {
- my ($title) = $Page{text} =~ m/ (?:^|\n) \#TITLE [ \t]+ (.*?) \s*\n+ /x;
- my ($subtitle) = $Page{text} =~ m/ (?:^|\n) \#SUBTITLE [ \t]+ (.*?) \s*\n+ /x;
- my ($suburl) = $Page{text} =~ m/ (?:^|\n) \#SUBURL [ \t]+ (.*?) \s*\n+ /x;
- return ($title, $subtitle, $suburl);
- }
- =head2 GetHeaderSmartTitles
- Changes the passed page's HTML header to reflect any "#TITLE" or "#SUBTITLE"
- within that passed page's Wiki content.
- =cut
- sub GetHeaderSmartTitles {
- my ($page_name, $title, undef, undef, undef, undef, $subtitle) = @_;
- my ($smart_title, $smart_subtitle, $smart_suburl);
- my $html_header = GetHeaderSmartTitlesOld(@_);
- if ($page_name) {
- OpenPage($page_name);
- $title = NormalToFree($title);
- ($smart_title, $smart_subtitle, $smart_suburl) = GetSmartTitles();
- }
- $smart_title ||= $title;
- $smart_subtitle ||= $subtitle;
- $smart_title = QuoteHtml($smart_title);
- $smart_subtitle = QuoteHtml($smart_subtitle);
- $smart_suburl = QuoteHtml($smart_suburl);
- $html_header =~ s~\Q>$title</a>\E~>$smart_title</a>~g;
- if ($smart_subtitle) {
- my $subtitlehtml = '<p class="subtitle">' . $smart_subtitle;
- if ($smart_suburl) {
- # ApplyRules is too much, we just want links. LinkRules should be enough.
- # $subtitlehtml .= ' ' . ToString(sub { ApplyRules($smart_suburl, 1, 1) }) if $smart_suburl;
- $_ = $smart_suburl;
- $subtitlehtml .= ' ' . ToString(sub {LinkRules(1)});
- }
- $html_header =~ s~\Q</h1>\E~</h1>$subtitlehtml</p>~;
- }
- my $smart_header;
- if ($SiteName eq $smart_title) { # show "MySite: subtitle" instead of "MySite: MySite (subtitle)"
- $smart_header = $smart_subtitle
- ? sprintf($SmartTitlesBrowserTitleWithoutSubtitle, $SiteName, $smart_subtitle)
- : $SiteName;
- } else {
- $smart_header = $smart_subtitle
- ? sprintf($SmartTitlesBrowserTitle, $SiteName, $smart_title, $smart_subtitle)
- : sprintf($SmartTitlesBrowserTitleWithoutSubtitle, $SiteName, $smart_title);
- }
- $html_header =~ s~\<title\>.*?\<\/title\>~<title>$smart_header</title>~;
- return $html_header;
- }
- =head1 COPYRIGHT AND LICENSE
- The information below applies to everything in this distribution,
- except where noted.
- Copyright 2014-2015 Alex-Daniel Jakimenko <alex.jakimenko@gmail.com>
- Copyleft 2008 by B.w.Curry <http://www.raiazome.com>.
- Copyright 2006 by Charles Mauch <mailto://cmauch@gmail.com>.
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 3 of the License, or
- (at your option) any later version.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with this program. If not, see <http://www.gnu.org/licenses/>.
- =cut
|