The source file `foo/bar.mdwn` or `foo/bar.html` generates the
page `foo/bar/index.html`, but the links to the page appear
as "`foo/bar/`".  This is fine (and recommended) for pages
served by an http server, but it doesn't work when browsing
the pages directly using `file:` URL.  The latter might be
desirable when testing pages before upload, or if you want to
read pages when off-line without access to a web server.

Here is a JavaScript "`onload`" script which fixes the URLs
if the `local.protocol` isn't `http` or `https`:

	function fixLinks() {
	  var scheme = location.protocol;
 	 if (scheme=="http:" || scheme=="https:") return;
 	 var links = document.getElementsByTagName("a");
	  for (var i = links.length; --i >= 0; ) {
 	   var link = links[i];
	    var href = link.href;
	    var hlen = href.length;
 	   if (hlen > 0 && link.protocol==scheme && href.charAt(hlen-1) == "/")
 	     links[i].href = href + "index.html";
	  }
	}

This can be placed in `page.tmpl`:

	<html>
	<head>
	<script language="JavaScript">
	function fixLinks() {
	...
	}
	</script>
	</head>
	<body onload="javascript:fixLinks();">
	...
	</html>

This script has not been extensively tested.

---

A version that handles anchors:


	function fixLinks() {
	  var scheme = location.protocol;
	  if (scheme != "file:") return;
	  var links = document.getElementsByTagName("a");
	  for (var i = links.length; --i >= 0; ) {
	    var link = links[i];
	    var href = link.href;
	    var anchor = "";
	    var anchorIndex = href.indexOf("#");
	    if (anchorIndex != -1) {
	      anchor = href.substring(anchorIndex);
	      href = href.substring(0, anchorIndex);
	    };
	    var hlen = href.length;
	    if (hlen > 0 && link.protocol==scheme && href.charAt(hlen-1) == "/")
	      links[i].href = href + "index.html" + anchor;
	  }
	}