]> sipb.mit.edu Git - ikiwiki.git/blobdiff - IkiWiki/Render.pm
fix other cases of unicode mixing issue
[ikiwiki.git] / IkiWiki / Render.pm
index 0e7aa9a48a2bd5ddb4267ca948e3f6eba6ba121a..740bb52b0fc6d9ea1797a08080a273f5fb3701f6 100644 (file)
@@ -292,11 +292,16 @@ sub find_src_files () {
        eval q{use File::Find};
        error($@) if $@;
 
+       eval q{use Cwd};
+       die $@ if $@;
+       my $origdir=getcwd();
+       my $abssrcdir=Cwd::abs_path($config{srcdir});
+
        my ($page, $underlay);
        my $helper=sub {
                my $file=decode_utf8($_);
                return if -l $file || -d _;
-               $file=~s/^\Q.\/\E//;
+               $file=~s/^\.\///;
                return if ! length $file;
                $page = pagename($file);
                if (! exists $pagesources{$page} &&
@@ -313,7 +318,7 @@ sub find_src_files () {
        
                if ($underlay) {
                        # avoid underlaydir override attacks; see security.mdwn
-                       if (! -l "$config{srcdir}/$f" && ! -e _) {
+                       if (! -l "$abssrcdir/$f" && ! -e _) {
                                if (! $pages{$page}) {
                                        push @files, $f;
                                        $pages{$page}=1;
@@ -329,10 +334,6 @@ sub find_src_files () {
                }
        };
 
-       eval q{use Cwd};
-       die $@ if $@;
-       my $origdir=getcwd();
-
        chdir($config{srcdir}) || die "chdir: $!";
        find({
                no_chdir => 1,