mirror of https://github.com/jimsalterjrs/sanoid
Merge pull request #809 from phreaker0/handle-same-second-bookmarks
support bookmarks which are taken in the same second
This commit is contained in:
commit
f8ff5ab0c2
20
syncoid
20
syncoid
|
|
@ -1753,6 +1753,7 @@ sub getbookmarks() {
|
||||||
# as though each were an entirely separate get command.
|
# as though each were an entirely separate get command.
|
||||||
|
|
||||||
my $lastguid;
|
my $lastguid;
|
||||||
|
my %creationtimes=();
|
||||||
|
|
||||||
foreach my $line (@rawbookmarks) {
|
foreach my $line (@rawbookmarks) {
|
||||||
# only import bookmark guids, creation from the specified filesystem
|
# only import bookmark guids, creation from the specified filesystem
|
||||||
|
|
@ -1769,7 +1770,24 @@ sub getbookmarks() {
|
||||||
$creation =~ s/^.*\tcreation\t*(\d*).*/$1/;
|
$creation =~ s/^.*\tcreation\t*(\d*).*/$1/;
|
||||||
my $bookmark = $line;
|
my $bookmark = $line;
|
||||||
$bookmark =~ s/^.*\#(.*)\tcreation.*$/$1/;
|
$bookmark =~ s/^.*\#(.*)\tcreation.*$/$1/;
|
||||||
$bookmarks{$lastguid}{'creation'}=$creation . "000";
|
|
||||||
|
# the accuracy of the creation timestamp is only for a second, but
|
||||||
|
# bookmarks in the same second are possible. The list command
|
||||||
|
# has an ordered output so we append another three digit running number
|
||||||
|
# to the creation timestamp and make sure those are ordered correctly
|
||||||
|
# for bookmarks with the same creation timestamp
|
||||||
|
my $counter = 0;
|
||||||
|
my $creationsuffix;
|
||||||
|
while ($counter < 999) {
|
||||||
|
$creationsuffix = sprintf("%s%03d", $creation, $counter);
|
||||||
|
if (!defined $creationtimes{$creationsuffix}) {
|
||||||
|
$creationtimes{$creationsuffix} = 1;
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
$counter += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$bookmarks{$lastguid}{'creation'}=$creationsuffix;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue