aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--winsup/utils/ChangeLog6
-rw-r--r--winsup/utils/setfacl.c31
2 files changed, 28 insertions, 9 deletions
diff --git a/winsup/utils/ChangeLog b/winsup/utils/ChangeLog
index 43b4638..9078823 100644
--- a/winsup/utils/ChangeLog
+++ b/winsup/utils/ChangeLog
@@ -1,5 +1,11 @@
2015-12-21 Corinna Vinschen <corinna@vinschen.de>
+ * setfacl.cc (delace): New helper function to delete a single ACE.
+ (delacl): Call delace.
+ (modacl): Ditto, if entry is supposed to get deleted. Align comments.
+
+2015-12-21 Corinna Vinschen <corinna@vinschen.de>
+
* setfacl.cc (modacl): Move recomputing mask into new function.
(check_got_mask): New function checking if mask is in input.
(recompute_mask): New function to recompute mask.
diff --git a/winsup/utils/setfacl.c b/winsup/utils/setfacl.c
index 75b5120..3169e63 100644
--- a/winsup/utils/setfacl.c
+++ b/winsup/utils/setfacl.c
@@ -242,6 +242,17 @@ searchace (aclent_t *aclp, int nentries, int type, int id)
}
int
+delace (aclent_t *tgt, int tcnt, int t)
+{
+ int i;
+
+ for (i = t + 1; i < tcnt; ++i)
+ tgt[i - 1] = tgt[i];
+ --tcnt;
+ return tcnt;
+}
+
+int
delacl (aclent_t *tgt, int tcnt, aclent_t *src, int scnt)
{
int t, s, i;
@@ -253,11 +264,7 @@ delacl (aclent_t *tgt, int tcnt, aclent_t *src, int scnt)
if (t < 0)
return -1;
if (t < tcnt)
- {
- for (i = t + 1; i < tcnt; ++i)
- tgt[i - 1] = tgt[i];
- --tcnt;
- }
+ tcnt = delace (tgt, tcnt, t);
}
return tcnt;
}
@@ -267,16 +274,22 @@ modacl (aclent_t *tgt, int tcnt, aclent_t *src, int scnt)
{
int t, s;
- /* Replace or add given acl entries. */
+ /* Delete, replace or add given acl entries. */
for (s = 0; s < scnt; ++s)
{
t = searchace (tgt, MAX_ACL_ENTRIES, src[s].a_type,
(src[s].a_type & (USER | GROUP)) ? src[s].a_id : -1);
if (t < 0)
return -1;
- tgt[t] = src[s];
- if (t >= tcnt)
- ++tcnt;
+ /* ILLEGAL_MODE means "delete". */
+ if (src[s].a_perm == ILLEGAL_MODE && t < tcnt)
+ tcnt = delace (tgt, tcnt, t);
+ else
+ {
+ tgt[t] = src[s];
+ if (t >= tcnt)
+ ++tcnt;
+ }
}
return tcnt;
}