Xinqi Bao's Git

Remove initialization to 0 for static vars
[slstatus.git] / components / temperature.c
index a5df012..32eb691 100644 (file)
@@ -1,45 +1,46 @@
 /* See LICENSE file for copyright and license details. */
-#include <errno.h>
-#include <stdio.h>
-#include <string.h>
-#if defined(__OpenBSD__)
-#include <sys/sysctl.h>
-#include <sys/time.h>
-#include <sys/sensors.h>
-#endif
+#include <stddef.h>
 
 #include "../util.h"
 
 #if defined(__linux__)
-const char *
-temp(const char *file)
-{
-       int temp;
-
-       return (pscanf(file, "%d", &temp) == 1) ?
-              bprintf("%d", temp / 1000) : NULL;
-}
-#elif defined(__OpenBSD__)
-const char *
-temp(const char *null)
-{
-       int mib[5];
-       size_t size;
-       struct sensor temp;
-
-       mib[0] = CTL_HW;
-       mib[1] = HW_SENSORS;
-       mib[2] = 0; /* cpu0 */
-       mib[3] = SENSOR_TEMP;
-       mib[4] = 0; /* temp0 */
-
-       size = sizeof(temp);
-
-       if (sysctl(mib, 5, &temp, &sz, NULL, 0) == -1) {
-               fprintf(stderr, "sysctl 'SENSOR_TEMP': %s\n", strerror(errno));
-               return NULL;
+       const char *
+       temp(const char *file)
+       {
+               int temp;
+
+               return (pscanf(file, "%d", &temp) == 1) ?
+                      bprintf("%d°C", temp / 1000) : NULL;
        }
+#elif defined(__OpenBSD__)
+       #include <errno.h>
+       #include <stdio.h>
+       #include <string.h>
+       #include <sys/time.h> /* before <sys/sensors.h> for struct timeval */
+       #include <sys/sensors.h>
+       #include <sys/sysctl.h>
+
+       const char *
+       temp(const char *unused)
+       {
+               int mib[5];
+               size_t size;
+               struct sensor temp;
 
-       return bprintf("%d", (temp.value - 273150000) / 1000000); /* kelvin to celsius */
-}
+               mib[0] = CTL_HW;
+               mib[1] = HW_SENSORS;
+               mib[2] = 0; /* cpu0 */
+               mib[3] = SENSOR_TEMP;
+               mib[4] = 0; /* temp0 */
+
+               size = sizeof(temp);
+
+               if (sysctl(mib, 5, &temp, &size, NULL, 0) < 0) {
+                       warn("sysctl 'SENSOR_TEMP':");
+                       return NULL;
+               }
+
+               /* kelvin to celsius */
+               return bprintf("%d°C", (temp.value - 273150000) / 1000000);
+       }
 #endif