#pragma prototyped
#if defined(__STDPP__directive) && defined(__STDPP__hide)
__STDPP__directive pragma pp:hide getpwnam getpwuid
#else
#define getpwnam ______getpwnam
#define getpwuid ______getpwuid
#endif
#include <ast.h>
#include <cdt.h>
#include <pwd.h>
#if defined(__STDPP__directive) && defined(__STDPP__hide)
__STDPP__directive pragma pp:nohide getpwnam getpwuid
#else
#undef getpwnam
#undef getpwuid
#endif
extern struct passwd* getpwnam(const char*);
extern struct passwd* getpwuid(uid_t);
typedef struct Id_s
{
Dtlink_t link;
int id;
char name[1];
} Id_t;
int
struid(const char* name)
{
register Id_t* ip;
register struct passwd* pw;
int id;
char* e;
static Dt_t* dict;
static Dtdisc_t disc;
if (!dict)
{
disc.key = offsetof(Id_t, name);
dict = dtopen(&disc, Dthash);
}
else if (ip = (Id_t*)dtmatch(dict, name))
return ip->id;
if (pw = getpwnam(name))
id = pw->pw_uid;
else
{
id = strtol(name, &e, 0);
#if _WINIX
if (!*e)
{
if (!getpwuid(id))
id = -1;
}
else if (streq(name, "root") && (pw = getpwnam("Administrator")))
id = pw->pw_uid;
else
id = -1;
#else
if (*e || !getpwuid(id))
id = -1;
#endif
}
if (dict && (ip = newof(0, Id_t, 1, strlen(name))))
{
strcpy(ip->name, name);
ip->id = id >= 0 ? id : -2;
dtinsert(dict, ip);
}
return id;
}