diff options
author | Thierry Vignaud <tvignaud@mandriva.org> | 2003-10-20 15:21:54 +0000 |
---|---|---|
committer | Thierry Vignaud <tvignaud@mandriva.org> | 2003-10-20 15:21:54 +0000 |
commit | 3fde3164488e9597a6e2ddc156f9d62d1ac288e5 (patch) | |
tree | 0cd96f9a6605ace66e3a1a3f787c5d8eb791f7f9 | |
parent | 5b3f43ff3bf9f9b49cdcd55c624019f6397478d6 (diff) | |
download | drakx-3fde3164488e9597a6e2ddc156f9d62d1ac288e5.tar drakx-3fde3164488e9597a6e2ddc156f9d62d1ac288e5.tar.gz drakx-3fde3164488e9597a6e2ddc156f9d62d1ac288e5.tar.bz2 drakx-3fde3164488e9597a6e2ddc156f9d62d1ac288e5.tar.xz drakx-3fde3164488e9597a6e2ddc156f9d62d1ac288e5.zip |
un-jonathan-ize()
-rwxr-xr-x | perl-install/standalone/drakperm | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/perl-install/standalone/drakperm b/perl-install/standalone/drakperm index 9b793790e..d5c125105 100755 --- a/perl-install/standalone/drakperm +++ b/perl-install/standalone/drakperm @@ -244,11 +244,7 @@ sub row_setting_dialog { my $browse = new Gtk2::Button(N("browse")); my $file = new Gtk2::Entry; my ($id_box, $usr_check); - my $rght = $model->get($iter, 4) if $iter; - my $s = length($rght) == 4 ? substr($rght,0,1) : 0; - my $user = $s ? substr($rght,1,1) : substr($rght,0,1); - my $group = $s ? substr($rght,2,1) : substr($rght,1,1); - my $other = $s ? substr($rght,3,1) : substr($rght,2,1); + my ($other, $group, $user, $s) = reverse(split(//, $model->get($iter, 4))) if $iter; my @bits = qw(sticky gid suid); my @rights = qw(read write execute); my @owners = qw(user group other); @@ -317,11 +313,9 @@ sub row_setting_dialog { $model->set($iter, 2 => $users->entry->get_text); $model->set($iter, 3 => $groups->entry->get_text); } - $user = ($perms{user}{read}->get_active ? 4 : 0)+($perms{user}{write}->get_active ? 2 : 0)+($perms{user}{execute}->get_active ? 1 : 0); - $group = ($perms{group}{read}->get_active ? 4 : 0)+($perms{group}{write}->get_active ? 2 : 0)+($perms{group}{execute}->get_active ? 1 : 0); - $other = ($perms{other}{read}->get_active ? 4 : 0)+($perms{other}{write}->get_active ? 2 : 0)+($perms{other}{execute}->get_active ? 1 : 0); - my $s = ($sticky->get_active ? 1 : 0) + ($suid->get_active ? 4 : 0) + ($gid->get_active ? 2 : 0); - $model->set($iter, 4 => ($s || '') . $user . $group . $other); + $model->set($iter, 4 => sprintf("%o", eval(join('', "0b", + (map { $perms{$_}->get_active || 0 } reverse @bits), + (map { my $owner = $_;map_index { $perms{$owner}{$_}->get_active || 0 } @rights } @owners))))); $dlg->destroy; $modified++; }); |