X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=restore.pl;h=ad1f5949840fc1ef9caa20e7a4816d6b6fff1e36;hb=79c9c740d9b78e357dd66cb9a4b77d03a5076f3b;hp=309fb738677988678decb3aaa4451908b5419217;hpb=9f8f2a00b54a80d1563288bf11556cbc15a07c50;p=cumulus.git diff --git a/restore.pl b/restore.pl index 309fb73..ad1f594 100755 --- a/restore.pl +++ b/restore.pl @@ -140,6 +140,15 @@ sub load_ref { # iterate_objects is a helper function used to iterate over the set of object # references that contain the file data for a regular file. +sub parse_int { + my $str = shift; + if ($str =~ /^0/) { + return oct($str); + } else { + return $str + 0; + } +} + sub uri_decode { my $str = shift; $str =~ s/%([0-9a-f]{2})/chr(hex($1))/ge; @@ -197,6 +206,8 @@ sub unpack_file { die "File $name is missing checksum or size"; } + $info{size} = parse_int($info{size}); + # Open the file to be recreated. The data will be written out by the call # to iterate_objects. open FILE, ">", "$DEST_DIR/$name" @@ -274,17 +285,17 @@ sub process_file { my $gid = -1; if (defined $info{user}) { my @items = split /\s/, $info{user}; - $uid = $items[0] + 0 if exists $items[0]; + $uid = parse_int($items[0]) if exists $items[0]; } if (defined $info{group}) { my @items = split /\s/, $info{group}; - $gid = $items[0] + 0 if exists $items[0]; + $gid = parse_int($items[0]) if exists $items[0]; } chown $uid, $gid, $dest or warn "Unable to change ownership for $dest"; if (defined $info{mode}) { - my $mode = $info{mode}; + my $mode = parse_int($info{mode}); chmod $mode, $dest or warn "Unable to change permissions for $dest"; }