Revision [6613]
This is an old revision of FreeLinks made by SteveB on 2005-03-08 18:02:05.
Free links
This code change allows page names to have spaces in. URL's are then in this format when you have mod_rewrite ( i havnt tested it without mod_rewrite - i suspect it would fall over so any solution to this would be good) http://www.domain.com/Page+Name+here. That would go to a page called 'Page Name here'.This also changes the format for forced links. Because pages can now have spaces obviouly the old method of the seperator being a space wont work any more. So on JavaWoman JavaWoman's suggestion i changed it to a | (pipe). the new format after these changes for a forced link is [[name here|link text here]] or [[name here]]
in wikka.php find:
- if (preg_match("/^([A-ZÄÖÜ][A-Za-zÄÖÜßäöü]+)[:](\S*)$/", $tag, $matches)) # before the : should be a WikiName; anything after can be (nearly) anything that's allowed in a URL
and replace it with:
- // Changed so a WikiName can have spaces in.
- if (preg_match("/^([A-ZÄÖÜ][A-Z a-zÄÖÜßäöü]+)[:](\S*)$/", $tag, $matches)) # before the : should be a WikiName; anything after can be (nearly) anything that's allowed in a URL
then find:
- // is this a full link? ie, does it contain alpha-numeric characters?
and replace it with:
- // is this a full link? ie, does it contain characters not valid for a wiki page name?
- // changed so that a space is a valid character for a wikiname
and last but not least, find:
- return ($linkedPage ? "<a href=\"".$this->Href($method, $linkedPage['tag'])."\" title=\"$title\">".$text."</a>" : "<a class=\"missingpage\" href=\"".$this->Href("edit", $tag)."\" title=\"Create this page\">".$text."</a>");
and replace with:
- // changed so that the tag name is urlencoded. this converts the spaces to +'s to make the URL valid
then in handlers/page/edit.php find
and replace with:
- // changed so the edit handler allows pages with spaces in the names to be created/edited
and the last file to change is formatters/wakka.php.
find:
- else if (preg_match("/^\[\[(\S*)(\s+(.+))?\]\]$/s", $thing, $matches)) # recognize forced links across lines
and replace with:
- // changed so that the seperator for forced links is a | (pipe) and not the first space.
- else if (preg_match("/^\[\[(.+?)(\|(.+))?\]\]$/s", $thing, $matches)) # recognize forced links across lines
i THINK thats all of the changes. let me know what you think, if anything needs to be changed or whatever.
Categories: CategoryUserContributions