summaryrefslogtreecommitdiff
path: root/wm/icewm/patches/patch-ab
blob: de1b544a2a66397b066388ad8168f91b2b00f9e5 (plain)
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
59
60
61
62
63
64
65
66
67
68
$NetBSD: patch-ab,v 1.1.1.1 2000/12/12 02:03:48 wiz Exp $

--- src/aapm.cc.orig	Sun Feb 13 10:28:36 2000
+++ src/aapm.cc	Mon Mar  6 22:22:36 2000
@@ -22,11 +22,18 @@
 
 #ifdef CONFIG_APM
 
+#if defined(__NetBSD__)
+#include <sys/ioctl.h>
+#include <machine/apmvar.h>
+#include <fcntl.h>
+#endif
+
 YColor *YApm::apmBg = 0;
 YColor *YApm::apmFg = 0;
 YFont *YApm::apmFont = 0;
 
 void ApmStr(char *s, bool Tool) {
+#ifdef __linux__
     char buf[45];
     int len, i, fd = open("/proc/apm", O_RDONLY);
     char driver[16];
@@ -97,6 +104,44 @@
             strcat(s," - Charging");
         else
             strcat(s,"M");
+#elif defined(__NetBSD__)
+    struct apm_power_info aip;
+    int fd = open(APMDEV, O_RDONLY);
+
+    if (fd == -1) {
+        return;
+    }
+
+    if (ioctl(fd, APM_IOC_GETPOWER, &aip) == -1) {
+        fprintf(stderr, "ioctl failed on APMDEV");
+        return;
+    }
+
+    if (!Tool) {
+        if (taskBarShowApmTime) {
+            if (aip.minutes_left == 0) {
+                sprintf(s, "%02d", aip.battery_life);
+            } else
+                sprintf(s, "%d:%02d", aip.minutes_left/60, aip.minutes_left%60);
+        } else
+            sprintf(s, "%02d", aip.battery_life);
+    } else {
+        sprintf(s, "%d%%", aip.battery_life);
+    }
+
+    if (aip.ac_state == APM_AC_ON)
+        if (Tool)
+            strcat(s," - Power");
+        else
+            strcat(s,"P");
+    if (aip.battery_state == APM_BATT_CHARGING)
+        if (Tool)
+            strcat(s," - Charging");
+        else
+            strcat(s,"M");
+
+    close(fd);
+#endif
 }
 
 YApm::YApm(YWindow *aParent): YWindow(aParent) {