Pour compléter la réponse, sous Linux, ce qui suit peut être utilisé (j'ai testé sur Ubuntu
):
#include <sys/types.h>
#include <pwd.h>
#include <grp.h>
void do_chown (const char *file_path,
const char *user_name,
const char *group_name)
{
uid_t uid;
gid_t gid;
struct passwd *pwd;
struct group *grp;
pwd = getpwnam(user_name);
if (pwd == NULL) {
die("Failed to get uid");
}
uid = pwd->pw_uid;
grp = getgrnam(group_name);
if (grp == NULL) {
die("Failed to get gid");
}
gid = grp->gr_gid;
if (chown(file_path, uid, gid) == -1) {
die("chown fail");
}
}
Vous pouvez utiliser le chmod
, fchmodat
et/ou fchmod
appels système. Tous les trois sont situés au <sys/stat.h>
.
Pour la propriété, il y a chown
et fchownat
, tous deux en <unistd.h>
.