better long filename detection method
Let's just try to write and fall back to a short ugly filename on error.master
parent
d86f248329
commit
45fb0371db
|
@ -614,6 +614,7 @@ sub add_page (@) {
|
|||
# updating an existing post
|
||||
$guid=$guids{$params{guid}};
|
||||
return if $guid->{expired};
|
||||
write_page($feed, $guid, $mtime, \%params);
|
||||
}
|
||||
else {
|
||||
# new post
|
||||
|
@ -640,23 +641,33 @@ sub add_page (@) {
|
|||
$c++
|
||||
}
|
||||
|
||||
# Make sure that the file name isn't too long.
|
||||
# NB: This doesn't check for path length limits.
|
||||
my $max=POSIX::pathconf($config{srcdir}, &POSIX::_PC_NAME_MAX);
|
||||
if (defined $max && length(htmlfn($page).".ikiwiki-new") >= $max) {
|
||||
$guid->{page}=$page;
|
||||
eval { write_page($feed, $guid, $mtime, \%params) };
|
||||
if ($@) {
|
||||
# assume failure was due to a too long filename
|
||||
# (or o
|
||||
$c="";
|
||||
$page=$feed->{dir}."/item";
|
||||
while (exists $IkiWiki::pagecase{lc $page.$c} ||
|
||||
-e $IkiWiki::Plugin::transient::transientdir."/".htmlfn($page.$c) ||
|
||||
|
||||
-e "$config{srcdir}/".htmlfn($page.$c)) {
|
||||
$c++
|
||||
}
|
||||
}
|
||||
|
||||
$guid->{page}=$page;
|
||||
write_page($feed, $guid, $mtime, \%params);
|
||||
}
|
||||
|
||||
debug(sprintf(gettext("creating new page %s"), $page));
|
||||
}
|
||||
}
|
||||
|
||||
sub write_page ($$$$$) {
|
||||
my $feed=shift;
|
||||
my $guid=shift;
|
||||
my $mtime=shift;
|
||||
my %params=%{shift()};
|
||||
|
||||
$guid->{feed}=$feed->{name};
|
||||
|
||||
# To write or not to write? Need to avoid writing unchanged pages
|
||||
|
|
|
@ -35,3 +35,6 @@ It would also appear this abrubtly terminates aggregate processing (if not ikiwi
|
|||
|
||||
>>> Path length seems unlikely, since the max is 4096 there.
|
||||
>>> --[[Joey]]
|
||||
|
||||
>>>> Aggregate now used a "if it crashes, it must be too long" strategy.
|
||||
>>>> [[done]] --[[Joey]]
|
||||
|
|
Loading…
Reference in New Issue