| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
 | --- e_mod_main.c
+++ e_mod_main.c
@@ -4,7 +4,7 @@
 #include <stdlib.h>
 #include <stdint.h>
 #include <sys/types.h>
-#include <utmp.h>
+#include <utmpx.h>
 
 #if TIME_WITH_SYS_TIME
 # include <sys/time.h>
@@ -445,11 +445,7 @@
   struct timeval boottime;
   time_t now;
 
-  FILE *utmp;
-  struct timespec tp;
-  struct utmp ut;
-  char ttybuf[MAXPATHLEN];
-  struct stat st;
+  struct utmpx *utmpstruct;
 #endif
 
   if (!inst)
@@ -498,26 +494,15 @@
   if (ret < 0)
     warn ("getloadavg()");
 # endif
-
-  /* retrive number of active users */
-  utmp = fopen (_PATH_UTMP, "r");
-  if (utmp == NULL)
-    inst->nusers = -1;
-  else
+  inst->nusers = 0;
+  setutxent ();
+  while ((utmpstruct = getutxent ()))
     {
-      for (inst->nusers = 0; fread (&ut, sizeof (ut), 1, utmp);)
-	{
-	  if (ut.ut_name[0] == '\0')
-	    continue;
-	  (void) snprintf (ttybuf, sizeof (ttybuf), "%s%.*s", _PATH_DEV,
-			   UT_LINESIZE, ut.ut_line);
-	  if (stat (ttybuf, &st) != 0)
-	    continue;		/* broken record */
-
-	  inst->nusers++;
-	}
-      fclose (utmp);
+      if ((utmpstruct->ut_type == USER_PROCESS) &&
+	  (utmpstruct->ut_user[0] != '\0'))
+	inst->nusers++;
     }
+  endutxent ();
 #else /* unsupported */
   inst->uptime = -1;
   inst->nusers = -1;
 |